ChiantiPy.model package¶
Submodules¶
ChiantiPy.model.Maker module¶
classes and methods to analyze observations of astrophysical spectra
-
ChiantiPy.model.Maker.
doDemGofntQ
(inQueue, outQueue)¶ helper for multiprocessing with maker.mgofnt()
-
ChiantiPy.model.Maker.
emPlot
(matchDict, vs='T', loc='upper right', fs=10, adjust=None, position='both', legend=True, verbose=0)¶ to plot line intensities divided by gofnt adjust is to provide an adjustment to the position of the labels position : one of ‘both’, ‘right’, ‘left’, or ‘none’
- Keyword Arguments
vs (str, either ‘T’, or ‘D’) – whether to plot the emission measure vs temperature or density
loc (str) – matplotlib argument for plt.legend
fs (int) – the fontsize for the legend
adjust (list) – a list of multiplicative adjustments to the labels to the plot lines must be the same length as the number of lines
position (str) – where the labels to the lines should be placed, both for both ends, left for the left size only, ‘right’ for the right side only, or None for no labels
label (bool) – whether to apply
legend (bool) – whether to include a matplotlib legend
fontsize (int) – fontsize for the matplotlib xlabel and ylabel
tscale (float) – scale the temperature by dividing by tscale
verbose (bool) – if True, additional output is sent to the terminal
-
class
ChiantiPy.model.Maker.
maker
(specData, temperature=None, eDensity=None, elementList=[], ionList=[], allLines=False, abundanceName=None, minAbund=10.0, wghtFactor=None, verbose=False)¶ Bases:
ChiantiPy.base._IonTrails.ionTrails
,ChiantiPy.base._SpecTrails.specTrails
a class matching observed lines to lines in the CHIANTI database
- Parameters
specData (dict) – contains the following keys intensity - a list of observed line intensities wvlObs - a list of observed wavelengths, usually in Angstroms dwvl the expected wavelength different between the observed wvl and CHIANTI
- Keyword Arguments
temperature (float, list, ndarray) – the temperature(s) in K
eDensity (float, ndarray) – eDensity: electron density in \(\mathrm{cm^{-3}}\)
elementList (list) – a list of elements, such as fe, to be searched
ionList (list) – a list of ions, such as fe_14, to be searched
allLines (bool) – if true, unobserved lines in CHIANTI are included in the search
abundanceName (str) – the name of the elemental abundance file to be used, if not set, the default abundance file is used
minAbund (float) – sets the minimum abundance for an element to be included in the search
verbose (bool) – if True, additional output is sent to the terminal
-
argCheck
(temperature=None, eDensity=None, pDensity='default', verbose=False)¶ to check the compatibility of the three arguments and put them into numpy arrays of atleast_1d
- Keyword Arguments
temperature (float, list, ndarray) – the temperature(s) in K
eDensity (float, ndarray) – eDensity: electron density in \(\mathrm{cm^{-3}}\)
pDensity (str, float, ndarray) – pDensity: proton density in \(\mathrm{cm^{-3}}\) defaults to ‘default’
verbose (bool) – if True, additional output is sent to the terminal
-
diff
(sort=None, verbose=False)¶ calculates the weighted and straight differences between observed and predicted creates an attribute self.Dict, a dict with the following keys: ‘wvl’ = observed wavelength (A) ‘relDiff’ = (I_obs - I_pred)/(I_obs) ‘ionS’ the CHIANTI type name for an ion sort be either of none, ‘wvl’, or ‘ion’
- Keyword Arguments
sort (str or None) – whether the output should be sorted by wvl or ion or not
-
diffPlot
(ratio='diffOverInt', title=False, loc='upper right', fontsize=16, figsize=[7.0, 5.0])¶ - Parameters
ratio (str) – determines which Y values to print can be ‘diffOverInt’ (default), or ‘intOverPred’, or ‘predOverInt’
title (bool) – whether to plot the title or not
fontsize (int) – fontsize for matplotlib plots
figsize (2d list, ndarray) – the figure size for the plot
- Variables
DiffPlot (dict) – contains the fig, ax matplotlib objects created
-
diffPrint
(filename='diffPrint.txt', sort=None)¶ calculates the weighted and straight differences between observed and predicted prints the values and saves to a file also created a attribute self.Dict, a dict with the following keys: ‘wvl’ = observed wavelength (A) ‘relDiff’ = (I_obs - I_pred)/(I_obs) ‘ionS’ the CHIANTI type name for an ion
- Keyword Arguments
filename (str) – the filename where the text should be output
sort (str, can be wvl, ion, or None) – whether the output should be sorted by wvl or ion or not
-
emFitPlot
()¶ to plot the emission measures derived from a chi-squared search over temperature
-
emPlot
(vs='T', loc='upper right', fs=10, adjust=None, position='both', label=True, legend=True, fontsize=16, tscale=1.0, verbose=True)¶ to plot line intensities divided by gofnt adjust is to provide an adjustment to the position of the labels position : one of ‘both’, ‘right’, ‘left’, or ‘none’
- Keyword Arguments
vs (str, either ‘T’, or ‘D’) – whether to plot the emission measure vs temperature or density
loc (str) – matplotlib argument for plt.legend
fs (int) – the fontsize for the legend
adjust (list) – a list of multiplicative adjustments to the labels to the plot lines must be the same length as the number of lines
position (str) – where the labels to the lines should be placed, both for both ends, left for the left size only, ‘right’ for the right side only, or None for no labels
label (bool) – whether to apply
legend (bool) – whether to include a matplotlib legend
fontsize (int) – fontsize for the matplotlib xlabel and ylabel
tscale (float) – scale the temperature by dividing by tscale
verbose (bool) – if True, additional output is sent to the terminal
-
emPlotObj
(vs='T', loc='upper right', fs=10, adjust=None, position='both', label=True, legend=True, fontsize=16, figsize=[7.0, 5.0], tscale=1.0, verbose=True)¶ the emPlot using the object oriented version of matplotlib - a figure and axis objects are returned to plot line intensities divided by gofnt adjust is to provide an adjustment to the position of the labels position : one of ‘both’, ‘right’, ‘left’, or ‘none’ this uses the modern object interface fig, ax = plt.subplots(figsize=figsize) fig, ax are in returned in the self.EmPlotOjb dict
- Keyword Arguments
vs (str, either ‘T’, or ‘D’) – whether to plot the emission measure vs temperature or density
loc (str) – matplotlib argument for plt.legend
fs (int) – the fontsize for the legend
adjust (list) – a list of multiplicative adjustments to the labels to the plot lines must be the same length as the number of lines
position (str) – where the labels to the lines should be placed, both for both ends, left for the left size only, ‘right’ for the right side only, or None for no labels
label (bool) – whether to apply
legend (bool) – whether to include a matplotlib legend
fontsize (int) – fontsize for the matplotlib xlabel and ylabel
figsize (two element list or ndarray) – sets the figure size when using matplotlib subplots to initiate the object style plotting
tscale (float) – scale the temperature by dividing by tscale
verbose (bool) – if True, additional output is sent to the terminal
-
emSet
(value)¶ sets the EM values for a N temperature EM distribution
- Parameters
value (list, ndarray) – the values of the emission measure to be used when the intensities are predicted
-
emSetIndices
(indices, add=0.0, verbose=0)¶ to set the indices of the N temperature/density EM distribution can increase the number of paramaters if additional parameters have been used
- Parameters
indices (list, ndarray) – the indices of the temperature/density arrays for which a set of intensities will be predicted
- Keyword Arguments
add (float) – to increase the number of parameters used in the calculation of the reduced chi-squared
verbose (bool) – if True, additional output is sent to the terminal
-
emWrite
(filename, directory, reference)¶ to make a CHIANTI style emission measure file outName does not need the suffix .em reference should be a list of references
- Parameters
filename (str) – the name of the em file to be produced
reference (list) – a list of strings providing a reference at the end of the em file
-
findMinMaxIndices
(verbose=0)¶ to find the minimum and maximum indices where all match[‘intensitySum’] are greater than 0
- Keyword Arguments
verbose (bool) – if True, additional output is sent to the terminal
-
fit1t
(initialValue, maxfev=0)¶ calls leastsq to fit the 1t (single temperature) model used in search1dspace
- Parameters
initialValue (float) – the initial value to start the leastsq process
Todo
see if this can be replaced by fitFunct1t or fitNt
-
fitFunc1t
(em)¶ the fitting function for the isothermal model to be called by leastsq called by fit1t
- Parameters
em (number) – the log10 value of the emission measure
- Returns
weighted chisquared
- Return type
float
Todo
see if this can be replaced by fitFuncNt
-
fitFuncNt
(value)¶ the fitting function for the multiple temperature model to be called by leastsq called by fitNt
- Parameters
value (list) – the initial values for the em fit
-
fitNt
(initialValue, maxfev=0)¶ calls leastsq to fit the multi temperature models called by search2tSpace, search3tSpace etc
- Parameters
initialValue (list) – the initial trial value for the emission measure (log1))
- Keyword Arguments
maxfev (int) – not sure it is needed
-
getChisq
()¶ return the weighted chi-squared
-
getNormalizedChisq
()¶ return normalized chisq: chi-squared divided by the number of observed lines
-
getWeightedDiff
()¶ to calculated the weighted difference of each of the intensities returns a 1D array
-
gofnt
(temperature, density, verbose=1)¶ calculate the gofnt function for each of the matched lines do each ion only once
- Parameters
temperature (float, list, ndarray) – the temperature(s) in K
density (float, list, ndarray) – density: electron density in \(\mathrm{cm^{-3}}\)
-
loadMatch
(filename)¶ to open a pickle file, return the match data and make it an attribute
-
loadSearchData
(filename)¶ to load the pickled search data as an attribute self.SearchData
- Keyword Arguments
filename (str) – the filename of the pickle file where the search data has been created
-
makeMatch
(verbose=False)¶ to match the CHIANTI lines with the input specdata uses ionTrails.ionGate to sort through ions
- Keyword Arguments
verbose (bool) – if True, additional output is sent to the terminal
-
matchPrint
(filename='matchPrint.txt', sort=None, verbose=False)¶ to print out the data for the matches to the observed lines sort can be ‘wvl’ or ‘ion’, otherwise, there is no sorting done does not require predicted values
- Keyword Arguments
filename (str) – the filename where the text should be output
sort (str, can be wvl, ion, or None) – whether the output should be sorted by wvl or ion or not
verbose (bool) – if True, additional output is sent to the terminal
-
mgofnt
(temperature, density, proc=6, timeout=0.1, verbose=False)¶ calculate the gofnt function for each of the matched lines this is the multiprocessing version does each ion only once
- Parameters
temperature (float, list, ndarray) – the temperature(s) in K
density (float, list, ndarray) – density: electron density in \(\mathrm{cm^{-3}}\)
- Keyword Arguments
proc (int) – the number of cores to be used
timeout ('float') – may not actually be necessary
verbose (bool) – if True, additional output is sent to the terminal
-
predict
()¶ to predict the intensities of the observed lines from an emission measure the emission measure is already specified as self.Em which is an ndarray the temperatures are set by emSetIndices
-
predictPrint
(minContribution=0.1, filename='predictPrint.txt', sort=None, verbose=0)¶ to predict the intensities of the observed lines from an emission measure the emission measure is already specified as self.Em which is an np array sort can be ‘wvl’ or ‘ion’, otherwise, there is no sorting done
- Keyword Arguments
minContribution (float) – the minimum contribution a blend must supply to be included in the text output
filename (str) – the filename where the text should be output
sort (str, can be wvl, ion, or None) – whether the output should be sorted by wvl or ion or not
verbose (bool) – if True, additional output is sent to the terminal
-
predictPrint1d
(minContribution=0.1, filename='predictPrint1d.txt', verbose=False)¶ to predict the intensities of the observed lines from an emission measure the emission measure is already specified as self.Em which is an np array
to be used after a 1d search over density
- Keyword Arguments
minContribution (float) – the minimum contribution a blend must supply to be included in the text output
filename (str) – the filename where the text should be output
verbose (bool) – if True, additional output is sent to the terminal
-
saveMatch
(filename)¶ to save the attribute Match to a pickle file so that it can be reloaded later
- Keyword Arguments
filename (str) – the filename where the text should be output
-
saveSearchData
(filename)¶ to save the attribute SearchData to a pickle file
- Keyword Arguments
filename (str) – the filename of the pickle file where the search data is to be created
-
search1dSpace
(initialEm, indxlimits=None, verbose=False, log=False, maxfev=0)¶ to conduct a brute force search over electron density for an isothermal-space and find the best fit to the em and density indxlimits give the range of indices to fit over can use self.MinIndex and self.MaxIndex+1 initialEm = log value of the emission measure to begin the searching
- Parameters
initialEm (float) – the initial trial value for the log10 emission measure
- Keyword Arguments
indxlimits (list, None) – the range of indices of the density array to search if None is specified, the whole range is searched
verbose (bool) – if True, additional output is sent to the terminal
log (bool) – if True, a log file is created - ‘search1d.raw’
-
search1tEmSpace
(verbose=False)¶ to find the value of chisq as a function of Em with T = best-fit
- Keyword Arguments
verbose (bool) – if True, additional output is sent to the terminal
-
search2tSpace
(initial, indxlimits=None, verbose=0, log=0, maxfev=0)¶ to conduct a brute force search of 2 temperature space and find the best fit indxlimits give the range of indices to fit over
- Parameters
initial (list) – the initial trial values (2) for the log10 emission measure
- Keyword Arguments
indxlimits (list, None) – the range of indices of the density array to search if None is specified, the whole range is searched
verbose (bool) – if True, additional output is sent to the terminal
log (bool) – if True, a log file is created - ‘search1d.raw’
-
search3tSpace
(initial, indxlimits=None, verbose=0, log=0)¶ to conduct a brute force search of 3 temperature space and find the best fit
- Parameters
initial (list) – the initial trial values (3) for the log10 emission measure
- Keyword Arguments
indxlimits (list, None) – the range of indices of the density array to search if None is specified, the whole range is searched
verbose (bool) – if True, additional output is sent to the terminal
log (bool) – if True, a log file is created - ‘search1d.raw’
-
search4tSpace
(initial, indxlimits=None, verbose=0, log=0)¶ to conduct a brute force search of 4 temperature space and find the best fit set log to create a log file of the iterations rather that outputting to the jupyter/ipython session
- Parameters
initial (list) – the initial trial values (4) for the log10 emission measure
- Keyword Arguments
indxlimits (list, None) – the range of indices of the density array to search if None is specified, the whole range is searched
verbose (bool) – if True, additional output is sent to the terminal
log (bool) – if True, a log file is created - ‘search1d.raw’