AttitudeManeuverWriter.java

  1. /* Copyright 2002-2024 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.AccurateFormatter;
  23. import org.orekit.utils.units.Unit;

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

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

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

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

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

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

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

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

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

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

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

  78.     }

  79. }