// 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; namespace Ringtoets.DuneErosion.Data { /// /// Factory for creating assembly results for a dune erosion failure mechanism. /// public static class DuneErosionFailureMechanismAssemblyFactory { /// /// Assembles the simple assessment results based on . /// /// 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(DuneErosionFailureMechanismSectionResult 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 results. /// /// 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( DuneErosionFailureMechanismSectionResult 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 results. /// /// 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( DuneErosionFailureMechanismSectionResult 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 assessment results. /// /// 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( DuneErosionFailureMechanismSectionResult failureMechanismSectionResult) { if (failureMechanismSectionResult == null) { throw new ArgumentNullException(nameof(failureMechanismSectionResult)); } FailureMechanismSectionAssemblyCategoryGroup simpleAssembly = AssembleSimpleAssessment(failureMechanismSectionResult); FailureMechanismSectionAssemblyCategoryGroup detailedAssembly = AssembleDetailedAssessment(failureMechanismSectionResult); FailureMechanismSectionAssemblyCategoryGroup tailorMadeAssembly = AssembleTailorMadeAssessment(failureMechanismSectionResult); IAssemblyToolCalculatorFactory calculatorFactory = AssemblyToolCalculatorFactory.Instance; IFailureMechanismSectionAssemblyCalculator calculator = calculatorFactory.CreateFailureMechanismSectionAssemblyCalculator(AssemblyToolKernelFactory.Instance); try { return calculator.AssembleCombined(simpleAssembly, detailedAssembly, tailorMadeAssembly); } 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. /// A . /// Thrown when is null. /// Thrown when the /// could not be created. public static FailureMechanismSectionAssemblyCategoryGroup GetSectionAssemblyCategoryGroup( DuneErosionFailureMechanismSectionResult failureMechanismSectionResult) { if (failureMechanismSectionResult == null) { throw new ArgumentNullException(nameof(failureMechanismSectionResult)); } return failureMechanismSectionResult.UseManualAssemblyCategoryGroup ? failureMechanismSectionResult.ManualAssemblyCategoryGroup : AssembleCombinedAssessment(failureMechanismSectionResult); } /// /// Assembles the failure mechanism assembly. /// /// The failure mechanism to assemble for. /// A . /// Thrown when /// is null. /// Thrown when the /// could not be created. public static FailureMechanismAssemblyCategoryGroup AssembleFailureMechanism(DuneErosionFailureMechanism failureMechanism) { if (failureMechanism == null) { throw new ArgumentNullException(nameof(failureMechanism)); } if (!failureMechanism.IsRelevant) { return FailureMechanismAssemblyResultFactory.CreateNotApplicableCategory(); } IEnumerable sectionAssemblies = failureMechanism.SectionResults.Select(GetSectionAssemblyCategoryGroup).ToArray(); IAssemblyToolCalculatorFactory calculatorFactory = AssemblyToolCalculatorFactory.Instance; IFailureMechanismAssemblyCalculator calculator = calculatorFactory.CreateFailureMechanismAssemblyCalculator(AssemblyToolKernelFactory.Instance); try { return calculator.Assemble(sectionAssemblies); } catch (FailureMechanismAssemblyCalculatorException e) { throw new AssemblyException(e.Message, e); } } } }