把“距离过近”的节点(或端点)合并成一个,避免重复。机器学习 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
相关推荐
财富自由且长命百岁1 天前
移动端老兵转型端侧 AI:第一周,我跑通了 ResNet50 推理
机器学习
美酒没故事°1 天前
Open WebUI安装指南。搭建自己的自托管 AI 平台
人工智能·windows·ai
云烟成雨TD1 天前
Spring AI Alibaba 1.x 系列【6】ReactAgent 同步执行 & 流式执行
java·人工智能·spring
Csvn1 天前
🌟 LangChain 30 天保姆级教程 · Day 13|OutputParser 进阶!让 AI 输出自动转为结构化对象,并支持自动重试!
python·langchain
AI攻城狮1 天前
用 Obsidian CLI + LLM 构建本地 RAG:让你的笔记真正「活」起来
人工智能·云原生·aigc
鸿乃江边鸟1 天前
Nanobot 从onboard启动命令来看个人助理Agent的实现
人工智能·ai
lpfasd1231 天前
基于Cloudflare生态的应用部署与开发全解
人工智能·agent·cloudflare
俞凡1 天前
DevOps 2.0:智能体如何接管故障修复和基础设施维护
人工智能
comedate1 天前
[OpenClaw] GLM 5 关于电影 - 人工智能 - 的思考
人工智能·电影评价
财迅通Ai1 天前
6000万吨产能承压 卫星化学迎来战略窗口期
大数据·人工智能·物联网·卫星化学