Skip to main content

Tools for scanning tire tread(s).

Project description

treadscan

PyPI version Documentation Status Downloads

This package provides utilities for extracting tire tread (pattern) from images, or even from video of passing cars.

treadscan

Three main classes are
Detector - picks out stopped cars from continoous footage (like at an intersection, under a traffic light).
Segmentor - finds ellipse defining car wheel in image (using image segmentation techniques).
Extractor - creates a tire model from the ellipse, then "unwraps" the tire tread (or rather part of the tire tread, as only about a quarter of the tread is visible).

Currently Segmentor works correctly only if the car has bright wheels (rims). But there is a way to also extract tire tread from images where this detection method fails, by manual input. In the extras folder, there is another module annotator.py containing the Annotator class and the script manual_annotation.py which uses it. The script manual_annotation.py takes an image as input, which it then allows the user to manually annotate.
The user places specific points over the image, which in turn creates the car wheel and tire model, from which the tire tread is then extracted as usual.

manual annotation

This GUI utilises the OpenCV window, using mouse position and keyboard input to place the points. So to place a point, user can hover over a location and press a specific key, or hold the key while dragging with the mouse.
The points which have to be placed manually are:

  • T - top of car wheel (not the tire but the rim)
  • B - bottom of car wheel
  • R - right (or left) side

These 3 points form an ellipse, which defines the location of car wheel in image (red ellipse in the above image). Then the tire model is extrapolated from that, or can be further modified using the optional points:

  • O - move outer tire ellipse (left yellow ellipse)
  • S - tire sidewall height (height of yellow ellipses)
  • W - tire width (move inner tire ellipse, right yellow ellipse)
  • U - top of tread extraction (starting angle, top of green rectangle)
  • I - bottom of tread extraction (ending angle, bottom of green rectangle)

Pressing SPACEBAR shows preview of extracted tread, BACKSPACE hides this preview. Pressing ENTER saves full size extracted tread as new image. Closing the window or pressing ESCAPE closes the window.

Additionally the treadscan_script.py in the extras folder can process footage (folder of images/video/stream) and extract the tread of each car from the footage. It has 3 modes: manual (user annotates each manually), semiauto (user annotates only those where Segmentor fails) and auto (images where Segmentor fails are discarded). Extracted treads are saved to a folder.

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

treadscan-0.4.0.tar.gz (23.9 kB view details)

Uploaded Source

Built Distribution

treadscan-0.4.0-py3-none-any.whl (24.6 kB view details)

Uploaded Python 3

File details

Details for the file treadscan-0.4.0.tar.gz.

File metadata

  • Download URL: treadscan-0.4.0.tar.gz
  • Upload date:
  • Size: 23.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/33.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.8 tqdm/4.63.0 importlib-metadata/4.11.2 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.8.12

File hashes

Hashes for treadscan-0.4.0.tar.gz
Algorithm Hash digest
SHA256 92c8daad3b196cf3ceb6616d7e5e590bbeaab5746d3f064f70f971b90aa5eb50
MD5 d6c8000189eade3d7ed38097bd396cd2
BLAKE2b-256 d40533d499480dc0288e9716478e1a006026a3ae6b78985a3dba5cf36e2968b6

See more details on using hashes here.

File details

Details for the file treadscan-0.4.0-py3-none-any.whl.

File metadata

  • Download URL: treadscan-0.4.0-py3-none-any.whl
  • Upload date:
  • Size: 24.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/33.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.8 tqdm/4.63.0 importlib-metadata/4.11.2 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.8.12

File hashes

Hashes for treadscan-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 7fe08b6cf2eadd46e5025e896ff3250a32f57583f52340f566b8797282a1ec85
MD5 48d28073be992e2c3427fe83d88096dd
BLAKE2b-256 ca486a846504490738e6b3e02921962f3e1237d26c0cfe0a40f0aa88a8e3c071

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page