All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.yamcs.simulator.launchland.RCSHandler Maven / Gradle / Ivy

package org.yamcs.simulator.launchland;

import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.util.Vector;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.yamcs.simulator.CCSDSPacket;
import org.yamcs.simulator.SimulationConfiguration;

class RCSHandler {
    private final static String csvName = "RCS.csv";

    private Vector entries;
    private int currentEntry = 0;

    private Logger log = LoggerFactory.getLogger(this.getClass().getName());

    public RCSHandler(SimulationConfiguration simconf) {
        entries = new Vector<>(100, 100);
        try (BufferedReader in = new BufferedReader(new FileReader(simconf.getTestDataDir() + "/" + csvName))) {
            String line;
            in.readLine(); // skip column titles

            while ((line = in.readLine()) != null) {

                line = line.replace(',', '.'); // compatible to decimals with comma (e.g. 1,23)
                String[] parts = line.split(";");
                RCSData entry = new RCSData();

                entry.timestamp = new Float(parts[0]).floatValue();

                entry.H2TankFill = new Float(parts[1]).floatValue();
                entry.H2TankTemp = new Float(parts[2]).floatValue();
                entry.H2TankPressure = new Float(parts[3]).floatValue();
                entry.H2ValveTemp = new Float(parts[4]).floatValue();
                entry.H2ValvePressure = new Float(parts[5]).floatValue();

                entry.O2TankFill = new Float(parts[6]).floatValue();
                entry.O2TankTemp = new Float(parts[7]).floatValue();
                entry.O2TankPressure = new Float(parts[8]).floatValue();
                entry.O2ValveTemp = new Float(parts[9]).floatValue();
                entry.O2ValvePressure = new Float(parts[10]).floatValue();

                entry.TurbineTemp = new Float(parts[11]).floatValue();
                entry.TurbinePressure = new Float(parts[12]).floatValue();

                entries.add(entry);
            }
        } catch (IOException e) {
            log.warn(e.getMessage(), e);
        }
        log.info("have " + entries.size() + " RHS data records");
    }

    public void fillPacket(CCSDSPacket packet) {
        if (entries.isEmpty())
            return;

        if (currentEntry >= entries.size()) {
            currentEntry = 0;
        }

        RCSData entry = entries.elementAt(currentEntry++);
        entry.fillPacket(packet, 0);
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy