Create fastFLIM images from PicoQuant PTU files.
Figure 1, Example of a 1 channel fastFLIM converted image, of cells labelled with FluoVolt dye, that shows change in lifetime, Shep2 cell made by E. de Jong PhD..
The main purpose of the fastFLIM script is one can convert by batch multiple PTU files, or a folder with PTU files, and get a series Fluorescent fastFLIM images with minimal user input. This is usefull for screening results during imaging and to be used in presentations. FastFLIM calculates the average arrival time, which is a fast method to get a fluorescent lifetime information for image with low photon counts per pixel, which is typical for TCSPC methods.
A PicoQuant microscope MT200 with FLIMbee scanner.
The script is developed and tested on Python 3.11, Install:
- wx python 4.2.1 for the file selector app.
- imageIO
- matplotlib-scalebar
- updated readPTU_FLIM-bidirect version is inlcuded, source PTU file reader
- File Check, if it is a 2D image.
- Autodetects the number of APD channels, and laser lines used.
- Supports 'normal' and 'PIE' excitation, one can set channel Timegate.
- fastFLIM/rapidFLIM Conversion.
- Optional: binning Image pixels .
- Optional: channel_binning Combine TCSPC of multiple SPAD's into channel 1.
- Optional: TCSPC_PIE_Start_ns include timebins from ns.
- Optional: TCSPC_PIE_End_ns exclude timebins from ns.
- Optional: clean_imsave saves clean TIF images and datafiles.
- Optional: Save_tiff_LTstack saves a tiff stack for the selected channel(s) and TimeGates. 2D Int(timebins)
- Optinal: FLIM_Database_NPZ to speed-up processing multipl times same file, ptu→flim datastack arrtay is saved as npz and reused at next run.
- Any File-errors are catched and reported in the end.
Figure 2: command line PTU file experiment setitings summary
Put the 2D_PicoQuant_fastFLIM.py and readPU_FLUM_bidirect.py files in the sample folder, preferable with you .sptw datafolder. Open 2D_PicoQuant_fastFLIM in a python editor such as Spyder. The File readPTU_FLIM_bidirect is modified from https://github.com/RobertMolenaar-UT/readPTU_FLIM and expanded with bidirection line-offset correction, subpixel shift correction is set by bi-direct variable.
- Set the Channel configuration according optical setup.
Detector Channels need to be configured: Config1 = Set_Channel_Info(1, 'Namelabel', Brighter=1.2, PIE_TimeGate=1, ch_irf=2.55)
- Namelabel: name of the used dye or sample.
- Brigther: intensity is maximum scaled, increasing brightness helps visibility.
- PIE TimeGate: Contrast can be enhanced by using Pulsed Interlieved Excitation in the measurment to supress any cross-excitation.
- ch_irf: instrument response, channel specific time offset.
- Read and set all options in the section -- USER input -- upon description.
- Run 2D_PicoQuant_fastFLIM.py.
- Note the pop-up window in the taskbar and browse and select the PTU files.
- Next the *.PTU files are proccessed, and images are shown in the command line. (for large PTU file size it can take time to proccess)
- Images and data files are saved in folder /Python_converted_TAC-range_* Username* /
- Errors on files are listed at the end.
The countrate in FLIM should not exceed 10-20%, FLIM_sync_limit shows the 20% count limit value.
- Summary Intensity plus FLIM image. Figure1
- Optional clean_imsave, saves a clean, FLIM and Intensity TIF file for each channel.
- Optional Save_tiff_stack, saves a tiffstack: 2D image stack, slices are the timebin, used for FLUTE phasor post analysis.
- Optional Save_data_files, saves a csv data of intensity and Tavg lifetimes.
- File sizes > 1GB use a lot of Memory. 32GB or higher is recommended for 1GB PTU files.
- Multiframe PTU conversion appears to skip a Frame, modification needed in the readPTU_FLIM code. aug '24
Script is used on a Picoquant MT200 with FLIMBEE laserscanner with 4x SPAD detectors and a multiharp 150N. v1.1 - 28 November 2024 Robert Molenaar ©.
2D_PicoQuant_fastFLIM update v1.0 → v1.1
- Included saving Flim_data_stack database
- Enhanced bi-directional scanning pixel shift from pixel to subpixel correction
- Maximum countrate (sync limit) is marked in the intensity scale
- Updated experimental settings overview
readPTU_FLIM_bidirect
- Modified bi-directional pixel shift to subpixel pixelshift, moved bi-shift entry from init to get_FLIM_data_stack()
- wx 'GUI_select_Multi_file' app prompts to select (multiple) *.PTU files.
- The main For-loop proccesses all files sequentially.
- The PTU file is read by "ptu_file = PTUreader((path), print_header_data = False)"
- File is checked if it's a 2D image file:
- The PTU file is converted "flim_data_stack, intensity_image = ptu_file.get_flim_data_stack()"
- FLIM data stack is checked for avaialbe channels 'ch_list, ch_listst=Channels_list(flim_data_stack)'
- Option: with pixel binning set to 2 or higher, FLIM data stack is reshaped.
- If 'PIE'exication is used, Timegates are calcualted.
- For each channel, FLIM data is converted for the current channel and timegates from the FLIM data stack
- For each channel, Colour map is applied on the FLIM data, based on the Tau min & max.
- Option. Tav and intensity csv data is saved.
- Figure is plotted.
- Option FLIM image and Intensity tif image is saved.
- Option, FLIM images from multiple channels can be overlapped by overlap_FLIMchannels.
Figure 3: Example of 3 colours BPAE, Fluorescent colors overlay made with PicoQuant-multi channel screen, and FLIM with this fastFLIM script.