Library for solving optimization problems over Graphs of Convex Sets (GCS).
Project description
GCSOPT
GCSOPT is a Python library for solving optimization problems over Graphs of Convex Sets (GCS).
For a detailed description of the algorithms implemented in this library see the article A Unified and Scalable Method for Optimization over Graphs of Convex Sets.
Main features
- Uses the syntax of
CVXPYfor describing convex sets and convex functions. - Provides a simple interface for assembling your graphs.
- Interface with state-of-the-art solvers via
CVXPY.
Installation
You can install the latest release from PyPI:
pip install gcsopt
To install from source:
git clone https://github.com/TobiaMarcucci/gcsopt.git
cd gcsopt
pip install .
Mixed-integer solvers
GCSOPT reformulates a GCS problem as a mixed-integer program and solves the latter using one of the solvers available in CVXPY.
Gurobi and MOSEK are two high-performance mixed-integer solvers that are free for academic use.
Once one of these solvers is installed, CVXPY will automatically detect it.
You can verify your installation by running:
import cvxpy
print(cvxpy.installed_solvers())
If GUROBI or MOSEK appears in the list, you are ready to use GCSOPT.
Installation of Gurobi
- Get a
Gurobilicense here or here for academic use. - Install the Python package
gurobipyusing your favorite installation method as described here.
Installation of MOSEK
- Get a
MOSEKlicense here or here for academic use. - Install the Python package
mosekusing your favorite installation method as described here.
Example
Below is a minimal example of how to use GCSOPT for solving a shortest-path problem in GCS.
import cvxpy as cp
from gcsopt import GraphOfConvexSets
# Initialize directed graph.
directed = True
G = GraphOfConvexSets(directed)
# Add vertices to graph.
l = 3 # Side length of vertex grid.
r = .3 # Radius of vertex circles.
for i in range(l):
for j in range(l):
c = (i, j) # Center of the circle.
v = G.add_vertex(c) # Vertex named after its center.
x = v.add_variable(2) # Continuous variable.
v.add_constraint(cp.norm2(x - c) <= r) # Constrain in circle.
# Add edges to graph.
for i in range(l):
for j in range(l):
cv = (i, j) # Name of vertex v.
v = G.get_vertex(cv) # Retrieve vertex using its name.
xv = v.variables[0] # Get first and only variable paired with vertex.
# Add right and upward neighbors if not at grid boundary.
neighbors = [(i + 1, j), (i, j + 1)] # Names of candidate neighbors.
for cw in neighbors:
if G.has_vertex(cw): # False if at grid boundary.
w = G.get_vertex(cw) # Get neighbor vertex from its name.
xw = w.variables[0] # Get neighbor variable.
e = G.add_edge(v, w) # Connect vertices with edge.
e.add_cost(cp.norm2(xw - xv)) # Add L2 cost to edge.
# Solve shortest-path problem.
s = G.get_vertex((0, 0)) # Source vertex.
t = G.get_vertex((l - 1, l - 1)) # Target vertex.
G.solve_shortest_path(s, t) # Solve problem and populate graph with result.
# Print solution statistics.
print("Problem status:", G.status)
print("Problem optimal value:", G.value)
for v in G.vertices:
x = v.variables[0]
print(f"Variable {v.name} optimal value:", x.value)
# Plot optimal solution.
import matplotlib.pyplot as plt
plt.figure() # Initialize empty figure.
G.plot_2d() # Plot graph of convex sets.
G.plot_2d_solution() # Plot optimal subgraph.
plt.show() # Show figure.
The output of this script is:
Problem status: optimal
Optimal value: 2.4561622509772887
Variable (0, 0) optimal value: [0.28768714 0.08506533]
Variable (0, 1) optimal value: None
Variable (0, 2) optimal value: None
Variable (1, 0) optimal value: [0.82565028 0.24413557]
Variable (1, 1) optimal value: [1.21213203 0.78786797]
Variable (1, 2) optimal value: None
Variable (2, 0) optimal value: None
Variable (2, 1) optimal value: [1.75586443 1.17434971]
Variable (2, 2) optimal value: [1.91493467 1.71231286]
Contributing
Contributions, bug reports, and feature requests are very welcome! To contribute, please open an issue or submit a pull request on GitHub.
License
This project is licensed under the MIT License.
Author
Developed and maintained by Tobia Marcucci. For questions or feedback, please contact marcucci@ucsb.edu.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file gcsopt-0.1.3-py3-none-any.whl.
File metadata
- Download URL: gcsopt-0.1.3-py3-none-any.whl
- Upload date:
- Size: 39.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0fd153cd76511515d020a699906a349a37acebed9b7cbf3a38b5cd567b81b9e5
|
|
| MD5 |
835c916f060b5ce8a43b4de61fc86e0f
|
|
| BLAKE2b-256 |
3889938caee548ddaf11d06926b8bf0f18215c99194c6d79566596da306b0429
|