tidy3d.plugins.invdes.InverseDesign#

class InverseDesign[source]#

Bases: AbstractInverseDesign

Container for an inverse design problem.

Parameters:
  • design_region (TopologyDesignRegion) – Region within which we will optimize the simulation.

  • task_name (str) – Task name to use in the objective function when running the JaxSimulation.

  • verbose (bool = False) – If True, will print the regular output from web functions.

  • metric (Optional[Union[Union[Add, Subtract, Multiply, Divide, Power, Modulus, FloorDivide, MatMul, Negate, Abs], Union[Sin, Cos, Tan, Exp, Log, Log10, Sqrt], Union[Constant, Variable, ModeAmp, ModePower]]] = None) – Serializable expression defining the objective function.

  • simulation (Simulation) – Simulation without the design regions or monitors used in the objective fn.

  • output_monitor_names (Optional[tuple[str, ...]] = None) – Optional names of monitors whose data the differentiable output depends on.If this field is left None, the plugin will try to add all compatible monitors automatically. While this will work, there may be warnings if certain monitor types are not fully supported, for example FieldMonitor instances with .colocate != False.

Attributes

simulation

output_monitor_names

design_region

task_name

verbose

metric

Methods

is_output_monitor(monitor)

Whether a monitor is added to the JaxSimulation as an output_monitor.

separate_output_monitors(monitors)

Separate monitors into output_monitors and regular monitors.

to_simulation(params)

Convert the InverseDesign to a corresponding td.Simulation with traced fields.

to_simulation_data(params, **kwargs)

Convert the InverseDesign to a td.Simulation and run it.

simulation#
output_monitor_names#
is_output_monitor(monitor)[source]#

Whether a monitor is added to the JaxSimulation as an output_monitor.

separate_output_monitors(monitors)[source]#

Separate monitors into output_monitors and regular monitors.

to_simulation(params)[source]#

Convert the InverseDesign to a corresponding td.Simulation with traced fields.

to_simulation_data(params, **kwargs)[source]#

Convert the InverseDesign to a td.Simulation and run it.