// 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.Collections.Generic;
using System.Collections.ObjectModel;
using Ringtoets.Piping.IO.Exceptions;
using Ringtoets.Piping.IO.Properties;
using Ringtoets.Piping.Primitives;
namespace Ringtoets.Piping.IO.Builders
{
///
/// Constructs a 1d Soil Profile based on definitions of .
///
internal class SoilProfileBuilder2D
{
private readonly ICollection layers = new Collection();
private readonly double atX;
private readonly string profileName;
private readonly long soilProfileId;
private double bottom;
///
/// Creates a new instance of with the supposed name for the new
/// and the point at which a 1D profile should be obtained from the 2D profile.
///
/// The name for the constructed by the .
/// The x position from which to obtain a 1D profile.
/// The indentifier of the profile in the database.
/// Thrown when can not be used to determine intersections with
/// (is ).
internal SoilProfileBuilder2D(string profileName, double atX, long soilProfileId)
{
if (double.IsNaN(atX))
{
string message = string.Format(Resources.Error_SoilProfileBuilder_cant_determine_intersect_SoilProfileName_0_at_double_NaN, profileName);
throw new ArgumentException(message);
}
this.profileName = profileName;
this.atX = atX;
bottom = double.MaxValue;
this.soilProfileId = soilProfileId;
}
///
/// Creates a new instances of the based on the layer definitions.
///
/// A new .
/// Thrown when trying to build a
/// and not having added any layers using .
///
internal PipingSoilProfile Build()
{
try
{
return new PipingSoilProfile(profileName, bottom, layers, SoilProfileType.SoilProfile2D, soilProfileId);
}
catch (ArgumentException e)
{
throw new SoilProfileBuilderException(e.Message, e);
}
}
///
/// Adds a new to the profile.
///
/// The to add to the profile.
/// The .
/// Thrown when either:
///
/// - the 's geometry contains vertical segments at the
/// X-coordinate given for the construction of the .
/// - any of the distributions of the stochastic parameters for is not defined
/// as lognormal or is shifted when it should not be
///
internal SoilProfileBuilder2D Add(SoilLayer2D soilLayer)
{
double newBottom;
try
{
IEnumerable pipingSoilLayers = soilLayer.AsPipingSoilLayers(atX, out newBottom);
foreach (PipingSoilLayer layer in pipingSoilLayers)
{
layers.Add(layer);
}
}
catch (SoilLayerConversionException e)
{
throw new SoilProfileBuilderException(e.Message, e);
}
bottom = Math.Min(bottom, newBottom);
return this;
}
}
}