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

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

?? orc_arm_lib.c

?? 卡內基梅隆大學(CMU)開發的移動機器人控制開發軟件包。可對多種機器人進行控制
?? C
?? 第 1 頁 / 共 3 頁
字號:
 /********************************************************* * * 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 "arm_low_level.h"#include <carmen/serial.h>#include <sys/ioctl.h>#include <limits.h>#define ORC_MASTER 0#define ORC_SLAVE 1#define ORC_PAD 2#define ORC_STATUS 0x2A#define ORC_LEFT_SONAR_PING 4#define ORC_RIGHT_SONAR_PING 6#define ORC_LEFT_SONAR_ECHO 49#define ORC_RIGHT_SONAR_ECHO 51#define ORC_SONAR_PING 6#define ORC_SONAR_ECHO 7#define ORC_LEFT_MOTOR 0#define ORC_RIGHT_MOTOR 2#define ORC_LEFT_MOTOR_ACTUAL_PWM 14#define ORC_RIGHT_MOTOR_ACTUAL_PWM 19#define ORC_LEFT_PINMODE 4#define ORC_RIGHT_PINMODE 5#define ORC_LEFT_MOTOR_QUAD_PORT 16#define ORC_RIGHT_MOTOR_QUAD_PORT 18#define ORC_QUAD_PHASE_FAST 14#define ORC_LEFT_MOTOR_DIR 25#define ORC_RIGHT_MOTOR_DIR 26#define ORC_FORWARD 1#define ORC_BACKWARD 2#define ORC_MAX_ANGULAR_VEL 8.0 // Radians / seconds#define ORC_MAX_PWM 255#define ORC_FF_GAIN ((ORC_MAX_PWM / ORC_MAX_ANGULAR_VEL) * 0.9)#define ORC_P_GAIN 8#define ORC_I_GAIN 3#define ORC_D_GAIN 15#define ORC_VEL_ACCEL_TEMP 0.9#define ORC_VEL_DECEL_TEMP 0.4#define ORC_LEFT_MOTOR_ENCODER 7#define ORC_RIGHT_MOTOR_ENCODER 10#define ORC_MASTER_TIME 4#define ORC_SLAVE_TIME 48#define ORC_WHEEL_DIAMETER .125#define ORC_WHEEL_BASE .43#define ORC_ENCODER_RESOLUTION 500#define ORC_GEAR_RATIO 65.5#define ORC_DIGITAL_IN_PULL_UP 1#define ORC_DIGITAL_IN 6#define ORC_SERVO_CURRENT 35#define ORC_SERVO_PWM_STATE 8#define ORC_SERVO_PIN 5// velezj: For RssII Arm#define ORC_SHOULDER_MOTOR 1#define ORC_SHOULDER_MOTOR_ACTUAL_PWM 17#define ORC_SHOULDER_MOTOR_DIR 25#define ORC_SHOULDER_MOTOR_QUAD_PORT 16#define ORC_SHOULDER_MOTOR_ENCODER 7#define ORC_SHOULDER_MOTOR_DIRECTION_SIGN 1#define ORC_ELBOW_MOTOR 3#define ORC_ELBOW_MOTOR_ACTUAL_PWM 23#define ORC_ELBOW_MOTOR_DIR 26#define ORC_ELBOW_MOTOR_QUAD_PORT 18#define ORC_ELBOW_MOTOR_ENCODER 10#define ORC_ELBOW_MOTOR_DIRECTION_SIGN -1#define ORC_ARM_GEAR_REDUCTION ( 65.5 * 5.0 )#define ORC_ARM_TICKS_PER_RADIAN ( ORC_ENCODER_RESOLUTION * ORC_ARM_GEAR_REDUCTION / ( 2.0 * M_PI ) )#define ORC_ELBOW_MAX_PWM 40 // 27#define ORC_ELBOW_MIN_PWM 35 // 22#define ORC_SHOULDER_MAX_PWM 50 // 37#define ORC_SHOULDER_MIN_PWM 42 // 30#define ORC_ARM_P_GAIN 8#define ORC_ARM_D_GAIN 15#define ORC_ARM_I_GAIN 0 // 3#define ORC_ARM_MAX_ANGULAR_VEL 0.0035 // Radians / second#define ORC_ARM_MIN_ANGULAR_VEL 0.00125 // Radians / second //#define ORC_ARM_FF_GAIN ((ORC_ARM_MAX_PWM / ORC_ARM_MAX_ANGULAR_VEL) * 0.9)#define ORC_ARM_FF_GAIN ( (90 / ORC_ARM_MAX_ANGULAR_VEL ) * 0.9 );#define ORC_ARM_THETA_P_GAIN 0.008#define ORC_ARM_THETA_D_GAIN 0.028 // 0.018#define ORC_ARM_THETA_I_GAIN 0.000 // 0.003#define ORC_ARM_GRIPPER_SERVO 0 // 0#define ORC_ARM_GRIPPER_MIN_PWM 8600#define ORC_ARM_GRIPPER_PWM_PER_RADIAN 2214.2 static double acceleration;static double deceleration;static double x, y, theta;static double displacement, rotation;static double left_velocity, right_velocity;static double left_iTerm = 0.0, right_iTerm = 0.0;static double left_vel_ramp = 0.0, right_vel_ramp = 0.0;static double left_error_prev = 0.0, right_error_prev = 0.0;static double left_desired_velocity = 0, right_desired_velocity = 0;static double left_range, right_range;static int initialized = 0;static int sonar_on = 1;static int left_pwm = 0, right_pwm = 0;static short last_master_ticks;static short last_slave_ticks;static int left_last_tick, right_last_tick;static double time_since_last_command;static double last_command_time;static double servo_state[4];static double servo_current[2];static char bumpers[4];static int gripper_state = 0;static int serial_fd = -1;// velezj: rssII Armstatic double gripper_theta = 0.0, gripper_desired_theta = 0.0;static double shoulder_theta = 0.0, elbow_theta = 0.0;static double shoulder_desired_theta = 0.0, elbow_desired_theta = 0.0;static double shoulder_theta_iTerm = 0.0, elbow_theta_iTerm = 0.0;static double shoulder_theta_error_prev = 0.0, elbow_theta_error_prev = 0.0;static double shoulder_iTerm = 0.0, elbow_iTerm = 0.0;static double shoulder_error_prev = 0.0, elbow_error_prev = 0.0;static double shoulder_desired_angular_velocity = 0.0, elbow_desired_angular_velocity = 0.0;static double shoulder_angular_velocity, elbow_angular_velocity;static int shoulder_pwm, elbow_pwm;static int shoulder_last_tick = 0, elbow_last_tick = 0;static void recover_failure(void){  printf("Recovering from Serial Failure\n");  initialized = 0;  if (serial_fd >= 0) {    close(serial_fd);    serial_fd = -1;  }  while (serial_fd < 0) {    sleep(1);    carmen_warn("Trying to reconnect to arm...\n");    carmen_arm_direct_initialize(NULL,  NULL);  }}unsigned char create_checksum(unsigned char *buffer, int size){  unsigned char checksum = 0;  int i;  for (i = 0; i < size; i++)    checksum = (checksum << 1) + buffer[i] + (checksum & 0x80 ? 1 : 0);  return checksum;}void send_packet(unsigned char *byte, int length,  unsigned char where){  static unsigned char *buffer;  static unsigned char size;  static int buffer_size = 0;  int i;  int num_written;    static unsigned char count = 0;  //  carmen_warn("Sent packet %x to %d : %d\n", byte[0], where, count);  count++;  if (count == 0x40)    count = 0;  if (buffer_size == 0) {    buffer = (unsigned char *)calloc(sizeof(unsigned char), length+4);    carmen_test_alloc(buffer);    buffer_size = length+4;  } else if (buffer_size < length+4) {    buffer = (unsigned char *)realloc      (buffer, sizeof(unsigned char)*(length+4));    carmen_test_alloc(buffer);    buffer_size = length+4;  }  size = length+4;  buffer[0] = 0xED;  buffer[1] = size;  buffer[2] = (where << 6) | count; // was | 0xF;  for (i = 0; i < length; i++)    buffer[i+3] = byte[i];  buffer[length+3] = create_checksum(buffer, length+3);  num_written = carmen_serial_writen(serial_fd, buffer, length+4);  if (num_written < 0)    recover_failure();}static unsigned char *check_packet_length(int packet_length){  unsigned char *buffer = (unsigned char *)calloc(sizeof(unsigned char), packet_length);  carmen_test_alloc(buffer);  return buffer;}static unsigned char *read_packet(void){  unsigned char byte, routing;  unsigned char *buffer = NULL;  unsigned char *data_ptr;  unsigned char checksum;  fd_set rfds;  int num_ready_chars;  int packet_length;  struct timeval timeout;  int num_ready;  int count = 0;  int packet_count = 0;  do {    do {      num_ready_chars = carmen_serial_numChars(serial_fd);            if (num_ready_chars == -1) 	return NULL;            count = 0;      while (count < 50 && num_ready_chars == 0) {        timeout.tv_sec = 0;        timeout.tv_usec = 1000;	FD_ZERO(&rfds);	FD_SET(0, &rfds);        num_ready = select(1, &rfds, NULL, NULL, &timeout);        num_ready_chars = carmen_serial_numChars(serial_fd);        count++;      }      if (num_ready_chars < 1) {	return NULL;      }      //      carmen_warn("Ready: %d\n", num_ready_chars);            if (carmen_serial_readn(serial_fd, &byte, 1) < 0)	return NULL;    } while (byte != 0xED);        if (carmen_serial_readn(serial_fd, &byte, 1) < 0)       return NULL;        packet_length = byte;        buffer = check_packet_length(packet_length);    buffer[0] = 0xED;    buffer[1] = byte;    if (carmen_serial_readn(serial_fd, &byte, 1) < 0)       return NULL;        buffer[2] = byte;     data_ptr = buffer+3;    routing = byte >> 6;    if (carmen_serial_readn(serial_fd, data_ptr, packet_length-3) < 0)       return NULL;      checksum = create_checksum(buffer, packet_length-1);        if (checksum != buffer[packet_length-1]) {      carmen_warn("Corrupted data from serial line. "		  "Dropping packet.\n");      free(buffer);      buffer = NULL;    }        if (routing == ORC_PAD) {      //      carmen_warn("Tossing orc_pad packet\n");      free(buffer);      buffer = NULL;    }     //    else    //      carmen_warn("Got packet %x from %d : %d\n", buffer[3],    //		  routing, byte & 0x3f);              packet_count++;  } while (!buffer && packet_count < 3);  //  carmen_warn("Returning buffer of size %d\n", packet_length);  return buffer;}static int wait_for_ack(void){  unsigned char *buffer;  unsigned char response;    buffer = read_packet();  if (buffer == NULL)    return -1;  response = buffer[3];  free(buffer);  if (response != 0)    return -1;  return 0;}static int send_packet_and_ack(unsigned char *byte, int length,  			       unsigned char where){  int count;  int err;  count = 0;  do {    send_packet(byte, length, where);    err = wait_for_ack();    if (err == 0)      return 0;    count++;  } while (count < 3);  return -1;}static void command_velocity(double desired_velocity, double current_velocity,           int current_pwm, unsigned char WHICH_MOTOR){  double desired_angular_velocity, current_angular_velocity;  double desired_velocity_ramp = 0;  double ffTerm = 0.0, pTerm = 0.0, dTerm = 0.0, velError = 0.0;  double * iTermPtr;  double * velErrorPrevPtr;  double * velRampPtr;  unsigned char command_pwm;  unsigned char dir;  unsigned char buffer[4];  char which;  if (WHICH_MOTOR == ORC_LEFT_MOTOR) {    which = 'L';    iTermPtr = &left_iTerm;    velRampPtr = &left_vel_ramp;    velErrorPrevPtr = &left_error_prev;  }  else {    which = 'R';    iTermPtr = &right_iTerm;    velRampPtr = &right_vel_ramp;    velErrorPrevPtr = &right_error_prev;  }  if (desired_velocity == 0) {    *velRampPtr = 0;  }  else if (desired_velocity > *velRampPtr) {    (*velRampPtr) += acceleration * time_since_last_command;    printf("accel %f %f %f\n", acceleration * time_since_last_command,	   acceleration, time_since_last_command);    //    (*velRampPtr) += ORC_VEL_ACCEL_TEMP * time_since_last_command;    //    printf("accel %f\n", ORC_VEL_ACCEL_TEMP * time_since_last_command);    if (*velRampPtr > desired_velocity) {      *velRampPtr = desired_velocity;    }  }  else if (desired_velocity < *velRampPtr) {    (*velRampPtr) -= deceleration * time_since_last_command;    printf("decel %f %f %f\n", deceleration * time_since_last_command,    	   deceleration, time_since_last_command);    //    (*velRampPtr) -= ORC_VEL_DECEL_TEMP * time_since_last_command;    //    printf("decel %f\n", ORC_VEL_DECEL_TEMP * time_since_last_command);    if (*velRampPtr < desired_velocity) {      *velRampPtr = desired_velocity;    }  }  desired_velocity_ramp = *velRampPtr;  desired_angular_velocity = desired_velocity_ramp / (ORC_WHEEL_DIAMETER/2.0);  current_angular_velocity = current_velocity / (ORC_WHEEL_DIAMETER/2.0);  if (fabs(desired_angular_velocity) > .001) {      /* Nick, what did you mean to do here?  I don't understand these         comparisons.  Do you mean < 3 and &&? */    if (desired_angular_velocity > ORC_MAX_ANGULAR_VEL)      desired_angular_velocity = ORC_MAX_ANGULAR_VEL;    if (desired_angular_velocity < -ORC_MAX_ANGULAR_VEL)      desired_angular_velocity = -ORC_MAX_ANGULAR_VEL;    velError = (desired_angular_velocity - current_angular_velocity);    ffTerm = desired_angular_velocity * ORC_FF_GAIN;    pTerm = velError * ORC_P_GAIN;    *iTermPtr += velError * ORC_I_GAIN;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品麻豆网站| 九一九一国产精品| 成人网在线播放| 精品99一区二区| 久久99精品国产| 精品日韩一区二区三区免费视频| 日日摸夜夜添夜夜添精品视频| 99国产精品久久久久久久久久 | 亚洲精品国产品国语在线app| 国产精品白丝av| 欧美国产综合色视频| 国产美女一区二区| 久久久久久久综合| 国产精品1024| 亚洲欧美日韩系列| 色偷偷成人一区二区三区91 | 精品播放一区二区| 国产一区二区免费看| 久久夜色精品一区| 成人一区二区三区| 亚洲欧美国产77777| 色狠狠av一区二区三区| 亚洲国产精品久久人人爱蜜臀 | 欧美日韩国产在线观看| 亚洲成人在线观看视频| 日韩视频国产视频| 国产精品1区2区| 最新欧美精品一区二区三区| 欧美亚洲综合在线| 日韩电影免费在线| 久久五月婷婷丁香社区| 成人av手机在线观看| 亚洲永久免费视频| 日韩一级二级三级| 丁香婷婷综合网| 亚洲综合在线五月| 精品久久久久久久人人人人传媒 | 91小视频在线观看| 亚洲一区二区三区三| 精品日韩欧美在线| 北岛玲一区二区三区四区| 亚洲综合区在线| 日韩欧美中文字幕制服| 国产成都精品91一区二区三| 一区二区成人在线观看| 日韩色视频在线观看| 成人永久看片免费视频天堂| 亚洲综合另类小说| 久久亚洲综合av| 欧洲精品在线观看| 国产麻豆视频一区| 亚洲一区二区三区精品在线| 精品国产一区二区精华| 91国在线观看| 久久精品国产99国产| 国产午夜三级一区二区三| 色综合久久精品| 日本中文字幕一区二区视频| 中文字幕va一区二区三区| 欧美久久久久久久久| 99久久99久久综合| 久久99精品网久久| 亚洲国产人成综合网站| 国产精品久久三区| 日韩美女视频一区二区在线观看| 一道本成人在线| 国产福利一区二区三区视频 | 亚洲欧洲日韩女同| 精品理论电影在线观看| 欧美日韩高清在线| 色综合一区二区| 不卡的av网站| 国产精品系列在线播放| 久久国产乱子精品免费女| 亚洲国产aⅴ成人精品无吗| 国产精品国产三级国产普通话蜜臀 | 6080日韩午夜伦伦午夜伦| 91黄色激情网站| 色综合久久综合中文综合网| 国产酒店精品激情| 午夜国产精品影院在线观看| 亚洲欧美自拍偷拍色图| 久久久久久久一区| 日韩欧美国产三级电影视频| 欧美三级日韩三级国产三级| 91原创在线视频| av在线不卡观看免费观看| 成人永久看片免费视频天堂| 国产精品自在在线| 国精产品一区一区三区mba桃花| 奇米色一区二区三区四区| 亚洲午夜视频在线| 一区二区三区中文字幕精品精品| 中文字幕日韩一区| 中文字幕一区二区三区蜜月| 国产午夜精品在线观看| 2021中文字幕一区亚洲| 欧美tickling挠脚心丨vk| 日韩一级视频免费观看在线| 制服丝袜一区二区三区| 欧美日本一道本| 91精品午夜视频| 欧美肥妇free| 日韩一区二区三区在线| 欧美一级片在线| 91一区二区在线| 99久精品国产| 色综合视频一区二区三区高清| 波多野结衣中文一区| jizz一区二区| 色女孩综合影院| 欧美日韩国产高清一区二区三区| 欧美老肥妇做.爰bbww| 欧美日韩成人综合天天影院| 3d成人h动漫网站入口| 欧美大片免费久久精品三p| 精品99一区二区三区| 亚洲欧美日韩精品久久久久| 亚洲美女电影在线| 日韩毛片精品高清免费| 国产精品麻豆视频| 亚洲精品成人悠悠色影视| 午夜影视日本亚洲欧洲精品| 久久精工是国产品牌吗| 国产成人在线影院| 91福利在线免费观看| 制服视频三区第一页精品| 精品福利一区二区三区免费视频| 久久久精品影视| 亚洲色图色小说| 婷婷综合在线观看| 久久超碰97中文字幕| 国产一区二区91| 日本精品一区二区三区四区的功能| 欧美另类z0zxhd电影| 久久精品夜夜夜夜久久| 最近日韩中文字幕| 日韩成人一级大片| a级精品国产片在线观看| 欧美三级乱人伦电影| 国产亚洲一区二区三区四区| 一区二区三区四区国产精品| 久久99精品久久只有精品| 99久久婷婷国产综合精品电影| 欧美午夜在线一二页| 欧美一区二区三区视频免费 | 亚洲一区免费观看| 国产乱人伦偷精品视频不卡| 色就色 综合激情| 91精品欧美久久久久久动漫| 国产精品蜜臀在线观看| 亚洲综合色视频| 美脚の诱脚舐め脚责91| 91麻豆免费看| 欧美一区二区网站| 亚洲天堂免费看| 久88久久88久久久| 91精彩视频在线观看| 国产亚洲欧美激情| 日韩激情中文字幕| 99国产精品久| 久久亚洲综合av| 麻豆一区二区在线| 欧美自拍偷拍一区| 日本一区二区久久| 免费成人小视频| 欧美亚州韩日在线看免费版国语版| 精品国产91九色蝌蚪| 视频一区视频二区中文| 欧美美女bb生活片| 五月天婷婷综合| 日韩一区二区免费高清| 美女视频网站久久| 精品国产乱码久久久久久蜜臀 | 国产精品 日产精品 欧美精品| 精品少妇一区二区三区在线播放| 极品少妇xxxx精品少妇| 精品国产伦一区二区三区观看方式| 国产综合色视频| 中文子幕无线码一区tr| 91在线免费视频观看| 亚洲九九爱视频| 欧美精品在线观看播放| 久久不见久久见免费视频1| 久久久777精品电影网影网| 成人高清视频在线| 亚洲国产精品一区二区久久| 91精品国产综合久久精品麻豆| 久久成人av少妇免费| 国产精品午夜久久| 972aa.com艺术欧美| 亚洲第一狼人社区| 欧美精品一区二区三区视频| 99久久精品一区二区| 亚洲123区在线观看| 久久亚洲私人国产精品va媚药| av电影天堂一区二区在线观看| 洋洋av久久久久久久一区| 日韩欧美国产精品一区| 日韩午夜激情免费电影|