// 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.Drawing;
namespace Ringtoets.Piping.Primitives
{
///
/// This class represents profiles that were imported from D-Soil Model and will later on be used to create the
/// necessary input for executing a piping calculation.
///
public class PipingSoilLayer
{
private string materialName;
///
/// Creates a new instance of , where the top is set to .
///
///
public PipingSoilLayer(double top)
{
Top = top;
MaterialName = string.Empty;
BelowPhreaticLevelMean = double.NaN;
BelowPhreaticLevelDeviation = double.NaN;
BelowPhreaticLevelShift = double.NaN;
DiameterD70Mean = double.NaN;
DiameterD70Deviation = double.NaN;
PermeabilityMean = double.NaN;
PermeabilityDeviation = double.NaN;
}
///
/// Gets the top level of the .
///
public double Top { get; }
///
/// Gets or sets a value indicating whether or not the is an aquifer.
///
public bool IsAquifer { get; set; }
///
/// Gets or sets the mean of the distrubtion for the volumic weight of the below the phreatic level.
/// [kN/m³]
///
public double BelowPhreaticLevelMean { get; set; }
///
/// Gets or sets the deviation of the distrubtion for the volumic weight of the below the phreatic level.
/// [kN/m³]
///
public double BelowPhreaticLevelDeviation { get; set; }
///
/// Gets or sets the shift of the distrubtion for the volumic weight of the below the phreatic level.
/// [kN/m³]
///
public double BelowPhreaticLevelShift { get; set; }
///
/// Gets or sets the mean of the distribution for the mean diameter of small scale tests applied to different kinds of sand,
/// on which the formula of Sellmeijer has been fit.
/// [m]
///
public double DiameterD70Mean { get; set; }
///
/// Gets or sets the deviation of the distribution for the mean diameter of small scale tests applied to different kinds of sand,
/// on which the formula of Sellmeijer has been fit.
/// [m]
///
public double DiameterD70Deviation { get; set; }
///
/// Gets or sets the mean of the distribution for the the Darcy-speed with which water flows through the aquifer layer.
/// [m/s]
///
public double PermeabilityMean { get; set; }
///
/// Gets or sets the deviation of the distribution for the Darcy-speed with which water flows through the aquifer layer.
/// [m/s]
///
public double PermeabilityDeviation { get; set; }
///
/// Gets or sets the name of the material that was assigned to the .
///
/// Thrown when is null.
public string MaterialName
{
get
{
return materialName;
}
set
{
if (value == null)
{
throw new ArgumentNullException(nameof(value));
}
materialName = value;
}
}
///
/// Gets or sets the that was used to represent the .
///
public Color Color { get; set; }
public override bool Equals(object obj)
{
if (ReferenceEquals(null, obj))
{
return false;
}
if (ReferenceEquals(this, obj))
{
return true;
}
if (obj.GetType() != GetType())
{
return false;
}
return Equals((PipingSoilLayer) obj);
}
public override int GetHashCode()
{
unchecked
{
int hashCode = materialName?.GetHashCode() ?? 0;
hashCode = (hashCode * 397) ^ Top.GetHashCode();
hashCode = (hashCode * 397) ^ IsAquifer.GetHashCode();
hashCode = (hashCode * 397) ^ BelowPhreaticLevelMean.GetHashCode();
hashCode = (hashCode * 397) ^ BelowPhreaticLevelDeviation.GetHashCode();
hashCode = (hashCode * 397) ^ BelowPhreaticLevelShift.GetHashCode();
hashCode = (hashCode * 397) ^ DiameterD70Mean.GetHashCode();
hashCode = (hashCode * 397) ^ DiameterD70Deviation.GetHashCode();
hashCode = (hashCode * 397) ^ PermeabilityMean.GetHashCode();
hashCode = (hashCode * 397) ^ PermeabilityDeviation.GetHashCode();
hashCode = (hashCode * 397) ^ Color.GetHashCode();
return hashCode;
}
}
private bool Equals(PipingSoilLayer other)
{
return string.Equals(materialName, other.materialName)
&& Top.Equals(other.Top)
&& IsAquifer == other.IsAquifer
&& BelowPhreaticLevelMean.Equals(other.BelowPhreaticLevelMean)
&& BelowPhreaticLevelDeviation.Equals(other.BelowPhreaticLevelDeviation)
&& BelowPhreaticLevelShift.Equals(other.BelowPhreaticLevelShift)
&& DiameterD70Mean.Equals(other.DiameterD70Mean)
&& DiameterD70Deviation.Equals(other.DiameterD70Deviation)
&& PermeabilityMean.Equals(other.PermeabilityMean)
&& PermeabilityDeviation.Equals(other.PermeabilityDeviation)
&& Color.Equals(other.Color);
}
}
}