From bfe51f9c2ce2181fee372ed5f9017c7af59cc896 Mon Sep 17 00:00:00 2001
From: zhang <zc857179121@qq.com>
Date: 星期一, 01 九月 2025 12:49:55 +0800
Subject: [PATCH] 1
---
zy-acs-manager/src/main/java/com/zy/acs/manager/common/utils/MapDataUtils.java | 45 +++++++++++++++++++++++++--------------------
1 files changed, 25 insertions(+), 20 deletions(-)
diff --git a/zy-acs-manager/src/main/java/com/zy/acs/manager/common/utils/MapDataUtils.java b/zy-acs-manager/src/main/java/com/zy/acs/manager/common/utils/MapDataUtils.java
index f744fd9..b7c7104 100644
--- a/zy-acs-manager/src/main/java/com/zy/acs/manager/common/utils/MapDataUtils.java
+++ b/zy-acs-manager/src/main/java/com/zy/acs/manager/common/utils/MapDataUtils.java
@@ -2,16 +2,29 @@
import com.alibaba.fastjson.JSON;
import com.zy.acs.framework.common.Cools;
-import com.zy.acs.manager.core.service.astart.WaveNodeType;
-import java.util.ArrayList;
-import java.util.List;
-import java.util.Optional;
+import java.util.*;
/**
* Created by vincent on 8/7/2024
*/
public class MapDataUtils {
+
+ public static Double[][][] preComputeCdaMatrix(String[][] cdaStrMatrix) {
+ int rows = cdaStrMatrix.length;
+ int cols = cdaStrMatrix[0].length;
+
+ Double[][][] cdaMatrix = new Double[rows][cols][2];
+ for (int i = 0; i < rows; i++) {
+ for (int j = 0; j < cols; j++) {
+ List<Double> cda = MapDataUtils.parseCdaNode(cdaStrMatrix[i][j]);
+ cdaMatrix[i][j][0] = cda.get(0);
+ cdaMatrix[i][j][1] = cda.get(1);
+ }
+ }
+
+ return cdaMatrix;
+ }
public static List<String> parseWaveNode(String waveNodeStr) {
List<String> waveNodeList = new ArrayList<>();
@@ -22,9 +35,8 @@
}
public static List<Double> parseCdaNode(String cdaNodeStr) {
- List<Double> waveNodeList = new ArrayList<>();
if (Cools.isEmpty(cdaNodeStr)) {
- return waveNodeList;
+ return new ArrayList<>();
}
return JSON.parseArray(cdaNodeStr, Double.class);
}
@@ -38,25 +50,18 @@
}
public static String generateWaveNode(String originStr, String waveNode) {
- List<String> waveNodeList;
- if (originStr.equals(WaveNodeType.ENABLE.val)) {
- waveNodeList = new ArrayList<>();
- waveNodeList.add(waveNode);
- } else {
- waveNodeList = JSON.parseArray(originStr, String.class);
- if (!waveNodeList.contains(waveNode)) {
- waveNodeList.add(waveNode);
- }
- }
- return JSON.toJSONString(waveNodeList);
+ List<String> originNode = JSON.parseArray(originStr, String.class);
+ Set<String> set = new HashSet<>(originNode);
+ set.add(waveNode);
+ return JSON.toJSONString(set);
}
- public static Double getVehicleWaveSafeDistance(Integer diameter, Double coe) {
+ public static Double getVehicleWaveSafeDistance(Integer diameter, Double factor) {
if (Cools.isEmpty(diameter)) {
return 0.0D;
}
- coe = Optional.ofNullable(coe).orElse(1.0D);
- return diameter * coe;
+ factor = Optional.ofNullable(factor).orElse(1.0D);
+ return diameter * factor;
}
}
--
Gitblit v1.9.1