From 69218874b7d166cf9c5a10e23e9d2e0b9280633a Mon Sep 17 00:00:00 2001
From: jinlin <jinlin>
Date: 星期二, 12 三月 2024 10:14:57 +0800
Subject: [PATCH] 修改

---
 modules/mainPart/src/main/java/com/zt/life/modules/taskReliability/service/ModelLineService.java |  729 ++++++++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 714 insertions(+), 15 deletions(-)

diff --git a/modules/mainPart/src/main/java/com/zt/life/modules/taskReliability/service/ModelLineService.java b/modules/mainPart/src/main/java/com/zt/life/modules/taskReliability/service/ModelLineService.java
index f1089bf..f60aa9e 100644
--- a/modules/mainPart/src/main/java/com/zt/life/modules/taskReliability/service/ModelLineService.java
+++ b/modules/mainPart/src/main/java/com/zt/life/modules/taskReliability/service/ModelLineService.java
@@ -9,11 +9,13 @@
 import com.zt.life.modules.taskReliability.dao.ModelLineDao;
 import com.zt.life.modules.taskReliability.dao.ModelNodeDao;
 import com.zt.life.modules.taskReliability.dao.ModelRbdDao;
+import com.zt.life.modules.taskReliability.dto.ModelLinePair;
 import com.zt.life.modules.taskReliability.model.Algorithm;
 import com.zt.life.modules.taskReliability.model.ModelLine;
 import com.zt.life.modules.taskReliability.model.ModelNode;
 import com.zt.life.modules.taskReliability.model.ModelRbd;
 import org.apache.commons.lang3.StringUtils;
+import org.checkerframework.checker.units.qual.C;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 import com.zt.common.db.query.QueryFilter;
@@ -66,8 +68,8 @@
     @Transactional(rollbackFor = Exception.class)
     public void insert(ModelRbd modelRbd) {
         if (modelRbd==null) return;
-        if (modelRbd.getModelId()==null) return;
-        Long modelId = modelRbd.getModelId();
+        if (modelRbd.getId()==null) return;
+        Long modelId = modelRbd.getId();
 
         // 鍒犻櫎鏃㈡湁鏁版嵁
         modelRbdDao.deleteByModelId(modelId);
@@ -80,27 +82,696 @@
     @Transactional(rollbackFor = Exception.class)
     public void update(ModelRbd modelRbd) {
         if (modelRbd==null) return;
-        if (modelRbd.getModelId()==null) return;
-        Long modelId = modelRbd.getModelId();
+        if (modelRbd.getId()==null) return;
+        Long modelId = modelRbd.getId();
 
         // 鍒犻櫎鏃㈡湁鏁版嵁
         modelRbdDao.deleteByModelId(modelId);
 
-        // 鎻掑叆鏁版嵁
-        modelRbd.setId(UUIDUtil.generateId());
         modelRbdDao.insert(modelRbd);
     }
 
     @Transactional(rollbackFor = Exception.class)
-    public void analyze(ModelRbd modelRbd) {
-        if (modelRbd==null) return;
-        if (modelRbd.getModelId()==null) return;
-        Long modelId = modelRbd.getModelId();
-
-        analyzeRbdAndSave(modelId, modelRbd.getContent(), true);
+    public boolean analyze(ModelRbd modelRbd) {
+        boolean result = true;
+        if (modelRbd==null) return result;
+        Long modelId = modelRbd.getId();
+        result = analyzeRbd(modelId, modelRbd.getContent(), true);
+        return result;
     }
 
-    public void analyzeRbdAndSave(Long modelId, String content, boolean saveFlag) {
+    private boolean analyzeRbd(Long modelId, String content, boolean saveFlag) {
+        boolean result = true;
+        String rbdsonStr = content;
+
+        JSONArray rbdJsonArray = new JSONObject(rbdsonStr).getJSONArray("cells");
+        if (rbdJsonArray == null) return result;
+
+        // 瑙f瀽缁撴灉瀛樻斁list
+        List<ModelNode> modelNodeList = new ArrayList<>();
+        List<ModelLine> modelLineList = new ArrayList<>();
+        List<Algorithm> algorithmList = new ArrayList<>();
+
+        // 1. 瑙f瀽鍑鸿妭鐐逛笌杈�
+        getNodeAndLineFromRbd(modelId, rbdJsonArray, modelNodeList, modelLineList);
+        // 2. 璁$畻鎵�鏈夎妭鐐圭殑鍏ュ彛绾挎暟鍙婂嚭鍙g嚎鏁�
+        calcInOutLineNumAllNode(modelNodeList, modelLineList);
+        // 3. 澶嶅埗浜у搧鑺傜偣(node)鍒發ist
+        List<ModelNode> modelNodeAndVnodeList = modelNodeList.stream().filter(item ->
+                "node".equals(item.getNodeType())).collect(Collectors.toList());
+        // 4. 涓嶆柇灏嗗熀鏈ā鍨嬶紙涓茶仈銆佸苟鑱斻�佹梺鑱斻�佽〃鍐炽�佹ˉ鑱旓級鏇挎崲涓鸿櫄鑺傜偣鑰岀畝鍖栧浘褰紝鐩磋嚦鏃犳硶绠�鍖栦负姝€��
+        result = getAlgorithmFromRbd(modelId, modelNodeList, modelLineList, algorithmList, modelNodeAndVnodeList);
+
+        // 5. 淇濆瓨妯″瀷
+        if (saveFlag) saveModel(modelId, modelNodeList, modelLineList, algorithmList);
+
+        return result;
+    }
+
+    private boolean getAlgorithmFromRbd(Long modelId,
+                                     List<ModelNode> modelNodeList,
+                                     List<ModelLine> modelLineList,
+                                     List<Algorithm> algorithmList,
+                                     List<ModelNode> modelNodeAndVnodeList) {
+        // 鏍规嵁浠ヤ笅鐨勬瀯鍥捐鍒欐潵杩涜绠楁硶鍒嗚В锛�
+        // 1銆佽妭鐐圭殑瀹氫箟
+        // 1-1) 杩愮畻鑺傜偣锛氬叡2涓細鏃佽仈銆佽〃鍐筹紝涓旇繍绠楄妭鐐归渶鏀惧湪琚繍绠楄妭鐐圭殑鍙充晶銆�
+        // 1-2) 浜у搧鑺傜偣锛氫骇鍝佹ā鍨嬩腑鐨勮妭鐐�
+        // 1-3) 杩炴帴鑺傜偣锛氬叡3涓細start銆乪nd銆乧onnect
+        // 1-4) 铏氳妭鐐癸細浠f浛鍩烘湰妯″瀷锛屾瀯鍥捐鍒欎笂绛夋晥浜庝骇鍝佽妭鐐�
+        // 2銆佸熀鏈ā鍨嬬殑瀹氫箟
+        // 2-1) 涓茶仈锛氭病鏈変笓闂ㄧ殑琛ㄧず绗﹀彿锛岀敱鑺傜偣闂寸殑杩炴帴鍏崇郴瀹氫箟銆�2涓強浠ヤ笂鐨勮妭鐐癸紙浜у搧鑺傜偣鎴栬櫄鑺傜偣锛夊彧鏋勬垚1鏉¤矾寰勶紝缁堢鑺傜偣鍙湁1涓嚭鍙o紙鍏ュ彛涓暟鏃犻檺鍒讹級銆�
+        // 2-2) 骞惰仈锛氭病鏈変笓闂ㄧ殑琛ㄧず绗﹀彿锛岀敱鑺傜偣闂寸殑杩炴帴鍏崇郴瀹氫箟銆�2涓強浠ヤ笂鐨勮妭鐐癸紙浜у搧鑺傜偣鎴栬櫄鑺傜偣锛夐兘鍙湁1涓叆鍙e拰鍑哄彛锛屼笖杩欎簺鑺傜偣鎷ユ湁鍚屼竴涓叆鍙h妭鐐瑰拰鍚屼竴涓嚭鍙h妭鐐广��
+        // 2-3) 鏃佽仈锛氱敱涓撻棬鐨勬梺鑱旇繍绠楃琛ㄧず锛屾瘡鏉℃梺鑱旀敮璺彧鏈�1涓妭鐐癸紙浜у搧鑺傜偣鎴栬櫄鑺傜偣锛夛紝杩欎簺鑺傜偣閮戒互璇ユ梺鑱旇妭鐐逛负鍑哄彛鑺傜偣锛屼笖杩欎簺鑺傜偣鎷ユ湁鍚屼竴涓叆鍙h妭鐐广��
+        // 2-4) 琛ㄥ喅锛氱敱涓撻棬鐨勮〃鍐宠繍绠楃琛ㄧず锛屾瘡鏉¤〃鍐虫敮璺彧鏈�1涓妭鐐癸紙浜у搧鑺傜偣鎴栬櫄鑺傜偣锛夛紝杩欎簺鑺傜偣閮戒互璇ヨ〃鍐宠妭鐐逛负鍑哄彛鑺傜偣锛屼笖杩欎簺鑺傜偣鎷ユ湁鍚屼竴涓叆鍙h妭鐐广��
+        // 2-5) 妗ヨ仈锛氭病鏈変笓闂ㄧ殑琛ㄧず绗﹀彿锛岀敱鑺傜偣闂寸殑杩炴帴鍏崇郴瀹氫箟銆�
+        // 3銆佹牴鎹互涓婂熀鏈ā鍨嬬殑瀹氫箟锛屼笉鏂皢鍩烘湰妯″瀷绠�鍖栦负铏氳妭鐐癸紝鐩磋嚦绠�鍖栧畬姣曪紝鎴栬�呮棤娉曠畝鍖栦负姝€��
+        boolean isEnd = false; // 鍥惧舰绠�鍖栧畬姣曪紙鍏ㄩ儴绠�鍖栨病浜嗭級
+        boolean hasSimplified = false; // 鑷冲皯绠�鍖栦簡涓�澶勫浘褰�
+        do {
+            hasSimplified = false;
+            hasSimplified = simplifySeries(modelId, modelNodeList, modelLineList, algorithmList, modelNodeAndVnodeList, hasSimplified);
+            hasSimplified = simplifyParallel(modelId, modelNodeList, modelLineList, algorithmList, modelNodeAndVnodeList, hasSimplified);
+            hasSimplified = simplifyOperator("switch", modelId, modelNodeList, modelLineList, algorithmList, hasSimplified);
+            hasSimplified = simplifyOperator("vote", modelId, modelNodeList, modelLineList, algorithmList, hasSimplified);
+            hasSimplified = simplifyBridge(modelId, modelNodeList, modelLineList, algorithmList, modelNodeAndVnodeList, hasSimplified);
+            isEnd = simplifyEnd(modelId, modelNodeList, modelLineList, algorithmList, modelNodeAndVnodeList);
+        } while (!isEnd && hasSimplified);
+
+        // 鍚堝苟纰庣墖鍖栦簡鐨勪覆鑱�
+
+        // 鍚堝苟纰庣墖鍖栦簡鐨勫苟鑱�
+
+        return isEnd;
+    }
+
+    private boolean simplifyEnd(Long modelId,
+                                List<ModelNode> modelNodeList,
+                                List<ModelLine> modelLineList,
+                                List<Algorithm> algorithmList,
+                                List<ModelNode> modelNodeAndVnodeList) {
+        ModelNode endNode = modelNodeList.stream().filter(item ->
+                "end".equals(item.getNodeType())).collect(Collectors.toList()).get(0);
+        if (endNode.getInLineNum()!=1) return false;
+
+        ModelLine lineToEnd = modelLineList.stream().filter(item ->
+                item.getEndCell().equals(endNode.getPicId())).collect(Collectors.toList()).get(0);
+        ModelNode node = modelNodeList.stream().filter(item ->
+                lineToEnd.getBeginCell().equals(item.getPicId())).collect(Collectors.toList()).get(0);
+        if (node.getInLineNum()!=1 || node.getOutLineNum()!=1) return false;
+
+        ModelLine lineToNode = modelLineList.stream().filter(item ->
+                item.getEndCell().equals(node.getPicId())).collect(Collectors.toList()).get(0);
+        ModelNode startNode = modelNodeList.stream().filter(item ->
+                lineToNode.getBeginCell().equals(item.getPicId())).collect(Collectors.toList()).get(0);
+        if (!"start".equals(startNode.getNodeType()) || startNode.getOutLineNum()!=1) return false;
+
+        // 鍒犻櫎鑺傜偣鍙婅繛绾�
+        modelLineList.remove(lineToEnd);
+        modelLineList.remove(lineToNode);
+        modelNodeList.remove(endNode);
+        modelNodeList.remove(node);
+        modelNodeList.remove(startNode);
+
+        // 鐢熸垚缁撴潫鐨勭畻娉曟楠�
+        // 鏂板algorithm
+        Algorithm algorithm = new Algorithm();
+        Long id = UUIDUtil.generateId();
+        algorithm.setId(id);
+        algorithm.setModelId(modelId);
+        algorithm.setComputerId(id);
+        algorithm.setModelType(endNode.getNodeType());
+        algorithm.setAlgorithmType(endNode.getNodeType());
+        algorithm.setComputerList(node.getId().toString());
+        algorithm.setObjectList(node.getName());
+        algorithm.setStep(algorithmList.size());
+        algorithmList.add(algorithm);
+
+        // 鏂板缁撴潫鐨勮櫄鑺傜偣
+        ModelNode vnode = new ModelNode();
+        vnode.setId(id);
+        vnode.setPicId(id.toString());
+        vnode.setModelId(modelId);
+        vnode.setNodeType("vnode");
+        vnode.setName("v"+algorithm.getStep());
+        modelNodeAndVnodeList.add(vnode);
+
+        return true;
+    }
+
+    private boolean simplifySeries(Long modelId,
+                                   List<ModelNode> modelNodeList,
+                                   List<ModelLine> modelLineList,
+                                   List<Algorithm> algorithmList,
+                                   List<ModelNode> modelNodeAndVnodeList,
+                                   boolean hasSimplified) {
+        List<ModelNode> startNodes = modelNodeList.stream().filter(item ->
+                "node,vnode,connect,end".contains(item.getNodeType())).collect(Collectors.toList());
+        if (startNodes.size()==0) return hasSimplified;
+
+        for (ModelNode startNode : startNodes) {
+            if (startNode.getInLineNum()!=1) continue;
+
+            List<ModelNode> result = new ArrayList<>();
+            if (!"end".equals(startNode.getNodeType())) result.add(startNode);
+            seekPathSeries(modelNodeList, modelLineList, startNode, result);
+            if (result.size()<2) continue;
+
+            ModelNode endNode = result.get(result.size()-1);
+            if ("start,switch,vote".contains(endNode.getNodeType()) || endNode.getOutLineNum()!=1) {
+                result.remove(endNode);
+            }
+            List<ModelNode> seriesNodes = result.stream().filter(item ->
+                    !"connect".equals(item.getNodeType())).collect(Collectors.toList());
+            if (seriesNodes.size()<2) continue;
+
+            // 鏇挎崲鎴愯櫄鑺傜偣
+            replaceToVnodeSeries(modelId, modelNodeList, modelLineList,
+                    algorithmList, modelNodeAndVnodeList, result, seriesNodes);
+            hasSimplified = true;
+        }
+
+        return hasSimplified;
+    }
+
+    private void replaceToVnodeSeries(Long modelId,
+                                      List<ModelNode> modelNodeList,
+                                      List<ModelLine> modelLineList,
+                                      List<Algorithm> algorithmList,
+                                      List<ModelNode> modelNodeAndVnodeList,
+                                      List<ModelNode> path,
+                                      List<ModelNode> seriesNodes) {
+        // 鏂板algorithm
+        Algorithm algorithm = new Algorithm();
+        Long id = UUIDUtil.generateId();
+        algorithm.setId(id);
+        algorithm.setModelId(modelId);
+        algorithm.setComputerId(id);
+        algorithm.setModelType("series");
+        algorithm.setAlgorithmType("series");
+        algorithm.setComputerList(joinNodeId(seriesNodes, ","));
+        algorithm.setObjectList(joinNodeName(seriesNodes, ","));
+        algorithm.setStep(algorithmList.size());
+        algorithmList.add(algorithm);
+
+        // 鏂板铏氳妭鐐�
+        ModelNode vnode = new ModelNode();
+        vnode.setId(id);
+        vnode.setPicId(id.toString());
+        vnode.setModelId(modelId);
+        vnode.setNodeType("vnode");
+        vnode.setName("v"+algorithm.getStep());
+        modelNodeList.add(vnode);
+        modelNodeAndVnodeList.add(vnode);
+
+        // 灏唒ath鏇挎崲涓鸿铏氳妭鐐�
+        for (int i=0; i<path.size(); i++) {
+            ModelNode finalNode = path.get(i);
+            if (i==0) {
+                // 灏嗚鑺傜偣鐨勫嚭鍙g嚎鏀逛负杩炴帴鍒拌櫄鑺傜偣
+                List<ModelLine> outLines = modelLineList.stream().filter(item ->
+                        item.getBeginCell().equals(finalNode.getPicId())).collect(Collectors.toList());
+                for (ModelLine line : outLines) {
+                    line.setBeginCell(vnode.getPicId());
+                }
+                // 灏嗚鑺傜偣鐨勫叆鍙g嚎鍒犻櫎
+                List<ModelLine> inLines = modelLineList.stream().filter(item ->
+                        item.getEndCell().equals(finalNode.getPicId())).collect(Collectors.toList());
+                modelLineList.removeAll(inLines);
+            }
+            if (i==path.size()-1) {
+                // 灏嗚鑺傜偣鐨勫叆鍙g嚎鏀逛负杩炴帴鍒拌櫄鑺傜偣
+                List<ModelLine> inLines = modelLineList.stream().filter(item ->
+                        item.getEndCell().equals(finalNode.getPicId())).collect(Collectors.toList());
+                for (ModelLine line : inLines) {
+                    line.setEndCell(vnode.getPicId());
+                }
+                // 灏嗚鑺傜偣鐨勫嚭鍙g嚎鍒犻櫎
+                List<ModelLine> outLines = modelLineList.stream().filter(item ->
+                        item.getBeginCell().equals(finalNode.getPicId())).collect(Collectors.toList());
+                modelLineList.removeAll(outLines);
+            }
+            // 鍒犻櫎璇ヨ妭鐐圭殑鍑哄叆鍙g嚎
+            List<ModelLine> inOutLines = modelLineList.stream().filter(item ->
+                    item.getEndCell().equals(finalNode.getPicId()) || item.getBeginCell().equals(finalNode.getPicId())
+            ).collect(Collectors.toList());
+            modelLineList.removeAll(inOutLines);
+            // 鍒犻櫎璇ヨ妭鐐�
+            modelNodeList.remove(finalNode);
+            calcInOutLineNum(finalNode, modelLineList);
+        }
+
+        calcInOutLineNum(vnode, modelLineList);
+    }
+
+    private void seekPathSeries(List<ModelNode> modelNodeList,
+                                List<ModelLine> modelLineList,
+                                ModelNode startNode,
+                                List<ModelNode> result) {
+        ModelLine inLine = modelLineList.stream().filter(item ->
+                item.getEndCell().equals(startNode.getPicId())).collect(Collectors.toList()).get(0);
+        ModelNode pathNode = modelNodeList.stream().filter(item ->
+                inLine.getBeginCell().equals(item.getPicId())).collect(Collectors.toList()).get(0);
+        result.add(pathNode);
+        if (pathNode.getOutLineNum()!=1 || pathNode.getInLineNum()!=1) return;
+        if ("switch,vote".contains(pathNode.getNodeType())) return;
+        seekPathSeries(modelNodeList, modelLineList, pathNode, result);
+    }
+
+    private boolean simplifyParallel(Long modelId,
+                                     List<ModelNode> modelNodeList,
+                                     List<ModelLine> modelLineList,
+                                     List<Algorithm> algorithmList,
+                                     List<ModelNode> modelNodeAndVnodeList,
+                                     boolean hasSimplified) {
+        boolean hasSimplifiedMe = false;
+        List<ModelNode> startNodes = modelNodeList.stream().filter(item ->
+                "node,vnode,connect,end".contains(item.getNodeType())).collect(Collectors.toList());
+        if (startNodes.size()==0) return hasSimplified;
+
+        for (ModelNode startNode : startNodes) {
+            if (startNode.getInLineNum()<2) continue;
+            List<ModelLine> inLines = modelLineList.stream().filter(item ->
+                    item.getEndCell().equals(startNode.getPicId())).collect(Collectors.toList());
+            hasSimplifiedMe = simplifyParallelGroup(modelId, modelNodeList, modelLineList,
+                    algorithmList, modelNodeAndVnodeList, startNode, inLines);
+            if (hasSimplifiedMe) {
+                hasSimplified = true;
+            }
+        }
+
+        return hasSimplified;
+    }
+
+    private boolean simplifyParallelGroup(Long modelId,
+                                        List<ModelNode> modelNodeList,
+                                        List<ModelLine> modelLineList,
+                                        List<Algorithm> algorithmList,
+                                        List<ModelNode> modelNodeAndVnodeList,
+                                        ModelNode startNode,
+                                        List<ModelLine> lines) {
+        boolean hasSimplified = false;
+        List<List<ModelNode>> pathList = new ArrayList<>();
+        for (ModelLine line : lines) {
+            List<ModelNode> path = getOneBranchParallel(modelNodeList, modelLineList, line);
+            if (path.size() > 0) pathList.add(path);
+        }
+        Map<ModelNode, List<List<ModelNode>>> endNodePathsMap = groupingPathByEndNode(pathList);
+        for (Map.Entry<ModelNode, List<List<ModelNode>>> entry : endNodePathsMap.entrySet()) {
+            List<List<ModelNode>> pathOneGroup = entry.getValue();
+            if (pathOneGroup.size()>1) {
+                List<ModelNode> branchNodeList = new ArrayList<>();
+                ModelNode endNode = getBranchNodesOneParallel(pathOneGroup, branchNodeList);
+                if ("connect".equals(startNode.getNodeType()) && pathOneGroup.size()==lines.size()) {
+                    // 鏇挎崲鎴愯櫄鑺傜偣
+                    replaceToVnode("parallel", modelId, modelNodeList, modelLineList,
+                            algorithmList, startNode, endNode, branchNodeList);
+                } else {
+                    // 鏂板铏氳妭鐐�
+                    ModelNode vnode = new ModelNode();
+                    Long id = UUIDUtil.generateId();
+                    vnode.setId(id);
+                    vnode.setPicId(id.toString());
+                    vnode.setModelId(modelId);
+                    vnode.setNodeType("vnode");
+                    modelNodeList.add(vnode);
+                    modelNodeAndVnodeList.add(vnode);
+                    ModelLine modelLineNew = new ModelLine();
+                    Long picId2 = UUIDUtil.generateId();
+                    modelLineNew.setId(picId2);
+                    modelLineNew.setPicId(picId2.toString());
+                    modelLineNew.setModelId(modelId);
+                    modelLineNew.setBeginCell(vnode.getPicId());
+                    modelLineNew.setEndCell(startNode.getPicId());
+                    modelLineList.add(modelLineNew);
+                    replaceToVnode("parallel", modelId, modelNodeList, modelLineList,
+                            algorithmList, vnode, endNode, branchNodeList);
+                    calcInOutLineNum(startNode, modelLineList);
+                }
+                hasSimplified = true;
+            }
+        }
+
+        return hasSimplified;
+    }
+
+    private List<ModelNode> getOneBranchParallel(List<ModelNode> modelNodeList,
+                                                 List<ModelLine> modelLineList,
+                                                 ModelLine line) {
+        List<ModelNode> path = new ArrayList<>();
+        ModelNode branchNode = modelNodeList.stream().filter(item ->
+                line.getBeginCell().equals(item.getPicId())).collect(Collectors.toList()).get(0);
+        List<ModelLine> inLines = modelLineList.stream().filter(item ->
+                item.getEndCell().equals(branchNode.getPicId())).collect(Collectors.toList());
+        List<ModelLine> outLines = modelLineList.stream().filter(item ->
+                item.getBeginCell().equals(branchNode.getPicId())).collect(Collectors.toList());
+        if (inLines.size()!=1 || outLines.size()!=1) return path;
+        ModelLine lineToBranchNode = inLines.get(0);
+        ModelNode endNode = modelNodeList.stream().filter(item ->
+                lineToBranchNode.getBeginCell().equals(item.getPicId())).collect(Collectors.toList()).get(0);
+        path.add(branchNode);
+        path.add(endNode);
+
+        return path;
+    }
+
+    private Map<ModelNode, List<List<ModelNode>>> groupingPathByEndNode(List<List<ModelNode>> pathList) {
+        Map<ModelNode, List<List<ModelNode>>> endNodePathsMap = new HashMap<>();
+        for (List<ModelNode> path : pathList) {
+            ModelNode endNode = path.get(path.size()-1);
+            if (endNodePathsMap.containsKey(endNode)) {
+                endNodePathsMap.get(endNode).add(path);
+            } else {
+                List<List<ModelNode>> paths = new ArrayList<>();
+                paths.add(path);
+                endNodePathsMap.put(endNode, paths);
+            }
+        }
+        return endNodePathsMap;
+    }
+
+    private ModelNode getBranchNodesOneParallel(List<List<ModelNode>> paths,
+                                           List<ModelNode> branchNodeList) {
+        ModelNode endNode = null;
+        for (List<ModelNode> path : paths) {
+            branchNodeList.add(path.get(0));
+            endNode = path.get(path.size()-1);
+        }
+        return endNode;
+    }
+
+    private boolean simplifyBridge(Long modelId,
+                                   List<ModelNode> modelNodeList,
+                                   List<ModelLine> modelLineList,
+                                   List<Algorithm> algorithmList,
+                                   List<ModelNode> modelNodeAndVnodeList,
+                                   boolean hasSimplified) {
+        boolean hasSimplifiedMe = false;
+        List<ModelNode> startNodes = modelNodeList.stream().filter(item ->
+                "node,vnode,connect,end".contains(item.getNodeType())).collect(Collectors.toList());
+        if (startNodes.size()==0) return hasSimplified;
+
+        for (ModelNode startNode : startNodes) {
+            List<ModelLine> lines = modelLineList.stream().filter(item ->
+                    item.getEndCell().equals(startNode.getPicId())).collect(Collectors.toList());
+            if (lines.size()<2) continue;
+            List<ModelLinePair> linePairs = getLinePairs(lines);
+            for (ModelLinePair linePair : linePairs) {
+                hasSimplifiedMe = simplifyBridgeOneLinePair(modelId, modelNodeList, modelLineList,
+                        algorithmList, modelNodeAndVnodeList, startNode, linePair);
+                if (hasSimplifiedMe) {
+                    hasSimplified = true;
+                    break;
+                }
+            }
+        }
+
+        return hasSimplified;
+    }
+
+    private boolean simplifyBridgeOneLinePair(Long modelId,
+                                              List<ModelNode> modelNodeList,
+                                              List<ModelLine> modelLineList,
+                                              List<Algorithm> algorithmList,
+                                              List<ModelNode> modelNodeAndVnodeList,
+                                              ModelNode startNode,
+                                              ModelLinePair linePair) {
+        ModelNode node1 = null;
+        ModelNode node2 = null;
+        ModelNode node3 = null;
+        ModelNode node4 = null;
+        ModelNode node5 = null;
+        ModelNode nodeTmp1 = modelNodeList.stream().filter(item ->
+                linePair.getLine1().getBeginCell().equals(item.getPicId())).collect(Collectors.toList()).get(0);
+        ModelNode nodeTmp2 = modelNodeList.stream().filter(item ->
+                linePair.getLine2().getBeginCell().equals(item.getPicId())).collect(Collectors.toList()).get(0);
+        calcInOutLineNum(nodeTmp1, modelLineList);
+        calcInOutLineNum(nodeTmp2, modelLineList);
+        if (nodeTmp1.getOutLineNum()!=1 || nodeTmp2.getOutLineNum()!=1) return false;
+        if (nodeTmp1.getInLineNum()<1 || nodeTmp1.getInLineNum()>2) return false;
+        if (nodeTmp2.getInLineNum()<1 || nodeTmp2.getInLineNum()>2) return false;
+        if ((nodeTmp1.getInLineNum() + nodeTmp2.getInLineNum())!=3) return false;
+        if (nodeTmp1.getInLineNum()==1) {
+            node2 = nodeTmp1;
+            node5 = nodeTmp2;
+        } else {
+            node2 = nodeTmp2;
+            node5 = nodeTmp1;
+        }
+        ModelNode finalNode = node2;
+        ModelLine line1To2 = modelLineList.stream().filter(item ->
+                item.getEndCell().equals(finalNode.getPicId())).collect(Collectors.toList()).get(0);
+        node1 = modelNodeList.stream().filter(item ->
+                line1To2.getBeginCell().equals(item.getPicId())).collect(Collectors.toList()).get(0);
+        if (node1.getInLineNum()!=1 || node1.getOutLineNum()!=2) return false;
+        ModelNode finalNode1 = node1;
+        List<ModelLine> outLinesFrom1 = modelLineList.stream().filter(item ->
+                item.getBeginCell().equals(finalNode1.getPicId())).collect(Collectors.toList());
+        if (outLinesFrom1.get(0).getEndCell().equals(node2.getPicId())) {
+            node3 = modelNodeList.stream().filter(item ->
+                    outLinesFrom1.get(1).getEndCell().equals(item.getPicId())).collect(Collectors.toList()).get(0);
+        } else {
+            node3 = modelNodeList.stream().filter(item ->
+                    outLinesFrom1.get(0).getEndCell().equals(item.getPicId())).collect(Collectors.toList()).get(0);
+        }
+        if (node3.getId().equals(node5.getId())) return false;
+        if (node3.getInLineNum()!=1 || node3.getOutLineNum()!=1) return false;
+        ModelNode finalNode2 = node3;
+        ModelLine outLineFrom3 = modelLineList.stream().filter(item ->
+                item.getBeginCell().equals(finalNode2.getPicId())).collect(Collectors.toList()).get(0);
+        if (!outLineFrom3.getEndCell().equals(node5.getPicId())) return false;
+        ModelNode finalNode3 = node5;
+        List<ModelLine> inLinesTo5 = modelLineList.stream().filter(item ->
+                item.getEndCell().equals(finalNode3.getPicId())).collect(Collectors.toList());
+        if (inLinesTo5.get(0).getBeginCell().equals(node3.getPicId())) {
+            node4 = modelNodeList.stream().filter(item ->
+                    inLinesTo5.get(1).getBeginCell().equals(item.getPicId())).collect(Collectors.toList()).get(0);
+        } else {
+            node4 = modelNodeList.stream().filter(item ->
+                    inLinesTo5.get(0).getBeginCell().equals(item.getPicId())).collect(Collectors.toList()).get(0);
+        }
+        if (node4.getId().equals(node1.getId())) return false;
+        if (node4.getId().equals(node2.getId())) return false;
+        if (node4.getInLineNum()!=1 || node4.getOutLineNum()!=1) return false;
+        ModelNode finalNode4 = node1;
+        ModelLine lineTo1 = modelLineList.stream().filter(item ->
+                item.getEndCell().equals(finalNode4.getPicId())).collect(Collectors.toList()).get(0);
+        ModelNode finalNode5 = node4;
+        ModelLine lineTo4 = modelLineList.stream().filter(item ->
+                item.getEndCell().equals(finalNode5.getPicId())).collect(Collectors.toList()).get(0);
+        nodeTmp1 = modelNodeList.stream().filter(item ->
+                lineTo1.getBeginCell().equals(item.getPicId())).collect(Collectors.toList()).get(0);
+        nodeTmp2 = modelNodeList.stream().filter(item ->
+                lineTo4.getBeginCell().equals(item.getPicId())).collect(Collectors.toList()).get(0);
+        if (!nodeTmp1.getId().equals(nodeTmp2.getId())) return false;
+        ModelNode endNode = nodeTmp1;
+        List<ModelNode> branchNodeList = new ArrayList<>();
+        branchNodeList.add(node1);
+        branchNodeList.add(node2);
+        branchNodeList.add(node3);
+        branchNodeList.add(node4);
+        branchNodeList.add(node5);
+
+        if ("connect".contains(startNode.getNodeType()) && startNode.getInLineNum()==2) {
+            // 鏇挎崲鎴愯櫄鑺傜偣
+            replaceToVnode("bridge", modelId, modelNodeList, modelLineList,
+                    algorithmList, startNode, endNode, branchNodeList);
+        } else {
+            // 鏂板铏氳妭鐐�
+            ModelNode vnode = new ModelNode();
+            Long id = UUIDUtil.generateId();
+            vnode.setId(id);
+            vnode.setPicId(id.toString());
+            vnode.setModelId(modelId);
+            vnode.setNodeType("vnode");
+            modelNodeList.add(vnode);
+            modelNodeAndVnodeList.add(vnode);
+            ModelLine modelLineNew = new ModelLine();
+            Long picId2 = UUIDUtil.generateId();
+            modelLineNew.setId(picId2);
+            modelLineNew.setPicId(picId2.toString());
+            modelLineNew.setModelId(modelId);
+            modelLineNew.setBeginCell(vnode.getPicId());
+            modelLineNew.setEndCell(startNode.getPicId());
+            modelLineList.add(modelLineNew);
+            replaceToVnode("bridge", modelId, modelNodeList, modelLineList,
+                    algorithmList, vnode, endNode, branchNodeList);
+            calcInOutLineNum(startNode, modelLineList);
+        }
+
+        return true;
+    }
+
+    private void calcInOutLineNumAllNode(List<ModelNode> modelNodeList, List<ModelLine> modelLineList) {
+        for (ModelNode node : modelNodeList) {
+            calcInOutLineNum(node, modelLineList);
+        }
+    }
+
+    private void calcInOutLineNum(ModelNode node, List<ModelLine> modelLineList) {
+        List<ModelLine> inLines = modelLineList.stream().filter(item ->
+                item.getEndCell().equals(node.getPicId())).collect(Collectors.toList());
+        List<ModelLine> outLines = modelLineList.stream().filter(item ->
+                item.getBeginCell().equals(node.getPicId())).collect(Collectors.toList());
+        node.setInLineNum(inLines.size());
+        node.setOutLineNum(outLines.size());
+    }
+
+    // 鎵惧嚭鎵�鏈�2鏍圭嚎鐨勭粍鍚�
+    private List<ModelLinePair> getLinePairs(List<ModelLine> lines) {
+        List<ModelLinePair> linePairs = new ArrayList<>();
+        for (int i=0; i<lines.size()-1; i++) {
+            for (int j=i+1; j<lines.size(); j++) {
+                ModelLinePair linePair = new ModelLinePair();
+                linePair.setLine1(lines.get(i));
+                linePair.setLine2(lines.get(j));
+                linePairs.add(linePair);
+            }
+        }
+        return linePairs;
+    }
+
+    private boolean simplifyOperator(String operator,
+                                     Long modelId,
+                                     List<ModelNode> modelNodeList,
+                                     List<ModelLine> modelLineList,
+                                     List<Algorithm> algorithmList,
+                                     boolean hasSimplified) {
+        List<ModelNode> opNodes = modelNodeList.stream().filter(item ->
+                operator.equals(item.getNodeType())).collect(Collectors.toList());
+        if (opNodes.size()==0) return hasSimplified;
+
+        for (ModelNode opNode : opNodes) {
+            List<ModelLine> lines = modelLineList.stream().filter(item ->
+                    item.getEndCell().equals(opNode.getPicId())).collect(Collectors.toList());
+            boolean thisNodeSuccess = true;
+            ModelNode endNode = null;
+            List<ModelNode> branchNodeList = new ArrayList<>();
+            for (ModelLine line : lines) {
+                ModelNode curEndNode = handleOneBranch(modelNodeList, modelLineList, line, branchNodeList);
+                if (curEndNode == null) {
+                    thisNodeSuccess = false;
+                    break;
+                }
+                if (endNode == null) {
+                    endNode = curEndNode;
+                } else {
+                    if (!endNode.getId().equals(curEndNode.getId())) {
+                        thisNodeSuccess = false;
+                        break;
+                    }
+                }
+            }
+            if (thisNodeSuccess) {
+                replaceToVnode(opNode.getNodeType(), modelId, modelNodeList, modelLineList,
+                        algorithmList, opNode, endNode, branchNodeList);
+                hasSimplified = true;
+            }
+        }
+
+        return hasSimplified;
+    }
+
+    private void replaceToVnode(String type,
+                                Long modelId,
+                                List<ModelNode> modelNodeList,
+                                List<ModelLine> modelLineList,
+                                List<Algorithm> algorithmList,
+                                ModelNode startNode,
+                                ModelNode endNode,
+                                List<ModelNode> branchNodeList) {
+        // 鏂板algorithm
+        Algorithm algorithm = new Algorithm();
+        Long id = UUIDUtil.generateId();
+        algorithm.setId(id);
+        algorithm.setModelId(modelId);
+        algorithm.setComputerId(id);
+        algorithm.setModelType(type);
+        algorithm.setAlgorithmType(type);
+        algorithm.setComputerList(joinNodeId(branchNodeList, ","));
+        algorithm.setObjectList(joinNodeName(branchNodeList, ","));
+        algorithm.setStep(algorithmList.size());
+        algorithmList.add(algorithm);
+
+        // 鏇挎崲涓鸿櫄鑺傜偣
+        for (ModelNode node : branchNodeList) {
+            List<ModelLine> branchNodeLineList = modelLineList.stream().filter(item ->
+                    item.getEndCell().equals(node.getPicId()) || item.getBeginCell().equals(node.getPicId())
+            ).collect(Collectors.toList());
+            modelLineList.removeAll(branchNodeLineList);
+            modelNodeList.remove(node);
+            calcInOutLineNum(node, modelLineList);
+        }
+        startNode.setId(id);
+        startNode.setNodeType("vnode");
+        startNode.setName("v"+algorithm.getStep());
+
+        ModelLine modelLineNew = new ModelLine();
+        Long picId2 = UUIDUtil.generateId();
+        modelLineNew.setId(picId2);
+        modelLineNew.setPicId(picId2.toString());
+        modelLineNew.setModelId(modelId);
+        modelLineNew.setBeginCell(endNode.getPicId());
+        modelLineNew.setEndCell(startNode.getPicId());
+        modelLineList.add(modelLineNew);
+
+        calcInOutLineNum(startNode, modelLineList);
+        calcInOutLineNum(endNode, modelLineList);
+    }
+
+    private ModelNode handleOneBranch(List<ModelNode> modelNodeList,
+                                      List<ModelLine> modelLineList,
+                                      ModelLine line,
+                                      List<ModelNode> branchNodeList
+                                      ) {
+        ModelNode branchNode = modelNodeList.stream().filter(item ->
+                line.getBeginCell().equals(item.getPicId())).collect(Collectors.toList()).get(0);
+        List<ModelLine> inLines = modelLineList.stream().filter(item ->
+                item.getEndCell().equals(branchNode.getPicId())).collect(Collectors.toList());
+        List<ModelLine> outLines = modelLineList.stream().filter(item ->
+                item.getBeginCell().equals(branchNode.getPicId())).collect(Collectors.toList());
+        if (inLines.size()!=1 || outLines.size()!=1) return null;
+        ModelLine lineToBranchNode = inLines.get(0);
+        ModelNode endNode = modelNodeList.stream().filter(item ->
+                lineToBranchNode.getBeginCell().equals(item.getPicId())).collect(Collectors.toList()).get(0);
+
+        branchNodeList.add(branchNode);
+        return endNode;
+    }
+
+    private void getNodeAndLineFromRbd(Long modelId,
+                                       JSONArray rbdJsonArray,
+                                       List<ModelNode> modelNodeList,
+                                       List<ModelLine> modelLineList) {
+        for (int i = 0; i < rbdJsonArray.size(); i++) {
+            JSONObject jsonObject = rbdJsonArray.getJSONObject(i);
+            String shape = jsonObject.get("shape").toString();
+            if ("edge".equals(shape)) {
+                ModelLine modelLine = new ModelLine();
+                modelLine.setId(UUIDUtil.generateId());
+                modelLine.setModelId(modelId);
+                modelLine.setPicId(jsonObject.get("id").toString());
+                modelLine.setBeginCell(JsonUtils2.getJsonValueByPath(jsonObject, "source/cell".split("/")).toString());
+                modelLine.setEndCell(JsonUtils2.getJsonValueByPath(jsonObject, "target/cell".split("/")).toString());
+                modelLineList.add(modelLine);
+            } else if ("image".equals(shape)){
+                ModelNode modelNode = new ModelNode();
+                modelNode.setId(UUIDUtil.generateId());
+                modelNode.setModelId(modelId);
+                modelNode.setPicId(jsonObject.get("id").toString());
+                modelNode.setNodeType(JsonUtils2.getJsonValueByPath(jsonObject, "data/nodeType".split("/")).toString());
+                if ("node".equals(modelNode.getNodeType())) {
+                    modelNode.setDataId(Long.valueOf(JsonUtils2.getJsonValueByPath(jsonObject, "data/dataId".split("/")).toString()));
+//                    modelNode.setNodeTypeExt(JsonUtils2.getJsonValueByPath(jsonObject, "data/nodeTypeExt".split("/")).toString());
+                    Object label = JsonUtils2.getJsonValueByPath(jsonObject, "attrs/label/textWrap/text".split("/"));
+                    modelNode.setName(label==null ? "" : label.toString());
+                }
+                modelNodeList.add(modelNode);
+            }
+        }
+    }
+
+    private void analyzeRbdAndSave(Long modelId, String content, boolean saveFlag) {
         String diagramJsonStr = content;
 //        String diagramJsonStr = "{\"cells\":[{\"shape\":\"edge\",\"attrs\":{\"line\":{\"stroke\":\"#5F95FF\"}},\"id\":\"26d1a5a6-0be8-4890-86a0-a33d429e6673\",\"labels\":[{\"attrs\":{\"body\":{\"stroke\":\"#5F95FF\"},\"text\":{\"text\":\"\"}},\"position\":{\"distance\":0.5,\"angle\":180,\"options\":{\"keepGradient\":true,\"ensureLegibility\":true}}}],\"zIndex\":0,\"source\":{\"cell\":\"f91765b1-af48-4396-84ba-eb16e3476aa5\",\"port\":\"839cb2d9-59ca-4a39-a63c-26bf60cc6989\"},\"target\":{\"cell\":\"31585e99-58c7-4a98-8824-8000743b364d\",\"port\":\"01eb49d9-4b1c-466f-8263-935542436c7e\"}},{\"shape\":\"edge\",\"attrs\":{\"line\":{\"stroke\":\"#5F95FF\"}},\"id\":\"f2286e46-84c7-4702-8670-d7cda22c34e5\",\"labels\":[{\"attrs\":{\"body\":{\"stroke\":\"#5F95FF\"},\"text\":{\"text\":\"\"}},\"position\":{\"distance\":0.5,\"angle\":180,\"options\":{\"keepGradient\":true,\"ensureLegibility\":true}}}],\"zIndex\":0,\"source\":{\"cell\":\"f91765b1-af48-4396-84ba-eb16e3476aa5\",\"port\":\"839cb2d9-59ca-4a39-a63c-26bf60cc6989\"},\"target\":{\"cell\":\"5123ad82-18bb-46fe-9d93-138b24b54a15\",\"port\":\"01eb49d9-4b1c-466f-8263-935542436c7e\"}},{\"shape\":\"edge\",\"attrs\":{\"line\":{\"stroke\":\"#5F95FF\"}},\"id\":\"2ab8b7f8-7fe2-490f-89c5-4250d4a62a78\",\"labels\":[{\"attrs\":{\"body\":{\"stroke\":\"#5F95FF\"},\"text\":{\"text\":\"\"}},\"position\":{\"distance\":0.5,\"angle\":180,\"options\":{\"keepGradient\":true,\"ensureLegibility\":true}}}],\"zIndex\":0,\"source\":{\"cell\":\"31585e99-58c7-4a98-8824-8000743b364d\",\"port\":\"a977d555-b8c8-4578-9a8b-3097c405c1a8\"},\"target\":{\"cell\":\"6df9adc8-cb83-405c-8482-633db0f3644f\",\"port\":\"f93ccd2f-dedd-47b1-9ad0-9be20c5db8a4\"}},{\"shape\":\"edge\",\"attrs\":{\"line\":{\"stroke\":\"#5F95FF\"}},\"id\":\"700c05a5-f151-4b28-8135-705ccf013522\",\"labels\":[{\"attrs\":{\"body\":{\"stroke\":\"#5F95FF\"},\"text\":{\"text\":\"\"}},\"position\":{\"distance\":0.5,\"angle\":180,\"options\":{\"keepGradient\":true,\"ensureLegibility\":true}}}],\"zIndex\":0,\"source\":{\"cell\":\"5123ad82-18bb-46fe-9d93-138b24b54a15\",\"port\":\"a977d555-b8c8-4578-9a8b-3097c405c1a8\"},\"target\":{\"cell\":\"6df9adc8-cb83-405c-8482-633db0f3644f\",\"port\":\"f93ccd2f-dedd-47b1-9ad0-9be20c5db8a4\"}},{\"shape\":\"edge\",\"attrs\":{\"line\":{\"stroke\":\"#5F95FF\"}},\"id\":\"feef2a57-3c72-4d69-92a6-c828c736b61a\",\"labels\":[{\"attrs\":{\"body\":{\"stroke\":\"#5F95FF\"},\"text\":{\"text\":\"\"}},\"position\":{\"distance\":0.5,\"angle\":180,\"options\":{\"keepGradient\":true,\"ensureLegibility\":true}}}],\"zIndex\":0,\"source\":{\"cell\":\"6df9adc8-cb83-405c-8482-633db0f3644f\",\"port\":\"80d3bd61-1ed3-493a-b4e8-d4576e6fbfda\"},\"target\":{\"cell\":\"da634b2e-5ffc-4e1b-a636-f86ace9eb082\",\"port\":\"01eb49d9-4b1c-466f-8263-935542436c7e\"}},{\"shape\":\"edge\",\"attrs\":{\"line\":{\"stroke\":\"#5F95FF\"}},\"id\":\"49e36d6f-6a94-4edc-9894-6dd825091706\",\"labels\":[{\"attrs\":{\"body\":{\"stroke\":\"#5F95FF\"},\"text\":{\"text\":\"\"}},\"position\":{\"distance\":0.5,\"angle\":180,\"options\":{\"keepGradient\":true,\"ensureLegibility\":true}}}],\"zIndex\":0,\"source\":{\"cell\":\"f91765b1-af48-4396-84ba-eb16e3476aa5\",\"port\":\"839cb2d9-59ca-4a39-a63c-26bf60cc6989\"},\"target\":{\"cell\":\"2b6df966-4e19-4055-bb13-c4c083b18e58\",\"port\":\"01eb49d9-4b1c-466f-8263-935542436c7e\"}},{\"shape\":\"edge\",\"attrs\":{\"line\":{\"stroke\":\"#5F95FF\"}},\"id\":\"ed8c1bfa-c0a6-4e9b-8697-862aef109bcf\",\"labels\":[{\"attrs\":{\"body\":{\"stroke\":\"#5F95FF\"},\"text\":{\"text\":\"\"}},\"position\":{\"distance\":0.5,\"angle\":180,\"options\":{\"keepGradient\":true,\"ensureLegibility\":true}}}],\"zIndex\":0,\"source\":{\"cell\":\"f91765b1-af48-4396-84ba-eb16e3476aa5\",\"port\":\"839cb2d9-59ca-4a39-a63c-26bf60cc6989\"},\"target\":{\"cell\":\"323f5abe-05ed-419d-9d81-d25c7d3b19f3\",\"port\":\"01eb49d9-4b1c-466f-8263-935542436c7e\"}},{\"shape\":\"edge\",\"attrs\":{\"line\":{\"stroke\":\"#5F95FF\"}},\"id\":\"70c6b5fb-1b48-4a2f-bacd-be0284134818\",\"labels\":[{\"attrs\":{\"body\":{\"stroke\":\"#5F95FF\"},\"text\":{\"text\":\"\"}},\"position\":{\"distance\":0.5,\"angle\":180,\"options\":{\"keepGradient\":true,\"ensureLegibility\":true}}}],\"zIndex\":0,\"source\":{\"cell\":\"2b6df966-4e19-4055-bb13-c4c083b18e58\",\"port\":\"a977d555-b8c8-4578-9a8b-3097c405c1a8\"},\"target\":{\"cell\":\"1f378f5e-066d-49bb-a6cc-de24a8882d65\",\"port\":\"01eb49d9-4b1c-466f-8263-935542436c7e\"}},{\"shape\":\"edge\",\"attrs\":{\"line\":{\"stroke\":\"#5F95FF\"}},\"id\":\"6a134969-623b-428e-9b0c-436bae2d6608\",\"labels\":[{\"attrs\":{\"body\":{\"stroke\":\"#5F95FF\"},\"text\":{\"text\":\"\"}},\"position\":{\"distance\":0.5,\"angle\":180,\"options\":{\"keepGradient\":true,\"ensureLegibility\":true}}}],\"zIndex\":0,\"source\":{\"cell\":\"323f5abe-05ed-419d-9d81-d25c7d3b19f3\",\"port\":\"a977d555-b8c8-4578-9a8b-3097c405c1a8\"},\"target\":{\"cell\":\"1f378f5e-066d-49bb-a6cc-de24a8882d65\",\"port\":\"01eb49d9-4b1c-466f-8263-935542436c7e\"}},{\"shape\":\"edge\",\"attrs\":{\"line\":{\"stroke\":\"#5F95FF\"}},\"id\":\"51de5faf-1766-4dd1-abd0-eec2e867a322\",\"labels\":[{\"attrs\":{\"body\":{\"stroke\":\"#5F95FF\"},\"text\":{\"text\":\"\"}},\"position\":{\"distance\":0.5,\"angle\":180,\"options\":{\"keepGradient\":true,\"ensureLegibility\":true}}}],\"zIndex\":0,\"source\":{\"cell\":\"1f378f5e-066d-49bb-a6cc-de24a8882d65\",\"port\":\"a977d555-b8c8-4578-9a8b-3097c405c1a8\"},\"target\":{\"cell\":\"0bb2ba89-a92d-4b32-b3cd-45df2300fa34\",\"port\":\"61eaafd2-095b-41d6-8e34-862fb470b7a6\"}},{\"shape\":\"edge\",\"attrs\":{\"line\":{\"stroke\":\"#A2B1C3\"}},\"id\":\"161f78dc-1f44-4e43-9ced-e39d345aac78\",\"labels\":[{\"attrs\":{\"body\":{\"stroke\":\"#5F95FF\"},\"text\":{\"text\":\"\"}},\"position\":{\"distance\":0.5,\"angle\":180,\"options\":{\"keepGradient\":true,\"ensureLegibility\":true}}}],\"zIndex\":0,\"source\":{\"cell\":\"da634b2e-5ffc-4e1b-a636-f86ace9eb082\",\"port\":\"a977d555-b8c8-4578-9a8b-3097c405c1a8\"},\"target\":{\"cell\":\"0bb2ba89-a92d-4b32-b3cd-45df2300fa34\",\"port\":\"61eaafd2-095b-41d6-8e34-862fb470b7a6\"}},{\"position\":{\"x\":-350,\"y\":-280},\"size\":{\"width\":60,\"height\":60},\"attrs\":{\"text\":{\"refY\":\"100%\",\"textVerticalAnchor\":\"top\",\"text\":\"logo\",\"style\":{\"color\":\"#080808\"},\"refY2\":4},\"image\":{\"xlink:href\":\"dist/img/logo.36cbc06d.png\"},\"body\":{\"stroke\":\"#5F95FF\"},\"line\":{\"stroke\":\"orange\"}},\"visible\":true,\"shape\":\"image\",\"id\":\"31585e99-58c7-4a98-8824-8000743b364d\",\"data\":{\"dataId\":\"123456\",\"nodeType\":\"node\",\"nodeTypeExt\":\"aaa\"},\"ports\":{\"groups\":{\"top\":{\"position\":\"top\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"right\":{\"position\":\"right\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"bottom\":{\"position\":\"bottom\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"left\":{\"position\":\"left\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}}},\"items\":[{\"group\":\"top\",\"id\":\"bc0336ec-7912-4720-aea7-e5869de77692\"},{\"group\":\"right\",\"id\":\"a977d555-b8c8-4578-9a8b-3097c405c1a8\"},{\"group\":\"bottom\",\"id\":\"fef0f533-9581-4831-ba65-427f097a3d17\"},{\"group\":\"left\",\"id\":\"01eb49d9-4b1c-466f-8263-935542436c7e\"}]},\"zIndex\":1,\"labels\":[{\"attrs\":{\"body\":{\"stroke\":\"orange\"}}}]},{\"position\":{\"x\":-350,\"y\":-180},\"size\":{\"width\":60,\"height\":60},\"attrs\":{\"text\":{\"refY\":\"100%\",\"textVerticalAnchor\":\"top\",\"text\":\"logo\",\"style\":{\"color\":\"#080808\"},\"refY2\":4},\"image\":{\"xlink:href\":\"dist/img/logo.36cbc06d.png\"},\"body\":{\"stroke\":\"#5F95FF\"},\"line\":{\"stroke\":\"orange\"}},\"visible\":true,\"shape\":\"image\",\"id\":\"5123ad82-18bb-46fe-9d93-138b24b54a15\",\"data\":{\"dataId\":\"123456\",\"nodeType\":\"node\",\"nodeTypeExt\":\"aaa\"},\"ports\":{\"groups\":{\"top\":{\"position\":\"top\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"right\":{\"position\":\"right\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"bottom\":{\"position\":\"bottom\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"left\":{\"position\":\"left\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}}},\"items\":[{\"group\":\"top\",\"id\":\"bc0336ec-7912-4720-aea7-e5869de77692\"},{\"group\":\"right\",\"id\":\"a977d555-b8c8-4578-9a8b-3097c405c1a8\"},{\"group\":\"bottom\",\"id\":\"fef0f533-9581-4831-ba65-427f097a3d17\"},{\"group\":\"left\",\"id\":\"01eb49d9-4b1c-466f-8263-935542436c7e\"}]},\"zIndex\":2,\"labels\":[{\"attrs\":{\"body\":{\"stroke\":\"orange\"}}}]},{\"position\":{\"x\":-620,\"y\":-200},\"size\":{\"width\":60,\"height\":60},\"attrs\":{\"text\":{\"refY\":\"100%\",\"textVerticalAnchor\":\"top\",\"text\":\"start\",\"style\":{\"color\":\"#080808\"},\"refY2\":4},\"image\":{\"xlink:href\":\"dist/img/start.88f586e1.png\"},\"body\":{\"stroke\":\"#5F95FF\"},\"line\":{\"stroke\":\"orange\"}},\"visible\":true,\"shape\":\"image\",\"id\":\"f91765b1-af48-4396-84ba-eb16e3476aa5\",\"data\":{\"dataId\":\"\",\"nodeType\":\"start\",\"nodeTypeExt\":\"\"},\"ports\":{\"groups\":{\"top\":{\"position\":\"top\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"right\":{\"position\":\"right\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"bottom\":{\"position\":\"bottom\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"left\":{\"position\":\"left\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}}},\"items\":[{\"group\":\"top\",\"id\":\"2ad6a8d5-d86d-49e6-908a-d317b61997c1\"},{\"group\":\"right\",\"id\":\"839cb2d9-59ca-4a39-a63c-26bf60cc6989\"},{\"group\":\"bottom\",\"id\":\"7048578f-94d9-4f75-b653-eb5f43ff55db\"},{\"group\":\"left\",\"id\":\"e7bb1134-4b4c-401d-89ea-e77ae24cbd03\"}]},\"zIndex\":3,\"labels\":[{\"attrs\":{\"body\":{\"stroke\":\"orange\"}}}]},{\"position\":{\"x\":-153,\"y\":-240},\"size\":{\"width\":60,\"height\":60},\"attrs\":{\"text\":{\"refY\":\"100%\",\"textVerticalAnchor\":\"top\",\"text\":\"switchRight\",\"style\":{\"color\":\"#080808\"},\"refY2\":4},\"image\":{\"xlink:href\":\"dist/img/switchRight.74768797.png\"},\"body\":{\"stroke\":\"#5F95FF\"}},\"visible\":true,\"shape\":\"image\",\"id\":\"6df9adc8-cb83-405c-8482-633db0f3644f\",\"data\":{\"dataId\":\"\",\"nodeType\":\"switchRight\",\"nodeTypeExt\":\"\"},\"ports\":{\"groups\":{\"top\":{\"position\":\"top\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"right\":{\"position\":\"right\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"bottom\":{\"position\":\"bottom\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"left\":{\"position\":\"left\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}}},\"items\":[{\"group\":\"top\",\"id\":\"adceedb7-f842-4d1e-be3a-8b3cb0a7e3ce\"},{\"group\":\"right\",\"id\":\"80d3bd61-1ed3-493a-b4e8-d4576e6fbfda\"},{\"group\":\"bottom\",\"id\":\"8fa84779-80b2-4c91-8366-7dd4fa0d93ff\"},{\"group\":\"left\",\"id\":\"f93ccd2f-dedd-47b1-9ad0-9be20c5db8a4\"}]},\"zIndex\":4},{\"position\":{\"x\":-21,\"y\":-240},\"size\":{\"width\":60,\"height\":60},\"attrs\":{\"text\":{\"refY\":\"100%\",\"textVerticalAnchor\":\"top\",\"text\":\"logo\",\"style\":{\"color\":\"#080808\"},\"refY2\":4},\"image\":{\"xlink:href\":\"dist/img/logo.36cbc06d.png\"},\"body\":{\"stroke\":\"#5F95FF\"},\"line\":{\"stroke\":\"orange\"}},\"visible\":true,\"shape\":\"image\",\"id\":\"da634b2e-5ffc-4e1b-a636-f86ace9eb082\",\"data\":{\"dataId\":\"123456\",\"nodeType\":\"node\",\"nodeTypeExt\":\"aaa\"},\"ports\":{\"groups\":{\"top\":{\"position\":\"top\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"right\":{\"position\":\"right\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"bottom\":{\"position\":\"bottom\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"left\":{\"position\":\"left\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}}},\"items\":[{\"group\":\"top\",\"id\":\"bc0336ec-7912-4720-aea7-e5869de77692\"},{\"group\":\"right\",\"id\":\"a977d555-b8c8-4578-9a8b-3097c405c1a8\"},{\"group\":\"bottom\",\"id\":\"fef0f533-9581-4831-ba65-427f097a3d17\"},{\"group\":\"left\",\"id\":\"01eb49d9-4b1c-466f-8263-935542436c7e\"}]},\"zIndex\":5,\"labels\":[{\"attrs\":{\"body\":{\"stroke\":\"orange\"}}}]},{\"position\":{\"x\":170,\"y\":-100},\"size\":{\"width\":60,\"height\":60},\"attrs\":{\"text\":{\"refY\":\"100%\",\"textVerticalAnchor\":\"top\",\"text\":\"end\",\"style\":{\"color\":\"#080808\"},\"refY2\":4},\"image\":{\"xlink:href\":\"dist/img/end.814a7041.png\"},\"body\":{\"stroke\":\"#5F95FF\"}},\"visible\":true,\"shape\":\"image\",\"id\":\"0bb2ba89-a92d-4b32-b3cd-45df2300fa34\",\"data\":{\"dataId\":\"\",\"nodeType\":\"end\",\"nodeTypeExt\":\"\"},\"ports\":{\"groups\":{\"top\":{\"position\":\"top\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"right\":{\"position\":\"right\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"bottom\":{\"position\":\"bottom\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"left\":{\"position\":\"left\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}}},\"items\":[{\"group\":\"top\",\"id\":\"223c9b3a-6baa-4bb8-99ba-c3300db9a942\"},{\"group\":\"right\",\"id\":\"2806bc8a-4e11-4657-9af9-089907985671\"},{\"group\":\"bottom\",\"id\":\"c56eed35-95fa-4e3c-adba-9847ef705e1c\"},{\"group\":\"left\",\"id\":\"61eaafd2-095b-41d6-8e34-862fb470b7a6\"}]},\"zIndex\":6},{\"position\":{\"x\":-350,\"y\":-54},\"size\":{\"width\":60,\"height\":60},\"attrs\":{\"text\":{\"refY\":\"100%\",\"textVerticalAnchor\":\"top\",\"text\":\"logo\",\"style\":{\"color\":\"#080808\"},\"refY2\":4},\"image\":{\"xlink:href\":\"dist/img/logo.36cbc06d.png\"},\"body\":{\"stroke\":\"#5F95FF\"}},\"visible\":true,\"shape\":\"image\",\"id\":\"2b6df966-4e19-4055-bb13-c4c083b18e58\",\"data\":{\"dataId\":\"123456\",\"nodeType\":\"node\",\"nodeTypeExt\":\"aaa\"},\"ports\":{\"groups\":{\"top\":{\"position\":\"top\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"right\":{\"position\":\"right\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"bottom\":{\"position\":\"bottom\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"left\":{\"position\":\"left\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}}},\"items\":[{\"group\":\"top\",\"id\":\"bc0336ec-7912-4720-aea7-e5869de77692\"},{\"group\":\"right\",\"id\":\"a977d555-b8c8-4578-9a8b-3097c405c1a8\"},{\"group\":\"bottom\",\"id\":\"fef0f533-9581-4831-ba65-427f097a3d17\"},{\"group\":\"left\",\"id\":\"01eb49d9-4b1c-466f-8263-935542436c7e\"}]},\"zIndex\":7},{\"position\":{\"x\":-330,\"y\":40},\"size\":{\"width\":60,\"height\":60},\"attrs\":{\"text\":{\"refY\":\"100%\",\"textVerticalAnchor\":\"top\",\"text\":\"logo\",\"style\":{\"color\":\"#080808\"},\"refY2\":4},\"image\":{\"xlink:href\":\"dist/img/logo.36cbc06d.png\"},\"body\":{\"stroke\":\"#5F95FF\"}},\"visible\":true,\"shape\":\"image\",\"id\":\"323f5abe-05ed-419d-9d81-d25c7d3b19f3\",\"data\":{\"dataId\":\"123456\",\"nodeType\":\"node\",\"nodeTypeExt\":\"aaa\"},\"ports\":{\"groups\":{\"top\":{\"position\":\"top\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"right\":{\"position\":\"right\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"bottom\":{\"position\":\"bottom\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"left\":{\"position\":\"left\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}}},\"items\":[{\"group\":\"top\",\"id\":\"bc0336ec-7912-4720-aea7-e5869de77692\"},{\"group\":\"right\",\"id\":\"a977d555-b8c8-4578-9a8b-3097c405c1a8\"},{\"group\":\"bottom\",\"id\":\"fef0f533-9581-4831-ba65-427f097a3d17\"},{\"group\":\"left\",\"id\":\"01eb49d9-4b1c-466f-8263-935542436c7e\"}]},\"zIndex\":8},{\"position\":{\"x\":-153,\"y\":-20},\"size\":{\"width\":60,\"height\":60},\"attrs\":{\"text\":{\"refY\":\"100%\",\"textVerticalAnchor\":\"top\",\"text\":\"logo\",\"style\":{\"color\":\"#080808\"},\"refY2\":4},\"image\":{\"xlink:href\":\"dist/img/logo.36cbc06d.png\"},\"body\":{\"stroke\":\"#5F95FF\"},\"line\":{\"stroke\":\"orange\"}},\"visible\":true,\"shape\":\"image\",\"id\":\"1f378f5e-066d-49bb-a6cc-de24a8882d65\",\"data\":{\"dataId\":\"123456\",\"nodeType\":\"node\",\"nodeTypeExt\":\"aaa\"},\"ports\":{\"groups\":{\"top\":{\"position\":\"top\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"right\":{\"position\":\"right\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"bottom\":{\"position\":\"bottom\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}},\"left\":{\"position\":\"left\",\"attrs\":{\"circle\":{\"r\":4,\"magnet\":true,\"stroke\":\"#5F95FF\",\"strokeWidth\":1,\"fill\":\"#fff\",\"style\":{\"visibility\":\"hidden\"}}}}},\"items\":[{\"group\":\"top\",\"id\":\"bc0336ec-7912-4720-aea7-e5869de77692\"},{\"group\":\"right\",\"id\":\"a977d555-b8c8-4578-9a8b-3097c405c1a8\"},{\"group\":\"bottom\",\"id\":\"fef0f533-9581-4831-ba65-427f097a3d17\"},{\"group\":\"left\",\"id\":\"01eb49d9-4b1c-466f-8263-935542436c7e\"}]},\"zIndex\":9,\"labels\":[{\"attrs\":{\"body\":{\"stroke\":\"orange\"}}}]}]}";
 
@@ -131,6 +802,7 @@
                 if ("node".equals(modelNode.getNodeType())) {
                     modelNode.setDataId(Long.valueOf(JsonUtils2.getJsonValueByPath(jsonObject, "data/dataId".split("/")).toString()));
                     modelNode.setNodeTypeExt(JsonUtils2.getJsonValueByPath(jsonObject, "data/nodeTypeExt".split("/")).toString());
+                    modelNode.setName(JsonUtils2.getJsonValueByPath(jsonObject, "attrs/label/textWrap/text".split("/")).toString());
                 }
                 modelNodeList.add(modelNode);
             }
@@ -251,27 +923,35 @@
                                 List<Algorithm> algoList,
                                 int stepNo) {
         String computerList = "";
+        String objectList = "";
         for (List<ModelNode> path : listPath) {
             path.remove(path.get(path.size()-1));
             Long id = null;
+            String name = "";
             if (path.size()==0) {
                 return stepNo;
             } else if (path.size()==1) {
+                if ("end".equals(opNode.getNodeType()) && !"start".equals(lastNode.getNodeType())) return stepNo;
                 id = path.get(path.size()-1).getId();
+                name = path.get(path.size()-1).getName();
             } else {
                 id = UUIDUtil.generateId();
+                name = id.toString();
                 Algorithm algo = new Algorithm();
                 algo.setId(id);
                 algo.setModelId(modelId);
                 algo.setComputerId(id);
                 algo.setModelType("series");
                 algo.setAlgorithmType("series");
-                algo.setComputerList(StringUtils.join(path.stream().map(ModelNode::getId).collect(Collectors.toSet()), ","));
+                algo.setComputerList(joinNodeId(path, ","));
+                algo.setObjectList(joinNodeName(path, ","));
                 algo.setStep(stepNo);
                 stepNo++;
                 algoList.add(algo);
+                name = "v"+ algo.getStep();
             }
             computerList = computerList.equals("") ? id.toString() : computerList + "," + id.toString();
+            objectList = objectList.equals("") ? name : objectList + "," + name;
             for (ModelNode node : path) {
                 List<ModelLine> lineList4 = modelLineList.stream().filter(item ->
                         item.getEndCell().equals(node.getPicId()) || item.getBeginCell().equals(node.getPicId())).collect(Collectors.toList());
@@ -287,14 +967,15 @@
         algo.setModelType(opNode.getNodeType());
         algo.setAlgorithmType(opNode.getNodeType());
         algo.setComputerList(computerList);
+        algo.setObjectList(objectList);
         algo.setStep(stepNo);
         stepNo++;
         algoList.add(algo);
 
         //灏嗗師杩愮畻鑺傜偣鏀规垚铏氳妭鐐�
         opNode.setId(id);
-//        opNode.setPicId(id.toString());
         opNode.setNodeType("vnode");
+        opNode.setName("v"+algo.getStep());
 
         ModelLine modelLineNew = new ModelLine();
         Long picId2 = UUIDUtil.generateId();
@@ -308,6 +989,24 @@
         return stepNo;
     }
 
+    private String joinNodeId(List<ModelNode> nodeList, String sep) {
+        String result = "";
+        for (int i = 0; i < nodeList.size(); i++) {
+            if (i > 0) result = result + sep;
+            result = result + nodeList.get(i).getId().toString();
+        }
+        return result;
+    }
+
+    private String joinNodeName(List<ModelNode> nodeList, String sep) {
+        String result = "";
+        for (int i = 0; i < nodeList.size(); i++) {
+            if (i > 0) result = result + sep;
+            result = result + nodeList.get(i).getName();
+        }
+        return result;
+    }
+
     private void saveModel(Long modelId,
                            List<ModelNode> modelNodeList,
                            List<ModelLine> modelLineList,

--
Gitblit v1.9.1