stats.h 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220
  1. #ifndef STATS_MODULE
  2. #define STATS_MODULE
  3. #import <Arduino.h>
  4. #include "definitions.h"
  5. #include "pins.h"
  6. #include "reporter.h"
  7. struct StatsStruct
  8. {
  9. StatsMessage ENTERED_LANE(short lane)
  10. {
  11. reportPWM(Pins.PWM_LaneState, LaneStatePwm::InsideLane);
  12. return StatsMessage(0, "Entered lane\0", lane + 1);
  13. }
  14. StatsMessage EXITED_LANE(short lane)
  15. {
  16. reportPWM(Pins.PWM_LaneState, LaneStatePwm::OutsideLane);
  17. return StatsMessage(1, "Exited lane\0", lane + 1);
  18. }
  19. StatsMessage MOTOR_PUSHED()
  20. {
  21. reportPWM(Pins.PWM_Actuator, ActuatorPwm::Pushing);
  22. return StatsMessage(10, "Motor is pushed\0");
  23. }
  24. StatsMessage MOTOR_PULLED()
  25. {
  26. reportPWM(Pins.PWM_Actuator, ActuatorPwm::Retracting);
  27. return StatsMessage(11, "Motor is pulled\0");
  28. }
  29. StatsMessage MOTOR_MAX_RANGE()
  30. {
  31. reportPWM(Pins.PWM_Actuator, ActuatorPwm::MaxDistance);
  32. return StatsMessage(12, "Motor is at max distance\0");
  33. }
  34. StatsMessage MOTOR_MIN_RANGE()
  35. {
  36. reportPWM(Pins.PWM_Actuator, ActuatorPwm::MinDistance);
  37. return StatsMessage(13, "Motor is at min distance\0");
  38. }
  39. StatsMessage MOTOR_WAIT_DONE()
  40. {
  41. return StatsMessage(14, "Motor wait time is is done.\0");
  42. }
  43. StatsMessage ENTERED_LANE_RANGE(short lane)
  44. {
  45. lane++; // Make lanes start from 1 instead of zero
  46. // TODO: Create a function to take care of this
  47. switch (lane)
  48. {
  49. case 1:
  50. reportPWM(Pins.PWM_CurrentLaneNum, CurrentLaneNumPWM::Lane1);
  51. break;
  52. case 2:
  53. reportPWM(Pins.PWM_CurrentLaneNum, CurrentLaneNumPWM::Lane2);
  54. break;
  55. case 3:
  56. reportPWM(Pins.PWM_CurrentLaneNum, CurrentLaneNumPWM::Lane3);
  57. break;
  58. case 4:
  59. reportPWM(Pins.PWM_CurrentLaneNum, CurrentLaneNumPWM::Lane4);
  60. break;
  61. default:
  62. reportPWM(Pins.PWM_CurrentLaneNum, CurrentLaneNumPWM::Unknown);
  63. }
  64. return StatsMessage(20, "Entered rotation range of lane\0", lane);
  65. }
  66. StatsMessage CORRECT_SENSOR_TOUCHED()
  67. {
  68. reportPWM(Pins.PWM_DecisionResult, DecisionResultPwm::Correct);
  69. return StatsMessage(30, "Correct sensor touched\0");
  70. }
  71. StatsMessage WRONG_SENSOR_TOUCHED()
  72. {
  73. reportPWM(Pins.PWM_DecisionResult, DecisionResultPwm::Wrong);
  74. return StatsMessage(31, "Wrong sensor touched\0");
  75. }
  76. StatsMessage RIGHT_SENSOR_TOUCHED()
  77. {
  78. reportPWM(Pins.PWM_LickDirection, LickDirectionPwm::Right);
  79. return StatsMessage(35, "R-located sensor touched\0");
  80. }
  81. StatsMessage LEFT_SENSOR_TOUCHED()
  82. {
  83. reportPWM(Pins.PWM_LickDirection, LickDirectionPwm::Left);
  84. return StatsMessage(36, "L-located sensor touched\0");
  85. }
  86. void REPORT_SENSORS_UNTOUCHED ()
  87. {
  88. reportPWM(Pins.PWM_LickDirection, LickDirectionPwm::Untouched);
  89. }
  90. // Next one is not reported yet
  91. StatsMessage OTHER_SENSOR_TOUCHED(short sensor)
  92. {
  93. return StatsMessage(37, "Other sensor touched - Sensor nr.\0", sensor);
  94. }
  95. StatsMessage REWARD_GIVEN(bool automated_mode)
  96. {
  97. if (automated_mode)
  98. {
  99. reportPWM(Pins.PWM_RewardResult, RewardResultPwm::AutomatedGiven);
  100. return StatsMessage(44, "Giving reward automatically\0");
  101. }
  102. else
  103. {
  104. reportPWM(Pins.PWM_RewardResult, RewardResultPwm::Given);
  105. return StatsMessage(40, "Giving reward\0");
  106. }
  107. }
  108. StatsMessage REWARD_NOT_GIVEN()
  109. {
  110. reportPWM(Pins.PWM_RewardResult, RewardResultPwm::NotGiven);
  111. return StatsMessage(41, "Not giving reward\0");
  112. }
  113. StatsMessage MISS_DECISION()
  114. {
  115. reportPWM(Pins.PWM_DecisionResult, DecisionResultPwm::Miss);
  116. return StatsMessage(42, "No Decision was made in time\0");
  117. }
  118. StatsMessage NEW_LANE(short lane)
  119. {
  120. // reset trial based PWMs
  121. reportPWM(Pins.PWM_DecisionResult, DecisionResultPwm::Unknown);
  122. reportPWM(Pins.PWM_RewardResult, RewardResultPwm::Unknown);
  123. lane++; // Make lanes start from 1 instead of zero
  124. reportPWM(Pins.PWM_CorrectLaneNum, lane);
  125. return StatsMessage(50, "New lane chosen\0", lane);
  126. }
  127. StatsMessage NEW_TRIAL(short trial)
  128. {
  129. return StatsMessage(55, "Trial number\0", trial);
  130. }
  131. StatsMessage LIGHT_ON()
  132. {
  133. // TEMP: Move this to its own stats
  134. reportPWM(Pins.InCorrecctLane, LaneLedPwm::Off);
  135. reportPWM(Pins.PWM_LaneLed, LaneLedPwm::On);
  136. return StatsMessage(60, "Cue light turned on\0");
  137. }
  138. StatsMessage LIGHT_OFF()
  139. {
  140. // TEMP: Move this to its own stats
  141. reportPWM(Pins.InCorrecctLane, LaneLedPwm::On);
  142. reportPWM(Pins.PWM_LaneLed, LaneLedPwm::Off);
  143. return StatsMessage(61, "Cue light turned off\0");
  144. }
  145. StatsMessage SOLENOID_RIGHT_ON()
  146. {
  147. reportPWM(Pins.PWM_Solenoid, SolenoidPwm::RightOpen);
  148. return StatsMessage(70, "R-located solenoid turned on\0");
  149. }
  150. StatsMessage SOLENOID_RIGHT_OFF()
  151. {
  152. reportPWM(Pins.PWM_Solenoid, SolenoidPwm::BothOff);
  153. return StatsMessage(71, "R-located solenoid turned off\0");
  154. }
  155. StatsMessage SOLENOID_LEFT_ON()
  156. {
  157. reportPWM(Pins.PWM_Solenoid, SolenoidPwm::LeftOpen);
  158. return StatsMessage(72, "L-located solenoid turned on\0");
  159. }
  160. StatsMessage SOLENOID_LEFT_OFF()
  161. {
  162. reportPWM(Pins.PWM_Solenoid, SolenoidPwm::BothOff);
  163. return StatsMessage(73, "L-located solenoid turned off\0");
  164. }
  165. StatsMessage FORCE_SENSOR_ON(bool is_left)
  166. {
  167. char* msg;
  168. if (is_left)
  169. {
  170. // TODO: change PWM in next trial
  171. //reportPWM(Pins.PWM_RewardState, RewardStatePwm::ForcedLeft);
  172. msg = (char*)"Force sensor mode on (left)\0";
  173. }
  174. else
  175. {
  176. //reportPWM(Pins.PWM_RewardState, RewardStatePwm::ForcedRight);
  177. msg = (char*)"Force sensor mode on (right)\0";
  178. }
  179. return StatsMessage(80, msg, is_left);
  180. }
  181. StatsMessage FORCE_SENSOR_OFF()
  182. {
  183. //reportPWM(Pins.PWM_RewardState, RewardStatePwm::Normal);
  184. return StatsMessage(81, "Force sensor mode is off\0");
  185. }
  186. StatsMessage FEEDBACK_AUTOMATED_ON()
  187. {
  188. return StatsMessage(82, "Feedback automated on\0");
  189. }
  190. StatsMessage FEEDBACK_AUTOMATED_OFF()
  191. {
  192. return StatsMessage(83, "Feedback automated off\0");
  193. }
  194. void REPORT_PIXY_POSITION (SubjectLocation location)
  195. {
  196. reportPWM(Pins.PWM_PixyX, PixyXPwm.convert(location.x));
  197. reportPWM(Pins.PWM_PixyY, PixyYPwm.convert(location.y));
  198. reportPWM(Pins.PWM_PixyAngle, PixyAnglePwm.convert(location.angle));
  199. }
  200. } Stats;
  201. #endif