1 #ifndef _VKTSAMPLEVERIFIERUTIL_HPP
2 #define _VKTSAMPLEVERIFIERUTIL_HPP
3 /*-------------------------------------------------------------------------
4  * Vulkan Conformance Tests
5  * ------------------------
6  *
7  * Copyright (c) 2016 Google Inc.
8  *
9  * Licensed under the Apache License, Version 2.0 (the "License");
10  * you may not use this file except in compliance with the License.
11  * You may obtain a copy of the License at
12  *
13  *      http://www.apache.org/licenses/LICENSE-2.0
14  *
15  * Unless required by applicable law or agreed to in writing, software
16  * distributed under the License is distributed on an "AS IS" BASIS,
17  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18  * See the License for the specific language governing permissions and
19  * limitations under the License.
20  *
21  *//*!
22  * \file
23  * \brief GPU image sample verification
24  *//*--------------------------------------------------------------------*/
25 
26 #include "vktSampleVerifier.hpp"
27 
28 #include "deMath.h"
29 #include "tcuFloatFormat.hpp"
30 #include "tcuTexture.hpp"
31 #include "vkDefs.hpp"
32 
33 namespace vkt
34 {
35 namespace texture
36 {
37 namespace util
38 {
39 
40 float		addUlp						(float							num,
41 										 deInt32						ulp);
42 
43 deInt32		mod							(const deInt32					a,
44 										 const deInt32					n);
45 deInt32	    mirror						(const deInt32					n);
46 
47 tcu::Vec2	calcLodBounds				(const tcu::Vec3&				dPdx,
48 										 const tcu::Vec3&				dPdy,
49 										 const tcu::IVec3				size,
50 										 const float					lodBias,
51 										 const float					lodMin,
52 										 const float					lodMax);
53 tcu::UVec2	calcLevelBounds				(const tcu::Vec2&				lodBounds,
54 										 const int						levelCount,
55 										 vk::VkSamplerMipmapMode		mipmapFilter);
56 tcu::Vec2	calcLevelLodBounds			(const tcu::Vec2&				lodBounds,
57 										 int							level);
58 
59 void		wrapTexelGridCoordLinear	(tcu::IVec3&					baseTexel,
60 										 tcu::IVec3&					texelGridOffset,
61 										 const int						coordBits,
62 										 const ImgDim					dim);
63 void		calcTexelBaseOffset			(const tcu::IVec3&				gridCoord,
64 										 const int						coordBits,
65 										 tcu::IVec3&					baseTexel,
66 										 tcu::IVec3&					texelGridOffset);
67 void		calcTexelGridCoordRange		(const tcu::Vec3&				unnormalizedCoordMin,
68 										 const tcu::Vec3&				unnormalizedCoordMax,
69 										 const int						coordBits,
70 										 tcu::IVec3&					gridCoordMin,
71 										 tcu::IVec3&					gridCoordMax);
72 void		calcUnnormalizedCoordRange	(const tcu::Vec4&				coord,
73 										 const tcu::IVec3&				levelSize,
74 										 const tcu::FloatFormat&		internalFormat,
75 										 tcu::Vec3&						unnormalizedCoordMin,
76 										 tcu::Vec3&						unnormalizedCoordMax);
77 void		calcCubemapFaceCoords		(const tcu::Vec3&				r,
78 										 const tcu::Vec3&				drdx,
79 										 const tcu::Vec3&				drdy,
80 										 const int						faceNdx,
81 										 tcu::Vec2&						coordFace,
82 										 tcu::Vec2&						dPdxFace,
83 										 tcu::Vec2&						dPdyFace);
84 int			calcCandidateCubemapFaces	(const tcu::Vec3&				r);
85 deInt32		wrapTexelCoord				(const deInt32					coord,
86 										 const int						size,
87 										 const vk::VkSamplerAddressMode wrap);
88 void		wrapCubemapEdge				(const tcu::IVec2&				coord,
89 										 const tcu::IVec2&				size,
90 										 const int						faceNdx,
91 										 tcu::IVec2&					newCoord,
92 										 int&							newFaceNdx);
93 void		wrapCubemapCorner			(const tcu::IVec2&				coord,
94 										 const tcu::IVec2&				size,
95 										 const int						faceNdx,
96 										 int&							adjacentFace1,
97 										 int&							adjacentFace2,
98 										 tcu::IVec2&					cornerCoord0,
99 										 tcu::IVec2&					cornerCoord1,
100 										 tcu::IVec2&					cornerCoord2);
101 
102 void		convertFormat				(const void*					pixelPtr,
103 										 tcu::TextureFormat				texFormat,
104 										 tcu::FloatFormat				internalFormat,
105 										 tcu::Vec4&						resultMin,
106 										 tcu::Vec4&						resultMax);
107 
108 template <int Size>
isEqualRelEpsilon(const tcu::Vector<float,Size> & a,const tcu::Vector<float,Size> & b,const float epsilon)109 bool isEqualRelEpsilon (const tcu::Vector<float, Size>& a, const tcu::Vector<float, Size>& b, const float epsilon)
110 {
111 	for (int compNdx = 0; compNdx < Size; ++compNdx)
112 	{
113 		if (!isEqualRelEpsilon(a[compNdx], b[compNdx], epsilon))
114 		{
115 			return false;
116 		}
117 	}
118 
119 	return true;
120 }
121 
122 template <int Size>
isInRange(const tcu::Vector<float,Size> & v,const tcu::Vector<float,Size> & min,const tcu::Vector<float,Size> & max)123 bool isInRange (const tcu::Vector<float, Size>& v, const tcu::Vector<float, Size>& min, const tcu::Vector<float, Size>& max)
124 {
125 	for (int compNdx = 0; compNdx < Size; ++compNdx)
126 	{
127 		if (v[compNdx] < min[compNdx] || v[compNdx] > max[compNdx])
128 		{
129 			return false;
130 		}
131 	}
132 
133 	return true;
134 }
135 
136 template <int Size>
floor(const tcu::Vector<float,Size> & v)137 tcu::Vector<float, Size> floor (const tcu::Vector<float, Size>& v)
138 {
139 	tcu::Vector<float, Size> result;
140 
141 	for (int compNdx = 0; compNdx < Size; ++compNdx)
142 	{
143 		result[compNdx] = (float)deFloor(v[compNdx]);
144 	}
145 
146 	return result;
147 }
148 
149 template <int Size>
ceil(const tcu::Vector<float,Size> & v)150 tcu::Vector<float, Size> ceil (const tcu::Vector<float, Size>& v)
151 {
152 	tcu::Vector<float, Size> result;
153 
154 	for (int compNdx = 0; compNdx < Size; ++compNdx)
155 	{
156 		result[compNdx] = (float)deCeil(v[compNdx]);
157 	}
158 
159 	return result;
160 }
161 
162 template <int Size>
abs(const tcu::Vector<float,Size> & v)163 tcu::Vector<float, Size> abs (const tcu::Vector<float, Size>& v)
164 {
165 	tcu::Vector<float, Size> result;
166 
167 	for (int compNdx = 0; compNdx < Size; ++compNdx)
168 	{
169 		result[compNdx] = de::abs(v[compNdx]);
170 	}
171 
172 	return result;
173 }
174 
175 } // util
176 } // texture
177 } // vkt
178 
179 #endif // _VKTSAMPLEVERIFIERUTIL_HPP
180