Fix weighted cluster fit.

Set metric before color sets.
This commit is contained in:
castano 2008-02-01 19:48:12 +00:00
parent 77168bb40b
commit b7f3ce664f
8 changed files with 55 additions and 30 deletions

View File

@ -30,9 +30,14 @@
namespace squish {
ClusterFit::ClusterFit( ColourSet const* colours, int flags )
: ColourFit( colours, flags )
ClusterFit::ClusterFit()
{
}
void ClusterFit::SetColourSet( ColourSet const* colours, int flags )
{
ColourFit::SetColourSet( colours, flags );
// initialise the best error
#if SQUISH_USE_SIMD
m_besterror = VEC4_CONST( FLT_MAX );
@ -91,7 +96,7 @@ ClusterFit::ClusterFit( ColourSet const* colours, int flags )
}
void ClusterFit::setMetric(float r, float g, float b)
void ClusterFit::SetMetric(float r, float g, float b)
{
#if SQUISH_USE_SIMD
m_metric = Vec4(r, g, b, 0);
@ -101,7 +106,7 @@ void ClusterFit::setMetric(float r, float g, float b)
m_metricSqr = m_metric * m_metric;
}
float ClusterFit::bestError() const
float ClusterFit::GetBestError() const
{
#if SQUISH_USE_SIMD
return m_besterror.GetVec3().X();

View File

@ -36,10 +36,12 @@ namespace squish {
class ClusterFit : public ColourFit
{
public:
ClusterFit( ColourSet const* colours, int flags );
ClusterFit();
void setMetric(float r, float g, float b);
float bestError() const;
void SetColourSet( ColourSet const* colours, int flags );
void SetMetric(float r, float g, float b);
float GetBestError() const;
private:
virtual void Compress3( void* block );

View File

@ -28,12 +28,16 @@
namespace squish {
ColourFit::ColourFit( ColourSet const* colours, int flags )
: m_colours( colours ),
m_flags( flags )
ColourFit::ColourFit()
{
}
void ColourFit::SetColourSet( ColourSet const* colours, int flags )
{
m_colours = colours;
m_flags = flags;
}
void ColourFit::Compress( void* block )
{
bool isDxt1 = ( ( m_flags & kDxt1 ) != 0 );

View File

@ -36,7 +36,9 @@ class ColourSet;
class ColourFit
{
public:
ColourFit( ColourSet const* colours, int flags );
ColourFit();
void SetColourSet( ColourSet const* colours, int flags );
void Compress( void* block );

View File

@ -31,9 +31,14 @@
namespace squish {
FastClusterFit::FastClusterFit( ColourSet const* colours, int flags ) :
ColourFit( colours, flags )
FastClusterFit::FastClusterFit()
{
}
void FastClusterFit::SetColourSet( ColourSet const* colours, int flags )
{
ColourFit::SetColourSet( colours, flags );
// initialise the best error
#if SQUISH_USE_SIMD
m_besterror = VEC4_CONST( FLT_MAX );
@ -102,7 +107,7 @@ struct Precomp {
static Precomp s_threeElement[153];
static Precomp s_fourElement[969];
void FastClusterFit::doPrecomputation()
void FastClusterFit::DoPrecomputation()
{
int i = 0;
@ -177,7 +182,7 @@ void FastClusterFit::doPrecomputation()
//printf("%d four cluster elements\n", i);
}
void FastClusterFit::setMetric(float r, float g, float b)
void FastClusterFit::SetMetric(float r, float g, float b)
{
#if SQUISH_USE_SIMD
m_metric = Vec4(r, g, b, 0);
@ -187,7 +192,7 @@ void FastClusterFit::setMetric(float r, float g, float b)
m_metricSqr = m_metric * m_metric;
}
float FastClusterFit::bestError() const
float FastClusterFit::GetBestError() const
{
#if SQUISH_USE_SIMD
Vec4 x = m_xxsum * m_metricSqr;

View File

@ -37,12 +37,14 @@ namespace squish {
class FastClusterFit : public ColourFit
{
public:
FastClusterFit( ColourSet const* colours, int flags );
FastClusterFit();
void setMetric(float r, float g, float b);
float bestError() const;
void SetColourSet( ColourSet const* colours, int flags );
static void doPrecomputation();
void SetMetric(float r, float g, float b);
float GetBestError() const;
static void DoPrecomputation();
// Make them public
virtual void Compress3( void* block );

View File

@ -32,9 +32,14 @@
namespace squish {
WeightedClusterFit::WeightedClusterFit( ColourSet const* colours, int flags ) :
ColourFit( colours, flags )
WeightedClusterFit::WeightedClusterFit()
{
}
void WeightedClusterFit::SetColourSet( ColourSet const* colours, int flags )
{
ColourFit::SetColourSet( colours, flags );
// initialise the best error
#if SQUISH_USE_SIMD
m_besterror = VEC4_CONST( FLT_MAX );
@ -100,7 +105,7 @@ WeightedClusterFit::WeightedClusterFit( ColourSet const* colours, int flags ) :
}
void WeightedClusterFit::setMetric(float r, float g, float b)
void WeightedClusterFit::SetMetric(float r, float g, float b)
{
#if SQUISH_USE_SIMD
m_metric = Vec4(r, g, b, 0);
@ -110,7 +115,7 @@ void WeightedClusterFit::setMetric(float r, float g, float b)
m_metricSqr = m_metric * m_metric;
}
float WeightedClusterFit::bestError() const
float WeightedClusterFit::GetBestError() const
{
#if SQUISH_USE_SIMD
Vec4 x = m_xxsum * m_metricSqr;

View File

@ -37,12 +37,12 @@ namespace squish {
class WeightedClusterFit : public ColourFit
{
public:
WeightedClusterFit( ColourSet const* colours, int flags );
WeightedClusterFit();
void setMetric(float r, float g, float b);
float bestError() const;
void SetColourSet( ColourSet const* colours, int flags );
static void doPrecomputation();
void SetMetric(float r, float g, float b);
float GetBestError() const;
// Make them public
virtual void Compress3( void* block );