Code for solving LP on GPU using first-order methods.
This is the C implementation of the Julia version cuPDLP.jl.
We use CMAKE to build CUPDLP. The current version switches to HiGHS project (previously, Coin-OR CLP).
Note that if you install HiGHS using the precompiled binaries, the compressed MPS files cannot be read. You can build and install with the zlib support from source, see this page to find out more. Once you setup HiGHS and CUDA, set the following environment variables.
export HIGHS_HOME=/path-to-highs
export CUDA_HOME=/path-to-cuda
By setting -DBUILD_CUDA=ON
(by default OFF, i.e., the CPU version), you have the GPU version of cuPDLP-C.
Examples
- use the debug mode:
mkdir build
cd build
cmake -DCMAKE_BUILD_TYPE=Debug -DBUILD_CUDA=ON ..
cmake --build . --target plc
then you can find the binary plc
in the folder build/bin/
.
- when using the release mode, we suggest the following options,
cmake -DBUILD_CUDA=ON \
-DCMAKE_C_FLAGS_RELEASE="-O2 -DNDEBUG" \
-DCMAKE_CXX_FLAGS_RELEASE="-O2 -DNDEBUG" \
-DCMAKE_CUDA_FLAGS_RELEASE="-O2 -DNDEBUG" ..
Usage example: set nIterLim
to 5000
and solve.
./bin/plc -fname <mpsfile> -nIterLim 5000
Param | Type | Range | Default | Description |
---|---|---|---|---|
fname |
str |
|
|
.mps file of the LP instance |
fout |
str |
|
./solution.json |
.json file to save result |
savesol |
bool |
true, false |
false |
whether to write solution to .json output |
ifScaling |
bool |
true, false |
true |
Whether to use scaling |
ifRuizScaling |
bool |
true, false |
true |
Whether to use Ruiz scaling (10 times) |
ifL2Scaling |
bool |
true, false |
false |
Whether to use L2 scaling |
ifPcScaling |
bool |
true, false |
true |
Whether to use Pock-Chambolle scaling |
nIterLim |
int |
>=0 |
10000000 |
Maximum iteration number |
eLineSearchMethod |
int |
0-2 |
2 |
Choose line search: 0-fixed, 1-Malitsky, 2-Adaptive |
dPrimalTol |
double |
>=0 |
1e-4 |
Primal feasibility tolerance for termination |
dDualTol |
double |
>=0 |
1e-4 |
Dual feasibility tolerance for termination |
dGapTol |
double |
>=0 |
1e-4 |
Duality gap tolerance for termination |
dFeasTol |
double |
>=0 |
1e-8 |
Not used yet, maybe infeasibility tolerance |
dTimeLim |
double |
>0 |
3600 |
Time limit (in seconds) |
eRestartMethod |
int |
0-1 |
1 |
Choose restart: 0-none, 1-GPU |
Consider the generic linear programming problem:
Equivalently, we solve the following saddle-point problem,
where dual variables
Primal-Dual Hybrid Gradient (PDHG) algorithm takes the step as follows,
The termination criteria contain the primal feasibility, dual feasibility, and duality gap.
where
Dongdong Ge, Haodong Hu, Qi Huangfu, Jinsong Liu, Tianhao Liu, Haihao Lu, Jinwen Yang, Yinyu Ye, Chuwen Zhang
- Jinsong Liu <github.com/JinsongLiu6>
- Tianhao Liu <github.com/SkyLiu0>
- Chuwen Zhang <github.com/bzhangcw>