Skip to main content

solving constrained optimization problem for the design of engineering systems

Project description

NoLOAD_Jax: Non Linear Optimization by Automatic Differentiation using Jax

We are happy that you will use or develop the NoLOAD_Jax. It is an Open Source project located on GitLab at https://gricad-gitlab.univ-grenoble-alpes.fr/design_optimization/NoLoad_v2 It aims at solving constrained optimization problem for the design of engineering systems

Project Presentation

NoLOAD_Jax: Please have a look to NoLOAD presentation : https://noload-jax.readthedocs.io/en/latest/

A scientific article presenting NoLOAD is available here:

Agobert Lucas, Hodencq Sacha, Delinchant Benoit, Gerbaud Laurent, Frederic Wurtz, “NoLOAD, Open Software for Optimal Design and Operation using Automatic Differentiation”, OIPE 2020, Poland, 09-2021. https://hal.archives-ouvertes.fr/hal-03352443

Please cite us when you use NoLOAD.

NoLOAD_Jax Community

Please use the git issues system to report an error: https://gricad-gitlab.univ-grenoble-alpes.fr/design_optimization/NoLoad_v2 Otherwise you can also contact the developer team using the following email adress: benoit.delinchant@G2ELab.grenoble-inp.fr

Installation Help

You can install the library as a user or as a developer. Please follow the corresponding installation steps below.

Prerequisite

Please install Python 3.8 or later https://www.python.org/downloads/

Installation as a user

Please install NoLOAD_Jax with pip using the command prompt.

If you are admin on Windows or working on a virtual environment

pip install noloadj

If you want a local installation or you are not admin

pip install --user noloadj

If you are admin on Linux:

sudo pip install noloadj

Launch the examples to understand how the NoLOAD_Jax works:

python noloadj/01-UnconstrainedMonoObjective.py
python noloadj/02-ConstrainedMonoObjective.py
python noloadj/03-ConstrainedMultiObjective.py
python noloadj/04-ConstrainedMonoObjective2.py

Enjoy your time using NoLOAD_Jax !

GPU

As it uses the JAX library, NoLOAD_Jax can run on CPU (Central Processor Unit) or GPU (Graphics Processor Unit), where GPU offers better performances than CPU. On Windows, only CPU can be used. To use GPU you may run NoLOAD on Ubuntu. If you want to use GPU, you need to install CUDA and CuDNN on your computer then tape on Pycharm terminal (where 0.3.XX is your JAX version):

pip install --upgrade pip
pip install --upgrade jax jaxlib==0.3.XX+cuda111 -f https://storage.googleapis.com/jax-releases/jax_releases.html

If you use GPU, you need to put these lines at the beginning of your "optimization" file to avoid memory issues :

import os
os.environ['XLA_PYTHON_CLIENT_PREALLOCATE']='false'
os.environ['XLA_PYTHON_CLIENT_MEM_FRACTION']='0.50'

To have more information, please have a look to : https://jax.readthedocs.io/en/latest/installation.html

IPOPT Algorithm

NoLOAD_Jax runs with SLSQP optimization algorithm from Scipy. To install IPOPT algorithm, please install an Anaconda environment and run this command on a terminal :

conda install -c conda-forge cyipopt

Library Installation Requirements

Matplotlib >= 3.0 Scipy >= 1.2 Jax >= 0.4.18 Jaxlib >= 0.4.18 Pandas >= 1.3.5 tk >= 0.1.0 openpyxl >= 3.1.2

Main Authors:

B. DELINCHANT, L. GERBAUD, F. WURTZ, L. AGOBERT

Partners:

Vesta-System: http://vesta-system.fr/

Acknowledgments:

Licence

This code is under the Apache License, Version 2.0

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

noloadj-1.2.9.tar.gz (68.2 kB view details)

Uploaded Source

Built Distribution

noloadj-1.2.9-py3-none-any.whl (62.1 kB view details)

Uploaded Python 3

File details

Details for the file noloadj-1.2.9.tar.gz.

File metadata

  • Download URL: noloadj-1.2.9.tar.gz
  • Upload date:
  • Size: 68.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.0

File hashes

Hashes for noloadj-1.2.9.tar.gz
Algorithm Hash digest
SHA256 5fbf3fc83b01b4a41f234ea50219d7be96ec05b6b1566b65238b37b22c0445b8
MD5 4434e4ddd62e2ec04fcb22613ba6e8a7
BLAKE2b-256 bc2be8774f23f5666550754fe927dbdf38e850ea78a044148522fed24667848f

See more details on using hashes here.

File details

Details for the file noloadj-1.2.9-py3-none-any.whl.

File metadata

  • Download URL: noloadj-1.2.9-py3-none-any.whl
  • Upload date:
  • Size: 62.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.0

File hashes

Hashes for noloadj-1.2.9-py3-none-any.whl
Algorithm Hash digest
SHA256 e87367bec728720d29cac426d197c7ef649c9f977d11370a90e91f2ea4e22eaf
MD5 b4098fc338ef97bbd797480f9131c72e
BLAKE2b-256 9743b15079d2eee2a390e6429e307c4a083a67340df5e1f49c25bc478fafc09b

See more details on using hashes here.

Supported by

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