Skip to content

pvermees/KJ.jl

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

KJ

Julia package for LA-ICP-MS data reduction

KJ ("Kasper Julia") is still in development and has not yet been added to the Julia package repository. However, if you want to play around with the current functionality, then you can install the package from GitHub. First, make sure that you have Julia installed on your system by downloading it from here. Then, at the Julia REPL:

import Pkg; Pkg.add(url="https://github.com/pvermees/KJ.jl.git")

There are four ways to interact with KJ:

  1. TUI: an interactive text-based user interface
  2. TUI + GUI: a TUI augmented with graphical user interface elements
  3. REPL: the command-line interface
  4. Hybrid: combining the TUI, GUI and REPL

TUI (text-based user interface)

Here is a short example of a menu-driven KJ session:

julia> using KJ
julia> TUI()
----------
 KJ 0.3.0
----------

r: Read data files[*]
m: Specify the method[*]
t: Tabulate the samples
s: Mark mineral standards[*]
g: Mark reference glasses[*]
v: View and adjust each sample
p: Process the data[*]
e: Export the results
l: Logs and templates
o: Options
u: Update
c: Clear
x: Exit
?: Help
r

a: Agilent
t: ThermoFisher
x: Exit
?: Help
a

d: Read a directory of individual data files
p: Parse the data from a single file using a laser log
(? for help, x to exit):
d

Enter the full path of the data directory (? for help, x to exit):
data/Lu-Hf

r: Read data files
m: Specify the method[*]
t: Tabulate the samples
s: Mark mineral standards[*]
g: Mark reference glasses[*]
v: View and adjust each sample
p: Process the data[*]
e: Export the results
l: Logs and templates
o: Options
u: Update
c: Clear
x: Exit
?: Help
v

TUI + GUI extension

You can augment the TUI with GUI elements (currently just file choosers) by installing the KJgui extension (installable from here):

julia> using KJ, KJgui
julia> TUI(KJgui)
----------
 KJ 0.3.0
----------

r: Read data files[*]
m: Specify the method[*]
t: Tabulate the samples
s: Mark mineral standards[*]
g: Mark reference glasses[*]
v: View and adjust each sample
p: Process the data[*]
e: Export the results
l: Logs and templates
o: Options
u: Update
c: Clear
x: Exit
?: Help
r

a: Agilent
t: ThermoFisher
x: Exit
?: Help
a

d: Read a directory of individual data files
p: Parse the data from a single file using a laser log
(? for help, x to exit):
d

REPL (command-line interface)

Advanced users can interact with KJ via Julia's command line interface or REPL ("read-eval-print loop"). Here is an example of a carbonate U-Pb data reduction using WC-1 for time-dependent elemental fractionation correction between U and Pb and NIST-612 for mass-dependent fractionation correction of the Pb-isotopes. The script exports all the aliquots of the "Duff" sample to a JSON file that can be opened in IsoplotR:

method = "U-Pb"
run = load("data/carbonate",instrument="Agilent")
standards = Dict("WC1"=>"WC1")
glass = Dict("NIST612"=>"NIST612")
channels = Dict("d"=>"Pb207","D"=>"Pb206","P"=>"U238")
blk, fit = process!(run,method,channels,standards,glass)
export2IsoplotR(run,method,channels,blk,fit,prefix="Duff",fname="Duff.json")

Type ?load, ?process!, ?export2IsoplotR or ?KJ at the REPL to view the documentation.

TUI + REPL

You can seamlessly switch from the TUI to the REPL and back. The following example stores the TUI settings into a variable called ctrl (type ctrl at the REPL to view its contents). You can manipulate the contents of ctrl and sync it with the TUI using the setKJctrl() function.

julia> using KJ
julia> TUI()
----------
 KJ 0.3.0
----------

r: Read data files[*]
m: Specify the method[*]
t: Tabulate the samples
s: Mark mineral standards[*]
g: Mark reference glasses[*]
v: View and adjust each sample
p: Process the data[*]
e: Export the results
l: Logs and templates
o: Options
u: Update
c: Clear
x: Exit
?: Help
r

a: Agilent
t: ThermoFisher
x: Exit
?: Help
a

d: Read a directory of individual data files
p: Parse the data from a single file using a laser log
(? for help, x to exit):
d

Enter the full path of the data directory (? for help, x to exit):
data/Lu-Hf

r: Read data files
m: Specify the method[*]
t: Tabulate the samples
s: Mark mineral standards[*]
g: Mark reference glasses[*]
v: View and adjust each sample
p: Process the data[*]
e: Export the results
l: Logs and templates
o: Options
u: Update
c: Clear
x: Exit
?: Help
x

julia> ctrl = getKJctrl();
julia> plot(ctrl["run"][1])

About

Julia package for LA-ICP-MS data reduction

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages