2021-03-26

创建对应的实体

@Data
public class NodeTest {
private Long id;
private String name;
private Long parentId;
private List children;

public NodeTest(Long id, String name, Long parentId) {
    this.id = id;
    this.name = name;
    this.parentId = parentId;
}

}

具体的生成树的方法和测试

public class TestTree {
//生成树结构数据方法
private static List getTree(List nodes) {
Map<Long, NodeTest> nodeMap = new HashMap<>();//方便查找
List rootList = new ArrayList<>();//定义根节点,租后返回的也是根节点
//根节点特点:parentId小于0
for (NodeTest node : nodes) {//找出根节点,并且给nodemap赋值
nodeMap.put(node.getId(), node);
if (node.getParentId() == null || node.getParentId() <= 0) {
rootList.add(node);
}
}

    for (NodeTest node : nodes) { //循环相对于根节点的所有子节点:循环除根节点外的其他节点;
        if (node.getParentId() == null || node.getParentId() <= 0) {
            continue;
        }
        NodeTest pNode = nodeMap.get(node.getParentId());//找出子节点对应的父节点,给父节点的children进行add该子节点;
        if (pNode == null) {
            continue;
        }
        List<NodeTest> children = pNode.getChildren();
        if (children == null) {//不加这个判断会报错; 对父节点中不存在children属性的,要进行set添加;
            children = new ArrayList<>();
            pNode.setChildren(children);
        }
        children.add(node);
    }
    return rootList;
}

public static void main(String[] args) {
    List<NodeTest> nodeTestList = new ArrayList<>();
    nodeTestList.add(new NodeTest(1L, "一级", -1L));
    nodeTestList.add(new NodeTest(2L, "一级-1", 1L));
    nodeTestList.add(new NodeTest(3L, "一级-1-1", 2L));
    nodeTestList.add(new NodeTest(4L, "二级", -1L));
    System.out.println(JSON.toJSONString(getTree(nodeTestList)));
}

}

2021-03-26 20:54:33,596 - Model - INFO - Epoch 1 (1/200): 2021-03-26 20:57:40,380 - Model - INFO - Train Instance Accuracy: 0.571037 2021-03-26 20:58:16,623 - Model - INFO - Test Instance Accuracy: 0.718528, Class Accuracy: 0.627357 2021-03-26 20:58:16,623 - Model - INFO - Best Instance Accuracy: 0.718528, Class Accuracy: 0.627357 2021-03-26 20:58:16,623 - Model - INFO - Save model... 2021-03-26 20:58:16,623 - Model - INFO - Saving at log/classification/pointnet2_msg_normals/checkpoints/best_model.pth 2021-03-26 20:58:16,698 - Model - INFO - Epoch 2 (2/200): 2021-03-26 21:01:26,685 - Model - INFO - Train Instance Accuracy: 0.727947 2021-03-26 21:02:03,642 - Model - INFO - Test Instance Accuracy: 0.790858, Class Accuracy: 0.702316 2021-03-26 21:02:03,642 - Model - INFO - Best Instance Accuracy: 0.790858, Class Accuracy: 0.702316 2021-03-26 21:02:03,642 - Model - INFO - Save model... 2021-03-26 21:02:03,643 - Model - INFO - Saving at log/classification/pointnet2_msg_normals/checkpoints/best_model.pth 2021-03-26 21:02:03,746 - Model - INFO - Epoch 3 (3/200): 2021-03-26 21:05:15,349 - Model - INFO - Train Instance Accuracy: 0.781606 2021-03-26 21:05:51,538 - Model - INFO - Test Instance Accuracy: 0.803641, Class Accuracy: 0.738575 2021-03-26 21:05:51,538 - Model - INFO - Best Instance Accuracy: 0.803641, Class Accuracy: 0.738575 2021-03-26 21:05:51,539 - Model - INFO - Save model... 2021-03-26 21:05:51,539 - Model - INFO - Saving at log/classification/pointnet2_msg_normals/checkpoints/best_model.pth 我有类似于这样的一段txt文件,请你帮我写一段代码来可视化这些训练结果
02-06
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值