特征匹配 选取 reference image 上的 公共点 及其相应匹配

现在我有 N 张图像,选取第 1 张图像作为 reference image,剩下的图像都要跟第 1 张图像做 feature matching。一共做 N-1 次 feature matching。每次 feature matching 之后,都能得到两个输出,分别是 参与 匹配的两张图像对应的匹配点kp0_numpy, kp1_numpy。

N-1 次 feature matching,就会得到两个 list,input1 跟 input2,分别对应N-1个kp0_numpy跟N-1个kp1_numpy。

现在我需要找到 N-1 个 kp0_numpy 共有的 keypoints,以及这些keypoints 在 每个 kp1_numpy 对应的 keypoints。 下面的 FindCommonUV 函数可以做到。

CombineFeaturePointArrays 函数则是实现将 N-1 个 kp0_numpy 共有的 keypoints,以及这些keypoints 在 每个 kp1_numpy 对应的 keypoints 拼凑成 一个 [2*N, num_feature ] 形状的 np.darray。其中 num_feature 是 公共 keypoints的数目,N 是 图像数目。

函数 FindCommonUV 的输入 input1 跟 input2 是两个 keypoints 的 list。 input1 对应 reference image

python 复制代码
def CombineFeaturePointArrays(common_points, matched_points_list):
    # 将common_points和matched_points_list中的数组转置
    transposed_common_points = common_points.T
    transposed_matched_points = [feature_array.T for feature_array in matched_points_list]
    result_array = np.vstack([transposed_common_points, *transposed_matched_points])

    return result_array

def FindCommonUV(input1, input2):
    common_points = None
    matched_points_list = []

    # Find common points in the first pair of arrays
    common_points = np.array([point for point in input1[0] if all( np.any(np.all(point == sublist, axis=1)) for sublist in input1[1:] )])

    # Iterate over input1 and input2 simultaneously
    for i, (kp0, kp1) in enumerate(zip(input1, input2)):
        # Find indices of common points in input1[i]
        indices = [np.where((kp0 == point).all(axis=1))[0][0] for point in common_points]
        # Extract corresponding points from input2[i]
        matched_points = kp1[indices]
        
        # Append to matched_points_list
        matched_points_list.append(matched_points)

    return common_points, matched_points_list

def FilterKeypoints(kp0_numpy, kp1_numpy, H_original, W_original):
    # 找到超出范围的索引
    invalid_indices_kp0 = np.where((kp0_numpy[:, 0] < 0.) | (kp0_numpy[:, 0] >= W_original) |
                                   (kp0_numpy[:, 1] < 0.) | (kp0_numpy[:, 1] >= H_original))[0]
    
    #print(invalid_indices_kp0)
    invalid_indices_kp1 = np.where((kp1_numpy[:, 0] < 0.) | (kp1_numpy[:, 0] >= W_original) |
                                   (kp1_numpy[:, 1] < 0.) | (kp1_numpy[:, 1] >= H_original))[0]
    #print(invalid_indices_kp1)
    # 合并两个数组,去重
    invalid_indices = np.unique(np.concatenate((invalid_indices_kp0, invalid_indices_kp1)))

    # 删除超出范围的点
    kp0_filtered = np.delete(kp0_numpy, invalid_indices, axis=0)
    kp1_filtered = np.delete(kp1_numpy, invalid_indices, axis=0)

    return kp0_filtered, kp1_filtered
相关推荐
桃花键神20 分钟前
AI可信论坛亮点:合合信息分享视觉内容安全技术前沿
人工智能
野蛮的大西瓜41 分钟前
开源呼叫中心中,如何将ASR与IVR菜单结合,实现动态的IVR交互
人工智能·机器人·自动化·音视频·信息与通信
CountingStars6191 小时前
目标检测常用评估指标(metrics)
人工智能·目标检测·目标跟踪
tangjunjun-owen1 小时前
第四节:GLM-4v-9b模型的tokenizer源码解读
人工智能·glm-4v-9b·多模态大模型教程
冰蓝蓝1 小时前
深度学习中的注意力机制:解锁智能模型的新视角
人工智能·深度学习
橙子小哥的代码世界1 小时前
【计算机视觉基础CV-图像分类】01- 从历史源头到深度时代:一文读懂计算机视觉的进化脉络、核心任务与产业蓝图
人工智能·计算机视觉
新加坡内哥谈技术2 小时前
苏黎世联邦理工学院与加州大学伯克利分校推出MaxInfoRL:平衡内在与外在探索的全新强化学习框架
大数据·人工智能·语言模型
fanstuck3 小时前
Prompt提示工程上手指南(七)Prompt编写实战-基于智能客服问答系统下的Prompt编写
人工智能·数据挖掘·openai
lovelin+v175030409663 小时前
安全性升级:API接口在零信任架构下的安全防护策略
大数据·数据库·人工智能·爬虫·数据分析
唐小旭3 小时前
python3.6搭建pytorch环境
人工智能·pytorch·python