Add curvature calculator

This commit is contained in:
Evgeny Redikultsev
2025-11-22 21:17:39 +05:00
parent 215f631bb0
commit 7ab4909c67
42 changed files with 705 additions and 108 deletions

View File

@@ -148,14 +148,14 @@ namespace StructureHelperLogics.NdmCalculations.Cracking
TraceLogger?.AddMessage($"Valid result was obtained", TraceLogStatuses.Debug);
}
private StrainTuple GetSofteningFactors(StrainTuple reducedStrainTuple)
private StrainTuple GetSofteningFactors(IForceTuple reducedStrainTuple)
{
softeningFactorLogic.NdmCollection = InputData.SectionNdmCollection;
softeningFactorLogic.StrainTuple = reducedStrainTuple;
return softeningFactorLogic.GetSofteningFactors();
}
private StrainTuple GetReducedStrainTuple(double factorOfCrackAppearance, double softeningFactor)
private IForceTuple GetReducedStrainTuple(double factorOfCrackAppearance, double softeningFactor)
{
const double notCrackedForceFactor = 0.99d;
var notCrackedForceTuple = ForceTupleService.InterpolateTuples(InputData.StartTuple, InputData.EndTuple, factorOfCrackAppearance * notCrackedForceFactor) as ForceTuple;

View File

@@ -12,7 +12,7 @@ namespace StructureHelperLogics.NdmCalculations.Cracking
/// <summary>
/// Result of crack calculation
/// </summary>
public class CrackForceResult : IResult
public class CrackForceResult : ICrackForceResult
{
/// <inheritdoc/>
public bool IsValid { get; set; }
@@ -41,15 +41,15 @@ namespace StructureHelperLogics.NdmCalculations.Cracking
/// <summary>
/// General curvature in cracked section
/// </summary>
public StrainTuple CrackedStrainTuple { get; set; }
public IForceTuple CrackedStrainTuple { get; set; }
/// <summary>
/// Average general curvature with considering of cracking
/// </summary>
public StrainTuple ReducedStrainTuple { get; set; }
public IForceTuple ReducedStrainTuple { get; set; }
/// <summary>
/// Factor of softening of stifness with considering of cracks
/// </summary>
public StrainTuple SofteningFactors { get; set; }
public IForceTuple SofteningFactors { get; set; }
/// <summary>
/// Collection of ndms which crack properties looking for
/// </summary>
@@ -58,6 +58,6 @@ namespace StructureHelperLogics.NdmCalculations.Cracking
/// Common softening factor
/// </summary>
public double PsiS { get; set; }
}
}

View File

@@ -10,11 +10,11 @@ namespace StructureHelperLogics.NdmCalculations.Cracking
{
internal class CrackStrainLogic : ICrackStrainLogic
{
public StrainTuple BeforeCrackingTuple { get; set; }
public StrainTuple AfterCrackingTuple { get; set; }
public IForceTuple BeforeCrackingTuple { get; set; }
public IForceTuple AfterCrackingTuple { get; set; }
public double SofteningFactor { get; set; }
public StrainTuple GetCrackedStrainTuple()
public IForceTuple GetCrackedStrainTuple()
{
var strainTuple = ForceTupleService.InterpolateTuples(BeforeCrackingTuple, AfterCrackingTuple, SofteningFactor) as StrainTuple;
return strainTuple;

View File

@@ -1,20 +1,29 @@
using LoaderCalculator.Data.Ndms;
using StructureHelperCommon.Models.Calculators;
using StructureHelperCommon.Models.Forces;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace StructureHelperLogics.NdmCalculations.Cracking
{
/// <summary>
/// Implements input data for search of forces of crack appearance in some range of load
/// </summary>
public interface ICrackForceCalculatorInputData: IInputData
{
/// <summary>
/// Start tuple of range for search of forces of crack appearance
/// </summary>
IForceTuple StartTuple { get; set; }
/// <summary>
/// End tuple of range for search of forces of crack appearance
/// </summary>
IForceTuple EndTuple { get; set; }
/// <summary>
/// Collection of NdmElements for checking of crack appearance
/// </summary>
IEnumerable<INdm> CheckedNdmCollection { get; set; }
/// <summary>
/// Collection of initial NdmElements of cross-section
/// </summary>
IEnumerable<INdm> SectionNdmCollection { get; set; }
}
}

View File

@@ -0,0 +1,20 @@
using LoaderCalculator.Data.Ndms;
using StructureHelperCommon.Models.Calculators;
using StructureHelperCommon.Models.Forces;
namespace StructureHelperLogics.NdmCalculations.Cracking
{
public interface ICrackForceResult : IResult
{
IForceTuple CrackedStrainTuple { get; set; }
IForceTuple EndTuple { get; set; }
double FactorOfCrackAppearance { get; set; }
bool IsSectionCracked { get; set; }
IEnumerable<INdm> NdmCollection { get; set; }
double PsiS { get; set; }
IForceTuple ReducedStrainTuple { get; set; }
IForceTuple SofteningFactors { get; set; }
IForceTuple StartTuple { get; set; }
IForceTuple TupleOfCrackAppearance { get; set; }
}
}

View File

@@ -9,9 +9,9 @@ namespace StructureHelperLogics.NdmCalculations.Cracking
{
internal interface ICrackStrainLogic
{
StrainTuple BeforeCrackingTuple { get; set; }
StrainTuple AfterCrackingTuple { get; set; }
IForceTuple BeforeCrackingTuple { get; set; }
IForceTuple AfterCrackingTuple { get; set; }
double SofteningFactor { get; set; }
StrainTuple GetCrackedStrainTuple();
IForceTuple GetCrackedStrainTuple();
}
}