Skip to main content

A collection of inverse design challenges

Project description

invrs-gym - A collection of inverse design challenges

v0.3.4

Overview

The invrs_gym package is an open-source gym containing a diverse set of photonic design challenges, which are relevant for a wide range of applications such as AR/VR, optical networking, LIDAR, and others.

Each of the challenges consists of a high-dimensional problem in which a physical structure (the photonic device) is optimized. The structure includes typically >10,000 degrees of freedom (DoF), generally including one or more arrays representing the structure or patterning of a layer, and may also include scalar variables representing e.g. layer thickness. In general, the DoF must satisfy certain constraints to be physical: thicknesses must be positive, and layer patterns must be manufacturable---they must not include features that are too small, or too closely spaced.

In general, we seek optimization techniques that reliably produce manufacturable, high-quality solutions and require reasonable compute resources. Among the techniques that could be applied are topology optimization, inverse design, and AI-guided design.

invrs_gym is intended to facilitate research on such methods within the jax ecosystem. It includes several challenges that have been used in previous works, so that researchers may directly compare their results to those of the literature. While some challenges are test problems (e.g. where the structure is two-dimensional, which is unphysical but allows fast simulation), others are actual problems that are relevant e.g. for quantum computing or 3D sensing.

Key concepts

The key types of the challenge are the Challenge and Component objects.

The Component represents the physical structure to be optimized, and has some intended excitation or operating condition (e.g. illumination with a particular wavelength from a particular direction). The Component includes methods to obtain initial parameters, and to compute the response of a component to the excitation.

Each Challenge has a Component as an attribute, and also has a target that can be used to determine whether particular parameters "solve" the challenge. The Challenge also provides functions to compute a scalar loss for use with gradient-based optimization, and additional metrics.

Example

# Select the challenge.
challenge = invrs_gym.challenges.ceviche_lightweight_waveguide_bend()

# Define loss function, which also returns auxilliary quantities.
def loss_fn(params):
    response, aux = challenge.component.response(params)
    loss = challenge.loss(response)
    distance = challenge.distance_to_target(response)
    metrics = challenge.metrics(response, params, aux)
    return loss, (response, distance, metrics, aux)

value_and_grad_fn = jax.value_and_grad(loss_fn, has_aux=True)

# Select an optimizer.
opt = invrs_opt.density_lbfgsb(beta=4)

# Generate initial parameters, and use these to initialize the optimizer state.
params = challenge.component.init(jax.random.PRNGKey(0))
state = opt.init(params)

# Carry out the optimization.
for i in range(steps):
    params = opt.params(state)
    (value, (response, distance, metrics, aux)), grad = value_and_grad_fn(params)
    state = opt.update(grad=grad, value=value, params=params, state=state)

With some plotting (see the example notebook), this code will produce the following waveguide bend:

Animated evolution of waveguide bend design

Challenges

The current list of challenges is below. Check out the notebooks for ready-to-go examples of each.

Install

pip install invrs_gym

Testing

Some tests are marked as slow and are skipped by default. To run these manually, use

pytest --runslow

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

invrs_gym-0.3.4.tar.gz (38.2 kB view details)

Uploaded Source

Built Distribution

invrs_gym-0.3.4-py3-none-any.whl (48.0 kB view details)

Uploaded Python 3

File details

Details for the file invrs_gym-0.3.4.tar.gz.

File metadata

  • Download URL: invrs_gym-0.3.4.tar.gz
  • Upload date:
  • Size: 38.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.12.1

File hashes

Hashes for invrs_gym-0.3.4.tar.gz
Algorithm Hash digest
SHA256 72b81e1e203fea704506a0163ec5404a0b34eadd24e45752bc541b988f1a6c63
MD5 5974ed886d0701c1f73e9bdbe3d1a580
BLAKE2b-256 8dc72c5126c2793f4c72b1a00c0ea65a89532bb02ba42df24e06032496430747

See more details on using hashes here.

File details

Details for the file invrs_gym-0.3.4-py3-none-any.whl.

File metadata

  • Download URL: invrs_gym-0.3.4-py3-none-any.whl
  • Upload date:
  • Size: 48.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.12.1

File hashes

Hashes for invrs_gym-0.3.4-py3-none-any.whl
Algorithm Hash digest
SHA256 c1b229e9b2db178b295edafce401f46fb3c4ae5a33263db5fbf1f68f225e63dd
MD5 f759428b4f51aadd1d8e55e1550ed65c
BLAKE2b-256 717a5fe636510c2389bbf3f1b755cb1db9f3d19cdf2f5a871b23887bf3bbd1b2

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