cddlib: Double description method for polyhedral representation conversion#

Description#

The C-library cddlib is a C implementation of the Double Description Method of Motzkin et al. for generating all vertices (i.e. extreme points) and extreme rays of a general convex polyhedron in R^d given by a system of linear inequalities:

P = { x=(x1, …, xd)^T : b - A x >= 0 }

where A is a given m x d real matrix, b is a given m-vector and 0 is the m-vector of all zeros.

The program can be used for the reverse operation (i.e. convex hull computation). This means that one can move back and forth between an inequality representation and a generator (i.e. vertex and ray) representation of a polyhedron with cdd. Also, cdd can solve a linear programming problem, i.e. a problem of maximizing and minimizing a linear function over P.

License#

GPL v2

Upstream Contact#

https://github.com/cddlib/cddlib

Type#

standard

Dependencies#

  • $(MP_LIBRARY)

Version Information#

package-version.txt:

0.94m

Equivalent System Packages#

arch:

$ sudo pacman -S  cddlib

conda:

$ conda install  cddlib

cygwin:

$ apt-cyg install cddlib-devel cddlib-tools

Debian/Ubuntu:

$ sudo apt-get install  libcdd-dev libcdd-tools

Fedora/Redhat/CentOS:

$ sudo yum install  cddlib

freebsd:

$ sudo pkg install math/cddlib

gentoo:

$ sudo emerge sci-libs/cddlib

homebrew:

macports: install the following packages: cddlib

nix:

$ nix-env --install cddlib

opensuse:

$ sudo zypper install cddlib-tools "pkgconfig(cddlib)"

void:

$ sudo xbps-install  cddlib-devel

See https://repology.org/project/cddlib/versions

If the system package is installed, ./configure will check whether it can be used.