|
@@ -1,13 +1,19 @@
|
|
|
-using BHJD.DEMdll.Public;
|
|
|
-using KYFramework;
|
|
|
+using KYFramework;
|
|
|
using Model;
|
|
|
+using MuShiApp;
|
|
|
+using SimulationCommon;
|
|
|
+using SimulationSingleServer.Utils;
|
|
|
+using Unity.Mathematics;
|
|
|
+using Define = SimulationServer.Utils.Define;
|
|
|
+using Random = System.Random;
|
|
|
|
|
|
namespace SimulationServer;
|
|
|
|
|
|
public class AircraftSJ : AircraftEntity
|
|
|
{
|
|
|
- public MissionEndPoint MissionEndPoint;
|
|
|
-
|
|
|
+ public bool IsOver;
|
|
|
+
|
|
|
+ private MissionEndPoint MissionEndPoint;
|
|
|
private CurrentLocation currentLocation;
|
|
|
private double temptime = 0;
|
|
|
private double probability = 0;
|
|
@@ -15,86 +21,132 @@ public class AircraftSJ : AircraftEntity
|
|
|
private Random random = new Random();
|
|
|
private bool isseefire = false;
|
|
|
private int fireIndex = -1; // 记录发现火点的位置
|
|
|
- public bool IsOver;
|
|
|
+ public EquationHelper helper;
|
|
|
+
|
|
|
public override void Start()
|
|
|
{
|
|
|
- FXJHGenerate.FromStartToMission(FlightPlanEditor, ref TurningPoints);//生成从起点到任务段起点的航路点
|
|
|
+ //TODO 计算 AirRoute[]
|
|
|
+
|
|
|
+ float[] longitudeArray = null;//:经度一维数组;
|
|
|
+ float[] latitudeArray = null;//:纬度一维数组;
|
|
|
+ float[][][] u10Arrayu = null;// 10Array:风的10米U分量三维数组_24(时间)*7(纬度)*10(经度);
|
|
|
+
|
|
|
+ float[][][] v10Array = null;// v10Array:风的10米V分量三维数组_24(时间)*7(纬度)*10(经度);
|
|
|
+
|
|
|
+ float[][][] p140208Array = null;//:海洋上空的自由对流速度_24(时间)*7(纬度)*10(经度);
|
|
|
+ float[][][] mwdArray = null;//:平均波向_24(时间)*7(纬度)*10(经度);
|
|
|
+
|
|
|
+ WeatherResponse weatherResponse = new WeatherResponse() { };
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ //
|
|
|
+
|
|
|
+
|
|
|
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ FXJHGenerate.FromStartToMission(FlightPlanEditor, ref TurningPoints); //生成从起点到任务段起点的航路点
|
|
|
+
|
|
|
+ FXJHGenerate.SeaSouJiu(FlightPlanEditor, ref TurningPoints);
|
|
|
+
|
|
|
FXJHGenerate.FXJHTPDiedai(FlightPlanEditor, ref TurningPoints, Velocitys, FuelConsumptions);
|
|
|
- }
|
|
|
|
|
|
- public override void Update(double time)
|
|
|
- {
|
|
|
- if (!isseefire)
|
|
|
+ Task.Run(() =>
|
|
|
{
|
|
|
- (currentLocation, _) = FXJHGenerate.GetCurrentLocation(TurningPoints, FlightPlanEditor, temptime);// 获取飞机当前位置
|
|
|
- //*******
|
|
|
- probability = EquationHelper.getProbability(); // 计算发现概率,需要其他模型输入
|
|
|
+ bool isseefire = false;
|
|
|
+ double temptime = 0; // 自增时间,每次增加1s
|
|
|
+ CurrentLocation currentLocation = new CurrentLocation();
|
|
|
+ double probability = 0;
|
|
|
+ double finalProbability = 1.0;
|
|
|
+ Random random = new Random();
|
|
|
+ int fireIndex = -1; // 记录发现火点的位置
|
|
|
|
|
|
- finalProbability *= (1 - probability);
|
|
|
- double randomValue = random.NextDouble(); // 生成随机数比较概率
|
|
|
- if (randomValue < (1 - finalProbability))
|
|
|
+ do
|
|
|
{
|
|
|
- isseefire = true;
|
|
|
- fireIndex = currentLocation.Currentsegnum; // 记录当前航路点位置
|
|
|
- IsOver = true;
|
|
|
- }
|
|
|
- else
|
|
|
+ (currentLocation, _) =
|
|
|
+ FXJHGenerate.GetCurrentLocation(TurningPoints, FlightPlanEditor, temptime); // 获取飞机当前位置
|
|
|
+ double3 aricraftPoint = new double3(currentLocation.CurrentLon, currentLocation.CurrentLat,
|
|
|
+ currentLocation.CurrentHei);
|
|
|
+
|
|
|
+ double3 targetPoint = new double3(FlightPlanEditor.targetpoint[0].TargetPointLongitude,
|
|
|
+ FlightPlanEditor.targetpoint[0].TargetPointLatitude,
|
|
|
+ FlightPlanEditor.targetpoint[0].TargetPointHeight);
|
|
|
+
|
|
|
+ //*******
|
|
|
+ probability = helper.getProbability(aricraftPoint, targetPoint, currentLocation.CurrentCourse,
|
|
|
+ Define.WIND, 1, "落水人员", "陆地"); // 计算发现概率,需要其他模型输入 // 计算发现概率,需要其他模型输入
|
|
|
+
|
|
|
+ finalProbability *= (1 - probability);
|
|
|
+
|
|
|
+ Console.WriteLine($"海上任务: {Name} 当前时间:{temptime},当前位置:{currentLocation.CurrentLon},{currentLocation.CurrentLat},{currentLocation.CurrentHei},概率:{probability},最终概率:{1 -finalProbability},是否看到火点:{isseefire}");
|
|
|
+
|
|
|
+ double randomValue = random.NextDouble(); // 生成随机数比较概率
|
|
|
+ if (randomValue < (1 - finalProbability))
|
|
|
+ {
|
|
|
+ isseefire = true;
|
|
|
+ fireIndex = currentLocation.Currentsegnum; // 记录当前航路点位置
|
|
|
+ IsOver = true;
|
|
|
+ }
|
|
|
+ else
|
|
|
+ {
|
|
|
+ isseefire = false;
|
|
|
+ }
|
|
|
+
|
|
|
+ if (temptime >= 7200) IsOver = true;
|
|
|
+
|
|
|
+ temptime += 1;
|
|
|
+ } while (!isseefire && IsOver == false);
|
|
|
+
|
|
|
+ finalProbability = 1 - finalProbability;
|
|
|
+
|
|
|
+ if (fireIndex != -1)
|
|
|
{
|
|
|
- isseefire = false;
|
|
|
+ // 删除目标点位置开始的所有后续航路点
|
|
|
+ TurningPoints.RemoveRange(fireIndex + 1, TurningPoints.Count - fireIndex - 1);
|
|
|
+
|
|
|
+
|
|
|
+ MissionPoint missionPoint = new MissionPoint
|
|
|
+ {
|
|
|
+ MissionPointLongitude = currentLocation.CurrentLon,
|
|
|
+ MissionPointLatitude = currentLocation.CurrentLat,
|
|
|
+ MissionPointHeight = currentLocation.CurrentHei
|
|
|
+ };
|
|
|
+ FXJHGenerate.SeaSouJiu2(FlightPlanEditor, missionPoint, ref TurningPoints);
|
|
|
+
|
|
|
+ //*********
|
|
|
+ //更新任务终点
|
|
|
+ //发现的目标坐标,需要其他模型输入
|
|
|
+ FXJHGenerate.FromMissionToEnd(FlightPlanEditor, MissionEndPoint, ref TurningPoints);
|
|
|
}
|
|
|
- temptime += 1;
|
|
|
- }
|
|
|
-
|
|
|
+
|
|
|
+ FXJHGenerate.FXJHTPDiedai(FlightPlanEditor, ref TurningPoints, Velocitys, FuelConsumptions);
|
|
|
+ End();
|
|
|
+ });
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
+
|
|
|
public override void End()
|
|
|
{
|
|
|
- finalProbability = 1 - finalProbability;
|
|
|
- if (fireIndex != -1)
|
|
|
- {
|
|
|
- // 删除目标点位置开始的所有后续航路点
|
|
|
- TurningPoints.RemoveRange(fireIndex + 1, TurningPoints.Count - fireIndex - 1);
|
|
|
|
|
|
-
|
|
|
- MissionPoint missionPoint = new MissionPoint
|
|
|
- {
|
|
|
- MissionPointLongitude = currentLocation.CurrentLon,
|
|
|
- MissionPointLatitude = currentLocation.CurrentLat,
|
|
|
- MissionPointHeight = currentLocation.CurrentHei
|
|
|
- };
|
|
|
-
|
|
|
- FXJHGenerate.SeaSouJiu2(FlightPlanEditor, missionPoint, ref TurningPoints);
|
|
|
- }
|
|
|
-
|
|
|
-
|
|
|
- //*********
|
|
|
- //更新任务终点
|
|
|
- FXJHGenerate.FromMissionToEnd(FlightPlanEditor, MissionEndPoint, ref TurningPoints);
|
|
|
-
|
|
|
- FXJHGenerate.FXJHTPDiedai(FlightPlanEditor, ref TurningPoints, Velocitys, Velocitys);
|
|
|
-
|
|
|
-
|
|
|
- for (int i = 0; i < currentLocation.Currentsegnum+2; i++)
|
|
|
+ for (int i = 0; i < currentLocation.Currentsegnum + 2; i++)
|
|
|
{
|
|
|
EffMisTime += TurningPoints[i].SegmentFlightTime;
|
|
|
}
|
|
|
-
|
|
|
- TotalFuelConsumption = TurningPoints[0].RemainingFuel - TurningPoints[currentLocation.Currentsegnum+1].RemainingFuel;
|
|
|
-
|
|
|
+
|
|
|
+ TotalFuelConsumption = TurningPoints[0].RemainingFuel -
|
|
|
+ TurningPoints[currentLocation.Currentsegnum + 1].RemainingFuel;
|
|
|
}
|
|
|
}
|
|
|
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
[ObjectSystem]
|
|
|
-public class AircraftSJAwakeSystem : AwakeSystem<AircraftSJ,FlightPlanEditor>
|
|
|
+public class AircraftSJAwakeSystem : AwakeSystem<AircraftSJ, FlightPlanEditor>
|
|
|
{
|
|
|
- public override void Awake(AircraftSJ self,FlightPlanEditor flightPlanEditor)
|
|
|
+ public override void Awake(AircraftSJ self, FlightPlanEditor flightPlanEditor)
|
|
|
{
|
|
|
self.FlightPlanEditor = flightPlanEditor;
|
|
|
-
|
|
|
+ self.helper = new EquationHelper(HttpInterface.baseUrl);
|
|
|
self.Awake();
|
|
|
}
|
|
|
}
|