Skip to main content

A package for refractive index values.

Project description

PyOptik is a powerful Python tool designed to import refractive indexes and extinction coefficients for various materials across different wavelengths. The data provided by PyOptik can be used in numerous applications, including simulating light interactions with particles. All data is sourced from the reputable RefractiveIndex.INFO database.

Logo

python docs PyPi PyPi_download Unittest coverage

Features

  • Comprehensive Database Access: Seamlessly import refractive index and extinction coefficient data for a wide range of materials.

  • Simulation Ready: Ideal for light-matter interaction simulations, particularly in optics and photonics.

  • Simple API: Easy-to-use API that integrates well with other Python libraries.

  • Open Source: Fully open-source.

Installation

To install PyOptik, simply use pip:

pip install pyoptik

Usage

After installing PyOptik, you can easily access material properties:

from PyOptik import UsualMaterial

# Access the refractive index of BK7 glass
bk7 = UsualMaterial.BK7
n = bk7.compute_refractive_index(0.55e-6)
print(f"Refractive index at 0.55 µm: {n}")

# Accessing and plotting material properties
bk7.plot(wavelength_range=[0.3e-6, 2.5e-6])

Example

Here’s a quick example demonstrating how to use PyOptik to retrieve and plot the refractive index of a material:

import numpy as np
from PyOptik import UsualMaterial

# Define wavelength range
wavelengths = np.linspace(0.3e-6, 2.5e-6, 100)

# Retrieve refractive index for BK7 glass
bk7 = UsualMaterial.BK7
n_values = bk7.compute_refractive_index(wavelengths)

# Plot the results
bk7.plot(wavelength_range=wavelengths)

Testing

To test locally after cloning the GitHub repository, install the dependencies and run the tests:

git clone https://github.com/MartinPdeS/PyOptik.git
cd PyOptik
pip install .
pytest

Contributing

PyOptik is open to contributions. Whether you’re fixing bugs, adding new features, or improving documentation, your help is welcome! Please feel free to fork the repository and submit pull requests.

Contact Information

As of 2024, PyOptik is still under development. If you would like to collaborate, it would be a pleasure to hear from you. Contact me at:

Author: Martin Poinsinet de Sivry-Houle

Email: martin.poinsinet.de.sivry@gmail.com

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

pyoptik-1.1.7.post0.tar.gz (562.1 kB view details)

Uploaded Source

Built Distribution

PyOptik-1.1.7.post0-py3-none-any.whl (41.8 kB view details)

Uploaded Python 3

File details

Details for the file pyoptik-1.1.7.post0.tar.gz.

File metadata

  • Download URL: pyoptik-1.1.7.post0.tar.gz
  • Upload date:
  • Size: 562.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.9.19

File hashes

Hashes for pyoptik-1.1.7.post0.tar.gz
Algorithm Hash digest
SHA256 1f5052216c5744090c58bbc6b5b61cbdcd2ccdccbc5295275c40ed06d1e2ab4f
MD5 e8867b19c81a2c46d1bfb875d9c62c96
BLAKE2b-256 2660fc61a0e0bae72897e38c7291b2345a1829b2dde9a91b72c134e94b8c5740

See more details on using hashes here.

File details

Details for the file PyOptik-1.1.7.post0-py3-none-any.whl.

File metadata

File hashes

Hashes for PyOptik-1.1.7.post0-py3-none-any.whl
Algorithm Hash digest
SHA256 e9cc6af7aed6a615932547f771255bbe4d9b637880a9c2ffc4930f51bac258e1
MD5 6225078f928375ece2c77e462793fff8
BLAKE2b-256 a5ed94ccebf6bfdc3c276a66c60c1e04c04f494af15446fcc6cccd2265539e40

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