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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? robot_client.c

?? 卡內(nèi)基梅隆大學(xué)(CMU)開(kāi)發(fā)的移動(dòng)機(jī)器人控制開(kāi)發(fā)軟件包。可對(duì)多種機(jī)器人進(jìn)行控制
?? C
字號(hào):
 /********************************************************* * * 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 <stdlib.h>#include <stdio.h>#include <sys/types.h>#include <sys/stat.h>#include <fcntl.h>#include <unistd.h>#include <sys/ioctl.h>#include <assert.h>#include <string.h>#include "extend.h"#include "i200m.h"#include "Nclient.h"#include "setup.h"#include "arcnet.h"#include "arcnet_sensors.h"struct I100_sensor_data {  long int reading;  long int auxiliary;  long unsigned int sens_time;  long int integ_x;  long int integ_y;  long int integ_steer;  long int integ_turret;  long int vel_trans;  long int vel_steer;  long int vel_turret;  long unsigned int integ_time;};static unsigned char rclnt_initialized = 0; static unsigned char rclnt_connected = 0;typedef enum {  RCLNT_I100_BATTERY,   RCLNT_PDB_BATTERY} RCLNT_BatteryType;static long int rclnt_robot_id; static char rclnt_robot_type; static RCLNT_BatteryType rclnt_battery_type; static int rclnt_battery_fd; static int Infrared; static int Sonar; static int Bumper; static int Zero; static int Sound; static int Clock; static double RobotTimeout; struct N_RobotState rclnt_rs; struct N_RobotStateExt rclnt_rs_ext; int N_InitializeClient(const char *scheduler_hostname		       __attribute__ ((unused)), 		       unsigned short scheduler_socket		       __attribute__ ((unused))){  char *setup_value;   if (rclnt_initialized == 1)    return 0;    if ((setup_value = SETUP_GetValue("[robot]type")) == NULL) {    rclnt_rs.RobotType = 'x';    rclnt_robot_type = 'x';  } else if ((strcasecmp(setup_value, "x") == 0) ||	     (strcasecmp(setup_value, "xr4k") == 0) ||	     (strcasecmp(setup_value, "xr4000") == 0)) {    rclnt_rs.RobotType = 'x';    rclnt_robot_type = 'x';  } else if ((strcasecmp(setup_value, "n") == 0) ||	     (strcasecmp(setup_value, "n200") == 0) ||	     (strcasecmp(setup_value, "nomad200") == 0)) {    rclnt_rs.RobotType = 'n';    rclnt_robot_type = 'n';  } else {    fprintf(stderr, "Nrobot: (fatal) %s is not a valid value for %s\n"	    "This entry is required to determine the appropriate "	    "hardware interface to\n"	    "use.  For further information, please consult your manual.\n",	    setup_value, "[robot]type");    return N_CONNECTION_FAILED;  }   Sound = open("/dev/dbtk", 1);    switch (rclnt_robot_type) {  case 'n':    Sonar = open("/dev/i100_sonar", 2);    Bumper = open("/dev/i100_bumper", 0);    Infrared = open("/dev/i100_infrared", 2);    Zero = open("/dev/i100_zeroswitch", 0);    Clock = open("/dev/i100_clock", 0);    I200M_Initialize(&rclnt_rs);    rclnt_rs.AxisSet.AxisCount = 3;    rclnt_battery_type = RCLNT_I100_BATTERY;    rclnt_battery_fd = open("/dev/i100_battery", 0);    rclnt_rs.BatterySet.BatteryCount = 2;    break;  case 'x':     ANET_Initialize();    I200M_Initialize(&rclnt_rs);    rclnt_rs.AxisSet.AxisCount = 3;    rclnt_battery_type = RCLNT_PDB_BATTERY;    rclnt_rs.BatterySet.BatteryCount = 4;    break;  }    SON_Initialize(&rclnt_rs, &rclnt_rs_ext);  INF_Initialize(&rclnt_rs, &rclnt_rs_ext);  BUMP_Initialize(&rclnt_rs, &rclnt_rs_ext);    rclnt_initialized = 1;    return 0;}int N_PollClient(){  ANET_Poll();  return 0;}int N_ConnectRobot(long int robot_id){  int i;   if (!rclnt_initialized)    return N_CONNECTION_FAILED;    if (rclnt_connected) {    if (robot_id == rclnt_robot_id)      return 0;    else       return N_ROBOT_NOT_FOUND;  }    rclnt_rs.RobotID = rclnt_robot_id = robot_id;  for (i = 0; i < (int)rclnt_rs.AxisSet.AxisCount; i++) {    rclnt_rs.AxisSet.Axis[i].Update = 0;    rclnt_rs.AxisSet.Axis[i].DataActive = 1;    rclnt_rs.AxisSet.Axis[i].TimeStampActive = 0;      }    for (i = 0; i < (int)rclnt_rs.SonarController.SonarSetCount; i++) {    rclnt_rs.SonarController.SonarSet[i].DataActive = 1;    rclnt_rs.SonarController.SonarSet[i].TimeStampActive = 0;  }  for (i = 0; i < (int)rclnt_rs.InfraredController.InfraredSetCount; i++) {    rclnt_rs.InfraredController.InfraredSet[i].DataActive = 1;    rclnt_rs.InfraredController.InfraredSet[i].TimeStampActive = 0;  }  for (i = 0; i < (int)rclnt_rs.BumperController.BumperSetCount; i++) {    rclnt_rs.BumperController.BumperSet[i].DataActive = 1;    rclnt_rs.BumperController.BumperSet[i].TimeStampActive = 0;  }  rclnt_rs.Integrator.DataActive = 1;  rclnt_rs.Integrator.TimeStampActive = 0;  rclnt_rs.BatterySet.DataActive = 1;    rclnt_connected = 1;    return 0;}int N_DisconnectRobot(long int robot_id){  if ((rclnt_connected == 0) || (robot_id != rclnt_robot_id))    return N_ROBOT_NOT_FOUND;  rclnt_connected = 0;  return 0;}struct N_RobotState *N_GetRobotState(long int robot_id){  if ((rclnt_connected == 0) || (robot_id != rclnt_robot_id))    return NULL;    return &rclnt_rs;}int N_GetInfrared(long int robot_id){  int i;   struct I100_sensor_data SensorData[16];   if ((rclnt_connected == 0) || (robot_id != rclnt_robot_id))    return N_ROBOT_NOT_FOUND;    switch (rclnt_robot_type) {  case 'n':     if (rclnt_rs.InfraredController.InfraredSet[0].DataActive == 0)      return 0;    if (lseek(Infrared, 0, SEEK_SET) < 0)      return N_UNKNOWN_ERROR;        if (read(Infrared, &SensorData, sizeof(SensorData)) < 0)      return N_UNKNOWN_ERROR;        for (i = 0; i < 16; i++) {      rclnt_rs.InfraredController.InfraredSet[0].Infrared[i].Reading =	SensorData[i].reading / 2400000.0 * 255.0;      if (rclnt_rs.InfraredController.InfraredSet[0].TimeStampActive)	rclnt_rs.InfraredController.InfraredSet[0].Infrared[i].TimeStamp =	  SensorData[i].sens_time;    }        break;      case 'x':     break;      }  return 0;}int N_SetSonarConfiguration(long int robot_id){  if ((rclnt_connected == 0) || (robot_id != rclnt_robot_id))    return N_ROBOT_NOT_FOUND;    switch (rclnt_robot_type) {  case 'n':         if (ioctl(Sonar, 0, &(rclnt_rs.SonarController.SonarSet[0].FiringDelay))	< 0)      return N_UNKNOWN_ERROR;    if (ioctl(Sonar, 2, &(rclnt_rs.SonarController.SonarSet[0].FiringOrder))	< 0)      return N_UNKNOWN_ERROR;        break;  case 'x':     ANET_ConfSonar();    break;      }    return 0;}int N_GetSonarConfiguration(long int robot_id){  if ((rclnt_connected == 0) || (robot_id != rclnt_robot_id))    return N_ROBOT_NOT_FOUND;  switch (rclnt_robot_type) {  case 'n':     if (ioctl(Sonar, 1, &(rclnt_rs.SonarController.SonarSet[0].FiringDelay)) 	< 0)      return N_UNKNOWN_ERROR;    if (ioctl(Sonar, 3, &(rclnt_rs.SonarController.SonarSet[0].FiringOrder))	< 0)      return N_UNKNOWN_ERROR;        break;      case 'x':     break;  }    return 0;}int N_GetSonar(long int robot_id){  int i;   struct I100_sensor_data SensorData[16];   if ((rclnt_connected == 0) || (robot_id != rclnt_robot_id))    return N_ROBOT_NOT_FOUND;  switch (rclnt_robot_type) {  case 'n':     if (!rclnt_rs.SonarController.SonarSet[0].DataActive)      return 0;    if (lseek(Sonar, 0, SEEK_SET) < 0)      return N_UNKNOWN_ERROR;        if (read(Sonar, &SensorData, sizeof(SensorData)) < 0)      return N_UNKNOWN_ERROR;    for (i = 0; i < 16; i++) {      rclnt_rs.SonarController.SonarSet[0].Sonar[i].Reading =	((double) SensorData[i].reading);      if (rclnt_rs.SonarController.SonarSet[0].TimeStampActive)	rclnt_rs.SonarController.SonarSet[0].Sonar[i].TimeStamp =	  SensorData[i].sens_time;    }    break;      case 'x':     break;      }    return 0;}int N_GetBumper(long int robot_id){  int i;   struct I100_sensor_data SensorData;   if ((rclnt_connected == 0) || (robot_id != rclnt_robot_id))    return N_ROBOT_NOT_FOUND;  switch (rclnt_robot_type) {  case 'n':     if (!rclnt_rs.BumperController.BumperSet[0].DataActive)      return 0;    /* WARNING lseek needed here?? */    if (read(Bumper, &SensorData, sizeof(SensorData)) < 0)      return N_UNKNOWN_ERROR;    for (i = 0; i < 20; i++) {      rclnt_rs.BumperController.BumperSet[0].Bumper[i].Reading =	SensorData.reading % 2;       SensorData.reading /= 2;            if (rclnt_rs.BumperController.BumperSet[0].TimeStampActive)	rclnt_rs.BumperController.BumperSet[0].Bumper[i].TimeStamp =	  SensorData.sens_time;    }        break;      case 'x':     break;  }  return 0;}int N_SetTimer(long int robot_id){  if ((rclnt_connected == 0) || (robot_id != rclnt_robot_id))    return N_ROBOT_NOT_FOUND;  RobotTimeout = rclnt_rs.Timer.Timeout;    return 0;}int N_SetAxes(long int robot_id){  if ((rclnt_connected == 0) || (robot_id != rclnt_robot_id))    return N_ROBOT_NOT_FOUND;  return I200M_SetAxes(&rclnt_rs);}int N_GetAxes(long int robot_id){  if ((rclnt_connected == 0) || (robot_id != rclnt_robot_id))    return N_ROBOT_NOT_FOUND;  return I200M_GetAxes(&rclnt_rs);  }int N_GetIntegratedConfiguration(long int robot_id){  if ((rclnt_connected == 0) || (robot_id != rclnt_robot_id))    return N_ROBOT_NOT_FOUND;  return I200M_GetIntegratedConfiguration(&rclnt_rs);}int N_SetIntegratedConfiguration(long int robot_id){  if ((rclnt_connected == 0) || (robot_id != rclnt_robot_id))    return N_ROBOT_NOT_FOUND;  return I200M_SetIntegratedConfiguration(&rclnt_rs);}int N_GetTimer(long int robot_id){  if ((rclnt_connected == 0) || (robot_id != rclnt_robot_id))    return N_ROBOT_NOT_FOUND;  rclnt_rs.Timer.Timeout = RobotTimeout;  rclnt_rs.Timer.Time = I200M_MSecSinceBoot();  return 0;}int N_GetBattery(long int robot_id){  int i;   unsigned char data[4];   if ((rclnt_connected == 0) || (robot_id != rclnt_robot_id))    return N_ROBOT_NOT_FOUND;  if (!rclnt_rs.BatterySet.DataActive)    return 0;  switch (rclnt_battery_type) {  case RCLNT_I100_BATTERY:     if (read(rclnt_battery_fd, &data, 2) < 0)      return N_UNKNOWN_ERROR;    for (i = 0; i < (int)rclnt_rs.BatterySet.BatteryCount; i++) {      rclnt_rs.BatterySet.Battery[i].Voltage = data[i];    }    break;      case RCLNT_PDB_BATTERY:     break;  default:     assert(0);  }     return 0;}int N_GetState(long int robot_id){  if ((rclnt_connected == 0) || (robot_id != rclnt_robot_id))    return N_ROBOT_NOT_FOUND;  N_GetAxes(robot_id);  N_GetIntegratedConfiguration(robot_id);  N_GetSonar(robot_id);  N_GetBumper(robot_id);  N_GetInfrared(robot_id);  N_GetBattery(robot_id);  N_GetTimer(robot_id);  return 0;}int N_Speak(long int robot_id, const char *text){  if ((rclnt_connected == 0) || (robot_id != rclnt_robot_id))    return N_ROBOT_NOT_FOUND;  if (Sound < 0)    return N_DEVICE_NOT_FOUND;    if (write(Sound, text, strlen(text) + 1) < 0)    return N_UNKNOWN_ERROR;    return 0;}void N_ResetMotionTimer(){  I200M_ResetMotionTimer();  return;}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品一线二线三线| av资源站一区| 亚洲已满18点击进入久久| 欧美国产日韩一二三区| 国产亚洲一区字幕| 国产丝袜欧美中文另类| 亚洲国产精品久久艾草纯爱| 亚洲电影视频在线| 日本大胆欧美人术艺术动态| 日产国产高清一区二区三区| 99久久伊人久久99| 色婷婷久久久久swag精品| 色综合久久中文综合久久牛| 久久精品亚洲乱码伦伦中文| 男男gaygay亚洲| 国产成人自拍在线| 91影视在线播放| 51精品国自产在线| 久久综合资源网| 国产精品久线在线观看| 亚洲精品伦理在线| 日韩精品午夜视频| 国产不卡免费视频| 在线免费观看日韩欧美| 91精品欧美综合在线观看最新| 亚洲精品欧美二区三区中文字幕| 国产高清久久久久| 欧美老女人第四色| 26uuu国产电影一区二区| 日韩高清在线电影| 欧美伦理影视网| 亚洲国产欧美日韩另类综合 | 日本一区二区三区四区在线视频| 国产精品久久久久久久久图文区 | 国产不卡高清在线观看视频| 91精品国产综合久久久久| 亚洲精品成人天堂一二三| 99久久伊人网影院| 国产精品超碰97尤物18| 成人精品一区二区三区四区| 欧美狂野另类xxxxoooo| 亚洲福利视频一区| 欧美三级韩国三级日本一级| 国产欧美一区二区精品仙草咪| 精品影院一区二区久久久| 成人激情综合网站| 欧美久久久影院| 亚洲成人一区二区| 欧美精品久久久久久久久老牛影院 | 国产成人一级电影| 国产精品日韩成人| 精品一区二区免费视频| 日韩女优毛片在线| 国产精品超碰97尤物18| 91丨九色丨黑人外教| 最好看的中文字幕久久| 麻豆精品在线看| 91精品1区2区| 国产精品嫩草影院av蜜臀| 成人av在线看| 亚洲精品乱码久久久久久久久| 在线视频国内自拍亚洲视频| 亚欧色一区w666天堂| 91精品国产综合久久国产大片| 亚洲嫩草精品久久| 成人v精品蜜桃久久一区| 亚洲欧美偷拍卡通变态| 欧美在线播放高清精品| 免费成人av资源网| 久久精品一区四区| 色综合色综合色综合色综合色综合 | 精品国产免费人成电影在线观看四季| 一区二区视频免费在线观看| 粉嫩一区二区三区性色av| 亚洲天堂久久久久久久| 欧美亚洲国产一区二区三区| 日韩理论片网站| 欧美电影在线免费观看| 国产呦萝稀缺另类资源| 精品国产第一区二区三区观看体验| 国产精品 欧美精品| 亚洲乱码国产乱码精品精可以看 | 国产福利一区二区三区| 中文字幕一区av| av在线这里只有精品| 亚洲高清久久久| 久久久综合视频| 精品系列免费在线观看| 国产精品成人在线观看| 3atv一区二区三区| 风间由美性色一区二区三区| 亚洲国产精品影院| 国产亚洲短视频| 91国产成人在线| 国产一区中文字幕| 一级日本不卡的影视| 久久久影视传媒| 在线免费不卡视频| 国产乱淫av一区二区三区| 一区二区三区中文在线观看| 精品国产人成亚洲区| 在线亚洲人成电影网站色www| 捆绑调教美女网站视频一区| 日韩精品在线网站| 色视频成人在线观看免| 韩日欧美一区二区三区| 欧美成人精品高清在线播放 | 亚洲永久精品国产| 国产欧美va欧美不卡在线| 欧美日韩国产在线播放网站| 免费高清在线视频一区·| 亚洲天堂成人网| 精品少妇一区二区三区在线播放| 色综合天天综合网天天狠天天| 亚洲男人都懂的| 久久久国产精华| 91麻豆精品国产| 色欧美88888久久久久久影院| 国产永久精品大片wwwapp| 午夜国产不卡在线观看视频| 欧美成人激情免费网| 在线观看免费亚洲| 盗摄精品av一区二区三区| 久久成人羞羞网站| 亚洲成人免费在线观看| 亚洲人成精品久久久久久| 久久嫩草精品久久久精品一| 欧美丰满少妇xxxbbb| 色999日韩国产欧美一区二区| 福利视频网站一区二区三区| 美女高潮久久久| 国产老女人精品毛片久久| 天堂一区二区在线免费观看| 亚洲人吸女人奶水| 中文字幕在线观看不卡视频| 久久夜色精品一区| 日韩欧美一区二区在线视频| 精品夜夜嗨av一区二区三区| 丝袜a∨在线一区二区三区不卡| 亚洲色图清纯唯美| 日韩毛片精品高清免费| 中文字幕av在线一区二区三区| 久久人人爽人人爽| 日韩欧美国产午夜精品| 91精品婷婷国产综合久久| 精品视频免费在线| 欧美三区在线观看| 在线观看视频91| 在线日韩av片| 日本乱人伦一区| 色先锋aa成人| 欧美在线视频你懂得| 色88888久久久久久影院野外| 一本色道a无线码一区v| 91亚洲国产成人精品一区二三| 成人福利电影精品一区二区在线观看| 国产成人鲁色资源国产91色综| 国产成人av电影| fc2成人免费人成在线观看播放 | 人禽交欧美网站| 青娱乐精品视频在线| 青娱乐精品在线视频| 久久精品国产精品亚洲精品| 久久se精品一区二区| 国产尤物一区二区在线| 国产999精品久久| 成人精品视频.| 91麻豆文化传媒在线观看| 色综合久久久久久久| 在线精品视频一区二区三四 | 成人免费黄色在线| av成人免费在线观看| 色综合天天综合在线视频| 在线观看视频91| 日韩一级二级三级精品视频| 精品国产乱码久久久久久浪潮| 欧美xxxx在线观看| 久久精品日产第一区二区三区高清版 | 欧美一区二区精品久久911| 日韩欧美中文字幕公布| 亚洲精品在线免费观看视频| 久久久精品国产99久久精品芒果 | 久久午夜色播影院免费高清| 久久久久久久av麻豆果冻| 国产精品久久久久久久裸模| 亚洲一区二区三区激情| 秋霞国产午夜精品免费视频| 国产在线视视频有精品| 成人av网站在线观看免费| 91官网在线免费观看| 日韩一二在线观看| 欧美国产精品一区二区三区| 亚洲麻豆国产自偷在线| 日本成人在线看| 国产成人小视频| 欧美性大战久久| 亚洲精品一区二区精华| 亚洲黄一区二区三区| 免费在线观看成人| 成人av在线资源网|