Blame IlmImfTest/testStandardAttributes.cpp

Packit 0d464f
///////////////////////////////////////////////////////////////////////////
Packit 0d464f
//
Packit 0d464f
// Copyright (c) 2004-2012, Industrial Light & Magic, a division of Lucas
Packit 0d464f
// Digital Ltd. LLC
Packit 0d464f
// 
Packit 0d464f
// All rights reserved.
Packit 0d464f
// 
Packit 0d464f
// Redistribution and use in source and binary forms, with or without
Packit 0d464f
// modification, are permitted provided that the following conditions are
Packit 0d464f
// met:
Packit 0d464f
// *       Redistributions of source code must retain the above copyright
Packit 0d464f
// notice, this list of conditions and the following disclaimer.
Packit 0d464f
// *       Redistributions in binary form must reproduce the above
Packit 0d464f
// copyright notice, this list of conditions and the following disclaimer
Packit 0d464f
// in the documentation and/or other materials provided with the
Packit 0d464f
// distribution.
Packit 0d464f
// *       Neither the name of Industrial Light & Magic nor the names of
Packit 0d464f
// its contributors may be used to endorse or promote products derived
Packit 0d464f
// from this software without specific prior written permission. 
Packit 0d464f
// 
Packit 0d464f
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
Packit 0d464f
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
Packit 0d464f
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
Packit 0d464f
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
Packit 0d464f
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
Packit 0d464f
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
Packit 0d464f
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
Packit 0d464f
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
Packit 0d464f
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
Packit 0d464f
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
Packit 0d464f
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Packit 0d464f
//
Packit 0d464f
///////////////////////////////////////////////////////////////////////////
Packit 0d464f
Packit 0d464f
Packit 0d464f
#include <ImfRgbaFile.h>
Packit 0d464f
#include <ImfStandardAttributes.h>
Packit 0d464f
#include <ImfFramesPerSecond.h>
Packit 0d464f
#include <ImfArray.h>
Packit 0d464f
#include "ImathRandom.h"
Packit 0d464f
#include <fstream>
Packit 0d464f
#include <iomanip>
Packit 0d464f
#include <stdio.h>
Packit 0d464f
#include <assert.h>
Packit 0d464f
Packit 0d464f
using namespace OPENEXR_IMF_NAMESPACE;
Packit 0d464f
using namespace std;
Packit 0d464f
using namespace IMATH_NAMESPACE;
Packit 0d464f
Packit 0d464f
Packit 0d464f
namespace {
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
convertRGBtoXYZ ()
Packit 0d464f
{
Packit 0d464f
    cout << "conversion from RGB to XYZ" << endl;
Packit 0d464f
Packit 0d464f
    Chromaticities c;
Packit 0d464f
    float Y = 100;
Packit 0d464f
    M44f M1 = RGBtoXYZ (c, Y);
Packit 0d464f
Packit 0d464f
    V3f R1 = V3f (1, 0, 0) * M1;
Packit 0d464f
    V3f G1 = V3f (0, 1, 0) * M1;
Packit 0d464f
    V3f B1 = V3f (0, 0, 1) * M1;
Packit 0d464f
    V3f W1 = V3f (1, 1, 1) * M1;
Packit 0d464f
Packit 0d464f
    cout << "red   XYZ = " << R1 << endl;
Packit 0d464f
    cout << "green XYZ = " << G1 << endl;
Packit 0d464f
    cout << "blue  XYZ = " << B1 << endl;
Packit 0d464f
    cout << "white XYZ = " << W1 << endl;
Packit 0d464f
Packit 0d464f
    V2f r1 (R1.x / (R1.x + R1.y + R1.z), R1.y / (R1.x + R1.y + R1.z));
Packit 0d464f
    V2f g1 (G1.x / (G1.x + G1.y + G1.z), G1.y / (G1.x + G1.y + G1.z));
Packit 0d464f
    V2f b1 (B1.x / (B1.x + B1.y + B1.z), B1.y / (B1.x + B1.y + B1.z));
Packit 0d464f
    V2f w1 (W1.x / (W1.x + W1.y + W1.z), W1.y / (W1.x + W1.y + W1.z));
Packit 0d464f
Packit 0d464f
    cout << "red   xy = " << r1 << endl;
Packit 0d464f
    cout << "green xy = " << g1 << endl;
Packit 0d464f
    cout << "blue  xy = " << b1 << endl;
Packit 0d464f
    cout << "white xy = " << w1 << endl;
Packit 0d464f
Packit 0d464f
    assert (equalWithRelError (W1.y, Y, 1e-5F));
Packit 0d464f
    assert (r1.equalWithAbsError (c.red, 1e-5F));
Packit 0d464f
    assert (g1.equalWithAbsError (c.green, 1e-5F));
Packit 0d464f
    assert (b1.equalWithAbsError (c.blue, 1e-5F));
Packit 0d464f
    assert (w1.equalWithAbsError (c.white, 1e-5F));
Packit 0d464f
Packit 0d464f
    cout << "conversion from XYZ to RGB" << endl;
Packit 0d464f
Packit 0d464f
    M44f M2 = XYZtoRGB (c, Y);
Packit 0d464f
Packit 0d464f
    V3f R2 = R1 * M2;
Packit 0d464f
    V3f G2 = G1 * M2;
Packit 0d464f
    V3f B2 = B1 * M2;
Packit 0d464f
    V3f W2 = W1 * M2;
Packit 0d464f
Packit 0d464f
    cout << "red   RGB = " << R2 << endl;
Packit 0d464f
    cout << "green RGB = " << G2 << endl;
Packit 0d464f
    cout << "blue  RGB = " << B2 << endl;
Packit 0d464f
    cout << "white RGB = " << W2 << endl;
Packit 0d464f
Packit 0d464f
    assert (R2.equalWithAbsError (V3f (1, 0, 0), 1e-3F));
Packit 0d464f
    assert (G2.equalWithAbsError (V3f (0, 1, 0), 1e-3F));
Packit 0d464f
    assert (B2.equalWithAbsError (V3f (0, 0, 1), 1e-3F));
Packit 0d464f
    assert (W2.equalWithAbsError (V3f (1, 1, 1), 1e-3F));
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
writeReadChromaticities (const char fileName[])
Packit 0d464f
{
Packit 0d464f
    cout << "chromaticities attribute" << endl;
Packit 0d464f
Packit 0d464f
    cout << "writing, ";
Packit 0d464f
Packit 0d464f
    Chromaticities c1 (V2f (1, 2), V2f (3, 4), V2f (5, 6), V2f (7, 8));
Packit 0d464f
    static const int W = 100;
Packit 0d464f
    static const int H = 100;
Packit 0d464f
Packit 0d464f
    Header header (W, H);
Packit 0d464f
    assert (hasChromaticities (header) == false);
Packit 0d464f
Packit 0d464f
    addChromaticities (header, c1);
Packit 0d464f
    assert (hasChromaticities (header) == true);
Packit 0d464f
Packit 0d464f
    {
Packit 0d464f
	RgbaOutputFile out (fileName, header);
Packit 0d464f
	Rgba pixels[W];
Packit 0d464f
Packit 0d464f
	for (int i = 0; i < W; ++i)
Packit 0d464f
	{
Packit 0d464f
	    pixels[i].r = 1;
Packit 0d464f
	    pixels[i].g = 1;
Packit 0d464f
	    pixels[i].b = 1;
Packit 0d464f
	    pixels[i].a = 1;
Packit 0d464f
	}
Packit 0d464f
Packit 0d464f
	out.setFrameBuffer (pixels, 1, 0);
Packit 0d464f
	out.writePixels (H);
Packit 0d464f
    }
Packit 0d464f
Packit 0d464f
    cout << "reading, comparing" << endl;
Packit 0d464f
Packit 0d464f
    {
Packit 0d464f
	RgbaInputFile in (fileName);
Packit 0d464f
	const Chromaticities &c2 = chromaticities (in.header());
Packit 0d464f
Packit 0d464f
	assert (hasChromaticities (in.header()) == true);
Packit 0d464f
	assert (c1.red == c2.red);
Packit 0d464f
	assert (c1.green == c2.green);
Packit 0d464f
	assert (c1.blue == c2.blue);
Packit 0d464f
	assert (c1.white == c2.white);
Packit 0d464f
    }
Packit 0d464f
Packit 0d464f
    remove (fileName);
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
latLongMap (const char fileName1[], const char fileName2[])
Packit 0d464f
{
Packit 0d464f
    cout << "latitude-longitude environment map" << endl;
Packit 0d464f
    const int W = 360;
Packit 0d464f
    const int H = 180;
Packit 0d464f
Packit 0d464f
    Header header (W, H);
Packit 0d464f
    addEnvmap (header, ENVMAP_LATLONG);
Packit 0d464f
Packit 0d464f
    V2f pos;
Packit 0d464f
Packit 0d464f
    pos = LatLongMap::latLong (V3f (0, 1, 0));
Packit 0d464f
    assert (equalWithAbsError (pos.x, float (M_PI/2), 1e-6f));
Packit 0d464f
Packit 0d464f
    pos = LatLongMap::latLong (V3f (0, -1, 0));
Packit 0d464f
    assert (equalWithAbsError (pos.x, float (-M_PI/2), 1e-6f));
Packit 0d464f
Packit 0d464f
    pos = LatLongMap::latLong (V3f (0, 0, 1));
Packit 0d464f
    assert (pos.equalWithAbsError (V2f (0, 0), 1e-6f));
Packit 0d464f
Packit 0d464f
    pos = LatLongMap::latLong (V3f (1, 0, 0));
Packit 0d464f
    assert (pos.equalWithAbsError (V2f (0, M_PI/2), 1e-6f));
Packit 0d464f
Packit 0d464f
    pos = LatLongMap::latLong (V3f (-1, 0, 0));
Packit 0d464f
    assert (pos.equalWithAbsError (V2f (0, -M_PI/2), 1e-6f));
Packit 0d464f
Packit 0d464f
    pos = LatLongMap::latLong (V3f (0, 1, 1));
Packit 0d464f
    assert (pos.equalWithAbsError (V2f (M_PI/4, 0), 1e-6f));
Packit 0d464f
Packit 0d464f
    pos = LatLongMap::latLong (V3f (0, -1, 1));
Packit 0d464f
    assert (pos.equalWithAbsError (V2f (-M_PI/4, 0), 1e-6f));
Packit 0d464f
Packit 0d464f
    pos = LatLongMap::pixelPosition (header.dataWindow(), V2f (M_PI/2, M_PI));
Packit 0d464f
    assert (pos.equalWithAbsError (V2f (0, 0), 1e-6f * W));
Packit 0d464f
Packit 0d464f
    pos = LatLongMap::pixelPosition(header.dataWindow(), V2f (-M_PI/2, -M_PI));
Packit 0d464f
    assert (pos.equalWithAbsError (V2f (header.dataWindow().max), 1e-6f * W));
Packit 0d464f
Packit 0d464f
    Array2D<Rgba> pixels (H, W);
Packit 0d464f
Packit 0d464f
    for (int y = 0; y < H; ++y)
Packit 0d464f
    {
Packit 0d464f
	for (int x = 0; x < W; ++x)
Packit 0d464f
	{
Packit 0d464f
	    Rgba &p = pixels[y][x];
Packit 0d464f
	    V3f dir = LatLongMap::direction (header.dataWindow(), V2f (x, y));
Packit 0d464f
Packit 0d464f
	    p.r = dir.x + 1;
Packit 0d464f
	    p.g = dir.y + 1;
Packit 0d464f
	    p.b = dir.z + 1;
Packit 0d464f
	}
Packit 0d464f
    }
Packit 0d464f
Packit 0d464f
    {
Packit 0d464f
	RgbaOutputFile out (fileName1, header, WRITE_RGB);
Packit 0d464f
	out.setFrameBuffer (&pixels[0][0], 1, W);
Packit 0d464f
	out.writePixels (H);
Packit 0d464f
    }
Packit 0d464f
Packit 0d464f
    Rand48 rand (0);
Packit 0d464f
Packit 0d464f
    for (int i = 0; i < W * H * 3; ++i)
Packit 0d464f
    {
Packit 0d464f
	V3f dir = hollowSphereRand<V3f> (rand);
Packit 0d464f
	V2f pos = LatLongMap::pixelPosition (header.dataWindow(), dir);
Packit 0d464f
Packit 0d464f
	Rgba &p = pixels[int (pos.y + 0.5)][int (pos.x + 0.5)];
Packit 0d464f
Packit 0d464f
	p.r = (dir.x + 1) * 0.8;
Packit 0d464f
	p.g = (dir.y + 1) * 0.8;
Packit 0d464f
	p.b = (dir.z + 1) * 0.8;
Packit 0d464f
Packit 0d464f
	V3f dir1 = LatLongMap::direction (header.dataWindow(), pos);
Packit 0d464f
	assert (dir.equalWithAbsError (dir1.normalized(), 1e-5f));
Packit 0d464f
    }
Packit 0d464f
Packit 0d464f
    {
Packit 0d464f
	RgbaOutputFile out (fileName2, header, WRITE_RGB);
Packit 0d464f
	out.setFrameBuffer (&pixels[0][0], 1, W);
Packit 0d464f
	out.writePixels (H);
Packit 0d464f
    }
Packit 0d464f
Packit 0d464f
Packit 0d464f
    remove (fileName1);
Packit 0d464f
    remove (fileName2);
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
cubeMap (const char fileName1[], const char fileName2[])
Packit 0d464f
{
Packit 0d464f
    cout << "cube environment map" << endl;
Packit 0d464f
    const int N = 128;
Packit 0d464f
    const int W = N;
Packit 0d464f
    const int H = N * 6;
Packit 0d464f
Packit 0d464f
    Header header (W, H);
Packit 0d464f
    addEnvmap (header, ENVMAP_CUBE);
Packit 0d464f
Packit 0d464f
    int sof = CubeMap::sizeOfFace (header.dataWindow());
Packit 0d464f
Packit 0d464f
    assert (sof == N);
Packit 0d464f
Packit 0d464f
    for (int face1 = 0; face1 < 6; ++face1)
Packit 0d464f
    {
Packit 0d464f
	Box2i dw1 = CubeMap::dataWindowForFace (CubeMapFace (face1),
Packit 0d464f
						header.dataWindow());
Packit 0d464f
Packit 0d464f
	assert (dw1.max.x - dw1.min.x == sof - 1);
Packit 0d464f
	assert (dw1.max.y - dw1.min.y == sof - 1);
Packit 0d464f
	assert (header.dataWindow().intersects (dw1.min));
Packit 0d464f
	assert (header.dataWindow().intersects (dw1.max));
Packit 0d464f
Packit 0d464f
	for (int face2 = face1 + 1; face2 < 6; ++face2)
Packit 0d464f
	{
Packit 0d464f
	    Box2i dw2 = CubeMap::dataWindowForFace (CubeMapFace (face2),
Packit 0d464f
						    header.dataWindow());
Packit 0d464f
	    assert (!dw1.intersects (dw2));
Packit 0d464f
	}
Packit 0d464f
    }
Packit 0d464f
Packit 0d464f
    CubeMapFace face;
Packit 0d464f
    V2f pos;
Packit 0d464f
Packit 0d464f
    CubeMap::faceAndPixelPosition (V3f (1, 0, 0),
Packit 0d464f
				   header.dataWindow(),
Packit 0d464f
				   face, pos);
Packit 0d464f
    
Packit 0d464f
    assert (face == CUBEFACE_POS_X);
Packit 0d464f
    assert (pos.equalWithAbsError (V2f ((sof - 1), (sof - 1)) / 2, 1e-6 * W));
Packit 0d464f
Packit 0d464f
    CubeMap::faceAndPixelPosition (V3f (-1, 0, 0),
Packit 0d464f
	                           header.dataWindow(),
Packit 0d464f
				   face, pos);
Packit 0d464f
    
Packit 0d464f
    assert (face == CUBEFACE_NEG_X);
Packit 0d464f
    assert (pos.equalWithAbsError (V2f ((sof - 1), (sof - 1)) / 2, 1e-6 * W));
Packit 0d464f
Packit 0d464f
    CubeMap::faceAndPixelPosition (V3f (0, 1, 0),
Packit 0d464f
	    			   header.dataWindow(),
Packit 0d464f
				   face, pos);
Packit 0d464f
    
Packit 0d464f
    assert (face == CUBEFACE_POS_Y);
Packit 0d464f
    assert (pos.equalWithAbsError (V2f ((sof - 1), (sof - 1)) / 2, 1e-6 * W));
Packit 0d464f
Packit 0d464f
    CubeMap::faceAndPixelPosition (V3f (0, -1, 0),
Packit 0d464f
	    			   header.dataWindow(),
Packit 0d464f
				   face, pos);
Packit 0d464f
    
Packit 0d464f
    assert (face == CUBEFACE_NEG_Y);
Packit 0d464f
    assert (pos.equalWithAbsError (V2f ((sof - 1), (sof - 1)) / 2, 1e-6 * W));
Packit 0d464f
Packit 0d464f
    CubeMap::faceAndPixelPosition (V3f (0, 0, 1),
Packit 0d464f
	    			   header.dataWindow(),
Packit 0d464f
				   face, pos);
Packit 0d464f
    
Packit 0d464f
    assert (face == CUBEFACE_POS_Z);
Packit 0d464f
    assert (pos.equalWithAbsError (V2f ((sof - 1), (sof - 1)) / 2, 1e-6 * W));
Packit 0d464f
Packit 0d464f
    CubeMap::faceAndPixelPosition (V3f (0, 0, -1),
Packit 0d464f
	    			   header.dataWindow(),
Packit 0d464f
				   face, pos);
Packit 0d464f
    
Packit 0d464f
    assert (face == CUBEFACE_NEG_Z);
Packit 0d464f
    assert (pos.equalWithAbsError (V2f ((sof - 1), (sof - 1)) / 2, 1e-6 * W));
Packit 0d464f
Packit 0d464f
    Array2D<Rgba> pixels (H, W);
Packit 0d464f
Packit 0d464f
    for (int y = 0; y < H; ++y)
Packit 0d464f
    {
Packit 0d464f
	for (int x = 0; x < W; ++x)
Packit 0d464f
	{
Packit 0d464f
	    Rgba &p = pixels[y][x];
Packit 0d464f
	    p.r = p.g = p.b = 0;
Packit 0d464f
	}
Packit 0d464f
    }
Packit 0d464f
Packit 0d464f
    for (int face = 0; face < 6; ++face)
Packit 0d464f
    {
Packit 0d464f
	for (int y = 0; y < sof; ++y)
Packit 0d464f
	{
Packit 0d464f
	    for (int x = 0; x < sof; ++x)
Packit 0d464f
	    {
Packit 0d464f
		V2f px = CubeMap::pixelPosition (CubeMapFace (face),
Packit 0d464f
						 header.dataWindow(),
Packit 0d464f
						 V2f (x, y));
Packit 0d464f
Packit 0d464f
		Rgba &p = pixels[int (px.y + 0.5)][int (px.x + 0.5)];
Packit 0d464f
Packit 0d464f
		V3f dir = CubeMap::direction (CubeMapFace (face),
Packit 0d464f
			                      header.dataWindow(),
Packit 0d464f
					      V2f (x, y));
Packit 0d464f
		dir.normalize();
Packit 0d464f
Packit 0d464f
		p.r = dir.x + 1;
Packit 0d464f
		p.g = dir.y + 1;
Packit 0d464f
		p.b = dir.z + 1;
Packit 0d464f
	    }
Packit 0d464f
	}
Packit 0d464f
    }
Packit 0d464f
Packit 0d464f
    {
Packit 0d464f
	RgbaOutputFile out (fileName1, header, WRITE_RGB);
Packit 0d464f
	out.setFrameBuffer (&pixels[0][0], 1, W);
Packit 0d464f
	out.writePixels (H);
Packit 0d464f
    }
Packit 0d464f
Packit 0d464f
    for (int y = 0; y < H; ++y)
Packit 0d464f
    {
Packit 0d464f
	for (int x = 0; x < W; ++x)
Packit 0d464f
	{
Packit 0d464f
	    Rgba &p = pixels[y][x];
Packit 0d464f
	    assert (p.r != 0 || p.g != 0 || p.b != 0);
Packit 0d464f
	}
Packit 0d464f
    }
Packit 0d464f
Packit 0d464f
    Rand48 rand (0);
Packit 0d464f
Packit 0d464f
    for (int i = 0; i < W * H * 3; ++i)
Packit 0d464f
    {
Packit 0d464f
	V3f dir = hollowSphereRand<V3f> (rand);
Packit 0d464f
Packit 0d464f
	CubeMapFace face;
Packit 0d464f
	V2f pif;
Packit 0d464f
Packit 0d464f
	CubeMap::faceAndPixelPosition (dir, header.dataWindow(), face, pif);
Packit 0d464f
Packit 0d464f
	V2f pos = CubeMap::pixelPosition (face, header.dataWindow(), pif);
Packit 0d464f
Packit 0d464f
	Rgba &p = pixels[int (pos.y + 0.5)][int (pos.x + 0.5)];
Packit 0d464f
Packit 0d464f
	p.r = (dir.x + 1) * 0.8;
Packit 0d464f
	p.g = (dir.y + 1) * 0.8;
Packit 0d464f
	p.b = (dir.z + 1) * 0.8;
Packit 0d464f
Packit 0d464f
	V3f dir1 = CubeMap::direction (face, header.dataWindow(), pif);
Packit 0d464f
	assert (dir.equalWithAbsError (dir1.normalized(), 1e-6f));
Packit 0d464f
    }
Packit 0d464f
Packit 0d464f
    {
Packit 0d464f
	RgbaOutputFile out (fileName2, header, WRITE_RGB);
Packit 0d464f
	out.setFrameBuffer (&pixels[0][0], 1, W);
Packit 0d464f
	out.writePixels (H);
Packit 0d464f
    }
Packit 0d464f
Packit 0d464f
    remove (fileName1);
Packit 0d464f
    remove (fileName2);
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
writeReadKeyCode (const char fileName[])
Packit 0d464f
{
Packit 0d464f
    cout << "key code attribute" << endl;
Packit 0d464f
Packit 0d464f
    cout << "writing, ";
Packit 0d464f
Packit 0d464f
    KeyCode k1 (12,	// filmMfcCode
Packit 0d464f
	        34,	// filmType
Packit 0d464f
		123456,	// prefix
Packit 0d464f
		1234,	// count
Packit 0d464f
		45,	// perfOffset
Packit 0d464f
		3,	// perfsPerFrame
Packit 0d464f
		80);	// perfsPerCount
Packit 0d464f
Packit 0d464f
    assert (k1.filmMfcCode() == 12);
Packit 0d464f
    assert (k1.filmType() == 34);
Packit 0d464f
    assert (k1.prefix() == 123456);
Packit 0d464f
    assert (k1.count() == 1234);
Packit 0d464f
    assert (k1.perfOffset() == 45);
Packit 0d464f
    assert (k1.perfsPerFrame() == 3);
Packit 0d464f
    assert (k1.perfsPerCount() == 80);
Packit 0d464f
Packit 0d464f
    static const int W = 100;
Packit 0d464f
    static const int H = 100;
Packit 0d464f
Packit 0d464f
    Header header (W, H);
Packit 0d464f
    assert (hasKeyCode (header) == false);
Packit 0d464f
Packit 0d464f
    addKeyCode (header, k1);
Packit 0d464f
    assert (hasKeyCode (header) == true);
Packit 0d464f
Packit 0d464f
    {
Packit 0d464f
	RgbaOutputFile out (fileName, header);
Packit 0d464f
	Rgba pixels[W];
Packit 0d464f
Packit 0d464f
	for (int i = 0; i < W; ++i)
Packit 0d464f
	{
Packit 0d464f
	    pixels[i].r = 1;
Packit 0d464f
	    pixels[i].g = 1;
Packit 0d464f
	    pixels[i].b = 1;
Packit 0d464f
	    pixels[i].a = 1;
Packit 0d464f
	}
Packit 0d464f
Packit 0d464f
	out.setFrameBuffer (pixels, 1, 0);
Packit 0d464f
	out.writePixels (H);
Packit 0d464f
    }
Packit 0d464f
Packit 0d464f
    cout << "reading, comparing" << endl;
Packit 0d464f
Packit 0d464f
    {
Packit 0d464f
	RgbaInputFile in (fileName);
Packit 0d464f
	const KeyCode &k2 = keyCode (in.header());
Packit 0d464f
Packit 0d464f
	assert (hasKeyCode (in.header()) == true);
Packit 0d464f
	assert (k1.filmMfcCode() == k2.filmMfcCode());
Packit 0d464f
	assert (k1.filmType() == k2.filmType());
Packit 0d464f
	assert (k1.prefix() == k2.prefix());
Packit 0d464f
	assert (k1.count() == k2.count());
Packit 0d464f
	assert (k1.perfOffset() == k2.perfOffset());
Packit 0d464f
	assert (k1.perfsPerFrame() == k2.perfsPerFrame());
Packit 0d464f
	assert (k1.perfsPerCount() == k2.perfsPerCount());
Packit 0d464f
    }
Packit 0d464f
Packit 0d464f
    remove (fileName);
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
timeCodeMethods ()
Packit 0d464f
{
Packit 0d464f
    cout << "time code methods" << endl;
Packit 0d464f
Packit 0d464f
    TimeCode t;
Packit 0d464f
Packit 0d464f
    assert (t.timeAndFlags() == 0);
Packit 0d464f
    assert (t.userData() == 0);
Packit 0d464f
Packit 0d464f
    // Frames
Packit 0d464f
Packit 0d464f
    t.setTimeAndFlags (0x00000000);
Packit 0d464f
    t.setFrame (29);
Packit 0d464f
    assert (t.frame() == 29);
Packit 0d464f
    assert (t.timeAndFlags() == 0x00000029);
Packit 0d464f
Packit 0d464f
    t.setTimeAndFlags (0xffffffff);
Packit 0d464f
    t.setFrame (0);
Packit 0d464f
    assert (t.frame() == 0);
Packit 0d464f
    assert (t.timeAndFlags() == 0xffffffc0);
Packit 0d464f
Packit 0d464f
    // Seconds
Packit 0d464f
Packit 0d464f
    t.setTimeAndFlags (0x00000000);
Packit 0d464f
    t.setSeconds (59);
Packit 0d464f
    assert (t.seconds() == 59);
Packit 0d464f
    assert (t.timeAndFlags() == 0x00005900);
Packit 0d464f
Packit 0d464f
    t.setTimeAndFlags (0xffffffff);
Packit 0d464f
    t.setSeconds (0);
Packit 0d464f
    assert (t.seconds() == 0);
Packit 0d464f
    assert (t.timeAndFlags() == 0xffff80ff);
Packit 0d464f
Packit 0d464f
    // Minutes
Packit 0d464f
Packit 0d464f
    t.setTimeAndFlags (0x00000000);
Packit 0d464f
    t.setMinutes (59);
Packit 0d464f
    assert (t.minutes() == 59);
Packit 0d464f
    assert (t.timeAndFlags() == 0x00590000);
Packit 0d464f
Packit 0d464f
    t.setTimeAndFlags (0xffffffff);
Packit 0d464f
    t.setMinutes (0);
Packit 0d464f
    assert (t.minutes() == 0);
Packit 0d464f
    assert (t.timeAndFlags() == 0xff80ffff);
Packit 0d464f
Packit 0d464f
    // Hours
Packit 0d464f
Packit 0d464f
    t.setTimeAndFlags (0x00000000);
Packit 0d464f
    t.setHours (23);
Packit 0d464f
    assert (t.hours() == 23);
Packit 0d464f
    assert (t.timeAndFlags() == 0x23000000);
Packit 0d464f
Packit 0d464f
    t.setTimeAndFlags (0xffffffff);
Packit 0d464f
    t.setHours (0);
Packit 0d464f
    assert (t.hours() == 0);
Packit 0d464f
    assert (t.timeAndFlags() == 0xc0ffffff);
Packit 0d464f
Packit 0d464f
    // Drop frame flag
Packit 0d464f
Packit 0d464f
    t.setTimeAndFlags (0x00000000);
Packit 0d464f
    t.setDropFrame (true);
Packit 0d464f
    assert (t.dropFrame() == true);
Packit 0d464f
    assert (t.timeAndFlags() == 0x00000040);
Packit 0d464f
Packit 0d464f
    t.setTimeAndFlags (0xffffffff);
Packit 0d464f
    t.setDropFrame (false);
Packit 0d464f
    assert (t.dropFrame() == false);
Packit 0d464f
    assert (t.timeAndFlags() == 0xffffffbf);
Packit 0d464f
Packit 0d464f
    // Color frame flag
Packit 0d464f
Packit 0d464f
    t.setTimeAndFlags (0x00000000);
Packit 0d464f
    t.setColorFrame (true);
Packit 0d464f
    assert (t.colorFrame() == true);
Packit 0d464f
    assert (t.timeAndFlags() == 0x00000080);
Packit 0d464f
Packit 0d464f
    t.setTimeAndFlags (0xffffffff);
Packit 0d464f
    t.setColorFrame (false);
Packit 0d464f
    assert (t.colorFrame() == false);
Packit 0d464f
    assert (t.timeAndFlags() == 0xffffff7f);
Packit 0d464f
Packit 0d464f
    // Field/phase flag
Packit 0d464f
Packit 0d464f
    t.setTimeAndFlags (0x00000000);
Packit 0d464f
    t.setFieldPhase (true);
Packit 0d464f
    assert (t.fieldPhase() == true);
Packit 0d464f
    assert (t.timeAndFlags (TimeCode::TV60_PACKING)   == 0x00008000);
Packit 0d464f
    assert (t.timeAndFlags (TimeCode::TV50_PACKING)   == 0x80000000);
Packit 0d464f
    assert (t.timeAndFlags (TimeCode::FILM24_PACKING) == 0x00008000);
Packit 0d464f
Packit 0d464f
    t.setTimeAndFlags (0xffffffff);
Packit 0d464f
    t.setFieldPhase (false);
Packit 0d464f
    assert (t.fieldPhase() == false);
Packit 0d464f
    assert (t.timeAndFlags (TimeCode::TV60_PACKING)   == 0xffff7fff);
Packit 0d464f
    assert (t.timeAndFlags (TimeCode::TV50_PACKING)   == 0x7fffffbf);
Packit 0d464f
    assert (t.timeAndFlags (TimeCode::FILM24_PACKING) == 0xffff7f3f);
Packit 0d464f
Packit 0d464f
    t.setTimeAndFlags (0x23595929 | 0x00008000, TimeCode::TV60_PACKING);
Packit 0d464f
    assert (t.timeAndFlags() == (0x23595929 | 0x00008000));
Packit 0d464f
Packit 0d464f
    t.setTimeAndFlags (0x23595929 | 0x80000000, TimeCode::TV50_PACKING);
Packit 0d464f
    assert (t.timeAndFlags() == (0x23595929 | 0x00008000));
Packit 0d464f
Packit 0d464f
    t.setTimeAndFlags (0x23595929 | 0x00008000, TimeCode::FILM24_PACKING);
Packit 0d464f
    assert (t.timeAndFlags() == (0x23595929 | 0x00008000));
Packit 0d464f
Packit 0d464f
    // bgf0
Packit 0d464f
Packit 0d464f
    t.setTimeAndFlags (0x00000000);
Packit 0d464f
    t.setBgf0 (true);
Packit 0d464f
    assert (t.bgf0() == true);
Packit 0d464f
    assert (t.timeAndFlags (TimeCode::TV60_PACKING)   == 0x00800000);
Packit 0d464f
    assert (t.timeAndFlags (TimeCode::TV50_PACKING)   == 0x00008000);
Packit 0d464f
    assert (t.timeAndFlags (TimeCode::FILM24_PACKING) == 0x00800000);
Packit 0d464f
Packit 0d464f
    t.setTimeAndFlags (0xffffffff);
Packit 0d464f
    t.setBgf0 (false);
Packit 0d464f
    assert (t.bgf0() == false);
Packit 0d464f
    assert (t.timeAndFlags (TimeCode::TV60_PACKING)   == 0xff7fffff);
Packit 0d464f
    assert (t.timeAndFlags (TimeCode::TV50_PACKING)   == 0xffff7fbf);
Packit 0d464f
    assert (t.timeAndFlags (TimeCode::FILM24_PACKING) == 0xff7fff3f);
Packit 0d464f
Packit 0d464f
    t.setTimeAndFlags (0x23595929 | 0x00800000, TimeCode::TV60_PACKING);
Packit 0d464f
    assert (t.timeAndFlags() == (0x23595929 | 0x00800000));
Packit 0d464f
Packit 0d464f
    t.setTimeAndFlags (0x23595929 | 0x00008000, TimeCode::TV50_PACKING);
Packit 0d464f
    assert (t.timeAndFlags() == (0x23595929 | 0x00800000));
Packit 0d464f
Packit 0d464f
    t.setTimeAndFlags (0x23595929 | 0x00800000, TimeCode::FILM24_PACKING);
Packit 0d464f
    assert (t.timeAndFlags() == (0x23595929 | 0x00800000));
Packit 0d464f
Packit 0d464f
    // bgf1
Packit 0d464f
Packit 0d464f
    t.setTimeAndFlags (0x00000000);
Packit 0d464f
    t.setBgf1 (true);
Packit 0d464f
    assert (t.bgf1() == true);
Packit 0d464f
    assert (t.timeAndFlags (TimeCode::TV60_PACKING)   == 0x40000000);
Packit 0d464f
    assert (t.timeAndFlags (TimeCode::TV50_PACKING)   == 0x40000000);
Packit 0d464f
    assert (t.timeAndFlags (TimeCode::FILM24_PACKING) == 0x40000000);
Packit 0d464f
Packit 0d464f
    t.setTimeAndFlags (0xffffffff);
Packit 0d464f
    t.setBgf1 (false);
Packit 0d464f
    assert (t.bgf1() == false);
Packit 0d464f
    assert (t.timeAndFlags (TimeCode::TV60_PACKING)   == 0xbfffffff);
Packit 0d464f
    assert (t.timeAndFlags (TimeCode::TV50_PACKING)   == 0xbfffffbf);
Packit 0d464f
    assert (t.timeAndFlags (TimeCode::FILM24_PACKING) == 0xbfffff3f);
Packit 0d464f
Packit 0d464f
    t.setTimeAndFlags (0x23595929 | 0x40000000, TimeCode::TV60_PACKING);
Packit 0d464f
    assert (t.timeAndFlags() == (0x23595929 | 0x40000000));
Packit 0d464f
Packit 0d464f
    t.setTimeAndFlags (0x23595929 | 0x40000000, TimeCode::TV50_PACKING);
Packit 0d464f
    assert (t.timeAndFlags() == (0x23595929 | 0x40000000));
Packit 0d464f
Packit 0d464f
    t.setTimeAndFlags (0x23595929 | 0x40000000, TimeCode::FILM24_PACKING);
Packit 0d464f
    assert (t.timeAndFlags() == (0x23595929 | 0x40000000));
Packit 0d464f
Packit 0d464f
    // bgf2
Packit 0d464f
Packit 0d464f
    t.setTimeAndFlags (0x00000000);
Packit 0d464f
    t.setBgf2 (true);
Packit 0d464f
    assert (t.bgf2() == true);
Packit 0d464f
    assert (t.timeAndFlags (TimeCode::TV60_PACKING)   == 0x80000000);
Packit 0d464f
    assert (t.timeAndFlags (TimeCode::TV50_PACKING)   == 0x00800000);
Packit 0d464f
    assert (t.timeAndFlags (TimeCode::FILM24_PACKING) == 0x80000000);
Packit 0d464f
Packit 0d464f
    t.setTimeAndFlags (0xffffffff);
Packit 0d464f
    t.setBgf2 (false);
Packit 0d464f
    assert (t.bgf2() == false);
Packit 0d464f
    assert (t.timeAndFlags (TimeCode::TV60_PACKING)   == 0x7fffffff);
Packit 0d464f
    assert (t.timeAndFlags (TimeCode::TV50_PACKING)   == 0xff7fffbf);
Packit 0d464f
    assert (t.timeAndFlags (TimeCode::FILM24_PACKING) == 0x7fffff3f);
Packit 0d464f
Packit 0d464f
    t.setTimeAndFlags (0x23595929 | 0x80000000, TimeCode::TV60_PACKING);
Packit 0d464f
    assert (t.timeAndFlags() == (0x23595929 | 0x80000000));
Packit 0d464f
Packit 0d464f
    t.setTimeAndFlags (0x23595929 | 0x00800000, TimeCode::TV50_PACKING);
Packit 0d464f
    assert (t.timeAndFlags() == (0x23595929 | 0x80000000));
Packit 0d464f
Packit 0d464f
    t.setTimeAndFlags (0x23595929 | 0x80000000, TimeCode::FILM24_PACKING);
Packit 0d464f
    assert (t.timeAndFlags() == (0x23595929 | 0x80000000));
Packit 0d464f
Packit 0d464f
    // User-defined data
Packit 0d464f
    
Packit 0d464f
    t.setUserData (0x87654321);
Packit 0d464f
    assert (t.userData() == 0x87654321);
Packit 0d464f
Packit 0d464f
    assert (t.binaryGroup (1) == 1);
Packit 0d464f
    assert (t.binaryGroup (2) == 2);
Packit 0d464f
    assert (t.binaryGroup (3) == 3);
Packit 0d464f
    assert (t.binaryGroup (4) == 4);
Packit 0d464f
    assert (t.binaryGroup (5) == 5);
Packit 0d464f
    assert (t.binaryGroup (6) == 6);
Packit 0d464f
    assert (t.binaryGroup (7) == 7);
Packit 0d464f
Packit 0d464f
    t.setBinaryGroup (1, 2);
Packit 0d464f
    t.setBinaryGroup (2, 3);
Packit 0d464f
    t.setBinaryGroup (3, 4);
Packit 0d464f
    t.setBinaryGroup (4, 5);
Packit 0d464f
    t.setBinaryGroup (5, 6);
Packit 0d464f
    t.setBinaryGroup (6, 7);
Packit 0d464f
    t.setBinaryGroup (7, 8);
Packit 0d464f
    t.setBinaryGroup (8, 9);
Packit 0d464f
Packit 0d464f
    assert (t.userData() == 0x98765432);
Packit 0d464f
    
Packit 0d464f
    // Assignment
Packit 0d464f
Packit 0d464f
    TimeCode t1 (12, 17, 57, 14,	   // hours, minutes, seconds, frame
Packit 0d464f
		 false, false, false,	   // dropFrame, colorFrame, fieldPhase
Packit 0d464f
		 false, false, false,	   // bgf0, bgf1, bgf2
Packit 0d464f
		 1, 2, 3, 4, 5, 6, 7, 8);  // binary groups 1 to 8
Packit 0d464f
    t = t1;
Packit 0d464f
Packit 0d464f
    assert (t.timeAndFlags() == 0x12175714);
Packit 0d464f
    assert (t.userData() == 0x87654321);
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
writeReadTimeCode (const char fileName[])
Packit 0d464f
{
Packit 0d464f
    cout << "time code attribute" << endl;
Packit 0d464f
Packit 0d464f
    cout << "writing, ";
Packit 0d464f
Packit 0d464f
    TimeCode t1 (0x23595829, 0x12345678, TimeCode::FILM24_PACKING);
Packit 0d464f
Packit 0d464f
    assert (t1.timeAndFlags (TimeCode::FILM24_PACKING) == 0x23595829);
Packit 0d464f
    assert (t1.userData() == 0x12345678);
Packit 0d464f
Packit 0d464f
    static const int W = 100;
Packit 0d464f
    static const int H = 100;
Packit 0d464f
Packit 0d464f
    Header header (W, H);
Packit 0d464f
    assert (hasTimeCode (header) == false);
Packit 0d464f
Packit 0d464f
    addTimeCode (header, t1);
Packit 0d464f
    assert (hasTimeCode (header) == true);
Packit 0d464f
Packit 0d464f
    {
Packit 0d464f
	RgbaOutputFile out (fileName, header);
Packit 0d464f
	Rgba pixels[W];
Packit 0d464f
Packit 0d464f
	for (int i = 0; i < W; ++i)
Packit 0d464f
	{
Packit 0d464f
	    pixels[i].r = 1;
Packit 0d464f
	    pixels[i].g = 1;
Packit 0d464f
	    pixels[i].b = 1;
Packit 0d464f
	    pixels[i].a = 1;
Packit 0d464f
	}
Packit 0d464f
Packit 0d464f
	out.setFrameBuffer (pixels, 1, 0);
Packit 0d464f
	out.writePixels (H);
Packit 0d464f
    }
Packit 0d464f
Packit 0d464f
    cout << "reading, comparing" << endl;
Packit 0d464f
Packit 0d464f
    {
Packit 0d464f
	RgbaInputFile in (fileName);
Packit 0d464f
	const TimeCode &t2 = timeCode (in.header());
Packit 0d464f
Packit 0d464f
	assert (hasTimeCode (in.header()) == true);
Packit 0d464f
	assert (t1.timeAndFlags() == t2.timeAndFlags());
Packit 0d464f
	assert (t1.userData() == t2.userData());
Packit 0d464f
    }
Packit 0d464f
Packit 0d464f
    remove (fileName);
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
bool
Packit 0d464f
equal (const Rational &a, const Rational &b)
Packit 0d464f
{
Packit 0d464f
    return a.n == b.n && a.d == b.d;
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
rationalMethods ()
Packit 0d464f
{
Packit 0d464f
    cout << "rational methods" << endl;
Packit 0d464f
Packit 0d464f
    Rational r0 (0, 1);
Packit 0d464f
    assert (r0 == 0);
Packit 0d464f
Packit 0d464f
    Rational r1 (1, 1);
Packit 0d464f
    assert (r1 == 1);
Packit 0d464f
Packit 0d464f
    Rational r2 (1, 4);
Packit 0d464f
    assert (r2 == 0.25);
Packit 0d464f
Packit 0d464f
    Rational r3 (-8, 2);
Packit 0d464f
    assert (r3 == -4);
Packit 0d464f
Packit 0d464f
    Rational r4 (0.0);
Packit 0d464f
    assert (r4 == 0);
Packit 0d464f
Packit 0d464f
    Rational r5 (1e-50);
Packit 0d464f
    assert (r5 == 0);
Packit 0d464f
Packit 0d464f
    Rational r6 (1.0);
Packit 0d464f
    assert (r6 == 1.0 && r6.n == 1 && r6.d == 1);
Packit 0d464f
Packit 0d464f
    Rational r7 (-10.0);
Packit 0d464f
    assert (r7 == -10.0 && r7.n == -10 && r7.d == 1);
Packit 0d464f
Packit 0d464f
    Rational r8 (0.03125);
Packit 0d464f
    assert (r8 == 0.03125 && r8.n == 1 && r8.d == 32);
Packit 0d464f
Packit 0d464f
    Rational r9 (0.53125);
Packit 0d464f
    assert (r9 == 0.53125 && r9.n == 17 && r9.d == 32);
Packit 0d464f
Packit 0d464f
    Rational r10 (10.1);
Packit 0d464f
    assert (equalWithAbsError (double (r10), 10.1, 1e-8));
Packit 0d464f
Packit 0d464f
    Rational r11 (double ((1U << 30) - 1));
Packit 0d464f
    assert (r11 == double ((1U << 30) - 1));
Packit 0d464f
Packit 0d464f
    assert (equal (guessExactFps (23.976), fps_23_976()));
Packit 0d464f
    assert (equal (guessExactFps (24.000), fps_24()));
Packit 0d464f
    assert (equal (guessExactFps (25.000), fps_25()));
Packit 0d464f
    assert (equal (guessExactFps (29.970), fps_29_97()));
Packit 0d464f
    assert (equal (guessExactFps (30.000), fps_30()));
Packit 0d464f
    assert (equal (guessExactFps (47.952), fps_47_952()));
Packit 0d464f
    assert (equal (guessExactFps (48.000), fps_48()));
Packit 0d464f
    assert (equal (guessExactFps (50.000), fps_50()));
Packit 0d464f
    assert (equal (guessExactFps (59.940), fps_59_94()));
Packit 0d464f
    assert (equal (guessExactFps (60.000), fps_60()));
Packit 0d464f
    assert (equal (guessExactFps (70.500), Rational (141, 2)));
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
writeReadRational (const char fileName[])
Packit 0d464f
{
Packit 0d464f
    cout << "rational attribute" << endl;
Packit 0d464f
Packit 0d464f
    cout << "writing, ";
Packit 0d464f
Packit 0d464f
    Rational r1 (12, 17);
Packit 0d464f
    Rational r2 (-12, 3);
Packit 0d464f
Packit 0d464f
    static const int W = 100;
Packit 0d464f
    static const int H = 100;
Packit 0d464f
Packit 0d464f
    Header header (W, H);
Packit 0d464f
    header.insert ("r1", RationalAttribute (r1));
Packit 0d464f
    header.insert ("r2", RationalAttribute (r2));
Packit 0d464f
Packit 0d464f
    {
Packit 0d464f
	RgbaOutputFile out (fileName, header);
Packit 0d464f
	Rgba pixels[W];
Packit 0d464f
Packit 0d464f
	for (int i = 0; i < W; ++i)
Packit 0d464f
	{
Packit 0d464f
	    pixels[i].r = 1;
Packit 0d464f
	    pixels[i].g = 1;
Packit 0d464f
	    pixels[i].b = 1;
Packit 0d464f
	    pixels[i].a = 1;
Packit 0d464f
	}
Packit 0d464f
Packit 0d464f
	out.setFrameBuffer (pixels, 1, 0);
Packit 0d464f
	out.writePixels (H);
Packit 0d464f
    }
Packit 0d464f
Packit 0d464f
    cout << "reading, comparing" << endl;
Packit 0d464f
Packit 0d464f
    {
Packit 0d464f
	RgbaInputFile in (fileName);
Packit 0d464f
Packit 0d464f
	const Rational &r3 =
Packit 0d464f
	    in.header().typedAttribute<RationalAttribute>("r1").value();
Packit 0d464f
Packit 0d464f
	const Rational &r4 =
Packit 0d464f
	    in.header().typedAttribute<RationalAttribute>("r2").value();
Packit 0d464f
Packit 0d464f
	assert (equal (r1, r3));
Packit 0d464f
	assert (equal (r2, r4));
Packit 0d464f
    }
Packit 0d464f
Packit 0d464f
    remove (fileName);
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
generatedFunctions ()
Packit 0d464f
{
Packit 0d464f
    //
Packit 0d464f
    // Most optional standard attributes are of type string, float,
Packit 0d464f
    // etc.  The attribute types are already being tested elsewhere
Packit 0d464f
    // (testAttributes.C), and the convenience functions to access
Packit 0d464f
    // the standard attributes are all generated via macros.  Here
Packit 0d464f
    // we just verify that all the convenience functions exist
Packit 0d464f
    // (that is, ImfStandardAttributes.C and ImfStandardAttributes.h
Packit 0d464f
    // contain the right macro invocations).  If any functions are
Packit 0d464f
    // missing, we should get an error during compiling or linking.
Packit 0d464f
    //
Packit 0d464f
Packit 0d464f
    cout << "automatically generated functions" << endl;
Packit 0d464f
Packit 0d464f
    Header header;
Packit 0d464f
Packit 0d464f
    assert (hasChromaticities (header) == false);
Packit 0d464f
    assert (hasWhiteLuminance (header) == false);
Packit 0d464f
    assert (hasAdoptedNeutral (header) == false);
Packit 0d464f
    assert (hasRenderingTransform (header) == false);
Packit 0d464f
    assert (hasLookModTransform (header) == false);
Packit 0d464f
    assert (hasXDensity (header) == false);
Packit 0d464f
    assert (hasOwner (header) == false);
Packit 0d464f
    assert (hasComments (header) == false);
Packit 0d464f
    assert (hasCapDate (header) == false);
Packit 0d464f
    assert (hasUtcOffset (header) == false);
Packit 0d464f
    assert (hasLongitude (header) == false);
Packit 0d464f
    assert (hasLatitude (header) == false);
Packit 0d464f
    assert (hasAltitude (header) == false);
Packit 0d464f
    assert (hasFocus (header) == false);
Packit 0d464f
    assert (hasExpTime (header) == false);
Packit 0d464f
    assert (hasAperture (header) == false);
Packit 0d464f
    assert (hasIsoSpeed (header) == false);
Packit 0d464f
    assert (hasEnvmap (header) == false);
Packit 0d464f
    assert (hasKeyCode (header) == false);
Packit 0d464f
    assert (hasTimeCode (header) == false);
Packit 0d464f
    assert (hasWrapmodes (header) == false);
Packit 0d464f
    assert (hasFramesPerSecond (header) == false);
Packit 0d464f
    assert (hasMultiView (header) == false);
Packit 0d464f
    assert (hasWorldToCamera (header) == false);
Packit 0d464f
    assert (hasWorldToNDC (header) == false);
Packit 0d464f
    assert (hasDeepImageState (header) == false);
Packit 0d464f
    assert (hasOriginalDataWindow (header) == false);
Packit 0d464f
}
Packit 0d464f
Packit 0d464f
Packit 0d464f
} // namespace
Packit 0d464f
Packit 0d464f
Packit 0d464f
void
Packit 0d464f
testStandardAttributes (const std::string &tempDir)
Packit 0d464f
{
Packit 0d464f
    try
Packit 0d464f
    {
Packit 0d464f
	cout << "Testing optional standard attributes" << endl;
Packit 0d464f
Packit 0d464f
	convertRGBtoXYZ();
Packit 0d464f
Packit 0d464f
	{
Packit 0d464f
	    std::string filename = tempDir + "imf_test_chromaticities.exr";
Packit 0d464f
	    writeReadChromaticities (filename.c_str());
Packit 0d464f
	}
Packit 0d464f
Packit 0d464f
	{
Packit 0d464f
	    std::string fn1 = tempDir + "imf_test_latlong1.exr";
Packit 0d464f
	    std::string fn2 = tempDir + "imf_test_latlong2.exr";
Packit 0d464f
	    latLongMap (fn1.c_str(), fn2.c_str());
Packit 0d464f
	}
Packit 0d464f
Packit 0d464f
	{
Packit 0d464f
	    std::string fn1 = tempDir + "imf_test_cube1.exr";
Packit 0d464f
	    std::string fn2 = tempDir + "imf_test_cube2.exr";
Packit 0d464f
	    cubeMap (fn1.c_str(), fn2.c_str());
Packit 0d464f
	}
Packit 0d464f
Packit 0d464f
	{
Packit 0d464f
	    std::string filename = tempDir + "imf_test_keycode.exr";
Packit 0d464f
	    writeReadKeyCode (filename.c_str());
Packit 0d464f
	}
Packit 0d464f
Packit 0d464f
	{
Packit 0d464f
	    timeCodeMethods();
Packit 0d464f
	    std::string filename = tempDir + "imf_test_timecode.exr";
Packit 0d464f
	    writeReadTimeCode (filename.c_str());
Packit 0d464f
	}
Packit 0d464f
Packit 0d464f
	{
Packit 0d464f
	    rationalMethods();
Packit 0d464f
	    std::string filename = tempDir + "imf_test_rational.exr";
Packit 0d464f
	    writeReadRational (filename.c_str());
Packit 0d464f
	}
Packit 0d464f
Packit 0d464f
	generatedFunctions();
Packit 0d464f
Packit 0d464f
	cout << "ok\n" << endl;
Packit 0d464f
    }
Packit 0d464f
    catch (const std::exception &e)
Packit 0d464f
    {
Packit 0d464f
	cerr << "ERROR -- caught exception: " << e.what() << endl;
Packit 0d464f
	assert (false);
Packit 0d464f
    }
Packit 0d464f
}