The SuperGlue network is a Graph Neural Network combined with an Optimal Matching layer that is trained to perform matching on two sets of sparse image features. This repo includes PyTorch code for training the SuperGlue matching network on top of both SuperPoint and SIFT keypoints and descriptors. SuperGlue operates as a "middle-end," performing context aggregation, matching, and filtering in a single end-to-end architecture. For more details, please see:
- Full paper PDF: SuperGlue: Learning Feature Matching with Graph Neural Networks.
- Python 3
- PyTorch >= 1.1
- OpenCV >= 3.4 (4.1.2.30 recommended for best GUI keyboard interaction, see this note)
- Matplotlib >= 3.1
- NumPy >= 1.18
Simply run the following command: pip3 install numpy opencv-python torch matplotlib
Or create a conda environment by conda install --name myenv --file superglue.txt
There are two main top-level scripts in this repo:
train.py
: trains the superglue model.datasets/sift_dataset.py
: reads images from files and creates pairs. It generates SIFT keypoints, descriptors and ground truth matches which will be used in training.datasets/superpoint_dataset.py
: reads images from files and creates pairs. It generates SuperPoint keypoints, descriptors and ground truth matches which will be used in training.
To train the SuperGlue with default parameters (SuperPoint detector), run the following command:
python train.py
- Use
--detector
to set the detector mode :superpoint
orsift
(default:superpoint
). - Use
--epoch
to set the number of epochs (default:20
). - Use
--train_path
to set the path to the directory of training images. - Use
--eval_output_dir
to set the path to the directory in which the visualizations is written (default:dump_match_pairs/
). - Use
--show_keypoints
to visualize the detected keypoints (default:False
). - Use
--viz_extension
to set the visualization file extension (default:png
). Use pdf for highest-quality.
The matches are colored by their predicted confidence in a jet colormap (Red: more confident, Blue: less confident).