We're Hiring!

Bioformats: Fastest way to get RGB of an extra large image

Historical discussions about the Bio-Formats library. Please look for and ask new questions at https://forum.image.sc/tags/bio-formats
Please note:
Historical discussions about the Bio-Formats library. Please look for and ask new questions at https://forum.image.sc/tags/bio-formats

If you are having trouble with image files, there is information about reporting bugs in the Bio-Formats documentation. Please send us the data and let us know what version of Bio-Formats you are using. For issues with your code, please provide a link to a public repository, ideally GitHub.

Bioformats: Fastest way to get RGB of an extra large image

Postby kazak » Wed Nov 26, 2014 12:06 pm

Hello,

I'm using Bioformats and ImageJ to process extra large images (~75000 x 75000 px) such as .vsi extension. I currently use imp = BF.openImagePlus(options)[0]; with crop options. Then I use the method convertToRGB of the ImageConverter class to convert the ImagePlus and getRGB method of the ColorProcessor class to retrieve the RGB values.

My problem is that the conversion process seems very time consuming, whereas I don't really need this ImagePlus but only the RGB arrays.

I wondered what would be the fastest (minimal) way to scan any type of image format, tile by tile, and for each tile retrieving only the RGB arrays?

Best regards

Gilles
kazak
 
Posts: 5
Joined: Fri Oct 03, 2014 5:44 pm

Re: Bioformats: Fastest way to get RGB of an extra large ima

Postby bramalingam » Fri Nov 28, 2014 3:29 pm

Hi,

The Bio-Formats macro extensions for ImageJ, are limited in their coverage.
So to get any sort of performance improvements, you should consider using the Bio-Formats API (in Jython, or etc).

If you prefer to work within the Macro world, you can try the following suggestion,

The thing that is affecting your performance is this,
imp = BF.openImagePlus(options)[0];

and you can access the backend code for the openImagePlus method here,
https://github.com/openmicroscopy/biofo ... ns/BF.java

Calling the setId method iteratively does not help your cause!

setId - "setId initializes the file set, reads all of the metadata, and sets the reader up for reading planes. for large file sets, it can be slow (several seconds to minutes)"

So using larger tile sizes to crop your images (which would mean, lesser number of setId calls) might slightly improve your performance.

Hope that helps,
Best,
Balaji
User avatar
bramalingam
 
Posts: 70
Joined: Tue Jan 14, 2014 12:01 pm

Re: Bioformats: Fastest way to get RGB of an extra large ima

Postby kazak » Mon Dec 01, 2014 10:20 am

Hi Balaji,

First thank you for your answer. I did not noticed the difference between the API and the macro extension...

I finally followed this example: https://www.openmicroscopy.org/site/sup ... xport.html with success. The reader.openBytes() does exactly what I was looking for.

It takes now about 3 seconds to read tiles of 5000 x 5000 px, and I have images in the range of 75000 x 75000 px to process. Thus, total reading time is still larger than 10 minutes. I thought about parallelization but I will have to limit the number of threads in order to avoid out of memory.

Do you have any tips to improve the reading performances?

Best regards

Gilles
kazak
 
Posts: 5
Joined: Fri Oct 03, 2014 5:44 pm

Re: Bioformats: Fastest way to get RGB of an extra large ima

Postby bramalingam » Tue Dec 02, 2014 2:06 pm

Hi,

Try the following methods to optimise your tile width and tile height parameters,

reader.getOptimalTileWidth()
reader.getOptimalTileHeight()

Incorporating the values obtained from these methods might improve your performance slightly.
Hope that helps.

Best,
Balaji
User avatar
bramalingam
 
Posts: 70
Joined: Tue Jan 14, 2014 12:01 pm

Re: Bioformats: Fastest way to get RGB of an extra large ima

Postby kazak » Mon Jan 19, 2015 5:31 pm

Hello Balaji and everyone,

I tried the reader.getOptimalTileWidth() to improve the speed of reading, without success. It seems that large tiles are faster, but there is of course the limit of the heap space memory.

Does anyone know if it is possible to map the file into memory for faster access? I see: "DEBUG loci.common.NIOByteBufferProvider - Using mapped byte buffer? false" when I run the reader and I wonder what this is?

Can someone tell me if it is feasable and where I can start?

I found also: http://downloads.openmicroscopy.org/bio ... vider.html

Actually I already tested with a ssd, but the performances are quite similar to my standard hard drive.

Gilles
kazak
 
Posts: 5
Joined: Fri Oct 03, 2014 5:44 pm

Re: Bioformats: Fastest way to get RGB of an extra large ima

Postby mtbc » Tue Jan 20, 2015 9:55 am

I believe that you can set the use of mapped byte buffers with System.setProperty("mappedBuffers", "true") or by using -DmappedBuffers=true on the Java command line. However, I believe that users have seen bugs with this mode so, if what I am saying works at all, definitely use it with caution; I'm not sure it's even supported, let alone recommended. Somebody who knows more than I should be along in due course, with better help!

Cheers,
Mark
User avatar
mtbc
Team Member
 
Posts: 282
Joined: Tue Oct 23, 2012 10:59 am
Location: Dundee, Scotland


Return to User Discussion [Legacy]

Who is online

Users browsing this forum: No registered users and 1 guest