400 lines
16 KiB
C++
400 lines
16 KiB
C++
#ifndef _GLUTEXTURETESTUTIL_HPP
|
|
#define _GLUTEXTURETESTUTIL_HPP
|
|
/*-------------------------------------------------------------------------
|
|
* drawElements Quality Program OpenGL ES Utilities
|
|
* ------------------------------------------------
|
|
*
|
|
* Copyright 2014 The Android Open Source Project
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*
|
|
*//*!
|
|
* \file
|
|
* \brief Utility functions and structures for texture tests.
|
|
*
|
|
* This code is originated from the modules/glshared/glsTextureTestUtil.hpp
|
|
* and it is tightly coupled with the GLES and Vulkan texture tests!
|
|
*
|
|
* About coordinates:
|
|
* + Quads consist of 2 triangles, rendered using explicit indices.
|
|
* + All TextureTestUtil functions and classes expect texture coordinates
|
|
* for quads to be specified in order (-1, -1), (-1, 1), (1, -1), (1, 1).
|
|
*//*--------------------------------------------------------------------*/
|
|
|
|
#include "tcuDefs.hpp"
|
|
#include "tcuSurfaceAccess.hpp"
|
|
#include "tcuTestContext.hpp"
|
|
#include "tcuTestLog.hpp"
|
|
#include "tcuTexture.hpp"
|
|
#include "tcuTexCompareVerifier.hpp"
|
|
#include "qpWatchDog.h"
|
|
|
|
namespace glu
|
|
{
|
|
namespace TextureTestUtil
|
|
{
|
|
enum TextureType
|
|
{
|
|
TEXTURETYPE_2D = 0,
|
|
TEXTURETYPE_CUBE,
|
|
TEXTURETYPE_2D_ARRAY,
|
|
TEXTURETYPE_3D,
|
|
TEXTURETYPE_CUBE_ARRAY,
|
|
TEXTURETYPE_1D,
|
|
TEXTURETYPE_1D_ARRAY,
|
|
TEXTURETYPE_BUFFER,
|
|
|
|
TEXTURETYPE_LAST
|
|
};
|
|
|
|
enum SamplerType
|
|
{
|
|
SAMPLERTYPE_FLOAT,
|
|
SAMPLERTYPE_INT,
|
|
SAMPLERTYPE_UINT,
|
|
SAMPLERTYPE_SHADOW,
|
|
|
|
SAMPLERTYPE_FETCH_FLOAT,
|
|
SAMPLERTYPE_FETCH_INT,
|
|
SAMPLERTYPE_FETCH_UINT,
|
|
|
|
SAMPLERTYPE_LAST
|
|
};
|
|
|
|
struct RenderParams
|
|
{
|
|
enum Flags
|
|
{
|
|
PROJECTED = (1<<0),
|
|
USE_BIAS = (1<<1),
|
|
LOG_PROGRAMS = (1<<2),
|
|
LOG_UNIFORMS = (1<<3),
|
|
|
|
LOG_ALL = LOG_PROGRAMS|LOG_UNIFORMS
|
|
};
|
|
|
|
RenderParams (TextureType texType_)
|
|
: texType (texType_)
|
|
, samplerType (SAMPLERTYPE_FLOAT)
|
|
, flags (0)
|
|
, w (1.0f)
|
|
, bias (0.0f)
|
|
, ref (0.0f)
|
|
, colorScale (1.0f)
|
|
, colorBias (0.0f)
|
|
{
|
|
}
|
|
|
|
TextureType texType; //!< Texture type.
|
|
SamplerType samplerType; //!< Sampler type.
|
|
deUint32 flags; //!< Feature flags.
|
|
tcu::Vec4 w; //!< w coordinates for quad vertices.
|
|
float bias; //!< User-supplied bias.
|
|
float ref; //!< Reference value for shadow lookups.
|
|
|
|
// color = lookup() * scale + bias
|
|
tcu::Vec4 colorScale; //!< Scale for texture color values.
|
|
tcu::Vec4 colorBias; //!< Bias for texture color values.
|
|
};
|
|
|
|
enum LodMode
|
|
{
|
|
LODMODE_EXACT = 0, //!< Ideal lod computation.
|
|
LODMODE_MIN_BOUND, //!< Use estimation range minimum bound.
|
|
LODMODE_MAX_BOUND, //!< Use estimation range maximum bound.
|
|
|
|
LODMODE_LAST
|
|
};
|
|
|
|
struct ReferenceParams : public RenderParams
|
|
{
|
|
ReferenceParams (TextureType texType_)
|
|
: RenderParams (texType_)
|
|
, sampler ()
|
|
, lodMode (LODMODE_EXACT)
|
|
, minLod (-1000.0f)
|
|
, maxLod (1000.0f)
|
|
, baseLevel (0)
|
|
, maxLevel (1000)
|
|
, unnormal (false)
|
|
{
|
|
}
|
|
|
|
ReferenceParams (TextureType texType_, const tcu::Sampler& sampler_, LodMode lodMode_ = LODMODE_EXACT)
|
|
: RenderParams (texType_)
|
|
, sampler (sampler_)
|
|
, lodMode (lodMode_)
|
|
, minLod (-1000.0f)
|
|
, maxLod (1000.0f)
|
|
, baseLevel (0)
|
|
, maxLevel (1000)
|
|
, unnormal (false)
|
|
{
|
|
}
|
|
|
|
tcu::Sampler sampler;
|
|
LodMode lodMode;
|
|
float minLod;
|
|
float maxLod;
|
|
int baseLevel;
|
|
int maxLevel;
|
|
bool unnormal;
|
|
};
|
|
|
|
|
|
SamplerType getSamplerType (tcu::TextureFormat format);
|
|
SamplerType getFetchSamplerType (tcu::TextureFormat format);
|
|
|
|
// Similar to sampleTexture() except uses texelFetch.
|
|
void fetchTexture (const tcu::SurfaceAccess& dst, const tcu::ConstPixelBufferAccess& src, const float* texCoord, const tcu::Vec4& colorScale, const tcu::Vec4& colorBias);
|
|
|
|
void sampleTexture (const tcu::SurfaceAccess& dst, const tcu::Texture2DView& src, const float* texCoord, const ReferenceParams& params);
|
|
void sampleTexture (const tcu::SurfaceAccess& dst, const tcu::TextureCubeView& src, const float* texCoord, const ReferenceParams& params);
|
|
void sampleTexture (const tcu::SurfaceAccess& dst, const tcu::Texture2DArrayView& src, const float* texCoord, const ReferenceParams& params);
|
|
void sampleTexture (const tcu::SurfaceAccess& dst, const tcu::Texture3DView& src, const float* texCoord, const ReferenceParams& params);
|
|
void sampleTexture (const tcu::SurfaceAccess& dst, const tcu::TextureCubeArrayView& src, const float* texCoord, const ReferenceParams& params);
|
|
void sampleTexture (const tcu::SurfaceAccess& dst, const tcu::Texture1DView& src, const float* texCoord, const ReferenceParams& params);
|
|
void sampleTexture (const tcu::SurfaceAccess& dst, const tcu::Texture1DArrayView& src, const float* texCoord, const ReferenceParams& params);
|
|
|
|
float triangleInterpolate (float v0, float v1, float v2, float x, float y);
|
|
float triangleInterpolate (const tcu::Vec3& v, float x, float y);
|
|
|
|
float computeLodFromDerivates (LodMode mode, float dudx, float dudy);
|
|
float computeLodFromDerivates (LodMode mode, float dudx, float dvdx, float dudy, float dvdy);
|
|
float computeLodFromDerivates (LodMode mode, float dudx, float dvdx, float dwdx, float dudy, float dvdy, float dwdy);
|
|
|
|
float computeNonProjectedTriLod (LodMode mode, const tcu::IVec2& dstSize, deInt32 srcSize, const tcu::Vec3& sq);
|
|
float computeNonProjectedTriLod (LodMode mode, const tcu::IVec2& dstSize, const tcu::IVec2& srcSize, const tcu::Vec3& sq, const tcu::Vec3& tq);
|
|
float computeNonProjectedTriLod (LodMode mode, const tcu::IVec2& dstSize, const tcu::IVec3& srcSize, const tcu::Vec3& sq, const tcu::Vec3& tq, const tcu::Vec3& rq);
|
|
|
|
void computeQuadTexCoord1D (std::vector<float>& dst, float left, float right);
|
|
void computeQuadTexCoord1DArray (std::vector<float>& dst, int layerNdx, float left, float right);
|
|
void computeQuadTexCoord2D (std::vector<float>& dst, const tcu::Vec2& bottomLeft, const tcu::Vec2& topRight);
|
|
void computeQuadTexCoord2DArray (std::vector<float>& dst, int layerNdx, const tcu::Vec2& bottomLeft, const tcu::Vec2& topRight);
|
|
void computeQuadTexCoord3D (std::vector<float>& dst, const tcu::Vec3& p0, const tcu::Vec3& p1, const tcu::IVec3& dirSwz);
|
|
void computeQuadTexCoordCube (std::vector<float>& dst, tcu::CubeFace face);
|
|
void computeQuadTexCoordCube (std::vector<float>& dst, tcu::CubeFace face, const tcu::Vec2& bottomLeft, const tcu::Vec2& topRight);
|
|
void computeQuadTexCoordCubeArray (std::vector<float>& dst, tcu::CubeFace face, const tcu::Vec2& bottomLeft, const tcu::Vec2& topRight, const tcu::Vec2& layerRange);
|
|
|
|
bool compareImages (tcu::TestLog& log, const char* name, const char* desc, const tcu::Surface& reference, const tcu::Surface& rendered, tcu::RGBA threshold);
|
|
bool compareImages (tcu::TestLog& log, const tcu::Surface& reference, const tcu::Surface& rendered, tcu::RGBA threshold);
|
|
int measureAccuracy (tcu::TestLog& log, const tcu::Surface& reference, const tcu::Surface& rendered, int bestScoreDiff, int worstScoreDiff);
|
|
|
|
int computeTextureLookupDiff (const tcu::ConstPixelBufferAccess& result,
|
|
const tcu::ConstPixelBufferAccess& reference,
|
|
const tcu::PixelBufferAccess& errorMask,
|
|
const tcu::Texture1DView& src,
|
|
const float* texCoord,
|
|
const ReferenceParams& sampleParams,
|
|
const tcu::LookupPrecision& lookupPrec,
|
|
const tcu::LodPrecision& lodPrec,
|
|
qpWatchDog* watchDog);
|
|
|
|
int computeTextureLookupDiff (const tcu::ConstPixelBufferAccess& result,
|
|
const tcu::ConstPixelBufferAccess& reference,
|
|
const tcu::PixelBufferAccess& errorMask,
|
|
const tcu::Texture2DView& src,
|
|
const float* texCoord,
|
|
const ReferenceParams& sampleParams,
|
|
const tcu::LookupPrecision& lookupPrec,
|
|
const tcu::LodPrecision& lodPrec,
|
|
qpWatchDog* watchDog);
|
|
|
|
int computeTextureLookupDiff (const tcu::ConstPixelBufferAccess& result,
|
|
const tcu::ConstPixelBufferAccess& reference,
|
|
const tcu::PixelBufferAccess& errorMask,
|
|
const tcu::TextureCubeView& src,
|
|
const float* texCoord,
|
|
const ReferenceParams& sampleParams,
|
|
const tcu::LookupPrecision& lookupPrec,
|
|
const tcu::LodPrecision& lodPrec,
|
|
qpWatchDog* watchDog);
|
|
|
|
int computeTextureLookupDiff (const tcu::ConstPixelBufferAccess& result,
|
|
const tcu::ConstPixelBufferAccess& reference,
|
|
const tcu::PixelBufferAccess& errorMask,
|
|
const tcu::Texture1DArrayView& src,
|
|
const float* texCoord,
|
|
const ReferenceParams& sampleParams,
|
|
const tcu::LookupPrecision& lookupPrec,
|
|
const tcu::LodPrecision& lodPrec,
|
|
qpWatchDog* watchDog);
|
|
|
|
int computeTextureLookupDiff (const tcu::ConstPixelBufferAccess& result,
|
|
const tcu::ConstPixelBufferAccess& reference,
|
|
const tcu::PixelBufferAccess& errorMask,
|
|
const tcu::Texture2DArrayView& src,
|
|
const float* texCoord,
|
|
const ReferenceParams& sampleParams,
|
|
const tcu::LookupPrecision& lookupPrec,
|
|
const tcu::LodPrecision& lodPrec,
|
|
qpWatchDog* watchDog);
|
|
|
|
int computeTextureLookupDiff (const tcu::ConstPixelBufferAccess& result,
|
|
const tcu::ConstPixelBufferAccess& reference,
|
|
const tcu::PixelBufferAccess& errorMask,
|
|
const tcu::Texture3DView& src,
|
|
const float* texCoord,
|
|
const ReferenceParams& sampleParams,
|
|
const tcu::LookupPrecision& lookupPrec,
|
|
const tcu::LodPrecision& lodPrec,
|
|
qpWatchDog* watchDog);
|
|
|
|
int computeTextureLookupDiff (const tcu::ConstPixelBufferAccess& result,
|
|
const tcu::ConstPixelBufferAccess& reference,
|
|
const tcu::PixelBufferAccess& errorMask,
|
|
const tcu::TextureCubeArrayView& src,
|
|
const float* texCoord,
|
|
const ReferenceParams& sampleParams,
|
|
const tcu::LookupPrecision& lookupPrec,
|
|
const tcu::IVec4& coordBits,
|
|
const tcu::LodPrecision& lodPrec,
|
|
qpWatchDog* watchDog);
|
|
|
|
bool verifyTextureResult (tcu::TestContext& testCtx,
|
|
const tcu::ConstPixelBufferAccess& result,
|
|
const tcu::Texture1DView& src,
|
|
const float* texCoord,
|
|
const ReferenceParams& sampleParams,
|
|
const tcu::LookupPrecision& lookupPrec,
|
|
const tcu::LodPrecision& lodPrec,
|
|
const tcu::PixelFormat& pixelFormat);
|
|
|
|
bool verifyTextureResult (tcu::TestContext& testCtx,
|
|
const tcu::ConstPixelBufferAccess& result,
|
|
const tcu::Texture2DView& src,
|
|
const float* texCoord,
|
|
const ReferenceParams& sampleParams,
|
|
const tcu::LookupPrecision& lookupPrec,
|
|
const tcu::LodPrecision& lodPrec,
|
|
const tcu::PixelFormat& pixelFormat);
|
|
|
|
bool verifyTextureResult (tcu::TestContext& testCtx,
|
|
const tcu::ConstPixelBufferAccess& result,
|
|
const tcu::TextureCubeView& src,
|
|
const float* texCoord,
|
|
const ReferenceParams& sampleParams,
|
|
const tcu::LookupPrecision& lookupPrec,
|
|
const tcu::LodPrecision& lodPrec,
|
|
const tcu::PixelFormat& pixelFormat);
|
|
|
|
bool verifyTextureResult (tcu::TestContext& testCtx,
|
|
const tcu::ConstPixelBufferAccess& result,
|
|
const tcu::Texture1DArrayView& src,
|
|
const float* texCoord,
|
|
const ReferenceParams& sampleParams,
|
|
const tcu::LookupPrecision& lookupPrec,
|
|
const tcu::LodPrecision& lodPrec,
|
|
const tcu::PixelFormat& pixelFormat);
|
|
|
|
bool verifyTextureResult (tcu::TestContext& testCtx,
|
|
const tcu::ConstPixelBufferAccess& result,
|
|
const tcu::Texture2DArrayView& src,
|
|
const float* texCoord,
|
|
const ReferenceParams& sampleParams,
|
|
const tcu::LookupPrecision& lookupPrec,
|
|
const tcu::LodPrecision& lodPrec,
|
|
const tcu::PixelFormat& pixelFormat);
|
|
|
|
bool verifyTextureResult (tcu::TestContext& testCtx,
|
|
const tcu::ConstPixelBufferAccess& result,
|
|
const tcu::Texture3DView& src,
|
|
const float* texCoord,
|
|
const ReferenceParams& sampleParams,
|
|
const tcu::LookupPrecision& lookupPrec,
|
|
const tcu::LodPrecision& lodPrec,
|
|
const tcu::PixelFormat& pixelFormat);
|
|
|
|
bool verifyTextureResult (tcu::TestContext& testCtx,
|
|
const tcu::ConstPixelBufferAccess& result,
|
|
const tcu::TextureCubeArrayView& src,
|
|
const float* texCoord,
|
|
const ReferenceParams& sampleParams,
|
|
const tcu::LookupPrecision& lookupPrec,
|
|
const tcu::IVec4& coordBits,
|
|
const tcu::LodPrecision& lodPrec,
|
|
const tcu::PixelFormat& pixelFormat);
|
|
|
|
int computeTextureCompareDiff (const tcu::ConstPixelBufferAccess& result,
|
|
const tcu::ConstPixelBufferAccess& reference,
|
|
const tcu::PixelBufferAccess& errorMask,
|
|
const tcu::Texture2DView& src,
|
|
const float* texCoord,
|
|
const ReferenceParams& sampleParams,
|
|
const tcu::TexComparePrecision& comparePrec,
|
|
const tcu::LodPrecision& lodPrec,
|
|
const tcu::Vec3& nonShadowThreshold);
|
|
|
|
int computeTextureCompareDiff (const tcu::ConstPixelBufferAccess& result,
|
|
const tcu::ConstPixelBufferAccess& reference,
|
|
const tcu::PixelBufferAccess& errorMask,
|
|
const tcu::TextureCubeView& src,
|
|
const float* texCoord,
|
|
const ReferenceParams& sampleParams,
|
|
const tcu::TexComparePrecision& comparePrec,
|
|
const tcu::LodPrecision& lodPrec,
|
|
const tcu::Vec3& nonShadowThreshold);
|
|
|
|
int computeTextureCompareDiff (const tcu::ConstPixelBufferAccess& result,
|
|
const tcu::ConstPixelBufferAccess& reference,
|
|
const tcu::PixelBufferAccess& errorMask,
|
|
const tcu::Texture2DArrayView& src,
|
|
const float* texCoord,
|
|
const ReferenceParams& sampleParams,
|
|
const tcu::TexComparePrecision& comparePrec,
|
|
const tcu::LodPrecision& lodPrec,
|
|
const tcu::Vec3& nonShadowThreshold);
|
|
|
|
|
|
inline tcu::IVec4 getBitsVec (const tcu::PixelFormat& format)
|
|
{
|
|
return tcu::IVec4(format.redBits, format.greenBits, format.blueBits, format.alphaBits);
|
|
}
|
|
|
|
inline tcu::BVec4 getCompareMask (const tcu::PixelFormat& format)
|
|
{
|
|
return tcu::BVec4(format.redBits > 0,
|
|
format.greenBits > 0,
|
|
format.blueBits > 0,
|
|
format.alphaBits > 0);
|
|
}
|
|
|
|
|
|
// Mipmap generation comparison.
|
|
|
|
struct GenMipmapPrecision
|
|
{
|
|
tcu::IVec3 filterBits; //!< Bits in filtering parameters (fixed-point).
|
|
tcu::Vec4 colorThreshold; //!< Threshold for color value comparison.
|
|
tcu::BVec4 colorMask; //!< Color channel comparison mask.
|
|
};
|
|
|
|
qpTestResult compareGenMipmapResult (tcu::TestLog& log, const tcu::Texture2D& resultTexture, const tcu::Texture2D& level0Reference, const GenMipmapPrecision& precision);
|
|
qpTestResult compareGenMipmapResult (tcu::TestLog& log, const tcu::TextureCube& resultTexture, const tcu::TextureCube& level0Reference, const GenMipmapPrecision& precision);
|
|
|
|
// Utility for logging texture gradient ranges.
|
|
struct LogGradientFmt
|
|
{
|
|
LogGradientFmt (const tcu::Vec4* min_, const tcu::Vec4* max_) : valueMin(min_), valueMax(max_) {}
|
|
const tcu::Vec4* valueMin;
|
|
const tcu::Vec4* valueMax;
|
|
};
|
|
|
|
std::ostream& operator<< (std::ostream& str, const LogGradientFmt& fmt);
|
|
inline LogGradientFmt formatGradient (const tcu::Vec4* minVal, const tcu::Vec4* maxVal) { return LogGradientFmt(minVal, maxVal); }
|
|
|
|
} // TextureTestUtil
|
|
} // glu
|
|
|
|
#endif // _GLUTEXTURETESTUTIL_HPP
|