public class MarshallSolarActivityFutureEstimation extends Object implements DTM2000InputParameters, DataLoader
The data are retrieved through the NASA Marshall Solar Activity Future Estimation (MSAFE) as estimates of monthly F10.7 Mean solar flux and Ap geomagnetic parameter. The data can be retrieved at the NASA Marshall Solar Activity website. Here Kp indices are deduced from Ap indexes, which in turn are tabulated equivalent of retrieved Ap values.
If several MSAFE files are available, some dates may appear in several files (for example August 2007 is in all files from the first one published in March 1999 to the February 2008 file). In this case, the data from the most recent file is used and the older ones are discarded. The date of the file is assumed to be 6 months after its first entry (which explains why the file having August 2007 as its first entry is the February 2008 file). This implies that MSAFE files must not be edited to change their time span, otherwise this would break the old entries overriding mechanism.
With these data, the getInstantFlux(AbsoluteDate)
and getMeanFlux(AbsoluteDate)
methods return the same values and the get24HoursKp(AbsoluteDate)
and getThreeHourlyKP(AbsoluteDate)
methods return the same values.
Conversion from Ap index values in the MSAFE file to Kp values used by the atmosphere model is done using Jacchia's equation in [1].
Modifier and Type | Class and Description |
---|---|
static class |
MarshallSolarActivityFutureEstimation.StrengthLevel
Strength level of activity.
|
Constructor and Description |
---|
MarshallSolarActivityFutureEstimation(String supportedNames,
MarshallSolarActivityFutureEstimation.StrengthLevel strengthLevel)
Simple constructor.
|
Modifier and Type | Method and Description |
---|---|
double |
get24HoursKp(AbsoluteDate date)
The Kp index is derived from the Ap index.
|
DateComponents |
getFileDate(AbsoluteDate date)
Get the date of the file from which data at the specified date comes from.
|
double |
getInstantFlux(AbsoluteDate date)
Get the value of the instantaneous solar flux.
|
AbsoluteDate |
getMaxDate()
Gets the available data range maximum date.
|
double |
getMeanFlux(AbsoluteDate date)
Get the value of the mean solar flux.
|
AbsoluteDate |
getMinDate()
Gets the available data range minimum date.
|
MarshallSolarActivityFutureEstimation.StrengthLevel |
getStrengthLevel()
Get the strength level for activity.
|
String |
getSupportedNames()
Get the supported names for data files.
|
double |
getThreeHourlyKP(AbsoluteDate date)
Get the value of the 3 hours geomagnetic index.
|
void |
loadData(InputStream input,
String name)
Load data from a stream.
|
boolean |
stillAcceptsData()
Check if the loader still accepts new data.
|
public MarshallSolarActivityFutureEstimation(String supportedNames, MarshallSolarActivityFutureEstimation.StrengthLevel strengthLevel)
The original file names used by NASA Marshall space center are of the form: Dec2010F10.txt or Oct1999F10.TXT. So a recommended regular expression for the supported name that work with all published files is: "(?:Jan|Feb|Mar|Apr|May|Jun|Jul|Aug|Sep|Oct|Nov|Dec)\\p{Digit}\\p{Digit}\\p{Digit}\\p{Digit}F10\\.(?:txt|TXT)"
supportedNames
- regular expression for supported files namesstrengthLevel
- selected strength level of activitypublic MarshallSolarActivityFutureEstimation.StrengthLevel getStrengthLevel()
public String getSupportedNames()
public AbsoluteDate getMinDate() throws OrekitException
getMinDate
in interface DTM2000InputParameters
OrekitException
- if data cannot be loadedpublic AbsoluteDate getMaxDate() throws OrekitException
getMaxDate
in interface DTM2000InputParameters
OrekitException
- if data cannot be loadedpublic double getInstantFlux(AbsoluteDate date) throws OrekitException
getInstantFlux
in interface DTM2000InputParameters
date
- the current dateOrekitException
- if the date is out of range of available datapublic double getMeanFlux(AbsoluteDate date) throws OrekitException
getMeanFlux
in interface DTM2000InputParameters
date
- the current dateOrekitException
- if the date is out of range of available datapublic double getThreeHourlyKP(AbsoluteDate date) throws OrekitException
getThreeHourlyKP
in interface DTM2000InputParameters
date
- the current dateOrekitException
- if the date is out of range of available datapublic DateComponents getFileDate(AbsoluteDate date) throws OrekitException
If several MSAFE files are available, some dates may appear in several files (for example August 2007 is in all files from the first one published in March 1999 to the February 2008 file). In this case, the data from the most recent file is used and the older ones are discarded. The date of the file is assumed to be 6 months after its first entry (which explains why the file having August 2007 as its first entry is the February 2008 file). This implies that MSAFE files must not be edited to change their time span, otherwise this would break the old entries overriding mechanism.
date
- date of the solar activity dataOrekitException
- if specified date is out of rangepublic double get24HoursKp(AbsoluteDate date) throws OrekitException
The method used is explained on NOAA website. as follows:
The scale is 0 to 9 expressed in thirds of a unit, e.g. 5- is 4 2/3, 5 is 5 and 5+ is 5 1/3. The ap (equivalent range) index is derived from the Kp index as follows:
Kp | 0o | 0+ | 1- | 1o | 1+ | 2- | 2o | 2+ | 3- | 3o | 3+ | 4- | 4o | 4+ |
ap | 0 | 2 | 3 | 4 | 5 | 6 | 7 | 9 | 12 | 15 | 18 | 22 | 27 | 32 |
Kp | 5- | 5o | 5+ | 6- | 6o | 6+ | 7- | 7o | 7+ | 8- | 8o | 8+ | 9- | 9o |
ap | 39 | 48 | 56 | 67 | 80 | 94 | 111 | 132 | 154 | 179 | 207 | 236 | 300 | 400 |
get24HoursKp
in interface DTM2000InputParameters
date
- date of the Kp dataOrekitException
- if the date is out of range of available datapublic void loadData(InputStream input, String name) throws IOException, ParseException, OrekitException
loadData
in interface DataLoader
input
- data input streamname
- name of the file (or zip entry)IOException
- if data can't be readParseException
- if data can't be parsedOrekitException
- if some data is missing
or if some loader specific error occurspublic boolean stillAcceptsData()
This method is used to speed up data loading by interrupting crawling the data sets as soon as a loader has found the data it was waiting for. For loaders that can merge data from any number of sources (for example JPL ephemerides or Earth Orientation Parameters that are split among several files), this method should always return true to make sure no data is left over.
stillAcceptsData
in interface DataLoader
Copyright © 2002-2017 CS Systèmes d'information. All rights reserved.