// Copyright (C) Stichting Deltares 2016. 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 Application.Ringtoets.Storage.DbContext; using Ringtoets.Piping.Data; namespace Application.Ringtoets.Storage.Create.Piping { /// /// Extension methods for related to creating /// an . /// internal static class PipingCalculationScenarioCreateExtensions { /// /// Creates a based on the information of the . /// /// The piping calculation to create a database entity for. /// The object keeping track of create operations. /// The index at which resides within its parent. /// A new . /// Thrown when is null. internal static PipingCalculationEntity Create(this PipingCalculationScenario calculation, PersistenceRegistry registry, int order) { if (registry == null) { throw new ArgumentNullException("registry"); } var entity = new PipingCalculationEntity { RelevantForScenario = Convert.ToByte(calculation.IsRelevant), ScenarioContribution = calculation.Contribution.Value.ToNaNAsNull(), Name = calculation.Name, Comments = calculation.Comments, Order = order }; SetInputParametersToEntity(entity, calculation.InputParameters, registry); CreatePipingOutputEntity(entity, calculation.Output, registry); CreatePipingSemiProbabilisticOutputEntity(entity, calculation.SemiProbabilisticOutput, registry); registry.Register(entity, calculation); return entity; } private static void SetInputParametersToEntity(PipingCalculationEntity entity, PipingInput inputParameters, PersistenceRegistry registry) { if (inputParameters.SurfaceLine != null) { entity.SurfaceLineEntity = inputParameters.SurfaceLine.Create(registry); } if (inputParameters.HydraulicBoundaryLocation != null) { entity.HydraulicLocationEntity = inputParameters.HydraulicBoundaryLocation.Create(registry); } if (inputParameters.StochasticSoilProfile != null) { inputParameters.StochasticSoilModel.Create(registry); entity.StochasticSoilProfileEntity = registry.Get(inputParameters.StochasticSoilProfile); } double tempQualifier = inputParameters.ExitPointL.Value; entity.ExitPointL = tempQualifier.ToNaNAsNull(); double tempQualifier1 = inputParameters.EntryPointL.Value; entity.EntryPointL = tempQualifier1.ToNaNAsNull(); entity.PhreaticLevelExitMean = inputParameters.PhreaticLevelExit.Mean.Value.ToNaNAsNull(); entity.PhreaticLevelExitStandardDeviation = inputParameters.PhreaticLevelExit.StandardDeviation.Value.ToNaNAsNull(); entity.DampingFactorExitMean = inputParameters.DampingFactorExit.Mean.Value.ToNaNAsNull(); entity.DampingFactorExitStandardDeviation = inputParameters.DampingFactorExit.StandardDeviation.Value.ToNaNAsNull(); entity.SaturatedVolumicWeightOfCoverageLayerMean = inputParameters.SaturatedVolumicWeightOfCoverageLayer.Mean.Value.ToNaNAsNull(); entity.SaturatedVolumicWeightOfCoverageLayerStandardDeviation = inputParameters.SaturatedVolumicWeightOfCoverageLayer.StandardDeviation.Value.ToNaNAsNull(); entity.SaturatedVolumicWeightOfCoverageLayerShift = inputParameters.SaturatedVolumicWeightOfCoverageLayer.Shift.Value.ToNaNAsNull(); entity.Diameter70Mean = inputParameters.Diameter70.Mean.Value.ToNaNAsNull(); entity.Diameter70StandardDeviation = inputParameters.Diameter70.StandardDeviation.Value.ToNaNAsNull(); entity.DarcyPermeabilityMean = inputParameters.DarcyPermeability.Mean.Value.ToNaNAsNull(); entity.DarcyPermeabilityStandardDeviation = inputParameters.DarcyPermeability.StandardDeviation.Value.ToNaNAsNull(); } private static void CreatePipingOutputEntity(PipingCalculationEntity entity, PipingOutput output, PersistenceRegistry registry) { if (output != null) { entity.PipingCalculationOutputEntity = output.Create(registry); } } private static void CreatePipingSemiProbabilisticOutputEntity(PipingCalculationEntity entity, PipingSemiProbabilisticOutput output, PersistenceRegistry registry) { if (output != null) { entity.PipingSemiProbabilisticOutputEntity = output.Create(registry); } } } }