using KYFramework; using Model; using OpenQA.Selenium.Remote; using SimulationCommon; using SimulationServer.Utils; namespace SimulationServer; public class TaskComponent : Component { public static Weather Weather; public static int Speed = 100; // 救援任务列表 public List MHRescueMissions; public List XHRescueMissions; public List ZCRescueMissions; public List SeaSJRescueMissions; public List LandSJRescueMissions; public List KZDYMissions; public List KTKSMissions; public List ZSJYMissions; public List JJJYMissions; public List SHJMissions; public List XCJJMissions; public List YLZYMissions; public List YLWPYSMissions; public List JCDZZYMissions; public SJAllTotalTaskPerformanceComponent SSJAllTotalTaskPerformance = new SJAllTotalTaskPerformanceComponent(); public Dictionary>> alltotalReportSea = new(); public Dictionary>> alltotalReportLand = new(); // > public Dictionary>> totalReportSea = new(); public Dictionary>> totalReportLand = new(); private int currentSeaExecuteCount = 1; private int currentLandExecuteCount = 1; public int ExecutionContext = 0; public int seaSuccessCount = 0; public int landSuccessCount = 0; public bool isSea; public bool isLand; public string date; public int missionCount; public void Start() { MHRescueMissions?.ForEach(r => r.Reset()); XHRescueMissions?.ForEach(r => r.Reset()); MHRescueMissions?.ForEach(r => r.Start()); XHRescueMissions?.ForEach(r => r.Start()); ZCRescueMissions?.ForEach(r => r.Start()); SeaSJRescueMissions?.ForEach(r => r.Start()); LandSJRescueMissions?.ForEach(r => r.Start()); KZDYMissions?.ForEach(r => r.Start()); KTKSMissions?.ForEach(r => r.Start()); ZSJYMissions?.ForEach(r => r.Start()); JJJYMissions?.ForEach(r => r.Start()); SHJMissions?.ForEach(r => r.Start()); XCJJMissions?.ForEach(r => r.Start()); YLZYMissions?.ForEach(r => r.Start()); YLWPYSMissions?.ForEach(r => r.Start()); JCDZZYMissions?.ForEach(r => r.Start()); } public void SaveSeaSJ(Dictionary> totalReport) { //把totalReport保存到alltotalReport foreach (var kv in totalReport) { if (!alltotalReportSea.ContainsKey(kv.Key)) alltotalReportSea[kv.Key] = new Dictionary>(); foreach (var kv2 in kv.Value) { if (!alltotalReportSea[kv.Key].ContainsKey(kv2.Key)) alltotalReportSea[kv.Key][kv2.Key] = new List(); alltotalReportSea[kv.Key][kv2.Key].Add(kv2.Value); } } if (currentSeaExecuteCount == ExecutionContext) { // 求一个平均值放到最后一位 foreach (var kv in alltotalReportSea) { foreach (var kv2 in kv.Value) { var sum = 0f; foreach (var value in kv2.Value) { bool isfloat = float.TryParse(value, out float f); if (isfloat) sum += float.Parse(value); else sum = -1f; } if (sum != -1f) kv2.Value.Add((sum / kv2.Value.Count).ToString()); else kv2.Value.Add(""); } } } currentSeaExecuteCount++; } public void SaveLandSJ(Dictionary> totalReport) { //把totalReport保存到alltotalReport foreach (var kv in totalReport) { if (!alltotalReportLand.ContainsKey(kv.Key)) alltotalReportLand[kv.Key] = new Dictionary>(); foreach (var kv2 in kv.Value) { if (!alltotalReportLand[kv.Key].ContainsKey(kv2.Key)) alltotalReportLand[kv.Key][kv2.Key] = new List(); alltotalReportLand[kv.Key][kv2.Key].Add(kv2.Value); } } if (currentLandExecuteCount == ExecutionContext) { // 求一个平均值放到最后一位 foreach (var kv in alltotalReportLand) { foreach (var kv2 in kv.Value) { var sum = 0f; foreach (var value in kv2.Value) { bool isfloat = float.TryParse(value, out float f); if (isfloat) sum += float.Parse(value); else sum = -1f; } if (sum != -1f) kv2.Value.Add((sum / kv2.Value.Count).ToString()); else kv2.Value.Add(""); } } } currentLandExecuteCount++; } public void ReportAllSJSea() { //string data = DateTime.Now.ToString("yyyy-MM-dd"); string path = $"Reports/{date}"; if (!Directory.Exists(path)) Directory.CreateDirectory(path); string totalPath = ""; if (isSea) totalPath = $"{path}/{"海上搜救任务总体指标报告"}.xls"; if (isLand) totalPath = $"{path}/{"陆上搜救任务总体指标报告"}.xls"; DataTableExtensions.SaveToExcel(totalPath, alltotalReportSea, true, true, (seaSuccessCount * 1f / ExecutionContext).ToString()); //string totalPath1 = $"{path}/{"搜救任务总体指标报告"}.xls"; //DataTableExtensions.SaveToExcel(totalPath1, totalReportSea); } public void ReportAllSJLand() { string data = DateTime.Now.ToString("yyyy-MM-dd"); string path = $"Reports/{date}"; if (!Directory.Exists(path)) Directory.CreateDirectory(path); string totalPath = $"{path}/{"陆上搜寻任务总体指标报告"}.xls"; DataTableExtensions.SaveToExcel(totalPath, alltotalReportLand, true, true, (landSuccessCount * 1f / ExecutionContext).ToString()); //string totalPath1 = $"{path}/{"搜救任务总体指标报告"}.xls"; //DataTableExtensions.SaveToExcel(totalPath1, totalReportLand); } public void SaveTotalMHSea() { if (!totalReportSea.ContainsKey("总任务表现")) totalReportSea["总任务表现"] = new Dictionary>(); if (!totalReportSea["总任务表现"].ContainsKey("任务成功率")) totalReportSea["总任务表现"]["任务成功率"] = new List(); totalReportSea["总任务表现"]["任务成功率"].Add((seaSuccessCount * 1f / ExecutionContext).ToString()); } public void SaveTotalMHLand() { if (!totalReportLand.ContainsKey("总任务表现")) totalReportLand["总任务表现"] = new Dictionary>(); if (!totalReportLand["总任务表现"].ContainsKey("任务成功率")) totalReportLand["总任务表现"]["任务成功率"] = new List(); totalReportLand["总任务表现"]["任务成功率"].Add((landSuccessCount * 1f / ExecutionContext).ToString()); } } [ObjectSystem] public class TaskComponentAwakeSystem : AwakeSystem { public override void Awake(TaskComponent self) { self.MHRescueMissions = new List(); self.ZCRescueMissions = new List(); self.XHRescueMissions = new List(); self.SeaSJRescueMissions = new List(); self.LandSJRescueMissions = new List(); self.KZDYMissions = new List(); self.KTKSMissions = new List(); self.ZSJYMissions = new List(); self.JJJYMissions = new List(); self.SHJMissions = new List(); self.XCJJMissions = new List(); self.YLZYMissions = new List(); self.YLWPYSMissions = new List(); self.JCDZZYMissions = new List(); } } [ObjectSystem] public class TaskComponentUpdateSystem : UpdateSystem { double 任务准备时间 = 0; double 平均搜索时间 = 0; double 总飞行时间 = 0; double 人员存活率 = 0; double 任务是否成功 = 0; float 识别成功率 = 0f; double 平均救助时间 = 0; float 人员数量 = 0; float 识别数量 = 0; double 环境搜索覆盖面积 = 0; double 海上搜索覆盖面积 = 0; double aircreftCount = 0; double searchCount = 0; double jzCount = 0; public bool isSeaSJRescueMissionsOver = false; public bool isLandSJRescueMissionsOver = false; public bool isKZDYMissionsOver = false; public bool isKTKSMissionsOver = false; public bool isZSJYMissionsOver = false; public bool isJJJYMissionsOver = false; public bool isSHJMissionsOver = false; public bool isXCJJMissionsOver = false; public bool isYLZYMissionsOver = false; public bool isYLWPYSMissionsOver = false; public bool isJCDZZYMissionsOver = false; public bool isReport; public override void Update(TaskComponent self) { if (self.SeaSJRescueMissions.Count > 0) { if (self.SeaSJRescueMissions.All(m => m.IsOver) && !isSeaSJRescueMissionsOver) { self.missionCount -= self.SeaSJRescueMissions.Count; isSeaSJRescueMissionsOver = true; //for (int i = 0; i < self.ExecutionContext; i++) //{ // self.SSJAllTotalTaskPerformance.FillData(self.SeaSJRescueMissions); // var report = self.SSJAllTotalTaskPerformance.GetReport(); // if (report["总任务表现"]["任务是否成功"] == "1") // self.seaSuccessCount++; // self.SaveSeaSJ(report); //} ////self.SaveTotalMHSea(); //self.ReportAllSJSea(); //self.SeaSJRescueMissions.Clear(); } } if (self.LandSJRescueMissions.Count > 0) { if (self.LandSJRescueMissions.All(m => m.IsOver) && !isLandSJRescueMissionsOver) { self.missionCount -= self.LandSJRescueMissions.Count; isLandSJRescueMissionsOver = true; //for (int i = 0; i < self.ExecutionContext; i++) //{ // self.SSJAllTotalTaskPerformance.FillData1(self.LandSJRescueMissions); // var report = self.SSJAllTotalTaskPerformance.GetReport1(); // if (report["总任务表现"]["任务是否成功"] == "1") // self.landSuccessCount++; // self.SaveLandSJ(report); //} ////self.SaveTotalMHLand(); //self.ReportAllSJLand(); //self.LandSJRescueMissions.Clear(); } } if (self.KZDYMissions.Count > 0) { if (self.KZDYMissions.All(m => m.IsOver) && !isKZDYMissionsOver) { self.missionCount -= self.KZDYMissions.Count; isKZDYMissionsOver = true; } } if (self.KTKSMissions.Count > 0) { if (self.KTKSMissions.All(m => m.IsOver) && !isKTKSMissionsOver) { self.missionCount -= self.KTKSMissions.Count; isKTKSMissionsOver = true; } } if (self.ZSJYMissions.Count > 0) { if (self.ZSJYMissions.All(m => m.IsOver) && !isZSJYMissionsOver) { self.missionCount -= self.ZSJYMissions.Count; isZSJYMissionsOver = true; } } if (self.JJJYMissions.Count > 0) { if (self.JJJYMissions.All(m => m.IsOver) && !isJJJYMissionsOver) { self.missionCount -= self.JJJYMissions.Count; isJJJYMissionsOver = true; } } if (self.SHJMissions.Count > 0) { if (self.SHJMissions.All(m => m.IsOver) && !isSHJMissionsOver) { self.missionCount -= self.SHJMissions.Count; isSHJMissionsOver = true; } } if (self.XCJJMissions.Count > 0) { if (self.XCJJMissions.All(m => m.IsOver) && !isXCJJMissionsOver) { self.missionCount -= self.XCJJMissions.Count; isXCJJMissionsOver = true; } } if (self.YLZYMissions.Count > 0) { if (self.YLZYMissions.All(m => m.IsOver) && !isYLZYMissionsOver) { self.missionCount -= self.YLZYMissions.Count; isYLZYMissionsOver = true; } } if (self.YLWPYSMissions.Count > 0) { if (self.YLWPYSMissions.All(m => m.IsOver) && !isYLWPYSMissionsOver) { self.missionCount -= self.YLWPYSMissions.Count; isYLWPYSMissionsOver = true; } } if (self.JCDZZYMissions.Count > 0) { if (self.JCDZZYMissions.All(m => m.IsOver) && !isJCDZZYMissionsOver) { self.missionCount -= self.JCDZZYMissions.Count; isJCDZZYMissionsOver = true; } } //Console.WriteLine("self.missionCount:" + self.missionCount); if (self.missionCount == 0 && !isReport) { for (int i = 0; i < self.ExecutionContext; i++) { 任务准备时间 = 0; 平均搜索时间 = 0; 总飞行时间 = 0; 人员存活率 = 0; 任务是否成功 = 0; 识别成功率 = 0f; 平均救助时间 = 0; 人员数量 = 0; 识别数量 = 0; 环境搜索覆盖面积 = 0; 海上搜索覆盖面积 = 0; aircreftCount = 0; searchCount = 0; jzCount = 0; foreach (var item in self.SeaSJRescueMissions) { foreach (var item1 in item.aircraftSJDatas) { 识别成功率 += float.Parse(item1.Value["识别成功率"][i]); 人员数量 += float.Parse(item1.Value["人员数量"][i]); 识别数量 += float.Parse(item1.Value["识别数量"][i]); if (任务准备时间 < float.Parse(item1.Value["任务准备时间"][i])) 任务准备时间 = float.Parse(item1.Value["任务准备时间"][i]); 平均搜索时间 += float.Parse(item1.Value["平均搜索时间"][i]); 平均救助时间 += float.Parse(item1.Value["平均救助时间"][i]); 总飞行时间 += float.Parse(item1.Value["总飞行时间"][i]); 人员存活率 += float.Parse(item1.Value["人员存活率"][i]); 海上搜索覆盖面积 += float.Parse(item1.Value["海上搜索覆盖面积"][i]); aircreftCount++; if (item1.Value["平均搜索时间"][i] != "0") searchCount++; if (item1.Value["平均救助时间"][i] != "0") jzCount++; Console.WriteLine("海上搜救" + item1.Key + "识别成功数:" + item1.Value["识别成功率"][i]); Console.WriteLine("海上搜救" + item1.Key + "识别数量:" + item1.Value["识别数量"][i]); Console.WriteLine("海上搜救" + item1.Key + "任务准备时间:" + item1.Value["任务准备时间"][i]); Console.WriteLine("海上搜救" + item1.Key + "平均搜索时间:" + item1.Value["平均搜索时间"][i]); Console.WriteLine("海上搜救" + item1.Key + "平均救助时间:" + item1.Value["平均救助时间"][i]); Console.WriteLine("海上搜救" + item1.Key + "总飞行时间:" + item1.Value["总飞行时间"][i]); Console.WriteLine("海上搜救" + item1.Key + "存活人数:" + item1.Value["人员存活率"][i]); Console.WriteLine("海上搜救" + item1.Key + "人员数量:" + item1.Value["人员数量"][i]); Console.WriteLine("海上搜救" + item1.Key + "海上搜索覆盖面积:" + item1.Value["海上搜索覆盖面积"][i]); Console.WriteLine("==============================================================="); } } foreach (var item in self.LandSJRescueMissions) { foreach (var item1 in item.aircraftSJDatas) { 识别成功率 += float.Parse(item1.Value["识别成功率"][i]); 人员数量 += float.Parse(item1.Value["人员数量"][i]); 识别数量 += float.Parse(item1.Value["识别数量"][i]); if (任务准备时间 < float.Parse(item1.Value["任务准备时间"][i])) 任务准备时间 = float.Parse(item1.Value["任务准备时间"][i]); 平均搜索时间 += float.Parse(item1.Value["平均搜索时间"][i]); 平均救助时间 += float.Parse(item1.Value["平均救助时间"][i]); 总飞行时间 += float.Parse(item1.Value["总飞行时间"][i]); 人员存活率 += float.Parse(item1.Value["人员存活率"][i]); 环境搜索覆盖面积 += float.Parse(item1.Value["环境搜索覆盖面积"][i]); aircreftCount++; if (item1.Value["平均搜索时间"][i] != "0") searchCount++; if (item1.Value["平均救助时间"][i] != "0") jzCount++; Console.WriteLine("路上搜寻" + item1.Key + "识别成功数:" + item1.Value["识别成功率"][i]); Console.WriteLine("路上搜寻" + item1.Key + "识别数量:" + item1.Value["识别数量"][i]); Console.WriteLine("路上搜寻" + item1.Key + "任务准备时间:" + item1.Value["任务准备时间"][i]); Console.WriteLine("路上搜寻" + item1.Key + "平均搜索时间:" + item1.Value["平均搜索时间"][i]); Console.WriteLine("路上搜寻" + item1.Key + "平均救助时间:" + item1.Value["平均救助时间"][i]); Console.WriteLine("路上搜寻" + item1.Key + "总飞行时间:" + item1.Value["总飞行时间"][i]); Console.WriteLine("路上搜寻" + item1.Key + "存活人数:" + item1.Value["人员存活率"][i]); Console.WriteLine("路上搜寻" + item1.Key + "人员数量:" + item1.Value["人员数量"][i]); Console.WriteLine("路上搜寻" + item1.Key + "环境搜索覆盖面积:" + item1.Value["环境搜索覆盖面积"][i]); Console.WriteLine("==============================================================="); } } foreach (var item in self.KZDYMissions) { foreach (var item1 in item.aircraftSJDatas) { 识别成功率 += float.Parse(item1.Value["识别成功率"][i]); 人员数量 += float.Parse(item1.Value["人员数量"][i]); 识别数量 += float.Parse(item1.Value["识别数量"][i]); if (任务准备时间 < float.Parse(item1.Value["任务准备时间"][i])) 任务准备时间 = float.Parse(item1.Value["任务准备时间"][i]); 平均搜索时间 += float.Parse(item1.Value["平均搜索时间"][i]); 平均救助时间 += float.Parse(item1.Value["平均救助时间"][i]); 总飞行时间 += float.Parse(item1.Value["总飞行时间"][i]); 人员存活率 += float.Parse(item1.Value["人员存活率"][i]); aircreftCount++; if (item1.Value["平均搜索时间"][i] != "0") searchCount++; if (item1.Value["平均救助时间"][i] != "0") jzCount++; Console.WriteLine("空中吊运" + item1.Key + "识别成功数:" + item1.Value["识别成功率"][i]); Console.WriteLine("空中吊运" + item1.Key + "识别数量:" + item1.Value["识别数量"][i]); Console.WriteLine("空中吊运" + item1.Key + "任务准备时间:" + item1.Value["任务准备时间"][i]); Console.WriteLine("空中吊运" + item1.Key + "平均搜索时间:" + item1.Value["平均搜索时间"][i]); Console.WriteLine("空中吊运" + item1.Key + "平均救助时间:" + item1.Value["平均救助时间"][i]); Console.WriteLine("空中吊运" + item1.Key + "总飞行时间:" + item1.Value["总飞行时间"][i]); Console.WriteLine("空中吊运" + item1.Key + "存活人数:" + item1.Value["人员存活率"][i]); Console.WriteLine("空中吊运" + item1.Key + "人员数量:" + item1.Value["人员数量"][i]); Console.WriteLine("==============================================================="); } } foreach (var item in self.KTKSMissions) { foreach (var item1 in item.aircraftSJDatas) { 识别成功率 += float.Parse(item1.Value["识别成功率"][i]); 人员数量 += float.Parse(item1.Value["人员数量"][i]); 识别数量 += float.Parse(item1.Value["识别数量"][i]); if (任务准备时间 < float.Parse(item1.Value["任务准备时间"][i])) 任务准备时间 = float.Parse(item1.Value["任务准备时间"][i]); 平均搜索时间 += float.Parse(item1.Value["平均搜索时间"][i]); 平均救助时间 += float.Parse(item1.Value["平均救助时间"][i]); 总飞行时间 += float.Parse(item1.Value["总飞行时间"][i]); 人员存活率 += float.Parse(item1.Value["人员存活率"][i]); aircreftCount++; if (item1.Value["平均搜索时间"][i] != "0") searchCount++; if (item1.Value["平均救助时间"][i] != "0") jzCount++; Console.WriteLine("空投空送" + item1.Key + "识别成功数:" + item1.Value["识别成功率"][i]); Console.WriteLine("空投空送" + item1.Key + "识别数量:" + item1.Value["识别数量"][i]); Console.WriteLine("空投空送" + item1.Key + "任务准备时间:" + item1.Value["任务准备时间"][i]); Console.WriteLine("空投空送" + item1.Key + "平均搜索时间:" + item1.Value["平均搜索时间"][i]); Console.WriteLine("空投空送" + item1.Key + "平均救助时间:" + item1.Value["平均救助时间"][i]); Console.WriteLine("空投空送" + item1.Key + "总飞行时间:" + item1.Value["总飞行时间"][i]); Console.WriteLine("空投空送" + item1.Key + "存活人数:" + item1.Value["人员存活率"][i]); Console.WriteLine("空投空送" + item1.Key + "人员数量:" + item1.Value["人员数量"][i]); Console.WriteLine("==============================================================="); } } foreach (var item in self.ZSJYMissions) { foreach (var item1 in item.aircraftSJDatas) { 识别成功率 += float.Parse(item1.Value["识别成功率"][i]); 人员数量 += float.Parse(item1.Value["人员数量"][i]); 识别数量 += float.Parse(item1.Value["识别数量"][i]); if (任务准备时间 < float.Parse(item1.Value["任务准备时间"][i])) 任务准备时间 = float.Parse(item1.Value["任务准备时间"][i]); 平均搜索时间 += float.Parse(item1.Value["平均搜索时间"][i]); 平均救助时间 += float.Parse(item1.Value["平均救助时间"][i]); 总飞行时间 += float.Parse(item1.Value["总飞行时间"][i]); 人员存活率 += float.Parse(item1.Value["人员存活率"][i]); aircreftCount++; if (item1.Value["平均搜索时间"][i] != "0") searchCount++; if (item1.Value["平均救助时间"][i] != "0") jzCount++; Console.WriteLine("着水救援" + item1.Key + "识别成功数:" + item1.Value["识别成功率"][i]); Console.WriteLine("着水救援" + item1.Key + "识别数量:" + item1.Value["识别数量"][i]); Console.WriteLine("着水救援" + item1.Key + "任务准备时间:" + item1.Value["任务准备时间"][i]); Console.WriteLine("着水救援" + item1.Key + "平均搜索时间:" + item1.Value["平均搜索时间"][i]); Console.WriteLine("着水救援" + item1.Key + "平均救助时间:" + item1.Value["平均救助时间"][i]); Console.WriteLine("着水救援" + item1.Key + "总飞行时间:" + item1.Value["总飞行时间"][i]); Console.WriteLine("着水救援" + item1.Key + "存活人数:" + item1.Value["人员存活率"][i]); Console.WriteLine("着水救援" + item1.Key + "人员数量:" + item1.Value["人员数量"][i]); Console.WriteLine("==============================================================="); } } foreach (var item in self.JJJYMissions) { foreach (var item1 in item.aircraftSJDatas) { 识别成功率 += float.Parse(item1.Value["识别成功率"][i]); 人员数量 += float.Parse(item1.Value["人员数量"][i]); 识别数量 += float.Parse(item1.Value["识别数量"][i]); if (任务准备时间 < float.Parse(item1.Value["任务准备时间"][i])) 任务准备时间 = float.Parse(item1.Value["任务准备时间"][i]); 平均搜索时间 += float.Parse(item1.Value["平均搜索时间"][i]); 平均救助时间 += float.Parse(item1.Value["平均救助时间"][i]); 总飞行时间 += float.Parse(item1.Value["总飞行时间"][i]); 人员存活率 += float.Parse(item1.Value["人员存活率"][i]); aircreftCount++; if (item1.Value["平均搜索时间"][i] != "0") searchCount++; if (item1.Value["平均救助时间"][i] != "0") jzCount++; Console.WriteLine("机降救援" + item1.Key + "识别成功数:" + item1.Value["识别成功率"][i]); Console.WriteLine("机降救援" + item1.Key + "识别数量:" + item1.Value["识别数量"][i]); Console.WriteLine("机降救援" + item1.Key + "任务准备时间:" + item1.Value["任务准备时间"][i]); Console.WriteLine("机降救援" + item1.Key + "平均搜索时间:" + item1.Value["平均搜索时间"][i]); Console.WriteLine("机降救援" + item1.Key + "平均救助时间:" + item1.Value["平均救助时间"][i]); Console.WriteLine("机降救援" + item1.Key + "总飞行时间:" + item1.Value["总飞行时间"][i]); Console.WriteLine("机降救援" + item1.Key + "存活人数:" + item1.Value["人员存活率"][i]); Console.WriteLine("机降救援" + item1.Key + "人员数量:" + item1.Value["人员数量"][i]); Console.WriteLine("==============================================================="); } } foreach (var item in self.SHJMissions) { foreach (var item1 in item.aircraftSJDatas) { 识别成功率 += float.Parse(item1.Value["识别成功率"][i]); 人员数量 += float.Parse(item1.Value["人员数量"][i]); 识别数量 += float.Parse(item1.Value["识别数量"][i]); if (任务准备时间 < float.Parse(item1.Value["任务准备时间"][i])) 任务准备时间 = float.Parse(item1.Value["任务准备时间"][i]); 平均搜索时间 += float.Parse(item1.Value["平均搜索时间"][i]); 平均救助时间 += float.Parse(item1.Value["平均救助时间"][i]); 总飞行时间 += float.Parse(item1.Value["总飞行时间"][i]); 人员存活率 += float.Parse(item1.Value["人员存活率"][i]); aircreftCount++; if (item1.Value["平均搜索时间"][i] != "0") searchCount++; if (item1.Value["平均救助时间"][i] != "0") jzCount++; Console.WriteLine("索滑降" + item1.Key + "识别成功数:" + item1.Value["识别成功率"][i]); Console.WriteLine("索滑降" + item1.Key + "识别数量:" + item1.Value["识别数量"][i]); Console.WriteLine("索滑降" + item1.Key + "任务准备时间:" + item1.Value["任务准备时间"][i]); Console.WriteLine("索滑降" + item1.Key + "平均搜索时间:" + item1.Value["平均搜索时间"][i]); Console.WriteLine("索滑降" + item1.Key + "平均救助时间:" + item1.Value["平均救助时间"][i]); Console.WriteLine("索滑降" + item1.Key + "总飞行时间:" + item1.Value["总飞行时间"][i]); Console.WriteLine("索滑降" + item1.Key + "存活人数:" + item1.Value["人员存活率"][i]); Console.WriteLine("索滑降" + item1.Key + "人员数量:" + item1.Value["人员数量"][i]); Console.WriteLine("==============================================================="); } } SJAllTotalTaskPerformance allTotalTaskPerformance = new SJAllTotalTaskPerformance(); if (人员存活率 != 0) 任务是否成功 = 1; if (任务是否成功 == 1) self.seaSuccessCount++; if (识别数量 != 0) allTotalTaskPerformance.识别成功率 = (识别成功率 / 识别数量).ToString(); else allTotalTaskPerformance.识别成功率 = "0"; allTotalTaskPerformance.任务准备时间 = 任务准备时间.ToString(); if (searchCount != 0) allTotalTaskPerformance.平均搜索时间 = (平均搜索时间 / searchCount).ToString("f4"); // aircreftCount else allTotalTaskPerformance.平均搜索时间 = "0"; if (jzCount != 0) allTotalTaskPerformance.平均救助时间 = (平均救助时间 / jzCount).ToString("f4"); // aircreftCount else allTotalTaskPerformance.平均救助时间 = "0"; allTotalTaskPerformance.总飞行时间 = 总飞行时间.ToString("f4"); allTotalTaskPerformance.海上搜索覆盖面积 = 海上搜索覆盖面积.ToString();//"0.6".ToString();//"60%" allTotalTaskPerformance.环境搜索覆盖面积 = 环境搜索覆盖面积.ToString();//"0.6".ToString(); allTotalTaskPerformance.任务是否成功 = 任务是否成功.ToString(); if (人员数量 != 0) allTotalTaskPerformance.人员存活率 = (人员存活率 / 人员数量).ToString(); else allTotalTaskPerformance.人员存活率 = "0"; Console.WriteLine("单轮次总体指标识别成功率:" + allTotalTaskPerformance.识别成功率); Console.WriteLine("单轮次总体指标任务准备时间:" + allTotalTaskPerformance.任务准备时间); Console.WriteLine("单轮次总体指标平均搜索时间:" + allTotalTaskPerformance.平均搜索时间); Console.WriteLine("单轮次总体指标平均救助时间:" + allTotalTaskPerformance.平均救助时间); Console.WriteLine("单轮次总体指标总飞行时间:" + allTotalTaskPerformance.总飞行时间); Console.WriteLine("单轮次总体指标海上搜索覆盖面积:" + allTotalTaskPerformance.海上搜索覆盖面积); Console.WriteLine("单轮次总体指标环境搜索覆盖面积:" + allTotalTaskPerformance.环境搜索覆盖面积); Console.WriteLine("单轮次总体指标任务是否成功:" + allTotalTaskPerformance.任务是否成功); Console.WriteLine("单轮次总体指标人员存活率:" + allTotalTaskPerformance.人员存活率); Console.WriteLine("==============================================================="); Dictionary> report = new Dictionary>(); if (self.isSea) { report["总任务表现"] = new Dictionary { { "识别成功率", allTotalTaskPerformance.识别成功率.ToString() }, { "任务准备时间", allTotalTaskPerformance.任务准备时间.ToString() }, { "平均搜索时间", allTotalTaskPerformance.平均搜索时间.ToString() }, { "平均救助时间", allTotalTaskPerformance.平均救助时间.ToString() }, { "总飞行时间", allTotalTaskPerformance.总飞行时间.ToString() }, { "海上搜索覆盖面积", allTotalTaskPerformance.海上搜索覆盖面积.ToString() }, { "任务是否成功", allTotalTaskPerformance.任务是否成功.ToString() }, { "人员存活率", allTotalTaskPerformance.人员存活率.ToString() } }; } else if (self.isLand) { report["总任务表现"] = new Dictionary { { "识别成功率", allTotalTaskPerformance.识别成功率.ToString() }, { "任务准备时间", allTotalTaskPerformance.任务准备时间.ToString() }, { "平均搜索时间", allTotalTaskPerformance.平均搜索时间.ToString() }, { "平均救助时间", allTotalTaskPerformance.平均救助时间.ToString() }, { "总飞行时间", allTotalTaskPerformance.总飞行时间.ToString() }, { "环境搜索覆盖面积", allTotalTaskPerformance.环境搜索覆盖面积.ToString() }, { "任务是否成功", allTotalTaskPerformance.任务是否成功.ToString() }, { "人员存活率", allTotalTaskPerformance.人员存活率.ToString() } }; } self.SaveSeaSJ(report); } self.ReportAllSJSea(); isReport = true; Console.WriteLine("所有任务执行完成"); } } }