// 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;
}
}
}