Skip to main content

Algorithms for universal interferometers

Project description

Interferometer package

The ability to implement arbitrary interference between any number of optical inputs is useful for both classical and quantum optics. This package provides implementations of the following two papers:

  • Reck, Michael, et al. "Experimental realization of any discrete unitary operator." Physical review letters 73.1 (1994): 58.
  • Clements, William R., et al. "Optimal design for universal multiport interferometers." Optica 3.12 (2016): 1460-1465.

These papers show how any interfometer can be implemented by triangular or square meshes of 2x2 beam splitters, which are experimentally simple to fabricate.

This package also includes the following features:

  • a function to generate Haar-random unitary matrices of any size
  • a method for drawing interferometers using matplotlib
  • a method for building up interferometers one beam splitter at a time

Installation

This package requires python 3, and apart from the tests and the demo notebook only numpy and matplotlib are required. You can install this package with:

pip install interferometer

Examples

A demonstration notebook can be found in the notebook folder. Alternatively, you can try the following code snippet that produces a 5x5 random unitary matrix U describing an interferometer, and determines how this interferometer can be implemented using a square mesh of beam splitters.

import interferometer as itf

U = itf.random_unitary(5)
I = itf.square_decomposition(U)
I.draw()

Testing

You can run the tests from the root directory with

pip install pytest
python -m pytest

Contributing

If you want to add new features to this package, feel free to suggest pull requests!

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

interferometer-1.1.2.tar.gz (6.0 kB view details)

Uploaded Source

Built Distribution

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

interferometer-1.1.2-py3-none-any.whl (6.4 kB view details)

Uploaded Python 3

File details

Details for the file interferometer-1.1.2.tar.gz.

File metadata

  • Download URL: interferometer-1.1.2.tar.gz
  • Upload date:
  • Size: 6.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.5

File hashes

Hashes for interferometer-1.1.2.tar.gz
Algorithm Hash digest
SHA256 604709b4824375d1bca6777bd8d6d83ae17c5bb80106b53eb9c77645b31dca8d
MD5 78576493f74e730bb8352e962646b25e
BLAKE2b-256 6a35e6855d6ec13f026d7f2927fabdc2fbbf6ede42adf7303df4394168b1e981

See more details on using hashes here.

File details

Details for the file interferometer-1.1.2-py3-none-any.whl.

File metadata

  • Download URL: interferometer-1.1.2-py3-none-any.whl
  • Upload date:
  • Size: 6.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.5

File hashes

Hashes for interferometer-1.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 9f6af79fb32b9f254b1f36988a24a37b9a417a8e60c7c49a81a17c2e98eb951c
MD5 e8453f17a2af3588e1c6a0f4c1bed6b5
BLAKE2b-256 898fc8910668c3caae9fef15c4efec291a957b20cf22bfba5f83d53de767a984

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