// Copyright (C) Stichting Deltares 2018. All rights reserved. // // This file is part of the application DAM - UI. // // DAM - UI 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 Deltares.Dam.Data; using Deltares.Dam.Data.DataPlugins.Configuration; using Deltares.Dam.Data.Importers; using Deltares.Geotechnics; using Deltares.Geotechnics.IO; using Deltares.Standard; using Deltares.Standard.IO.Xml; namespace Deltares.Dam.TestHelper { public class ProjectLoader { private static DamProjectData LoadDike(string projectDataFolder) { var damProject = new DamProject{ DamProjectData = new DamProjectData() }; var csvSource = new DataSource { DataSourceType = DataSourceType.CsvFiles, DataLocation = ""}; var soilSource = new DataSource { DataSourceType = DataSourceType.MSoilBase, DataLocation = "./soilmaterials.mdb" }; var container = new DataSourceContainer{ DataSourceList = { csvSource, soilSource }}; damProject.Import(projectDataFolder, container, new[] { "Dike from CSV" }, DamProjectType.Design, null); return damProject.DamProjectData; } public static DamProjectData LoadProjectData(string dataFileOrPath) { if (dataFileOrPath.EndsWith(".damx")) { using (var damProject = new DamProject()) { return (damProject.OpenXMLProject(dataFileOrPath) as DamProjectData); } } return LoadProjectData(dataFileOrPath, CreateDefaultFailureMechanismeCalculationSpecification); } private static DamProjectData LoadProjectData(string projectDataFolder, Func failureMechanismCalculationSpecificationFactoryMethod) { var damProjectData = LoadDike(projectDataFolder); var dike = damProjectData.WaterBoard.Dikes.First(); var soilDatabaseName = dike.SoilDatabaseName; // Specify calculation var damCalculationSpecification = failureMechanismCalculationSpecificationFactoryMethod(damProjectData, soilDatabaseName); damProjectData.DamProjectCalculationSpecification.DamCalculationSpecifications.Add(damCalculationSpecification); return damProjectData; } public static DamFailureMechanismeCalculationSpecification CreateDefaultFailureMechanismeCalculationSpecification( DamProjectData damProjectData, string soilDatabaseName) { MStabParameters mstabParameters = FactoryForStabilityTests.CreateMStabParameters(); mstabParameters.GridPosition = MStabGridPosition.Left; mstabParameters.SearchMethod = MStabSearchMethod.Grid; mstabParameters.SoilDatabaseName = soilDatabaseName; var damCalculationSpecification = new DamFailureMechanismeCalculationSpecification() { FailureMechanismSystemType = FailureMechanismSystemType.StabilityOutside, FailureMechanismeParamatersMStab = new FailureMechanismeParamatersMStab() { MStabParameters = mstabParameters } }; DamProjectCalculationSpecification.SelectedAnalysisType = AnalysisType.AdaptGeometry; damProjectData.DamProjectCalculationSpecification.SelectedProbabilisticType = ProbabilisticType.Deterministic; return damCalculationSpecification; } } }