Update stress test.

Fix errors in single color compressor.
This commit is contained in:
castano 2008-02-28 03:09:51 +00:00
parent b41752aa84
commit d0c21cecfb
3 changed files with 25 additions and 11 deletions

View File

@ -359,6 +359,12 @@ void QuickCompress::compressDXT1(Color32 c, BlockDXT1 * dxtBlock)
dxtBlock->col1.g = OMatch6[c.g][1]; dxtBlock->col1.g = OMatch6[c.g][1];
dxtBlock->col1.b = OMatch5[c.b][1]; dxtBlock->col1.b = OMatch5[c.b][1];
dxtBlock->indices = 0xaaaaaaaa; dxtBlock->indices = 0xaaaaaaaa;
if (dxtBlock->col0.u < dxtBlock->col1.u)
{
swap(dxtBlock->col0.u, dxtBlock->col1.u);
dxtBlock->indices ^= 0x55555555;
}
} }
void QuickCompress::compressDXT1(const ColorBlock & rgba, BlockDXT1 * dxtBlock) void QuickCompress::compressDXT1(const ColorBlock & rgba, BlockDXT1 * dxtBlock)

View File

@ -1012,8 +1012,16 @@ __device__ void saveSingleColorBlockDXT1(float3 color, uint2 * result)
ushort color0 = (OMatch5[r][0] << 11) | (OMatch6[g][0] << 5) | OMatch5[b][0]; ushort color0 = (OMatch5[r][0] << 11) | (OMatch6[g][0] << 5) | OMatch5[b][0];
ushort color1 = (OMatch5[r][1] << 11) | (OMatch6[g][1] << 5) | OMatch5[b][1]; ushort color1 = (OMatch5[r][1] << 11) | (OMatch6[g][1] << 5) | OMatch5[b][1];
if (color0 < color1)
{
result[bid].x = (color0 << 16) | color1;
result[bid].y = 0xffffffff;
}
else
{
result[bid].x = (color1 << 16) | color0; result[bid].x = (color1 << 16) | color0;
result[bid].y = 0xaaaaaaaa; result[bid].y = 0xaaaaaaaa;
}
} }
@ -1029,14 +1037,14 @@ __global__ void compressDXT1(const uint * permutations, const uint * image, uint
loadColorBlock(image, colors, sums, xrefs, &sameColor); loadColorBlock(image, colors, sums, xrefs, &sameColor);
__syncthreads();
if (sameColor) if (sameColor)
{ {
if (threadIdx.x == 0) saveSingleColorBlockDXT1(colors[0], result); if (threadIdx.x == 0) saveSingleColorBlockDXT1(colors[0], result);
return; return;
} }
__syncthreads();
ushort bestStart, bestEnd; ushort bestStart, bestEnd;
uint bestPermutation; uint bestPermutation;

View File

@ -31,8 +31,8 @@
#define FRAME_COUNT 1000 #define FRAME_COUNT 1000
#define WIDTH 1024 #define WIDTH 2048
#define HEIGHT 1024 #define HEIGHT 2048
#define INPUT_SIZE (WIDTH*HEIGHT) #define INPUT_SIZE (WIDTH*HEIGHT)
#define OUTPUT_SIZE (WIDTH*HEIGHT/16*2) #define OUTPUT_SIZE (WIDTH*HEIGHT/16*2)
@ -180,20 +180,20 @@ int main(int argc, char *argv[])
//precomp(); //precomp();
nvtt::InputOptions inputOptions; nvtt::InputOptions inputOptions;
inputOptions.setTextureLayout(nvtt::TextureType_2D, 1024, 1024); inputOptions.setTextureLayout(nvtt::TextureType_2D, WIDTH, HEIGHT);
for (int i = 0; i < 1024 * 1024; i++) for (int i = 0; i < INPUT_SIZE; i++)
{ {
s_input[i] = rand(); s_input[i] = rand();
} }
inputOptions.setMipmapData(s_input, 1024, 1024); inputOptions.setMipmapData(s_input, WIDTH, HEIGHT);
inputOptions.setMipmapGeneration(false); inputOptions.setMipmapGeneration(false);
nvtt::CompressionOptions compressionOptions; nvtt::CompressionOptions compressionOptions;
// compressionOptions.setFormat(nvtt::Format_DXT1); compressionOptions.setFormat(nvtt::Format_DXT1);
// compressionOptions.setFormat(nvtt::Format_DXT1n); // compressionOptions.setFormat(nvtt::Format_DXT1n);
compressionOptions.setFormat(nvtt::Format_CTX1); // compressionOptions.setFormat(nvtt::Format_CTX1);
nvtt::OutputOptions outputOptions; nvtt::OutputOptions outputOptions;
outputOptions.setOutputHeader(false); outputOptions.setOutputHeader(false);