// Copyright (C) Stichting Deltares 2017. 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.Linq; using Core.Common.Base; using Core.Common.Base.Data; using Ringtoets.Common.Data.UpdateDataStrategies; using Ringtoets.Common.Service; using Ringtoets.MacroStabilityInwards.Data; using Ringtoets.MacroStabilityInwards.Forms; using Ringtoets.MacroStabilityInwards.IO.Importers; using Ringtoets.MacroStabilityInwards.Primitives; using Ringtoets.MacroStabilityInwards.Service; namespace Ringtoets.MacroStabilityInwards.Plugin.FileImporter { /// /// An for updating surface lines based on imported data. /// public class RingtoetsPipingSurfaceLineUpdateDataStrategy : UpdateDataStrategyBase, ISurfaceLineUpdateDataStrategy { /// /// Creates a new instance of . /// /// The failure mechanism in which the surface lines are updated. /// Thrown when is null. public RingtoetsPipingSurfaceLineUpdateDataStrategy(MacroStabilityInwardsFailureMechanism failureMechanism) : base(failureMechanism, new RingtoetsPipingSurfaceLineNameEqualityComparer()) {} public IEnumerable UpdateSurfaceLinesWithImportedData(RingtoetsPipingSurfaceLineCollection targetDataCollection, IEnumerable readRingtoetsPipingSurfaceLines, string sourceFilePath) { return UpdateTargetCollectionData(targetDataCollection, readRingtoetsPipingSurfaceLines, sourceFilePath); } protected override IEnumerable RemoveObjectAndDependentData(RingtoetsPipingSurfaceLine removedSurfaceLine) { return PipingDataSynchronizationService.RemoveSurfaceLine(FailureMechanism, removedSurfaceLine); } /// /// Class for comparing by only the name. /// private class RingtoetsPipingSurfaceLineNameEqualityComparer : IEqualityComparer { public bool Equals(RingtoetsPipingSurfaceLine x, RingtoetsPipingSurfaceLine y) { return x.Name == y.Name; } public int GetHashCode(RingtoetsPipingSurfaceLine obj) { return obj.Name.GetHashCode(); } } #region Updating Data Functions protected override IEnumerable UpdateObjectAndDependentData(RingtoetsPipingSurfaceLine surfaceLineToUpdate, RingtoetsPipingSurfaceLine matchingSurfaceLine) { surfaceLineToUpdate.CopyProperties(matchingSurfaceLine); var affectedObjects = new List(); affectedObjects.AddRange(UpdateSurfaceLineDependentData(surfaceLineToUpdate)); affectedObjects.AddRange(UpdateStochasticSoilModel(surfaceLineToUpdate)); ValidateEntryAndExitPoints(surfaceLineToUpdate); return affectedObjects; } private IEnumerable UpdateSurfaceLineDependentData(RingtoetsPipingSurfaceLine surfaceLine) { IEnumerable affectedCalculations = GetAffectedCalculationWithSurfaceLine(surfaceLine); var affectedObjects = new List(); foreach (PipingCalculation affectedCalculation in affectedCalculations) { affectedObjects.AddRange(RingtoetsCommonDataSynchronizationService.ClearCalculationOutput(affectedCalculation)); } return affectedObjects; } private IEnumerable UpdateStochasticSoilModel(RingtoetsPipingSurfaceLine updatedSurfaceLine) { IEnumerable calculationsToUpdate = GetAffectedCalculationWithSurfaceLine(updatedSurfaceLine); var affectedObjects = new List(); foreach (PipingCalculation calculation in calculationsToUpdate) { IEnumerable matchingSoilModels = GetAvailableStochasticSoilModels(updatedSurfaceLine); MacroStabilityInwardsInput calculationInput = calculation.InputParameters; PipingInputService.SetMatchingStochasticSoilModel(calculationInput, matchingSoilModels); affectedObjects.Add(calculationInput); } return affectedObjects; } private IEnumerable GetAffectedCalculationWithSurfaceLine(RingtoetsPipingSurfaceLine surfaceLine) { IEnumerable affectedCalculations = FailureMechanism.Calculations .Cast() .Where(calc => ReferenceEquals(calc.InputParameters.SurfaceLine, surfaceLine)); return affectedCalculations; } private IEnumerable GetAvailableStochasticSoilModels(RingtoetsPipingSurfaceLine surfaceLine) { return PipingCalculationConfigurationHelper.GetStochasticSoilModelsForSurfaceLine(surfaceLine, FailureMechanism.StochasticSoilModels); } private void ValidateEntryAndExitPoints(RingtoetsPipingSurfaceLine surfaceLine) { IEnumerable affectedCalculations = GetAffectedCalculationWithSurfaceLine(surfaceLine); foreach (PipingCalculation affectedCalculation in affectedCalculations) { MacroStabilityInwardsInput inputParameters = affectedCalculation.InputParameters; if (!ValidateLocalCoordinateOnSurfaceLine(surfaceLine, inputParameters.EntryPointL)) { inputParameters.EntryPointL = RoundedDouble.NaN; } if (!ValidateLocalCoordinateOnSurfaceLine(surfaceLine, inputParameters.ExitPointL)) { inputParameters.ExitPointL = RoundedDouble.NaN; } } } private static bool ValidateLocalCoordinateOnSurfaceLine(RingtoetsPipingSurfaceLine surfaceLine, double localCoordinateL) { return surfaceLine.ValidateInRange(localCoordinateL); } #endregion } }