AttitudeManeuverWriter.java

  1. /* Copyright 2022-2025 Luc Maisonobe
  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.adm.acm;

  18. import java.io.IOException;

  19. import org.orekit.files.ccsds.definitions.Units;
  20. import org.orekit.files.ccsds.section.AbstractWriter;
  21. import org.orekit.files.ccsds.utils.generation.Generator;
  22. import org.orekit.utils.units.Unit;

  23. /** Writer for attitude maneuver data.
  24.  * @author Luc Maisonobe
  25.  * @since 12.0
  26.  */
  27. class AttitudeManeuverWriter extends AbstractWriter {

  28.     /** Attitude maneuver block. */
  29.     private final AttitudeManeuver man;

  30.     /** Create a writer.
  31.      * @param attitudeManeuver attitude maneuver to write
  32.      */
  33.     AttitudeManeuverWriter(final AttitudeManeuver attitudeManeuver) {
  34.         super(AcmDataSubStructureKey.man.name(), AcmDataSubStructureKey.MAN.name());
  35.         this.man = attitudeManeuver;
  36.     }

  37.     /** {@inheritDoc} */
  38.     @Override
  39.     protected void writeContent(final Generator generator) throws IOException {

  40.         // attitude maneuver block
  41.         generator.writeComments(man.getComments());

  42.         // identifiers
  43.         generator.writeEntry(AttitudeManeuverKey.MAN_ID.name(),      man.getID(),         null, false);
  44.         generator.writeEntry(AttitudeManeuverKey.MAN_PREV_ID.name(), man.getPrevID(),     null, false);
  45.         generator.writeEntry(AttitudeManeuverKey.MAN_PURPOSE.name(), man.getManPurpose(), null, true);

  46.         // time
  47.         generator.writeEntry(AttitudeManeuverKey.MAN_BEGIN_TIME.name(),             man.getBeginTime(), Unit.SECOND,      false);
  48.         generator.writeEntry(AttitudeManeuverKey.MAN_END_TIME.name(),               man.getEndTime(),   Unit.SECOND,      false);
  49.         generator.writeEntry(AttitudeManeuverKey.MAN_DURATION.name(),               man.getDuration(),  Unit.SECOND,      false);

  50.         // actuator
  51.         generator.writeEntry(AttitudeManeuverKey.ACTUATOR_USED.name(), man.getActuatorUsed(), null, false);

  52.         // target
  53.         if (man.getTargetMomentum() != null) {
  54.             final StringBuilder momentum = new StringBuilder();
  55.             momentum.append(generator.doubleToString(Units.N_M_S.fromSI(man.getTargetMomentum().getX())));
  56.             momentum.append(' ');
  57.             momentum.append(generator.doubleToString(Units.N_M_S.fromSI(man.getTargetMomentum().getY())));
  58.             momentum.append(' ');
  59.             momentum.append(generator.doubleToString(Units.N_M_S.fromSI(man.getTargetMomentum().getZ())));
  60.             generator.writeEntry(AttitudeManeuverKey.TARGET_MOMENTUM.name(), momentum.toString(),                Units.N_M_S, true);
  61.             if (man.getTargetMomFrame() != null) {
  62.                 generator.writeEntry(AttitudeManeuverKey.TARGET_MOM_FRAME.name(), man.getTargetMomFrame().getName(), null,    false);
  63.             }
  64.         }

  65.         if (man.getTargetAttitude() != null) {
  66.             final StringBuilder attitude = new StringBuilder();
  67.             attitude.append(generator.doubleToString(man.getTargetAttitude().getQ1()));
  68.             attitude.append(' ');
  69.             attitude.append(generator.doubleToString(man.getTargetAttitude().getQ2()));
  70.             attitude.append(' ');
  71.             attitude.append(generator.doubleToString(man.getTargetAttitude().getQ3()));
  72.             attitude.append(' ');
  73.             attitude.append(generator.doubleToString(man.getTargetAttitude().getQ0()));
  74.             generator.writeEntry(AttitudeManeuverKey.TARGET_ATTITUDE.name(), attitude.toString(), null, true);
  75.         }

  76.         generator.writeEntry(AttitudeManeuverKey.TARGET_SPINRATE.name(), man.getTargetSpinRate(), Units.DEG_PER_S, false);

  77.     }

  78. }