Spaces:
Running
Running
File size: 11,670 Bytes
2738832 499e141 e228d30 499e141 e228d30 499e141 e228d30 499e141 e228d30 499e141 e228d30 499e141 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 |
---
title: Image Matching Webui
emoji: π€
colorFrom: red
colorTo: yellow
sdk: gradio
sdk_version: 5.4.0
app_file: app.py
pinned: true
license: apache-2.0
---
[![Contributors][contributors-shield]][contributors-url]
[![Forks][forks-shield]][forks-url]
[![Stargazers][stars-shield]][stars-url]
[![Issues][issues-shield]][issues-url]
<p align="center">
<h1 align="center"><br><ins>Image Matching WebUI</ins>
<br>Matching Keypoints between two images</h1>
</p>
<div align="center">
<a target="_blank" href="https://github.com/Vincentqyw/image-matching-webui/actions/workflows/release.yml"><img src="https://github.com/Vincentqyw/image-matching-webui/actions/workflows/release.yml/badge.svg" alt="PyPI Release"></a>
<a target="_blank" href='https://huggingface.co/spaces/Realcat/image-matching-webui'><img src='https://img.shields.io/badge/%F0%9F%A4%97%20Hugging%20Face-Spaces-blue'></a>
<a target="_blank" href="https://pypi.org/project/imcui"><img alt="PyPI - Version" src="https://img.shields.io/pypi/v/imcui?style=flat&logo=pypi&label=imcui&link=https%3A%2F%2Fpypi.org%2Fproject%2Fimcui"></a>
<a target="_blank" href="https://hub.docker.com/r/vincentqin/image-matching-webui"><img alt="Docker Image Version" src="https://img.shields.io/docker/v/vincentqin/image-matching-webui?sort=date&arch=amd64&logo=docker&label=imcui&link=https%3A%2F%2Fhub.docker.com%2Fr%2Fvincentqin%2Fimage-matching-webui"></a>
<a target="_blank" href="https://pepy.tech/projects/imcui"><img src="https://static.pepy.tech/badge/imcui" alt="PyPI Downloads"></a>
</div>
## Description
`Image Matching WebUI (IMCUI)` efficiently matches image pairs using multiple famous image matching algorithms. The tool features a Graphical User Interface (GUI) designed using [gradio](https://gradio.app/). You can effortlessly select two images and a matching algorithm and obtain a precise matching result.
**Note**: the images source can be either local images or webcam images.
Try it on
<a href='https://huggingface.co/spaces/Realcat/image-matching-webui'><img src='https://img.shields.io/badge/%F0%9F%A4%97%20Hugging%20Face-Spaces-blue'></a>
<a target="_blank" href="https://lightning.ai/realcat/studios/image-matching-webui"><img src="https://pl-bolts-doc-images.s3.us-east-2.amazonaws.com/app-2/studio-badge.svg" alt="Open In Studio"/></a>
Here is a demo of the tool:
https://github.com/Vincentqyw/image-matching-webui/assets/18531182/263534692-c3484d1b-cc00-4fdc-9b31-e5b7af07ecd9
The tool currently supports various popular image matching algorithms, namely:
| Algorithm | Supported | Conference/Journal | Year | GitHub Link |
|------------------|-----------|--------------------|------|-------------|
| MINIMA | β
| ARXIV | 2024 | [Link](https://github.com/LSXI7/MINIMA) |
| XoFTR | β
| CVPR | 2024 | [Link](https://github.com/OnderT/XoFTR) |
| EfficientLoFTR | β
| CVPR | 2024 | [Link](https://github.com/zju3dv/EfficientLoFTR) |
| MASt3R | β
| CVPR | 2024 | [Link](https://github.com/naver/mast3r) |
| DUSt3R | β
| CVPR | 2024 | [Link](https://github.com/naver/dust3r) |
| OmniGlue | β
| CVPR | 2024 | [Link](https://github.com/Vincentqyw/omniglue-onnx) |
| XFeat | β
| CVPR | 2024 | [Link](https://github.com/verlab/accelerated_features) |
| RoMa | β
| CVPR | 2024 | [Link](https://github.com/Vincentqyw/RoMa) |
| DeDoDe | β
| 3DV | 2024 | [Link](https://github.com/Parskatt/DeDoDe) |
| Mickey | β | CVPR | 2024 | [Link](https://github.com/nianticlabs/mickey) |
| GIM | β
| ICLR | 2024 | [Link](https://github.com/xuelunshen/gim) |
| ALIKED | β
| ICCV | 2023 | [Link](https://github.com/Shiaoming/ALIKED) |
| LightGlue | β
| ICCV | 2023 | [Link](https://github.com/cvg/LightGlue) |
| DarkFeat | β
| AAAI | 2023 | [Link](https://github.com/THU-LYJ-Lab/DarkFeat) |
| SFD2 | β
| CVPR | 2023 | [Link](https://github.com/feixue94/sfd2) |
| IMP | β
| CVPR | 2023 | [Link](https://github.com/feixue94/imp-release) |
| ASTR | β | CVPR | 2023 | [Link](https://github.com/ASTR2023/ASTR) |
| SEM | β | CVPR | 2023 | [Link](https://github.com/SEM2023/SEM) |
| DeepLSD | β | CVPR | 2023 | [Link](https://github.com/cvg/DeepLSD) |
| GlueStick | β
| ICCV | 2023 | [Link](https://github.com/cvg/GlueStick) |
| ConvMatch | β | AAAI | 2023 | [Link](https://github.com/SuhZhang/ConvMatch) |
| LoFTR | β
| CVPR | 2021 | [Link](https://github.com/zju3dv/LoFTR) |
| SOLD2 | β
| CVPR | 2021 | [Link](https://github.com/cvg/SOLD2) |
| LineTR | β | RA-L | 2021 | [Link](https://github.com/yosungho/LineTR) |
| DKM | β
| CVPR | 2023 | [Link](https://github.com/Parskatt/DKM) |
| NCMNet | β | CVPR | 2023 | [Link](https://github.com/xinliu29/NCMNet) |
| TopicFM | β
| AAAI | 2023 | [Link](https://github.com/Vincentqyw/TopicFM) |
| AspanFormer | β
| ECCV | 2022 | [Link](https://github.com/Vincentqyw/ml-aspanformer) |
| LANet | β
| ACCV | 2022 | [Link](https://github.com/wangch-g/lanet) |
| LISRD | β | ECCV | 2022 | [Link](https://github.com/rpautrat/LISRD) |
| REKD | β | CVPR | 2022 | [Link](https://github.com/bluedream1121/REKD) |
| CoTR | β
| ICCV | 2021 | [Link](https://github.com/ubc-vision/COTR) |
| ALIKE | β
| TMM | 2022 | [Link](https://github.com/Shiaoming/ALIKE) |
| RoRD | β
| IROS | 2021 | [Link](https://github.com/UditSinghParihar/RoRD) |
| SGMNet | β
| ICCV | 2021 | [Link](https://github.com/vdvchen/SGMNet) |
| SuperPoint | β
| CVPRW | 2018 | [Link](https://github.com/magicleap/SuperPointPretrainedNetwork) |
| SuperGlue | β
| CVPR | 2020 | [Link](https://github.com/magicleap/SuperGluePretrainedNetwork) |
| D2Net | β
| CVPR | 2019 | [Link](https://github.com/Vincentqyw/d2-net) |
| R2D2 | β
| NeurIPS | 2019 | [Link](https://github.com/naver/r2d2) |
| DISK | β
| NeurIPS | 2020 | [Link](https://github.com/cvlab-epfl/disk) |
| Key.Net | β | ICCV | 2019 | [Link](https://github.com/axelBarroso/Key.Net) |
| OANet | β | ICCV | 2019 | [Link](https://github.com/zjhthu/OANet) |
| SOSNet | β
| CVPR | 2019 | [Link](https://github.com/scape-research/SOSNet) |
| HardNet | β
| NeurIPS | 2017 | [Link](https://github.com/DagnyT/hardnet) |
| SIFT | β
| IJCV | 2004 | [Link](https://docs.opencv.org/4.x/da/df5/tutorial_py_sift_intro.html) |
## How to use
### HuggingFace / Lightning AI
Just try it on <a href='https://huggingface.co/spaces/Realcat/image-matching-webui'><img src='https://img.shields.io/badge/%F0%9F%A4%97%20Hugging%20Face-Spaces-blue'></a>
<a target="_blank" href="https://lightning.ai/realcat/studios/image-matching-webui">
<img src="https://pl-bolts-doc-images.s3.us-east-2.amazonaws.com/app-2/studio-badge.svg" alt="Open In Studio"/>
</a>
or deploy it locally following the instructions below.
### Requirements
- [Python 3.9+](https://www.python.org/downloads/)
#### Install from pip [NEW]
Update: now support install from [pip](https://pypi.org/project/imcui), just run:
```bash
pip install imcui
```
#### Install from source
``` bash
git clone --recursive https://github.com/Vincentqyw/image-matching-webui.git
cd image-matching-webui
conda env create -f environment.yaml
conda activate imw
pip install -e .
```
or using [docker](https://hub.docker.com/r/vincentqin/image-matching-webui):
``` bash
docker pull vincentqin/image-matching-webui:latest
docker run -it -p 7860:7860 vincentqin/image-matching-webui:latest python app.py --server_name "0.0.0.0" --server_port=7860
```
### Deploy to Railway
Deploy to [Railway](https://railway.app/), setting up a `Custom Start Command` in `Deploy` section:
``` bash
python -m imcui.api.server
```
### Run demo
``` bash
python app.py --config ./config/config.yaml
```
then open http://localhost:7860 in your browser.

### Add your own feature / matcher
I provide an example to add local feature in [imcui/hloc/extractors/example.py](imcui/hloc/extractors/example.py). Then add feature settings in `confs` in file [imcui/hloc/extract_features.py](imcui/hloc/extract_features.py). Last step is adding some settings to `matcher_zoo` in file [imcui/ui/config.yaml](imcui/ui/config.yaml).
### Upload models
IMCUI hosts all models on [Huggingface](https://huggingface.co/Realcat/imcui_checkpoints). You can upload your model to Huggingface and add it to the [Realcat/imcui_checkpoints](https://huggingface.co/Realcat/imcui_checkpoints) repository.
## Contributions welcome!
External contributions are very much welcome. Please follow the [PEP8 style guidelines](https://www.python.org/dev/peps/pep-0008/) using a linter like flake8. This is a non-exhaustive list of features that might be valuable additions:
- [x] support pip install command
- [x] add [CPU CI](.github/workflows/ci.yml)
- [x] add webcam support
- [x] add [line feature matching](https://github.com/Vincentqyw/LineSegmentsDetection) algorithms
- [x] example to add a new feature extractor / matcher
- [x] ransac to filter outliers
- [ ] add [rotation images](https://github.com/pidahbus/deep-image-orientation-angle-detection) options before matching
- [ ] support export matches to colmap ([#issue 6](https://github.com/Vincentqyw/image-matching-webui/issues/6))
- [x] add config file to set default parameters
- [x] dynamically load models and reduce GPU overload
Adding local features / matchers as submodules is very easy. For example, to add the [GlueStick](https://github.com/cvg/GlueStick):
``` bash
git submodule add https://github.com/cvg/GlueStick.git imcui/third_party/GlueStick
```
If remote submodule repositories are updated, don't forget to pull submodules with:
``` bash
git submodule update --init --recursive # init and download
git submodule update --remote # update
```
if you only want to update one submodule, use `git submodule update --remote imcui/third_party/GlueStick`.
To format code before committing, run:
```bash
pre-commit run -a # Auto-checks and fixes
```
## Contributors
<a href="https://github.com/Vincentqyw/image-matching-webui/graphs/contributors">
<img src="https://contrib.rocks/image?repo=Vincentqyw/image-matching-webui" />
</a>
## Resources
- [Image Matching: Local Features & Beyond](https://image-matching-workshop.github.io)
- [Long-term Visual Localization](https://www.visuallocalization.net)
## Acknowledgement
This code is built based on [Hierarchical-Localization](https://github.com/cvg/Hierarchical-Localization). We express our gratitude to the authors for their valuable source code.
[contributors-shield]: https://img.shields.io/github/contributors/Vincentqyw/image-matching-webui.svg?style=for-the-badge
[contributors-url]: https://github.com/Vincentqyw/image-matching-webui/graphs/contributors
[forks-shield]: https://img.shields.io/github/forks/Vincentqyw/image-matching-webui.svg?style=for-the-badge
[forks-url]: https://github.com/Vincentqyw/image-matching-webui/network/members
[stars-shield]: https://img.shields.io/github/stars/Vincentqyw/image-matching-webui.svg?style=for-the-badge
[stars-url]: https://github.com/Vincentqyw/image-matching-webui/stargazers
[issues-shield]: https://img.shields.io/github/issues/Vincentqyw/image-matching-webui.svg?style=for-the-badge
[issues-url]: https://github.com/Vincentqyw/image-matching-webui/issues
|