mirror of
https://github.com/g-truc/glm.git
synced 2024-11-27 02:34:35 +00:00
Added detail code for simplex noise implementation
This commit is contained in:
parent
bbf97d0e23
commit
b2ae0a3ce9
@ -12,6 +12,41 @@ namespace glm
|
|||||||
namespace core{
|
namespace core{
|
||||||
namespace function{
|
namespace function{
|
||||||
namespace noise{
|
namespace noise{
|
||||||
|
namespace detail
|
||||||
|
{
|
||||||
|
template <typenane valType, typenane vecType>
|
||||||
|
inline vecType permute
|
||||||
|
(
|
||||||
|
vecType const & x0,
|
||||||
|
detail::tvec3<valType> const & p
|
||||||
|
)
|
||||||
|
{
|
||||||
|
vecType x1 = mod(x0 * p.y, p.x);
|
||||||
|
return floor( mod( (x1 + p.z) *x0, p.x ));
|
||||||
|
}
|
||||||
|
|
||||||
|
inline detail::tvec2<T> permute
|
||||||
|
(
|
||||||
|
detail::tvec2<T> const & x0,
|
||||||
|
detail::tvec3<valType> const & p
|
||||||
|
)
|
||||||
|
{
|
||||||
|
vec2 x1 = mod(x0 * p.y, p.x);
|
||||||
|
return floor( mod( (x1 + p.z) *x0, p.x ));
|
||||||
|
}
|
||||||
|
|
||||||
|
inline vec3 permute(vec3 x0,vec3 p)
|
||||||
|
{
|
||||||
|
vec3 x1 = mod(x0 * p.y, p.x);
|
||||||
|
return floor( mod( (x1 + p.z) *x0, p.x ));
|
||||||
|
}
|
||||||
|
|
||||||
|
inline vec4 permute(vec4 x0,vec3 p)
|
||||||
|
{
|
||||||
|
vec4 x1 = mod(x0 * p.y, p.x);
|
||||||
|
return floor( mod( (x1 + p.z) *x0, p.x ));
|
||||||
|
}
|
||||||
|
}//namespace detail
|
||||||
|
|
||||||
// noise1
|
// noise1
|
||||||
template <typename genType>
|
template <typename genType>
|
||||||
|
Loading…
Reference in New Issue
Block a user