summaryrefslogtreecommitdiff
path: root/gui/libs/ofxAChaosLib/src/AChaosLorenz.h
blob: 0f1ae2f0978319148a860f42556e0cf1e5b16ccd (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
/*
	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 vector<string> &get_param_labels(){return this->param_labels;};

	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;
 	}
};