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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? pioneer_lib.c

?? 卡內基梅隆大學(CMU)開發的移動機器人控制開發軟件包。可對多種機器人進行控制
?? C
?? 第 1 頁 / 共 2 頁
字號:
/********************************************************* * * 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 <carmen/drive_low_level.h>#include <limits.h>#include "pioneer_params.h"#define        PIONEER_SERIAL_TIMEOUT            5static int dev_fd;static int sonar_is_on = 0;static int pioneer_version = 0;static double angle_conv_factor, dist_conv_factor, vel_conv_factor;static double range_conv_factor, diff_conv_factor, vel2_divisor;/*** Some pioneer internal constants.  I have them defined here since the ***//*** outside world doesn't need to know about them.                       ***/#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_POLLING         3#define PIONEER_ENABLE          4#define PIONEER_SETA            5#define PIONEER_VEL             11#define PIONEER_RVEL            21#define PIONEER_SETRA           23#define PIONEER_SONAR           28#define PIONEER_STOP            29#define PIONEER_VEL2            32#define PIONEER_NEGATIVE_INT    0x1B#define PIONEER_STRING          0x2B#define PIONEER_POSITIVE_INT    0x3B#define PIONEER_ON              1#define PIONEER_OFF             0#define PIONEER_MOTOR_NO_POWER  0x31#define PIONEER_MOTOR_STOPPED   0x32#define PIONEER_MOTOR_MOVING    0x33#define PIONEER_BATTERY_CONVERSION_FACTOR           0.1#define PIONEER_COMPASS_CONVERSION_FACTOR           2.0#define PIONEER_MAX_NUM_SONARS   32#define PIONEER_MAX_NUM_BUMPERS  14/* Cyrill, 14.01.2004   according to the ActivMedia manual the discretization   is 4mm/sec, not 5mm/sec. So the factor should be 250.0   and not 200.0 *///#define PIONEER1_VEL2_CONVERSION_FACTOR             200.0             // m/s => 5mm/sec#define PIONEER1_VEL2_CONVERSION_FACTOR             250.0             // m/s => 4mm/sec#define PIONEER2_VEL2_CONVERSION_FACTOR             50.0              // m/s => 2cm/sec/*** When we receive an information packet back from the robot, it is     ***//*** initially read into a raw information packet as if to a big char     ***//*** buffer.  It is then converted to a regular information packet, which ***//*** contains more useful data types.                                     ***/struct 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];};typedef enum {PIONEER_NO_POWER, PIONEER_STOPPED, PIONEER_MOVING} motor_status_t;static struct pioneer_raw_information_packet raw_state;int pioneer_vel2(int vl, int vr) ;/*** TABLE OF CONTENTS ***//*** Higher-level robot functions ***/static int pioneer_buf_to_checksum(unsigned char *buf) {  return 256*buf[0] + buf[1];}static int pioneer_buf_to_int(unsigned char *buf) {  int val = buf[0] + 256*buf[1];  if (val > SHRT_MAX)    val -= USHRT_MAX;  return val;}static int pioneer_buf_to_unsigned_int(unsigned char *buf) {  int val = buf[0] + 256 * (0x7F & buf[1]);    return val;}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_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);}/*** Return value:  the length of the string read                       ***/static int pioneer_read_string(unsigned char *buf, double read_timeout, double * packet_timestamp) {  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;  double header_time;  for (i = 0; i <= header_length; ++i)    header[i] = '\0';  start_time = carmen_get_time();  header_time = start_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);      header_time=carmen_get_time();      if (read_timeout > 0) {	current_time = carmen_get_time();	if (current_time - start_time > read_timeout)	  // timeout	  return -1;      }    }   while (strcmp((char *)header, 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, NULL);    }  if (packet_timestamp)	*packet_timestamp=header_time;  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 intpioneer_sonar(int b) {  if (pioneer_version == 1 && b == 0) {    int result = pioneer_send_command1(PIONEER_POLLING, 0);    if (result >=0)      sonar_is_on=0;    return result;  }  else {    int result = pioneer_send_command1(PIONEER_SONAR, b);    if (result >=0) {      if (b == 0)	sonar_is_on=0;      else	sonar_is_on=1;    }    return result;  }}static int pioneer_sync0(void) {  unsigned char buf[256];  buf[0] = !PIONEER_SYNC0;  pioneer_send_command0(PIONEER_SYNC0);  if ((pioneer_read_string(buf, 0.2, NULL) == -1) && (pioneer_version == 1))     {      /* sometimes the Pioneer I's want two syncs */      pioneer_send_command0(PIONEER_SYNC0);      if (pioneer_read_string(buf, 0.2, NULL) == -1) 	{	  carmen_warn("Could not SYNC0\n");	  return -1;	}    }  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, NULL);  if (buf[0] != PIONEER_SYNC1)     {      carmen_warn("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, NULL);  return 0;}int abs_max(int a, int b) {  a = abs(a);  b = abs(b);  return (a>b)?a:b;}intpioneer_vel2(int vl, int vr) {  int arg;  int absmax;  absmax = abs_max(vl, vr);  if (absmax > 127) {    float scale_factor;    scale_factor = 127.0 / ((float)absmax);    vl = (int) ( scale_factor * ((float)vl));    vr = (int) ( scale_factor * ((float)vr));  }  if (1)    fprintf(stderr,"(%d %d)\n", vl, vr);  arg = 256*vl + vr;  return pioneer_send_command1(PIONEER_VEL2, arg);}intcarmen_base_direct_sonar_on(void){  int err = 0;  fprintf(stderr, "Switching sonars on\n");    //  if (!sonar_is_on){     err = pioneer_sonar(1);    //  }  if (err < 0)    return -1;  return PIONEER_MAX_NUM_SONARS;}intcarmen_base_direct_sonar_off(void){  fprintf(stderr, "Switching sonars off\n");  //  if (sonar_is_on)   return pioneer_sonar(0);  //  return 0;}int carmen_base_direct_reset(void){  return 0;}int carmen_base_direct_initialize_robot(char *model, char *dev) 

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
麻豆国产一区二区| 最新不卡av在线| 免费观看91视频大全| 日韩视频123| 久久99精品国产91久久来源| 精品国产一区a| 国产精品18久久久| 国产精品福利一区二区| 色欧美88888久久久久久影院| 国产性天天综合网| av电影天堂一区二区在线| 亚洲美女视频在线| 国产欧美日韩不卡| 99re8在线精品视频免费播放| 一区二区三区四区中文字幕| 欧美福利视频导航| 国产成人综合网站| 一区av在线播放| 精品国产区一区| 91片在线免费观看| 日韩电影在线一区| 国产精品久久久久久亚洲毛片| 色诱亚洲精品久久久久久| 日本不卡123| 自拍视频在线观看一区二区| 91精品国产全国免费观看| 国产精品自在在线| 亚洲综合激情网| 26uuu国产在线精品一区二区| 97久久超碰精品国产| 青青草视频一区| 亚洲女厕所小便bbb| 欧美v国产在线一区二区三区| eeuss影院一区二区三区| 日韩精品久久理论片| 中文字幕精品三区| 日韩欧美中文字幕制服| 99国产精品视频免费观看| 麻豆91在线播放免费| 亚洲啪啪综合av一区二区三区| 欧美电影免费观看高清完整版 | 国产调教视频一区| 欧美又粗又大又爽| 国产成人午夜视频| 日韩精品一二区| 1024国产精品| 国产日产亚洲精品系列| 制服丝袜av成人在线看| 97se亚洲国产综合自在线观| 国产一区二三区| 免费看精品久久片| 亚洲狠狠丁香婷婷综合久久久| 久久香蕉国产线看观看99| 在线不卡一区二区| 欧美综合亚洲图片综合区| 99久久伊人精品| 国产激情精品久久久第一区二区| 蜜臂av日日欢夜夜爽一区| 亚洲成在线观看| 亚洲一区二区三区四区五区黄 | www成人在线观看| 欧美麻豆精品久久久久久| 91免费小视频| 日韩一级欧美一级| 欧美中文字幕一区二区三区| 成人中文字幕在线| 国产精品一级片在线观看| 狠狠色2019综合网| 久久成人av少妇免费| 五月婷婷久久丁香| 丝袜亚洲另类欧美综合| 亚洲福利视频一区| 亚洲成a人片在线不卡一二三区 | 亚洲成a人片在线观看中文| 亚洲美女偷拍久久| 亚洲精选免费视频| 亚洲一区二区三区激情| 亚洲主播在线播放| 亚洲成人综合视频| 天堂午夜影视日韩欧美一区二区| 亚洲第一激情av| 日韩电影一区二区三区四区| 视频在线观看国产精品| 奇米精品一区二区三区四区| 日韩精品久久理论片| 久久国产欧美日韩精品| 激情六月婷婷综合| 国产精品亚洲视频| 99精品黄色片免费大全| 欧美性三三影院| 日韩你懂的在线观看| 久久女同性恋中文字幕| 中文字幕av资源一区| 中文字幕综合网| 一区二区免费视频| 天天av天天翘天天综合网色鬼国产| 日韩影视精彩在线| 国产主播一区二区| 99视频有精品| 欧美三级一区二区| 欧美变态tickling挠脚心| 国产午夜一区二区三区| 自拍偷在线精品自拍偷无码专区| 亚洲国产精品久久久久婷婷884| 美腿丝袜亚洲色图| 国产a久久麻豆| 欧美在线视频全部完| 91精品国产一区二区| 亚洲国产精品传媒在线观看| 亚洲视频在线观看三级| 日本中文一区二区三区| 国产大陆亚洲精品国产| 欧美色视频在线| 久久久久久日产精品| 一区二区三区欧美日韩| 美女被吸乳得到大胸91| 91香蕉视频在线| 日韩欧美一区在线观看| 亚洲天堂a在线| 蜜桃传媒麻豆第一区在线观看| thepron国产精品| 666欧美在线视频| 亚洲欧洲日本在线| 激情欧美日韩一区二区| 欧美视频在线一区| 中文字幕成人网| 免费观看一级欧美片| 色噜噜狠狠一区二区三区果冻| 日韩美女视频在线| 亚洲成人高清在线| 不卡电影免费在线播放一区| 欧美二区三区的天堂| 自拍偷拍国产精品| 国产成人在线免费观看| 日韩一区二区视频在线观看| 亚洲丝袜自拍清纯另类| 国产精品69毛片高清亚洲| 中文字幕av一区二区三区| 日韩一区精品字幕| 在线精品亚洲一区二区不卡| 久久精品一区二区三区不卡牛牛| 亚洲国产日韩一区二区| 91美女视频网站| 国产欧美久久久精品影院| 久久精品国产精品亚洲综合| 欧美三级在线视频| 亚洲精品中文字幕在线观看| 国产91清纯白嫩初高中在线观看| 欧美一区二区三区的| 亚洲一区二区中文在线| 91欧美激情一区二区三区成人| 国产视频911| 久久97超碰国产精品超碰| 91精品国产综合久久久久久漫画| 亚洲永久精品大片| 91色乱码一区二区三区| 亚洲色图视频网| 99热精品一区二区| 国产精品国产精品国产专区不蜜 | 国产综合久久久久久久久久久久| 欧美群妇大交群中文字幕| 亚洲亚洲精品在线观看| 在线观看亚洲精品| 一区二区三区欧美视频| 在线视频欧美区| 亚洲精品乱码久久久久久| 91在线porny国产在线看| 日韩一区日韩二区| 91麻豆国产精品久久| 亚洲欧美aⅴ...| 日本高清成人免费播放| 亚洲一区在线免费观看| 在线观看免费一区| 一区二区三区视频在线观看| 欧美最猛黑人xxxxx猛交| 亚洲一区二区三区四区在线免费观看 | 国产成人av自拍| 国产日韩亚洲欧美综合| www.在线欧美| 亚洲最大成人网4388xx| 欧美日韩在线电影| 麻豆精品久久久| 久久奇米777| eeuss国产一区二区三区| 亚洲视频网在线直播| 欧美性受xxxx黑人xyx性爽| 亚洲成av人片在www色猫咪| 欧美一区二区免费视频| 国产最新精品免费| 亚洲欧洲99久久| 欧美精品亚洲二区| 狠狠色综合播放一区二区| 国产精品久久久久aaaa樱花| 欧美丝袜丝nylons| 精品一区二区三区日韩| 国产精品毛片大码女人| 欧美日韩久久一区| 国产老肥熟一区二区三区| 中文字幕一区二区三区在线不卡 | 日韩欧美国产不卡|