Skip to main content

A package to get thermal information out of FLIR radiometric JPGs

Project description

Flir Image Extractor

FLIR® thermal cameras like the FLIR ONE® include both a thermal and a visual light camera. The latter is used to enhance the thermal image using an edge detector.

The resulting image is saved as a jpg image but both the original visual image and the raw thermal sensor data are embedded in the jpg metadata.

This small Python tool/library allows to extract the original photo and thermal sensor values converted to temperatures.

Requirements and Install

This tool relies on exiftool. It should be available in most Linux distributions (e.g. as perl-image-exiftool in Arch Linux or libimage-exiftool-perl in Debian and Ubuntu). Links for downloading the Mac version and more information is available on the ExifTool site.

It also requires other python packages, matplotlib, numpy and pillow, which are installed when installed through pip.

sudo apt update
sudo apt install exiftool
pip install flirimageextractor

Usage

Example

import flirimageextractor
from matplotlib import cm

flir = flirimageextractor.FlirImageExtractor(palettes=[cm.jet, cm.bwr, cm.gist_ncar])
flir.process_image('examples/ax8.jpg')
flir.save_images()
flir.plot()

This script will show an interactive plot of the thermal image using matplotlib and save three image files ax8_thermal_jet.jpg, ax8_thermal_bwr.jpg, and ax8_thermal_gist_ncar.jpg.

Resulting Plot and Saved Images

Plot

Python 2019-05-17 at 14 14 57

Saved Images

ax8_thermal_jet ax8_thermal_bwr ax8_thermal_gist_ncar

The original temperature array is available using either the get_thermal_np or export_thermal_to_csv functions.

The function check_for_thermal_image will check the metadata of the image to see if it contains thermal information.

The functions get_rgb_np and get_thermal_np yield numpy arrays and can be called from your own script after importing this library.

The function save_image saves the thermal image(s) in the same folder as the original image. By default it will output three images using the bwr, gnuplot, and gist_ncar colormaps from matplotlib. You can define the pallete(s) that you would rather use when creating the class (see example). For a list of available matplotlib colormaps click here. save_images(self, min=5, max=100) can be used to set global minimum and maximum temperature values so that multiple images can be process with the same scale.

Supported/Tested cameras:

  • Flir One (thermal + RGB)
  • Xenmuse XTR (thermal + thumbnail, set the subject distance to 1 meter)
  • AX8 (thermal + RGB)

Other cameras might need some small tweaks (the embedded raw data can be in multiple image formats)

Credits

Raw value to temperature conversion is ported from this R package: https://github.com/gtatters/Thermimage/blob/master/R/raw2temp.R Original Python code from: https://github.com/Nervengift/read_thermal.py

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

flirimageextractor-1.2.2.tar.gz (6.1 kB view details)

Uploaded Source

Built Distribution

flirimageextractor-1.2.2-py3-none-any.whl (10.7 kB view details)

Uploaded Python 3

File details

Details for the file flirimageextractor-1.2.2.tar.gz.

File metadata

  • Download URL: flirimageextractor-1.2.2.tar.gz
  • Upload date:
  • Size: 6.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/2.7.16

File hashes

Hashes for flirimageextractor-1.2.2.tar.gz
Algorithm Hash digest
SHA256 53a4c91f0c34429f19a4295cf182a82756b300a0542e0e2c24a0902d9c322ef7
MD5 406f50ad419da21b491d5cde5eacc4d2
BLAKE2b-256 b00a68a6755372b856a8ca576f78c0110570962fcd581ee814e3b759efed0c74

See more details on using hashes here.

Provenance

File details

Details for the file flirimageextractor-1.2.2-py3-none-any.whl.

File metadata

  • Download URL: flirimageextractor-1.2.2-py3-none-any.whl
  • Upload date:
  • Size: 10.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/2.7.16

File hashes

Hashes for flirimageextractor-1.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 524bc328f38d34c5e74ac13b2739427fc57648e8de9320f8460b45fcbc27247f
MD5 a33511851129658f083daace85c47149
BLAKE2b-256 8ffd666ea025556e26a226bec37145e47a102476aa683ebb45556fbf69ab7ecd

See more details on using hashes here.

Provenance

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