亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? pioneer_test.c

?? 卡內(nèi)基梅隆大學(xué)(CMU)開發(fā)的移動(dòng)機(jī)器人控制開發(fā)軟件包??蓪Χ喾N機(jī)器人進(jìn)行控制
?? C
字號:
 /********************************************************* * * This source code is part of the Carnegie Mellon Robot * Navigation Toolkit (CARMEN) * * CARMEN Copyright (c) 2002 Michael Montemerlo, Nicholas * Roy, Sebastian Thrun, Dirk Haehnel, Cyrill Stachniss, * and Jared Glover * * CARMEN is free software; you can redistribute it and/or  * modify it under the terms of the GNU General Public  * License as published by the Free Software Foundation;  * either version 2 of the License, or (at your option) * any later version. * * CARMEN 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 General Public License for more  * details. * * You should have received a copy of the GNU General  * Public License along with CARMEN; if not, write to the * Free Software Foundation, Inc., 59 Temple Place,  * Suite 330, Boston, MA  02111-1307 USA * ********************************************************/#include <carmen/carmen.h>#include <limits.h>#define        PIONEER_SERIAL_TIMEOUT            5.0#define        METRES_PER_INCH          0.0254#define        WHEELBASE                (16.5 * METRES_PER_INCH) // need to set this#define        ROT_VEL_FACT_RAD         (WHEELBASE)static int dev_fd;static double max_t_vel = 1.0;#define PIONEER_PACKET_HEADER  "\xFA\xFB"#define PIONEER_SYNC0           0#define PIONEER_SYNC1           1#define PIONEER_SYNC2           2#define PIONEER_PULSE           0#define PIONEER_OPEN            1#define PIONEER_CLOSE           2#define PIONEER_ENABLE          4#define PIONEER_SETA            5#define PIONEER_STOP            29#define PIONEER_VEL2            32#define PIONEER_NEGATIVE_INT    0x1B#define PIONEER_POSITIVE_INT    0x3B#define PIONEER_ON              1#define PIONEER_OFF             0#define PIONEER2_VEL2_CONVERSION_FACTOR             50.0              // m/s => 2cm/sec#define PIONEER_MAX_NUM_SONARS  16struct pioneer_raw_information_packet {  unsigned char motor_status;  unsigned char x[2];  unsigned char y[2];  unsigned char orientation[2];  unsigned char vl[2];  unsigned char vr[2];  unsigned char battery;  unsigned char bumper[2];  unsigned char servo_position[2];  unsigned char pulse_width[2];  unsigned char compass_heading;  unsigned char num_sonar_readings;  struct {    unsigned char n;    unsigned char range[2];  } sonar[3*PIONEER_MAX_NUM_SONARS];};static int pioneer_buf_to_checksum(unsigned char *buf) {  return 256*buf[0] + buf[1];}static int pioneer_calculate_checksum(unsigned char *ptr, int length) {  unsigned int c = 0;    while(length > 1)     {      c += (*(ptr)<<8) | *(ptr+1);      c = c & 0xffff;      length -= 2;      ptr += 2;    }  if(length > 0)     c = c ^ (int)*(ptr++);  return(c);}static void pioneer_int_to_buf(unsigned char *buf, int n) {  if (n >= 0)    buf[0] = PIONEER_POSITIVE_INT;  else    buf[0] = PIONEER_NEGATIVE_INT;  n = abs(n);  buf[1] = n & 0x00FF;  buf[2] = (n & 0xFF00) >> 8;} static int pioneer_read_string(unsigned char *buf, double read_timeout) {  int c = 0;  int header_length = strlen(PIONEER_PACKET_HEADER);  unsigned char header[header_length+1];  unsigned char length_char[1];  int i;  double start_time, current_time;  for (i = 0; i <= header_length; ++i)    header[i] = '\0';  start_time = carmen_get_time();  do     {                                  /* busy waits until we read the   */      for (i = 1; i < header_length; ++i) /* command header                 */	header[i-1] = header[i];      carmen_serial_readn(dev_fd, header + header_length - 1, 1);      if (read_timeout > 0) {	current_time = carmen_get_time();	if (current_time - start_time > read_timeout)	  // timeout	  return -1;      }    }   while (strcmp((char *)header, (const char *)PIONEER_PACKET_HEADER) != 0);    carmen_serial_readn(dev_fd, length_char, 1);  c = (int) length_char[0];             /* the length, including chksum   */  carmen_serial_readn(dev_fd, buf, c);  c -= 2;                               /* removes checksum from length,  */                                        /* checksum is now at buf+c       */  if (pioneer_calculate_checksum(buf, c) != pioneer_buf_to_checksum(buf+c))     {      fprintf(stderr, "Checksum error on packet ");      for (i = 0; i < c; ++i)	fprintf(stderr, "%c", buf[i]);      fprintf(stderr, "\n");      return pioneer_read_string(buf, read_timeout);    }  return c;}static int pioneer_send_string(unsigned char *ptr, int length) {  int send_length = length + 5;         /* adds a 2-byte packet header,   */                                        /* a 1-byte length (inc. chksum), */                                        /* and a 2-byte checksum          */  unsigned char cmd[256] = PIONEER_PACKET_HEADER;  int checksum;  int i;  if (length <= 0)    return 0;  cmd[2] = (unsigned char) length+2;  for (i = 0; i < length; ++i)    cmd[i+3] = ptr[i];  checksum = pioneer_calculate_checksum(ptr, length);  cmd[send_length-2] = (unsigned char) ((checksum & 0xFF00) >> 8);  cmd[send_length-1] = (unsigned char) (checksum & 0x00FF);  return carmen_serial_writen(dev_fd, cmd, send_length);}static int pioneer_send_command0(char cmd) {  char buf[256];  buf[0] = cmd;  return pioneer_send_string((unsigned char *)buf, 1);}static int pioneer_send_command1(char cmd, int arg1) {  char buf[256];    buf[0] = cmd;  pioneer_int_to_buf((unsigned char *)(buf+1), arg1);  return pioneer_send_string((unsigned char *)buf, 4);}static void pioneer_seta(int accel, int decel) {  accel = abs(accel);  decel = abs(decel);  accel *= 10;  decel *= 10;  pioneer_send_command1(PIONEER_SETA, accel);  pioneer_send_command1(PIONEER_SETA, -decel);}static int pioneer_sync0(void) {  unsigned char buf[256];  buf[0] = !PIONEER_SYNC0;  pioneer_send_command0(PIONEER_SYNC0);  pioneer_read_string(buf, 0.2);  if (buf[0] != PIONEER_SYNC0) {    carmen_warn("Could not SYNC0\n");    return -1;  }  return 0;}static int pioneer_sync1(void) {  unsigned char buf[256];  pioneer_send_command0(PIONEER_SYNC1);  pioneer_read_string(buf, PIONEER_SERIAL_TIMEOUT);  if (buf[0] != PIONEER_SYNC1) {    fprintf(stderr, "Could not SYNC1\n");    return -1;  }  return 0;}static int pioneer_sync2(void) {  unsigned char buf[256];  pioneer_send_command0(PIONEER_SYNC2);  pioneer_read_string(buf, PIONEER_SERIAL_TIMEOUT);  return 0;}void pioneer_vel2(int vl, int vr) {  int arg;  arg = 256*vl + vr;  pioneer_send_command1(PIONEER_VEL2, arg);}static void set_wheel_velocities(double vl, double vr){  if(vl > max_t_vel)    vl = max_t_vel;  else if(vl < -max_t_vel)    vl = -max_t_vel;  if(vr > max_t_vel)    vr = max_t_vel;  else if(vr < -max_t_vel)    vr = -max_t_vel;  vl *= PIONEER2_VEL2_CONVERSION_FACTOR;  vr *= PIONEER2_VEL2_CONVERSION_FACTOR;  if (vl > 127)    vl = 127;  else if  (vl < -127)    vl = -127;  if (vr > 127)    vr = 127;  else if (vr < -127)    vr = -127;  pioneer_vel2((int)vl, (int)vr);}void shutdown_pioneer(int signo __attribute__ ((unused))) {  fprintf(stderr, "\nShutting down robot...");  sleep(1);  pioneer_send_command0(PIONEER_CLOSE);  fprintf(stderr, "done.\n");  carmen_terminal_restore();  exit(0);}int main(int argc __attribute__ ((unused)),      char **argv __attribute__ ((unused))) {  double wheel_diameter;  char dev_name[100];  double vl, vr;  struct pioneer_raw_information_packet r;  int k;  double tv, rv;  signal(SIGINT, shutdown_pioneer);  signal(SIGTERM, shutdown_pioneer);  carmen_terminal_cbreak(0);  strcpy(dev_name, "/dev/ttyS24");  wheel_diameter = 0.165;  if (carmen_serial_connect(&dev_fd, dev_name) < 0)     return -1;  if (pioneer_sync0() < 0)    return -1;  if (pioneer_sync1() < 0)    return -1;  if (pioneer_sync2() < 0)    return -1;  pioneer_send_command0(PIONEER_OPEN);  pioneer_send_command0(PIONEER_PULSE);    pioneer_send_command1(PIONEER_ENABLE, PIONEER_ON);  pioneer_seta(10, 3.0);  while(1) {    fprintf(stderr, ".");    pioneer_send_command0(PIONEER_PULSE);      if (pioneer_read_string((unsigned char*) &r, PIONEER_SERIAL_TIMEOUT) < 0)      carmen_die("Serial read timed out\n");    k = getchar();    if (k != EOF) {      switch(k) {      case 'u': tv = 0.5; rv = 0.2; break;      case 'i': tv = 0.5; rv = 0.0; break;      case 'o': tv = 0.5; rv = -0.2; break;      case 'j': tv = 0.0; rv = 0.2; break;      case 'k': tv = 0.0; rv = 0; break;      case 'l': tv = 0.0; rv = -0.2; break;      case 'm': tv = -0.5; rv = 0.2; break;      case ',': tv = -0.5; rv = 0; break;      case '.': tv = -0.5; rv = -0.2; break;      default:  tv = 0.0; rv = 0; break;      }      if (tv == 0.0 && rv == 0.0) {	pioneer_send_command0(PIONEER_STOP);      } else {	vl = tv;	vr = tv;	vl -= 0.5 * rv * ROT_VEL_FACT_RAD*3;	vr += 0.5 * rv * ROT_VEL_FACT_RAD*3;	set_wheel_velocities(vl, vr);      }    }  }  return 0;}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
●精品国产综合乱码久久久久| 91在线一区二区三区| 欧美日韩国产免费一区二区| 怡红院av一区二区三区| 在线观看一区不卡| 亚洲午夜久久久久久久久电影院 | 欧美亚洲国产一区二区三区va| 自拍偷自拍亚洲精品播放| 色综合天天在线| 亚洲伊人伊色伊影伊综合网| 欧美日韩色一区| 蜜臀久久99精品久久久画质超高清 | 国产精品99久久久久久有的能看| 欧美精品一区二区三| 国产成人av电影免费在线观看| 国产精品亲子伦对白| 一本色道a无线码一区v| 婷婷丁香激情综合| 久久综合网色—综合色88| 不卡一区二区中文字幕| 亚洲一区二区美女| 久久综合999| 色菇凉天天综合网| 日本亚洲天堂网| 国产精品久久一卡二卡| 欧美日韩精品一区二区三区| 国产伦精品一区二区三区免费迷| 亚洲日穴在线视频| 日韩精品一区二区三区在线| 91丨porny丨首页| 蜜桃在线一区二区三区| 亚洲欧洲精品一区二区三区| 91.com视频| av亚洲精华国产精华| 青青草成人在线观看| √…a在线天堂一区| 欧美videos大乳护士334| 成人动漫中文字幕| 秋霞午夜鲁丝一区二区老狼| 亚洲少妇中出一区| 精品精品欲导航| 在线视频综合导航| 国产一区91精品张津瑜| 亚洲一卡二卡三卡四卡五卡| 国产调教视频一区| 欧美一三区三区四区免费在线看 | 一区二区三区在线免费| 国产亚洲欧美在线| 在线成人小视频| 北条麻妃一区二区三区| 国产自产视频一区二区三区| 亚洲一区二区三区视频在线| 国产精品美女一区二区三区 | 正在播放亚洲一区| 91在线观看成人| 国产经典欧美精品| 久久精品久久综合| 日韩黄色免费电影| 亚洲国产成人91porn| 亚洲人吸女人奶水| 国产精品护士白丝一区av| 久久久久久久国产精品影院| 欧美一区日韩一区| 欧美性色黄大片| 欧美午夜不卡视频| 色94色欧美sute亚洲线路一久| 大陆成人av片| eeuss国产一区二区三区| 国产成人亚洲综合a∨猫咪| 极品少妇xxxx偷拍精品少妇| 秋霞午夜鲁丝一区二区老狼| 日本不卡一区二区| 日本成人在线网站| 日韩成人午夜精品| 日韩av电影免费观看高清完整版 | 成人av资源站| 99久久婷婷国产综合精品电影| 成人综合在线网站| 成人国产亚洲欧美成人综合网| 成人综合在线观看| av电影在线观看不卡| 9l国产精品久久久久麻豆| 成人v精品蜜桃久久一区| 丁香天五香天堂综合| 成人综合在线网站| www.色综合.com| 色综合久久中文字幕| 在线观看网站黄不卡| 欧美日韩国产成人在线免费| 4438成人网| 精品精品国产高清一毛片一天堂| 国产色一区二区| 亚洲人xxxx| 香蕉影视欧美成人| 美国欧美日韩国产在线播放| 国产精品亚洲а∨天堂免在线| bt欧美亚洲午夜电影天堂| 在线免费观看视频一区| 欧美日韩一级视频| 精品久久99ma| 国产精品国产三级国产普通话99 | 五月天欧美精品| 久久国产乱子精品免费女| 国产福利一区二区| 91免费看视频| 欧美一区永久视频免费观看| 日本一区二区三区四区| 一区二区三区四区亚洲| 美女国产一区二区| jizzjizzjizz欧美| 在线播放亚洲一区| 国产日产欧美一区二区三区| 亚洲小说春色综合另类电影| 精品亚洲aⅴ乱码一区二区三区| 成人性色生活片| 3d动漫精品啪啪1区2区免费| 中文av字幕一区| 五月婷婷另类国产| eeuss鲁片一区二区三区在线看| 91麻豆精品国产无毒不卡在线观看| 精品福利在线导航| 亚洲福利视频导航| 成人动漫一区二区| 日韩欧美国产不卡| 一区二区在线观看视频在线观看| 开心九九激情九九欧美日韩精美视频电影| 成人黄页在线观看| 精品国产乱码久久久久久1区2区| 亚洲激情在线激情| 高清在线不卡av| 欧美大白屁股肥臀xxxxxx| 亚洲欧美另类图片小说| 狠狠色狠狠色综合| 欧美日韩久久久| 成人免费一区二区三区视频 | gogo大胆日本视频一区| 正在播放亚洲一区| 亚洲精选视频在线| 国产福利一区二区三区视频| 日韩视频一区二区在线观看| 一区二区三区精品视频| 成人美女在线视频| 久久亚洲免费视频| 美女视频一区二区| 69av一区二区三区| 亚洲18影院在线观看| 91亚洲精华国产精华精华液| 久久综合色婷婷| 蜜臀av在线播放一区二区三区| 在线免费视频一区二区| 亚洲视频小说图片| 99久久99久久精品免费观看| 精品国产sm最大网站免费看| 另类调教123区| 日韩视频免费直播| 奇米一区二区三区av| 欧美日韩国产小视频| 亚洲在线一区二区三区| 99久久久久久| 亚洲欧洲制服丝袜| 91视频免费播放| 日韩毛片在线免费观看| 不卡一区在线观看| 国产精品久久久久一区| av在线不卡电影| 中文字幕一区av| 色一情一乱一乱一91av| 1区2区3区精品视频| 99久久久国产精品| 亚洲人成在线播放网站岛国 | 国产一区二区视频在线| 欧美成人综合网站| 国产露脸91国语对白| 久久久久九九视频| 成人av综合在线| 亚洲精品免费在线| 欧美性三三影院| 午夜精品福利一区二区三区蜜桃| 欧美色图一区二区三区| 日韩激情视频网站| 欧美精品一区二区三区蜜桃| 成人午夜在线免费| 亚洲一区在线播放| 欧美一区二区大片| 国产成人aaaa| 国产精品动漫网站| 在线免费观看不卡av| 日本美女一区二区| 久久久久久黄色| 色婷婷综合在线| 日韩电影免费在线看| 欧美精品一区二区三区蜜臀| jlzzjlzz欧美大全| 天天影视涩香欲综合网| 久久久久久久综合| 在线观看av一区二区| 日本va欧美va瓶| 国产精品久久精品日日| 欧美精品粉嫩高潮一区二区| 国产精品伊人色|