List of options

presolve

  • Presolve option: "off", "choose" or "on"
  • Type: string
  • Default: "choose"

solver

  • Solver option: "simplex", "choose", "ipm" or "pdlp". If "simplex"/"ipm"/"pdlp" is chosen then, for a MIP (QP) the integrality constraint (quadratic term) will be ignored
  • Type: string
  • Default: "choose"

parallel

  • Parallel option: "off", "choose" or "on"
  • Type: string
  • Default: "choose"

run_crossover

  • Run IPM crossover: "off", "choose" or "on"
  • Type: string
  • Default: "on"

time_limit

  • Time limit (seconds)
  • Type: double
  • Range: [0, inf]
  • Default: inf

ranging

  • Compute cost, bound, RHS and basic solution ranging: "off" or "on"
  • Type: string
  • Default: "off"

infinite_cost

  • Limit on |cost coefficient|: values greater than or equal to this will be treated as infinite
  • Type: double
  • Range: [1e+15, inf]
  • Default: 1e+20

infinite_bound

  • Limit on |constraint bound|: values greater than or equal to this will be treated as infinite
  • Type: double
  • Range: [1e+15, inf]
  • Default: 1e+20

small_matrix_value

  • Lower limit on |matrix entries|: values less than or equal to this will be treated as zero
  • Type: double
  • Range: [1e-12, inf]
  • Default: 1e-09

large_matrix_value

  • Upper limit on |matrix entries|: values greater than or equal to this will be treated as infinite
  • Type: double
  • Range: [1, inf]
  • Default: 1e+15

primal_feasibility_tolerance

  • Primal feasibility tolerance
  • Type: double
  • Range: [1e-10, inf]
  • Default: 1e-07

dual_feasibility_tolerance

  • Dual feasibility tolerance
  • Type: double
  • Range: [1e-10, inf]
  • Default: 1e-07

ipm_optimality_tolerance

  • IPM optimality tolerance
  • Type: double
  • Range: [1e-12, inf]
  • Default: 1e-08

primal_residual_tolerance

  • Primal residual tolerance
  • Type: double
  • Range: [1e-10, inf]
  • Default: 1e-07

dual_residual_tolerance

  • Dual residual tolerance
  • Type: double
  • Range: [1e-10, inf]
  • Default: 1e-07

objective_bound

  • Objective bound for termination of the dual simplex solver
  • Type: double
  • Range: [-inf, inf]
  • Default: inf

objective_target

  • Objective target for termination of the MIP solver
  • Type: double
  • Range: [-inf, inf]
  • Default: -inf

random_seed

  • Random seed used in HiGHS
  • Type: integer
  • Range: {0, 2147483647}
  • Default: 0

threads

  • Number of threads used by HiGHS (0: automatic)
  • Type: integer
  • Range: {0, 2147483647}
  • Default: 0

user_bound_scale

  • Exponent of power-of-two bound scaling for model
  • Type: integer
  • Range: {-2147483647, 2147483647}
  • Default: 0

user_cost_scale

  • Exponent of power-of-two cost scaling for model
  • Type: integer
  • Range: {-2147483647, 2147483647}
  • Default: 0

simplex_strategy

  • Strategy for simplex solver 0 => Choose; 1 => Dual (serial); 2 => Dual (PAMI); 3 => Dual (SIP); 4 => Primal
  • Type: integer
  • Range: {0, 4}
  • Default: 1

simplex_scale_strategy

  • Simplex scaling strategy: off / choose / equilibration / forced equilibration / max value 0 / max value 1 (0/1/2/3/4/5)
  • Type: integer
  • Range: {0, 5}
  • Default: 1

simplex_dual_edge_weight_strategy

  • Strategy for simplex dual edge weights: Choose / Dantzig / Devex / Steepest Edge (-1/0/1/2)
  • Type: integer
  • Range: {-1, 2}
  • Default: -1

simplex_primal_edge_weight_strategy

  • Strategy for simplex primal edge weights: Choose / Dantzig / Devex / Steepest Edge (-1/0/1/2)
  • Type: integer
  • Range: {-1, 2}
  • Default: -1

simplex_iteration_limit

  • Iteration limit for simplex solver when solving LPs, but not subproblems in the MIP solver
  • Type: integer
  • Range: {0, 2147483647}
  • Default: 2147483647

simplex_update_limit

  • Limit on the number of simplex UPDATE operations
  • Type: integer
  • Range: {0, 2147483647}
  • Default: 5000

simplex_max_concurrency

  • Maximum level of concurrency in parallel simplex
  • Type: integer
  • Range: {1, 8}
  • Default: 8

output_flag

  • Enables or disables solver output
  • Type: boolean
  • Default: "true"

log_to_console

  • Enables or disables console logging
  • Type: boolean
  • Default: "true"

solution_file

  • Solution file
  • Type: string
  • Default: ""

log_file

  • Log file
  • Type: string
  • Default: ""

write_solution_to_file

  • Write the primal and dual solution to a file
  • Type: boolean
  • Default: "false"

write_solution_style

  • Style of solution file (raw = computer-readable, pretty = human-readable): -1 => HiGHS old raw (deprecated); 0 => HiGHS raw; 1 => HiGHS pretty; 2 => Glpsol raw; 3 => Glpsol pretty; 4 => HiGHS sparse raw
  • Type: integer
  • Range: {-1, 4}
  • Default: 0

glpsol_cost_row_location

  • Location of cost row for Glpsol file: -2 => Last; -1 => None; 0 => None if empty, otherwise data file location; 1 <= n <= num_row => Location n; n > num_row => Last
  • Type: integer
  • Range: {-2, 2147483647}
  • Default: 0

write_model_file

  • Write model file
  • Type: string
  • Default: ""

write_model_to_file

  • Write the model to a file
  • Type: boolean
  • Default: "false"

write_presolved_model_file

  • Write presolved model file
  • Type: string
  • Default: ""

write_presolved_model_to_file

  • Write the presolved model to a file
  • Type: boolean
  • Default: "false"

mip_detect_symmetry

  • Whether MIP symmetry should be detected
  • Type: boolean
  • Default: "true"

mip_allow_restart

  • Whether MIP restart is permitted
  • Type: boolean
  • Default: "true"

mip_max_nodes

  • MIP solver max number of nodes
  • Type: integer
  • Range: {0, 2147483647}
  • Default: 2147483647

mip_max_stall_nodes

  • MIP solver max number of nodes where estimate is above cutoff bound
  • Type: integer
  • Range: {0, 2147483647}
  • Default: 2147483647

mip_max_start_nodes

  • MIP solver max number of nodes when completing a partial MIP start
  • Type: integer
  • Range: {0, 2147483647}
  • Default: 500

mip_improving_solution_save

  • Whether improving MIP solutions should be saved
  • Type: boolean
  • Default: "false"

mip_improving_solution_report_sparse

  • Whether improving MIP solutions should be reported in sparse format
  • Type: boolean
  • Default: "false"

mip_improving_solution_file

  • File for reporting improving MIP solutions: not reported for an empty string \"\"
  • Type: string
  • Default: ""

mip_max_leaves

  • MIP solver max number of leaf nodes
  • Type: integer
  • Range: {0, 2147483647}
  • Default: 2147483647

mip_max_improving_sols

  • Limit on the number of improving solutions found to stop the MIP solver prematurely
  • Type: integer
  • Range: {1, 2147483647}
  • Default: 2147483647

mip_lp_age_limit

  • Maximal age of dynamic LP rows before they are removed from the LP relaxation in the MIP solver
  • Type: integer
  • Range: {0, 32767}
  • Default: 10

mip_pool_age_limit

  • Maximal age of rows in the MIP solver cutpool before they are deleted
  • Type: integer
  • Range: {0, 1000}
  • Default: 30

mip_pool_soft_limit

  • Soft limit on the number of rows in the MIP solver cutpool for dynamic age adjustment
  • Type: integer
  • Range: {1, 2147483647}
  • Default: 10000

mip_pscost_minreliable

  • Minimal number of observations before MIP solver pseudo costs are considered reliable
  • Type: integer
  • Range: {0, 2147483647}
  • Default: 8

mip_min_cliquetable_entries_for_parallelism

  • Minimal number of entries in the MIP solver cliquetable before neighbourhood queries of the conflict graph use parallel processing
  • Type: integer
  • Range: {0, 2147483647}
  • Default: 100000

mip_feasibility_tolerance

  • MIP feasibility tolerance
  • Type: double
  • Range: [1e-10, inf]
  • Default: 1e-06

mip_heuristic_effort

  • Effort spent for MIP heuristics
  • Type: double
  • Range: [0, 1]
  • Default: 0.05

mip_rel_gap

  • Tolerance on relative gap, |ub-lb|/|ub|, to determine whether optimality has been reached for a MIP instance
  • Type: double
  • Range: [0, inf]
  • Default: 0.0001

mip_abs_gap

  • Tolerance on absolute gap of MIP, |ub-lb|, to determine whether optimality has been reached for a MIP instance
  • Type: double
  • Range: [0, inf]
  • Default: 1e-06

mip_min_logging_interval

  • MIP minimum logging interval
  • Type: double
  • Range: [0, inf]
  • Default: 5

ipm_iteration_limit

  • Iteration limit for IPM solver
  • Type: integer
  • Range: {0, 2147483647}
  • Default: 2147483647

pdlp_native_termination

  • Use native termination for PDLP solver: Default = false
  • Type: boolean
  • Default: "false"

pdlp_scaling

  • Scaling option for PDLP solver: Default = true
  • Type: boolean
  • Default: "true"

pdlp_iteration_limit

  • Iteration limit for PDLP solver
  • Type: integer
  • Range: {0, 2147483647}
  • Default: 2147483647

pdlp_e_restart_method

  • Restart mode for PDLP solver: 0 => none; 1 => GPU (default); 2 => CPU
  • Type: integer
  • Range: {0, 2}
  • Default: 1

pdlp_d_gap_tol

  • Duality gap tolerance for PDLP solver: Default = 1e-4
  • Type: double
  • Range: [1e-12, inf]
  • Default: 0.0001

qp_iteration_limit

  • Iteration limit for QP solver
  • Type: integer
  • Range: {0, 2147483647}
  • Default: 2147483647

qp_nullspace_limit

  • Nullspace limit for QP solver
  • Type: integer
  • Range: {0, 2147483647}
  • Default: 4000

blend_multi_objectives

  • Blend multiple objectives or apply lexicographically: Default = true
  • Type: boolean
  • Default: "true"