summaryrefslogtreecommitdiff
path: root/gui/libs/ofxAChaosLib/src/AChaosLyapunov.h
blob: b894ecd979ef50a30b61d5ed20228e53915ee6e8 (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
/*
	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 AChaosLyapunov : public AChaosBase {
public:

	REAL	a[6], b[6], nx, ny;

	vector<string> param_labels={"a1","a2","a3","a4","a5","a6","b1","b2","b3","b4","b5","b6","nx","ny"};
	
	AChaosLyapunov(){}
	~AChaosLyapunov(){}	

	virtual void setup(REAL * params = NULL){
	
		AChaosBase::init(params, 14, 2);	
		if(params==NULL){		

			a[0] = -1.4f;
			a[1] = 0.7f;
			a[2] = -0.16f;
			a[3] = -1.21f;
			a[4] = 1.11f;
			a[5] = -1.46f;
			b[0] = -0.19f;
			b[1] = 0.04f;
			b[2] =  1.59f;
			b[3] = 1.3f;
			b[4] = 1.68f;
			b[5] = 1.76f;
			nx = ny = 0.0f;
			REAL p[14] = {a[0],a[1],a[2],a[3],a[4],a[5],
				b[0],b[1],b[2],b[3],b[4],b[5],nx,ny};
			set(p);
		} else { set(params); }
	
	}

	void reset(){
		nx = iv[12];
		ny = iv[13];
		for(int i=0; i<6; i++){
			a[i] = iv[i];
		}
		for(int i=0; i<6; i++){
			b[i] = iv[i+6];
		}
	}
	
 	void calc(){ 		
		// maybe lyapunov attractor : quadratic eq
		nx = a[0] + a[1]*nx + a[2]*nx*nx + a[3]*nx*ny + a[4]*ny + a[5]*ny*ny;
		ny = b[0] + b[1]*nx + b[2]*nx*nx + b[3]*nx*ny + b[4]*ny + b[5]*ny*ny;

		ov[0] = nx;
		ov[1] = ny;
 	}
};