// Copyright (C) Stichting Deltares 2017. All rights reserved. // // This file is part of Ringtoets. // // Ringtoets is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License // along with this program. If not, see . // // All names, logos, and references to "Deltares" are registered trademarks of // Stichting Deltares and remain full property of Stichting Deltares at all times. // All rights reserved. using System; using Core.Common.Base.Service; using Ringtoets.MacroStabilityInwards.Data; namespace Ringtoets.MacroStabilityInwards.Service { /// /// for running a piping calculation. /// public class PipingCalculationActivity : Activity { private readonly double norm; private readonly double contribution; private readonly PipingCalculation calculation; private readonly MacroStabilityInwardsProbabilityAssessmentInput macroStabilityInwardsProbabilityAssessmentInput; /// /// Initializes a new instance of the class. /// /// The piping data used for the calculation. /// General input that influences the probability estimate for a piping /// assessment. /// The norm to assess for. /// The contribution of piping as a percentage (0-100) to the total of the failure probability /// of the assessment section. /// Thrown when any /// or is null. public PipingCalculationActivity(PipingCalculation calculation, MacroStabilityInwardsProbabilityAssessmentInput macroStabilityInwardsProbabilityAssessmentInput, double norm, double contribution) { if (calculation == null) { throw new ArgumentNullException(nameof(calculation)); } if (macroStabilityInwardsProbabilityAssessmentInput == null) { throw new ArgumentNullException(nameof(macroStabilityInwardsProbabilityAssessmentInput)); } this.calculation = calculation; this.macroStabilityInwardsProbabilityAssessmentInput = macroStabilityInwardsProbabilityAssessmentInput; this.norm = norm; this.contribution = contribution; Name = calculation.Name; } protected override void OnRun() { if (!PipingCalculationService.Validate(calculation)) { State = ActivityState.Failed; return; } LogMessages.Clear(); PipingDataSynchronizationService.ClearCalculationOutput(calculation); PipingCalculationService.Calculate(calculation); PipingSemiProbabilisticCalculationService.Calculate(calculation, macroStabilityInwardsProbabilityAssessmentInput, norm, contribution); } protected override void OnCancel() { // Unable to cancel a running kernel, so nothing can be done. } protected override void OnFinish() { calculation.NotifyObservers(); } } }