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

org.yamcs.time.SimulationTimeService Maven / Gradle / Ivy

There is a newer version: 5.10.9
Show newest version
package org.yamcs.time;

import org.yamcs.YConfiguration;
import org.yamcs.tctm.AbstractTmDataLink;
import org.yamcs.utils.TimeEncoding;

/**
 * Simulation time model. Can be used by configuring in the yamcs.instance.yaml:
 * 
 * 
 * timeService:
 *     class: org.yamcs.time.SimulationTimeService
 *     args:
 *         time0: "2020-10-02T18:10:00.000Z"
 *         speed: 1.0
 * 
* * By default the time0 is initialised with the time at the instance startup and the speed is 1. *

* The service maintains a simulated time which is running based on the computer clock according to speed (e.g. speed = * 2 * means it runs two times realtime speed). If the speed is 0, the simulated time never advances and it has to be * advanced externally (see below). *

* The simulation time service (as well as the speed) can be updated by various means: *

    *
  • Using the http time API; see * https://docs.yamcs.org/yamcs-http-api/time/ for * details.
  • *
  • Setting the option {@code updateSimulationTime: true} on a TM Data Link (this is implemented in * {@link AbstractTmDataLink}) and will cause the simulation time to be updated with the packet generation time each * time a packet is received on the corresponding link. *
  • By a custom service. *
*

* Note: using a time0 configured with a fixed value will cause the Yamcs to start always with the same simulation time * and that might cause undesired effects such as packets overwriting eachother in the archive. *

* Such an option is better to be used in a template which * can then be used to create always new Yamcs instances (corresponding to test sessions) such that the data is * separated. See the instance and templates API . * * @author nm * */ public class SimulationTimeService implements TimeService { double speed; long time0; long javaTime; // this is the java time when the last simElapsedTime has been set long simElapsedTime; public SimulationTimeService(String yamcsInstance, YConfiguration config) { if (config.containsKey("time0")) { time0 = TimeEncoding.parse(config.getString("time0")); } else { time0 = TimeEncoding.getWallclockTime(); } speed = config.getDouble("speed", 1); javaTime = System.currentTimeMillis(); simElapsedTime = 0; } public SimulationTimeService(String yamcsInstance) { this(yamcsInstance, YConfiguration.emptyConfig()); } /** * The mission time returned is: *

* {@code time0 + simElapsedTime + speed * (System.currentTimeMillis() - javaTime)} *

* where time0 is the value set with {@link #setTime0(long)}, speed is the value set with * {@link #setSimSpeed(double)} and javaTime are the values set with {@link #setSimElapsedTime(long, long)}. */ @Override public long getMissionTime() { return (long) (time0 + simElapsedTime + speed * (System.currentTimeMillis() - javaTime)); } /** * Sets the javaTime and simElapsedTime used to compute the mission time by {@link #getMissionTime()} * * @param javaTime * @param simElapsedTime */ public void setSimElapsedTime(long javaTime, long simElapsedTime) { this.javaTime = javaTime; this.simElapsedTime = simElapsedTime; } /** * Same as setSimElapsedTime(System.currentTimeMillis(), simElapsedTime). * * @param simElapsedTime */ public void setSimElapsedTime(long simElapsedTime) { setSimElapsedTime(System.currentTimeMillis(), simElapsedTime); } /** * Set the time0 * * @param time0 */ public void setTime0(long time0) { this.time0 = time0; } /** * Set the simulation speed. If greater than 0, the time passes even without the update of the simElapsedTime. * * @param simSpeed */ public void setSimSpeed(double simSpeed) { this.speed = simSpeed; } public double getSpeed() { return speed; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy