Skip to main content

nash-mpqp - A Python package for solving parametric generalized Nash equilibrium (GNE) problems with quadratic objectives and coupled linear inequality constraints in explicit form.

Project description

nash_mpqp

Solver for parametric generalized Nash equilibrium (GNE) problems with quadratic objectives and coupled linear inequality constraints.

Each agent $i \in {1, ..., N}$ solves the parametric optimization problem:

$$ \begin{align} \min_{x_i\in\mathbb{R}^{n_i}} \quad & \frac{1}{2} x^T Q_i x + (c_i + F_i p)^T x \ \text{s.t.} \quad & Ax \leq b + Sp\ & \ell \ \leq x \ \leq u \end{align} $$

Where:

  • $x = [x_1; x_2; \ldots; x_N] \in [\ell_b, u_b]$ is the stacked decision vector of dimension $n=n_1+n_2+\ldots+n_N$;
  • $p \in [p_{\min}, p_{\max}]$ is the parameter vector
  • $Q_i \in \mathbb{R}^{n_x \times n_x}$ is the cost matrix for agent $i$
  • $F_i \in \mathbb{R}^{n_x \times n_p}$ is the parameter gain matrix
  • $A \in \mathbb{R}^{n_A \times n_x}$, $b \in \mathbb{R}^{n_A}$, $S \in \mathbb{R}^{n_A \times n_p}$ define the coupling inequality constraints
  • $\ell$ define lower bounds (if any exist) on the optimization variables
  • $u$ define upper bounds (if any exist) on the optimization variables

Note that the parameters can only appear in the linear term of the objective function and the right-hand-side of the constraints, and that they can be local or shared, depending on the selected matrices $A$ and $S$. The problem is solved for a given set of parameters

$$p_{\rm min} \leq p \leq p_{\rm max}$$

and a given range of interest of the variables

$$x_{\rm min} \leq x \leq x_{\rm max}$$

In case polyhedral regions containing infinitely many GNEs are detected, it is possible to characterize variational GNE solutions, minimum norm solutions, and welfare GNE solutions.

Installation

pip install nash-mpqp

API Reference

NashMPQP Constructor

NashMPQP(dim, pmin, pmax, xmin, xmax, Q, c, F, A, b, S, lb, ub, split, parallel_processing, verbose)

Parameters

Parameter Type Description
dim list[int] Number of variables for each agent $[n_1,n_2,\ldots,n_N]$
pmin np.ndarray Lower bounds on parameters
pmax np.ndarray Upper bounds on parameters
xmin np.ndarray Lower bounds on variables for which the solution is computed (not constraints on $x$, see lb)
xmax np.ndarray Upper bounds on parameters for which the solution is computed (not constraints on $x$, see ub)
Q list[np.ndarray] List of quadratic cost matrices for each agent
c list[np.ndarray] List of linear cost vectors for each agent
F list[np.ndarray] List of parameter gain matrices for each agent
A np.ndarray Inequality constraint matrix (coupling and local)
b np.ndarray Inequality constraint vector (coupling and local)
S np.ndarray Inequality constraint parameter matrix (coupling and local)
lb np.ndarray or None Lower bounds on x. Use entries equal to -inf for unbounded variables
lb np.ndarray or None Upper bounds on x. Use entries equal to inf for unbounded variables
split string or None How to deal with critical regions with infinitely many GNE solutions (see below)
parallel_processing bool If True, solve mpQPs in parallel using all CPU cores
verbose bool If True, print progress messages

The input argument split is used to decide how to handle critical regions with infinitely-many solutions:

  • split = "min-norm" (default): split the critical region into subregions, each with a unique minimum-norm equilibrium solution

  • split = "welfare": split the critical region into subregions, each with a unique fair equilibrium solution where the sum of all agents' costs is minimized

  • split = "variational": overlaps a (sub)region of unique variational GNE solution (if it exists) over a region of infinitely-many solutions

  • split = "variational-split": split the critical region into a subregion characterized by a unique variational GNE solution (if it exists), plus a partition of the remaining set into polyhedral subregions with infinitely-many solutions

  • split = None: keep an entire critical region with infinitely-many solutions as a single region.

Illustrative Example: 2-Agent Generalized Game

Consider following example (Rosen, 1965):

Agent 1: $$\min_{x_1 \geq 0} \frac{1}{2}x_1^2 - x_1x_2 + p_2x_1 \quad \text{s.t.} \quad -x_1 - x_2 \leq p_1$$

Agent 2: $$\min_{x_2 \geq 0} x_2^2 + x_1x_2 \quad \text{s.t.} \quad -x_1 - x_2 \leq p_1$$

where $p = [p_1\ p_2]^T$ are the parameters.

Problem Matrices

The quadratic cost matrices are

Q_1 = \begin{bmatrix} 1 & -1 \\ -1 & 0 \end{bmatrix}, \quad 
Q_2 = \begin{bmatrix} 0 & 1 \\ 1 & 2 \end{bmatrix}

The parameter gain matrices are

F_1 = \begin{bmatrix} 0 & 1 \\ 0 & 0 \end{bmatrix}, \quad 
F_2 = \begin{bmatrix} 0 & 0 \\ 0 & 0 \end{bmatrix}

The constraint matrices are

A =  \begin{bmatrix}
-1 & -1 \end{bmatrix},\quad b=0,\quad S = 
\begin{bmatrix}
1 & 0 \end{bmatrix}

Implementation

import numpy as np
from nash_mpqp import NashMPQP

np.random.seed(0)

N = 2  # number of agents
dim = [1,1]  # number of variables for each agent
npar = 2  # number of parameters
ncon = 1  # number of constraints
split = "min-norm"

# Create problem data
nvar = sum(dim)  # total number of variables
Q, c, F = [[],[],[]]

for i in range(N):
    if i==0:
        Q.append(np.array([[1.0, -1.0], [-1.0, 0.0]]))  
        F.append(np.array([[0.0, 1.0], [0.0, 0.0]]))
        
    if i==1:
        Q.append(np.array([[0.0, 1.0], [1.0, 2.0]]))
        F.append(np.zeros([nvar, npar]))
        
    c.append(np.zeros(nvar))

A = np.array([[-1.0, -1.0]])
b = np.zeros(ncon)
S = np.array([[1.0, 0.0]]) 

lb = np.zeros(nvar)  # lower bounds on variables
ub = None
xmin = lb # lower bounds on variables, used for computing the parametric solution
xmax = 10.*np.ones(nvar)   # upper bounds on variables, used for computing the parametric solution

pmin = -10*np.ones(npar) # lower bounds on parameters
pmax = 10*np.ones(npar) # upper bounds on parameters

# Problem setup and solve
nash_mpqp = NashMPQP(dim, pmin, pmax, xmin, xmax, Q, c, F, A, b, S, lb, ub, split=split)
nash_mpqp.solve()

The above code will find the multiparametric game-theoretic solution, which is plotted below (run example_1.py to reproduce):

Critical Regions

License

Apache License V2.0

Citation

If you use this software, please cite the following associated paper:

@article{HB25,
  title={Solving Multiparametric Generalized {Nash} Equilibrium Problems and Explicit Game-Theoretic Model Predictive Control},
  author={Sophie Hall, Alberto Bemporad},
  journal={\url{https://arxiv.org/abs/2512.05505}},
  year={2025}
}

Acknowledgements

This work was funded by the European Union (ERC Advanced Research Grant COMPACT, No. 101141351). Views and opinions expressed are however those of the authors only and do not necessarily reflect those of the European Union or the European Research Council. Neither the European Union nor the granting authority can be held responsible for them.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

nash_mpqp-0.2.0.tar.gz (21.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

nash_mpqp-0.2.0-py3-none-any.whl (21.8 kB view details)

Uploaded Python 3

File details

Details for the file nash_mpqp-0.2.0.tar.gz.

File metadata

  • Download URL: nash_mpqp-0.2.0.tar.gz
  • Upload date:
  • Size: 21.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.13

File hashes

Hashes for nash_mpqp-0.2.0.tar.gz
Algorithm Hash digest
SHA256 9169fe3b6ec1e1ccd49d7ef7df9a7fc0b691b6e58b470a9c8acf197adf05b5ad
MD5 df51411904abfbe360f9ab1a1592399f
BLAKE2b-256 964edc3f492acd59bbce31bc153a90aa8f5c2de71ab3e7fa4c1f48012f30a012

See more details on using hashes here.

File details

Details for the file nash_mpqp-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: nash_mpqp-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 21.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.13

File hashes

Hashes for nash_mpqp-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 dc3882e381c5d595e9f63ec17466be14c297ee6907e8951d5c407e7be64763d4
MD5 b16a771643a108fb6d8706dfd93967ec
BLAKE2b-256 8a30640bdabfc9f8ed84a898f92e2b935a5116da54bd3a221d823763a3dc1e17

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page