using Ringtoets.Piping.Data; using Ringtoets.Piping.Data.Probabilistics; namespace Ringtoets.Piping.Calculation { /// /// Factory for creating design variables based on probabilistic distributions. /// public static class PipingSemiProbabilisticDesignValueFactory { #region General parameters /// /// Creates the design variable for . /// public static DesignVariable GetThicknessCoverageLayer(PipingInputParameters parameters) { return CreateDesignVariable(parameters.ThicknessCoverageLayer, 0.05); } /// /// Creates the design variable for . /// public static DesignVariable GetPhreaticLevelExit(PipingInputParameters parameters) { return CreateDesignVariable(parameters.PhreaticLevelExit, 0.05); } /// /// Creates the design variable for . /// public static DesignVariable GetDampingFactorExit(PipingInputParameters parameters) { return CreateDesignVariable(parameters.DampingFactorExit, 0.95); } #endregion #region Piping parameters /// /// Creates the design variable for . /// public static DesignVariable GetSeepageLength(PipingInputParameters parameters) { return CreateDesignVariable(parameters.SeepageLength, 0.05); } /// /// Creates the design variable for . /// public static DesignVariable GetDiameter70(PipingInputParameters parameters) { return CreateDesignVariable(parameters.Diameter70, 0.05); } /// /// Creates the design variable for . /// public static DesignVariable GetDarcyPermeability(PipingInputParameters parameters) { return CreateDesignVariable(parameters.DarcyPermeability, 0.95); } /// /// Creates the design variable for . /// public static DesignVariable GetThicknessAquiferLayer(PipingInputParameters parameters) { return CreateDesignVariable(parameters.ThicknessAquiferLayer, 0.95); } #endregion private static DesignVariable CreateDesignVariable(NormalDistribution distribution, double percentile) { return new NormalDistributionDesignVariable(distribution) { Percentile = percentile }; } private static DesignVariable CreateDesignVariable(LognormalDistribution distribution, double percentile) { return new LognormalDistributionDesignVariable(distribution) { Percentile = percentile }; } } }