test
Dependencies: mbed-dev-f303 FastPWM3
Diff: PositionSensor/PositionSensor.cpp
- Revision:
- 10:370851e6e132
- Parent:
- 9:d7eb815cb057
- Child:
- 11:c83b18d41e54
--- a/PositionSensor/PositionSensor.cpp Tue May 10 01:15:57 2016 +0000 +++ b/PositionSensor/PositionSensor.cpp Thu May 12 05:02:52 2016 +0000 @@ -3,9 +3,10 @@ #include "PositionSensor.h" //#include <math.h> -PositionSensorSPI::PositionSensorSPI(int CPR, float offset){ +PositionSensorSPI::PositionSensorSPI(int CPR, float offset, int ppairs){ //_CPR = CPR; - _CPR = 2048; + _CPR = CPR; + _ppairs = ppairs; _offset = offset; rotations = 0; spi = new SPI(PC_12, PC_11, PC_10); @@ -35,7 +36,7 @@ cs->write(0); int response = spi->write(0)>>4; cs->write(1); - float elec = ((6.28318530718f/(float)_CPR) * (float) ((7*response)%_CPR)) - _offset; + float elec = ((6.28318530718f/(float)_CPR) * (float) ((_ppairs*response)%_CPR)) - _offset; if(elec < 0) elec += 6.28318530718f; return elec; } @@ -51,7 +52,8 @@ -PositionSensorEncoder::PositionSensorEncoder(int CPR, float offset) { +PositionSensorEncoder::PositionSensorEncoder(int CPR, float offset, int ppairs) { + _ppairs = ppairs; _CPR = CPR; _offset = offset; MechPosition = 0; @@ -124,7 +126,7 @@ float PositionSensorEncoder::GetElecPosition() { //returns rotor electrical angle in radians. int raw = TIM3->CNT; - float elec = ((6.28318530718f/(float)_CPR) * (float) ((7*raw)%_CPR)) - _offset; + float elec = ((6.28318530718f/(float)_CPR) * (float) ((_ppairs*raw)%_CPR)) - _offset; if(elec < 0) elec += 6.28318530718f; return elec; } @@ -132,7 +134,7 @@ float PositionSensorEncoder::GetElecVelocity(){ float rawPeriod = TIM2->CCR1; //Clock Ticks float dir = (((TIM3->CR1)>>4)&1)*2-1; // +/- 1 - return dir*7*90000000.0f*(6.28318530718f/(float)_CPR)/rawPeriod; + return dir*_ppairs*90000000.0f*(6.28318530718f/(float)_CPR)/rawPeriod; } float PositionSensorEncoder::GetMechVelocity(){