Go to the documentation of this file.
4 package com.google.ortools.sat;
9 com.
google.protobuf.ExtensionRegistryLite registry) {
13 com.
google.protobuf.ExtensionRegistry registry) {
15 (
com.
google.protobuf.ExtensionRegistryLite) registry);
17 static final com.
google.protobuf.Descriptors.Descriptor
18 internal_static_operations_research_sat_SatParameters_descriptor;
20 com.
google.protobuf.GeneratedMessageV3.FieldAccessorTable
21 internal_static_operations_research_sat_SatParameters_fieldAccessorTable;
23 public static com.
google.protobuf.Descriptors.FileDescriptor
27 private static com.
google.protobuf.Descriptors.FileDescriptor
30 java.lang.String[] descriptorData = {
31 "\n ortools/sat/sat_parameters.proto\022\027oper" +
32 "ations_research.sat\"\317;\n\rSatParameters\022`\n" +
33 "\030preferred_variable_order\030\001 \001(\01624.operat" +
34 "ions_research.sat.SatParameters.Variable" +
35 "Order:\010IN_ORDER\022Y\n\020initial_polarity\030\002 \001(" +
36 "\0162/.operations_research.sat.SatParameter" +
37 "s.Polarity:\016POLARITY_FALSE\022\036\n\020use_phase_" +
38 "saving\030, \001(\010:\004true\022 \n\025random_polarity_ra" +
39 "tio\030- \001(\001:\0010\022 \n\025random_branches_ratio\030 " +
40 "\001(\001:\0010\022!\n\022use_erwa_heuristic\030K \001(\010:\005fals" +
41 "e\022%\n\032initial_variables_activity\030L \001(\001:\0010" +
42 "\0226\n\'also_bump_variables_in_conflict_reas" +
43 "ons\030M \001(\010:\005false\022o\n\026minimization_algorit" +
44 "hm\030\004 \001(\0162D.operations_research.sat.SatPa" +
45 "rameters.ConflictMinimizationAlgorithm:\t" +
46 "RECURSIVE\022\202\001\n\035binary_minimization_algori" +
47 "thm\030\" \001(\0162@.operations_research.sat.SatP" +
48 "arameters.BinaryMinizationAlgorithm:\031BIN" +
49 "ARY_MINIMIZATION_FIRST\0222\n$subsumption_du" +
50 "ring_conflict_analysis\0308 \001(\010:\004true\022$\n\025cl" +
51 "ause_cleanup_period\030\013 \001(\005:\00510000\022$\n\025clau" +
52 "se_cleanup_target\030\r \001(\005:\00510000\022k\n\031clause" +
53 "_cleanup_protection\030: \001(\01627.operations_r" +
54 "esearch.sat.SatParameters.ClauseProtecti" +
55 "on:\017PROTECTION_NONE\022#\n\030clause_cleanup_lb" +
56 "d_bound\030; \001(\005:\0015\022g\n\027clause_cleanup_order" +
57 "ing\030< \001(\01625.operations_research.sat.SatP" +
58 "arameters.ClauseOrdering:\017CLAUSE_ACTIVIT" +
59 "Y\022!\n\024pb_cleanup_increment\030. \001(\005:\003200\022\035\n\020" +
60 "pb_cleanup_ratio\030/ \001(\001:\0030.5\0224\n(minimize_" +
61 "with_propagation_restart_period\030` \001(\005:\0021" +
62 "0\0225\n\'minimize_with_propagation_num_decis" +
63 "ions\030a \001(\005:\0041000\022$\n\027variable_activity_de" +
64 "cay\030\017 \001(\001:\0030.8\022+\n\033max_variable_activity_" +
65 "value\030\020 \001(\001:\0061e+100\022\037\n\021glucose_max_decay" +
66 "\030\026 \001(\001:\0040.95\022%\n\027glucose_decay_increment\030" +
67 "\027 \001(\001:\0040.01\022,\n\036glucose_decay_increment_p" +
68 "eriod\030\030 \001(\005:\0045000\022$\n\025clause_activity_dec" +
69 "ay\030\021 \001(\001:\0050.999\022(\n\031max_clause_activity_v" +
70 "alue\030\022 \001(\001:\0051e+20\022S\n\022restart_algorithms\030" +
71 "= \003(\01627.operations_research.sat.SatParam" +
72 "eters.RestartAlgorithm\022e\n\032default_restar" +
73 "t_algorithms\030F \001(\t:ALUBY_RESTART,LBD_MOV" +
74 "ING_AVERAGE_RESTART,DL_MOVING_AVERAGE_RE" +
75 "START\022\032\n\016restart_period\030\036 \001(\005:\00250\022\'\n\033res" +
76 "tart_running_window_size\030> \001(\005:\00250\022#\n\030re" +
77 "start_dl_average_ratio\030? \001(\001:\0011\022$\n\031resta" +
78 "rt_lbd_average_ratio\030G \001(\001:\0011\022#\n\024use_blo" +
79 "cking_restart\030@ \001(\010:\005false\022*\n\034blocking_r" +
80 "estart_window_size\030A \001(\005:\0045000\022(\n\033blocki" +
81 "ng_restart_multiplier\030B \001(\001:\0031.4\0220\n%num_" +
82 "conflicts_before_strategy_changes\030D \001(\005:" +
83 "\0010\022)\n\036strategy_change_increase_ratio\030E \001" +
84 "(\001:\0010\022 \n\023max_time_in_seconds\030$ \001(\001:\003inf\022" +
85 "#\n\026max_deterministic_time\030C \001(\001:\003inf\0224\n\027" +
86 "max_number_of_conflicts\030% \001(\003:\023922337203" +
87 "6854775807\022\037\n\020max_memory_in_mb\030( \001(\003:\00510" +
88 "000\022\036\n\022absolute_gap_limit\030\237\001 \001(\001:\0010\022\036\n\022r" +
89 "elative_gap_limit\030\240\001 \001(\001:\0010\022-\n\037treat_bin" +
90 "ary_clauses_separately\030! \001(\010:\004true\022\026\n\013ra" +
91 "ndom_seed\030\037 \001(\005:\0011\022\"\n\023log_search_progres" +
92 "s\030) \001(\010:\005false\022 \n\021use_pb_resolution\030+ \001(" +
93 "\010:\005false\0226\n\'minimize_reduction_during_pb" +
94 "_resolution\0300 \001(\010:\005false\022,\n\036count_assump" +
95 "tion_levels_in_lbd\0301 \001(\010:\004true\022#\n\026presol" +
96 "ve_bve_threshold\0306 \001(\005:\003500\022%\n\032presolve_" +
97 "bve_clause_weight\0307 \001(\005:\0013\0225\n)presolve_p" +
98 "robing_deterministic_time_limit\0309 \001(\001:\0023" +
99 "0\022%\n\027presolve_blocked_clause\030X \001(\010:\004true" +
100 "\022\036\n\020presolve_use_bva\030H \001(\010:\004true\022!\n\026pres" +
101 "olve_bva_threshold\030I \001(\005:\0011\022#\n\027max_preso" +
102 "lve_iterations\030\212\001 \001(\005:\0013\022\037\n\021cp_model_pre" +
103 "solve\030V \001(\010:\004true\0223\n#cp_model_postsolve_" +
104 "with_full_solver\030\242\001 \001(\010:\005false\0220\n$cp_mod" +
105 "el_max_num_presolve_operations\030\227\001 \001(\005:\0010" +
106 "\022!\n\026cp_model_probing_level\030n \001(\005:\0012\022\'\n\031c" +
107 "p_model_use_sat_presolve\030] \001(\010:\004true\022$\n\024" +
108 "use_sat_inprocessing\030\243\001 \001(\010:\005false\022)\n\032ex" +
109 "pand_element_constraints\030\214\001 \001(\010:\004true\022+\n" +
110 "\034expand_automaton_constraints\030\217\001 \001(\010:\004tr" +
111 "ue\022\'\n\030expand_table_constraints\030\236\001 \001(\010:\004t" +
112 "rue\0223\n\033merge_no_overlap_work_limit\030\221\001 \001(" +
113 "\001:\r1000000000000\0220\n\034merge_at_most_one_wo" +
114 "rk_limit\030\222\001 \001(\001:\t100000000\022\'\n\033presolve_s" +
115 "ubstitution_level\030\223\001 \001(\005:\0011\022$\n\026use_optim" +
116 "ization_hints\030# \001(\010:\004true\022\033\n\rminimize_co" +
117 "re\0302 \001(\010:\004true\022!\n\023find_multiple_cores\030T " +
118 "\001(\010:\004true\022 \n\022cover_optimization\030Y \001(\010:\004t" +
119 "rue\022x\n\030max_sat_assumption_order\0303 \001(\0162<." +
120 "operations_research.sat.SatParameters.Ma" +
121 "xSatAssumptionOrder:\030DEFAULT_ASSUMPTION_" +
122 "ORDER\022/\n max_sat_reverse_assumption_orde" +
123 "r\0304 \001(\010:\005false\022|\n\026max_sat_stratification" +
124 "\0305 \001(\0162D.operations_research.sat.SatPara" +
125 "meters.MaxSatStratificationAlgorithm:\026ST" +
126 "RATIFICATION_DESCENT\0227\n)use_precedences_" +
127 "in_disjunctive_constraint\030J \001(\010:\004true\022<\n" +
128 "-use_overload_checker_in_cumulative_cons" +
129 "traint\030N \001(\010:\005false\022B\n3use_timetable_edg" +
130 "e_finding_in_cumulative_constraint\030O \001(\010" +
131 ":\005false\022A\n3use_disjunctive_constraint_in" +
132 "_cumulative_constraint\030P \001(\010:\004true\022\036\n\023li" +
133 "nearization_level\030Z \001(\005:\0011\022!\n\026boolean_en" +
134 "coding_level\030k \001(\005:\0011\022\033\n\014max_num_cuts\030[ " +
135 "\001(\005:\00510000\022*\n\033only_add_cuts_at_level_zer" +
136 "o\030\\ \001(\010:\005false\022 \n\021add_knapsack_cuts\030o \001(" +
137 "\010:\005false\022\031\n\013add_cg_cuts\030u \001(\010:\004true\022\032\n\014a" +
138 "dd_mir_cuts\030x \001(\010:\004true\022!\n\025max_all_diff_" +
139 "cut_size\030\224\001 \001(\005:\0017\022\037\n\020add_lin_max_cuts\030\230" +
140 "\001 \001(\010:\004true\022)\n\034max_integer_rounding_scal" +
141 "ing\030w \001(\005:\003600\022\'\n\031add_lp_constraints_laz" +
142 "ily\030p \001(\010:\004true\0222\n$min_orthogonality_for" +
143 "_lp_constraints\030s \001(\001:\0040.05\022(\n\034max_cut_r" +
144 "ounds_at_level_zero\030\232\001 \001(\005:\0011\022+\n\036max_con" +
145 "secutive_inactive_count\030y \001(\005:\003100\0220\n\032cu" +
146 "t_max_active_count_value\030\233\001 \001(\001:\0131000000" +
147 "0000\022$\n\026cut_active_count_decay\030\234\001 \001(\001:\0030" +
148 ".8\022!\n\022cut_cleanup_target\030\235\001 \001(\005:\0041000\022&\n" +
149 "\032new_constraints_batch_size\030z \001(\005:\00250\022b\n" +
150 "\020search_branching\030R \001(\01626.operations_res" +
151 "earch.sat.SatParameters.SearchBranching:" +
152 "\020AUTOMATIC_SEARCH\022 \n\023hint_conflict_limit" +
153 "\030\231\001 \001(\005:\00210\022)\n\033exploit_integer_lp_soluti" +
154 "on\030^ \001(\010:\004true\022%\n\027exploit_all_lp_solutio" +
155 "n\030t \001(\010:\004true\022%\n\025exploit_best_solution\030\202" +
156 "\001 \001(\010:\005false\022+\n\033exploit_relaxation_solut" +
157 "ion\030\241\001 \001(\010:\005false\022 \n\021exploit_objective\030\203" +
158 "\001 \001(\010:\004true\022\"\n\026probing_period_at_root\030\216\001" +
159 " \001(\003:\0010\022.\n!pseudo_cost_reliability_thres" +
160 "hold\030{ \001(\003:\003100\022!\n\022optimize_with_core\030S " +
161 "\001(\010:\005false\022\'\n\033binary_search_num_conflict" +
162 "s\030c \001(\005:\002-1\022#\n\024optimize_with_max_hs\030U \001(" +
163 "\010:\005false\022&\n\027enumerate_all_solutions\030W \001(" +
164 "\010:\005false\0222\n\"fill_tightened_domains_in_re" +
165 "sponse\030\204\001 \001(\010:\005false\022\'\n\031instantiate_all_" +
166 "variables\030j \001(\010:\004true\0226\n(auto_detect_gre" +
167 "ater_than_at_least_one_of\030_ \001(\010:\004true\022(\n" +
168 "\031stop_after_first_solution\030b \001(\010:\005false\022" +
169 "#\n\023stop_after_presolve\030\225\001 \001(\010:\005false\022\035\n\022" +
170 "num_search_workers\030d \001(\005:\0011\022!\n\021interleav" +
171 "e_search\030\210\001 \001(\010:\005false\022!\n\025interleave_bat" +
172 "ch_size\030\206\001 \001(\005:\0011\0226\n&reduce_memory_usage" +
173 "_in_interleave_mode\030\215\001 \001(\010:\005false\022$\n\026sha" +
174 "re_objective_bounds\030q \001(\010:\004true\022%\n\027share" +
175 "_level_zero_bounds\030r \001(\010:\004true\022\033\n\014use_ln" +
176 "s_only\030e \001(\010:\005false\022.\n\037lns_focus_on_deci" +
177 "sion_variables\030i \001(\010:\005false\022\033\n\014use_rins_" +
178 "lns\030\201\001 \001(\010:\004true\022$\n\024use_feasibility_pump" +
179 "\030\244\001 \001(\010:\005false\022\"\n\022use_relaxation_lns\030\226\001 " +
180 "\001(\010:\005false\022$\n\024diversify_lns_params\030\211\001 \001(" +
181 "\010:\005false\022\037\n\020randomize_search\030g \001(\010:\005fals" +
182 "e\022)\n\036search_randomization_tolerance\030h \001(" +
183 "\003:\0010\022$\n\026use_optional_variables\030l \001(\010:\004tr" +
184 "ue\022!\n\023use_exact_lp_reason\030m \001(\010:\004true\022#\n" +
185 "\023use_branching_in_lp\030\213\001 \001(\010:\005false\022\'\n\027us" +
186 "e_combined_no_overlap\030\205\001 \001(\010:\005false\022\"\n\023c" +
187 "atch_sigint_signal\030\207\001 \001(\010:\004true\022!\n\022use_i" +
188 "mplied_bounds\030\220\001 \001(\010:\004true\022\037\n\rmip_max_bo" +
189 "und\030| \001(\001:\01010000000\022\032\n\017mip_var_scaling\030}" +
190 " \001(\001:\0011\022#\n\024mip_wanted_precision\030~ \001(\001:\0051" +
191 "e-06\022%\n\031mip_max_activity_exponent\030\177 \001(\005:" +
192 "\00253\022$\n\023mip_check_precision\030\200\001 \001(\001:\0060.000" +
193 "1\"H\n\rVariableOrder\022\014\n\010IN_ORDER\020\000\022\024\n\020IN_R" +
194 "EVERSE_ORDER\020\001\022\023\n\017IN_RANDOM_ORDER\020\002\"\206\001\n\010" +
195 "Polarity\022\021\n\rPOLARITY_TRUE\020\000\022\022\n\016POLARITY_" +
196 "FALSE\020\001\022\023\n\017POLARITY_RANDOM\020\002\022\032\n\026POLARITY" +
197 "_WEIGHTED_SIGN\020\003\022\"\n\036POLARITY_REVERSE_WEI" +
198 "GHTED_SIGN\020\004\"V\n\035ConflictMinimizationAlgo" +
199 "rithm\022\010\n\004NONE\020\000\022\n\n\006SIMPLE\020\001\022\r\n\tRECURSIVE" +
200 "\020\002\022\020\n\014EXPERIMENTAL\020\003\"\340\001\n\031BinaryMinizatio" +
201 "nAlgorithm\022\032\n\026NO_BINARY_MINIMIZATION\020\000\022\035" +
202 "\n\031BINARY_MINIMIZATION_FIRST\020\001\0227\n3BINARY_" +
203 "MINIMIZATION_FIRST_WITH_TRANSITIVE_REDUC" +
204 "TION\020\004\022)\n%BINARY_MINIMIZATION_WITH_REACH" +
205 "ABILITY\020\002\022$\n EXPERIMENTAL_BINARY_MINIMIZ" +
206 "ATION\020\003\"R\n\020ClauseProtection\022\023\n\017PROTECTIO" +
207 "N_NONE\020\000\022\025\n\021PROTECTION_ALWAYS\020\001\022\022\n\016PROTE" +
208 "CTION_LBD\020\002\"5\n\016ClauseOrdering\022\023\n\017CLAUSE_" +
209 "ACTIVITY\020\000\022\016\n\nCLAUSE_LBD\020\001\"\206\001\n\020RestartAl" +
210 "gorithm\022\016\n\nNO_RESTART\020\000\022\020\n\014LUBY_RESTART\020" +
211 "\001\022\035\n\031DL_MOVING_AVERAGE_RESTART\020\002\022\036\n\032LBD_" +
212 "MOVING_AVERAGE_RESTART\020\003\022\021\n\rFIXED_RESTAR" +
213 "T\020\004\"t\n\025MaxSatAssumptionOrder\022\034\n\030DEFAULT_" +
214 "ASSUMPTION_ORDER\020\000\022\035\n\031ORDER_ASSUMPTION_B" +
215 "Y_DEPTH\020\001\022\036\n\032ORDER_ASSUMPTION_BY_WEIGHT\020" +
216 "\002\"o\n\035MaxSatStratificationAlgorithm\022\027\n\023ST" +
217 "RATIFICATION_NONE\020\000\022\032\n\026STRATIFICATION_DE" +
218 "SCENT\020\001\022\031\n\025STRATIFICATION_ASCENT\020\002\"\260\001\n\017S" +
219 "earchBranching\022\024\n\020AUTOMATIC_SEARCH\020\000\022\020\n\014" +
220 "FIXED_SEARCH\020\001\022\024\n\020PORTFOLIO_SEARCH\020\002\022\r\n\t" +
221 "LP_SEARCH\020\003\022\026\n\022PSEUDO_COST_SEARCH\020\004\022\'\n#P" +
222 "ORTFOLIO_WITH_QUICK_RESTART_SEARCH\020\005\022\017\n\013" +
223 "HINT_SEARCH\020\006B\032\n\026com.google.ortools.satP" +
226 descriptor =
com.
google.protobuf.Descriptors.FileDescriptor
227 .internalBuildGeneratedFileFrom(descriptorData,
228 new com.
google.protobuf.Descriptors.FileDescriptor[] {
230 internal_static_operations_research_sat_SatParameters_descriptor =
232 internal_static_operations_research_sat_SatParameters_fieldAccessorTable =
new
233 com.
google.protobuf.GeneratedMessageV3.FieldAccessorTable(
234 internal_static_operations_research_sat_SatParameters_descriptor,
235 new java.lang.String[] {
"PreferredVariableOrder",
"InitialPolarity",
"UsePhaseSaving",
"RandomPolarityRatio",
"RandomBranchesRatio",
"UseErwaHeuristic",
"InitialVariablesActivity",
"AlsoBumpVariablesInConflictReasons",
"MinimizationAlgorithm",
"BinaryMinimizationAlgorithm",
"SubsumptionDuringConflictAnalysis",
"ClauseCleanupPeriod",
"ClauseCleanupTarget",
"ClauseCleanupProtection",
"ClauseCleanupLbdBound",
"ClauseCleanupOrdering",
"PbCleanupIncrement",
"PbCleanupRatio",
"MinimizeWithPropagationRestartPeriod",
"MinimizeWithPropagationNumDecisions",
"VariableActivityDecay",
"MaxVariableActivityValue",
"GlucoseMaxDecay",
"GlucoseDecayIncrement",
"GlucoseDecayIncrementPeriod",
"ClauseActivityDecay",
"MaxClauseActivityValue",
"RestartAlgorithms",
"DefaultRestartAlgorithms",
"RestartPeriod",
"RestartRunningWindowSize",
"RestartDlAverageRatio",
"RestartLbdAverageRatio",
"UseBlockingRestart",
"BlockingRestartWindowSize",
"BlockingRestartMultiplier",
"NumConflictsBeforeStrategyChanges",
"StrategyChangeIncreaseRatio",
"MaxTimeInSeconds",
"MaxDeterministicTime",
"MaxNumberOfConflicts",
"MaxMemoryInMb",
"AbsoluteGapLimit",
"RelativeGapLimit",
"TreatBinaryClausesSeparately",
"RandomSeed",
"LogSearchProgress",
"UsePbResolution",
"MinimizeReductionDuringPbResolution",
"CountAssumptionLevelsInLbd",
"PresolveBveThreshold",
"PresolveBveClauseWeight",
"PresolveProbingDeterministicTimeLimit",
"PresolveBlockedClause",
"PresolveUseBva",
"PresolveBvaThreshold",
"MaxPresolveIterations",
"CpModelPresolve",
"CpModelPostsolveWithFullSolver",
"CpModelMaxNumPresolveOperations",
"CpModelProbingLevel",
"CpModelUseSatPresolve",
"UseSatInprocessing",
"ExpandElementConstraints",
"ExpandAutomatonConstraints",
"ExpandTableConstraints",
"MergeNoOverlapWorkLimit",
"MergeAtMostOneWorkLimit",
"PresolveSubstitutionLevel",
"UseOptimizationHints",
"MinimizeCore",
"FindMultipleCores",
"CoverOptimization",
"MaxSatAssumptionOrder",
"MaxSatReverseAssumptionOrder",
"MaxSatStratification",
"UsePrecedencesInDisjunctiveConstraint",
"UseOverloadCheckerInCumulativeConstraint",
"UseTimetableEdgeFindingInCumulativeConstraint",
"UseDisjunctiveConstraintInCumulativeConstraint",
"LinearizationLevel",
"BooleanEncodingLevel",
"MaxNumCuts",
"OnlyAddCutsAtLevelZero",
"AddKnapsackCuts",
"AddCgCuts",
"AddMirCuts",
"MaxAllDiffCutSize",
"AddLinMaxCuts",
"MaxIntegerRoundingScaling",
"AddLpConstraintsLazily",
"MinOrthogonalityForLpConstraints",
"MaxCutRoundsAtLevelZero",
"MaxConsecutiveInactiveCount",
"CutMaxActiveCountValue",
"CutActiveCountDecay",
"CutCleanupTarget",
"NewConstraintsBatchSize",
"SearchBranching",
"HintConflictLimit",
"ExploitIntegerLpSolution",
"ExploitAllLpSolution",
"ExploitBestSolution",
"ExploitRelaxationSolution",
"ExploitObjective",
"ProbingPeriodAtRoot",
"PseudoCostReliabilityThreshold",
"OptimizeWithCore",
"BinarySearchNumConflicts",
"OptimizeWithMaxHs",
"EnumerateAllSolutions",
"FillTightenedDomainsInResponse",
"InstantiateAllVariables",
"AutoDetectGreaterThanAtLeastOneOf",
"StopAfterFirstSolution",
"StopAfterPresolve",
"NumSearchWorkers",
"InterleaveSearch",
"InterleaveBatchSize",
"ReduceMemoryUsageInInterleaveMode",
"ShareObjectiveBounds",
"ShareLevelZeroBounds",
"UseLnsOnly",
"LnsFocusOnDecisionVariables",
"UseRinsLns",
"UseFeasibilityPump",
"UseRelaxationLns",
"DiversifyLnsParams",
"RandomizeSearch",
"SearchRandomizationTolerance",
"UseOptionalVariables",
"UseExactLpReason",
"UseBranchingInLp",
"UseCombinedNoOverlap",
"CatchSigintSignal",
"UseImpliedBounds",
"MipMaxBound",
"MipVarScaling",
"MipWantedPrecision",
"MipMaxActivityExponent",
"MipCheckPrecision", });