Skip to main content

Python bindings for the AIMMS optimization platform, built with pybind11 for seamless C++ integration. Enables efficient data exchange and interaction with AIMMS projects using pandas, polars, and pyarrow. Ideal for advanced optimization workflows requiring high-performance native code.

Reason this release was yanked:

old

Project description

AIMMS Python library

This is a BETA version of the AIMMS Python library. Any feedback, bug reports, or feature requests are welcome.

With this library it is possible to interact with AIMMS models from Python.

Features

  • Seamless integration with AIMMS models from Python
  • Assign and retrieve data using Python dicts, Pandas, Polars, or Arrow tables
  • Execute AIMMS procedures and retrieve results programmatically
  • Built with pybind11 for high-performance C++ integration
  • Flexible data return types for different workflows

Getting Started

To use the AIMMS Python library, you need to have an AIMMS developer version installed (see https://www.aimms.com/support/downloads/), a valid license (see https://licensing.aimms.cloud/license) and an already existing AIMMS project. Below is a step-by-step example of how to use the library to solve a simple transportation optimization problem.

Step 1: Initialize the AIMMS Project

First, initialize the AIMMS project by specifying the AIMMS executable path, project path, and other configurations.

Note: Ensure that the aimms_path points to a valid AIMMS Bin (or Lib on linux) folder of an installed AIMMS version. You use can the utility function find_aimms_path to automatically search your system for that path.

import os

from aimmspy.project.project import DataReturnTypes, Project, AimmsException, AimmsPyException, Model
from aimmspy.utils import find_aimms_path


# Initialize the AIMMS project
project = Project(
    # path to the AIMMS Bin folder (on linux the Lib folder)
    aimms_path=find_aimms_path("25.4.3.3"),

    # path to the AIMMS project
    aimms_project_file=R"C:\AimmsProjects\MyAimmsProject\MyAimmsProject.aimms",

    # url
    license_url=R"wss://licensing.aimms.cloud/license-ws/license?profile=community&license=12345678-90ab-cdef-1234-567890abcdef"
)
my_aimms : Model = project.get_model(__file__)

Step 2: Assign Data to Parameters

This is an example of assigning data to parameters with Pandas DataFrames.

demand_df = pd.DataFrame({
    "c": ["Houston", "Phoenix", "Philadelphia"],
    "demand": [50.0, 60.0, 40.0]
})

supply_df = pd.DataFrame(data={
    "w": ["NewYork", "LosAngeles", "Chicago"],
    "supply": [70.0, 80.0, 60.0]
})

unit_transport_cost_df = pd.DataFrame({
    "w": ["NewYork", "NewYork", "NewYork", "LosAngeles", "LosAngeles", "LosAngeles", "Chicago", "Chicago", "Chicago"],
    "c": ["Houston", "Phoenix", "Philadelphia", "Houston", "Phoenix", "Philadelphia", "Houston", "Phoenix", "Philadelphia"],
    "unit_transport_cost": [5.0, 6.0, 4.0, 3.0, 2.0, 7.0, 4.0, 5.0, 3.0]
})

my_aimms.demand.assign( demand_df)
my_aimms.supply.assign( supply_df)
my_aimms.unit_transport_cost.assign( unit_transport_cost_df)

You can assign doubles, integers, strings to AIMMS parameters. The library will automatically convert the data types to the appropriate AIMMS types. The sets will be filled automatically based on the data you assign to the parameters.

Step 3: Execute the Optimization Procedure

It is possible in AIMMS to define procedures that encapsulate the logic of your optimization model. These procedures can be executed from Python using the AIMMS Python library. In this example we run the main procedure in the AIMMS project to solve the optimization problem.

my_aimms.MainExecution()

It is also possible to run procedures with arguments for example:

my_aimms.run_procedure(test1=5.0, test2=10.0, test3="hello")

Make sure the order of the arguments is correct, as well as the types.

Step 4: Retrieve and Display Results

Retrieve the results of the optimization, such as the total transport cost and the transport plan.

# Retrieve results
print(f"Total Transport Cost: {my_aimms.total_transport_cost.data()}")
print(f"Transport Plan: {my_aimms.transport.data()}")

The .data() function is used to fetch the current value of an AIMMS identifier (e.g., a parameter, variable, or set) into Python. This function is efficient and only fetches data if it has changed since the last fetch.

Data Types Returned by .data()

depending on the data_type_preference you set in the Project constructor, the .data() function will return different types of Python objects:

Sets always return a list of strings.

For parameters and variables, .data() can return:

  • A scalar value (e.g., float or int or string) if the parameter or variable is scalar.
  • A dictionary where the keys are tuples of strings (representing indices) and the values are float, int, string.
  • A Arrow Table or Pandas or Polars DataFrame depending on the data_type_preference set in the Project constructor.

Example Output

Depending on you return type preference the python object returned from the .data() function will be different, the output for dictionaries can look like this:

Total Transport Cost: 150.0
Transport: {("NewYork", "Houston"): 30, ("LosAngeles", "Phoenix"): 50, ...}

for Pandas DataFrames can look like this:

Total Transport Cost: 150.0
Transport:
        w               c               transport
    0   NewYork         Houston         30
    1   LosAngeles      Phoenix         50
    2   Chicago         Philadelphia    40
    3   NewYork         Philadelphia    20

extra

it is possible to generate a stub file for your project which can greatly help with autocompletion in your IDE. This stub file contains all the identifiers in your AIMMS project and their types. You can generate this stub file by running the following command:

my_aimms.generate_stub_file( "my_project_stub.py" )

To use this stub file you can the following to the top of your python script:

from typing import TYPE_CHECKING
if TYPE_CHECKING:
    from my_project_stub import Project

License

This project is licensed under the MIT License.

Support

For questions, bug reports, or feature requests, please contact AIMMS B.V. via support. Or post an question on the AIMMS Community. We are happy to help you with any issues or questions you may have.

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

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

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

aimmspy-1.0.1.post141-cp313-cp313-win_amd64.whl (584.1 kB view details)

Uploaded CPython 3.13Windows x86-64

aimmspy-1.0.1.post141-cp313-cp313-manylinux_2_27_x86_64.whl (741.3 kB view details)

Uploaded CPython 3.13manylinux: glibc 2.27+ x86-64

aimmspy-1.0.1.post141-cp312-cp312-win_amd64.whl (584.2 kB view details)

Uploaded CPython 3.12Windows x86-64

aimmspy-1.0.1.post141-cp312-cp312-manylinux_2_27_x86_64.whl (741.8 kB view details)

Uploaded CPython 3.12manylinux: glibc 2.27+ x86-64

aimmspy-1.0.1.post141-cp311-cp311-win_amd64.whl (584.3 kB view details)

Uploaded CPython 3.11Windows x86-64

aimmspy-1.0.1.post141-cp311-cp311-manylinux_2_27_x86_64.whl (739.6 kB view details)

Uploaded CPython 3.11manylinux: glibc 2.27+ x86-64

aimmspy-1.0.1.post141-cp310-cp310-win_amd64.whl (583.3 kB view details)

Uploaded CPython 3.10Windows x86-64

aimmspy-1.0.1.post141-cp310-cp310-manylinux_2_27_x86_64.whl (738.9 kB view details)

Uploaded CPython 3.10manylinux: glibc 2.27+ x86-64

File details

Details for the file aimmspy-1.0.1.post141-cp313-cp313-win_amd64.whl.

File metadata

File hashes

Hashes for aimmspy-1.0.1.post141-cp313-cp313-win_amd64.whl
Algorithm Hash digest
SHA256 bf7bc622c3c2f094d749f74535c2a487799acd8e80835a7eceee481caaf1bf11
MD5 d188a5000d18b663cc2a81eb23a97c47
BLAKE2b-256 4b5d4208f793194cb1ad78a9cb8b5faa36f36fc3d5d028a6dc338f1f28ee55f2

See more details on using hashes here.

File details

Details for the file aimmspy-1.0.1.post141-cp313-cp313-manylinux_2_27_x86_64.whl.

File metadata

File hashes

Hashes for aimmspy-1.0.1.post141-cp313-cp313-manylinux_2_27_x86_64.whl
Algorithm Hash digest
SHA256 76210d070e0175aa9be56291b8378000f0a477af39f9633ff48997a0215f34ea
MD5 6073c307ce68af8d16427371569aa674
BLAKE2b-256 32d4d8d1954f5079e52dcbda6df937f4101a15cffa5ed9fd0d0659222af8a0a4

See more details on using hashes here.

File details

Details for the file aimmspy-1.0.1.post141-cp312-cp312-win_amd64.whl.

File metadata

File hashes

Hashes for aimmspy-1.0.1.post141-cp312-cp312-win_amd64.whl
Algorithm Hash digest
SHA256 e690219837200bcdeb3859ae19c2574f3879441f2a551ca4a61c99cdeec6d79e
MD5 e397eb9f8d8f0a7caeeafb8f7c49ceaf
BLAKE2b-256 2de00d7d1b20b89f282e3ba8ed33c9c9eda2d0b2bace47cadf840735017c7a19

See more details on using hashes here.

File details

Details for the file aimmspy-1.0.1.post141-cp312-cp312-manylinux_2_27_x86_64.whl.

File metadata

File hashes

Hashes for aimmspy-1.0.1.post141-cp312-cp312-manylinux_2_27_x86_64.whl
Algorithm Hash digest
SHA256 8bee44ac57146d860ae3dd715727811ec2bdc095410aa7f6d62b45790be5d972
MD5 6fe331a945a58b54abd160b9a9afb53a
BLAKE2b-256 8aed469a451007fdcfda767ff95d6513d9a3ccc1d66ece60008ce43c30d577a1

See more details on using hashes here.

File details

Details for the file aimmspy-1.0.1.post141-cp311-cp311-win_amd64.whl.

File metadata

File hashes

Hashes for aimmspy-1.0.1.post141-cp311-cp311-win_amd64.whl
Algorithm Hash digest
SHA256 140cb8bc33be04b85e73eb967d2a2f743315e7eff9a79f00728769b70be6f92b
MD5 30a4e8b7a50c9a01c8320057588292f8
BLAKE2b-256 156acbc0ac28291b9a0e656a693b4913542c99d32311b7bb84185593736927cb

See more details on using hashes here.

File details

Details for the file aimmspy-1.0.1.post141-cp311-cp311-manylinux_2_27_x86_64.whl.

File metadata

File hashes

Hashes for aimmspy-1.0.1.post141-cp311-cp311-manylinux_2_27_x86_64.whl
Algorithm Hash digest
SHA256 962754c7c0d8e21d58f98b9d7dba294ad03d0deb25cbba648c414f7780f4faa3
MD5 027e5860cbc36e1e6cb0a6201c2c00ce
BLAKE2b-256 86f8b72c443ef06cf08367827f51bd91c7275ed2b9af3835b8ea1320a67aa0de

See more details on using hashes here.

File details

Details for the file aimmspy-1.0.1.post141-cp310-cp310-win_amd64.whl.

File metadata

File hashes

Hashes for aimmspy-1.0.1.post141-cp310-cp310-win_amd64.whl
Algorithm Hash digest
SHA256 b148c55c9473c06f417aa41bb58a1563b71cecf7075b4a5e02514f7dba122cd3
MD5 c72025699401b6331e95e6291aaa74ce
BLAKE2b-256 79c72cf68f7c0c96ad92ef296c22ef6946fb3a8a1bd9dc342e9f58878f5e8672

See more details on using hashes here.

File details

Details for the file aimmspy-1.0.1.post141-cp310-cp310-manylinux_2_27_x86_64.whl.

File metadata

File hashes

Hashes for aimmspy-1.0.1.post141-cp310-cp310-manylinux_2_27_x86_64.whl
Algorithm Hash digest
SHA256 f7307c59d4c2aeefd7915846034ba0f5f3e335b7ae1f6ab140b2b3f064483d1d
MD5 adf84dcf70d8ce76c0167c2a70f11524
BLAKE2b-256 eab3a6760a7994b97530fdc51017637157ad010830906b3e77ac3fd9d9304337

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