aboutsummaryrefslogtreecommitdiff
path: root/src/main.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/main.c')
-rw-r--r--src/main.c105
1 files changed, 105 insertions, 0 deletions
diff --git a/src/main.c b/src/main.c
new file mode 100644
index 0000000..53b4edf
--- /dev/null
+++ b/src/main.c
@@ -0,0 +1,105 @@
+#include <stdio.h>
+#include <math.h>
+#include "display.h"
+
+#define W 1600
+#define H 900
+#define FPS 60
+#define RFPS 1/600
+#define PI 3.141592654
+
+typedef struct{
+ float x;
+ float y;
+} vec;
+
+
+const float s = (PI/180 * 10); // rad
+const int l = 250; // mm
+const int m = 25; // kg
+// const vec g = {0.0f, -9.81f}; // m/s^2
+const float g = -9.81f;
+
+// vec p;
+// vec v;
+// vec a;
+float t;
+float v;
+float a;
+
+// vec rotate_grav(float angle, int d) // d = 0-clock, 1-anti
+// {
+// // vec rg = {0, g.y*m*sinf(angle)};
+// vec rg = {0, g.y};
+// if(d == 0) {
+// rg.x = (rg.y*sinf(angle));
+// rg.y = -(rg.y*cosf(angle));
+// } else if(d == 1) {
+// rg.x = -(rg.y*sinf(angle));
+// rg.y = (rg.y*cosf(angle));
+// }
+
+// printf("grav transform: %f %f %f\n", rg.x, rg.y, sqrt((rg.x*rg.x) + (rg.y*rg.y)));
+// return rg;
+// }
+
+void update()
+{
+
+ // float sinamp = p.x / l;
+ // vec rg = rotate_grav((PI/2) - asinf(sinamp), (p.x > 0) ? 0 : 1);
+
+ // printf("amp: %f\n", asinf(sinamp)*180/PI);
+ // printf("lenght: %f\n", sqrt((p.x*p.x) + (p.y*p.y)));
+
+ // p.x = sinf(t) * l;
+ // p.y = cosf(t) * l;
+
+ // a.x += rg.x;
+ // a.y += rg.y;
+ // v.x += a.x * RFPS;
+ // v.y += a.y * RFPS;
+ // p.x += v.x * RFPS;
+ // p.y += v.y * RFPS;
+
+ // dspl_draw_line(p.x, p.y, v.x + p.x, v.y + p.y, 0);
+ // dspl_draw_line(p.x, p.y, a.x + p.x, a.y + p.y, 1);
+ // dspl_draw_line(p.x, p.y, 0, 0, 0);
+ // dspl_draw_circle(p.x, p.y, 5);
+
+ a += g * cosf(t) * m;
+ printf("%f %f\n", sinf(t), a);
+ v += a * RFPS;
+ t += v * RFPS;
+
+
+ int px = sinf(t) * l;
+ int py = cosf(t) * l;
+ dspl_draw_line(px, py, 0, 0, 0);
+ dspl_draw_circle(px, py, 5);
+
+}
+
+int main(void)
+{
+ // p.x = sinf(t) * l;
+ // p.y = cosf(t) * l;
+ // v.x = 0; v.y = 0;
+ // a.x = 0; a.y = 0;
+
+ t = s;
+ v = 0;
+ a = 0;
+
+ dspl_createinfo info = {0};
+ info.width = W;
+ info.height = H;
+ info.name = "Pendulum";
+ info.fps = FPS;
+ info.update_func = &update;
+
+ dspl_create(info);
+ dspl_start();
+ dspl_destroy();
+ return 0;
+}