Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
m3pi.cpp
00001 /* m3pi Library 00002 * 00003 * Copyright (c) 2007-2010 cstyles 00004 * 00005 * Permission is hereby granted, free of charge, to any person obtaining a copy 00006 * of this software and associated documentation files (the "Software"), to deal 00007 * in the Software without restriction, including without limitation the rights 00008 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 00009 * copies of the Software, and to permit persons to whom the Software is 00010 * furnished to do so, subject to the following conditions: 00011 * 00012 * The above copyright notice and this permission notice shall be included in 00013 * all copies or substantial portions of the Software. 00014 * 00015 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 00016 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 00017 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 00018 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 00019 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 00020 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 00021 * THE SOFTWARE. 00022 */ 00023 00024 #include "mbed.h" 00025 #include "m3pi.h" 00026 00027 m3pi::m3pi(PinName nrst, PinName tx, PinName rx) : Stream("m3pi"), _nrst(nrst), _ser(tx, rx) { 00028 _ser.baud(115200); 00029 reset(); 00030 } 00031 00032 m3pi::m3pi() : Stream("m3pi"), _nrst(p23), _ser(p9, p10) { 00033 _ser.baud(115200); 00034 reset(); 00035 } 00036 00037 00038 void m3pi::reset () { 00039 _nrst = 0; 00040 wait (0.01); 00041 _nrst = 1; 00042 wait (0.1); 00043 } 00044 00045 void m3pi::left_motor (float speed) { 00046 motor(0,speed); 00047 } 00048 00049 void m3pi::right_motor (float speed) { 00050 motor(1,speed); 00051 } 00052 00053 void m3pi::forward (float speed) { 00054 motor(0,speed); 00055 motor(1,speed); 00056 } 00057 00058 void m3pi::backward (float speed) { 00059 motor(0,-1.0*speed); 00060 motor(1,-1.0*speed); 00061 } 00062 00063 void m3pi::left (float speed) { 00064 motor(0,speed); 00065 motor(1,-1.0*speed); 00066 } 00067 00068 void m3pi::right (float speed) { 00069 motor(0,-1.0*speed); 00070 motor(1,speed); 00071 } 00072 00073 void m3pi::stop (void) { 00074 motor(0,0.0); 00075 motor(1,0.0); 00076 } 00077 00078 void m3pi::motor (int motor, float speed) { 00079 char opcode = 0x0; 00080 if (speed > 0.0) { 00081 if (motor==1) 00082 opcode = M1_FORWARD; 00083 else 00084 opcode = M2_FORWARD; 00085 } else { 00086 if (motor==1) 00087 opcode = M1_BACKWARD; 00088 else 00089 opcode = M2_BACKWARD; 00090 } 00091 unsigned char arg = 0x7f * abs(speed); 00092 00093 _ser.putc(opcode); 00094 _ser.putc(arg); 00095 } 00096 00097 float m3pi::battery() { 00098 _ser.putc(SEND_BATTERY_MILLIVOLTS); 00099 char lowbyte = _ser.getc(); 00100 char hibyte = _ser.getc(); 00101 float v = ((lowbyte + (hibyte << 8))/1000.0); 00102 return(v); 00103 } 00104 00105 float m3pi::line_position() { 00106 int pos = 0; 00107 _ser.putc(SEND_LINE_POSITION); 00108 pos = _ser.getc(); 00109 pos += _ser.getc() << 8; 00110 00111 float fpos = ((float)pos - 2048.0)/2048.0; 00112 return(fpos); 00113 } 00114 00115 char m3pi::sensor_auto_calibrate() { 00116 _ser.putc(AUTO_CALIBRATE); 00117 return(_ser.getc()); 00118 } 00119 00120 00121 void m3pi::calibrate(void) { 00122 _ser.putc(PI_CALIBRATE); 00123 } 00124 00125 void m3pi::reset_calibration() { 00126 _ser.putc(LINE_SENSORS_RESET_CALIBRATION); 00127 } 00128 00129 void m3pi::PID_start(int max_speed, int a, int b, int c, int d) { 00130 _ser.putc(SET_PID); 00131 _ser.putc(max_speed); 00132 _ser.putc(a); 00133 _ser.putc(b); 00134 _ser.putc(c); 00135 _ser.putc(d); 00136 } 00137 00138 void m3pi::PID_stop() { 00139 _ser.putc(STOP_PID); 00140 } 00141 00142 float m3pi::pot_voltage(void) { 00143 int volt = 0; 00144 _ser.putc(SEND_TRIMPOT); 00145 volt = _ser.getc(); 00146 volt += _ser.getc() << 8; 00147 return(volt); 00148 } 00149 00150 00151 void m3pi::leds(int val) { 00152 00153 BusOut _leds(p20,p19,p18,p17,p16,p15,p14,p13); 00154 _leds = val; 00155 } 00156 00157 00158 void m3pi::locate(int x, int y) { 00159 _ser.putc(DO_LCD_GOTO_XY); 00160 _ser.putc(x); 00161 _ser.putc(y); 00162 } 00163 00164 void m3pi::cls(void) { 00165 _ser.putc(DO_CLEAR); 00166 } 00167 00168 int m3pi::print (char* text, int length) { 00169 _ser.putc(DO_PRINT); 00170 _ser.putc(length); 00171 for (int i = 0 ; i < length ; i++) { 00172 _ser.putc(text[i]); 00173 } 00174 return(0); 00175 } 00176 00177 void m3pi::play (char* music, int length) { 00178 // The default 3pi serial slave program 00179 // will not accept music strings longer than 100. 00180 if (length > 100) 00181 length = 100; 00182 _ser.putc(DO_PLAY); 00183 _ser.putc(length); 00184 for (int i = 0 ; i < length ; i++) { 00185 _ser.putc(music[i]); 00186 } 00187 } 00188 00189 int m3pi::_putc (int c) { 00190 _ser.putc(DO_PRINT); 00191 _ser.putc(0x1); 00192 _ser.putc(c); 00193 wait (0.001); 00194 return(c); 00195 } 00196 00197 int m3pi::_getc (void) { 00198 char r = 0; 00199 return(r); 00200 } 00201 00202 int m3pi::putc (int c) { 00203 return(_ser.putc(c)); 00204 } 00205 00206 int m3pi::getc (void) { 00207 return(_ser.getc()); 00208 } 00209 00210 00211 00212 00213 #ifdef MBED_RPC 00214 const rpc_method *m3pi::get_rpc_methods() { 00215 static const rpc_method rpc_methods[] = {{ "forward", rpc_method_caller<m3pi, float, &m3pi::forward> }, 00216 { "backward", rpc_method_caller<m3pi, float, &m3pi::backward> }, 00217 { "left", rpc_method_caller<m3pi, float, &m3pi::left> }, 00218 { "right", rpc_method_caller<m3pi, float, &m3pi::right> }, 00219 { "stop", rpc_method_caller<m3pi, &m3pi::stop> }, 00220 { "left_motor", rpc_method_caller<m3pi, float, &m3pi::left_motor> }, 00221 { "right_motor", rpc_method_caller<m3pi, float, &m3pi::right_motor> }, 00222 { "battery", rpc_method_caller<float, m3pi, &m3pi::battery> }, 00223 { "line_position", rpc_method_caller<float, m3pi, &m3pi::line_position> }, 00224 { "sensor_auto_calibrate", rpc_method_caller<char, m3pi, &m3pi::sensor_auto_calibrate> }, 00225 00226 00227 RPC_METHOD_SUPER(Base) 00228 }; 00229 return rpc_methods; 00230 } 00231 #endif
Generated on Thu Jul 21 2022 10:31:33 by
1.7.2