8#ifndef mx_astro_astroSpectra_hpp
9#define mx_astro_astroSpectra_hpp
12#include "../ioutils/readColumns.hpp"
23template <
typename _units>
27 typedef typename units::realT realT;
29 static const bool freq =
false;
37 static constexpr realT
fluxUnits =
static_cast<realT
>( 1 );
53 std::vector<realT> &rawLambda,
54 std::vector<realT> &rawSpectrum,
55 const std::string &path,
67template <
typename _units,
bool _rsr = true>
71 typedef typename units::realT realT;
73 static const bool freq =
false;
81 static constexpr realT
fluxUnits =
static_cast<realT
>( 1 );
83 static constexpr const char *dataDirEnvVar =
"ASTROFILT_DATADIR";
85 static std::string fileName(
const std::string &name )
91 std::vector<realT> &rawLambda,
92 std::vector<realT> &rawSpectrum,
93 const std::string &path,
100 for(
int i = 0; i < rawLambda.size(); ++i )
103 if( rawSpectrum[i] > max )
104 max = rawSpectrum[i];
107 for(
int i = 0; i < rawLambda.size(); ++i )
109 rawSpectrum[i] /= max;
138template <
typename _units,
bool _rsr = true>
141 typedef _units units;
142 typedef typename units::realT realT;
144 static const bool freq =
false;
158 static constexpr realT
fluxUnits =
static_cast<realT
>( 1 );
160 static constexpr const char *dataDirEnvVar = 0;
162 static std::string fileName(
const paramsT ¶ms )
168 std::vector<realT> &rawLambda,
169 std::vector<realT> &rawSpectrum,
170 const std::string &path,
174 rawLambda.resize( 4 );
175 rawSpectrum.resize( 4 );
177 rawLambda[0] = params.
lam0 - 0.5 * params.
fw - 0.5 * params.
dlam;
178 rawSpectrum[0] = 0.0;
180 rawLambda[1] = params.
lam0 - 0.5 * params.
fw + 0.5 * params.
dlam;
181 rawSpectrum[1] = 1.0;
183 rawLambda[2] = params.
lam0 + 0.5 * params.
fw - 0.5 * params.
dlam;
184 rawSpectrum[2] = 1.0;
186 rawLambda[3] = params.
lam0 + 0.5 * params.
fw + 0.5 * params.
dlam;
187 rawSpectrum[3] = 0.0;
198template <
typename _units>
201 typedef _units units;
202 typedef typename units::realT realT;
204 static const bool freq =
false;
213 static_cast<realT
>( 1e7 ) / (
static_cast<realT
>( 1e4 ) *
static_cast<realT
>( 1e10 ) );
215 static constexpr const char *dataDirEnvVar =
"CALSPEC_DATADIR";
218 static std::string
fileName(
const std::string &name )
220 if( name ==
"alpha_lyr" || name ==
"vega" )
221 return "alpha_lyr_stis_005.asc";
222 else if( name ==
"1740346" )
223 return "1740346_nic_002.ascii";
224 else if( name ==
"sun" || name ==
"sun_reference" )
225 return "sun_reference_stis.002.asc";
230 std::vector<realT> &rawLambda,
231 std::vector<realT> &rawSpectrum,
232 const std::string &path,
244template <
typename _units>
247 typedef _units units;
248 typedef typename units::realT realT;
250 static const bool freq =
false;
258 static constexpr realT
fluxUnits =
static_cast<realT
>( 1 );
264 static std::string
fileName(
const std::string &spt )
271 std::vector<realT> &rawLambda,
272 std::vector<realT> &rawSpectrum,
273 const std::string &path,
290template <
typename _units>
293 typedef _units units;
294 typedef typename units::realT realT;
296 static const bool freq =
false;
304 static constexpr realT
fluxUnits =
static_cast<realT
>( 1 );
310 static std::string
fileName(
const std::string &name )
312 if( name ==
"EPOXI" )
313 return "cowan_2013_EPOXI_albedo.dat";
314 if( name ==
"Earthshine" )
315 return "earthshine_epoxi_normalized.dat";
316 if( name ==
"RawEarthshine" )
317 return "Earthshine/F7_opt_NIR_ES_data.txt";
319 mxError(
"earthAlbeo::fileName", MXE_INVALIDARG,
"name not recognized." );
326 std::vector<realT> &rawLambda,
327 std::vector<realT> &rawSpectrum,
328 const std::string &path,
343template <
typename _units>
346 typedef _units units;
347 typedef typename units::realT realT;
349 static const bool freq =
false;
357 static constexpr realT
fluxUnits =
static_cast<realT
>( 1 );
363 static std::string
fileName(
const std::string &name )
365 if( name ==
"Venus" )
366 return "venus_combined_albedo.dat";
368 mxError(
"venusAlbeo::fileName", MXE_INVALIDARG,
"name not recognized." );
375 std::vector<realT> &rawLambda,
376 std::vector<realT> &rawSpectrum,
377 const std::string &path,
int readColumns(const std::string &fname, arrTs &...arrays)
Read in columns from a text file.
void toLower(std::string &outstr, const std::string &instr)
Convert a string to all lower case.
A spectrum from the astroFilt filter library.
static constexpr realT fluxUnits
No conversion is performed on filter transmission.
static int readSpectrum(std::vector< realT > &rawLambda, std::vector< realT > &rawSpectrum, const std::string &path, const paramsT ¶ms)
static constexpr realT wavelengthUnits
Convert from um to SI m.
std::string paramsT
The astroFilters are parameterized by name.
static constexpr realT fluxUnits
Specify how to convert to SI flux units. No conversions are performed in the basic spectrum.
std::string paramsT
The parameter is a string name.
static constexpr realT wavelengthUnits
Specify how to convert to SI wavelength units. No conversions are performed in the basic spectrum.
static std::string fileName(const paramsT &name)
This function should calculate the file name (without the path) for the spectrum parameters.
static int readSpectrum(std::vector< realT > &rawLambda, std::vector< realT > &rawSpectrum, const std::string &path, const paramsT ¶ms)
This function reads the spectrum, returning its raw wavelength and spectrum points.
static constexpr const char * dataDirEnvVar
The data directory environment variable name.
A spectrum from the HST calspec library.
static int readSpectrum(std::vector< realT > &rawLambda, std::vector< realT > &rawSpectrum, const std::string &path, const paramsT ¶ms)
Read a CALSPEC spectrum, which is a simple two column ASCII format.
static constexpr realT fluxUnits
Convert from erg s-1 cm-2 A-1 to SI W m-3.
static std::string fileName(const std::string &name)
The file name is found from the star's name.
std::string paramsT
The calspec Spectra are parameterized by star name.
static constexpr realT wavelengthUnits
Convert from A to SI m.
static int readSpectrum(std::vector< realT > &rawLambda, std::vector< realT > &rawSpectrum, const std::string &path, const paramsT ¶ms)
Read the Earthshine albedo spectrum, which is a simple two column ASCII format.
static constexpr realT wavelengthUnits
Convert from A to SI m.
static constexpr const char * dataDirEnvVar
The location is specified by the EARTHSHINE_DATADIR environment variable.
std::string paramsT
The name of the spectrum can be "EPOXI", "Earthshine", or "RawEarthshine".
static constexpr realT fluxUnits
The Earthshine is a dimensionless albedo.
static std::string fileName(const std::string &name)
The name of the datafile is a constant.
A spectrum from the Pickles library.
static constexpr const char * dataDirEnvVar
The Pickles spectra location is specified by the PICKLES_DATADIR environment variable.
static constexpr realT fluxUnits
The Pickles spectra are dimensionless.
static constexpr realT wavelengthUnits
Convert from A to SI m.
std::string paramsT
The Pickles spectra are parameterized by a spectral type string.
static std::string fileName(const std::string &spt)
The name of the datafile is constructed from its spectral type string.
static int readSpectrum(std::vector< realT > &rawLambda, std::vector< realT > &rawSpectrum, const std::string &path, const paramsT ¶ms)
Read a Pickles spectrum, which for these purposes is a simple two column ASCII format.
The square wave is parameterized by the central wavelength, width, and sampling (all in microns).
realT dlam
The wavelength sampling to use in microns.
realT lam0
The central Wavelength in microns.
realT fw
The full width of the filter in microns.
A square-wave filter spectrum.
static constexpr realT fluxUnits
No conversion is performed on filter transmission.
static constexpr realT wavelengthUnits
Convert from um to SI m.
static int readSpectrum(std::vector< realT > &rawLambda, std::vector< realT > &rawSpectrum, const std::string &path, const paramsT ¶ms)
static std::string fileName(const std::string &name)
The name of the datafile is a constant.
static constexpr realT fluxUnits
The Earthshine is a dimensionless albedo.
static int readSpectrum(std::vector< realT > &rawLambda, std::vector< realT > &rawSpectrum, const std::string &path, const paramsT ¶ms)
Read the Earthshine albedo spectrum, which is a simple two column ASCII format.
std::string paramsT
The name of the spectrum can be "venus".
static constexpr const char * dataDirEnvVar
The location is specified by the EARTHSHINE_DATADIR environment variable.
static constexpr realT wavelengthUnits
Convert from A to SI m.
Unit specifications and conversions.