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

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

?? orc_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 "../base_low_level.h"#include <carmen/carmenserial.h>#include <sys/ioctl.h>#include <limits.h>#define ORC_MASTER 0#define ORC_SLAVE 1#define ORC_PAD 2#define ORC_STATUS 0x2A// Sonar defines#define ORC_LEFT_SONAR_PING_PIN 4#define ORC_LEFT_SONAR_ECHO_PIN 5#define ORC_RIGHT_SONAR_PING_PIN 6#define ORC_RIGHT_SONAR_ECHO_PIN 7#define ORC_SONAR_PING_MODE 6#define ORC_SONAR_ECHO_MODE 7#define ORC_LEFT_SONAR_PING 0#define ORC_RIGHT_SONAR_PING 1#define ORC_LEFT_SONAR_RANGE 49#define ORC_RIGHT_SONAR_RANGE 51// Arm defines#define ORC_SERVO_PIN_0 0#define ORC_SERVO_PIN_1 1#define ORC_SERVO_PIN_2 2#define ORC_SERVO_PIN_3 3#define ORC_GRIPPER_PIN 12#define ORC_SERVO_CURRENT 35#define ORC_SERVO_PWM_STATE 8#define ORC_SERVO_MODE 5// Bumper defines#define ORC_BUMPER_PIN_0 8#define ORC_BUMPER_PIN_1 9#define ORC_BUMPER_PIN_2 10#define ORC_BUMPER_PIN_3 11#define ORC_DIGITAL_IN_PULL_UP 1#define ORC_DIGITAL_IN 6// Configuring IR sensor to use Sonar ports#define ORC_LEFT_IR_PING 5#define ORC_RIGHT_IR_PING 7// Configure pins to digital#define ORC_LEFT_IR_ECHO 4#define ORC_RIGHT_IR_ECHO 6// Sets modes for pins  #define ORC_IR_PING 3 // Digital Out; #define ORC_IR_ECHO 1 // Digital In (Pull-Up)#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_MOTOR_SLEW 15#define ORC_RIGHT_MOTOR_SLEW 21#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_LEFT_ENCODER_STATE 4#define ORC_RIGHT_ENCODER_STATE 5#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 250#define ORC_FF_GAIN ((ORC_MAX_PWM / ORC_MAX_ANGULAR_VEL) * 0.9)#define ORC_P_GAIN 20#define ORC_D_GAIN 5#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.5static double acceleration;static double deceleration;static double x, y, theta;static double displacement, rotation;static double left_velocity, right_velocity;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;// We ignore the d-term the first time we enter the control loop// after receiving a new velocity command. This is because the// d-term captures the derivative of the error, which is not // meaningful if the error is caused by the command that moved// the desired velocity set point.static int ignore_left_d_term = 1;static int ignore_right_d_term = 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 unsigned char irs[4];static unsigned char bumpers[4];static int gripper_state = 0;static int serial_fd = -1;static double left_displacement, right_displacement;static double delta_slave_time;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 base...\n");    carmen_base_direct_initialize_robot(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;  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) | 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 = select(0, NULL, 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);  } while (!buffer);  //  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;    //    carmen_warn("Resending: %d\n", count);    count++;  } while (count < 3);  return -1;}void carmen_base_command_velocity(double desired_velocity, 				  double current_velocity,				  unsigned char WHICH_MOTOR){  double desired_angular_velocity, current_angular_velocity;  double pTerm = 0.0, dTerm = 0.0, velError = 0.0;  double *velErrorPrevPtr;  double pGain = ORC_P_GAIN;  int current_pwm;  int new_pwm;  unsigned char command_pwm;  unsigned char dir;  unsigned char buffer[4];  int *ignore_d_term;  if (WHICH_MOTOR == ORC_LEFT_MOTOR) {    velErrorPrevPtr = &left_error_prev;    current_pwm = left_pwm;    ignore_d_term = &ignore_left_d_term;    pGain = pGain * 1.2;  } else {    velErrorPrevPtr = &right_error_prev;    current_pwm = right_pwm;    ignore_d_term = &ignore_right_d_term;  }  desired_angular_velocity = desired_velocity / (ORC_WHEEL_DIAMETER/2.0);  current_angular_velocity = current_velocity / (ORC_WHEEL_DIAMETER/2.0);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美疯狂做受xxxx富婆| 国产在线观看免费一区| 日本高清不卡视频| 亚洲小说欧美激情另类| 欧美日韩你懂得| 人人狠狠综合久久亚洲| 精品国产免费久久| 成人sese在线| 亚洲综合在线第一页| 欧美一区二区在线看| 韩国女主播成人在线观看| 国产婷婷色一区二区三区在线| www.视频一区| 亚洲高清不卡在线观看| 2023国产精华国产精品| a在线欧美一区| 视频一区视频二区中文| 欧美成人性战久久| 欧美优质美女网站| 狠狠色综合色综合网络| 亚洲欧美影音先锋| 欧美三片在线视频观看 | 91一区一区三区| 视频一区二区三区在线| 久久久综合精品| 欧美性极品少妇| 国产白丝精品91爽爽久久| 亚洲精品视频在线观看免费| 欧美一级艳片视频免费观看| 成人av小说网| 免费观看91视频大全| 国产精品高潮呻吟| 日韩三级精品电影久久久| 波多野结衣在线一区| 日韩电影在线一区| 最新日韩在线视频| 精品久久99ma| 欧美性生活一区| 成人一区二区三区中文字幕| 日韩影院在线观看| 综合精品久久久| 久久精品在这里| 欧美精品亚洲一区二区在线播放| 福利一区福利二区| 麻豆国产欧美日韩综合精品二区| 亚洲精品成人少妇| 久久久不卡网国产精品一区| 69av一区二区三区| 91福利国产精品| 99久久精品免费看国产| 精品无人码麻豆乱码1区2区| 天天亚洲美女在线视频| 中文字幕在线不卡| 久久精品亚洲一区二区三区浴池| 这里只有精品电影| 欧美最猛性xxxxx直播| 成人av午夜影院| 成人动漫精品一区二区| 国产成人综合在线| 国产一区二区精品久久| 久久成人久久爱| 久久国产成人午夜av影院| 男女男精品视频| 丝袜脚交一区二区| 午夜精品成人在线视频| 国产精品自拍网站| 久久精品噜噜噜成人88aⅴ| 视频一区欧美日韩| 日韩av午夜在线观看| 丝袜美腿亚洲色图| 奇米影视一区二区三区| 日韩黄色免费电影| 日韩电影一二三区| 免费在线观看日韩欧美| 捆绑变态av一区二区三区| 日韩国产欧美三级| 麻豆精品一区二区av白丝在线| 天天综合网 天天综合色| 视频一区二区欧美| 蜜臀av性久久久久蜜臀aⅴ流畅 | 麻豆传媒一区二区三区| 毛片基地黄久久久久久天堂| 日韩国产欧美在线视频| 精品制服美女丁香| 国产大陆精品国产| 91丨porny丨户外露出| 色视频一区二区| 欧美在线观看视频在线| 欧美久久久久久蜜桃| 欧美一区二区福利在线| 久久日韩精品一区二区五区| 日本一区二区三区在线观看| 中文字幕中文字幕中文字幕亚洲无线| 中文字幕在线观看一区| 依依成人精品视频| 日韩中文欧美在线| 国产一区二区三区四| 成人国产亚洲欧美成人综合网| 91丨九色丨蝌蚪丨老版| 在线电影国产精品| 国产三级精品视频| 亚洲欧美激情插| 婷婷久久综合九色综合绿巨人| 久久99国产精品尤物| 不卡大黄网站免费看| 91蜜桃免费观看视频| 制服丝袜在线91| 久久久精品欧美丰满| 亚洲欧美另类图片小说| 日本中文字幕不卡| 成人性色生活片| 欧美日本一区二区| 国产精品色在线观看| 午夜激情综合网| 国产成人av影院| 欧美色精品天天在线观看视频| 精品久久久久一区| 亚洲免费看黄网站| 精品亚洲国内自在自线福利| 99r精品视频| 日韩精品一区二区三区视频播放 | 欧美精品一区二区三区视频| 中文字幕一区二区三区四区| 丝袜亚洲精品中文字幕一区| 丰满少妇在线播放bd日韩电影| 欧美优质美女网站| 中文字幕欧美三区| 琪琪一区二区三区| 欧美影视一区在线| 国产精品嫩草影院com| 久久成人18免费观看| 欧美午夜精品久久久| 亚洲国产精品精华液ab| 蜜臀久久久久久久| 欧美性一二三区| 欧美国产综合一区二区| 日本aⅴ精品一区二区三区| 色屁屁一区二区| 国产精品久久午夜| 精品一区二区三区的国产在线播放 | 视频一区二区不卡| 在线观看欧美黄色| 国产精品毛片大码女人| 激情综合色播五月| 欧美伦理视频网站| 亚洲一区二区不卡免费| 99精品热视频| 国产精品欧美一区二区三区| 国产自产2019最新不卡| 91精品久久久久久久99蜜桃| 亚洲国产精品欧美一二99| 91网站黄www| 亚洲天堂久久久久久久| 成人免费精品视频| 国产精品入口麻豆原神| 成人免费视频一区| 国产女人水真多18毛片18精品视频| 美国毛片一区二区三区| 欧美大白屁股肥臀xxxxxx| 丝袜脚交一区二区| 欧美一级生活片| 毛片不卡一区二区| 日韩一区二区三区四区| 日产国产高清一区二区三区| 在线成人av网站| 日韩电影在线一区二区三区| 欧美一区二区日韩一区二区| 免费成人av资源网| 2欧美一区二区三区在线观看视频| 麻豆91在线观看| 26uuu精品一区二区| 国产一区二区三区免费看 | av日韩在线网站| 国产精品伦一区| 91麻豆国产福利精品| 一区二区三区在线观看欧美| 在线看不卡av| 日韩av网站免费在线| 26uuu精品一区二区三区四区在线| 国产麻豆精品95视频| 欧美高清在线精品一区| 日本韩国视频一区二区| 午夜精品一区在线观看| 日韩午夜激情电影| 国产+成+人+亚洲欧洲自线| 一区在线观看免费| 欧美日韩中文字幕一区二区| 日韩综合在线视频| 亚洲精品在线三区| 99国产精品国产精品久久| 午夜亚洲国产au精品一区二区| 日韩色在线观看| 成人av第一页| 婷婷综合久久一区二区三区| 精品人在线二区三区| 99久久精品国产麻豆演员表| 偷拍与自拍一区| 国产日产亚洲精品系列| 在线观看日韩一区| 激情综合网天天干|