Skip to content

This package provides access to the QuasiGrad solver, developed for the 3rd ARPA-E Grid Optimization (GO) Challenge.

License

Notifications You must be signed in to change notification settings

SamChevalier/QuasiGrad.jl

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

qg logo


QuasiGrad.jl

QuasiGrad.jl is a parallelized, adam-based solver for reserve and security constrained AC unit commitment problems. Solver details are sketeched out in a recent pre-print and the associated SI. QuasiGrad.jl is a parallelized, adam-based solver for reserve and security constrained AC unit commitment problems. Solver details are sketeched out in a recent pre-print and the associated SI.

The QuasiGrad solver recently competed in the 3rd Grid Optimizaiton Competition, scoring reasonably well in the day-ahead market clearing problem. QuasiGrad's internal gradient-based solver (Adam) can easily be substituted for other ML-inspired solvers (e.g., AdaGrad, AdaDelta, RMSProp, etc.).

Installation

QuasiGrad can be installed using the Julia package manager via

] add QuasiGrad

Julia 1.9.3 or higher is reccomended for use with QuasiGrad. Julia should be launched with as many CPU threads as you wish to dedicate to the solve. More threads, more parallelization.

Usage

This package is a work-in-progress, and contributions are more than welcome. A valid Gurobi license is needed to run the solver (with some effort, this solver can be swapped out). Note: no QuasiGrad functions are exported to Julia's namespace.

Out-of-the-box usage can be acheived by running the following "division 1" example (it solves reserve+security constrained AC Unit Commitment on the 617 bus testcase system).

using QuasiGrad

QuasiGrad_root = dirname(dirname(pathof(QuasiGrad)))
test_file = joinpath(QuasiGrad_root,"data","C3E3.1_20230629","D1","C3E3N00617D1","scenario_001.json")

# define some test parameters
NewTimeLimitInSeconds = 600.0
Division              = 1
NetworkModel          = "test"
AllowSwitching        = 0

# run the test
QuasiGrad.compute_quasiGrad_solution_d1(test_file, NewTimeLimitInSeconds, Division, NetworkModel, AllowSwitching; post_process=true)

Questions

Please contact Sam Chevalier (schevali@uvm.edu) with any questions.

About

This package provides access to the QuasiGrad solver, developed for the 3rd ARPA-E Grid Optimization (GO) Challenge.

Topics

Resources

License

Stars

Watchers

Forks

Languages