// 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; DiameterD70CoefficientOfVariation = double.NaN; PermeabilityMean = double.NaN; PermeabilityCoefficientOfVariation = 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 coefficient of variation 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 DiameterD70CoefficientOfVariation { 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 coefficient of variation of the distribution for the Darcy-speed with which water flows through the aquifer layer. /// [m/s] /// public double PermeabilityCoefficientOfVariation { 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) ^ DiameterD70CoefficientOfVariation.GetHashCode(); hashCode = (hashCode * 397) ^ PermeabilityMean.GetHashCode(); hashCode = (hashCode * 397) ^ PermeabilityCoefficientOfVariation.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) && DiameterD70CoefficientOfVariation.Equals(other.DiameterD70CoefficientOfVariation) && PermeabilityMean.Equals(other.PermeabilityMean) && PermeabilityCoefficientOfVariation.Equals(other.PermeabilityCoefficientOfVariation) && Color.Equals(other.Color); } } }