//-----------------------------------------------------------------------
//
// Copyright (c) 2011 Deltares. All rights reserved.
//
// B.S.T.I.M. The
// tom.the@deltares.nl
// 08-02-2011
// Integration test
//-----------------------------------------------------------------------
using System.IO;
using Deltares.Dam.TestHelper;
namespace Deltares.Dam.Tests
{
using System.Collections.Generic;
using Deltares.Dam.Data;
using Deltares.Dam.Data.Importers;
using NUnit.Framework;
[TestFixture]
public class DAMProjectCalculatorDijkring13Test
{
const string cmstabProgramPath = ".\\DGeoStability.exe";
const string cDikeFolder = @"TestData\Dijkring13-Sec1";
[Test, Category("Slow")]
public void Dijkring13NormalStabilityCalculation()
{
const double cTolerance = 0.001;
// Read dikering
using (var damProjectData = new DamProjectData())
{
var project = ProjectLoader.LoadProjectData(cDikeFolder);
var dike = project.WaterBoard.Dikes[0];
damProjectData.WaterBoard.Dikes.Add(dike);
dike.Validate();
Assert.AreEqual(1, dike.Locations.Count);
// Specify calculation
MStabParameters mstabParameters = FactoryForStabilityTests.CreateMStabParameters();
mstabParameters.SoilDatabaseName = dike.SoilDatabaseName;
var damCalculationSpecification = new DamFailureMechanismeCalculationSpecification()
{
FailureMechanismSystemType = FailureMechanismSystemType.StabilityInside,
FailureMechanismeParamatersMStab = new FailureMechanismeParamatersMStab()
{
MStabParameters = mstabParameters
}
};
DamProjectCalculationSpecification.SelectedAnalysisType = AnalysisType.NoAdaption;
damProjectData.DamProjectCalculationSpecification.SelectedProbabilisticType =
ProbabilisticType.Deterministic;
damProjectData.DamProjectCalculationSpecification.DamCalculationSpecifications.Add(damCalculationSpecification);
// Calculate dijkring
var damProjectCalculator = new DamProjectCalculator(damProjectData);
damProjectCalculator.CalculationBaseDirectory = Path.GetFullPath(Path.Combine(cDikeFolder, "CalculationFiles"));
damProjectCalculator.MStabProgramPath = cmstabProgramPath;
List> allCalculationresults = damProjectCalculator.Calculate(damProjectData, dike.Scenarios);
// Following values are just taken from the Geo Stability calculation and not manually calculated
Assert.AreEqual(0.82, allCalculationresults[0][0].StabilitySafetyFactor.Value, cTolerance);
Assert.AreEqual(1.046, allCalculationresults[0][1].StabilitySafetyFactor.Value, cTolerance);
Assert.AreEqual(1.152, allCalculationresults[0][2].StabilitySafetyFactor.Value, cTolerance);
}
}
}
}