flirpy is a Python library to interact with FLIR thermal imaging cameras and images.
It aims to be a one-stop-shop to:
- Interact and query cameras via serial
- Capture raw images
- Convert FLIR file formats (e.g. seq, fff, tmc, tfc) to geotagged readable images
- Convert raw images to radiometric images
- Extract and plot GPS traces from image sequences (e.g. from drones)
The library has been tested with:
- FLIR Tau (serial only)
- FLIR Boson (serial and image capture)
- FLIR Duo Pro R (image post-processing)
- TeAx Fusion Zoom (image post-processing)
Support for the Lepton is coming soon, but will probably be limited to the Raspberry Pi for the time being.
It is strongly recommended that you use Python 3. I have put some effort into making sure that the library is back-compatible with Python 2, since there are several use-cases (like ROS) where it's important. However, there may be bugs and as Python 2 is EOL in 2020, this is a low priority.
The library is organised into logical sections:
flirpy.camera
contains classes to communicate with FLIR camera cores directlyflirpy.io
contains claseses to deal with thermal image formatsflirpy.util
contains helper functions e.g. raw conversion
Flirpy includes a convenience utility split_seqs
for splitting FLIR sequence (SEQ) files.
Once installed, you can run:
$ split_seqs -h
usage: split_seqs [-h] [-o OUTPUT] -i INPUT [-v VERBOSITY]
Split all files in folder.
optional arguments:
-h, --help show this help message and exit
-o OUTPUT, --output OUTPUT
Output folder
-i INPUT, --input INPUT
Input file mask
-v VERBOSITY, --verbosity VERBOSITY
Logging level
split_seqs
accepts either a directory, a specific filename, or a wildcard string (e.g. "./my/data/flight_*.SEQ"
). If you use wildcards, be sure to enclose the argument in quotes, otherwise your shell will expand the wildcard before running the program and confuse it. If you specify a directoy, all SEQ files in that diretory will be used.
Files will be extracted to folders with the same base name as the SEQ file, for example 20180101_1030.SEQ
will be extracted to 20180101_1030
, etc. By default the splitter will three kinds of files, separated by subfolder.
- Raw (FFF) files with metadata text files
- Radiometric 16-bit tiff images
- Preview 8-bit RGB representations of the radiometric data
The tiff images will be geotagged if GPS information is present in the raw data.
Output images are numbered. If SEQ file 1 contains 1800 frames, the first frame from SEQ file 2 will be numbered 1800.
Flirpy has been tested with Python 3 and may work on Python 2. It is always recommended that you install packages inside a virtualenv or Conda environment.
Either install using pip
:
pip install flirpy
Or:
python setup.py install
flirpy is distributed with a copy of Exiftool which is used to extract metadata from certain file formats.
Flirpy mostly works well, and has been tested, on the Raspberry Pi. If you're building from scratch, you need to install a few things manually. Try to use Python 3 if you can.
It's recommended that you first install the Python dependencies using pip
in combination with piwheels. For whatever reason, setuptools
does not find these files, so it will fail if e.g. OpenCV isn't installed already. Once you've set up piwheels (it should be automatic on Raspbian if you've installed pip3) run:
pip3 install -r requirements.txt
You may need to install some dependencies for OpenCV, for example libjasper-dev
.
You should also install Exiftool manually with sudo apt install exiftool
.
To run the test suite:
pip install pytest pytest-cov
pytest --cov=flirpy test
Some tests are hardware dependent, e.g. for cameras, so expect them to fail unless you own and have a camera to try them with. Hardware tests are skipped by default if the requisite camera is not plugged in.
The repository includes some small representative examples of image files (e.g. SEQ). It is tested and is routinely used with flight data from FLIR Duo cameras, so larger files aren't a problem, but they're too large to include in the repository.
If you're testing on Python 2:
pip install pytest pytest-cov backports.tempfile
pytest --cov=flirpy test