summaryrefslogtreecommitdiff
path: root/gui/libs/ofxAChaosLib/src/AChaosLorenz.h
diff options
context:
space:
mode:
Diffstat (limited to 'gui/libs/ofxAChaosLib/src/AChaosLorenz.h')
-rw-r--r--gui/libs/ofxAChaosLib/src/AChaosLorenz.h83
1 files changed, 83 insertions, 0 deletions
diff --git a/gui/libs/ofxAChaosLib/src/AChaosLorenz.h b/gui/libs/ofxAChaosLib/src/AChaosLorenz.h
new file mode 100644
index 0000000..72e1efb
--- /dev/null
+++ b/gui/libs/ofxAChaosLib/src/AChaosLorenz.h
@@ -0,0 +1,83 @@
+/*
+ 32/64 bits A-Chaos Lib in openFrameworks
+ (c) s373.net/x 2004, 2012, 2015
+ http://s373.net/code/A-Chaos-Lib/A-Chaos.html
+ programmed by Andre Sier, revised 2015
+ License: MIT
+*/
+
+#pragma once
+#include "AChaosBase.h"
+#define lorx(x, y, a) (a) * ((y) - (x));
+#define lory(x, y, z, a) ((x) * ((r) - (z))) - (y);
+#define lorz(x, y, z, c) ((x) * (y)) - ((z) * (c));
+
+class AChaosLorenz : public AChaosBase {
+public:
+
+ REAL a, r, c, nx, ny, nz,dt; //eq variables
+
+ vector<string> param_labels={"a","r","c","nx","ny","nz","dt"};
+
+ AChaosLorenz(){}
+ ~AChaosLorenz(){}
+
+ virtual void setup(REAL * params = NULL){
+
+ AChaosBase::init(params, 7, 3);
+ if(params==NULL){
+ //classic lorenz
+ a=10.0;
+ r=28.0;
+ c= 2.67;
+ nx=0.1;
+ ny=0.1;
+ nz=0.1;
+ dt=0.01;
+ REAL p[7] = {nx,ny,nz,a,r,c,dt};
+ set(p);
+ } else { set(params); }
+
+ }
+
+
+
+ void reset(){
+ nx = iv[0];
+ ny = iv[1];
+ nz = iv[2];
+ a = iv[3];
+ r = iv[4];
+ c = iv[5];
+ dt = iv[6];
+ }
+
+ void calc(){
+
+ REAL dt2, fx, fy, fz,
+ ffx, ffy, ffz,
+ dtfx, dtfy, dtfz;
+
+ dt2 = dt/2.;
+
+ fx = lorx (nx,ny,a);
+ fz = lorz(nx,ny,nz,c);
+ fy = lory(nx,ny,nz,r);
+
+ dtfx = nx + (dt*fx);
+ dtfy = ny + (dt*fy);
+ dtfz = nz + (dt*fz);
+
+ ffx = lorx (dtfx,dtfy,a);
+ ffz = lorz(dtfx,dtfy,dtfz,c);
+ ffy = lory(dtfx,dtfy,dtfz,r);
+
+ nx += (dt2*(fx+ffx));
+ ny += (dt2*(fy+ffy));
+ nz += (dt2*(fz+ffz));
+
+ ov[0] = nx;
+ ov[1] = ny;
+ ov[2] = nz;
+ }
+}; \ No newline at end of file