| #ifndef _TCUTEXVERIFIERUTIL_HPP |
| #define _TCUTEXVERIFIERUTIL_HPP |
| /*------------------------------------------------------------------------- |
| * drawElements Quality Program Tester Core |
| * ---------------------------------------- |
| * |
| * 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 Internal utilities shared between TexLookup and TexCompare verifiers. |
| *//*--------------------------------------------------------------------*/ |
| |
| #include "tcuDefs.hpp" |
| #include "tcuTexture.hpp" |
| |
| namespace tcu |
| { |
| namespace TexVerifierUtil |
| { |
| |
| // Error bound utilities |
| |
| float computeFloatingPointError (const float value, const int numAccurateBits); |
| float computeFixedPointError (const int numAccurateBits); |
| float computeColorBitsError (const int bits, const int numAccurateBits); |
| |
| template<int Size> |
| inline Vector<float, Size> computeFloatingPointError (const Vector<float, Size>& value, const Vector<deInt32, Size>& numAccurateBits) |
| { |
| Vector<float, Size> res; |
| for (int ndx = 0; ndx < Size; ndx++) |
| res[ndx] = computeFloatingPointError(value[ndx], numAccurateBits[ndx]); |
| return res; |
| } |
| |
| template<int Size> |
| inline Vector<float, Size> computeFixedPointError (const Vector<deInt32, Size>& numAccurateBits) |
| { |
| Vector<float, Size> res; |
| for (int ndx = 0; ndx < Size; ndx++) |
| res[ndx] = computeFixedPointError(numAccurateBits[ndx]); |
| return res; |
| } |
| |
| template<int Size> |
| inline Vector<float, Size> computeColorBitsError(const Vector<deInt32, Size>& bits, const Vector<deInt32, Size>& numAccurateBits) |
| { |
| Vector<float, Size> res; |
| for (int ndx = 0; ndx < Size; ndx++) |
| res[ndx] = computeColorBitsError(bits[ndx], numAccurateBits[ndx]); |
| return res; |
| } |
| |
| // Sampler introspection |
| |
| inline bool isNearestMipmapFilter(const Sampler::FilterMode mode) |
| { |
| return mode == Sampler::NEAREST_MIPMAP_NEAREST || mode == Sampler::LINEAR_MIPMAP_NEAREST || mode == Sampler::CUBIC_MIPMAP_NEAREST; |
| } |
| |
| inline bool isLinearMipmapFilter(const Sampler::FilterMode mode) |
| { |
| return mode == Sampler::NEAREST_MIPMAP_LINEAR || mode == Sampler::LINEAR_MIPMAP_LINEAR || mode == Sampler::CUBIC_MIPMAP_LINEAR; |
| } |
| |
| inline bool isMipmapFilter(const Sampler::FilterMode mode) |
| { |
| return isNearestMipmapFilter(mode) || isLinearMipmapFilter(mode); |
| } |
| |
| inline bool isNearestFilter(const Sampler::FilterMode mode) |
| { |
| return mode == Sampler::NEAREST || mode == Sampler::NEAREST_MIPMAP_NEAREST || mode == Sampler::NEAREST_MIPMAP_LINEAR; |
| } |
| |
| inline bool isLinearFilter(const Sampler::FilterMode mode) |
| { |
| return mode == Sampler::LINEAR || mode == Sampler::LINEAR_MIPMAP_NEAREST || mode == Sampler::LINEAR_MIPMAP_LINEAR; |
| } |
| |
| inline bool isCubicFilter(const Sampler::FilterMode mode) |
| { |
| return mode == Sampler::CUBIC || mode == Sampler::CUBIC_MIPMAP_NEAREST || mode == Sampler::CUBIC_MIPMAP_LINEAR; |
| } |
| |
| inline Sampler::FilterMode getLevelFilter(const Sampler::FilterMode mode) |
| { |
| if (isNearestFilter(mode)) |
| return Sampler::NEAREST; |
| if (isLinearFilter(mode)) |
| return Sampler::LINEAR; |
| return Sampler::CUBIC; |
| } |
| |
| inline bool isWrapModeSupported (const Sampler::WrapMode mode) |
| { |
| return mode != Sampler::MIRRORED_REPEAT_CL && mode != Sampler::REPEAT_CL; |
| } |
| |
| // Misc utilities |
| |
| Vec2 computeNonNormalizedCoordBounds (const bool normalizedCoords, const int dim, const float coord, const int coordBits, const int uvBits); |
| void getPossibleCubeFaces (const Vec3& coord, const IVec3& bits, CubeFace* faces, int& numFaces); |
| |
| Sampler getUnnormalizedCoordSampler (const Sampler& sampler); |
| int wrap (Sampler::WrapMode mode, int c, int size); |
| |
| } // TexVerifierUtil |
| } // tcu |
| |
| #endif // _TCUTEXVERIFIERUTIL_HPP |