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

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

?? i200m.c

?? 卡內基梅隆大學(CMU)開發的移動機器人控制開發軟件包。可對多種機器人進行控制
?? 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 <sys/types.h>#include <sys/stat.h>#include <fcntl.h>#include <stdlib.h>#include <stdio.h>#include <unistd.h>#include "Nclient.h"static const unsigned short i200m_reg_table[4][9] = {  {0x161, 0x15e, 0x167, 0x16e, 0x17c, 0x182, 0x17f, 0x188, 0x185},  {0x162, 0x15f, 0x168, 0x16f, 0x17d, 0x183, 0x180, 0x189, 0x186},  {0x163, 0x160, 0x169, 0x170, 0x17e, 0x184, 0x181, 0x18a, 0x187},  {0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}};typedef struct {  short unsigned int reg;  long int val;} WriteType;static WriteType i200m_wr_pair[15]; static long int i200m_timestamp_offset; int i200m_fd = -1; int I200M_Initialize(struct N_RobotState *rs){  if (i200m_fd > 0) {    return 0;  }   if (rs->RobotType != 'x') {    return N_UNSUPPORTED;  }   i200m_fd = open("/dev/i200m", 2);  if (i200m_fd < 0)     return N_UNKNOWN_ERROR;    i200m_timestamp_offset = 0;  return 0;}int I200M_SetAxes(struct N_RobotState *rs){  long int value;   unsigned int i;   unsigned int write_index;   unsigned int read_index;   struct N_Axis *axis;   long int *pr_ptrs[3];   long int in[3];   if (i200m_fd < 0) {    return N_UNINITIALIZED;  }  read_index = 0;   in[0] = 0x31c0;  if (read(i200m_fd, &in, 4) < 0) {    return N_UNKNOWN_ERROR;  }   if ((in[0] != 0) && (in[0] != 8))    return N_AXES_NOT_READY;    for (i = 0; i <= 2; i++) {    pr_ptrs[i] = NULL;  }  i200m_wr_pair[0].reg = 0x2d40;  i200m_wr_pair[0].val = (rs->AxisSet.Global != 0);  write_index = 1;  read_index = 0;    for (i = 0, axis = &(rs->AxisSet.Axis[0]); i < rs->AxisSet.AxisCount;        i++, axis++) {    if (axis->Update == 0)       continue;    axis->Update = 0;    value = 0;    if (axis->Mode == N_AXIS_STOP) {      i200m_wr_pair[write_index].reg = i200m_reg_table[i][2] << 5;      i200m_wr_pair[write_index].val = 1000;      write_index++;      i200m_wr_pair[write_index].reg = i200m_reg_table[i][1] << 5;      i200m_wr_pair[write_index].val = 0;      write_index++;    } else {       if (axis->Mode == N_AXIS_ACCELERATION) { 	i200m_wr_pair[write_index].reg = i200m_reg_table[i][0] << 5;	i200m_wr_pair[write_index].val = 	  (axis->Acceleration < 0) ? 0x80000000 : 0x7fffffff;	write_index++;      } else if (axis->Mode == N_AXIS_VELOCITY) { 	i200m_wr_pair[write_index].reg = i200m_reg_table[i][0] << 5;	i200m_wr_pair[write_index].val = 	  (axis->DesiredSpeed < 0) ? 0x80000000 : 0x7fffffff;	write_index++;	      } else { 		if (axis->Mode == N_AXIS_POSITION_RELATIVE) { 	  pr_ptrs[read_index] = &(i200m_wr_pair[write_index].val);	  in[read_index++] = rs->AxisSet.Global ? i200m_reg_table[i][8] :	    i200m_reg_table[i][7] << 5;	} 		value = axis->DesiredPosition;	i200m_wr_pair[write_index].reg = i200m_reg_table[i][0] << 5;	i200m_wr_pair[write_index].val = axis->DesiredPosition;	write_index++;	      }             if (axis->Mode == N_AXIS_ACCELERATION) {	i200m_wr_pair[write_index].reg = i200m_reg_table[i][1] << 5;	i200m_wr_pair[write_index].val = 0x7fffffff;	write_index++;	      } else { 	if ((axis->Mode != N_AXIS_VELOCITY) && 	    (axis->DesiredSpeed < 0))	  return N_INVALID_ARGUMENT;		i200m_wr_pair[write_index].reg = i200m_reg_table[i][1] << 5;	i200m_wr_pair[write_index].val = abs(axis->DesiredSpeed);	write_index++;	      }             if (axis->Acceleration < 0)	return N_INVALID_ARGUMENT;            i200m_wr_pair[write_index].reg = i200m_reg_table[i][2] << 5;      i200m_wr_pair[write_index].val = axis->Acceleration;      write_index++;	    }   }   i200m_wr_pair[write_index].reg = 0x2e40;  i200m_wr_pair[write_index].val = 0;  write_index++;	  if (read_index != 0) {    if (read(i200m_fd, in, read_index * 4) < 0)      return N_UNKNOWN_ERROR;    for (i = 0; i < read_index; i++) {      *(pr_ptrs[i]) += in[i];    }   }    if (write(i200m_fd, i200m_wr_pair, write_index * 8) < 0)    return N_UNKNOWN_ERROR;    return 0;}int I200M_GetAxes(struct N_RobotState *rs){  unsigned char stamp;   int i;   unsigned int read_index;   long int in[rs->AxisSet.AxisCount * 7 + 2];   long int timestamp = 0;   struct N_Axis *axis;   if (i200m_fd < 0) {    return N_UNINITIALIZED;  }  read_index = 0;  in[read_index] = 0x2d40;  read_index++;  in[read_index] = 0x31c0;  read_index++;  axis = &(rs->AxisSet.Axis[0]);  stamp = 0;  for (i = 0; i < (int)rs->AxisSet.AxisCount; i++, axis++) {    if (axis->DataActive == 0)      continue;    stamp |= axis->TimeStampActive;        in[read_index] = i200m_reg_table[i][0] << 5;    read_index++;    in[read_index] = i200m_reg_table[i][1] << 5;    read_index++;    in[read_index] = i200m_reg_table[i][2] << 5;    read_index++;    in[read_index] = i200m_reg_table[i][5] << 5;    read_index++;    in[read_index] = i200m_reg_table[i][6] << 5;    read_index++;    if (rs->AxisSet.Global != 0) {      in[read_index] = i200m_reg_table[i][8] << 5;    } else {       in[read_index] = i200m_reg_table[i][7] << 5;    }     read_index++;    in[read_index] = i200m_reg_table[i][4] << 5;    read_index++;  }   if (stamp != 0) {    in[read_index] = 0x31e0;    read_index++;  }     if (read(i200m_fd, in, read_index * sizeof(long int)) < 0)    return N_UNKNOWN_ERROR;  if (stamp != 0) {    timestamp = in[read_index - 1] + i200m_timestamp_offset;  }   read_index = 0;  rs->AxisSet.Global = in[read_index++] == 1;  rs->AxisSet.Status = in[read_index++];  axis = &(rs->AxisSet.Axis[0]);  for (i = 0; i < (int)rs->AxisSet.AxisCount; i++, axis++) {    if (axis->DataActive == 0)      continue;        if (axis->TimeStampActive != 0) {      axis->TimeStamp = timestamp;    }     axis->DesiredPosition = in[read_index++];    axis->DesiredSpeed = in[read_index++];    axis->Acceleration = in[read_index++];    axis->TrajectoryPosition = in[read_index++];    axis->TrajectoryVelocity = in[read_index++];    axis->ActualPosition = in[read_index++];    axis->ActualVelocity = in[read_index++];    axis->InProgress = !((axis->TrajectoryPosition == axis->DesiredPosition) ||			 ((axis->DesiredSpeed == 0) &&			  (axis->TrajectoryVelocity == 0)));  }   return 0;}int I200M_SetJoystick(struct N_RobotState *rs){  int write_index;   long int bmask;   struct N_Joystick *jsp;   write_index = 0;  bmask = 0;  jsp = &(rs->Joystick);  if (jsp->ButtonA || jsp->ButtonB) {    bmask |= 0x40;  }   if (jsp->ButtonB || jsp->ButtonC) {    bmask |= 0x80;  }   if (bmask != 0) {    if ((jsp->X > 1.0) || (jsp->Y > 1.0)) {      return N_INVALID_ARGUMENT;    }    i200m_wr_pair[write_index].reg = 0x2e20;    i200m_wr_pair[write_index].val = 2;    write_index++;    i200m_wr_pair[write_index].reg = 0x2e60;    i200m_wr_pair[write_index].val = 100.0 * jsp->X;    write_index++;    i200m_wr_pair[write_index].reg = 0x2e80;    i200m_wr_pair[write_index].val = 100.0 * jsp->Y;    write_index++;    i200m_wr_pair[write_index].reg = 0x2ea0;    i200m_wr_pair[write_index].val = bmask;    write_index++;  } else {     i200m_wr_pair[write_index].reg = 0x2e20;    i200m_wr_pair[write_index].val = 0;    write_index++;  }   i200m_wr_pair[write_index].reg = 0x2e40;  i200m_wr_pair[write_index].val = 0;  write_index++;  if (write(i200m_fd, i200m_wr_pair, write_index * 8) < 0)    return N_UNKNOWN_ERROR;  return 0;}int I200M_SetIntegratedConfiguration(struct N_RobotState *rs){  struct N_Integrator *conf;   if (i200m_fd < 0)    return N_UNINITIALIZED;  conf = &(rs->Integrator);  i200m_wr_pair[0].reg = 0x2d60;  i200m_wr_pair[0].val = conf->x;  i200m_wr_pair[1].reg = 0x2d80;  i200m_wr_pair[1].val = conf->y;   i200m_wr_pair[2].reg = 0x2da0;  i200m_wr_pair[2].val = conf->Rotation;   i200m_wr_pair[3].reg = 0x2e40;  i200m_wr_pair[3].val = 0;   if (write(i200m_fd, i200m_wr_pair, 0x20) < 0)    return N_UNKNOWN_ERROR;  return 0;}int I200M_GetIntegratedConfiguration(struct N_RobotState *rs){  long int in[4];   struct N_Integrator *conf;   if (i200m_fd < 0)    return N_UNINITIALIZED;  conf = &(rs->Integrator);  if (!conf->DataActive)    return 0;  in[0] = 0x30a0;  in[1] = 0x30c0;  in[2] = 0x30e0;  if (conf->TimeStampActive)    in[3] = 0x31e0;  if (read(i200m_fd, in, conf->TimeStampActive ? 16 : 12) < 0)    return N_UNKNOWN_ERROR;    conf->x = in[0];  conf->y = in[1];  conf->Rotation = in[2];  if (conf->TimeStampActive)    conf->TimeStamp = in[3] + i200m_timestamp_offset;  return 0;}int I200M_ResetClient(){  long int mode;   if (i200m_fd < 0)    return N_UNINITIALIZED;  mode = 0x2d40;  if (read(i200m_fd, &mode, sizeof(mode)) < 0)    return N_UNKNOWN_ERROR;  return 0;}long unsigned int I200M_MSecSinceBoot(){  long int timeval;   if (i200m_fd < 0)    return 0;  timeval = 0x3200;  if (read(i200m_fd, &timeval, sizeof(timeval)) < 0)    return 0;  return timeval;}void I200M_ResetMotionTimer(){  i200m_wr_pair[0].reg = 0x2e60;  i200m_wr_pair[0].val = 0;  write(i200m_fd, i200m_wr_pair, 8);  return ;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人天堂资源www在线| 久久黄色级2电影| 日韩免费高清视频| 欧美一区二区三区在线| 欧美日韩视频在线观看一区二区三区 | 欧美成人午夜电影| 在线电影欧美成精品| 欧美这里有精品| 欧洲中文字幕精品| 欧美日韩一本到| 在线观看网站黄不卡| 日本电影欧美片| 欧美午夜电影网| 欧美日韩电影在线| 5566中文字幕一区二区电影| 91精品国产91久久综合桃花 | 精品一区二区三区在线视频| 另类小说欧美激情| 国产麻豆91精品| 成人av手机在线观看| 91久久人澡人人添人人爽欧美| 91在线视频免费91| 欧美军同video69gay| 欧美成人免费网站| 国产女人水真多18毛片18精品视频| 国产精品久线在线观看| 一区二区国产视频| 人人狠狠综合久久亚洲| 成人午夜激情影院| 日本韩国一区二区三区视频| 欧美二区乱c少妇| 日本一区二区免费在线| 一区二区三区国产精品| 免费看日韩精品| proumb性欧美在线观看| 欧美日韩中文字幕精品| 国产人伦精品一区二区| 亚洲1区2区3区视频| 国产99一区视频免费| 欧美性色黄大片| 久久久久久久av麻豆果冻| 亚洲一区在线观看免费| 国产盗摄女厕一区二区三区| 欧美三级电影精品| 久久精品人人做人人综合| 亚洲成人一区二区| 99久久婷婷国产精品综合| 91精品国产综合久久久蜜臀图片| 国产日韩成人精品| 麻豆成人综合网| 欧美日韩精品一二三区| 国产精品久久久久久久久久久免费看 | 91精品婷婷国产综合久久性色 | 91精品啪在线观看国产60岁| 综合激情成人伊人| 国产在线不卡一卡二卡三卡四卡| 91成人免费在线视频| 中文字幕第一区二区| 日韩av在线播放中文字幕| 色综合久久综合网97色综合| 中文字幕不卡三区| 老司机免费视频一区二区三区| 欧美三级电影在线看| 综合婷婷亚洲小说| 99久久综合色| 国产精品私房写真福利视频| 激情久久五月天| 日韩一区二区免费在线电影| 五月婷婷激情综合| 91麻豆精品久久久久蜜臀| 亚洲自拍偷拍九九九| 日本高清不卡视频| 亚洲丝袜精品丝袜在线| 99精品久久只有精品| 国产精品久线在线观看| 成人黄色一级视频| 中文字幕日本乱码精品影院| 成人免费黄色大片| 一区视频在线播放| 一本大道av伊人久久综合| 一区二区三区四区av| 色诱视频网站一区| 亚洲一区二区三区四区五区黄| 一本一道久久a久久精品| 亚洲欧美激情插| 欧美日韩一区二区在线观看| 亚洲高清免费在线| 日韩一区二区免费高清| 精品一区二区三区视频在线观看 | 亚洲制服丝袜av| 欧美日韩激情在线| 久久精品国产99国产| 26uuu国产在线精品一区二区| 国产精品一区免费视频| 久久精品欧美日韩| 99久久综合色| 日本亚洲三级在线| 久久日韩粉嫩一区二区三区| 国产 日韩 欧美大片| 亚洲视频香蕉人妖| 欧美精品一二三| 国产99久久久国产精品| 1024亚洲合集| 91精品欧美久久久久久动漫| 国产精品资源网| 一区二区三区小说| 制服丝袜成人动漫| 成人a免费在线看| 午夜av一区二区| 国产视频不卡一区| 91日韩在线专区| 免费久久99精品国产| 中文一区在线播放| 制服丝袜在线91| 91丨九色丨蝌蚪富婆spa| 奇米精品一区二区三区在线观看| 国产精品久久久久毛片软件| 91精品国产综合久久香蕉的特点| 国产999精品久久久久久| 亚洲第一在线综合网站| 日本一区二区三区四区| 欧美一区二区三区视频免费| 播五月开心婷婷综合| 另类小说一区二区三区| 一区二区三区色| 国产三级欧美三级| 制服丝袜亚洲精品中文字幕| 成人动漫av在线| 国产精品一区二区无线| 天天亚洲美女在线视频| 中文字幕一区三区| 国产日产欧美一区| 精品国产一区二区三区忘忧草 | 亚洲美女视频在线| 国产亚洲欧美色| 日韩欧美的一区| 欧美精品三级在线观看| 91国产视频在线观看| 成人网页在线观看| 成人在线视频一区二区| 精品一区二区三区香蕉蜜桃| 日本一不卡视频| 五月激情六月综合| 视频一区二区中文字幕| 亚洲综合免费观看高清完整版 | 国产精品一二三四区| 美女尤物国产一区| 天天综合网 天天综合色| 亚洲黄色小说网站| 亚洲色图欧洲色图| 亚洲视频免费在线观看| 亚洲国产精品精华液ab| 欧美激情资源网| 国产欧美日韩亚州综合| 久久久久久99久久久精品网站| 久久综合色播五月| 久久美女艺术照精彩视频福利播放| 26uuu欧美| 国产欧美va欧美不卡在线| 国产精品色哟哟网站| 国产精品久久久久久久久果冻传媒| 久久精品网站免费观看| 久久久久久久久久久久电影 | 美日韩一区二区三区| 久久精品国产久精国产爱| 国产综合久久久久影院| 国产一区二区三区四区五区入口 | 国产成人精品亚洲午夜麻豆| 国产91在线观看| 99久久精品一区二区| 91蜜桃婷婷狠狠久久综合9色| 色哟哟一区二区| 91.xcao| 久久午夜电影网| 国产精品美女久久久久aⅴ| 亚洲女与黑人做爰| jiyouzz国产精品久久| 亚洲成人第一页| 精品国产免费一区二区三区四区 | 日韩一区二区在线观看视频播放| 精品国产第一区二区三区观看体验| 伊人一区二区三区| 国产v综合v亚洲欧| 久久亚洲综合色| 久久99精品国产91久久来源| 欧美精品久久天天躁| 一区二区三区av电影| 99精品黄色片免费大全| 久久久久久久久一| 国产在线视频一区二区| 欧美电影免费观看高清完整版在| 性欧美疯狂xxxxbbbb| 日本精品视频一区二区| 亚洲精品免费在线| 色噜噜狠狠色综合中国| 亚洲日本一区二区| av爱爱亚洲一区| 亚洲四区在线观看| 在线免费观看日韩欧美| 一区二区理论电影在线观看|