官术网_书友最值得收藏!

Understanding feature matching

Once we have extracted features and their descriptors from two (or more) images, we can start asking whether some of these features show up in both (or all) images. For example, if we have descriptors for both our object of interest (self.desc_train) and the current video frame (desc_query), we can try to find regions of the current frame that look like our object of interest.

This is done by the following method, which makes use of FLANN:

good_matches = self.match_features(desc_query)

The process of finding frame-to-frame correspondences can be formulated as the search for the nearest neighbor from one set of descriptors for every element of another set.

The first set of descriptors is usually called the train set, because, in machine learning, these descriptors are used to train a model, such as the model of the object that we want to detect. In our case, the train set corresponds to the descriptor of the template image (our object of interest). Hence, we call our template image the train image (self.img_train).

The second set is usually called the query set because we continually ask whether it contains our train image. In our case, the query set corresponds to the descriptor of each incoming frame. Hence, we call a frame the query image (img_query).

Features can be matched in any number of ways, for example, with the help of a brute-force matcher (cv2.BFMatcher) that looks for each descriptor in the first set and the closest descriptor in the second set by trying each one (an exhaustive search).

In the next section, we'll learn how to match features across images with FLANN.

主站蜘蛛池模板: 广平县| 虹口区| 伊金霍洛旗| 莱芜市| 灵寿县| 双牌县| 安阳市| 和平县| 富源县| 阿拉善盟| 金川县| 濮阳市| 新干县| 太原市| 米泉市| 中阳县| 九台市| 怀仁县| 高平市| 龙门县| 永和县| 彩票| 石阡县| 渑池县| 玉田县| 富源县| 隆化县| 威远县| 砀山县| 锦屏县| 开化县| 祥云县| 石楼县| 桂东县| 抚顺县| 昌邑市| 呈贡县| 崇信县| 东光县| 洞头县| 肥城市|