demo project

Dependencies:   AX-12A Dynamixel mbed iothub_client EthernetInterface NTPClient ConfigFile SDFileSystem iothub_amqp_transport mbed-rtos proton-c-mbed wolfSSL

Committer:
henryrawas
Date:
Sat Jan 23 00:08:30 2016 +0000
Revision:
18:224289104fc0
Parent:
ControllerUtil.cpp@17:0dbcbd8587fd
Child:
19:2f0ec9ac1238
refactor

Who changed what in which revision?

UserRevisionLine numberNew contents of line
henryrawas 14:570c8071f577 1 #include "mbed.h"
henryrawas 14:570c8071f577 2 #include "rtos.h"
henryrawas 14:570c8071f577 3
henryrawas 14:570c8071f577 4 #include <RobotArm.h>
henryrawas 14:570c8071f577 5 #include <MeasureBuf.h>
henryrawas 14:570c8071f577 6 #include <ControllerIo.h>
henryrawas 14:570c8071f577 7 #include "Alert.h"
henryrawas 14:570c8071f577 8
henryrawas 14:570c8071f577 9 // use controller timer
henryrawas 14:570c8071f577 10 extern Timer IdleTimer;
henryrawas 14:570c8071f577 11
henryrawas 14:570c8071f577 12
henryrawas 14:570c8071f577 13 // utility method to show state in console
henryrawas 14:570c8071f577 14 void DispMeasure(char* label, int partSize, float vals[])
henryrawas 14:570c8071f577 15 {
henryrawas 14:570c8071f577 16 // printf("%s: ", label);
henryrawas 14:570c8071f577 17 // for (int ix = 0; ix < partSize; ix++)
henryrawas 14:570c8071f577 18 // {
henryrawas 14:570c8071f577 19 // printf("%d:%f ", ix, vals[ix]);
henryrawas 14:570c8071f577 20 // }
henryrawas 14:570c8071f577 21 // printf("\r\n");
henryrawas 14:570c8071f577 22 }
henryrawas 14:570c8071f577 23
henryrawas 14:570c8071f577 24
henryrawas 14:570c8071f577 25 // send position alert
henryrawas 14:570c8071f577 26 void PushPositionAlert(RobotArm& robotArm)
henryrawas 14:570c8071f577 27 {
henryrawas 14:570c8071f577 28 // stop trying to move
henryrawas 14:570c8071f577 29 float diff = robotArm.GetLastPosDiff();
henryrawas 14:570c8071f577 30 int ix = robotArm.GetLastErrorPart();
henryrawas 14:570c8071f577 31 robotArm.MoveArmPositionsStop();
henryrawas 14:570c8071f577 32
henryrawas 14:570c8071f577 33 // report load error
henryrawas 14:570c8071f577 34 printf("Position error detected joint %d, value diff %f\r\n", ix, diff);
henryrawas 14:570c8071f577 35
henryrawas 14:570c8071f577 36 Alert alert;
henryrawas 14:570c8071f577 37 time_t seconds = time(NULL);
henryrawas 14:570c8071f577 38
henryrawas 14:570c8071f577 39 ShowLedRed();
henryrawas 14:570c8071f577 40 alert.SetPositionAlert(seconds, ix, diff);
henryrawas 14:570c8071f577 41 AlertBuf.push(alert);
henryrawas 14:570c8071f577 42
henryrawas 14:570c8071f577 43 BuzzerStartMs((int)IdleTimer.read_ms(), 500);
henryrawas 14:570c8071f577 44 }
henryrawas 14:570c8071f577 45
henryrawas 14:570c8071f577 46 // send load alert
henryrawas 14:570c8071f577 47 void PushLoadAlert(RobotArm& robotArm)
henryrawas 14:570c8071f577 48 {
henryrawas 14:570c8071f577 49 float lastVals[NUMJOINTS];
henryrawas 14:570c8071f577 50
henryrawas 14:570c8071f577 51 // stop trying to move
henryrawas 14:570c8071f577 52 robotArm.GetArmLastMeasure(NM_Load, lastVals);
henryrawas 14:570c8071f577 53 int ix = robotArm.GetLastErrorPart();
henryrawas 14:570c8071f577 54 robotArm.MoveArmPositionsStop();
henryrawas 14:570c8071f577 55
henryrawas 14:570c8071f577 56 // report load error
henryrawas 14:570c8071f577 57 printf("Load error detected joint %d, value %f\r\n", ix, lastVals[ix]);
henryrawas 14:570c8071f577 58
henryrawas 14:570c8071f577 59 Alert alert;
henryrawas 14:570c8071f577 60 time_t seconds = time(NULL);
henryrawas 14:570c8071f577 61
henryrawas 14:570c8071f577 62 ShowLedRed();
henryrawas 14:570c8071f577 63 alert.SetLoadAlert(seconds, ix, lastVals[ix]);
henryrawas 14:570c8071f577 64 AlertBuf.push(alert);
henryrawas 14:570c8071f577 65
henryrawas 14:570c8071f577 66 BuzzerStartMs((int)IdleTimer.read_ms(), 500);
henryrawas 14:570c8071f577 67 }
henryrawas 14:570c8071f577 68
henryrawas 14:570c8071f577 69 // send temperature alert
henryrawas 14:570c8071f577 70 void PushTemperatureAlert(RobotArm& robotArm)
henryrawas 14:570c8071f577 71 {
henryrawas 14:570c8071f577 72 float lastVals[NUMJOINTS];
henryrawas 14:570c8071f577 73
henryrawas 14:570c8071f577 74 // stop trying to move
henryrawas 14:570c8071f577 75 robotArm.GetArmLastMeasure(NM_Temperature, lastVals);
henryrawas 14:570c8071f577 76 int ix = robotArm.GetLastErrorPart();
henryrawas 14:570c8071f577 77 robotArm.MoveArmPositionsStop();
henryrawas 14:570c8071f577 78
henryrawas 14:570c8071f577 79 // report load error
henryrawas 14:570c8071f577 80 printf("Temperature error detected joint %d, value %f\r\n", ix, lastVals[ix]);
henryrawas 14:570c8071f577 81
henryrawas 14:570c8071f577 82 Alert alert;
henryrawas 14:570c8071f577 83 time_t seconds = time(NULL);
henryrawas 14:570c8071f577 84
henryrawas 14:570c8071f577 85 ShowLedRed();
henryrawas 14:570c8071f577 86 alert.SetTemperatureAlert(seconds, ix, lastVals[ix]);
henryrawas 14:570c8071f577 87 AlertBuf.push(alert);
henryrawas 14:570c8071f577 88
henryrawas 14:570c8071f577 89 BuzzerStartMs((int)IdleTimer.read_ms(), 500);
henryrawas 14:570c8071f577 90 }
henryrawas 14:570c8071f577 91
henryrawas 14:570c8071f577 92 // send temperature alert
henryrawas 14:570c8071f577 93 void PushVoltageAlert(RobotArm& robotArm)
henryrawas 14:570c8071f577 94 {
henryrawas 14:570c8071f577 95 float lastVals[NUMJOINTS];
henryrawas 14:570c8071f577 96
henryrawas 14:570c8071f577 97 // stop trying to move
henryrawas 14:570c8071f577 98 robotArm.GetArmLastMeasure(NM_Voltage, lastVals);
henryrawas 14:570c8071f577 99 int ix = robotArm.GetLastErrorPart();
henryrawas 14:570c8071f577 100 robotArm.MoveArmPositionsStop();
henryrawas 14:570c8071f577 101
henryrawas 14:570c8071f577 102 // report load error
henryrawas 14:570c8071f577 103 printf("Voltage error detected joint %d, value %f\r\n", ix, lastVals[ix]);
henryrawas 14:570c8071f577 104
henryrawas 14:570c8071f577 105 Alert alert;
henryrawas 14:570c8071f577 106 time_t seconds = time(NULL);
henryrawas 14:570c8071f577 107
henryrawas 14:570c8071f577 108 ShowLedRed();
henryrawas 14:570c8071f577 109 alert.SetVoltageAlert(seconds, ix, lastVals[ix]);
henryrawas 14:570c8071f577 110 AlertBuf.push(alert);
henryrawas 14:570c8071f577 111
henryrawas 14:570c8071f577 112 BuzzerStartMs((int)IdleTimer.read_ms(), 500);
henryrawas 14:570c8071f577 113 }
henryrawas 14:570c8071f577 114
henryrawas 14:570c8071f577 115
henryrawas 14:570c8071f577 116 // send hardware error alert
henryrawas 14:570c8071f577 117 void PushHardwareAlert(int partIx, int code)
henryrawas 14:570c8071f577 118 {
henryrawas 14:570c8071f577 119 Alert alert;
henryrawas 14:570c8071f577 120 time_t seconds = time(NULL);
henryrawas 14:570c8071f577 121
henryrawas 14:570c8071f577 122 ShowLedRed();
henryrawas 14:570c8071f577 123 alert.SetHardwareAlert(seconds, partIx, code);
henryrawas 14:570c8071f577 124 AlertBuf.push(alert);
henryrawas 14:570c8071f577 125
henryrawas 14:570c8071f577 126 BuzzerStartMs((int)IdleTimer.read_ms(), 500);
henryrawas 14:570c8071f577 127 }
henryrawas 14:570c8071f577 128
henryrawas 14:570c8071f577 129 bool PushMeasurements(int partSize, RobotArm& robotArm)
henryrawas 14:570c8071f577 130 {
henryrawas 14:570c8071f577 131 // space for getting measurements from arm
henryrawas 17:0dbcbd8587fd 132 MeasureSnapshot measureSnap;
henryrawas 14:570c8071f577 133
henryrawas 14:570c8071f577 134 float lastVals[NUMJOINTS];
henryrawas 17:0dbcbd8587fd 135 measureSnap.Created = time(NULL);
henryrawas 14:570c8071f577 136
henryrawas 14:570c8071f577 137 bool ok = true;
henryrawas 14:570c8071f577 138
henryrawas 14:570c8071f577 139 ok = robotArm.GetArmLastMeasure(NM_Temperature, lastVals);
henryrawas 14:570c8071f577 140 DispMeasure("Temperatures", partSize, lastVals);
henryrawas 18:224289104fc0 141 measureSnap.Temps.SetMeasure(partSize, lastVals);
henryrawas 14:570c8071f577 142
henryrawas 14:570c8071f577 143 if (ok)
henryrawas 14:570c8071f577 144 {
henryrawas 14:570c8071f577 145 ok = robotArm.GetArmLastMeasure(NM_Voltage, lastVals);
henryrawas 14:570c8071f577 146 DispMeasure("Voltage", partSize, lastVals);
henryrawas 18:224289104fc0 147 measureSnap.Volts.SetMeasure(partSize, lastVals);
henryrawas 14:570c8071f577 148 }
henryrawas 14:570c8071f577 149
henryrawas 14:570c8071f577 150 if (ok)
henryrawas 14:570c8071f577 151 {
henryrawas 14:570c8071f577 152 ok = robotArm.GetArmLastMeasure(NM_Degrees, lastVals);
henryrawas 14:570c8071f577 153 DispMeasure("Rotation", partSize, lastVals);
henryrawas 18:224289104fc0 154 measureSnap.Positions.SetMeasure(partSize, lastVals);
henryrawas 14:570c8071f577 155 }
henryrawas 14:570c8071f577 156
henryrawas 14:570c8071f577 157 if (ok)
henryrawas 14:570c8071f577 158 {
henryrawas 17:0dbcbd8587fd 159 ok = robotArm.GetArmLastMeasure(NM_Load, lastVals);
henryrawas 14:570c8071f577 160 DispMeasure("Load", partSize, lastVals);
henryrawas 18:224289104fc0 161 measureSnap.Loads.SetMeasure(partSize, lastVals);
henryrawas 17:0dbcbd8587fd 162 }
henryrawas 17:0dbcbd8587fd 163
henryrawas 17:0dbcbd8587fd 164 if (ok)
henryrawas 17:0dbcbd8587fd 165 {
henryrawas 17:0dbcbd8587fd 166 MeasureBuf.push(measureSnap);
henryrawas 14:570c8071f577 167 }
henryrawas 14:570c8071f577 168
henryrawas 14:570c8071f577 169 return ok;
henryrawas 14:570c8071f577 170 }