// 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 System.Collections.Generic; using System.Linq; using Ringtoets.AssemblyTool.Data; using Ringtoets.AssemblyTool.KernelWrapper.Calculators; using Ringtoets.AssemblyTool.KernelWrapper.Calculators.Assembly; using Ringtoets.AssemblyTool.KernelWrapper.Kernels; using Ringtoets.Common.Data.AssemblyTool; using Ringtoets.Common.Data.Exceptions; using Ringtoets.Common.Primitives; using RingtoetsCommonDataResources = Ringtoets.Common.Data.Properties.Resources; namespace Ringtoets.StabilityStoneCover.Data { /// /// Factory for creating assembly results for a stability stone cover failure mechanism. /// public static class StabilityStoneCoverFailureMechanismAssemblyFactory { /// /// Assembles the simple assessment results. /// /// The failure mechanism section result to assemble the /// simple assembly results for. /// A based on the . /// Thrown when /// is null. /// Thrown when the /// could not be created. public static FailureMechanismSectionAssemblyCategoryGroup AssembleSimpleAssessment( StabilityStoneCoverFailureMechanismSectionResult failureMechanismSectionResult) { if (failureMechanismSectionResult == null) { throw new ArgumentNullException(nameof(failureMechanismSectionResult)); } IAssemblyToolCalculatorFactory calculatorFactory = AssemblyToolCalculatorFactory.Instance; IFailureMechanismSectionAssemblyCalculator calculator = calculatorFactory.CreateFailureMechanismSectionAssemblyCalculator(AssemblyToolKernelFactory.Instance); try { return calculator.AssembleSimpleAssessment(failureMechanismSectionResult.SimpleAssessmentResult).Group; } catch (FailureMechanismSectionAssemblyCalculatorException e) { throw new AssemblyException(e.Message, e); } } /// /// Assembles the detailed assessment result. /// /// The failure mechanism section result to assemble the /// detailed assembly results for. /// A based on the . /// Thrown when /// is null. /// Thrown when the /// could not be created. public static FailureMechanismSectionAssemblyCategoryGroup AssembleDetailedAssessment( StabilityStoneCoverFailureMechanismSectionResult failureMechanismSectionResult) { if (failureMechanismSectionResult == null) { throw new ArgumentNullException(nameof(failureMechanismSectionResult)); } IAssemblyToolCalculatorFactory calculatorFactory = AssemblyToolCalculatorFactory.Instance; IFailureMechanismSectionAssemblyCalculator calculator = calculatorFactory.CreateFailureMechanismSectionAssemblyCalculator(AssemblyToolKernelFactory.Instance); try { return calculator.AssembleDetailedAssessment(failureMechanismSectionResult.DetailedAssessmentResultForFactorizedSignalingNorm, failureMechanismSectionResult.DetailedAssessmentResultForSignalingNorm, failureMechanismSectionResult.DetailedAssessmentResultForMechanismSpecificLowerLimitNorm, failureMechanismSectionResult.DetailedAssessmentResultForLowerLimitNorm, failureMechanismSectionResult.DetailedAssessmentResultForFactorizedLowerLimitNorm); } catch (FailureMechanismSectionAssemblyCalculatorException e) { throw new AssemblyException(e.Message, e); } } /// /// Assembles the tailor made assessment result. /// /// The failure mechanism section result to assemble the /// tailor made assembly results for. /// A based on the . /// Thrown when /// is null. /// Thrown when the /// could not be created. public static FailureMechanismSectionAssemblyCategoryGroup AssembleTailorMadeAssessment( StabilityStoneCoverFailureMechanismSectionResult failureMechanismSectionResult) { if (failureMechanismSectionResult == null) { throw new ArgumentNullException(nameof(failureMechanismSectionResult)); } IAssemblyToolCalculatorFactory calculatorFactory = AssemblyToolCalculatorFactory.Instance; IFailureMechanismSectionAssemblyCalculator calculator = calculatorFactory.CreateFailureMechanismSectionAssemblyCalculator(AssemblyToolKernelFactory.Instance); try { return calculator.AssembleTailorMadeAssessment(failureMechanismSectionResult.TailorMadeAssessmentResult); } catch (FailureMechanismSectionAssemblyCalculatorException e) { throw new AssemblyException(e.Message, e); } } /// /// Assembles the combined assembly. /// /// The failure mechanism section result to assemble the /// combined assembly results for. /// A based on the . /// Thrown when /// is null. /// Thrown when the /// could not be created. public static FailureMechanismSectionAssemblyCategoryGroup AssembleCombinedAssessment( StabilityStoneCoverFailureMechanismSectionResult failureMechanismSectionResult) { if (failureMechanismSectionResult == null) { throw new ArgumentNullException(nameof(failureMechanismSectionResult)); } IAssemblyToolCalculatorFactory calculatorFactory = AssemblyToolCalculatorFactory.Instance; IFailureMechanismSectionAssemblyCalculator calculator = calculatorFactory.CreateFailureMechanismSectionAssemblyCalculator(AssemblyToolKernelFactory.Instance); try { FailureMechanismSectionAssemblyCategoryGroup simpleAssembly = AssembleSimpleAssessment(failureMechanismSectionResult); if (failureMechanismSectionResult.SimpleAssessmentResult == SimpleAssessmentValidityOnlyResultType.NotApplicable) { return calculator.AssembleCombined(simpleAssembly); } return calculator.AssembleCombined( simpleAssembly, AssembleDetailedAssessment(failureMechanismSectionResult), AssembleTailorMadeAssessment(failureMechanismSectionResult)); } catch (FailureMechanismSectionAssemblyCalculatorException e) { throw new AssemblyException(e.Message, e); } } /// /// Gets the assembly category group of the given . /// /// The failure mechanism section result to get the assembly category group for. /// Indicator that determines whether the manual assembly should be considered when assembling the result. /// A . /// Thrown when is null. /// Thrown when the /// could not be created. public static FailureMechanismSectionAssemblyCategoryGroup GetSectionAssemblyCategoryGroup( StabilityStoneCoverFailureMechanismSectionResult failureMechanismSectionResult, bool useManual) { if (failureMechanismSectionResult == null) { throw new ArgumentNullException(nameof(failureMechanismSectionResult)); } return failureMechanismSectionResult.UseManualAssemblyCategoryGroup && useManual ? failureMechanismSectionResult.ManualAssemblyCategoryGroup : AssembleCombinedAssessment(failureMechanismSectionResult); } /// /// Assembles the failure mechanism assembly. /// /// The failure mechanism to assemble for. /// Indicator that determines whether the manual assembly should be considered when assembling the result. /// A . /// Thrown when /// is null. /// Thrown when the /// could not be created. public static FailureMechanismAssemblyCategoryGroup AssembleFailureMechanism(StabilityStoneCoverFailureMechanism failureMechanism, bool useManual) { if (failureMechanism == null) { throw new ArgumentNullException(nameof(failureMechanism)); } if (!failureMechanism.IsRelevant) { return FailureMechanismAssemblyResultFactory.CreateNotApplicableCategory(); } try { IEnumerable sectionAssemblies = failureMechanism.SectionResults.Select(result => GetSectionAssemblyCategoryGroup(result, useManual)).ToArray(); IAssemblyToolCalculatorFactory calculatorFactory = AssemblyToolCalculatorFactory.Instance; IFailureMechanismAssemblyCalculator calculator = calculatorFactory.CreateFailureMechanismAssemblyCalculator(AssemblyToolKernelFactory.Instance); return calculator.Assemble(sectionAssemblies); } catch (FailureMechanismAssemblyCalculatorException e) { throw new AssemblyException(e.Message, e); } catch (AssemblyException e) { throw new AssemblyException(RingtoetsCommonDataResources.FailureMechanismAssemblyFactory_Error_while_assembling_failureMechanism, e); } } } }