aboutsummaryrefslogtreecommitdiff
path: root/3rdparty/glm/source/test/gtx/gtx_spline.cpp
diff options
context:
space:
mode:
Diffstat (limited to '3rdparty/glm/source/test/gtx/gtx_spline.cpp')
-rw-r--r--3rdparty/glm/source/test/gtx/gtx_spline.cpp100
1 files changed, 100 insertions, 0 deletions
diff --git a/3rdparty/glm/source/test/gtx/gtx_spline.cpp b/3rdparty/glm/source/test/gtx/gtx_spline.cpp
new file mode 100644
index 0000000..c93ee17
--- /dev/null
+++ b/3rdparty/glm/source/test/gtx/gtx_spline.cpp
@@ -0,0 +1,100 @@
+#define GLM_ENABLE_EXPERIMENTAL
+#include <glm/vec2.hpp>
+#include <glm/vec3.hpp>
+#include <glm/vec4.hpp>
+#include <glm/gtx/spline.hpp>
+
+namespace catmullRom
+{
+ int test()
+ {
+ int Error(0);
+
+ glm::vec2 Result2 = glm::catmullRom(
+ glm::vec2(0.0f, 0.0f),
+ glm::vec2(1.0f, 0.0f),
+ glm::vec2(1.0f, 1.0f),
+ glm::vec2(0.0f, 1.0f), 0.5f);
+
+ glm::vec3 Result3 = glm::catmullRom(
+ glm::vec3(0.0f, 0.0f, 0.0f),
+ glm::vec3(1.0f, 0.0f, 0.0f),
+ glm::vec3(1.0f, 1.0f, 0.0f),
+ glm::vec3(0.0f, 1.0f, 0.0f), 0.5f);
+
+ glm::vec4 Result4 = glm::catmullRom(
+ glm::vec4(0.0f, 0.0f, 0.0f, 1.0f),
+ glm::vec4(1.0f, 0.0f, 0.0f, 1.0f),
+ glm::vec4(1.0f, 1.0f, 0.0f, 1.0f),
+ glm::vec4(0.0f, 1.0f, 0.0f, 1.0f), 0.5f);
+
+ return Error;
+ }
+}//catmullRom
+
+namespace hermite
+{
+ int test()
+ {
+ int Error(0);
+
+ glm::vec2 Result2 = glm::hermite(
+ glm::vec2(0.0f, 0.0f),
+ glm::vec2(1.0f, 0.0f),
+ glm::vec2(1.0f, 1.0f),
+ glm::vec2(0.0f, 1.0f), 0.5f);
+
+ glm::vec3 Result3 = glm::hermite(
+ glm::vec3(0.0f, 0.0f, 0.0f),
+ glm::vec3(1.0f, 0.0f, 0.0f),
+ glm::vec3(1.0f, 1.0f, 0.0f),
+ glm::vec3(0.0f, 1.0f, 0.0f), 0.5f);
+
+ glm::vec4 Result4 = glm::hermite(
+ glm::vec4(0.0f, 0.0f, 0.0f, 1.0f),
+ glm::vec4(1.0f, 0.0f, 0.0f, 1.0f),
+ glm::vec4(1.0f, 1.0f, 0.0f, 1.0f),
+ glm::vec4(0.0f, 1.0f, 0.0f, 1.0f), 0.5f);
+
+ return Error;
+ }
+}//catmullRom
+
+namespace cubic
+{
+ int test()
+ {
+ int Error(0);
+
+ glm::vec2 Result2 = glm::cubic(
+ glm::vec2(0.0f, 0.0f),
+ glm::vec2(1.0f, 0.0f),
+ glm::vec2(1.0f, 1.0f),
+ glm::vec2(0.0f, 1.0f), 0.5f);
+
+ glm::vec3 Result3 = glm::cubic(
+ glm::vec3(0.0f, 0.0f, 0.0f),
+ glm::vec3(1.0f, 0.0f, 0.0f),
+ glm::vec3(1.0f, 1.0f, 0.0f),
+ glm::vec3(0.0f, 1.0f, 0.0f), 0.5f);
+
+ glm::vec4 Result = glm::cubic(
+ glm::vec4(0.0f, 0.0f, 0.0f, 1.0f),
+ glm::vec4(1.0f, 0.0f, 0.0f, 1.0f),
+ glm::vec4(1.0f, 1.0f, 0.0f, 1.0f),
+ glm::vec4(0.0f, 1.0f, 0.0f, 1.0f), 0.5f);
+
+ return Error;
+ }
+}//catmullRom
+
+int main()
+{
+ int Error(0);
+
+ Error += catmullRom::test();
+ Error += hermite::test();
+ Error += cubic::test();
+
+ return Error;
+}