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
treadscan.Detector - picks out stopped cars from continoous footage (like at an intersection, under a traffic light). treadscan.Segmentor - finds ellipse defining car wheel in image (using image segmentation techniques). treadscan.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).

There are 3 different ways to detect car wheels in image. Only treadscan.Segmentor is included in the treadscan package and works out of the box. This class has a major downfall and that is that it only has a chance to work correctly if the car in the image has very bright rims, which contrast enough with the tire. There is also treadscan.RCNNSegmentor which uses a region based convolutional neural network to find the car wheel in image but the treadscan package doesn't include a pre-trained model. You can however use the model included in this repository or even train your own. You will also need to install torch and torchvision libraries to use the RCNN. The last option is to annotate the image manually using a GUI script, manual_annotation.py, which is included in this folder.

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.5.0.tar.gz (25.4 kB view details)

Uploaded Source

Built Distribution

treadscan-0.5.0-py3-none-any.whl (26.2 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: treadscan-0.5.0.tar.gz
  • Upload date:
  • Size: 25.4 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.5.0.tar.gz
Algorithm Hash digest
SHA256 27efbea071c16ca431809f6f89f58cb7798e8d6e750dceda92bc81d1731a67ae
MD5 e7deb1326cd86f10e38f313644dc627d
BLAKE2b-256 8feeb68293c579374323f55b8712bad53edea5d063ba4b7e628d6f4b2a22e6fd

See more details on using hashes here.

File details

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

File metadata

  • Download URL: treadscan-0.5.0-py3-none-any.whl
  • Upload date:
  • Size: 26.2 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.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 5277ba6623660acd15d3716135e4ef6e7f62d03a0df8040de7c22abccda44699
MD5 a38903cf8630085448117df4f9524855
BLAKE2b-256 d85fcb4d4fc5587a7d2b6bd8b7ef593e041cbb5b26d27df4195782a12944f457

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