Add curvature calculator
This commit is contained in:
@@ -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;
|
||||
|
||||
@@ -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; }
|
||||
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
@@ -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;
|
||||
|
||||
@@ -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; }
|
||||
}
|
||||
}
|
||||
|
||||
@@ -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; }
|
||||
}
|
||||
}
|
||||
@@ -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();
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user