Skip to main content

A fast FDTD solver

Reason this release was yanked:

tidy3d should be installed moving forward from 'tidy3d' on PyPI. 'tidy3d-beta' will no longer be supported.

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


Download files

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

Source Distribution

tidy3d-beta-2.0.0.tar.gz (506.2 kB view details)

Uploaded Source

Built Distribution

tidy3d_beta-2.0.0-py3-none-any.whl (556.7 kB view details)

Uploaded Python 3

File details

Details for the file tidy3d-beta-2.0.0.tar.gz.

File metadata

  • Download URL: tidy3d-beta-2.0.0.tar.gz
  • Upload date:
  • Size: 506.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.9

File hashes

Hashes for tidy3d-beta-2.0.0.tar.gz
Algorithm Hash digest
SHA256 88d8f570ae1a3e471656a8b251d38a935b3a502be8c80f654368cd7b7ab89935
MD5 022694e17b7ac8c12e84e218e5d4fcac
BLAKE2b-256 e53197c29c937ff24ff1cc0532d45538decf71a9181d50691bd1ca42f7cfa277

See more details on using hashes here.

File details

Details for the file tidy3d_beta-2.0.0-py3-none-any.whl.

File metadata

  • Download URL: tidy3d_beta-2.0.0-py3-none-any.whl
  • Upload date:
  • Size: 556.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.9

File hashes

Hashes for tidy3d_beta-2.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 9e3f472141a3643250d417046e769456b5c3909066e17e65c2aaa0c98f847def
MD5 bb2369bb44728e9ea5e65f8aaef4ad96
BLAKE2b-256 46fc9010fc57febed70e103aa2bbd403425ddbaba4823fe85efde651764154c2

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