OpmWriter.java

  1. /* Copyright 2002-2023 CS GROUP
  2.  * Licensed to CS GROUP (CS) under one or more
  3.  * contributor license agreements.  See the NOTICE file distributed with
  4.  * this work for additional information regarding copyright ownership.
  5.  * CS licenses this file to You under the Apache License, Version 2.0
  6.  * (the "License"); you may not use this file except in compliance with
  7.  * the License.  You may obtain a copy of the License at
  8.  *
  9.  *   http://www.apache.org/licenses/LICENSE-2.0
  10.  *
  11.  * Unless required by applicable law or agreed to in writing, software
  12.  * distributed under the License is distributed on an "AS IS" BASIS,
  13.  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14.  * See the License for the specific language governing permissions and
  15.  * limitations under the License.
  16.  */
  17. package org.orekit.files.ccsds.ndm.odm.opm;

  18. import java.io.IOException;

  19. import org.orekit.data.DataContext;
  20. import org.orekit.files.ccsds.definitions.TimeSystem;
  21. import org.orekit.files.ccsds.ndm.ParsedUnitsBehavior;
  22. import org.orekit.files.ccsds.ndm.odm.CartesianCovarianceWriter;
  23. import org.orekit.files.ccsds.ndm.odm.OdmCommonMetadata;
  24. import org.orekit.files.ccsds.ndm.odm.CommonMetadataWriter;
  25. import org.orekit.files.ccsds.ndm.odm.OdmHeader;
  26. import org.orekit.files.ccsds.ndm.odm.SpacecraftParametersWriter;
  27. import org.orekit.files.ccsds.ndm.odm.StateVectorWriter;
  28. import org.orekit.files.ccsds.ndm.odm.UserDefinedWriter;
  29. import org.orekit.files.ccsds.section.Segment;
  30. import org.orekit.files.ccsds.section.XmlStructureKey;
  31. import org.orekit.files.ccsds.utils.ContextBinding;
  32. import org.orekit.files.ccsds.utils.FileFormat;
  33. import org.orekit.files.ccsds.utils.generation.AbstractMessageWriter;
  34. import org.orekit.files.ccsds.utils.generation.Generator;
  35. import org.orekit.time.AbsoluteDate;
  36. import org.orekit.utils.IERSConventions;


  37. /**
  38.  * Writer for CCSDS Orbit Parameter Message.
  39.  *
  40.  * @author Luc Maisonobe
  41.  * @since 11.0
  42.  */
  43. public class OpmWriter extends AbstractMessageWriter<OdmHeader, Segment<OdmCommonMetadata, OpmData>, Opm> {

  44.     /** Version number implemented. **/
  45.     public static final double CCSDS_OPM_VERS = 3.0;

  46.     /** Padding width for aligning the '=' sign. */
  47.     public static final int KVN_PADDING_WIDTH = 18;

  48.     /** Complete constructor.
  49.      * <p>
  50.      * Calling this constructor directly is not recommended. Users should rather use
  51.      * {@link org.orekit.files.ccsds.ndm.WriterBuilder#buildOpmWriter()
  52.      * writerBuilder.buildOpmWriter()}.
  53.      * </p>
  54.      * @param conventions IERS Conventions
  55.      * @param dataContext used to retrieve frames, time scales, etc.
  56.      * @param missionReferenceDate reference date for Mission Elapsed Time or Mission Relative Time time systems
  57.      */
  58.     public OpmWriter(final IERSConventions conventions, final DataContext dataContext,
  59.                      final AbsoluteDate missionReferenceDate) {
  60.         super(Opm.ROOT, Opm.FORMAT_VERSION_KEY, CCSDS_OPM_VERS,
  61.               new ContextBinding(
  62.                   () -> conventions, () -> false, () -> dataContext,
  63.                   () -> ParsedUnitsBehavior.STRICT_COMPLIANCE,
  64.                   () -> missionReferenceDate, () -> TimeSystem.UTC,
  65.                   () -> 0.0, () -> 1.0));
  66.     }

  67.     /** {@inheritDoc} */
  68.     @Override
  69.     protected void writeSegmentContent(final Generator generator, final double formatVersion,
  70.                                        final Segment<OdmCommonMetadata, OpmData> segment)
  71.         throws IOException {

  72.         // write the metadata
  73.         final ContextBinding oldContext = getContext();
  74.         final OdmCommonMetadata metadata   = segment.getMetadata();
  75.         setContext(new ContextBinding(oldContext::getConventions,
  76.                                       oldContext::isSimpleEOP,
  77.                                       oldContext::getDataContext,
  78.                                       oldContext::getParsedUnitsBehavior,
  79.                                       oldContext::getReferenceDate,
  80.                                       metadata::getTimeSystem,
  81.                                       oldContext::getClockCount,
  82.                                       oldContext::getClockRate));
  83.         new CommonMetadataWriter(metadata, getTimeConverter()).write(generator);

  84.         // start data block
  85.         if (generator.getFormat() == FileFormat.XML) {
  86.             generator.enterSection(XmlStructureKey.data.name());
  87.         }

  88.         // write mandatory state vector block
  89.         new StateVectorWriter(XmlSubStructureKey.stateVector.name(), null,
  90.                               segment.getData().getStateVectorBlock(), getTimeConverter()).
  91.         write(generator);

  92.         if (segment.getData().getKeplerianElementsBlock() != null) {
  93.             // write optional Keplerian elements block
  94.             new OsculationgKeplerianElementsWriter(XmlSubStructureKey.keplerianElements.name(), null,
  95.                                                    segment.getData().getKeplerianElementsBlock()).
  96.             write(generator);
  97.         }

  98.         if (segment.getData().getSpacecraftParametersBlock() != null) {
  99.             // write optional spacecraft parameters block
  100.             new SpacecraftParametersWriter(XmlSubStructureKey.spacecraftParameters.name(), null,
  101.                                            segment.getData().getSpacecraftParametersBlock()).
  102.             write(generator);
  103.         }

  104.         if (segment.getData().getCovarianceBlock() != null) {
  105.             // write optional spacecraft parameters block
  106.             new CartesianCovarianceWriter(XmlSubStructureKey.covarianceMatrix.name(), null,
  107.                                           segment.getData().getCovarianceBlock()).
  108.             write(generator);
  109.         }

  110.         if (!segment.getData().getManeuvers().isEmpty()) {
  111.             for (final Maneuver maneuver : segment.getData().getManeuvers()) {
  112.                 // write optional maneuver block
  113.                 new ManeuverWriter(maneuver, getTimeConverter()).write(generator);
  114.             }
  115.         }

  116.         if (segment.getData().getUserDefinedBlock() != null) {
  117.             // write optional user defined parameters block
  118.             new UserDefinedWriter(XmlSubStructureKey.userDefinedParameters.name(), null,
  119.                                   segment.getData().getUserDefinedBlock()).
  120.             write(generator);
  121.         }

  122.         // stop data block
  123.         if (generator.getFormat() == FileFormat.XML) {
  124.             generator.exitSection();
  125.         }

  126.     }

  127. }