Skip to main content

A fast FDTD solver

Project description

Tidy3D

Notebooks tests Documentation Status PyPI version shields.io

Tidy3D is a software product from Flexcompute that enables large scale electromagnetic simulation using the finite-difference time-domain (FDTD) method.

This repository stores the python interface for Tidy3d.

This code allows you to:

  • Programmatically define FDTD simulations.
  • Submit and magange simulations running on Flexcompute's servers.
  • Download and postprocess the results from the simulations.

You can find a detailed documentation and API reference here. The source code for our documentation is here.

Installation

Signing up for tidy3d

Note that while this front end package is open source, to run simulations on Flexcompute servers requires an account with credits. You can sign up for an account here. After that, you can install the front end with the instructions below, or visit this page in our documentation for more details.

Installing the front end

To install the Tidy3D Python API locally, the following instructions should work for most users.

pip install --user tidy3d
tidy3d configure --apikey=XXX

Where XXX is your API key, which can be copied from your account page in the web interface.

If those commands did not work, advanced installation instructions are below, which should help solve the issue.

Advanced Installation Instructions

Some users might require more a specialized installation, which we cover below.

Using pip (recommended)

The easiest way to install the tidy3d python interface is through pip.

pip install tidy3d

This will install the latest stable version.

To get a specific version x.y.z, including the "pre-release" versions, you may specify the version in the command as:

pip install tidy3d==x.y.z

Installing from source

Alternatively, for development purposes, eg. developing your own features, you may download and install the package from source as:

git clone https://github.com/flexcompute/tidy3d.git
cd tidy3d
pip install -e .

Configuring and authentication

With the front end installed, it must now be configured with your account information, which is done via an "API key".

You can find your API key in the web interface. After signing in and navigating to the account page by clicking the "Account Center" icon on the left-hand side. Then, click on the "API key" tab on the right hand side of the menu and copy your API key.

Note: We refer to your API specific API key value as XXX below.

To link your API key with Tidy3D, you may use one of three following options:

Command line (recommended)

The easiest way is through the command line via the tidy3d configure command. Run:

tidy3d configure

and then enter your API key XXX when prompted.

Note that Windows users must run the following instead (ideally in an anaconda prompt):

pip install pipx
pipx run tidy3d configure

You can also specify your API key directly as an option to this command using the api-key argument, for example:

tidy3d configure --api-key=XXX

Manually

Alternatively, you can manually set up the config file where Tidy3D looks for the API key. The API key must be in a file called .tidy3d/config located in your home directory, containing the following

apikey = "XXX"

You can manually set up your file like this, or do it through the command line line:

echo 'apikey = "XXX"' > ~/.tidy3d/config

Note the quotes around XXX.

Note that Windows users will most likely need to place the .tidy3d/config file in their C:\Users\username\ directory (where username is your username).

Environment Variable

Lastly, you may set the API key as an environment variable named SIMCLOUD_APIKEY.

This can be set up using

export SIMCLOUD_APIKEY="XXX"

Note the quotes around XXX.

Testing the installation and authentication

Front end package

You can verify the front end installation worked by running:

python -c "import tidy3d as td; print(td.__version__)"

and it should print out the version number, for example:

2.0.0

Authentication

To test the authentication, you may try importing the web interface via.

python -c "import tidy3d.web"

It should pass without any errors if the API key is set up correctly.

To get started, our documentation has a lot of examples for inspiration.

Issues / Feedback / Bug Reporting

Your feedback helps us immensely!

If you find bugs, file an Issue. For more general discussions, questions, comments, anything else, open a topic in the Discussions Tab.

License

GNU LGPL

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

tidy3d-2.0.1.tar.gz (504.6 kB view details)

Uploaded Source

Built Distribution

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

tidy3d-2.0.1-py3-none-any.whl (556.6 kB view details)

Uploaded Python 3

File details

Details for the file tidy3d-2.0.1.tar.gz.

File metadata

  • Download URL: tidy3d-2.0.1.tar.gz
  • Upload date:
  • Size: 504.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.2

File hashes

Hashes for tidy3d-2.0.1.tar.gz
Algorithm Hash digest
SHA256 eed5275e7f4788a586837c78701d3bd6479efc2852f0f825eda1f4f93bb92c91
MD5 b43cda92acbfa6d993fcbff6dde38166
BLAKE2b-256 e56620aa1c0b0ec3e6e122258b8903e2427495143a86f288328069580071267c

See more details on using hashes here.

File details

Details for the file tidy3d-2.0.1-py3-none-any.whl.

File metadata

  • Download URL: tidy3d-2.0.1-py3-none-any.whl
  • Upload date:
  • Size: 556.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.2

File hashes

Hashes for tidy3d-2.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 9b3b83833d535e890c77c1967acde7abda4cbd986f29875bbf584865a9fad1d2
MD5 b6994e426f8ad8eb9410e1d841aaf2c6
BLAKE2b-256 686abc1fe9f42a1b3d74cb17c65fa25b919f62c878a94594af081e24af72b6d5

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