把“距离过近”的节点(或端点)合并成一个,避免重复。机器学习 python

📌 函数作用一句话

把"距离过近"的节点(或端点)合并成一个,避免重复。


🎯 应用场景

  1. 节点去重

    • 霍夫变换或交点计算后,同一物理节点 可能得到 多个像素级坐标(±1~3 px)。
    • 例如:两条导线的交点被算成 (124, 200)(125, 201)(126, 200) → 需要合并为一个 (125, 200)
  2. 端点聚类

    • 元件边框与导线交点可能 密集成群(手绘粗细、锯齿)。
    • 例如:一个引脚附近出现 5 个交点 → 合并成 1 个代表点。
  3. 可视化降噪

    • 让最终 节点/端点的数量 = 实际电路点数,图更干净。

⚙️ 原理拆解

步骤 代码片段 解释
1. 输入 nodes = [(x1,y1), (x2,y2), ...] 原始点列表,可能有重复/过近。
2. 转 NumPy pts = np.array(nodes) 方便广播计算欧氏距离。
3. 贪心聚类 for i, p in enumerate(pts): ... 每个未用点作为"种子",找所有距离 < eps 的点归为一组。
4. 计算新坐标 np.round(np.mean(group, axis=0)) 用组内点的几何中心作为合并后的新坐标,避免偏移。
5. 去重输出 return list(set(...)) 防止重复添加。

📏 参数 eps 怎么选?

场景 推荐 eps
手绘电路,像素粗 8 ~ 12
高清扫描/矢量图 3 ~ 5
不确定 先试 8,再视结果微调。

✅ 一句话总结

把"像素级误差"的多个点 → 聚类成"物理级"唯一节点/引脚。

bash 复制代码
# 合并相邻节点
def merge_nearby_nodes(nodes, eps=10):
    """
    合并相邻节点(欧氏距离 < eps)
    输入:[(x1,y1), (x2,y2), ...]
    输出:合并后的节点列表
    """
    if not nodes:
        return []

    # 转成 numpy,便于广播计算
    pts = np.array(nodes).reshape(-1, 2)
    merged = []
    used = np.zeros(len(pts), dtype=bool)

    for i, p in enumerate(pts):
        if used[i]:
            continue
        group = [p]
        used[i] = True
        for j, q in enumerate(pts[i+1:], start=i+1):
            if not used[j] and np.linalg.norm(p - q) < eps:
                group.append(q)
                used[j] = True
        # 取平均坐标作为合并后的节点
        merged.append(tuple(np.round(np.mean(group, axis=0)).astype(int)))
    return merged
相关推荐
Pyeako1 小时前
机器学习--K-means聚类&DBSCAN&TF-IDF
python·机器学习·kmeans·tf-idf·聚类·dbscan
liu****1 小时前
01_NumPy讲义
开发语言·python·numpy·python高级语法
从负无穷开始的三次元代码生活1 小时前
Python网络爬虫——知识点
爬虫·python
Coovally AI模型快速验证1 小时前
当小龙虾算法遇上YOLO:如何提升太阳能电池缺陷检测精度?
人工智能·深度学习·算法·yolo·目标检测·无人机
仅此,1 小时前
Java请求进入Python FastAPI 后,请求体为空,参数不合法
java·spring boot·python·组合模式·fastapi
94620164zwb51 小时前
外观设置模块 Cordova 与 OpenHarmony 混合开发实战
python
深圳行云创新1 小时前
行云创新 AI+CloudOS:AI + 云原生落地新范式
人工智能·云原生·系统架构
AI视觉网奇1 小时前
火星- ue数字人智能体 学习笔记
人工智能·笔记·学习
深蓝海拓2 小时前
PySide6从0开始学习的笔记(二十) qdarkstyle的深入应用
笔记·python·qt·学习·pyqt