Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions docs/conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -168,6 +168,7 @@
"tidy3d/*",
"faq/docs/**",
"notebooks/*.ipynb",
"notebooks/**/*.ipynb",
"notebooks/docs/*",
"**.rst",
"**.png",
Expand Down
39 changes: 39 additions & 0 deletions docs/lectures/fabrication_invdes.rst
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

So if you don't want to duplicate the content you can just do an .. include:: <path/to/notebooks/docs/fabrication_aware_invdes.rst> Have you given that a shot? Technically you can consolidate the README and this into a single doc but involves correct notebook linking and checking.

Just suggesting. You probably don't have to duplicate this file at the minimum, but just proposing to give it a shot if you also want to consolidate with the README.rst.

Have you built the docs and seen it looks how you want too?

Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
Fabrication-aware inverse design
================================

.. meta::
:description: Fabrication-aware inverse design seminar notebooks and walkthrough
:keywords: tidy3d, inverse design, fabrication-aware, adjoint, grating coupler

The October 9, 2025 seminar walks through a complete dual-layer grating coupler workflow: start from a uniform baseline, pull a strong seed design with Bayesian optimization, switch to adjoint gradients for per-tooth control, study fabrication sensitivities, and close the loop with measurement-driven calibration. Everything runs inside Tidy3D, so you can rerun the exact same jobs or adapt the utilities to your own device stack.

Seminar recording: `YouTube link <https://www.youtube.com/watch?v=OpVBJmomzoo>`_

Notebook lineup
----------------
* :doc:`Setup Guide: Building the Simulation <../notebooks/2025-10-09-invdes-seminar/00_setup_guide>` - builds the nominal SiN stack, launches the reference simulation, and visualizes the initial geometry so the later notebooks can reuse the cached job ID.
* :doc:`Bayesian Optimization: Finding a Strong Baseline <../notebooks/2025-10-09-invdes-seminar/01_bayes>` - uses a five-parameter Bayesian search to quickly find a good uniform grating. This provides a practical baseline before investing in gradients.
* :doc:`Adjoint Optimization: High-Dimensional Refinement <../notebooks/2025-10-09-invdes-seminar/02_adjoint>` - expands to per-tooth parameters and applies Adam with adjoint sensitivities to apodize the grating and boost efficiency.
* :doc:`Fabrication Sensitivity Analysis: Is Our Design Robust? <../notebooks/2025-10-09-invdes-seminar/03_sensitivity>` - sweeps :math:`\pm 20` nm etch bias, runs Monte Carlo samples, and logs adjoint-derived sensitivity units (:math:`\Delta` objective / :math:`\Delta` parameter) so readers understand what the gradients mean physically.
* :doc:`Robust Adjoint Optimization for Manufacturability <../notebooks/2025-10-09-invdes-seminar/04_adjoint_robust>` - penalizes variance across nominal/over/under corners, illustrating a fabrication-aware adjoint loop that matches what we demoed live.
* :doc:`Monte Carlo View: Nominal vs Robust Grating <../notebooks/2025-10-09-invdes-seminar/05_robust_comparison>` - reruns the Monte Carlo campaign for both nominal and robust devices to quantify yield improvements.
* :doc:`Measurement Calibration: Bridging Simulation and Fabrication <../notebooks/2025-10-09-invdes-seminar/06_measurement_calibration>` - demonstrates gradient-based calibration of tooth widths against (synthetic) spectra, using adjoint sensitivities to recover the as-fabricated geometry from optical measurements.

Getting the code
----------------
The notebooks are available in the `Tidy3D notebooks repository <https://github.com/flexcompute/tidy3d-notebooks/tree/develop/2025-10-09-invdes-seminar>`_. You will need the ``.ipynb`` files as well as the helper scripts `setup.py <https://github.com/flexcompute/tidy3d-notebooks/blob/develop/2025-10-09-invdes-seminar/setup.py>`_ and `optim.py <https://github.com/flexcompute/tidy3d-notebooks/blob/develop/2025-10-09-invdes-seminar/optim.py>`_ to run the examples.

How to run the series
---------------------
1. Install ``tidy3d`` and ``bayesian-optimization`` (``pip install tidy3d bayesian-optimization``) and configure your API key.
2. Execute the notebooks in order; each step writes results into ``results/`` and later notebooks assume those JSON files exist.

Supporting assets
-----------------
* `setup.py <https://github.com/flexcompute/tidy3d-notebooks/blob/develop/2025-10-09-invdes-seminar/setup.py>`_ - shared simulation builders, fabrication constraints, and helper functions.
* `optim.py <https://github.com/flexcompute/tidy3d-notebooks/blob/develop/2025-10-09-invdes-seminar/optim.py>`_ - a lightweight, autograd-friendly Adam implementation with parameter clipping.
* ``results/`` - JSON checkpoints (Bayes best point, adjoint refinements, robust design) consumed by subsequent notebooks.




12 changes: 12 additions & 0 deletions docs/lectures/fabrication_invdes_notebooks.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
:orphan:

.. toctree::

../notebooks/2025-10-09-invdes-seminar/00_setup_guide
../notebooks/2025-10-09-invdes-seminar/01_bayes
../notebooks/2025-10-09-invdes-seminar/02_adjoint
../notebooks/2025-10-09-invdes-seminar/03_sensitivity
../notebooks/2025-10-09-invdes-seminar/04_adjoint_robust
../notebooks/2025-10-09-invdes-seminar/05_robust_comparison
../notebooks/2025-10-09-invdes-seminar/06_measurement_calibration

2 changes: 2 additions & 0 deletions docs/lectures/index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,10 @@ Welcome to our lecture series!
fdtd101
fdtd_workshop
inversedesign
fabrication_invdes


.. include:: /lectures/fdtd101.rst
.. include:: /lectures/fdtd_workshop.rst
.. include:: /lectures/inversedesign.rst
.. include:: /lectures/fabrication_invdes.rst
2 changes: 1 addition & 1 deletion docs/notebooks
Submodule notebooks updated 127 files