Files
wg_cpso/CPSO/Forms/51_Step/ViewSteadyStateDynamics.cs
2026-03-25 18:20:24 +08:00

189 lines
8.0 KiB
C#

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.ComponentModel;
using CaeGlobals;
using DynamicTypeDescriptor;
using CaeModel;
using System.Drawing.Design;
using CaeJob;
namespace CPSO
{
[Serializable]
public class ViewSteadyStateDynamics : ViewStep
{
// Variables
private SteadyStateDynamicsStep _steadyStep;
// Properties
[Category("Data")]
[OrderedDisplayName(3, 10, "Perturbation")]
[Description("Perturbation parameter set to On applies preloads from the previous step if it exists.")]
[Id(4, 1)]
public bool Perturbation { get { return _steadyStep.Perturbation; } set { _steadyStep.Perturbation = value; } }
[Category("Data")]
[OrderedDisplayName(4, 10, "Harmonic")]
[Description("Select yes for harmonic periodic loading and no for nonharmonic periodic loading.")]
[Id(5, 1)]
public bool Harmonic
{
get { return _steadyStep.Harmonic; }
set
{
_steadyStep.Harmonic = value;
UpdateVisibility();
}
}
//
[Category("Data")]
[OrderedDisplayName(5, 10, "Lower frequency bound")]
[Description("Lower bound of the frequency range.")]
[TypeConverter(typeof(StringFrequencyConverter))]
[Id(6, 1)]
public double LowerFrequency { get { return _steadyStep.LowerFrequency; } set { _steadyStep.LowerFrequency = value; } }
//
[Category("Data")]
[OrderedDisplayName(6, 10, "Upper frequency bound")]
[Description("Upper bound of the frequency range.")]
[TypeConverter(typeof(StringFrequencyConverter))]
[Id(7, 1)]
public double UpperFrequency { get { return _steadyStep.UpperFrequency; } set { _steadyStep.UpperFrequency = value; } }
//
[Category("Data")]
[OrderedDisplayName(7, 10, "Number of data points")]
[Description("Number of data points within the frequency range.")]
[TypeConverter(typeof(StringIntegerConverter))]
[Id(8, 1)]
public int NumDataPoints { get { return _steadyStep.NumDataPoints; } set { _steadyStep.NumDataPoints = value; } }
//
[Category("Data")]
[OrderedDisplayName(8, 10, "Bias")]
[Description("Distribution bias of the data points within the frequency range (use 1 for equal spacing).")]
[TypeConverter(typeof(StringDoubleConverter))]
[Id(9, 1)]
public double Bias { get { return _steadyStep.Bias; } set { _steadyStep.Bias = value; } }
//
[Category("Time")]
[OrderedDisplayName(0, 10, "Number of Fourier terms")]
[Description("Number of Fourier terms the nonharmonic loading is expanded in.")]
[TypeConverter(typeof(StringIntegerConverter))]
[Id(1, 2)]
public int NumFourierTerms { get { return _steadyStep.NumFourierTerms; } set { _steadyStep.NumFourierTerms = value; } }
//
[Category("Time")]
[OrderedDisplayName(1, 10, "Lower time bound")]
[Description("Lower bound of the time range.")]
[TypeConverter(typeof(StringTimeConverter))]
[Id(2, 2)]
public double TimeLower { get { return _steadyStep.TimeLower; } set { _steadyStep.TimeLower = value; } }
//
[Category("Time")]
[OrderedDisplayName(2, 10, "Upper time bound")]
[Description("Upper bound of the time range.")]
[TypeConverter(typeof(StringTimeConverter))]
[Id(3, 2)]
public double TimeUpper { get { return _steadyStep.TimeUpper; } set { _steadyStep.TimeUpper = value; } }
//
[Category("Damping")]
[OrderedDisplayName(0, 10, "Damping type")]
[Description("Select the modal damping type.")]
[Id(1, 3)]
public ModalDampingTypeEnum DampingType
{
get { return _steadyStep.ModalDamping.DampingType; }
set
{
_steadyStep.ModalDamping.DampingType = value;
UpdateVisibility();
}
}
//
[Category("Damping")]
[OrderedDisplayName(1, 10, "Alpha")]
[Description("Mass-proportional damping coefficient of the Rayleigh damping.")]
[TypeConverter(typeof(StringReciprocalTimeConverter))]
[Id(2, 3)]
public double Alpha { get { return _steadyStep.ModalDamping.Alpha; } set { _steadyStep.ModalDamping.Alpha = value; } }
//
[Category("Damping")]
[OrderedDisplayName(2, 10, "Beta")]
[Description("Stiffness-proportional damping coefficient of the Rayleigh damping.")]
[TypeConverter(typeof(StringTimeConverter))]
[Id(3, 3)]
public double Beta { get { return _steadyStep.ModalDamping.Beta; } set { _steadyStep.ModalDamping.Beta = value; } }
//
[Category("Damping")]
[OrderedDisplayName(3, 10, "Damping ratio")]
[Description("Viscous damping ratio between the damping coefficient and the critical damping coefficient.")]
[Id(4, 3)]
public double ViscousDampingRatio
{
get { return _steadyStep.ModalDamping.ViscousDampingRatio; }
set { _steadyStep.ModalDamping.ViscousDampingRatio = value; }
}
[Category("Damping")]
[OrderedDisplayName(3, 10, "Damping ratios")]
[Description("Viscous damping ratios between the damping coefficient and the critical damping coefficient.")]
[Editor(typeof(Forms.DampingRatiosAndValuesUIEditor), typeof(UITypeEditor))]
[Id(4, 3)]
public List<DampingRatioAndRange> DampingRatiosAndRanges
{
get { return _steadyStep.ModalDamping.DampingRatiosAndRanges; }
set { _steadyStep.ModalDamping.DampingRatiosAndRanges = value; }
}
// Constructors
public ViewSteadyStateDynamics(SteadyStateDynamicsStep step, bool installProvider = true)
: base(step)
{
_steadyStep = step;
//
if (installProvider)
{
InstallProvider();
UpdateVisibility();
}
}
// Methods
public override Step GetBase()
{
return _steadyStep;
}
public override void InstallProvider()
{
base.InstallProvider();
//
_dctd.RenameBooleanPropertyToOnOff("Perturbation");
_dctd.RenameBooleanProperty(nameof(Harmonic), "Yes", "No");
}
public override void UpdateVisibility()
{
base.UpdateVisibility();
//
_dctd.GetProperty(nameof(NumFourierTerms)).SetIsBrowsable(!_steadyStep.Harmonic);
_dctd.GetProperty(nameof(TimeLower)).SetIsBrowsable(!_steadyStep.Harmonic);
_dctd.GetProperty(nameof(TimeUpper)).SetIsBrowsable(!_steadyStep.Harmonic);
//
//
bool browsable = _steadyStep.ModalDamping.DampingType == ModalDampingTypeEnum.Constant;
_dctd.GetProperty(nameof(ViscousDampingRatio)).SetIsBrowsable(browsable);
//
browsable = _steadyStep.ModalDamping.DampingType == ModalDampingTypeEnum.Direct;
_dctd.GetProperty(nameof(DampingRatiosAndRanges)).SetIsBrowsable(browsable);
//
browsable = _steadyStep.ModalDamping.DampingType == ModalDampingTypeEnum.Rayleigh;
_dctd.GetProperty(nameof(Alpha)).SetIsBrowsable(browsable);
_dctd.GetProperty(nameof(Beta)).SetIsBrowsable(browsable);
}
}
}