// 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 System.Linq;
using Application.Ringtoets.Storage.DbContext;
using Core.Common.Base.Data;
using Ringtoets.Common.Data.Structures;
using Ringtoets.StabilityPointStructures.Data;
namespace Application.Ringtoets.Storage.Read.StabilityPointStructures
{
///
/// This class defines extension methods for read operations for a
/// based on the .
///
internal static class StabilityPointStructuresCalculationEntityReadExtensions
{
///
/// Reads the and use the
/// information to update a .
///
/// The
/// to create for.
/// The object keeping track of read operations.
/// A new .
/// Thrown when is null.
internal static StructuresCalculation Read(this StabilityPointStructuresCalculationEntity entity, ReadConversionCollector collector)
{
if (collector == null)
{
throw new ArgumentNullException("collector");
}
if (collector.Contains(entity))
{
return collector.Get(entity);
}
var calculation = new StructuresCalculation
{
Name = entity.Name,
Comments =
{
Body = entity.Comments
}
};
ReadInputParameters(calculation.InputParameters, entity, collector);
ReadOutput(calculation, entity);
collector.Read(entity, calculation);
return calculation;
}
private static void ReadInputParameters(StabilityPointStructuresInput inputParameters, StabilityPointStructuresCalculationEntity entity, ReadConversionCollector collector)
{
if (entity.StabilityPointStructureEntity != null)
{
inputParameters.Structure = entity.StabilityPointStructureEntity.Read(collector);
}
entity.Read(inputParameters, collector);
inputParameters.InsideWaterLevel.Mean = (RoundedDouble) entity.InsideWaterLevelMean.ToNullAsNaN();
inputParameters.InsideWaterLevel.StandardDeviation = (RoundedDouble) entity.InsideWaterLevelStandardDeviation.ToNullAsNaN();
inputParameters.ThresholdHeightOpenWeir.Mean = (RoundedDouble) entity.ThresholdHeightOpenWeirMean.ToNullAsNaN();
inputParameters.ThresholdHeightOpenWeir.StandardDeviation = (RoundedDouble) entity.ThresholdHeightOpenWeirStandardDeviation.ToNullAsNaN();
inputParameters.ConstructiveStrengthLinearLoadModel.Mean = (RoundedDouble) entity.ConstructiveStrengthLinearLoadModelMean.ToNullAsNaN();
inputParameters.ConstructiveStrengthLinearLoadModel.CoefficientOfVariation = (RoundedDouble) entity.ConstructiveStrengthLinearLoadModelCoefficientOfVariation.ToNullAsNaN();
inputParameters.ConstructiveStrengthQuadraticLoadModel.Mean = (RoundedDouble) entity.ConstructiveStrengthQuadraticLoadModelMean.ToNullAsNaN();
inputParameters.ConstructiveStrengthQuadraticLoadModel.CoefficientOfVariation = (RoundedDouble) entity.ConstructiveStrengthQuadraticLoadModelCoefficientOfVariation.ToNullAsNaN();
inputParameters.BankWidth.Mean = (RoundedDouble) entity.BankWidthMean.ToNullAsNaN();
inputParameters.BankWidth.StandardDeviation = (RoundedDouble) entity.BankWidthStandardDeviation.ToNullAsNaN();
inputParameters.InsideWaterLevelFailureConstruction.Mean = (RoundedDouble) entity.InsideWaterLevelFailureConstructionMean.ToNullAsNaN();
inputParameters.InsideWaterLevelFailureConstruction.StandardDeviation = (RoundedDouble) entity.InsideWaterLevelFailureConstructionStandardDeviation.ToNullAsNaN();
inputParameters.EvaluationLevel = (RoundedDouble) entity.EvaluationLevel.ToNullAsNaN();
inputParameters.LevelCrestStructure.Mean = (RoundedDouble) entity.LevelCrestStructureMean.ToNullAsNaN();
inputParameters.LevelCrestStructure.StandardDeviation = (RoundedDouble) entity.LevelCrestStructureStandardDeviation.ToNullAsNaN();
inputParameters.VerticalDistance = (RoundedDouble) entity.VerticalDistance.ToNullAsNaN();
inputParameters.FailureProbabilityRepairClosure = entity.FailureProbabilityRepairClosure;
inputParameters.FailureCollisionEnergy.Mean = (RoundedDouble) entity.FailureCollisionEnergyMean.ToNullAsNaN();
inputParameters.FailureCollisionEnergy.CoefficientOfVariation = (RoundedDouble) entity.FailureCollisionEnergyCoefficientOfVariation.ToNullAsNaN();
inputParameters.ShipMass.Mean = (RoundedDouble) entity.ShipMassMean.ToNullAsNaN();
inputParameters.ShipMass.CoefficientOfVariation = (RoundedDouble) entity.ShipMassCoefficientOfVariation.ToNullAsNaN();
inputParameters.ShipVelocity.Mean = (RoundedDouble) entity.ShipVelocityMean.ToNullAsNaN();
inputParameters.ShipVelocity.CoefficientOfVariation = (RoundedDouble) entity.ShipVelocityCoefficientOfVariation.ToNullAsNaN();
inputParameters.LevellingCount = entity.LevellingCount;
inputParameters.ProbabilityCollisionSecondaryStructure = entity.ProbabilityCollisionSecondaryStructure;
inputParameters.FlowVelocityStructureClosable.Mean = (RoundedDouble) entity.FlowVelocityStructureClosableMean.ToNullAsNaN();
inputParameters.StabilityLinearLoadModel.Mean = (RoundedDouble) entity.StabilityLinearLoadModelMean.ToNullAsNaN();
inputParameters.StabilityLinearLoadModel.CoefficientOfVariation = (RoundedDouble) entity.StabilityLinearLoadModelCoefficientOfVariation.ToNullAsNaN();
inputParameters.StabilityQuadraticLoadModel.Mean = (RoundedDouble) entity.StabilityQuadraticLoadModelMean.ToNullAsNaN();
inputParameters.StabilityQuadraticLoadModel.CoefficientOfVariation = (RoundedDouble) entity.StabilityQuadraticLoadModelCoefficientOfVariation.ToNullAsNaN();
inputParameters.AreaFlowApertures.Mean = (RoundedDouble) entity.AreaFlowAperturesMean.ToNullAsNaN();
inputParameters.AreaFlowApertures.StandardDeviation = (RoundedDouble) entity.AreaFlowAperturesStandardDeviation.ToNullAsNaN();
inputParameters.InflowModelType = (StabilityPointStructureInflowModelType) entity.InflowModelType;
inputParameters.LoadSchematizationType = (LoadSchematizationType) entity.LoadSchematizationType;
inputParameters.VolumicWeightWater = (RoundedDouble) entity.VolumicWeightWater.ToNullAsNaN();
inputParameters.FactorStormDurationOpenStructure = (RoundedDouble) entity.FactorStormDurationOpenStructure.ToNullAsNaN();
inputParameters.DrainCoefficient.Mean = (RoundedDouble) entity.DrainCoefficientMean.ToNullAsNaN();
}
private static void ReadOutput(StructuresCalculation calculation, StabilityPointStructuresCalculationEntity entity)
{
StabilityPointStructuresOutputEntity output = entity.StabilityPointStructuresOutputEntities.FirstOrDefault();
if (output != null)
{
calculation.Output = output.Read();
}
}
}
}