Status | Documentation | License | Build |
---|---|---|---|
OITOOLS is a Julia package to read, plot, model-fit and image optical interferometric data coming from astronomical arrays such as CHARA, VLTI, and NPOI. Note that despite having the same name as JMMC's oitools, they are completely unrelated and were developed independently.
If you're new to Julia, you may want to install OITOOLS and its dependencies without learning about activate/instantiate. You will only have to do this one.
using Pkg;
pkg"registry add General" # if not yet any registries
pkg"registry add https://github.com/emmt/EmmtRegistry"
Pkg.add(url="https://github.com/fabienbaron/OIFITS.jl", rev="t4");
Pkg.add(url="https://github.com/fabienbaron/OITOOLS.jl.git")
# Then check everything got installed properly
using OITOOLS
-
Load and filter data on the fly: split by spectral channel or time
-
All the classic plots: uv coverage, V2, T3, etc. by baseline or wavelengths
uv coverage | V2 |
---|---|
- Classic image reconstruction
-
Polychromatic and dynamical imaging with several regularizations
-
The ROTIR package uses OITOOLS to do stellar surface imaging with:
- light curve inversion
- Doppler imaging
- interferometric imaging
-
Fast multiple component fitting.
-
Polychromatic models
- Power and black-body laws
- Spectral line fitting
- Add your own laws!
-
Dynamical models (time variable parameters)
-
Optimization with several libraries
- Levenberg for classic error analysis
- NLOpt for flexibility in the parameter search (local and global optimizers including Nelder Mead and Genetic Algorithm)
- UltraNest for Bayesan model selection
-
Derive boostrap errors
- Boostrap by baseline, time, or wavelengths
-
Quickly make images from models.
ASPRO-like Gantt chart | chara_plan-like plots |
---|---|
-
Can simulate fake data from models or images
-
Can create your own telescope and/or instrumental configurations
Julia compiles your code on the fly, and OITOOLS functions are no exception. The so-called "time to first plot" will significantly decrease if you take the time to compile OITOOLS with PackageCompiler, The functions that will be accelerated are in precompile_oitools.jl from the OITOOLS.jl/demos/ directory. Feel free to add OITOOLS functions that you frequenly use. To precompile OITOOLS:
using PackageCompiler
create_sysimage([:OITOOLS], sysimage_path="oitools.so", precompile_execution_file="precompile_oitools.jl")
then launch julia with
julia --sysimage oitools.so
Here is a quick scropt to install all the packages needed to develop OITOOLS:
using Pkg;
#Install python packages
Pkg.add("Conda");
using Conda;
Conda.add("ultranest", channel="conda-forge");
Conda.add("astroquery", channel="astropy");
# Install mainstream Julia packages
Pkg.add(["CFITSIO","AstroTime","Crayons", "Dates","DelimitedFiles","Documenter","DocumenterTools","FFTW", "FITSIO","Glob","LaTeXStrings","LinearAlgebra","NFFT","NLopt","UltraNest","LsqFit","NearestNeighbors","PyCall","PyPlot","Random","SparseArrays","SpecialFunctions","Statistics","Parameters", "Match", "ProgressMeter"]);
# Install Eric Thiebaut's packages
Pkg.Registry.add(RegistrySpec(url = "https://github.com/emmt/EmmtRegistry"))
Pkg.add(["ArrayTools", "LazyAlgebra", "OptimPackNextGen"]);
# Install FB's packages
Pkg.add(url="https://github.com/fabienbaron/OIFITS.jl", rev="t4");
Pkg.add(url="https://github.com/fabienbaron/OITOOLS.jl.git")
# Then check everything got installed properly
using OITOOLS