// 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.Collections.Generic; using System.Xml; using Ringtoets.Common.Data.Probabilistics; using Ringtoets.Common.IO.Configurations; using Ringtoets.Common.IO.Configurations.Export; using Ringtoets.MacroStabilityInwards.Data; using Ringtoets.MacroStabilityInwards.IO.Schema; namespace Ringtoets.MacroStabilityInwards.IO.Exporters { /// /// Writer for writing a macro stability inwards calculation configuration to XML. /// public class MacroStabilityInwardsCalculationConfigurationWriter : CalculationConfigurationWriter { protected override void WriteCalculation(MacroStabilityInwardsCalculation calculation, XmlWriter writer) { writer.WriteStartElement(ConfigurationSchemaIdentifiers.CalculationElement); writer.WriteAttributeString(ConfigurationSchemaIdentifiers.NameAttribute, calculation.Name); MacroStabilityInwardsInput calculationInputParameters = calculation.InputParameters; if (calculationInputParameters.UseAssessmentLevelManualInput) { writer.WriteElementString(MacroStabilityInwardsCalculationConfigurationSchemaIdentifiers.AssessmentLevelElement, XmlConvert.ToString(calculationInputParameters.AssessmentLevel)); } else if (calculationInputParameters.HydraulicBoundaryLocation != null) { writer.WriteElementString(ConfigurationSchemaIdentifiers.HydraulicBoundaryLocationElement, calculationInputParameters.HydraulicBoundaryLocation.Name); } if (calculationInputParameters.SurfaceLine != null) { writer.WriteElementString(MacroStabilityInwardsCalculationConfigurationSchemaIdentifiers.SurfaceLineElement, calculationInputParameters.SurfaceLine.Name); writer.WriteElementString(MacroStabilityInwardsCalculationConfigurationSchemaIdentifiers.EntryPointLElement, XmlConvert.ToString(calculationInputParameters.EntryPointL)); writer.WriteElementString(MacroStabilityInwardsCalculationConfigurationSchemaIdentifiers.ExitPointLElement, XmlConvert.ToString(calculationInputParameters.ExitPointL)); } if (calculationInputParameters.StochasticSoilModel != null) { writer.WriteElementString(MacroStabilityInwardsCalculationConfigurationSchemaIdentifiers.StochasticSoilModelElement, calculationInputParameters.StochasticSoilModel.Name); if (calculationInputParameters.StochasticSoilProfile?.SoilProfile != null) { writer.WriteElementString(MacroStabilityInwardsCalculationConfigurationSchemaIdentifiers.StochasticSoilProfileElement, calculationInputParameters.StochasticSoilProfile.SoilProfile.Name); } } WriteDistributions(CreateInputDistributions(calculationInputParameters), writer); writer.WriteEndElement(); } private static IDictionary CreateInputDistributions(MacroStabilityInwardsInput calculationInputParameters) { return new Dictionary { { MacroStabilityInwardsCalculationConfigurationSchemaIdentifiers.PhreaticLevelExitStochastName, calculationInputParameters.PhreaticLevelExit }, { MacroStabilityInwardsCalculationConfigurationSchemaIdentifiers.DampingFactorExitStochastName, calculationInputParameters.DampingFactorExit } }; } } }