https://github.com/ansys/pysimai
A Python wrapper for Ansys SimAI
https://github.com/ansys/pysimai
Last synced: about 1 month ago
JSON representation
A Python wrapper for Ansys SimAI
- Host: GitHub
- URL: https://github.com/ansys/pysimai
- Owner: ansys
- License: mit
- Created: 2023-12-19T15:05:47.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-08-01T00:17:10.000Z (10 months ago)
- Last Synced: 2024-08-01T13:49:37.779Z (10 months ago)
- Language: Python
- Homepage: http://simai.docs.pyansys.com/
- Size: 2.8 MB
- Stars: 7
- Watchers: 5
- Forks: 1
- Open Issues: 7
-
Metadata Files:
- Readme: README.rst
- Changelog: CHANGELOG.rst
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Authors: AUTHORS
Awesome Lists containing this project
README
PySimAI
=======
|pyansys| |python| |pypi| |GH-CI| |codecov| |MIT| |ruff|.. |pyansys| image:: https://img.shields.io/badge/Py-Ansys-ffc107.svg?logo=
:target: https://docs.pyansys.com/
:alt: PyAnsys.. |python| image:: https://img.shields.io/pypi/pyversions/ansys-simai-core?logo=pypi
:target: https://pypi.org/project/ansys-simai-core/
:alt: Python.. |pypi| image:: https://img.shields.io/pypi/v/ansys-simai-core.svg?logo=python&logoColor=white
:target: https://pypi.org/project/ansys-simai-core
:alt: PyPI.. |codecov| image:: https://codecov.io/gh/ansys/pysimai/branch/main/graph/badge.svg
:target: https://codecov.io/gh/ansys/pysimai
:alt: Codecov.. |GH-CI| image:: https://github.com/ansys/pysimai/actions/workflows/ci_cd.yml/badge.svg
:target: https://github.com/ansys/pysimai/actions/workflows/ci_cd.yml
:alt: GH-CI.. |MIT| image:: https://img.shields.io/badge/License-MIT-yellow.svg
:target: https://opensource.org/licenses/MIT
:alt: MIT.. |ruff| image:: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/astral-sh/ruff/main/assets/badge/v2.json
:target: https://github.com/astral-sh/ruff
:alt: RuffA Python wrapper for Ansys SimAI
How to install
--------------At least two installation modes are provided: user and developer.
For users
^^^^^^^^^In order to install PySimAI, make sure you
have the latest version of `pip`_. To do so, run:.. code:: bash
python -m pip install -U pip
Then, you can simply execute:
.. code:: bash
python -m pip install ansys-simai-core
For developers
^^^^^^^^^^^^^^Installing PySimAI in developer mode allows
you to modify the source and enhance it.Before contributing to the project, please refer to the `PyAnsys Developer's guide`_. You will
need to follow these steps:#. Start by cloning this repository:
.. code:: bash
git clone https://github.com/ansys/pysimai
#. `Install PDM `_. NB: If you are a Windows user, make sure that Python is installed on your system and it is added to the Path.
#. Use PDM to create a virtual env with the dependencies and activate it
* For Linux/Mac:
.. code:: bash
pdm install
eval $(pdm venv activate)* For Windows:
.. code:: shell
pdm install
Invoke-Expression (pdm venv activate)#. Finally, verify your development installation by running:
.. code:: bash
python -m pip install tox
toxHow to test
-----------This project takes advantage of `tox`_. This tool allows to automate common
development tasks (similar to Makefile) but it is oriented towards Python
development.Using tox
^^^^^^^^^As Makefile has rules, `tox`_ has environments. In fact, the tool creates its
own virtual environment so anything being tested is isolated from the project in
order to guarantee project's integrity. The following environments commands are provided:- **tox -e style**: will check for coding style quality.
- **tox -e py**: checks for unit tests.
- **tox -e py-coverage**: checks for unit testing and code coverage.
- **tox -e doc**: checks for documentation building process.Raw testing
^^^^^^^^^^^If required, you can always call the style commands (`ruff`_) or unit testing ones (`pytest`_) from the command line. However,
this does not guarantee that your project is being tested in an isolated
environment, which is the reason why tools like `tox`_ exist.A note on pre-commit
^^^^^^^^^^^^^^^^^^^^The style checks take advantage of `pre-commit`_. Developers are not forced but
encouraged to install this tool via:.. code:: bash
python -m pip install pre-commit && pre-commit install
Documentation
-------------For building documentation, you can either run the usual rules provided in the
`Sphinx`_ Makefile, such as:.. code:: bash
make -C doc/ html && open doc/html/index.html
However, the recommended way of checking documentation integrity is using:
.. code:: bash
tox -e doc && open .tox/doc_out/index.html
Distributing
------------PDM commands can help you build or publish the package
.. code:: bash
pdm build
pdm publish.. LINKS AND REFERENCES
.. _ruff: https://github.com/astral-sh/ruff
.. _pip: https://pypi.org/project/pip/
.. _pre-commit: https://pre-commit.com/
.. _PyAnsys Developer's guide: https://dev.docs.pyansys.com/
.. _pytest: https://docs.pytest.org/en/stable/
.. _Sphinx: https://www.sphinx-doc.org/en/master/
.. _tox: https://tox.wiki/