// 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.Data; using Core.Common.Base.Service; using Ringtoets.Piping.Data; using RingtoetsCommonServiceResources = Ringtoets.Common.Service.Properties.Resources; namespace Ringtoets.Piping.Service { /// /// for running a piping calculation. /// public class PipingCalculationActivity : Activity { private readonly double norm; private readonly double contribution; private readonly PipingCalculation calculation; private readonly RoundedDouble calculatedAssessmentLevel; private readonly PipingProbabilityAssessmentInput pipingProbabilityAssessmentInput; /// /// Initializes a new instance of the class. /// /// The piping data used for the calculation. /// The calculated assessment level to use in case no manual assessment level is provided. /// 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, RoundedDouble calculatedAssessmentLevel, PipingProbabilityAssessmentInput pipingProbabilityAssessmentInput, double norm, double contribution) { if (calculation == null) { throw new ArgumentNullException(nameof(calculation)); } if (pipingProbabilityAssessmentInput == null) { throw new ArgumentNullException(nameof(pipingProbabilityAssessmentInput)); } this.calculation = calculation; this.calculatedAssessmentLevel = calculatedAssessmentLevel; this.pipingProbabilityAssessmentInput = pipingProbabilityAssessmentInput; this.norm = norm; this.contribution = contribution; Description = string.Format(RingtoetsCommonServiceResources.Perform_calculation_with_name_0_, calculation.Name); } protected override void OnRun() { if (!PipingCalculationService.Validate(calculation, calculatedAssessmentLevel)) { State = ActivityState.Failed; return; } PipingDataSynchronizationService.ClearCalculationOutput(calculation); PipingCalculationService.Calculate(calculation, calculatedAssessmentLevel); } protected override void OnCancel() { // Unable to cancel a running kernel, so nothing can be done. } protected override void OnFinish() { calculation.NotifyObservers(); } } }