forked from mindsensors/EVShield
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathEVs_NXTMMX.h
221 lines (167 loc) · 7.38 KB
/
EVs_NXTMMX.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
// EVs_NXTMMX.h
//
// This is a class for controlling the Lego Motor Multiplexer, made by Mindsensors.
// See http://www.mindsensors.com/index.php?module=pagemaster&PAGE_user_op=view_page&PAGE_id=134 .
// Initial version: 2010-06-07 by Clinton Blackmore
// Large ports of the code is ported from the NXC library for the device,
// written by Deepak Patil.
/*
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/
#ifndef EVs_NXTMMX_H
#define EVs_NXTMMX_H
// THE FOLLOWING CONSTANTS ARE ALL FROM THE NXC SOURCE CODE
#define MMX_CONTROL_SPEED 0x01
#define MMX_CONTROL_RAMP 0x02
#define MMX_CONTROL_RELATIVE 0x04
#define MMX_CONTROL_TACHO 0x08
#define MMX_CONTROL_BRK 0x10
#define MMX_CONTROL_ON 0x20
#define MMX_CONTROL_TIME 0x40
#define MMX_CONTROL_GO 0x80
#define MMX_COMMAND 0x41
#define MMX_VOLTAGE 0x41
#define MMX_SETPT_M1 0x42
#define MMX_SPEED_M1 0x46
#define MMX_TIME_M1 0x47
#define MMX_CMD_B_M1 0x48
#define MMX_CMD_A_M1 0x49
#define MMX_SETPT_M2 0x4A
#define MMX_SPEED_M2 0x4E
#define MMX_TIME_M2 0x4F
#define MMX_CMD_B_M2 0x50
#define MMX_CMD_A_M2 0x51
/*
* Read registers.
*/
#define MMX_POSITION_M1 0x62
#define MMX_POSITION_M2 0x66
#define MMX_STATUS_M1 0x72
#define MMX_STATUS_M2 0x73
#define MMX_TASKS_M1 0x76
#define MMX_TASKS_M2 0x77
#define MMX_ENCODER_PID 0x7A
#define MMX_SPEED_PID 0x80
#define MMX_PASS_COUNT 0x86
#define MMX_TOLERANCE 0x87
/* constants to be used by user programs */
/*
* Motor selection related constants
*/
#define MMX_Motor_1 0x01
#define MMX_Motor_2 0x02
#define MMX_Motor_Both 0x03
/*
* Next action related constants
*/
// stop and let the motor coast.
#define MMX_Next_Action_Float 0x00
// apply brakes, and resist change to tachometer
#define MMX_Next_Action_Brake 0x01
// apply brakes, and restore externally forced change to tachometer
#define MMX_Next_Action_BrakeHold 0x02
/*
* Direction related constants
*/
#define MMX_Direction_Forward 0x01
#define MMX_Direction_Reverse 0x00
/*
* Tachometer related constants
*/
#define MMX_Move_Relative 0x01
#define MMX_Move_Absolute 0x00
#define MMX_Completion_Wait_For 0x01
#define MMX_Completion_Dont_Wait 0x00
/*
* Speed constants, these are just convenience constants,
* You can use any value between 0 and 100.
*/
#define MMX_Speed_Full 90
#define MMX_Speed_Medium 60
#define MMX_Speed_Slow 25
#include "EVShieldI2C.h"
/**
@brief This class interfaces with NXTMMX attached to EVShield
*/
class EVs_NXTMMX : public EVShieldI2C
{
public:
/** constructor for NXTMMX
*/
EVs_NXTMMX(uint8_t i2c_address = 0x06);
/** get the battery voltage for the MMX */
uint8_t getBatteryVoltage();
/** issue a command to this bank of the NXTMMX */
uint8_t issueCommand(char command);
/** set the target encoder position for the motor */
bool setEncoderTarget(uint8_t which_motor, long target);
/** get the target encoder position for the motor */
long getEncoderTarget(uint8_t which_motor);
/** set the speed of the motor */
bool setSpeed(uint8_t which_motor, int speed);
/** get the speed of the motor */
int8_t getSpeed(uint8_t which_motor);
/** set the time in seconds for which the motor should run for */
bool getTimeToRun(uint8_t which_motor, int seconds);
/** get the time in seconds that the motor is running for */
uint8_t getTimeToRun(uint8_t which_motor);
bool setCommandRegB(uint8_t which_motor, uint8_t value);
uint8_t getCommandRegB(uint8_t which_motor);
bool setCommandRegA(uint8_t which_motor, uint8_t value);
uint8_t getCommandRegA(uint8_t which_motor);
/** get the current encoder position of the motor in degrees */
int32_t getEncoderPosition(uint8_t which_motor);
/** get the current status of the motor */
uint8_t getMotorStatusByte(uint8_t which_motor);
/** get the tasks that are running on the specific motor */
uint8_t getMotorTasksRunningByte(uint8_t which_motor);
/** set the PID control for the encoders */
bool setEncoderPID(uint16_t Kp, uint16_t Ki, uint16_t Kd);
/** set the PID control for the speed of the motors */
bool setSpeedPID(uint16_t Kp, uint16_t Ki, uint16_t Kd);
/** set how many times the PID controller is allowed to oscillate about the set point */
bool setPassCount(uint8_t pass_count);
/** set how far away from the set point the PID controller is allowed to oscillate (amplitude) */
bool setTolerance(uint8_t tolerance);
/** reset all the set values for the motors */
bool reset();
/** start both motors at the same time to follow the set conditions */
bool startMotorsInSync();
/** reset the current encoder position to zero for the motor */
bool resetEncoder(uint8_t which_motor);
/** set the speed, duration to run, and control for the motor */
bool setSpeedTimeAndControl(uint8_t which_motors, int speed, uint8_t duration, uint8_t control);
/** set the ratget encoder position, speed, duration to run, and control for the motor */
bool setEncoderSpeedTimeAndControl(uint8_t which_motors, long encoder, int speed, uint8_t duration, uint8_t control);
/** validate if the motor has finished running for the set time duration */
bool isTimeDone(uint8_t which_motors);
/** wait until the motor has finished running for its set respective time duration */
void waitUntilTimeDone(uint8_t which_motors);
/** validate if the motor has reached its set target tachometer position */
bool isTachoDone(uint8_t which_motors);
/** wait until the motor has reached its set target tachometer position */
void waitUntilTachoDone(uint8_t which_motors);
/** run the motor endlessly at the desired speed in the desired direction */
void runUnlimited(uint8_t which_motors, uint8_t direction, int speed);
/** run the motor for a set duration at a set speed and do the next action */
void runSeconds(uint8_t which_motors, uint8_t direction, int speed, uint8_t duration, uint8_t wait_for_completion, uint8_t next_action);
/** run until the tachometer target has been reached and do next action */
void runTachometer(uint8_t which_motors, uint8_t direction, int speed, long tachometer, uint8_t relative, uint8_t wait_for_completion, uint8_t next_action);
/** run the motor for a set number of degrees and proceed to the next action */
void runDegrees(uint8_t which_motors, uint8_t direction,int speed, long degrees, uint8_t wait_for_completion, uint8_t next_action);
/** run the motor for a set number of complete rotations and proceed to the next action */
void runRotations( uint8_t which_motors, uint8_t direction, int speed, long rotations, uint8_t wait_for_completion, uint8_t next_action);
/** stop the motor and do an action */
bool stop(uint8_t which_motors, uint8_t next_action);
};
#endif