A project for Ar-Ar geochronology
Project description
ArArPy
ArArPy is a module for the reduction of 40Ar/39Ar geochronologic data.
It packages the whole processing steps, including reading data from local files, blank correction, decay correction, interference reactions correction, age calculation, isochron regression, etc.
The current version supports exported files in Thermo Scientific Qtegra (ISDS) platform software.
ArArPy is written in Python language combined with some open source packages, such as numpy, pandas, os, scipy, pickle, xlrd, xlsxwriter, and json.
Installing from PyPI
ArArPy can be installed via pip from PyPI.
pip install ararpy
API
Class: Sample
new Sample(**kwargs)
__init__(
Doi = "",
RawData = RawData(),
Info = Info(),
SequenceName = [],
SequenceValue = [],
SequenceUnit = [],
NewIntercept = [],
NewBlank = [],
NewParam = [],
SampleIntercept = [],
BlankIntercept = [],
AnalysisDateTime = [],
BlankCorrected = [],
MassDiscrCorrected = [],
DecayCorrected = [],
InterferenceCorrected = [],
CorrectedValues = [],
DegasValues = [],
ApparentAgeValues = [],
IsochronValues = [],
TotalParam = [],
PublishValues = [],
SelectedSequence1 = [],
SelectedSequence2 = [],
UnselectedSequence = [],
IsochronMark = [],
UnknownTable = Table(),
BlankTable = Table(),
CorrectedTable = Table(),
DegasPatternTable = Table(),
PublishTable = Table(),
AgeSpectraTable = Table(),
IsochronsTable = Table(),
TotalParamsTable = Table(),
AgeSpectraPlot = Plot(),
NorIsochronPlot = Plot(),
InvIsochronPlot = Plot(),
KClAr1IsochronPlot = Plot(),
KClAr2IsochronPlot = Plot(),
KClAr3IsochronPlot = Plot(),
ThreeDIsochronPlot = Plot(),
CorrelationPlot = Plot(),
DegasPatternPlot = Plot(),
AgeDistributionPlot = Plot(),
)
-
Doi
type: str ""
default: ""
Instance id, created by uuid.uuid4().hex.
-
RawData
type: RawData()
RawData instance, contains information and data of the imported raw files.
-
Info
type: Info()
Info instance. it may contain:
attr_name
type: str
Infoid
type: str
0name
type: str
infotype
type: str
Infosample
Info instance.name
type: str
Sample name.material
type: str
Sample material.location
type: str
Sample location.
researcher
Info instancename
type: str
Researcher name.email
type: str
Researcher email.
laboratory
Info instancename
type: str
Laboratory name.email
type: str
Laboratory email.addr
type: str
Laboratory address.analyst
type: str
Laboratory analyst.info
type: str
Laboratory info.
results
Info instancename
type: str
RESULTSage_plateau
type: List[float]
Age plateau.age_spectra
type: List[float]
Age spectra.isochron
type: List[float]
Isochron.isochron_F
type: List[float]
Isochron F.isochron_age
type: List[float]
Isochron age.J
type: List[float]
J value, a list of value and error.plateau_F
type: List[float]
Plateau F.plateau_age
type: List[float]
Plateau age.total_F
type: List[float]
total F.total_age
type: List[float]
total age.
reference
Info instancename
type: str
REFERENCE.doi
type: str
Paper doi.journal
type: str
Journal name.
-
SequenceName = []
type: List[str]
Sequence name list.
-
SequenceValue = []
type: List[str]
Sequence label list.
-
SequenceUnit = []
type: List[str]
Sequence unit list.
-
NewIntercept = []
type: List[str]
New intercept list, 2d list, shape = (10, n), n is the number of sample sequences.
-
NewBlank = []
type: List[str]
New Blank list, 2d list, shape = (10, n), n is the number of sample sequences.
-
NewParam = []
type: List[str]
New Param list, 2d list, shape = (123, n), n is the number of sample sequences.
-
SampleIntercept = []
type: List[str]
Unknown intercept list, 2d list, shape = (10, n), n is the number of sample sequences.
-
BlankIntercept = []
type: List[str]
Blank intercept list, 2d list, shape = (10, n), n is the number of sample sequences.
-
AnalysisDateTime = []
type: List[str]
Analysis DateTime list, 1d list, length equals the number of sample sequences.
-
BlankCorrected = []
type: List[str]
Blank-corrected list, 2d list, shape = (10, n), n is the number of sample sequences.
-
MassDiscrCorrected = []
type: List[str]
Mass discrimination corrected list, 2d list, shape = (10, n), n is the number of sample sequences.
-
DecayCorrected = []
type: List[str]
Decay corrected list, 2d list, shape = (10, n), n is the number of sample sequences.
-
InterferenceCorrected = []
type: List[str]
Interference corrected values, 2d list, shape = (10, n), n is the number of sample sequences.
-
CorrectedValues = []
type: List[str]
Corrected values, 2d list, shape = (10, n), n is the number of sample sequences.
-
DegasValues = []
type: List[str]
Degas values, 2d list, shape = (10, n), n is the number of sample sequences.
-
ApparentAgeValues = []
type: List[str]
Degas values, 2d list, shape = (10, n), n is the number of sample sequences.
-
IsochronValues = []
type: List[str]
Isochron ratio values, 2d list, shape = (39, 0)
-
TotalParam = []
type: List[str]
Parameters values, 2d list, shape = (123, 0)
-
PublishValues = []
type: List[str]
Publish values, 2d list, shape = (11, 0)
-
SelectedSequence1 = []
type: List[str]
Selected sequence values of set 1, 1d list, shape = (n, ), n is the number of set 1 selected sequences
-
SelectedSequence2 = []
type: List[str]
Selected sequence values of set 2, 1d list, shape = (n, ), n is the number of set 2 selected sequences
-
UnselectedSequence = []
type: List[str]
Unselected sequence values, 1d list, shape = (n, ), n is the number of unselected sequences
-
IsochronMark = []
type: List[str]
Isochron mark values, 1d list, shape = (n, ), n is the number of whole sequences
-
UnknownTable = Table()
type: Table
Unknown intercept Table.
-
BlankTable = Table()
type: Table
Blank intercept Table.
-
CorrectedTable = Table()
type: Table
Corrected values Table.
-
DegasPatternTable = Table()
type: Table
Degas values Table.
-
PublishTable = Table()
type: Table
Publish values Table.
-
AgeSpectraTable = Table()
type: Table
Age spectra values Table.
-
IsochronsTable = Table()
type: Table
Isochron values Table.
-
TotalParamsTable = Table()
type: Table
Total parameters Table.
-
AgeSpectraPlot = Plot()
type: Plot
Age spectra Plot.
-
NorIsochronPlot = Plot()
type: Plot
Normal Isochron Plot.
-
InvIsochronPlot = Plot()
type: Plot
Inverse Isochron Plot.
-
KClAr1IsochronPlot = Plot()
type: Plot
K-Cl-Ar 1 Isochron Plot.
-
KClAr2IsochronPlot = Plot()
type: Plot
K-Cl-Ar 2 Isochron Plot.
-
KClAr3IsochronPlot = Plot()
type: Plot
K-Cl-Ar 3 Isochron Plot.
-
ThreeDIsochronPlot = Plot()
type: Plot
Three dimensional isochron Plot.
-
CorrelationPlot = Plot()
type: Plot
Correlation Plot.
-
DegasPatternPlot = Plot()
type: Plot
Degas pattern Plot.
-
AgeDistributionPlot = Plot()
type: Plot
Age distribution Plot.
name()
Get sample name.
doi()
Get sample doi.
sample()
Get sample info.
researcher()
Get researcher info.
laboratory()
Get laboratory info.
results()
Get results, a ArArBasic class.
For example:
{
'isochron': {
'normal': {
'set1': {'k': nan, 'sk': nan, 'm1': nan, 'sm1': nan, 'MSWD': nan,
'abs_conv': nan, 'iter': nan, 'mag': nan, 'R2': nan,
'Chisq': nan, 'Pvalue': nan, 'rs': nan, 'age': nan,
's1': nan, 's2': nan, 's3': nan, 'conv': nan, 'initial': nan,
'sinitial': nan, 'F': nan, 'sF': nan},
'set2': {'k': nan, 'sk': nan, 'm1': nan, 'sm1': nan, 'MSWD': nan, ...},
'unselected': {'k': nan, 'sk': nan, 'm1': nan, 'sm1': nan, 'MSWD': nan, ...}
},
'inverse': {
'set1': {'k': nan, 'sk': nan, 'm1': nan, 'sm1': nan, 'MSWD': nan, ...},
'set2': {'k': nan, 'sk': nan, 'm1': nan, 'sm1': nan, 'MSWD': nan, ...},
'unselected': {'k': nan, 'sk': nan, 'm1': nan, 'sm1': nan, 'MSWD': nan, ...}
},
'cl_1': {
'set1': {'k': nan, 'sk': nan, 'm1': nan, 'sm1': nan, 'MSWD': nan, ...},
'set2': {'k': nan, 'sk': nan, 'm1': nan, 'sm1': nan, 'MSWD': nan, ...},
'unselected': {'k': nan, 'sk': nan, 'm1': nan, 'sm1': nan, 'MSWD': nan, ...}
},
'cl_2': {
'set1': {'k': nan, 'sk': nan, 'm1': nan, 'sm1': nan, 'MSWD': nan, ...},
'set2': {'k': nan, 'sk': nan, 'm1': nan, 'sm1': nan, 'MSWD': nan, ...},
'unselected': {'k': nan, 'sk': nan, 'm1': nan, 'sm1': nan, 'MSWD': nan, ...}
},
'cl_3': {
'set1': {'k': nan, 'sk': nan, 'm1': nan, 'sm1': nan, 'MSWD': nan, ...},
'set2': {'k': nan, 'sk': nan, 'm1': nan, 'sm1': nan, 'MSWD': nan, ...},
'unselected': {'k': nan, 'sk': nan, 'm1': nan, 'sm1': nan, 'MSWD': nan, ...}
},
'three_d': {'set1': {'k': nan, 'sk': nan, 'm1': nan, 'sm1': nan, 'MSWD': nan, ...},
'set2': {'k': nan, 'sk': nan, 'm1': nan, 'sm1': nan, 'MSWD': nan, ...},
'unselected': {'k': nan, 'sk': nan, 'm1': nan, 'sm1': nan, 'MSWD': nan, ...}}
},
'age_plateau': {
'set1': {'F': nan, 'sF': nan, 'Num': nan, 'MSWD': nan, 'Chisq': nan, 'Pvalue': nan,
'age': nan, 's1': nan, 's2': nan, 's3': nan, 'Ar39': nan, 'rs': nan},
'set2': {'F': nan, 'sF': nan, 'Num': nan, 'MSWD': nan, 'Chisq': nan, 'Pvalue': nan, ...},
'unselected': {'F': nan, 'sF': nan, 'Num': nan, 'MSWD': nan, 'Chisq': nan, 'Pvalue': nan, ...}
}
}
sequence()
Get sequence, a ArArBasic class.
sample.sequence() = ArArBasic(
size=len(_smp.SequenceName), name=_smp.SequenceName,
value=_smp.SequenceValue, unit=_smp.SequenceUnit,
mark=ArArBasic(
size=len(_smp.IsochronMark),
set1=ArArBasic(
size=sum([1 if i == 1 else 0 for i in _smp.IsochronMark]),
index=[index for index, _ in enumerate(_smp.IsochronMark) if _ == 1],
),
set2=ArArBasic(
size=sum([1 if i == 2 else 0 for i in _smp.IsochronMark]),
index=[index for index, _ in enumerate(_smp.IsochronMark) if _ == 2],
),
unselected=ArArBasic(
size=sum([0 if i == 2 or i == 1 else 1 for i in _smp.IsochronMark]),
index=[index for index, _ in enumerate(_smp.IsochronMark) if _ != 1 and _ != 2],
),
value=_smp.IsochronMark,
)
)
initial()
Initialize sample instance.
set_selection(index, mark)
args: index, mark
index: int, index of the selected data point
mark: 1 or 2 for set 1 or set 2
update_table(data, table_id)
Update table data.
unknown()
Get sample intercept data.
blank()
Get blank intercept data.
parameters()
Get parameters data.
corrected()
Get corrected data.
degas()
Get degas data.
isochron()
Get isochron data.
apparent_ages()
Get apparent ages data.
publish()
Get publish data.
corr_blank()
Do correction for blank.
corr_massdiscr()
Do correction for mass discrimination.
corr_decay()
Do correction for decay.
corr_ca()
Do correction for ca.
corr_k()
Do correction for k.
corr_cl()
Do correction for cl.
corr_atm()
Do correction for atm.
corr_r()
Do calculation of radiogenic 40Ar.
corr_ratio()
Do calculation of ratios.
set_params()
Set parameters
set_info()
Set sample info
recalculate()
Re-calculate
plot_init()
Re-calculate initialize
plot_isochron()
Re-calculate plot isochron
plot_age_plateau()
Re-calculate plot age plateau
plot_normal()
Re-calculate plot normal isochron
plot_inverse()
Re-calculate plot inverse isochron
plot_cl_1()
Re-calculate plot K-Cl-Ar correlation 1
plot_cl_2()
Re-calculate plot K-Cl-Ar correlation 2
plot_cl_3()
Re-calculate plot K-Cl-Ar correlation 3
plot_3D()
Re-calculate plot 3D diagram
show_data()
Show all data
Testing
1. Running the test function from a Python terminal
>>> import ararpy as ap
>>> ap.test()
Running: ararpy.test()
============= Open an example .arr file =============
file_path = 'your_dir\\examples\\22WHA0433.arr'
sample = from_arr(file_path=file_path)
sample.name() = '22WHA0433 -PFI'
sample.help = 'builtin methods:\n __class__\t__delattr__\t__dir__\t__eq__\t__format__\t__ge__\t__getattribute__\t__gt__\t__hash__\t__init__\t__init_subclass__\t__le__\t__lt__\t__ne__\t__new__\t__reduce__\t__reduce_ex__\t__repr__\t__setattr__\t__sizeof__\t__str__\t__subclasshook__\ndunder-excluded methods:\n apparent_ages\tblank\tcalc_ratio\tcorr_atm\tcorr_blank\tcorr_ca\tcorr_cl\tcorr_decay\tcorr_k\tcorr_massdiscr\tcorr_r\tdoi\tinitial\tisochron\tlaboratory\tname\tparameters\tpublish\trecalculation\tresearcher\tresults\tsample\tsequence\tset_selection\tunknown\tupdate_table\n'
sample.parameters() = <ararpy.ArArData object at 0x0000027F7FBEC9D0>
sample.parameters().to_df() =
0 1 2 3 4 5 ... 117 118 119 120 121 122
0 298.56 0.0 0.018 0.0063 0.1885 0.0 ... 0.31 298.56 0.31 1 1 1
1 298.56 0.0 0.018 0.0063 0.1885 0.0 ... 0.31 298.56 0.31 1 1 1
2 298.56 0.0 0.018 0.0063 0.1885 0.0 ... 0.31 298.56 0.31 1 1 1
3 298.56 0.0 0.018 0.0063 0.1885 0.0 ... 0.31 298.56 0.31 1 1 1
4 298.56 0.0 0.018 0.0063 0.1885 0.0 ... 0.31 298.56 0.31 1 1 1
... ... ... ... ... ... ... ... ... ... ... ... ... ...
22 298.56 0.0 0.018 0.0063 0.1885 0.0 ... 0.31 298.56 0.31 1 1 1
23 298.56 0.0 0.018 0.0063 0.1885 0.0 ... 0.31 298.56 0.31 1 1 1
24 298.56 0.0 0.018 0.0063 0.1885 0.0 ... 0.31 298.56 0.31 1 1 1
25 298.56 0.0 0.018 0.0063 0.1885 0.0 ... 0.31 298.56 0.31 1 1 1
26 298.56 0.0 0.018 0.0063 0.1885 0.0 ... 0.31 298.56 0.31 1 1 1
2. Example 1: create an empty sample
>>> import ararpy as ap
>>> sample = ap.from_empty() # create new sample instance
>>> print(sample.show_data())
# Sample Name:
#
# Doi:
# 9a43b5c1a99747ee8608676ac31814da # uuid
# Corrected Values:
# Empty DataFrame
# Columns: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
# Index: []
# Parameters:
# Empty DataFrame
# Columns: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29,
# 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56,
# 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83,
# 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, ...]
# Index: []
#
# [0 rows x 123 columns]
# Isochron Values:
# Empty DataFrame
# Columns: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29,
# 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46]
# Index: []
# Apparent Ages:
# Empty DataFrame
# Columns: [0, 1, 2, 3, 4, 5, 6, 7]
# Index: []
# Publish Table:
# Empty DataFrame
# Columns: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
# Index: []
3. Example 2: change data point selection and recalculate
>>> import ararpy as ap
>>> import os
>>> example_dir = os.path.join(os.path.dirname(os.path.abspath(ap.__file__)), r'examples')
>>> file_path = os.path.join(example_dir, r'22WHA0433.arr')
>>> sample = ap.from_arr(file_path)
# normal isochron age
>>> print(f"{sample.results().isochron.inverse.set1.age = }")
# sample.results().isochron.inverse.set1.age = 163.10336210925516
# check current data point selection
>>> print(f"{sample.sequence().mark.value}")
# [nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, nan, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0]
>>> print(f"{sample.sequence().mark.set1.index}")
# [11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26]
# change data point selection
>>> sample.set_selection(10, 1)
# check new data point selection
>>> print(f"{sample.sequence().mark.set1.index}")
# [10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26]
# recalculate
>>> sample.recalculate(re_plot=True)
# check new results
>>> print(f"{sample.results().isochron.inverse.set1.age = }")
# sample.results().isochron.inverse.set1.age = 164.57644271385772
Classes
Info
Plot
Sample
Table
class Info(builtins.object)
| Info(id='', name='', type='Info', **kwargs)
|
| Methods defined here:
|
| __init__(self, id='', name='', type='Info', **kwargs)
| Initialize self. See help(type(self)) for accurate signature.
|
| ----------------------------------------------------------------------
| Data descriptors defined here:
|
| __dict__
| dictionary for instance variables (if defined)
|
| __weakref__
| list of weak references to the object (if defined)
class Plot(builtins.object)
| Plot(id='', type='', name='', data=None, info=None, **kwargs)
|
| Methods defined here:
|
| __init__(self, id='', type='', name='', data=None, info=None, **kwargs)
| Initialize self. See help(type(self)) for accurate signature.
|
| ----------------------------------------------------------------------
| Data descriptors defined here:
|
| __dict__
| dictionary for instance variables (if defined)
|
| __weakref__
| list of weak references to the object (if defined)
|
| ----------------------------------------------------------------------
| Data and other attributes defined here:
|
| Axis = <class 'sample.Plot.Axis'>
|
| BasicAttr = <class 'sample.Plot.BasicAttr'>
|
| Label = <class 'sample.Plot.Label'>
|
| Set = <class 'sample.Plot.Set'>
|
| Text = <class 'sample.Plot.Text'>
class Sample(builtins.object)
| Sample(**kwargs)
|
| Methods defined here:
|
| __init__(self, **kwargs)
| Initialize self. See help(type(self)) for accurate signature.
|
| apparent_ages(self)
|
| blank(self)
|
| calc_ratio(self)
|
| corr_atm(self)
|
| corr_blank(self)
|
| corr_ca(self)
|
| corr_cl(self)
|
| corr_decay(self)
|
| corr_k(self)
|
| corr_massdiscr(self)
|
| corr_r(self)
|
| corrected(self)
|
| doi(self)
|
| degas(self)
|
| initial(self)
|
| isochron(self)
|
| laboratory(self)
|
| name(self)
|
| parameters(self)
|
| publish(self)
|
| recalculation(self)
|
| researcher(self)
|
| results(self)
|
| sample(self)
|
| sequence(self)
|
| set_selection(self)
|
| show_data(self)
|
| unknown(self)
|
| update_table(self)
|
| ----------------------------------------------------------------------
| Readonly properties defined here:
|
| version
|
| ----------------------------------------------------------------------
| Data descriptors defined here:
|
| __dict__
| dictionary for instance variables (if defined)
|
| __weakref__
| list of weak references to the object (if defined)
class Table(builtins.object)
| Table(id='', name='Table', colcount=None, rowcount=None, header=None, data=None, coltypes=None, textindexs=None, numericindexs=None, **kwargs)
|
| Methods defined here:
|
| __init__(self, id='', name='Table', colcount=None, rowcount=None, header=None, data=None, coltypes=None, textindexs=None, numericindexs=None, **kwargs)
| Initialize self. See help(type(self)) for accurate signature.
|
| ----------------------------------------------------------------------
| Data descriptors defined here:
|
| __dict__
| dictionary for instance variables (if defined)
|
| __weakref__
| list of weak references to the object (if defined)
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
Built Distribution
File details
Details for the file ararpy-0.1.11.tar.gz
.
File metadata
- Download URL: ararpy-0.1.11.tar.gz
- Upload date:
- Size: 2.6 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b75a19f95619ea9c914d99f6b4f5d0240cc36a58816c41b5c14cf3010bc3147b |
|
MD5 | 3c67992ad6c6cb34231aa4f2dcec2b4a |
|
BLAKE2b-256 | 948d6fd30b0457ee9e228da21c6e656bc203ba7630573b9af3b34d5dd2fdda1d |
File details
Details for the file ararpy-0.1.11-py3-none-any.whl
.
File metadata
- Download URL: ararpy-0.1.11-py3-none-any.whl
- Upload date:
- Size: 2.6 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 26132bf9d3c9e58c4f048ca8d9179c1758a3b947355cd674ce6a7cdd42bc2684 |
|
MD5 | 9e9d918e5deefe1bf1b99f291b2305d7 |
|
BLAKE2b-256 | 3eb91352510b9e24b8f9e479bb986cefc09bc0972f466ab8121d4d58359a7e03 |