mirror of
https://github.com/g-truc/glm.git
synced 2024-11-10 04:31:47 +00:00
Fixed uaddCarray and updated tests #253
This commit is contained in:
parent
b90c4c430e
commit
72cbc4c065
@ -95,7 +95,7 @@ namespace detail
|
||||
uint64 const Value64(static_cast<uint64>(x) + static_cast<uint64>(y));
|
||||
uint64 const Max32(static_cast<uint64>(std::numeric_limits<uint>::max()));
|
||||
Carry = Value64 > Max32 ? 1 : 0;
|
||||
return static_cast<uint32>(Value64 % Max32);
|
||||
return static_cast<uint32>(Value64 % (Max32 + static_cast<uint64>(1)));
|
||||
}
|
||||
|
||||
template <precision P, template <typename, precision> class vecType>
|
||||
@ -104,7 +104,7 @@ namespace detail
|
||||
vecType<uint64, P> Value64(vecType<uint64, P>(x) + vecType<uint64, P>(y));
|
||||
vecType<uint64, P> Max32(static_cast<uint64>(std::numeric_limits<uint>::max()));
|
||||
Carry = mix(vecType<uint32, P>(0), vecType<uint32, P>(1), greaterThan(Value64, Max32));
|
||||
return vecType<uint32,P>(Value64 % Max32);
|
||||
return vecType<uint32,P>(Value64 % (Max32 + static_cast<uint64>(1)));
|
||||
}
|
||||
|
||||
// usubBorrow
|
||||
|
@ -898,71 +898,48 @@ namespace findLSB
|
||||
|
||||
namespace uaddCarry
|
||||
{
|
||||
void test_instance(unsigned int n)
|
||||
{
|
||||
glm::uint a = std::numeric_limits<glm::uint>::max() - 4,
|
||||
b = n,
|
||||
carry = 0;
|
||||
glm::uint result = glm::uaddCarry(a, b, carry);
|
||||
}
|
||||
|
||||
int test()
|
||||
{
|
||||
int Error(0);
|
||||
|
||||
{
|
||||
glm::uint x = 16;
|
||||
glm::uint y = 17;
|
||||
glm::uint x = std::numeric_limits<glm::uint>::max();
|
||||
glm::uint y = 0;
|
||||
glm::uint Carry = 0;
|
||||
glm::uint Result = glm::uaddCarry(x, y, Carry);
|
||||
|
||||
Error += Carry == 0 ? 0 : 1;
|
||||
Error += Result == std::numeric_limits<glm::uint>::max() ? 0 : 1;
|
||||
}
|
||||
|
||||
{
|
||||
glm::uint x = std::numeric_limits<glm::uint>::max();
|
||||
glm::uint y = 1;
|
||||
glm::uint Carry = 0;
|
||||
glm::uint Result = glm::uaddCarry(x, y, Carry);
|
||||
|
||||
Error += Carry == 1 ? 0 : 1;
|
||||
Error += Result == 33 ? 0 : 1;
|
||||
Error += Result == 0 ? 0 : 1;
|
||||
}
|
||||
|
||||
{
|
||||
glm::uvec1 x(16);
|
||||
glm::uvec1 y(17);
|
||||
glm::uvec1 x(std::numeric_limits<glm::uint>::max());
|
||||
glm::uvec1 y(0);
|
||||
glm::uvec1 Carry(0);
|
||||
glm::uvec1 Result(glm::uaddCarry(x, y, Carry));
|
||||
|
||||
Error += glm::all(glm::equal(Carry, glm::uvec1(0))) ? 0 : 1;
|
||||
Error += glm::all(glm::equal(Result, glm::uvec1(std::numeric_limits<glm::uint>::max()))) ? 0 : 1;
|
||||
}
|
||||
|
||||
{
|
||||
glm::uvec1 x(std::numeric_limits<glm::uint>::max());
|
||||
glm::uvec1 y(1);
|
||||
glm::uvec1 Carry(0);
|
||||
glm::uvec1 Result(glm::uaddCarry(x, y, Carry));
|
||||
|
||||
Error += glm::all(glm::equal(Carry, glm::uvec1(1))) ? 0 : 1;
|
||||
Error += glm::all(glm::equal(Result, glm::uvec1(33))) ? 0 : 1;
|
||||
}
|
||||
|
||||
{
|
||||
glm::uvec2 x(16);
|
||||
glm::uvec2 y(17);
|
||||
glm::uvec2 Carry(0);
|
||||
glm::uvec2 Result(glm::uaddCarry(x, y, Carry));
|
||||
|
||||
Error += glm::all(glm::equal(Carry, glm::uvec2(1))) ? 0 : 1;
|
||||
Error += glm::all(glm::equal(Result, glm::uvec2(33))) ? 0 : 1;
|
||||
}
|
||||
|
||||
{
|
||||
glm::uvec3 x(16);
|
||||
glm::uvec3 y(17);
|
||||
glm::uvec3 Carry(0);
|
||||
glm::uvec3 Result(glm::uaddCarry(x, y, Carry));
|
||||
|
||||
Error += glm::all(glm::equal(Carry, glm::uvec3(1))) ? 0 : 1;
|
||||
Error += glm::all(glm::equal(Result, glm::uvec3(33))) ? 0 : 1;
|
||||
}
|
||||
|
||||
{
|
||||
glm::uvec4 x(16);
|
||||
glm::uvec4 y(17);
|
||||
glm::uvec4 Carry(0);
|
||||
glm::uvec4 Result(glm::uaddCarry(x, y, Carry));
|
||||
|
||||
Error += glm::all(glm::equal(Carry, glm::uvec4(1))) ? 0 : 1;
|
||||
Error += glm::all(glm::equal(Result, glm::uvec4(33))) ? 0 : 1;
|
||||
}
|
||||
|
||||
{
|
||||
for(unsigned int i = 0; i < 10; ++i)
|
||||
test_instance(i);
|
||||
Error += glm::all(glm::equal(Result, glm::uvec1(0))) ? 0 : 1;
|
||||
}
|
||||
|
||||
return Error;
|
||||
|
Loading…
Reference in New Issue
Block a user