view projects/airharp/MassSpringDamper.cpp @ 269:ac8eb07afcf5

Oxygen text added to each render.cpp file for the default projects. Text includes project explanation from Wiki, edited in places. Empty project added as a default project. Doxyfile updated. Each of the project locations added to INPUT configuration option. Consider just watching the whole project file so all new projects are automatically pulled through.
author Robert Jack <robert.h.jack@gmail.com>
date Tue, 17 May 2016 15:40:16 +0100
parents 40badaff5729
children
line wrap: on
line source
/*
 *
 * Simple 1-Dimensional Mass Spring Damper
 *
 * Christian Heinrichs 04/2015
 *
 */

#include "MassSpringDamper.h"

MassSpringDamper::MassSpringDamper(float mass, float spring, float damp)	{

	_dt = 1.0/44100.0;
	_mass = mass;
	_spring = spring;
	_damp = damp;
	_position = 0;
	_velocity = 0;

}

void MassSpringDamper::setup()	{

}

double MassSpringDamper::update(float inForce)	{

	// 1. calculate spring/damper forces using current position and velocity

	double out = (_position * (double)_spring * -1) + (_velocity * (double)_damp * -1);

	// 2. apply external force

	out += inForce;

	// 3. derive acceleration (a = f/m)

	out /= (double)_mass;

	// 4. derive velocity (v = a*dt)

	out *= _dt;

	// 5. apply previous velocity

	out += _velocity;

	// 6. save current velocity state for next iteration

	_velocity = out;

	// 7. derive new position (x[n] = x[n-1] + v[n]) and save for next iteration

	out += _position;
	_position = out;

	return out;

}