mirror of
https://github.com/vcmi/vcmi.git
synced 2025-01-08 00:39:47 +02:00
Better float comparison
This commit is contained in:
parent
6d6137accc
commit
0d74959a33
5
Global.h
5
Global.h
@ -689,13 +689,14 @@ namespace vstd
|
||||
bool isAlmostZero(const Floating & value)
|
||||
{
|
||||
constexpr Floating epsilon(0.00001);
|
||||
return std::abs(value) < epsilon;
|
||||
return std::abs(value) <= epsilon;
|
||||
}
|
||||
|
||||
template<typename Floating1, typename Floating2>
|
||||
bool isAlmostEqual(const Floating1 & left, const Floating2 & right)
|
||||
{
|
||||
return isAlmostZero(left - right);
|
||||
const auto relativeEpsilon = std::max(std::abs(left), std::abs(right)) * 0.00001;
|
||||
return std::abs(left - right) <= relativeEpsilon;
|
||||
}
|
||||
|
||||
///compile-time version of std::abs for ints for int3, in clang++15 std::abs is constexpr
|
||||
|
@ -1383,7 +1383,7 @@ bool CGameState::checkForVictory(const PlayerColor & player, const EventConditio
|
||||
int total = 0; //creature counter
|
||||
for(auto object : map->objects)
|
||||
{
|
||||
const CArmedInstance *ai = dynamic_cast<const CArmedInstance *>(object.get());
|
||||
const auto * ai = dynamic_cast<const CArmedInstance *>(object.get());
|
||||
if(ai && ai->getOwner() == player)
|
||||
{
|
||||
for(const auto & elem : ai->Slots()) //iterate through army
|
||||
|
Loading…
Reference in New Issue
Block a user