// 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.ComponentModel; using AssemblyTool.Kernel; using AssemblyTool.Kernel.Data; using AssemblyTool.Kernel.Data.AssemblyCategories; using Ringtoets.AssemblyTool.Data; using Ringtoets.AssemblyTool.KernelWrapper.Creators; using Ringtoets.AssemblyTool.KernelWrapper.Kernels; using Ringtoets.Common.Primitives; using IFailureMechanismSectionAssemblyCalculatorKernel = AssemblyTool.Kernel.Assembly.IFailureMechanismSectionAssemblyCalculator; namespace Ringtoets.AssemblyTool.KernelWrapper.Calculators.Assembly { /// /// Class representing a failure mechanism section assembly calculator. /// public class FailureMechanismSectionAssemblyCalculator : IFailureMechanismSectionAssemblyCalculator { private readonly IAssemblyToolKernelFactory factory; /// /// Creates a new instance of . /// /// The factory responsible for creating the assembly kernel. /// Thrown when any parameter is null. public FailureMechanismSectionAssemblyCalculator(IAssemblyToolKernelFactory factory) { if (factory == null) { throw new ArgumentNullException(nameof(factory)); } this.factory = factory; } public FailureMechanismSectionAssembly AssembleDetailedAssessment(DetailedAssessmentResultType detailedAssessmentResult, double probability, IEnumerable categories) { if (!Enum.IsDefined(typeof(DetailedAssessmentResultType), detailedAssessmentResult)) { throw new InvalidEnumArgumentException(nameof(detailedAssessmentResult), (int) detailedAssessmentResult, typeof(DetailedAssessmentResultType)); } switch (detailedAssessmentResult) { case DetailedAssessmentResultType.Probability: try { IFailureMechanismSectionAssemblyCalculatorKernel kernel = factory.CreateFailureMechanismSectionAssemblyKernel(); CalculationOutput output = kernel.DetailedAssessmentDirectFailureMechanisms( FailureMechanismSectionAssemblyCalculatorInputCreator.CreateDetailedCalculationInputFromProbability(probability, categories)); return FailureMechanismSectionAssemblyCreator.Create(output.Result); } catch (Exception e) { throw new FailureMechanismSectionAssemblyCalculatorException(e.Message, e); } case DetailedAssessmentResultType.NotAssessed: return FailureMechanismSectionAssemblyCreator.Create(new FailureMechanismSectionAssemblyCategoryResult( FailureMechanismSectionCategoryGroup.VIIv, new Probability(0.0))); default: throw new NotSupportedException(); } } public FailureMechanismSectionAssembly AssembleSimpleAssessment(SimpleAssessmentResultType input) { try { IFailureMechanismSectionAssemblyCalculatorKernel kernel = factory.CreateFailureMechanismSectionAssemblyKernel(); CalculationOutput output = kernel.SimpleAssessmentDirectFailureMechanisms( FailureMechanismSectionAssemblyCalculatorInputCreator.CreateSimpleCalculationResult(input)); return FailureMechanismSectionAssemblyCreator.Create(output.Result); } catch (Exception e) { throw new FailureMechanismSectionAssemblyCalculatorException(e.Message, e); } } public FailureMechanismSectionAssembly AssembleSimpleAssessment(SimpleAssessmentResultValidityOnlyType input) { try { IFailureMechanismSectionAssemblyCalculatorKernel kernel = factory.CreateFailureMechanismSectionAssemblyKernel(); CalculationOutput output = kernel.SimpleAssessmentDirectFailureMechanisms( FailureMechanismSectionAssemblyCalculatorInputCreator.CreateSimpleCalculationResultValidityOnly(input)); return FailureMechanismSectionAssemblyCreator.Create(output.Result); } catch (Exception e) { throw new FailureMechanismSectionAssemblyCalculatorException(e.Message, e); } } public FailureMechanismSectionAssembly AssembleDetailedAssessment(double probability, IEnumerable categories, double n) { try { IFailureMechanismSectionAssemblyCalculatorKernel kernel = factory.CreateFailureMechanismSectionAssemblyKernel(); CalculationOutput output = kernel.DetailedAssessmentDirectFailureMechanisms( FailureMechanismSectionAssemblyCalculatorInputCreator.CreateDetailedCalculationInputFromProbabilityWithLengthEffect(probability, categories, n)); return FailureMechanismSectionAssemblyCreator.Create(output.Result); } catch (Exception e) { throw new FailureMechanismSectionAssemblyCalculatorException(e.Message, e); } } public FailureMechanismSectionAssembly AssembleTailorMadeAssessment(TailorMadeAssessmentProbabilityAndDetailedCalculationResultType tailorMadeAssessmentResult, double probability, IEnumerable categories) { return FailureMechanismSectionAssemblyCreator.Create(new FailureMechanismSectionAssemblyCategoryResult( FailureMechanismSectionCategoryGroup.VIIv, new Probability(probability))); } public FailureMechanismSectionAssembly AssembleTailorMadeAssessment(TailorMadeAssessmentProbabilityCalculationResultType tailorMadeAssessmentResult, double probability, IEnumerable categories) { try { IFailureMechanismSectionAssemblyCalculatorKernel kernel = factory.CreateFailureMechanismSectionAssemblyKernel(); CalculationOutput output = kernel.TailorMadeAssessmentDirectFailureMechanisms( FailureMechanismSectionAssemblyCalculatorInputCreator.CreateTailorMadeCalculationInputFromProbability(tailorMadeAssessmentResult, probability, categories)); return FailureMechanismSectionAssemblyCreator.Create(output.Result); } catch (Exception e) { throw new FailureMechanismSectionAssemblyCalculatorException(e.Message, e); } } public FailureMechanismSectionAssembly AssembleCombined(FailureMechanismSectionAssembly simpleAssembly, FailureMechanismSectionAssembly detailedAssembly, FailureMechanismSectionAssembly tailorMadeAssembly) { try { IFailureMechanismSectionAssemblyCalculatorKernel kernel = factory.CreateFailureMechanismSectionAssemblyKernel(); CalculationOutput output = kernel.CombinedAssessmentFromFailureMechanismSectionResults( FailureMechanismSectionAssemblyCalculatorInputCreator.CreateFailureMechanismSectionAssemblyCategoryResult(simpleAssembly), FailureMechanismSectionAssemblyCalculatorInputCreator.CreateFailureMechanismSectionAssemblyCategoryResult(detailedAssembly), FailureMechanismSectionAssemblyCalculatorInputCreator.CreateFailureMechanismSectionAssemblyCategoryResult(tailorMadeAssembly)); return FailureMechanismSectionAssemblyCreator.Create(output.Result); } catch (Exception e) { throw new FailureMechanismSectionAssemblyCalculatorException(e.Message, e); } } public FailureMechanismSectionAssemblyCategoryGroup AssembleCombined(FailureMechanismSectionAssemblyCategoryGroup simpleAssembly, FailureMechanismSectionAssemblyCategoryGroup detailedAssembly, FailureMechanismSectionAssemblyCategoryGroup tailorMadeAssembly) { try { IFailureMechanismSectionAssemblyCalculatorKernel kernel = factory.CreateFailureMechanismSectionAssemblyKernel(); CalculationOutput output = kernel.CombinedAssessmentFromFailureMechanismSectionResults( FailureMechanismSectionAssemblyCalculatorInputCreator.ConvertFailureMechanismSectionAssemblyCategoryGroup(simpleAssembly), FailureMechanismSectionAssemblyCalculatorInputCreator.ConvertFailureMechanismSectionAssemblyCategoryGroup(detailedAssembly), FailureMechanismSectionAssemblyCalculatorInputCreator.ConvertFailureMechanismSectionAssemblyCategoryGroup(tailorMadeAssembly)); return FailureMechanismSectionAssemblyCreator.ConvertFailureMechanismSectionCategoryGroup(output.Result); } catch (Exception e) { throw new FailureMechanismSectionAssemblyCalculatorException(e.Message, e); } } } }