SigmaEigenvectorsCovariance.java
- /* Copyright 2002-2023 CS GROUP
- * 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.cdm;
- import org.orekit.errors.OrekitException;
- import org.orekit.errors.OrekitMessages;
- import org.orekit.files.ccsds.section.CommentsContainer;
- /**
- * Container for Sigma/Eigenvectors Covariance data. The positional covariance one-sigma
- dispersions corresponding to the major, intermediate and minor eigenvalues, followed by the associated eigenvectors.
- The data is presented on a single line (12 values separated by spaces). (Condition: Mandatory if ALT_COV_TYPE = CSIG3EIGVEC3)
- */
- public class SigmaEigenvectorsCovariance extends CommentsContainer {
- /** Sigma/Eigenvectors Covariance covariance matrix. */
- private double[] csig3eigvec3;
- /** Flag indicating whether the alternate covariance type set in the CDM Object metadata section is Sigma/Eigenvectors Covariance. */
- private boolean altCovFlag;
- /** Simple constructor.
- * <p> The Sigma/Eigenvectors Covariance data is only provided if {@link CdmMetadataKey#ALT_COV_TYPE} is {@link AltCovarianceType#CSIG3EIGVEC3}, otherwise
- * its terms will return NaN. </p>
- * @param altCovFlag Flag indicating whether the alternate covariance type set in the CDM Object metadata section is Sigma/Eigenvectors Covariance.
- */
- public SigmaEigenvectorsCovariance(final boolean altCovFlag) {
- this.altCovFlag = altCovFlag;
- csig3eigvec3 = new double[12];
- for (int i = 0; i < csig3eigvec3.length; ++i) {
- csig3eigvec3[i] = Double.NaN;
- }
- }
- /** {@inheritDoc} */
- @Override
- public void validate(final double version) {
- super.validate(version);
- // Conditional on ALT_COV_TYPE = Sigma/Eigenvectors Covariance
- if (!isAltCovFlagSet()) {
- throw new OrekitException(OrekitMessages.CCSDS_DATE_INVALID_PREAMBLE_FIELD, CdmMetadataKey.ALT_COV_TYPE);
- }
- // We only check values that are mandatory in a cdm file
- for (int i = 0; i < getCsig3eigvec3().length; i++) {
- checkNotNaN(getCsig3eigvec3()[i], SigmaEigenvectorsCovarianceKey.CSIG3EIGVEC3.name());
- }
- }
- /**
- * Get the Sigma/Eigenvectors Covariance data.
- * <p> The Sigma/Eigenvectors Covariance data is only provided if {@link CdmMetadataKey#ALT_COV_TYPE} is {@link AltCovarianceType#CSIG3EIGVEC3}, otherwise
- * its terms will return NaN. </p>
- * @return covarianceData the covariance data in the Sigma/Eigenvectors format.
- */
- public double[] getCsig3eigvec3() {
- return csig3eigvec3 == null ? null : csig3eigvec3.clone();
- }
- /**
- * Set the Sigma/Eigenvectors Covariance data.
- * @param csig3eigvec3 the covariance data in the Sigma/Eigenvectors format.
- */
- public void setCsig3eigvec3(final double[] csig3eigvec3) {
- refuseFurtherComments();
- // Conditional on ALT_COV_TYPE = Sigma/Eigenvectors Covariance
- if (!isAltCovFlagSet()) {
- throw new OrekitException(OrekitMessages.CCSDS_DATE_INVALID_PREAMBLE_FIELD, CdmMetadataKey.ALT_COV_TYPE);
- }
- this.csig3eigvec3 = csig3eigvec3 == null ? null : csig3eigvec3.clone();
- }
- /** Get the flag indicating whether the alternate covariance type set in the CDM Object metadata section is Sigma/Eigenvectors Covariance.
- * @return the altCovFlag
- */
- public boolean isAltCovFlagSet() {
- return altCovFlag;
- }
- }