Skip to content

a simple tool for simulating trapped ion systems

License

Notifications You must be signed in to change notification settings

kdbarajas/IonSim.jl

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Build Status codecov License: MIT Twitter

A simple tool, built on top of QuantumOptics.jl, for simulating the dynamics of a configuration of trapped ions interacting with laser light.

IonSim.jl primarily performs two jobs:

  1. Keeps track of the physical parameters necessary for describing the system.
  2. Using these parameters, constructs a function that quickly computes the system's Hamiltonian as a function of time.

The functional form of the Hamiltonian can then be used as input to any of the solvers implemented in QuantumOptics.timeevolution. For more information see:

If you have an idea for how to improve IonSim, need some help getting things working or have any other IonSim-related questions feel free to open a GitHub issue.

How to use

  1. Install Julia (instructions here).
  2. Open up a Terminal session and fire up the Julia REPL with
$ julia

(If using Windows it's easier to start a REPL with the julia executable available after installation.)

  1. Now run
julia> using Pkg
julia> Pkg.add("IonSim")
julia> Pkg.add("IJulia")

The last line adds Jupyter compatibility, so you'll have the option to start a Julia kernel from Jupyter notebook.

Updating IonSim

IonSim.jl is a work in progress. You can update your local code to the most recent version with the following:

julia> using Pkg
julia> Pkg.update("IonSim")

Extra Linux notes

  • Extract the downloaded file
  • copy to /opt with:
$ sudo cp -r julia-1.3.1 /opt/

(replacing julia-1.3.1 with the appropriate version)

  • then create a symbolic link in /usr/local/bin with
$ sudo ln -s /opt/julia-1.3.1/bin/julia /usr/local/bin/julia

Development

If you want to run IonSim locally:

  • Open up the Julia REPL
$ julia
  • Open the package manager by pressing ]
  • Run the following:
pkg> dev IonSim

This will clone a version of this repo in ~/.julia/dev/IonSim/. Then when you make changes to that repo, it will be immediately reflected when using Julia.

You can run tests with

pkg> test IonSim

To go back to the version in the registry, use

pkg> free IonSim

If you have any questions, please make a GitHub issue.

About

a simple tool for simulating trapped ion systems

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Julia 100.0%