[Feature Matching using various method]
Github Code
Applied Feature Extraction and Descriptor Method to robust matching !!
[Goal] We can apply various extracton and descriptor method for matching in challenging environment
[Advanced] Algorithm extended by applying the corresponding github page → Parallax
[Advantage] We can easily apply various method only changing parameters!!
- Challenging Environment
    Query Image Candidate Image     
1. Dependencies
- 
    OpenCV 3.2.0, OpenCV Contrib 3.2.0, C++ 11 version 
- Use LibTorch (1.6.0 version)
    - [0] Just follow up this page !!
        - Reference Site: https://github.com/ChanWoo25/SuperPoint2CPP/blob/master/INSTALL_LibTorch.sh
 
- [1] Find Cuda version and cuDNN version
- [2] Install appropriate version of Libtorch in local desktop
        - Reference Site: https://pytorch.org/get-started/locally/
 
- [3] Add g++ in start.sh file
        - Reference Site: https://discuss.pytorch.org/t/compile-libtorch-with-g/114536
 
- [4] Error Related
        - (1) libc10.so: cannot open shared object file: No such file or directory
            - Reference Site: https://stackoverflow.com/questions/480764/linux-error-while-loading-shared-libraries-cannot-open-shared-object-file-no-s
 
- (2) ‘c10::Error’ what(): open file failed because of errno 2 on fopen
            - Reference Site: https://stackoverflow.com/questions/15753090/c-fopen-fails-for-write-with-errno-is-2
 
 
- (1) libc10.so: cannot open shared object file: No such file or directory
            
 
- [0] Just follow up this page !!
        
- Get Pre-trained Model (Thanks for freely using the pre-trained model !!)
    - [1] https://github.com/ChanWoo25/SuperPoint2CPP/tree/master/Weights
- [2] https://github.com/magicleap/SuperPointPretrainedNetwork
- [3] https://github.com/magicleap/SuperGluePretrainedNetwork
 
2. Methodology to apply feature matching
- Feature Extraction Method
    - [1] ORB
- [2] goodFeaturesToTrack
- [3] SIFT
- [4] SuperPoint
 
- Feature Descriptor Method
    - [1] AKAZE
- [2] SURF
- [3] DAISY
- [4] SuperPoint
 
- Macher Method
    - [1] Brute-Force Matcher (BF)
- [2] Fast Library for Approximate Nearest Neighbors Matcher (FLANN)
 
- Matching Method
    - [1] vanilla match (VANILLA)
- [2] knn match (KNN)
- [3] radius match (RADIUS)
 
- Outlier Rejection Method
    - [1] findFundamentalMatrix (FM)
- [2] vector field consensus (VFC)
 
3. Build and Run
Clone the repository and build and run simultaneously:
   $ cd ${workspace}
   $ git clone https://github.com/SungJaeShin/Feature_matching.git
   $ cd Feature_matching
   $ sh start.sh
4. Changing Parameters
- 
    IMAGE_NUM (include.h): Put value to test image pair 
- EXTRACT_MODE (include.h):
    - 1 → apply ORB
- 2 → apply GFTT (GoodFeaturesToTrack)
- 3 → apply SIFT
- 4 → apply GFTT(Query) + ORB(Candidate)
- 5 → apply GFTT(Query) + SIFT(Candidate)
- 6 → apply SuperPoint
 
- DESCRIPTOR_MODE (include.h):
    - 1 → apply AKAZE
- 2 → apply SURF
- 3 → apply DAISY
- 4 → apply SuperPoint
 
- MATCHER_MODE (include.h):
    - 1 → apply BF Matcher (Brute-Force)
- 2 → apply FLANN Matcher (Fast Library for Approximate Nearest Neighbors)
 
- MATCHING_MODE (include.h):
    - 1 → apply vanilla match
- 2 → apply knn match
- 3 → apply radius match
 
- REJECTION_MODE (include.h):
    - 1 → apply fundamentalMatrix
- 2 → apply VFC
 
- 
    MIN_DIS (include.h): Put value to change feature’s Euclidean distance when using GoodFeaturesToTrack extractor 
- 
    superpoint_model_weight_path (matching.cpp): Put absolute path for getting pre-trained SuperPoint model 
- 
    query_path, cand_path (matching.cpp): Put absolute path for getting query image and candidate image 
- save_path (plot.h): Put absolute path for saving matching result
5. Advanced Changing Parameters (Option)
This variables are not requirement, but the following variables are also considered to obtain more robust results.
- [CASE 1] When you use BFMatcher, please change in create arguments
    - SIFT, SURF → cv::NORM_L1 & cv::NORM_L2
- ORB → cv::NORM_HAMMING
 
- [CASE 2] When you use radiusMatch, please change maxDistance argument
    - In above case, there are some preference radius results !! (Default = 0.3)
        - [Preference radius] 0.4 => 405 matches / 0.3 => 183 matches / 0.2 => 117 matches
 
 
- In above case, there are some preference radius results !! (Default = 0.3)
        
- [CASE 3] When you use findFundamentalMat, please change ransacReprojThreshold argument (Default = 1)
    - If you want to get more robust result, then change ‘0.1’ or etc.
 
6. Results
- Results of Inlier Number and Time Consumption
    - ORB Result
   - GFTT Result
   - SIFT Result
   
- Matching Results Set
    ORB + AKAZE + FM (inliers 22) ORB + SURF + FM (inliers 44) ORB + DAISY + FM (inliers 57)       GFTT + AKAZE + FM (inliers 10) GFTT + SURF + FM (inliers 9) GFTT + DAISY + FM (inliers 10)       SIFT + AKAZE + FM (inliers 11) SIFT + SURF + FM (inliers 17) SIFT + DAISY + FM (inliers 19)       GFTT + ORB + AKAZE + FM (inliers 10) GFTT + ORB + SURF + FM (inliers 10) GFTT + ORB + DAISY + FM (inliers 8)       GFTT + SIFT + AKAZE + FM (inliers 10) GFTT + SIFT + SURF + FM (inliers 9) GFTT + SIFT + DAISY + FM (inliers 9)       
- SuperPoint Result (C++ Version)
    - Time consumption getting Pre-trained SuperPoint model: 21.1761 ms
- Result of features using SuperPoint Model
        Query Features Candidate Features     
 
- SuperPoint + SuperGlue Result (Python Version) (Follow this Page !!)
    - Red: more confident, Blue: less confident
 Threshold = 0.3 (inliers 64) Threshold = 0.4 (inliers 52)     Threshold = 0.5 (inliers 47) Threshold = 0.6 (inliers 40)     Threshold = 0.7 (inliers 30) Threshold = 0.8 (inliers 25)     
7. Best Results
- C++ Results
    - ORB + SURF + BF + KNN + FM (ransacReprojThreshold = 1)
   - ORB + DAISY + BF + KNN + FM (ransacReprojThreshold = 1)
   - ORB + SURF + BF + KNN + FM (ransacReprojThreshold = 0.1)
   - ORB + DAISY + BF + KNN + FM (ransacReprojThreshold = 0.1)
   - ORB + SURF + BF + KNN + VFC
   - ORB + DAISY + BF + KNN + VFC
   
- Python Version (Follow this Page !!)
    - SuperPoint + SuperGlue (matching threshold = 0.8) (Red: more confident, Blue: less confident)
   
8. Support Docker
Test on Ubuntu 18.04 equipped with P2000 NoteBook
- [0] Download Basic Envrionment
    - (Download) opecn 3.2.0 w/ contrib, CUDA 9.0, cuDNN 7, ubuntu 16.04
 
- [1] Install Docker
    - Ref Site: https://docs.docker.com/engine/install/ubuntu/
 
- [2] Get Appropriate Docker Images
    - Ref Site: https://hub.docker.com/
 
- [3] Other Docker properties to communicate host machine
    - Ref Site: https://github.com/deepshwang/howtodocker
 
- [4] Error Related
    - (1) docker: Error response from daemon: could not select device driver “” with capabilities: [[gpu]].
        - Ref Site: https://bluecolorsky.tistory.com/110
 
- (2) nvidia-container-cli: initialization error: load library failed: libnvidia-ml.so.1
        - Ref Site: https://my-grope-log.tistory.com/20
 
 
- (1) docker: Error response from daemon: could not select device driver “” with capabilities: [[gpu]].
        
9. Other Error Related
- [1] SuperGlue Error
    - (1) ImportError: /home/sj/anaconda3/envs/feature_matching/bin/../lib/libgio-2.0.so.0: undefined symbol: g_unix_get_passwd_entry
        - Ref Site: https://github.com/opencv/opencv/issues/7940#issuecomment-310553884
 
 
- (1) ImportError: /home/sj/anaconda3/envs/feature_matching/bin/../lib/libgio-2.0.so.0: undefined symbol: g_unix_get_passwd_entry
        
10. Reference
[1] Jianbo Shi and Carlo Tomasi. Good features to track. In Computer Vision and Pattern Recognition, 1994. Proceedings CVPR’94., 1994 IEEE Computer Society Conference on, pages 593–600. IEEE, 1994. 
[2] David G. Lowe. Distinctive image features from scale-invariant keypoints. Int. J. Comput. Vision, 60(2):91–110, November 2004. 
[3] Herbert Bay, Tinne Tuytelaars, and Luc Van Gool. Surf: Speeded up robust features. Computer Vision–ECCV 2006, pages 404–417, 2006. 
[4] Ethan Rublee, Vincent Rabaud, Kurt Konolige, Gary R. Bradski: ORB: An efficient alternative to SIFT or SURF. ICCV 2011: 2564-2571. 
[5] Pablo Fernández Alcantarilla, Jesús Nuevo, and Adrien Bartoli. Fast explicit diffusion for accelerated features in nonlinear scale spaces. BMVC, pages 13.1–13.11, 2013.
[6] E. Tola, V. Lepetit, and P. Fua. Daisy: An efficient dense descriptor applied to wide baseline stereo. IEEE Transactions on Pattern Analysis and Machine Intelligence, 32(5):815–830, May 2010. 
[7] Jiayi Ma, Ji Zhao, Jinwen Tian, Alan Yuille, and Zhuowen Tu. Robust Point Matching via Vector Field Consensus, IEEE Transactions on Image Processing, 23(4), pp. 1706-1721, 2014 
[8] Jiayi Ma, Ji Zhao, Jinwen Tian, Xiang Bai, and Zhuowen Tu. Regularized Vector Field Learning with Sparse Approximation for Mismatch Removal, Pattern Recognition, 46(12), pp. 3519-3532, 2013 
[9] DeTone, Daniel & Malisiewicz, Tomasz & Rabinovich, Andrew. SuperPoint: Self-Supervised Interest Point Detection and Description. CVPR Deep Learning for Visual SLAM Workshop (CVPR), 2018 
[10] https://bkshin.tistory.com/entry/OpenCV-28-%ED%8A%B9%EC%A7%95-%EB%A7%A4%EC%B9%ADFeature-Matching 
[11] https://stackoverflow.com/questions/18744051/what-the-hessian-minimum-threshold-means-on-the-surffeaturedetector-function 
[12] https://www.researchgate.net/figure/Relation-between-hessian-threshold-value-and-Accuracy-of-SURF-detector-As-shown-in_fig2_309363445 
[13] https://docs.opencv.org/3.4/d9/d37/classcv_1_1xfeatures2d_1_1DAISY.html 
[14] https://m.blog.naver.com/PostView.naver?isHttpsRedirect=true&blogId=pckbj123&logNo=100203116086 
[15] https://076923.github.io/posts/Python-opencv-38/ 
[16] https://docs.opencv.org/3.4/db/d95/classcv_1_1ORB.html#adc371099dc902a9674bd98936e79739c 
[17] https://bkshin.tistory.com/entry/OpenCV-27-%ED%8A%B9%EC%A7%95-%EB%94%94%EC%8A%A4%ED%81%AC%EB%A6%BD%ED%84%B0-%EA%B2%80%EC%B6%9C%EA%B8%B0-SIFT-SURF-ORB 
[18] https://docs.opencv.org/3.4/d7/d60/classcv_1_1SIFT.html 
[19] https://leechamin.tistory.com/330 
[20] https://github.com/mpkuse/robust_feature_matching 
[21] https://github.com/ChanWoo25/SuperPoint2CPP 
[22] https://github.com/magicleap/SuperPointPretrainedNetwork 
[23] https://github.com/magicleap/SuperGluePretrainedNetwork
11. Acknowledgement
Thanks for Yeeun Kim help to get robust feature matching method !!
12. Future Works
- Apply GCBB (Linear time vehicle relocation in SLAM paper)
 
      