226 lines
9.4 KiB
C#
226 lines
9.4 KiB
C#
|
|
using System;
|
|||
|
|
using System.Collections.Generic;
|
|||
|
|
using System.Linq;
|
|||
|
|
using System.Text;
|
|||
|
|
using System.Threading.Tasks;
|
|||
|
|
using CaeMesh;
|
|||
|
|
using CaeGlobals;
|
|||
|
|
using System.Runtime.Serialization;
|
|||
|
|
|
|||
|
|
namespace CaeModel
|
|||
|
|
{
|
|||
|
|
[Serializable]
|
|||
|
|
public class MomentLoad : Load, ISerializable
|
|||
|
|
{
|
|||
|
|
// Variables
|
|||
|
|
private string _regionName; //ISerializable
|
|||
|
|
private RegionTypeEnum _regionType; //ISerializable
|
|||
|
|
private int _nodeId; //ISerializable
|
|||
|
|
private EquationContainer _m1; //ISerializable
|
|||
|
|
private EquationContainer _m2; //ISerializable
|
|||
|
|
private EquationContainer _m3; //ISerializable
|
|||
|
|
private EquationContainer _magnitude; //ISerializable
|
|||
|
|
|
|||
|
|
|
|||
|
|
// Properties
|
|||
|
|
public override string RegionName { get { return _regionName; } set { _regionName = value; } }
|
|||
|
|
public override RegionTypeEnum RegionType { get { return _regionType; } set { _regionType = value; } }
|
|||
|
|
public int NodeId { get { return _nodeId; } set { _nodeId = value; } }
|
|||
|
|
public EquationContainer M1 { get { UpdateEquations(); return _m1; } set { SetM1(value); } }
|
|||
|
|
public EquationContainer M2 { get { UpdateEquations(); return _m2; } set { SetM2(value); } }
|
|||
|
|
public EquationContainer M3 { get { UpdateEquations(); return _m3; } set { SetM3(value); } }
|
|||
|
|
public EquationContainer Magnitude { get { UpdateEquations(); return _magnitude; } set { SetMagnitude(value); } }
|
|||
|
|
public double GetDirection(int direction)
|
|||
|
|
{
|
|||
|
|
if (direction == 0) return M1.Value;
|
|||
|
|
else if (direction == 1) return M2.Value;
|
|||
|
|
else if (direction == 2) return M3.Value;
|
|||
|
|
else throw new NotSupportedException();
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
|
|||
|
|
// Constructors
|
|||
|
|
public MomentLoad(string name, int nodeId, double m1, double m2, double m3, bool twoD, bool complex, double phaseDeg)
|
|||
|
|
: this(name, null, RegionTypeEnum.NodeId, m1, m2, m3, twoD, complex, phaseDeg)
|
|||
|
|
{
|
|||
|
|
_nodeId = nodeId; // set the nodeId
|
|||
|
|
}
|
|||
|
|
public MomentLoad(string name, string regionName, RegionTypeEnum regionType, double m1, double m2, double m3,
|
|||
|
|
bool twoD, bool complex, double phaseDeg)
|
|||
|
|
: base(name, twoD, complex, phaseDeg)
|
|||
|
|
{
|
|||
|
|
_regionName = regionName;
|
|||
|
|
RegionType = regionType;
|
|||
|
|
_nodeId = -1;
|
|||
|
|
//
|
|||
|
|
double mag = Math.Sqrt(m1 * m1 + m2 * m2 + m3 * m3);
|
|||
|
|
M1 = new EquationContainer(typeof(StringMomentConverter), m1);
|
|||
|
|
M2 = new EquationContainer(typeof(StringMomentConverter), m2);
|
|||
|
|
M3 = new EquationContainer(typeof(StringMomentConverter), m3);
|
|||
|
|
Magnitude = new EquationContainer(typeof(StringMomentConverter), mag);
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
public MomentLoad(SerializationInfo info, StreamingContext context)
|
|||
|
|
: base(info, context)
|
|||
|
|
{
|
|||
|
|
foreach (SerializationEntry entry in info)
|
|||
|
|
{
|
|||
|
|
switch (entry.Name)
|
|||
|
|
{
|
|||
|
|
case "_regionName":
|
|||
|
|
_regionName = (string)entry.Value; break;
|
|||
|
|
case "_regionType":
|
|||
|
|
_regionType = (RegionTypeEnum)entry.Value; break;
|
|||
|
|
case "_nodeId":
|
|||
|
|
_nodeId = (int)entry.Value; break;
|
|||
|
|
case "_m1":
|
|||
|
|
// Compatibility for version v1.4.0
|
|||
|
|
if (entry.Value is double valueM1)
|
|||
|
|
M1 = new EquationContainer(typeof(StringMomentConverter), valueM1);
|
|||
|
|
else
|
|||
|
|
SetM1((EquationContainer)entry.Value, false);
|
|||
|
|
break;
|
|||
|
|
case "_m2":
|
|||
|
|
// Compatibility for version v1.4.0
|
|||
|
|
if (entry.Value is double valueM2)
|
|||
|
|
M2 = new EquationContainer(typeof(StringMomentConverter), valueM2);
|
|||
|
|
else
|
|||
|
|
SetM2((EquationContainer)entry.Value, false);
|
|||
|
|
break;
|
|||
|
|
case "_m3":
|
|||
|
|
// Compatibility for version v1.4.0
|
|||
|
|
if (entry.Value is double valueM3)
|
|||
|
|
M3 = new EquationContainer(typeof(StringMomentConverter), valueM3);
|
|||
|
|
else
|
|||
|
|
SetM3((EquationContainer)entry.Value, false);
|
|||
|
|
break;
|
|||
|
|
case "_magnitude":
|
|||
|
|
SetMagnitude((EquationContainer)entry.Value, false); break;
|
|||
|
|
default:
|
|||
|
|
break;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
// Compatibility for version v1.4.0
|
|||
|
|
if (_magnitude == null)
|
|||
|
|
{
|
|||
|
|
double mag = Math.Sqrt(_m1.Value * _m1.Value + _m2.Value * _m2.Value + _m3.Value * _m3.Value);
|
|||
|
|
Magnitude = new EquationContainer(typeof(StringMomentConverter), mag);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
|
|||
|
|
// Methods
|
|||
|
|
private void UpdateEquations()
|
|||
|
|
{
|
|||
|
|
try
|
|||
|
|
{
|
|||
|
|
// If error catch it silently
|
|||
|
|
if (_m1.IsEquation() || _m2.IsEquation() || _m3.IsEquation()) MEquationChanged();
|
|||
|
|
else if (_magnitude.IsEquation()) MagnitudeEquationChanged();
|
|||
|
|
}
|
|||
|
|
catch (Exception ex) { }
|
|||
|
|
}
|
|||
|
|
private void SetM1(EquationContainer value, bool checkEquation = true)
|
|||
|
|
{
|
|||
|
|
EquationContainer.SetAndCheck(ref _m1, value, Check2D, MEquationChanged, checkEquation);
|
|||
|
|
}
|
|||
|
|
private void SetM2(EquationContainer value, bool checkEquation = true)
|
|||
|
|
{
|
|||
|
|
EquationContainer.SetAndCheck(ref _m2, value, Check2D, MEquationChanged, checkEquation);
|
|||
|
|
}
|
|||
|
|
private void SetM3(EquationContainer value, bool checkEquation = true)
|
|||
|
|
{
|
|||
|
|
EquationContainer.SetAndCheck(ref _m3, value, null, MEquationChanged, checkEquation);
|
|||
|
|
}
|
|||
|
|
private void SetMagnitude(EquationContainer value, bool checkEquation = true)
|
|||
|
|
{
|
|||
|
|
EquationContainer.SetAndCheck(ref _magnitude, value, CheckMagnitude, MagnitudeEquationChanged, checkEquation);
|
|||
|
|
}
|
|||
|
|
//
|
|||
|
|
private void MEquationChanged()
|
|||
|
|
{
|
|||
|
|
double mag = Math.Sqrt(_m1.Value * _m1.Value + _m2.Value * _m2.Value + _m3.Value * _m3.Value);
|
|||
|
|
_magnitude.SetEquationFromValue(mag, false);
|
|||
|
|
}
|
|||
|
|
private void MagnitudeEquationChanged()
|
|||
|
|
{
|
|||
|
|
double c1;
|
|||
|
|
double c2;
|
|||
|
|
double c3;
|
|||
|
|
//
|
|||
|
|
if (_magnitude.Value == 0)
|
|||
|
|
{
|
|||
|
|
c1 = 0;
|
|||
|
|
c2 = 0;
|
|||
|
|
c3 = 0;
|
|||
|
|
}
|
|||
|
|
else
|
|||
|
|
{
|
|||
|
|
double r;
|
|||
|
|
c1 = _m1.Value;
|
|||
|
|
c2 = _m2.Value;
|
|||
|
|
c3 = _m3.Value;
|
|||
|
|
double mag = Math.Sqrt(c1 * c1 + c2 * c2 + c3 * c3);
|
|||
|
|
//
|
|||
|
|
if (mag != 0)
|
|||
|
|
{
|
|||
|
|
r = _magnitude.Value / mag;
|
|||
|
|
c1 *= r;
|
|||
|
|
c2 *= r;
|
|||
|
|
c3 *= r;
|
|||
|
|
}
|
|||
|
|
else
|
|||
|
|
{
|
|||
|
|
r = Math.Sqrt(Math.Pow(_magnitude.Value, 2) / 3);
|
|||
|
|
c1 = r;
|
|||
|
|
c2 = r;
|
|||
|
|
c3 = r;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
//
|
|||
|
|
_m1.SetEquationFromValue(c1, false);
|
|||
|
|
_m2.SetEquationFromValue(c2, false);
|
|||
|
|
_m3.SetEquationFromValue(c3, false);
|
|||
|
|
}
|
|||
|
|
//
|
|||
|
|
private double Check2D(double value)
|
|||
|
|
{
|
|||
|
|
if (_twoD) return 0;
|
|||
|
|
else return value;
|
|||
|
|
}
|
|||
|
|
private double CheckMagnitude(double value)
|
|||
|
|
{
|
|||
|
|
if (value < 0) throw new Exception("Value of the moment load magnitude must be non-negative.");
|
|||
|
|
else return value;
|
|||
|
|
}
|
|||
|
|
public double[] GetDirection()
|
|||
|
|
{
|
|||
|
|
return new double[] { _m1.Value, _m2.Value, _m3.Value };
|
|||
|
|
}
|
|||
|
|
// IContainsEquations
|
|||
|
|
public override void CheckEquations()
|
|||
|
|
{
|
|||
|
|
base.CheckEquations();
|
|||
|
|
//
|
|||
|
|
_m1.CheckEquation();
|
|||
|
|
_m2.CheckEquation();
|
|||
|
|
_m3.CheckEquation();
|
|||
|
|
_magnitude.CheckEquation();
|
|||
|
|
}
|
|||
|
|
// ISerialization
|
|||
|
|
public new void GetObjectData(SerializationInfo info, StreamingContext context)
|
|||
|
|
{
|
|||
|
|
// Using typeof() works also for null fields
|
|||
|
|
base.GetObjectData(info, context);
|
|||
|
|
//
|
|||
|
|
info.AddValue("_regionName", _regionName, typeof(string));
|
|||
|
|
info.AddValue("_regionType", _regionType, typeof(RegionTypeEnum));
|
|||
|
|
info.AddValue("_nodeId", _nodeId, typeof(int));
|
|||
|
|
info.AddValue("_m1", _m1, typeof(EquationContainer));
|
|||
|
|
info.AddValue("_m2", _m2, typeof(EquationContainer));
|
|||
|
|
info.AddValue("_m3", _m3, typeof(EquationContainer));
|
|||
|
|
info.AddValue("_magnitude", _magnitude, typeof(EquationContainer));
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|