AttitudeManeuverWriter.java

/* Copyright 2023 Luc Maisonobe
 * Licensed to CS GROUP (CS) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * CS licenses this file to You under the Apache License, Version 2.0
 * (the "License"); you may not use this file except in compliance with
 * the License.  You may obtain a copy of the License at
 *
 *   http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.orekit.files.ccsds.ndm.adm.acm;

import java.io.IOException;

import org.orekit.files.ccsds.definitions.Units;
import org.orekit.files.ccsds.section.AbstractWriter;
import org.orekit.files.ccsds.utils.generation.Generator;
import org.orekit.utils.AccurateFormatter;
import org.orekit.utils.units.Unit;

/** Writer for attitude maneuver data.
 * @author Luc Maisonobe
 * @since 12.0
 */
class AttitudeManeuverWriter extends AbstractWriter {

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

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

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

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

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

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

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

        // target
        if (man.getTargetMomentum() != null) {
            final StringBuilder momentum = new StringBuilder();
            momentum.append(AccurateFormatter.format(Units.N_M_S.fromSI(man.getTargetMomentum().getX())));
            momentum.append(' ');
            momentum.append(AccurateFormatter.format(Units.N_M_S.fromSI(man.getTargetMomentum().getY())));
            momentum.append(' ');
            momentum.append(AccurateFormatter.format(Units.N_M_S.fromSI(man.getTargetMomentum().getZ())));
            generator.writeEntry(AttitudeManeuverKey.TARGET_MOMENTUM.name(), momentum.toString(),                Units.N_M_S, true);
            if (man.getTargetMomFrame() != null) {
                generator.writeEntry(AttitudeManeuverKey.TARGET_MOM_FRAME.name(), man.getTargetMomFrame().getName(), null,    false);
            }
        }

        if (man.getTargetAttitude() != null) {
            final StringBuilder attitude = new StringBuilder();
            attitude.append(AccurateFormatter.format(man.getTargetAttitude().getQ1()));
            attitude.append(' ');
            attitude.append(AccurateFormatter.format(man.getTargetAttitude().getQ2()));
            attitude.append(' ');
            attitude.append(AccurateFormatter.format(man.getTargetAttitude().getQ3()));
            attitude.append(' ');
            attitude.append(AccurateFormatter.format(man.getTargetAttitude().getQ0()));
            generator.writeEntry(AttitudeManeuverKey.TARGET_ATTITUDE.name(), attitude.toString(), null, true);
        }

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

    }

}