2019
Dependents: wheel_test6 wheel_test7 2019NHK_A_manual_red 2019NHK_A_manual_red
OmniPosition.cpp
- Committer:
- takeuchi
- Date:
- 2018-08-21
- Revision:
- 4:fc4c88fffef8
- Parent:
- 3:47676abdf529
- Child:
- 5:f8c3aeb4e65f
File content as of revision 4:fc4c88fffef8:
#include "OmniPosition.h" OmniPosition::OmniPosition(PinName serialTX, PinName serialRX) : RawSerial(serialTX, serialRX, DEFAULT_BAUD), readCounter(SERIAL_BUFFER_SIZE, 0), takeCounter(SERIAL_BUFFER_SIZE, 0), X(0), Y(0), theta(0.0) { buffer = new char[SERIAL_BUFFER_SIZE]; data = new char[2]; attach(callback(this, &OmniPosition::readData)); assembleTicker.attach(callback(this, &OmniPosition::assemble), RECEIVE_FREQ); sendTicker.attach(callback(this, &OmniPosition::send), SEND_FREQ); } void OmniPosition::readData() { buffer[(int)readCounter] = getc(); ++readCounter; } void OmniPosition::assemble() { //Find header headerCheck = false; headerPoint = 0xff; for(int i = 0; i < SERIAL_BUFFER_SIZE; i++) { if(buffer[i] == HEADER_FIRST_BYTE) { takeCounter = i; ++takeCounter; if(buffer[(int)takeCounter] == HEADER_SECOND_BYTE) { headerCheck = true; headerPoint = i; } } } if(headerPoint == 0xff) { return; } //assemble checksum = 0; takeCounter = headerPoint; //firstheader ++takeCounter; //secondheader ++takeCounter; data[0] = buffer[(int)takeCounter]; ++takeCounter; data[1] = buffer[(int)takeCounter]; X = ((data[0]<<8)|data[1]) - 32768; checksum = (data[0] ^ data[1]); ++takeCounter; data[0] = buffer[(int)takeCounter]; ++takeCounter; data[1] = buffer[(int)takeCounter]; Y = ((data[0]<<8)|data[1]) - 32768; checksum = (checksum ^ data[0]); checksum = (checksum ^ data[1]); ++takeCounter; data[0] = buffer[(int)takeCounter]; ++takeCounter; data[1] = buffer[(int)takeCounter]; thetaint = (data[0] & 0xFF) | ((data[1] << 8) & 0xFF00); theta = thetaint / 100.0; if(theta > 180.0) { theta -= 655.0; } theta *= -M_PI / 180.0; if(theta > M_PI) theta -= 2 * M_PI; if(theta < -M_PI) theta += 2 * M_PI; if(theta > M_PI) theta -= 2 * M_PI; if(theta < -M_PI) theta += 2 * M_PI; checksum = (checksum ^ data[0]); checksum = (checksum ^ data[1]); ++takeCounter; if(buffer[(int)takeCounter] != checksum) { X = bfrX; Y = bfrY; theta = bfrTheta; } else { bfrX = X; bfrY = Y; bfrTheta = theta; } } void OmniPosition::send() { if(resetSend) { putc('R'); resetSend = false; } else { //putc(0); } } int OmniPosition::getX() { return X; } int OmniPosition::getY() { return Y; } double OmniPosition::getTheta() { return -theta; } void OmniPosition::reset() { resetSend = true; }