Skip to main content

A Modelica to computer algebra system (CAS) translator.

Project description

Pymoca

A Modelica to computer algebra system (CAS) translator written in Python.

CI Coverage DOI

Overview

Pymoca can be used in applications that need to translate Modelica mathematical models into other forms. Pymoca can "flatten" a model containing a connected set of components defined by object-oriented Modelica classes into a set of variables and simultaneous equations that are easier to further process for analysis or simulation. It is particularly suited to provide Modelica models in symbolic form to computer algebra systems. A common use in this context is to provide differential and algebraic equations for use in optimal control problems. Pymoca can translate Modelica to CasADi, SymPy, and ModelicaXML, but most development and usage has been with CasADi.

Install

For parser support without backend dependencies:

pip install pymoca

Other options are:

pip install "pymoca[casadi]"    # CasADi backend dependencies
pip install "pymoca[sympy]"     # SymPy backend dependencies
pip install "pymoca[lxml]"      # ModelicaXML backend dependencies

pip install "pymoca[examples]"  # To run Jupyter notebook examples in the repo

pip install "pymoca[all]"       # All of the above

Usage

Pymoca reads and understands Modelica code (pymoca.parser) and provides access to an internal representation of the code called an Abstract Syntax Tree or AST (pymoca.ast). The AST is further processed to generate output in various formats (pymoca.backends). The pymoca.tree module provides functionality to transform the AST into a form that can be more easily used by the backends to generate the target output. In particular, pymoca.tree provides classes and functions to convert a hierarchical, object-oriented Modelica model of connected components into a "flat" system of equations and associated variables, parameters, and constants. Pymoca error checking is not always complete or easy to understand, so it is better to develop the Modelica code with other tools and then use Pymoca for translation.

The test suite contains examples showing how to use Pymoca and the subset of Modelica that it currently supports.

Here is an example using a simple spring and damper model from the test suite:

from pprint import pprint

import pymoca.parser
import pymoca.backends.casadi.generator as casadi_backend


MODELICA_MODEL = """
model Spring
    Real x, v_x;
    parameter Real c = 0.1;
    parameter Real k = 2;
equation
    der(x) = v_x;
    der(v_x) = -k*x - c*v_x;
end Spring;
"""

print("Modelica Model:\n", MODELICA_MODEL)

print("\nEquations from the parsed AST in a JSON representation:")
ast = pymoca.parser.parse(MODELICA_MODEL)
pprint(ast.to_json(ast.classes["Spring"].equations))

print("\nGenerated CasADi model:")
casadi_model = casadi_backend.generate(ast, "Spring")
print(casadi_model)

Some more interesting examples are in Jupyter notebooks:

Roadmap

See the GitHub Projects for plans. In particular, see the Info Panel in the Modelica Flattening project for an overview of a project getting some current focus. Breaking API changes are expected.

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

pymoca-0.11.1.tar.gz (123.7 kB view details)

Uploaded Source

Built Distribution

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

pymoca-0.11.1-py3-none-any.whl (126.8 kB view details)

Uploaded Python 3

File details

Details for the file pymoca-0.11.1.tar.gz.

File metadata

  • Download URL: pymoca-0.11.1.tar.gz
  • Upload date:
  • Size: 123.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.13.1

File hashes

Hashes for pymoca-0.11.1.tar.gz
Algorithm Hash digest
SHA256 620c105cd35b31b438965fc5c63dd7e5ea5e038279ee2e11498e23900448efd2
MD5 0d723effb45918a2f4488625a4fca02f
BLAKE2b-256 c5e3ef4f1a167a5562d848072ebf27c2a0ed4bad4cbd5a26cf3f890adaf5e50e

See more details on using hashes here.

File details

Details for the file pymoca-0.11.1-py3-none-any.whl.

File metadata

  • Download URL: pymoca-0.11.1-py3-none-any.whl
  • Upload date:
  • Size: 126.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.13.1

File hashes

Hashes for pymoca-0.11.1-py3-none-any.whl
Algorithm Hash digest
SHA256 d1af0894344a241d5d05470e9590340ddf5aa12c14e70a7973bce5fd275a86cc
MD5 662710cc3f974f3f71e9d689bf4eeb9a
BLAKE2b-256 3507dadf97b6b5bcb0d0bb97b0d1d09216de370b66c4fc3da9fe2086e4a02da7

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