154 lines
6.2 KiB
C#
154 lines
6.2 KiB
C#
|
|
using System;
|
|||
|
|
using System.Collections.Generic;
|
|||
|
|
using System.Linq;
|
|||
|
|
using System.Text;
|
|||
|
|
using System.Threading.Tasks;
|
|||
|
|
using System.Runtime.Serialization;
|
|||
|
|
using DynamicTypeDescriptor;
|
|||
|
|
|
|||
|
|
namespace CaeModel
|
|||
|
|
{
|
|||
|
|
[Serializable]
|
|||
|
|
public enum SolutionProcedureEnum
|
|||
|
|
{
|
|||
|
|
[StandardValue("ImplicitImplicit", DisplayName = "Implicit/Implicit")]
|
|||
|
|
ImplicitImplicit = 0,
|
|||
|
|
//
|
|||
|
|
[StandardValue("ImplicitExplicit", DisplayName = "Implicit/Explicit")]
|
|||
|
|
ImplicitExplicit = 1,
|
|||
|
|
//
|
|||
|
|
[StandardValue("ExplicitImplicit", DisplayName = "Explicit/Implicit")]
|
|||
|
|
ExplicitImplicit = 2,
|
|||
|
|
//
|
|||
|
|
[StandardValue("ExplicitExplicit", DisplayName = "Explicit/Explicit")]
|
|||
|
|
ExplicitExplicit = 3
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
[Serializable]
|
|||
|
|
public class DynamicStep : StaticStep, ISerializable
|
|||
|
|
{
|
|||
|
|
// Variables
|
|||
|
|
public static readonly double AlphaDefault = -0.05;
|
|||
|
|
private double _alpha; //ISerializable
|
|||
|
|
private SolutionProcedureEnum _solutionProcedure; //ISerializable
|
|||
|
|
private bool _relativeToAbsolute; //ISerializable
|
|||
|
|
private Damping _damping; //ISerializable
|
|||
|
|
|
|||
|
|
|
|||
|
|
// Properties
|
|||
|
|
public double Alpha
|
|||
|
|
{
|
|||
|
|
get { return _alpha; }
|
|||
|
|
set
|
|||
|
|
{
|
|||
|
|
_alpha = value;
|
|||
|
|
if (_alpha > 0) _alpha = 0;
|
|||
|
|
else if (_alpha < -1.0 / 3.0) _alpha = -1.0 / 3.0;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
public SolutionProcedureEnum SolutionProcedure { get { return _solutionProcedure; } set { _solutionProcedure = value; } }
|
|||
|
|
public bool RelativeToAbsolute { get { return _relativeToAbsolute; } set { _relativeToAbsolute = value; } }
|
|||
|
|
public Damping Damping { get { return _damping; } set { _damping = value; } }
|
|||
|
|
|
|||
|
|
|
|||
|
|
// Constructors
|
|||
|
|
public DynamicStep(string name)
|
|||
|
|
: this(name, true)
|
|||
|
|
{
|
|||
|
|
}
|
|||
|
|
public DynamicStep(string name, bool addFieldOutputs)
|
|||
|
|
: base(name, false)
|
|||
|
|
{
|
|||
|
|
_alpha = AlphaDefault;
|
|||
|
|
_solutionProcedure = SolutionProcedureEnum.ExplicitExplicit;
|
|||
|
|
_relativeToAbsolute = false;
|
|||
|
|
_damping = new Damping();
|
|||
|
|
_incrementationType = IncrementationTypeEnum.Automatic;
|
|||
|
|
//
|
|||
|
|
if (addFieldOutputs)
|
|||
|
|
{
|
|||
|
|
AddFieldOutput(new NodalFieldOutput("NF-Output-1", NodalFieldVariable.RF | NodalFieldVariable.U |
|
|||
|
|
NodalFieldVariable.V));
|
|||
|
|
AddFieldOutput(new ElementFieldOutput("EF-Output-1", ElementFieldVariable.E | ElementFieldVariable.S |
|
|||
|
|
ElementFieldVariable.ENER));
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
//ISerializable
|
|||
|
|
public DynamicStep(SerializationInfo info, StreamingContext context)
|
|||
|
|
: base(info, context)
|
|||
|
|
{
|
|||
|
|
foreach (SerializationEntry entry in info)
|
|||
|
|
{
|
|||
|
|
switch (entry.Name)
|
|||
|
|
{
|
|||
|
|
case "_alpha":
|
|||
|
|
_alpha = (double)entry.Value; break;
|
|||
|
|
case "_explicit":
|
|||
|
|
_solutionProcedure = (SolutionProcedureEnum)entry.Value; break;
|
|||
|
|
case "_relativeToAbsolute":
|
|||
|
|
_relativeToAbsolute = (bool)entry.Value; break;
|
|||
|
|
case "_damping":
|
|||
|
|
_damping = (Damping)entry.Value; break;
|
|||
|
|
default:
|
|||
|
|
break;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
|
|||
|
|
// Methods
|
|||
|
|
public override bool IsBoundaryConditionSupported(BoundaryCondition boundaryCondition)
|
|||
|
|
{
|
|||
|
|
if (boundaryCondition is FixedBC ||
|
|||
|
|
boundaryCondition is DisplacementRotation ||
|
|||
|
|
boundaryCondition is SubmodelBC)
|
|||
|
|
return true;
|
|||
|
|
else if (boundaryCondition is TemperatureBC)
|
|||
|
|
return false;
|
|||
|
|
else throw new NotSupportedException();
|
|||
|
|
}
|
|||
|
|
public override bool IsLoadTypeSupported(Type loadType)
|
|||
|
|
{
|
|||
|
|
if (loadType == typeof(CLoad) ||
|
|||
|
|
loadType == typeof(MomentLoad) ||
|
|||
|
|
loadType == typeof(DLoad) ||
|
|||
|
|
loadType == typeof(HydrostaticPressure) ||
|
|||
|
|
loadType == typeof(ImportedPressure) ||
|
|||
|
|
loadType == typeof(STLoad) ||
|
|||
|
|
loadType == typeof(ImportedSTLoad) ||
|
|||
|
|
loadType == typeof(ShellEdgeLoad) ||
|
|||
|
|
loadType == typeof(GravityLoad) ||
|
|||
|
|
loadType == typeof(CentrifLoad) ||
|
|||
|
|
loadType == typeof(PreTensionLoad))
|
|||
|
|
{
|
|||
|
|
return true;
|
|||
|
|
}
|
|||
|
|
else if (loadType == typeof(CFlux) ||
|
|||
|
|
loadType == typeof(DFlux) ||
|
|||
|
|
loadType == typeof(BodyFlux) ||
|
|||
|
|
loadType == typeof(FilmHeatTransfer) ||
|
|||
|
|
loadType == typeof(RadiationHeatTransfer))
|
|||
|
|
{
|
|||
|
|
return false;
|
|||
|
|
}
|
|||
|
|
else throw new NotSupportedException();
|
|||
|
|
}
|
|||
|
|
public override bool IsDefinedFieldSupported(DefinedField definedField)
|
|||
|
|
{
|
|||
|
|
if (definedField is DefinedTemperature) return true;
|
|||
|
|
else throw new NotSupportedException();
|
|||
|
|
}
|
|||
|
|
// ISerialization
|
|||
|
|
public new void GetObjectData(SerializationInfo info, StreamingContext context)
|
|||
|
|
{
|
|||
|
|
// Using typeof() works also for null fields
|
|||
|
|
base.GetObjectData(info, context);
|
|||
|
|
//
|
|||
|
|
info.AddValue("_alpha", _alpha, typeof(double));
|
|||
|
|
info.AddValue("_explicit", _solutionProcedure, typeof(SolutionProcedureEnum));
|
|||
|
|
info.AddValue("_relativeToAbsolute", _relativeToAbsolute, typeof(bool));
|
|||
|
|
info.AddValue("_damping", _damping, typeof(Damping));
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|