Matplotlib-based tool for labeling the two-view correspondences
Project description
pyxelstitch
Simple, matplotlib based tool for hand-labeling the two-image correspondences
Install
pip install pixelstitch
How to use
Let's test our annotator on a sample project. It needs a list of triplets: (path_to_img1
, path_to_img2
, path_to_corrs_to_save
).
import os
rootdir = 'sample_project'
pairs = os.listdir(rootdir)
img_pairs_list = []
for p in pairs:
if p == '.DS_Store':
continue
cur_dir = os.path.join(rootdir, p)
img_pairs_list.append((os.path.join(cur_dir, '01.png'),
os.path.join(cur_dir, '02.png'),
os.path.join(cur_dir, 'corrs.txt')))
print (img_pairs_list)
[('sample_project/ministry/01.png', 'sample_project/ministry/02.png', 'sample_project/ministry/corrs.txt'), ('sample_project/petrzin/01.png', 'sample_project/petrzin/02.png', 'sample_project/petrzin/corrs.txt')]
/opt/homebrew/Caskroom/miniforge/base/envs/python39/lib/python3.9/site-packages/ipykernel/ipkernel.py:283: DeprecationWarning: `should_run_async` will not call `transform_cell` automatically in the future. Please pass the result to `transformed_cell` argument and any exception that happen during thetransform in `preprocessing_exc_tuple` in IPython 7.17 and above.
and should_run_async(code)
Now we are ready to initialize CorrespondenceAnnotator
. Don't forget to declare magic command %matplotlib widget
.
WITHOUT MAGIC IT WOULD NOT WORK
You also should explicitly specify, if you want to save (and possibly over-write previous better annotation) current correspondences automatically when clicking on prev and next buttons for going to the next pair.
%matplotlib widget
from pixelstitch.core import *
CA = CorrespondenceAnnotator(img_pairs_list, save_on_next=True)
/opt/homebrew/Caskroom/miniforge/base/envs/python39/lib/python3.9/site-packages/ipykernel/ipkernel.py:283: DeprecationWarning: `should_run_async` will not call `transform_cell` automatically in the future. Please pass the result to `transformed_cell` argument and any exception that happen during thetransform in `preprocessing_exc_tuple` in IPython 7.17 and above.
and should_run_async(code)
Now we can run the annotation.
Left-click on the image to add a point
right-click -- to remove the point from both images.
Matplotlib shortcuts:
- o for zoom
- p for pan (move)
It is also recommended to set full page width for the jupyter
%matplotlib widget
from IPython.core.display import display, HTML
display(HTML("<style>.container { width:95% !important; }</style>"))
CA.start(figsize=(12,7))
Controls
Selectors
Model
. One can select between "F
" -- fundamental matrix and "H
" -- homography. The selection influences the reprojection error type, and the visualization of the models and reprojection errors, shown when clicked onNextCorrsValPoint
,NextCorrsValAll
andShowModel
buttons.
Buttons
-
NextCorrsValPoint
. Shows the correspondence in the bottom axis. The image title shows correspondence index and the reprojection error. IfModel
isF
, it will show induced epipolar line, ifH
-- the position of the reprojected point from other image. The model is estimated with all other correspondences except current one. -
NextCorrsValAll
. Shows the correspondences in the bottom axis. Similar toNextCorrsValPoint
button, but shows all points. The model is estimated with all correspondences except current one, which index is shown in the title. -
ShowModel
. Has different behavoir depending on theModel
selected. ForF
-- shows correspondences with their induced epipolar lines. UnlikeNextCorrsValPoint
andNextCorrsValPoint
all correspondences are used for model estimation. -
For
H
, the button shows overlay of image 1 reprojected into image2 with image2. The reprojected area is defined by the convex hull of the labelled correspondences. Next click flips the order, i.e. shows the image 2 reprojected into image 1. -
Save points
-- saves (overwrites) the correspondences into the text file. -
Prev
-- Loads and shows previous image pair to label. If theCorrespondenceAnnotator
was initialized withsave_on_next=True
, the current pair correspondences are saved before the switch. Change is not cyclical, so the button does nothing on 1st image pair -
Next
-- Loads and shows next image pair to label. If theCorrespondenceAnnotator
was initialized withsave_on_next=True
, the current pair correspondences are saved before the switch.Change is not cyclical, so the button does nothing on last image pair. -
CLAHE
-- Images are shown with enhanced contrast with CLAHE algorithm. -
Pick 4 points for homography
-- Special mode. User picks 4 points in one image, which define new fronto-parallel view. This mode helps for labeling obscure views, see example below. The order of the points: top-left -> top-right -> bottom right -> bottom left. After the 4 point picked, the mode is switched off, so user needs to click the button again if she wants to rectify another image. -
ResetView
-- Resets any recifications or zoom done to images.
Rectification picking mode example
3 points are selected
All points are selected and image1 is rectified to the rectangle, defined by the selected points
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file pixelstitch-0.1.5.tar.gz
.
File metadata
- Download URL: pixelstitch-0.1.5.tar.gz
- Upload date:
- Size: 22.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.8.18
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7d5c9596153b1e05ec36ed0433b1203137ac954b1cab5d6c3ac9c6829c62f166 |
|
MD5 | dc37b6d20b491f847bce22e5161891fd |
|
BLAKE2b-256 | d0621e40420b1eeb4f2c4c8cbecd4d41ddffdfbac7275c56a46c91bc6aef1962 |
File details
Details for the file pixelstitch-0.1.5-py3-none-any.whl
.
File metadata
- Download URL: pixelstitch-0.1.5-py3-none-any.whl
- Upload date:
- Size: 20.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.8.18
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2e1e9d9248fcb624de46547283625f0a71035827dd7518b64ea66f09154d9e1b |
|
MD5 | 5272de6b0cb6595a7213e60d5ff1587c |
|
BLAKE2b-256 | 1a83bf7923aaf791b6a4e671f71570fa56d50be4c0ef2dc8aced1685462e0531 |