openexr-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Openexr-devel] Problem with deep data


From: Richard Hadsell
Subject: Re: [Openexr-devel] Problem with deep data
Date: Fri, 20 Apr 2018 14:50:39 -0400
User-agent: Mozilla/5.0 (X11; Linux x86_64; rv:31.0) Gecko/20100101 Thunderbird/31.5.0

Your last suggestion was most helpful.  I had already examined the pointers and strides, set the part to NO_COMPRESSION, and generated only 1 sample per pixel, but I had not tried it with tiny images.

I found that an image with a single scanline and up to 256 pixels was okay.  However, 257 pixels resulted in the first pixel (pix[0]) having junk and the other pixels being shifted, so that pix[1-256] had the values that should have been in pix[0-255].  This was the result from reading the file.

Using 'od' to look at the file showed that the last float in the file was, indeed, the sample for pix[256].  Maybe the write was okay, but the read was not.

(Testing with 258 pixels in the scanline resulted in bad data for pix[0-1], and values in pix[2-257] were the samples that should have been in pix[0-255].)

For the test with 257 pixels, I looked at the data in TotalView and saw that readPtr, as calculated in line 673 of ImfDeepScanLineInputFile.cpp, points to floats that correspond to the samples that are bad.  The first float is junk, and the next 256 samples are those that should have been in pix[0-255].  The float after that was 0, not the value that should have been in pix[256], so I conclude that the data in the buffer were not read correctly from the file.

Of course, I don't know enough about the layout of data in the file to know whether the problem is in reading or writing.  I can see that the samples are there in the file, but maybe they are in the wrong place.

I hope this is enough information for someone to duplicate the problem.  I don't think I can take it any farther myself.

On 04/19/2018 06:36 PM, Peter Hillman wrote:

Hi Richard,

It may also be instructive to confirm the library built correctly by building and running the IlmImfTest suite. Running IlmImfTest with "deep" as an argument will run only the deep tests.

The source code of those tests should provide further examples of how to read/write deep data. The different tests intentionally use slightly different approaches to read/write data. You might modify one of those tests to disable the file cleanup, which would generate a deep file you can read with your own code, and compare to the known values written into the file.

Are you getting the correct sample counts but entirely incorrect data? That would suggest you have the pointer-to-arrays pointing to the wrong memory locations. If some of the values are correct (e.g. only the first pixel in the image, only the first pixel on each row, or only the first sample of each pixel) that would suggest the pointers are correct, but the yPixelStride,xPixelStride,sampleStride (respectively) values are wrong.

Try writing a small amount of 32 bit float data (e.g. a 2x2 pixel image with 1 channel) with compression set to NO_COMPRESSION and check the file contents in a hex editor: the last 4 bytes of the file should be the last sample of the last pixel of the last channel in the file. That might tell you whether you are writing the file correctly


-- 
Dick Hadsell			203-992-6320  Fax: 203-992-6001
Reply-to:			address@hidden
Blue Sky Studios                http://www.blueskystudios.com
1 American Lane, Greenwich, CT 06831-2560

reply via email to

[Prev in Thread] Current Thread [Next in Thread]