Ddddd4431 2023-02-02 12:57 采纳率: 90%
浏览 28
已结题

VLAD算法如何保存训练的码书

问题是这样的,在做行为识别中,对提取到的 HOG特征,HOF特征,或者SIFT特征训练码书,用的是VLAD算法。
这是网上搜到的步骤

img

在第二步中,我将训练集中的特征用K-means 训练完码本之后,应该怎么保存?

训练码本 和 后续的使用码本是不是分开的?(ps:我认为是分开的,或者说我需要分开)

如果说是分开的,将测试集中的特征 根据码本 做 3 步 操作的时候应该怎样操作?

  • 写回答

1条回答 默认 最新

  • m0_54204465 2023-02-02 13:14
    关注

    保存训练出的码本可以使用文件存储,例如使用 numpy 库存储为 .npy 文件,或者使用 pandas 库存储为 .csv 文件。这样就可以将训练出的码本保存下来,供后续使用。

    在后续的使用中,可以读取之前保存的码本,然后对新的查询图像的特征做剩下的步骤,即:

    把新的图像的 SIFT 描述子按照最近邻原则分配到码书上;
    计算每个聚类中心的残差和;
    对这个残差和做 L2 归一化;
    将所有的残差和拼接成长向量;
    计算长向量和图像库中的每个向量的欧式距离,输出前 5 个最小距离。
    假设你已经训练出了一个使用K-means算法的VLAD码书,该码书共有K个聚类中心,每个聚类中心都对应一个128维的向量。你可以使用以下代码将这个码本保存到磁盘上:

    import numpy as np
    
    # 聚类中心的数组,shape为K * 128
    cluster_centers = ...
    
    # 保存聚类中心到磁盘
    np.save("vlad_codebook.npy", cluster_centers)
    

    在后续的使用中,你可以加载这个码书,然后对新的图像中的SIFT描述子进行分配和残差操作,并使用以下代码加载训练好的码书:

    import numpy as np
    
    # 加载聚类中心
    cluster_centers = np.load("vlad_codebook.npy")
    
    

    在接下来的操作中,你可以使用这个cluster_centers数组作为码书,进行图像的检索。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 2月10日
  • 已采纳回答 2月2日
  • 创建了问题 2月2日

悬赏问题

  • ¥15 matlab代码代写,需写出详细代码,代价私
  • ¥15 ROS系统搭建请教(跨境电商用途)
  • ¥15 AIC3204的示例代码有吗,想用AIC3204测量血氧,找不到相关的代码。
  • ¥20 CST怎么把天线放在座椅环境中并仿真
  • ¥15 任务A:大数据平台搭建(容器环境)怎么做呢?
  • ¥15 YOLOv8obb获取边框坐标时报错AttributeError: 'NoneType' object has no attribute 'xywhr'
  • ¥15 r语言神经网络自变量重要性分析
  • ¥15 基于双目测规则物体尺寸
  • ¥15 wegame打不开英雄联盟
  • ¥15 公司的电脑,win10系统自带远程协助,访问家里个人电脑,提示出现内部错误,各种常规的设置都已经尝试,感觉公司对此功能进行了限制(我们是集团公司)