| /** |
| ******************************************************************************** |
| * Copyright (c) 2016-2019 Vector Informatik GmbH and others. |
| * |
| * This program and the accompanying materials are made |
| * available under the terms of the Eclipse Public License 2.0 |
| * which is available at https://www.eclipse.org/legal/epl-2.0/ |
| * |
| * SPDX-License-Identifier: EPL-2.0 |
| * |
| * Contributors: |
| * Vector Informatik GmbH - initial API and implementation |
| ******************************************************************************** |
| */ |
| package org.eclipse.app4mc.amalthea.validations.ta.basic; |
| |
| import java.util.List; |
| |
| import org.eclipse.app4mc.amalthea.model.AmaltheaServices; |
| import org.eclipse.app4mc.amalthea.model.ContinuousValueGaussDistribution; |
| import org.eclipse.app4mc.amalthea.model.INamed; |
| import org.eclipse.app4mc.amalthea.validation.core.AmaltheaValidation; |
| import org.eclipse.app4mc.validation.annotation.Validation; |
| import org.eclipse.app4mc.validation.core.ValidationDiagnostic; |
| import org.eclipse.emf.ecore.EClassifier; |
| import org.eclipse.emf.ecore.EObject; |
| |
| /** |
| * Checks sanity of mean of continuous value Gauss distributions |
| * |
| * <ul> |
| * <li>Mean must not be less than the lower bound</li> |
| * <li>Mean must not be greater than the upper bound</li> |
| * </ul> |
| */ |
| |
| @Validation( |
| id = "TA-Basic-ContinuousValueGaussDistribution-mean", |
| checks = { "Mean must not be less than the lower bound", |
| "Mean must not be greater than the upper bound" }) |
| |
| public class TABasicContinuousValueGaussDistribution extends AmaltheaValidation { |
| |
| @Override |
| public EClassifier getEClassifier() { |
| return ePackage.getContinuousValueGaussDistribution(); |
| } |
| |
| @Override |
| public void validate(EObject eObject, List<ValidationDiagnostic> results) { |
| if (eObject instanceof ContinuousValueGaussDistribution) { |
| ContinuousValueGaussDistribution cvgd = (ContinuousValueGaussDistribution) eObject; |
| INamed namedContainer = AmaltheaServices.getContainerOfType(cvgd, INamed.class); |
| double mean = cvgd.getMean(); |
| if (Double.isFinite(mean)) { |
| Double lower = cvgd.getLowerBound(); |
| if (lower != null && !lower.isNaN() && !lower.isInfinite()) { |
| if (Double.compare(lower, mean) > 0) { |
| addIssue(results, cvgd, ePackage.getContinuousValueGaussDistribution_Mean(), |
| getEClassifier().getName() + ": mean is less than the lower bound: (" + mean + " < " + lower + ", in " + objectInfo(namedContainer) + ")"); |
| } |
| } |
| Double upper = cvgd.getUpperBound(); |
| if (upper != null && !upper.isNaN() && !upper.isInfinite()) { |
| if (Double.compare(upper, mean) < 0) { |
| addIssue(results, cvgd, ePackage.getContinuousValueGaussDistribution_Mean(), |
| getEClassifier().getName() + ": mean is greater than the upper bound: (" + mean + " > " + upper + ", in " + objectInfo(namedContainer) + ")"); |
| } |
| } |
| } |
| } |
| } |
| |
| } |