Blame IlmImfTest/testConversion.cpp

Packit Service 6754ca
//////////////////////////////////////////////////////////////////////////////
Packit Service 6754ca
//
Packit Service 6754ca
// Copyright (c) 2003-2012, Industrial Light & Magic, a division of Lucasfilm
Packit Service 6754ca
// Entertainment Company Ltd.  Portions contributed and copyright held by
Packit Service 6754ca
// others as indicated.  All rights reserved.
Packit Service 6754ca
//
Packit Service 6754ca
// Redistribution and use in source and binary forms, with or without
Packit Service 6754ca
// modification, are permitted provided that the following conditions are
Packit Service 6754ca
// met:
Packit Service 6754ca
//
Packit Service 6754ca
//     * Redistributions of source code must retain the above
Packit Service 6754ca
//       copyright notice, this list of conditions and the following
Packit Service 6754ca
//       disclaimer.
Packit Service 6754ca
//
Packit Service 6754ca
//     * Redistributions in binary form must reproduce the above
Packit Service 6754ca
//       copyright notice, this list of conditions and the following
Packit Service 6754ca
//       disclaimer in the documentation and/or other materials provided with
Packit Service 6754ca
//       the distribution.
Packit Service 6754ca
//
Packit Service 6754ca
//     * Neither the name of Industrial Light & Magic nor the names of
Packit Service 6754ca
//       any other contributors to this software may be used to endorse or
Packit Service 6754ca
//       promote products derived from this software without specific prior
Packit Service 6754ca
//       written permission.
Packit Service 6754ca
//
Packit Service 6754ca
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
Packit Service 6754ca
// IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
Packit Service 6754ca
// THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
Packit Service 6754ca
// PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
Packit Service 6754ca
// CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
Packit Service 6754ca
// EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
Packit Service 6754ca
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
Packit Service 6754ca
// PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
Packit Service 6754ca
// LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
Packit Service 6754ca
// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
Packit Service 6754ca
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Packit Service 6754ca
//
Packit Service 6754ca
//////////////////////////////////////////////////////////////////////////////
Packit Service 6754ca
Packit Service 6754ca
Packit Service 6754ca
#include <ImfOutputFile.h>
Packit Service 6754ca
#include <ImfInputFile.h>
Packit Service 6754ca
#include <ImfTiledOutputFile.h>
Packit Service 6754ca
#include <ImfTiledInputFile.h>
Packit Service 6754ca
#include <ImfChannelList.h>
Packit Service 6754ca
#include <ImfArray.h>
Packit Service 6754ca
#include <ImfConvert.h>
Packit Service 6754ca
#include <half.h>
Packit Service 6754ca
#include "compareFloat.h"
Packit Service 6754ca
Packit Service 6754ca
#include <stdio.h>
Packit Service 6754ca
#include <assert.h>
Packit Service 6754ca
Packit Service 6754ca
Packit Service 6754ca
namespace IMF = OPENEXR_IMF_NAMESPACE;
Packit Service 6754ca
using namespace IMF;
Packit Service 6754ca
using namespace std;
Packit Service 6754ca
using namespace IMATH_NAMESPACE;
Packit Service 6754ca
Packit Service 6754ca
Packit Service 6754ca
namespace {
Packit Service 6754ca
Packit Service 6754ca
//
Packit Service 6754ca
// Functions to test conversion of individual numbers
Packit Service 6754ca
//
Packit Service 6754ca
Packit Service 6754ca
void
Packit Service 6754ca
testFloatToUint (unsigned int floatVal, unsigned int uintVal)
Packit Service 6754ca
{
Packit Service 6754ca
    union {unsigned int ui; float f;} u;
Packit Service 6754ca
    u.ui = floatVal;
Packit Service 6754ca
    cout << "floatToUint (" << u.f << ") == " << floatToUint(u.f) << endl;
Packit Service 6754ca
    assert (floatToUint (u.f) == uintVal);
Packit Service 6754ca
}
Packit Service 6754ca
Packit Service 6754ca
Packit Service 6754ca
void
Packit Service 6754ca
testHalfToUint (unsigned int halfVal, unsigned int uintVal)
Packit Service 6754ca
{
Packit Service 6754ca
    half h;
Packit Service 6754ca
    h.setBits (halfVal);
Packit Service 6754ca
    cout << "halfToUint (" << h << ") == " << halfToUint(h) << endl;
Packit Service 6754ca
    assert (halfToUint (h) == uintVal);
Packit Service 6754ca
}
Packit Service 6754ca
Packit Service 6754ca
Packit Service 6754ca
void
Packit Service 6754ca
testFloatToHalf (unsigned int floatVal, unsigned int halfVal)
Packit Service 6754ca
{
Packit Service 6754ca
    union {unsigned int ui; float f;} u;
Packit Service 6754ca
    u.ui = floatVal;
Packit Service 6754ca
    cout << "floatToHalf (" << u.f << ") == " << floatToHalf(u.f) << endl;
Packit Service 6754ca
    assert (floatToHalf(u.f).bits() == halfVal);
Packit Service 6754ca
}
Packit Service 6754ca
Packit Service 6754ca
Packit Service 6754ca
void
Packit Service 6754ca
testUintToHalf (unsigned int uintVal, unsigned int halfVal)
Packit Service 6754ca
{
Packit Service 6754ca
    cout << "uintToHalf (" << uintVal << ") == " << uintToHalf(uintVal) << endl;
Packit Service 6754ca
    assert (uintToHalf(uintVal).bits() == halfVal);
Packit Service 6754ca
}
Packit Service 6754ca
Packit Service 6754ca
void
Packit Service 6754ca
testNumbers ()
Packit Service 6754ca
{
Packit Service 6754ca
    testFloatToUint (0x00000000, 0);		//  0.0
Packit Service 6754ca
    testFloatToUint (0x3f000000, 0);		// +0.5
Packit Service 6754ca
    testFloatToUint (0xbf000000, 0);		// -0.5
Packit Service 6754ca
    testFloatToUint (0x42f82000, 124);		// +124.0625
Packit Service 6754ca
    testFloatToUint (0xc2f82000, 0);		// -124.0625
Packit Service 6754ca
    testFloatToUint (0x58635fa9, 0xffffffff);	// +1.0e15
Packit Service 6754ca
    testFloatToUint (0xd8635fa9, 0);		// -1.0e15
Packit Service 6754ca
    testFloatToUint (0x7f800000, 0xffffffff);	// +infinity
Packit Service 6754ca
    testFloatToUint (0xff800000, 0);		// -infinity
Packit Service 6754ca
    testFloatToUint (0x7fffffff, 0);		//  NaN
Packit Service 6754ca
    testFloatToUint (0xffffffff, 0);		//  NaN
Packit Service 6754ca
Packit Service 6754ca
    testHalfToUint  (0x0000, 0);		//  0.0
Packit Service 6754ca
    testHalfToUint  (0x3800, 0);		// +0.5
Packit Service 6754ca
    testHalfToUint  (0xb800, 0);		// -0.5
Packit Service 6754ca
    testHalfToUint  (0x57c1, 124);		// +124.0625
Packit Service 6754ca
    testHalfToUint  (0xd7c1, 0);		// -124.0625
Packit Service 6754ca
    testHalfToUint  (0x7c00, 0xffffffff);	// +infinity
Packit Service 6754ca
    testHalfToUint  (0xfc00, 0);		// -infinity
Packit Service 6754ca
    testHalfToUint  (0x7fff, 0);		//  NaN
Packit Service 6754ca
    testHalfToUint  (0xffff, 0);		//  NaN
Packit Service 6754ca
Packit Service 6754ca
    testFloatToHalf (0x00000000, 0x0000);	//  0.0
Packit Service 6754ca
    testFloatToHalf (0x3f000000, 0x3800);	// +0.5
Packit Service 6754ca
    testFloatToHalf (0xbf000000, 0xb800);	// -0.5
Packit Service 6754ca
    testFloatToHalf (0x42f82000, 0x57c1);	// +124.0625
Packit Service 6754ca
    testFloatToHalf (0xc2f82000, 0xd7c1);	// -124.0625
Packit Service 6754ca
    testFloatToHalf (0x58635fa9, 0x7c00);	// +1.0e15
Packit Service 6754ca
    testFloatToHalf (0xd8635fa9, 0xfc00);	// -1.0e15
Packit Service 6754ca
    testFloatToHalf (0x7f800000, 0x7c00);	// +infinity
Packit Service 6754ca
    testFloatToHalf (0xff800000, 0xfc00);	// -infinity
Packit Service 6754ca
    testFloatToHalf (0x7fffffff, 0x7fff);	//  NaN
Packit Service 6754ca
    testFloatToHalf (0xffffffff, 0xffff);	//  NaN
Packit Service 6754ca
Packit Service 6754ca
    testUintToHalf  (0,          0x0000);	
Packit Service 6754ca
    testUintToHalf  (1,          0x3c00);
Packit Service 6754ca
    testUintToHalf  (124,        0x57c0);
Packit Service 6754ca
    testUintToHalf  (1000000,    0x7c00);
Packit Service 6754ca
    testUintToHalf  (0xffffffff, 0x7c00);
Packit Service 6754ca
}
Packit Service 6754ca
Packit Service 6754ca
Packit Service 6754ca
template <class T>
Packit Service 6754ca
bool
Packit Service 6754ca
isEquivalent (T t1, T t2, Compression compression)
Packit Service 6754ca
{
Packit Service 6754ca
    return t1 == t2;
Packit Service 6754ca
}
Packit Service 6754ca
Packit Service 6754ca
Packit Service 6754ca
template<>
Packit Service 6754ca
bool
Packit Service 6754ca
isEquivalent (float t1, float t2, Compression compression)
Packit Service 6754ca
{
Packit Service 6754ca
    return equivalent (t1, t2, compression);
Packit Service 6754ca
}
Packit Service 6754ca
Packit Service 6754ca
Packit Service 6754ca
template 
Packit Service 6754ca
          class InType,  PixelType InTypeTag>
Packit Service 6754ca
void
Packit Service 6754ca
testScanLineImageChannel (const char fileName[],
Packit Service 6754ca
		          int width, int height,
Packit Service 6754ca
			  Compression compression)
Packit Service 6754ca
{
Packit Service 6754ca
    cout << "scan lines, "
Packit Service 6754ca
	    "compression " << compression << ", " <<
Packit Service 6754ca
	    "output type " << OutTypeTag << ", " <<
Packit Service 6754ca
	    "input type " << InTypeTag << ":\n    " << flush;
Packit Service 6754ca
Packit Service 6754ca
    Array2D<OutType> outPixels (height, width);
Packit Service 6754ca
Packit Service 6754ca
    for (int y = 0; y < height; ++y)
Packit Service 6754ca
	for (int x = 0; x < width; ++x)
Packit Service 6754ca
	    outPixels[y][x] = x * 10 + y;
Packit Service 6754ca
Packit Service 6754ca
    {
Packit Service 6754ca
	Header hdr (width, height);
Packit Service 6754ca
Packit Service 6754ca
	hdr.compression() = compression;
Packit Service 6754ca
Packit Service 6754ca
	hdr.channels().insert ("X", 				// name
Packit Service 6754ca
			       Channel (OutTypeTag));		// type
Packit Service 6754ca
Packit Service 6754ca
	FrameBuffer fb;
Packit Service 6754ca
Packit Service 6754ca
	fb.insert ("X",						// name
Packit Service 6754ca
		   Slice (OutTypeTag,				// type
Packit Service 6754ca
		          (char *) &outPixels[0][0],		// base
Packit Service 6754ca
			  sizeof (outPixels[0][0]),		// xStride
Packit Service 6754ca
			  sizeof (outPixels[0][0]) * width));	// yStride
Packit Service 6754ca
Packit Service 6754ca
	cout << "writing " << flush;
Packit Service 6754ca
Packit Service 6754ca
	OutputFile out (fileName, hdr);
Packit Service 6754ca
	out.setFrameBuffer (fb);
Packit Service 6754ca
	out.writePixels (height);
Packit Service 6754ca
    }
Packit Service 6754ca
Packit Service 6754ca
    Array2D<InType> inPixels (height, width);
Packit Service 6754ca
Packit Service 6754ca
    {
Packit Service 6754ca
	cout << "reading " << flush;
Packit Service 6754ca
Packit Service 6754ca
	FrameBuffer fb;
Packit Service 6754ca
Packit Service 6754ca
	fb.insert ("X",						// name
Packit Service 6754ca
		   Slice (InTypeTag,				// type
Packit Service 6754ca
		          (char *) &inPixels[0][0],		// base
Packit Service 6754ca
			  sizeof (inPixels[0][0]),		// xStride
Packit Service 6754ca
			  sizeof (inPixels[0][0]) * width));	// yStride
Packit Service 6754ca
Packit Service 6754ca
	InputFile in (fileName);
Packit Service 6754ca
	in.setFrameBuffer (fb);
Packit Service 6754ca
	in.readPixels (0, height - 1);
Packit Service 6754ca
    }
Packit Service 6754ca
Packit Service 6754ca
    cout << "comparing" << flush;
Packit Service 6754ca
Packit Service 6754ca
    for (int y = 0; y < height; ++y)
Packit Service 6754ca
    {
Packit Service 6754ca
	for (int x = 0; x < width; ++x)
Packit Service 6754ca
	{
Packit Service 6754ca
	    assert (isEquivalent (inPixels[y][x],
Packit Service 6754ca
				  InType (outPixels[y][x]),
Packit Service 6754ca
				  compression));
Packit Service 6754ca
	}
Packit Service 6754ca
    }
Packit Service 6754ca
Packit Service 6754ca
    cout << endl;
Packit Service 6754ca
Packit Service 6754ca
    remove (fileName);
Packit Service 6754ca
}
Packit Service 6754ca
Packit Service 6754ca
Packit Service 6754ca
template 
Packit Service 6754ca
          class InType,  PixelType InTypeTag>
Packit Service 6754ca
void
Packit Service 6754ca
testTiledImageChannel (const char fileName[],
Packit Service 6754ca
		       int width, int height,
Packit Service 6754ca
		       Compression compression)
Packit Service 6754ca
{
Packit Service 6754ca
    cout << "tiles, "
Packit Service 6754ca
	    "compression " << compression << ", " <<
Packit Service 6754ca
	    "output type " << OutTypeTag << ", " <<
Packit Service 6754ca
	    "input type " << InTypeTag << ":\n    " << flush;
Packit Service 6754ca
Packit Service 6754ca
    Array2D<OutType> outPixels (height, width);
Packit Service 6754ca
Packit Service 6754ca
    for (int y = 0; y < height; ++y)
Packit Service 6754ca
	for (int x = 0; x < width; ++x)
Packit Service 6754ca
	    outPixels[y][x] = x * 10 + y;
Packit Service 6754ca
Packit Service 6754ca
    {
Packit Service 6754ca
	Header hdr (width, height);
Packit Service 6754ca
Packit Service 6754ca
	hdr.setTileDescription (TileDescription (67, 67, ONE_LEVEL));
Packit Service 6754ca
Packit Service 6754ca
	hdr.compression() = compression;
Packit Service 6754ca
Packit Service 6754ca
	hdr.channels().insert ("X", 				// name
Packit Service 6754ca
			       Channel (OutTypeTag));		// type
Packit Service 6754ca
Packit Service 6754ca
	FrameBuffer fb;
Packit Service 6754ca
Packit Service 6754ca
	fb.insert ("X",						// name
Packit Service 6754ca
		   Slice (OutTypeTag,				// type
Packit Service 6754ca
		          (char *) &outPixels[0][0],		// base
Packit Service 6754ca
			  sizeof (outPixels[0][0]),		// xStride
Packit Service 6754ca
			  sizeof (outPixels[0][0]) * width));	// yStride
Packit Service 6754ca
Packit Service 6754ca
	cout << "writing " << flush;
Packit Service 6754ca
Packit Service 6754ca
	TiledOutputFile out (fileName, hdr);
Packit Service 6754ca
	out.setFrameBuffer (fb);
Packit Service 6754ca
        out.writeTiles (0, out.numXTiles() - 1, 0, out.numYTiles() - 1);
Packit Service 6754ca
    }
Packit Service 6754ca
Packit Service 6754ca
    Array2D<InType> inPixels (height, width);
Packit Service 6754ca
Packit Service 6754ca
    {
Packit Service 6754ca
	cout << "reading " << flush;
Packit Service 6754ca
Packit Service 6754ca
	FrameBuffer fb;
Packit Service 6754ca
Packit Service 6754ca
	fb.insert ("X",						// name
Packit Service 6754ca
		   Slice (InTypeTag,				// type
Packit Service 6754ca
		          (char *) &inPixels[0][0],		// base
Packit Service 6754ca
			  sizeof (inPixels[0][0]),		// xStride
Packit Service 6754ca
			  sizeof (inPixels[0][0]) * width));	// yStride
Packit Service 6754ca
Packit Service 6754ca
	TiledInputFile in (fileName);
Packit Service 6754ca
	in.setFrameBuffer (fb);
Packit Service 6754ca
        in.readTiles (0, in.numXTiles() - 1, 0, in.numYTiles() - 1);
Packit Service 6754ca
    }
Packit Service 6754ca
Packit Service 6754ca
    cout << "comparing" << flush;
Packit Service 6754ca
Packit Service 6754ca
    for (int y = 0; y < height; ++y)
Packit Service 6754ca
    {
Packit Service 6754ca
	for (int x = 0; x < width; ++x)
Packit Service 6754ca
	{
Packit Service 6754ca
	    assert (isEquivalent (inPixels[y][x],
Packit Service 6754ca
				  InType (outPixels[y][x]),
Packit Service 6754ca
				  compression));
Packit Service 6754ca
	}
Packit Service 6754ca
    }
Packit Service 6754ca
Packit Service 6754ca
    cout << endl;
Packit Service 6754ca
Packit Service 6754ca
    remove (fileName);
Packit Service 6754ca
}
Packit Service 6754ca
Packit Service 6754ca
Packit Service 6754ca
template 
Packit Service 6754ca
          class InType,  PixelType InTypeTag>
Packit Service 6754ca
void
Packit Service 6754ca
testImageChannel (const std::string &fileName,
Packit Service 6754ca
		  int width, int height,
Packit Service 6754ca
		  Compression compression)
Packit Service 6754ca
{
Packit Service 6754ca
    testScanLineImageChannel <OutType, OutTypeTag, InType, InTypeTag>
Packit Service 6754ca
	(fileName.c_str(), width, height, compression);
Packit Service 6754ca
Packit Service 6754ca
    testTiledImageChannel <OutType, OutTypeTag, InType, InTypeTag>
Packit Service 6754ca
	(fileName.c_str(), width, height, compression);
Packit Service 6754ca
}
Packit Service 6754ca
Packit Service 6754ca
Packit Service 6754ca
Packit Service 6754ca
} // namespace
Packit Service 6754ca
Packit Service 6754ca
Packit Service 6754ca
void
Packit Service 6754ca
testConversion (const std::string &tempDir)
Packit Service 6754ca
{
Packit Service 6754ca
    try
Packit Service 6754ca
    {
Packit Service 6754ca
	cout << "Testing conversion between pixel data types" << endl;
Packit Service 6754ca
Packit Service 6754ca
	cout << "individual numbers" << endl;
Packit Service 6754ca
Packit Service 6754ca
	testNumbers();
Packit Service 6754ca
Packit Service 6754ca
	cout << "conversion of image channels while reading a file " << endl;
Packit Service 6754ca
Packit Service 6754ca
	for (int comp = 0; comp < NUM_COMPRESSION_METHODS; ++comp)
Packit Service 6754ca
	{
Packit Service 6754ca
	    if (comp == B44_COMPRESSION ||
Packit Service 6754ca
                comp == B44A_COMPRESSION)
Packit Service 6754ca
            {
Packit Service 6754ca
		continue;
Packit Service 6754ca
            }
Packit Service 6754ca
Packit Service 6754ca
	    testImageChannel <unsigned int, IMF::UINT, unsigned int, IMF::UINT>
Packit Service 6754ca
			     (tempDir + "imf_test_conv.exr",
Packit Service 6754ca
			      317, 539,
Packit Service 6754ca
			      Compression (comp));
Packit Service 6754ca
Packit Service 6754ca
	    testImageChannel <unsigned int, IMF::UINT, half, IMF::HALF>
Packit Service 6754ca
			     (tempDir + "imf_test_conv.exr",
Packit Service 6754ca
			      317, 539,
Packit Service 6754ca
			      Compression (comp));
Packit Service 6754ca
Packit Service 6754ca
	    testImageChannel <unsigned int, IMF::UINT, float, IMF::FLOAT>
Packit Service 6754ca
			     (tempDir + "imf_test_conv.exr",
Packit Service 6754ca
			      317, 539,
Packit Service 6754ca
			      Compression (comp));
Packit Service 6754ca
Packit Service 6754ca
	    testImageChannel <half, IMF::HALF, unsigned int, IMF::UINT>
Packit Service 6754ca
			     (tempDir + "imf_test_conv.exr",
Packit Service 6754ca
			      317, 539,
Packit Service 6754ca
			      Compression (comp));
Packit Service 6754ca
Packit Service 6754ca
	    testImageChannel <half, IMF::HALF, half, IMF::HALF>
Packit Service 6754ca
			     (tempDir + "imf_test_conv.exr",
Packit Service 6754ca
			      317, 539,
Packit Service 6754ca
			      Compression (comp));
Packit Service 6754ca
Packit Service 6754ca
	    testImageChannel <half, IMF::HALF, float, IMF::FLOAT>
Packit Service 6754ca
			     (tempDir + "imf_test_conv.exr",
Packit Service 6754ca
			      317, 539,
Packit Service 6754ca
			      Compression (comp));
Packit Service 6754ca
Packit Service 6754ca
	    testImageChannel <float, IMF::FLOAT, unsigned int, IMF::UINT>
Packit Service 6754ca
			     (tempDir + "imf_test_conv.exr",
Packit Service 6754ca
			      317, 539,
Packit Service 6754ca
			      Compression (comp));
Packit Service 6754ca
Packit Service 6754ca
	    testImageChannel <float, IMF::FLOAT, half, IMF::HALF>
Packit Service 6754ca
			     (tempDir + "imf_test_conv.exr",
Packit Service 6754ca
			      317, 539,
Packit Service 6754ca
			      Compression (comp));
Packit Service 6754ca
Packit Service 6754ca
	    testImageChannel <float, IMF::FLOAT, float, IMF::FLOAT>
Packit Service 6754ca
			     (tempDir + "imf_test_conv.exr",
Packit Service 6754ca
			      317, 539,
Packit Service 6754ca
			      Compression (comp));
Packit Service 6754ca
Packit Service 6754ca
	}
Packit Service 6754ca
	cout << "ok\n" << endl;
Packit Service 6754ca
    }
Packit Service 6754ca
    catch (const std::exception &e)
Packit Service 6754ca
    {
Packit Service 6754ca
	cerr << "ERROR -- caught exception: " << e.what() << endl;
Packit Service 6754ca
	assert (false);
Packit Service 6754ca
    }
Packit Service 6754ca
}