Tune CPLEX Options from AIMMS
The CPLEX solver has many options that influence the way CPLEX solves your model. For certain types of constraints and/or models, you can make an educated guess about which combination of options works best for your problem. However, sometimes you need more help.
To help you out, CPLEX has some automatic tuning options.
In AIMMS, you can access this CPLEX tuning tool via the following two functions: GMP::Tuning::TuneMultipleMPS
and GMP::Tuning::TuneSingleGMP
.
As the names already suggest, the first function will tune the CPLEX options for a set of LP/MPS files. As an argument, you will have to specify the directory containing the LP/MPS files. The second function will tune the options based on one single GMP, which you will have to provide as an argument.
The function GMP::Tuning::TuneSingleGMP
works like the other GMP function, so the solver to use is already known. In case of the function GMP::Tuning::TuneMultipleMPS
, you must also provide which solver to use as an argument.
In order to create the MPS files for multiple instances of your problem, you can set the project setting CPLEX
specific solver options to At every solve. Each time you solve an instance of your problem, the solver will generate a MPS file.
The other options to provide are the following:
FixedOptions
: A subset of the setAllOptions
that are to be considered unchangeable and for which the current project options will be used
ApplyTunedSettings
: A binary argument indicating whether the found tuned option settings should be set in the project options
OptionFileName
: File to which the tuned option settings should be written. This file can be imported in the Project Options screen.
To use these functions, we first need the following declarations:
Set FixedOptions {
SubsetOf: AllOptions;
}
ElementParameter genMathProgram {
Range: AllGeneratedMathematicalPrograms;
}
To actually tune the solver settings, you can use the following code:
1!Determines which options we consider to be unchangable by CPLEX
2!It will use the current value for this setting in the project options.
3!As an example, we will forbid the tuning of the setting mip_search_strategy.
4
5FixedOptions := { 'CPLEX 12.3::mip_search_strategy' } ;
6
7!First create the GMP out of the Math Program
8
9genMathProgram := GMP::Instance::Generate( MP );
10
11!Then call the TuneSingleGMP function, which will try to find a good
12!combination of settings for the solver options for this instance.
13!The settings that are in the set FixedOptions will not be considered
14!for tuning.
15!The found settings will be applied directly in the project settings
16!and also will be written to the file "tuned_options_gmp.opt"
17
18gmp::Tuning::TuneSingleGMP(
19 GMP : genMathProgram ,
20 FixedOptions : FixedOptions ,
21 ApplyTunedSettings : 1 , !Save found settings directly in project
22 OptionFileName : "tuned_options_gmp.opt" ) ; !Store found settings in this file
23
24
25!This call will try to find a combination of settings for
26!the solver options that are good for the set of MPS/LP files that
27!are found in the subdirectory mps-files in the directory of
28!the project.
29!The settings that are in the set FixedOptions will not be considered
30!for tuning.
31!The found settings will be applied directly in the project settings
32!and also will be written to the file "tuned_options_gmp_mps.opt"
33
34gmp::Tuning::TuneMultipleMPS(
35 DirectoryName : "mps-files" , ! location of mps files, relative to project
36 Solver : 'CPLEX 12.3' ,! Which solver to use, in this case CPLEX 12.3
37 FixedOptions : FixedOptions , !Consider these options unchangable.
38 ApplyTunedSettings : 1 , !Save found settings directly in project
39 OptionFileName : "tuned_options_gmp_mps.opt" ) ; !Store found settings in this file
Note
Take care when tuning; always ensure that you have a few instances that are a good sample of the range of possible instances. If the instances you are tuning are not representative for all possible instances, you will tune to one specific instance but risk decreasing performance for all instances overall.