Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
PointCloud
Glm
提交
ac1fe72a
G
Glm
项目概览
PointCloud
/
Glm
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
G
Glm
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
ac1fe72a
编写于
5月 07, 2011
作者:
C
Christophe Riccio
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Back to 0.9.1.3 version
上级
e74f71eb
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
50 addition
and
60 deletion
+50
-60
glm/core/func_integer.inl
glm/core/func_integer.inl
+50
-60
未找到文件。
glm/core/func_integer.inl
浏览文件 @
ac1fe72a
...
...
@@ -20,7 +20,7 @@ namespace glm
{
// uaddCarry
template <typename genUType>
GLM_FUNC_QUALIFIER
genUType uaddCarry
inline
genUType uaddCarry
(
genUType const & x,
genUType const & y,
...
...
@@ -34,7 +34,7 @@ namespace glm
}
template <typename T>
GLM_FUNC_QUALIFIER
detail::tvec2<T> uaddCarry
inline
detail::tvec2<T> uaddCarry
(
detail::tvec2<T> const & x,
detail::tvec2<T> const & y,
...
...
@@ -47,7 +47,7 @@ namespace glm
}
template <typename T>
GLM_FUNC_QUALIFIER
detail::tvec3<T> uaddCarry
inline
detail::tvec3<T> uaddCarry
(
detail::tvec3<T> const & x,
detail::tvec3<T> const & y,
...
...
@@ -61,7 +61,7 @@ namespace glm
}
template <typename T>
GLM_FUNC_QUALIFIER
detail::tvec4<T> uaddCarry
inline
detail::tvec4<T> uaddCarry
(
detail::tvec4<T> const & x,
detail::tvec4<T> const & y,
...
...
@@ -77,7 +77,7 @@ namespace glm
// usubBorrow
template <typename genUType>
GLM_FUNC_QUALIFIER
genUType usubBorrow
inline
genUType usubBorrow
(
genUType const & x,
genUType const & y,
...
...
@@ -92,7 +92,7 @@ namespace glm
}
template <typename T>
GLM_FUNC_QUALIFIER
detail::tvec2<T> usubBorrow
inline
detail::tvec2<T> usubBorrow
(
detail::tvec2<T> const & x,
detail::tvec2<T> const & y,
...
...
@@ -105,7 +105,7 @@ namespace glm
}
template <typename T>
GLM_FUNC_QUALIFIER
detail::tvec3<T> usubBorrow
inline
detail::tvec3<T> usubBorrow
(
detail::tvec3<T> const & x,
detail::tvec3<T> const & y,
...
...
@@ -119,7 +119,7 @@ namespace glm
}
template <typename T>
GLM_FUNC_QUALIFIER
detail::tvec4<T> usubBorrow
inline
detail::tvec4<T> usubBorrow
(
detail::tvec4<T> const & x,
detail::tvec4<T> const & y,
...
...
@@ -135,7 +135,7 @@ namespace glm
// umulExtended
template <typename genUType>
GLM_FUNC_QUALIFIER
void umulExtended
inline
void umulExtended
(
genUType const & x,
genUType const & y,
...
...
@@ -151,7 +151,7 @@ namespace glm
}
template <typename T>
GLM_FUNC_QUALIFIER
detail::tvec2<T> umulExtended
inline
detail::tvec2<T> umulExtended
(
detail::tvec2<T> const & x,
detail::tvec2<T> const & y,
...
...
@@ -165,7 +165,7 @@ namespace glm
}
template <typename T>
GLM_FUNC_QUALIFIER
detail::tvec3<T> umulExtended
inline
detail::tvec3<T> umulExtended
(
detail::tvec3<T> const & x,
detail::tvec3<T> const & y,
...
...
@@ -180,7 +180,7 @@ namespace glm
}
template <typename T>
GLM_FUNC_QUALIFIER
detail::tvec4<T> umulExtended
inline
detail::tvec4<T> umulExtended
(
detail::tvec4<T> const & x,
detail::tvec4<T> const & y,
...
...
@@ -213,7 +213,7 @@ namespace glm
}
template <typename T>
GLM_FUNC_QUALIFIER
detail::tvec2<T> imulExtended
inline
detail::tvec2<T> imulExtended
(
detail::tvec2<T> const & x,
detail::tvec2<T> const & y,
...
...
@@ -227,7 +227,7 @@ namespace glm
}
template <typename T>
GLM_FUNC_QUALIFIER
detail::tvec3<T> imulExtended
inline
detail::tvec3<T> imulExtended
(
detail::tvec3<T> const & x,
detail::tvec3<T> const & y,
...
...
@@ -242,7 +242,7 @@ namespace glm
}
template <typename T>
GLM_FUNC_QUALIFIER
detail::tvec4<T> imulExtended
inline
detail::tvec4<T> imulExtended
(
detail::tvec4<T> const & x,
detail::tvec4<T> const & y,
...
...
@@ -258,40 +258,30 @@ namespace glm
}
// bitfieldExtract
template <typename genIUType
, typename sizeType
>
GLM_FUNC_QUALIFIER
genIUType bitfieldExtract
template <typename genIUType>
genIUType bitfieldExtract
(
genIUType const & Value,
sizeType
const & Offset,
sizeType
const & Bits
int
const & Offset,
int
const & Bits
)
{
/*
GLM_STATIC_ASSERT(std::numeric_limits<genIUType>::is_integer, "'bitfieldExtract' only accept integer values");
assert(Offset + Bits <=
(sizeof(genIUType) << 3
));
assert(Offset + Bits <=
sizeof(genIUType
));
genIUType Result
(0)
;
genIUType Result
= 0
;
if(std::numeric_limits<genIUType>::is_signed)
Result |= (
genIUType(1) << (sizeof(genIUType) * genIUType(8) - genIUType(1))) & (genIUType(1) << (Offset + Bits - genIUType(1)
));
Result |= (
1 << (sizeof(genIUType) * 8 - 1)) & (1 << (Offset + Bits - 1
));
genIUType Mask
(0)
;
genIUType Mask
= 0
;
for(int Bit = Offset; Bit < Bits; ++Bit)
Mask |= (
genIUType(1)
<< Bit);
Mask |= (
1
<< Bit);
return Result | ((Mask & Value) >> Offset);
*/
sizeType GenSize = sizeof(genIUType) << sizeType(3);
assert(Offset + Bits <= GenSize);
genIUType ShiftLeft = Bits ? Value << (GenSize - (Bits + Offset)) : genIUType(0);
genIUType ShiftBack = ShiftLeft >> genIUType(GenSize - Bits);
return ShiftBack;
}
template <typename T>
GLM_FUNC_QUALIFIER
detail::tvec2<T> bitfieldExtract
inline
detail::tvec2<T> bitfieldExtract
(
detail::tvec2<T> const & Value,
int const & Offset,
...
...
@@ -304,7 +294,7 @@ namespace glm
}
template <typename T>
GLM_FUNC_QUALIFIER
detail::tvec3<T> bitfieldExtract
inline
detail::tvec3<T> bitfieldExtract
(
detail::tvec3<T> const & Value,
int const & Offset,
...
...
@@ -318,7 +308,7 @@ namespace glm
}
template <typename T>
GLM_FUNC_QUALIFIER
detail::tvec4<T> bitfieldExtract
inline
detail::tvec4<T> bitfieldExtract
(
detail::tvec4<T> const & Value,
int const & Offset,
...
...
@@ -334,7 +324,7 @@ namespace glm
// bitfieldInsert
template <typename genIUType>
GLM_FUNC_QUALIFIER
genIUType bitfieldInsert
inline
genIUType bitfieldInsert
(
genIUType const & Base,
genIUType const & Insert,
...
...
@@ -350,13 +340,13 @@ namespace glm
genIUType Mask = 0;
for(int Bit = Offset; Bit < Offset + Bits; ++Bit)
Mask |= (
genIUType(1)
<< Bit);
Mask |= (
1
<< Bit);
return (Base & ~Mask) | (Insert & Mask);
}
template <typename T>
GLM_FUNC_QUALIFIER
detail::tvec2<T> bitfieldInsert
inline
detail::tvec2<T> bitfieldInsert
(
detail::tvec2<T> const & Base,
detail::tvec2<T> const & Insert,
...
...
@@ -370,7 +360,7 @@ namespace glm
}
template <typename T>
GLM_FUNC_QUALIFIER
detail::tvec3<T> bitfieldInsert
inline
detail::tvec3<T> bitfieldInsert
(
detail::tvec3<T> const & Base,
detail::tvec3<T> const & Insert,
...
...
@@ -385,7 +375,7 @@ namespace glm
}
template <typename T>
GLM_FUNC_QUALIFIER
detail::tvec4<T> bitfieldInsert
inline
detail::tvec4<T> bitfieldInsert
(
detail::tvec4<T> const & Base,
detail::tvec4<T> const & Insert,
...
...
@@ -402,19 +392,19 @@ namespace glm
// bitfieldReverse
template <typename genIUType>
GLM_FUNC_QUALIFIER
genIUType bitfieldReverse(genIUType const & Value)
inline
genIUType bitfieldReverse(genIUType const & Value)
{
GLM_STATIC_ASSERT(std::numeric_limits<genIUType>::is_integer, "'bitfieldReverse' only accept integer values");
genIUType Result = 0;
for(std::size_t i = 0; i < sizeof(genIUType) * std::size_t(8); ++i)
if(Value & (
genIUType(1) << genIUType(i)
))
Result |= (genIUType(1) << (
genIUType(sizeof(genIUType)) * genIUType(8)) - genIUType(1) - genIUType(i)
);
if(Value & (
1 << i
))
Result |= (genIUType(1) << (
sizeof(genIUType) * std::size_t(8)) - genIUType(1) - i
);
return Result;
}
template <typename T>
GLM_FUNC_QUALIFIER
detail::tvec2<T> bitfieldReverse
inline
detail::tvec2<T> bitfieldReverse
(
detail::tvec2<T> const & value
)
...
...
@@ -425,7 +415,7 @@ namespace glm
}
template <typename T>
GLM_FUNC_QUALIFIER
detail::tvec3<T> bitfieldReverse
inline
detail::tvec3<T> bitfieldReverse
(
detail::tvec3<T> const & value
)
...
...
@@ -437,7 +427,7 @@ namespace glm
}
template <typename T>
GLM_FUNC_QUALIFIER
detail::tvec4<T> bitfieldReverse
inline
detail::tvec4<T> bitfieldReverse
(
detail::tvec4<T> const & value
)
...
...
@@ -458,14 +448,14 @@ namespace glm
int Count = 0;
for(std::size_t i = 0; i < sizeof(genIUType) * std::size_t(8); ++i)
{
if(Value & (
genIUType(1)
<< i))
if(Value & (
1
<< i))
++Count;
}
return Count;
}
template <typename T>
GLM_FUNC_QUALIFIER
detail::tvec2<int> bitCount
inline
detail::tvec2<int> bitCount
(
detail::tvec2<T> const & value
)
...
...
@@ -476,7 +466,7 @@ namespace glm
}
template <typename T>
GLM_FUNC_QUALIFIER
detail::tvec3<int> bitCount
inline
detail::tvec3<int> bitCount
(
detail::tvec3<T> const & value
)
...
...
@@ -488,7 +478,7 @@ namespace glm
}
template <typename T>
GLM_FUNC_QUALIFIER
detail::tvec4<int> bitCount
inline
detail::tvec4<int> bitCount
(
detail::tvec4<T> const & value
)
...
...
@@ -502,7 +492,7 @@ namespace glm
// findLSB
template <typename genIUType>
GLM_FUNC_QUALIFIER
int findLSB
inline
int findLSB
(
genIUType const & Value
)
...
...
@@ -517,7 +507,7 @@ namespace glm
}
template <typename T>
GLM_FUNC_QUALIFIER
detail::tvec2<int> findLSB
inline
detail::tvec2<int> findLSB
(
detail::tvec2<T> const & value
)
...
...
@@ -528,7 +518,7 @@ namespace glm
}
template <typename T>
GLM_FUNC_QUALIFIER
detail::tvec3<int> findLSB
inline
detail::tvec3<int> findLSB
(
detail::tvec3<T> const & value
)
...
...
@@ -540,7 +530,7 @@ namespace glm
}
template <typename T>
GLM_FUNC_QUALIFIER
detail::tvec4<int> findLSB
inline
detail::tvec4<int> findLSB
(
detail::tvec4<T> const & value
)
...
...
@@ -554,7 +544,7 @@ namespace glm
// findMSB
template <typename genIUType>
GLM_FUNC_QUALIFIER
int findMSB
inline
int findMSB
(
genIUType const & Value
)
...
...
@@ -569,7 +559,7 @@ namespace glm
}
template <typename T>
GLM_FUNC_QUALIFIER
detail::tvec2<int> findMSB
inline
detail::tvec2<int> findMSB
(
detail::tvec2<T> const & value
)
...
...
@@ -580,7 +570,7 @@ namespace glm
}
template <typename T>
GLM_FUNC_QUALIFIER
detail::tvec3<int> findMSB
inline
detail::tvec3<int> findMSB
(
detail::tvec3<T> const & value
)
...
...
@@ -592,7 +582,7 @@ namespace glm
}
template <typename T>
GLM_FUNC_QUALIFIER
detail::tvec4<int> findMSB
inline
detail::tvec4<int> findMSB
(
detail::tvec4<T> const & value
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录