Mercurial > hg > beaglert
annotate examples/10-Instruments/airharp/MassSpringDamper.cpp @ 550:5d954690a7c1 prerelease
merge
author | Giulio Moro <giuliomoro@yahoo.it> |
---|---|
date | Fri, 24 Jun 2016 14:55:12 +0100 |
parents | 8fcfbfb32aa0 |
children |
rev | line source |
---|---|
robert@464 | 1 /* |
robert@464 | 2 * |
robert@464 | 3 * Simple 1-Dimensional Mass Spring Damper |
robert@464 | 4 * |
robert@464 | 5 * Christian Heinrichs 04/2015 |
robert@464 | 6 * |
robert@464 | 7 */ |
robert@464 | 8 |
robert@464 | 9 #include "MassSpringDamper.h" |
robert@464 | 10 |
robert@464 | 11 MassSpringDamper::MassSpringDamper(float mass, float spring, float damp) { |
robert@464 | 12 |
robert@464 | 13 _dt = 1.0/44100.0; |
robert@464 | 14 _mass = mass; |
robert@464 | 15 _spring = spring; |
robert@464 | 16 _damp = damp; |
robert@464 | 17 _position = 0; |
robert@464 | 18 _velocity = 0; |
robert@464 | 19 |
robert@464 | 20 } |
robert@464 | 21 |
robert@464 | 22 void MassSpringDamper::setup() { |
robert@464 | 23 |
robert@464 | 24 } |
robert@464 | 25 |
robert@464 | 26 double MassSpringDamper::update(float inForce) { |
robert@464 | 27 |
robert@464 | 28 // 1. calculate spring/damper forces using current position and velocity |
robert@464 | 29 |
robert@464 | 30 double out = (_position * (double)_spring * -1) + (_velocity * (double)_damp * -1); |
robert@464 | 31 |
robert@464 | 32 // 2. apply external force |
robert@464 | 33 |
robert@464 | 34 out += inForce; |
robert@464 | 35 |
robert@464 | 36 // 3. derive acceleration (a = f/m) |
robert@464 | 37 |
robert@464 | 38 out /= (double)_mass; |
robert@464 | 39 |
robert@464 | 40 // 4. derive velocity (v = a*dt) |
robert@464 | 41 |
robert@464 | 42 out *= _dt; |
robert@464 | 43 |
robert@464 | 44 // 5. apply previous velocity |
robert@464 | 45 |
robert@464 | 46 out += _velocity; |
robert@464 | 47 |
robert@464 | 48 // 6. save current velocity state for next iteration |
robert@464 | 49 |
robert@464 | 50 _velocity = out; |
robert@464 | 51 |
robert@464 | 52 // 7. derive new position (x[n] = x[n-1] + v[n]) and save for next iteration |
robert@464 | 53 |
robert@464 | 54 out += _position; |
robert@464 | 55 _position = out; |
robert@464 | 56 |
robert@464 | 57 return out; |
robert@464 | 58 |
robert@464 | 59 } |