Customize output variables
Warning: this section is only relevant for PSIMU version 11.4 (or more recent ones).
Create new specific variables in the output list is relatively simple. As an example, we are going to show how to add two additional variables HPM and HAM, corresponding respectively the mean perigee and apogee altitudes considering the mean semi-major axis and eccentricity already computed by PSIMU.
Sommaire
Creating a class implementing the INewVarsFunction interface
As explained in the title of this paragraph, we have to create a new class implementing the INewVarsFunction interface where we will be able to compute the new variables. On the code below, we see that this interface forces us to have the addNewVars(), computeNewVars() and getNames() methods:
public class MyNewMeanVars implements INewVarsFunction { @Override public void addNewVars(ResultWriter resultWriter) throws SqliteException { // TODO Auto-generated method stub } @Override public void computeNewVars(ResultWriter resultWriter, String tableName, SpacecraftState currentState, HashMap<String, Object> currentVarsList) throws SqliteException { // TODO Auto-generated method stub } @Override public List<String> getNames() { // TODO Auto-generated method stub return null; } }
Adding a constructor
As we will need information on the equatorial radius, we will add a constructor allowing to store a ExtendedOneAxisEllipsoid object. We will also add a list including the names of the new variables (this list will be returned by the getNames() method:
public class MyNewMeanVars implements INewVarsFunction { private final ExtendedOneAxisEllipsoid earth; private final ArrayList<String> listOfNames; public MyNewMeanVars ( final ExtendedOneAxisEllipsoid earth ) { this.earth = earth; // List initialization listOfNames = new ArrayList<String>(); listOfNames.add("HPM"); listOfNames.add("HAM"); } … @Override public List<String> getNames() { return listOfNames; }
Implementing the addNewVars() method
To fill the addNewVars() method, we will have to call for the addColumn() method giving for each variable and each table (ephemeris and events ones) as inputs:
- its name (String)
- its description (String)
- its unit (String)
- its gap threshold (for plotting; may be null)
- a boolean to know if it will be visible or not
public void addNewVars ( final ResultWriter resultWriter ) throws SqliteException { if ( resultWriter != null) { // Mean perigee altitude creation String varName = listOfNames.get(0); String varDesc = "Mean perigee altitude"; String varUnit = "km"; // Adding a column in the ephemeris table resultWriter.addColumn(PsimuUtils.EPH_TABLE, varName, varDesc, ColumnType.REAL, varUnit, null, true); // Adding a column in the event table resultWriter.addColumn(PsimuUtils.EVENT_TABLE, varName, varDesc, ColumnType.REAL, varUnit, null, true); // Mean apogee altitude creation varName = listOfNames.get(1); varDesc = "Mean apogee altitude"; // Adding a column in the ephemeris table resultWriter.addColumn(PsimuUtils.EPH_TABLE, varName, varDesc, ColumnType.REAL, varUnit, null, true); // Adding a column in the event table resultWriter.addColumn(PsimuUtils.EVENT_TABLE, varName, varDesc, ColumnType.REAL, varUnit, null, true); } }
Implementing the computeNewVars() method
Using the data previously computed as included in the currentState and listOfCurrentVars objects, we have just to compute the new variables then to store them using the addValue() method of the ResultWriter object.
public void computeNewVars(final ResultWriter resultWriter, final String tableName, final SpacecraftState currentState, final HashMap<String, Object> listOfCurrentVars) throws SqliteException { // Getting previously computed mean semi major axis and eccentricity final double am = (Double)listOfCurrentVars.get("AM"); final double em = (Double)listOfCurrentVars.get("EM"); // Computation of the mean perigee and apogee altitude final double hpm = am*(1. - em) - earth.getEquatorialRadius(); final double ham = am*(1. + em) - earth.getEquatorialRadius(); // Storing in the table if ( resultWriter != null) { resultWriter.addValue(tableName, listOfNames.get(0), hpm); resultWriter.addValue(tableName, listOfNames.get(1), ham); } // Storing in the current list if ( listOfCurrentVars != null ) { listOfCurrentVars.put("HPM", hpm); listOfCurrentVars.put("HAM", ham); } }
Giving information to PSIMU!
All we need now is to call for the addOutputVarsFunction() method of the OutputConfig class with the object issued from our MyNewMeanVars class !
final OutputConfig output = new OutputConfig(...); output.addOutputVarsFunction(new MyNewMeanVars(EARTH));