You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
o3de/Gems/EMotionFX/Code/MCore/Source/CompressedFloat.inl

61 lines
1.8 KiB
C++

/*
* Copyright (c) Contributors to the Open 3D Engine Project.
* For complete copyright and license terms please see the LICENSE at the root of this distribution.
*
* SPDX-License-Identifier: Apache-2.0 OR MIT
*
*/
// constructor
template <class StorageType>
MCORE_INLINE TCompressedFloat<StorageType>::TCompressedFloat()
{
}
// constructor
template <class StorageType>
MCORE_INLINE TCompressedFloat<StorageType>::TCompressedFloat(float value, float minValue, float maxValue)
{
// TODO: make sure due to rounding/floating point errors the result is not negative?
const StorageType f = (1.0f / (maxValue - minValue)) * CONVERT_VALUE;
m_value = (value - minValue) * f;
}
// constructor
template <class StorageType>
MCORE_INLINE TCompressedFloat<StorageType>::TCompressedFloat(StorageType value)
{
m_value = value;
}
// create from a floating point value
template <class StorageType>
MCORE_INLINE void TCompressedFloat<StorageType>::FromFloat(float value, float minValue, float maxValue)
{
// TODO: make sure due to rounding/floating point errors the result is not negative?
const StorageType f = (StorageType)(1.0f / (maxValue - minValue)) * CONVERT_VALUE;
m_value = (StorageType)((value - minValue) * f);
}
// uncompress into a floating point value
template <class StorageType>
MCORE_INLINE void TCompressedFloat<StorageType>::UnCompress(float* output, float minValue, float maxValue) const
{
// unpack and normalize
const float f = (1.0f / (float)CONVERT_VALUE) * (maxValue - minValue);
*output = ((float)m_value * f) + minValue;
}
// convert to a floating point value
template <class StorageType>
MCORE_INLINE float TCompressedFloat<StorageType>::ToFloat(float minValue, float maxValue) const
{
const float f = (1.0f / (float)CONVERT_VALUE) * (maxValue - minValue);
return ((m_value * f) + minValue);
}