Skip to main content

Device Modeling Toolkit Core

Project description

DMT-core

pyversion Build Status Coverage Code style: black status

logo

DeviceModelingToolkit (DMT) is a Python tool targeted at helping modeling engineers extract model parameters, run circuit and TCAD simulations and automate their infrastructure.

See the DMT-website for further information.

This project is funded by NLnet under the NGI Zero Entrust fund.

Usage

Installation to virtual environment

After installing python 3.8 or later, create a virtual environment and install the release version using

    python3 -m pip install DMT-core[full]

For more information have a look at our installation guide

Currently, DMT is developed mostly on Ubuntu using Python 3.10. So for the easiest install this is the best supported platform. If you want or have to use Windows and MacOS there may be more dependency and installation issues, although needed projects we use support these platforms. Please report these issues to us. In our installation guide, we collect guides to solve the already known issues.

Full docker container

DMT is tested inside a docker container and this container can be used to run python/DMT scripts locally on your machine. See docker/dmt for an example bash script to run a file. Notice the configuration, this is needed so that simulation results and read measurement files persist on your host machine and do not vanish each time the container is closed.

For more information have a look at our docker guide

Questions, bugs and feature requests

If you have any questions or issues regarding DMT, we kindly ask you to contact us. Either mail us directly or open an issue here. There we have prepared several templates for the description:

Authors

Contributing

More contributors and merge-requests are always welcome. When contributing to this repository, please first discuss the change you wish to make via issue, email, or any other method with the owners of this repository before making a change.

Contact Markus or Mario, if you are interested to join the team permanently.

Pull Request Process

If you want to supply a new feature, you have implemented in your fork, to DMT, we are looking forward to your merge request. There we have a template for the merge request, including a checklist of suggested steps.

The steps are:

  1. Implement the new feature
  2. Add test cases for the new feature with a large coverage
  3. Add new python dependencies to setup.py
  4. If a interface is used, add a Dockerfile in which the interfaced software is installed and run the tests inside this Dockerfile
  5. Add additional documentation to the new features you implemented in the code and the documentation.
  6. Format the code using black
  7. Update the CHANGELOG with your changes and increase the version numbers in the changed files to the new version that this Pull Request would represent. The versioning scheme we use is SemVer.

License

This project is licensed under GLP-v3-or-later

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

DMT_core-2.1.0.tar.gz (223.8 kB view hashes)

Uploaded Source

Built Distribution

DMT_core-2.1.0-py3-none-any.whl (258.8 kB view hashes)

Uploaded Python 3

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