Skip to main content

Python library for describing time-dependent laserfields by Johannes Feist.

Project description

laserfields

laserfields is a library to describe the time-dependent electric fields of a laser pulse. It implements the same pulse shapes and most of the features of the laserfields library written in Fortran. Please see the documentation of that library for the parameter meanings, conventions used, etc. In particular, the "main" function make_laserfield(**kwargs...) accepts the same parameters as the Fortran library parameter files as keyword arguments, and returns an instance of a subtype of the base class LaserField depending on the parameters. E.g., to create a Gaussian pulse with a duration (defined as the FWHM of the intensity) of 6 fs, a wavelength of 800 nm, a peak intensity of 1e14 W/cm^2, and with the peak at time t=7fs, one should call

lf = make_laserfield(form="gaussianI", is_vecpot=true, lambda_nm=800,
                      intensity_Wcm2=1e16, duration_as=6000, peak_time_as=7000)

Given a LaserField instance lf, the functions lf.E(t), lf.E_fourier(ω), lf.A(t), and lf.A_fourier(ω) can be used to obtain, respectively, the electric field as a function of time, its Fourier transform (implemented for most pulse shapes), the vector potential as a function of time, and its Fourier transform. Calling the instance as a function, lf(t) returns the electric field, i.e., is equivalent to lf.E(t). The notebooks in the examples folder show some ways to use the library, including how to define a set of fields through a YAML configuration file.

The "effective" duration of the pulse for n-photon processes can be obtained as lf.Teff(n_photon), which is the integral over the pulse intensity envelope to the n-th power (i.e., electric field intensity envelope to the (2n)th power) over the pulse, see, e.g., https://doi.org/10.1103/PhysRevA.77.043420 (Eq. 14).

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

laserfields-0.2.1.tar.gz (1.9 MB view details)

Uploaded Source

Built Distribution

laserfields-0.2.1-py3-none-any.whl (8.1 kB view details)

Uploaded Python 3

File details

Details for the file laserfields-0.2.1.tar.gz.

File metadata

  • Download URL: laserfields-0.2.1.tar.gz
  • Upload date:
  • Size: 1.9 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.28.2

File hashes

Hashes for laserfields-0.2.1.tar.gz
Algorithm Hash digest
SHA256 90d61f3e26482b581fc2083309b978ac8337ea285eeadcf63cf056a55e9949fd
MD5 aa6d9eaf5940a702ee54506675239882
BLAKE2b-256 5d42d14206c026ca09cf996b4446cc9f2ea9ead8b778e5e675e006551eb40a31

See more details on using hashes here.

File details

Details for the file laserfields-0.2.1-py3-none-any.whl.

File metadata

File hashes

Hashes for laserfields-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 e82a62cf9a937133ec236400c6919815f84a0882413840f98690c581443db9d0
MD5 a9b02107604743e255e6ef0ec9906902
BLAKE2b-256 b174c0b362ee8454e0dc5cd874a4b618c2280086a9f2ab15ca4b738fbb49ff60

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