annotate projects/airharp/String.cpp @ 240:1fd334f64f0a

Fixed behaviour of the -G command line closes #1680
author Giulio Moro <giuliomoro@yahoo.it>
date Thu, 14 Apr 2016 15:44:38 +0100
parents 40badaff5729
children
rev   line source
chris@164 1 /*
chris@164 2 *
chris@164 3 * 1-D string consisting of two waveguides and junction
chris@164 4 *
chris@164 5 * Christian Heinrichs 04/2015
chris@164 6 *
chris@164 7 */
chris@164 8
chris@164 9 #include "String.h"
chris@164 10 #include "Junction.h"
chris@164 11 #include "Waveguide.h"
chris@164 12
chris@164 13 #include "../include/Utilities.h"
chris@164 14 #include <rtdk.h>
chris@164 15 #include <cmath>
chris@164 16 #include <stdio.h>
chris@164 17 #include <cstdlib>
chris@164 18
chris@164 19 String::String(){
chris@164 20
chris@164 21 wg_l = Waveguide();
chris@164 22 wg_r = Waveguide();
chris@164 23 junction = Junction();
chris@164 24
chris@164 25 junction.setPluckPosition(0.5);
chris@164 26
chris@164 27 _previous_l = 0;
chris@164 28 _previous_r = 0;
chris@164 29
chris@164 30 }
chris@164 31
chris@164 32 float String::update(float in) {
chris@164 33
chris@164 34 // 1. send excitation signal and previous waveguide outputs into junction
chris@164 35
chris@164 36 junction.update(in,_previous_l,_previous_r);
chris@164 37
chris@164 38 // 2. save new waveguide outputs for next iteration
chris@164 39
chris@164 40 _previous_l = wg_l.update(junction.getOutput(0));
chris@164 41 _previous_r = wg_r.update(junction.getOutput(1));
chris@164 42
chris@164 43 // 3. use right waveguide as output
chris@164 44
chris@164 45 //rt_printf("BANANA %f ",_readPtr);
chris@164 46 //rt_printf("%f\n",_previous_r);
chris@164 47
chris@164 48 return _previous_r;
chris@164 49 }
chris@164 50
chris@164 51 float String::getPlectrumDisplacement() {
chris@164 52
chris@164 53 return junction.getExcitationDisplacement();
chris@164 54
chris@164 55 }
chris@164 56
chris@164 57 void String::setPluckPosition(float pluckPos){
chris@164 58
chris@164 59 junction.setPluckPosition(pluckPos);
chris@164 60
chris@164 61 }
chris@164 62
chris@164 63 void String::setGlobalPosition(float pos) {
chris@164 64
chris@164 65 _globalPosition = pos;
chris@164 66
chris@164 67 }
chris@164 68
chris@164 69 float String::getGlobalPosition() {
chris@164 70
chris@164 71 return _globalPosition;
chris@164 72
chris@164 73 }
chris@164 74
chris@164 75 void String::setMidinote(float midinote) {
chris@164 76
chris@164 77 float frequency = 440.0f*(float)powf(2,(midinote-57)/12.0f);
chris@164 78
chris@164 79 junction.setFrequency(frequency);
chris@164 80 wg_l.setFrequency(frequency);
chris@164 81 wg_r.setFrequency(frequency);
chris@164 82
chris@164 83 }
chris@164 84
chris@164 85 void String::setFrequency(float frequency) {
chris@164 86
chris@164 87 junction.setFrequency(frequency);
chris@164 88 wg_l.setFrequency(frequency);
chris@164 89 wg_r.setFrequency(frequency);
chris@164 90
chris@164 91 }