Skip to content

usra-riacs/copositive-cutting-plane-max-clique

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

3 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Copositive cutting plane algorithm with Ising solvers and experiments with max-clique

This code base is using the Julia Language and DrWatson to make a reproducible scientific project named

copositive-cutting-plane-max-clique

Details of this method can be found in our arxiv preprint.

To (locally) reproduce this project, do the following:

  1. Download this code base. Notice that raw data are typically not included in the git-history and may need to be downloaded independently.

  2. Set up your conda environment to use dwave-neal:

    > conda create --name "myenv" python=3.9
    > conda activate myenv
    > python -m pip install -r requirements.txt
    
  3. Open a Julia console and do:

    julia> using Pkg
    julia> Pkg.add("DrWatson") # install globally, for using `quickactivate`
    julia> Pkg.activate("path/to/this/project/src/COP")
    julia> Pkg.build("Gurobi") # you may need to set ENV["GUROBI_HOME"] prior if it isn't set
    julia> Pkg.activate("path/to/this/project/")
    julia> Pkg.instantiate()
    

This will install all necessary packages for you to be able to run the julia scripts and everything should work out of the box.

  1. To run the copositive cutting plane algorithm:

    > cd path/to/this/project/scripts
    > julia run_cutting_plane.jl exp_raw --param {#} --anst --neal
    

    Replace {#} with 25, 05, or 75
    --anst runs the cutting plane algorithm with Anstreicher's MILP copositivity formulation
    --neal runs the cutting plane algorithm with dwave neal as the copositivity checker

  2. To run additional benchmarks:

    > python benchmarking.py exp_raw --param {#} --hpo --fixed --gp_cop --gp_mip --dw_mc
    

    Replace {#} with 25, 05, or 75
    --hpo run hyperopt parameter tuning'
    --fixed run fixed neal with 100 sweeps
    --gp_cop run gurobi copositivity check experiment
    --gp_mip run gurobi mip formulations
    --dw_mc run dwave maximum clique sampler

    Note that the graphs are generated in 2. so it needs to be run before 4.

  3. To generate plots: run cells in notebooks/plotting.ipynb

To cite this work, you can use the following bibtex citation:

@misc{brown2022copositive,
      title={Copositive programming for mixed-binary quadratic optimization via Ising solvers}, 
      author={Robin Brown and David E. Bernal Neira and Davide Venturelli and Marco Pavone},
      year={2022},
      eprint={2207.13630},
      archivePrefix={arXiv},
      primaryClass={math.OC}
}

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Jupyter Notebook 94.0%
  • Python 3.0%
  • Julia 3.0%