📄 rwi_sonardevice.cc
字号:
/* * Player - One Hell of a Robot Server * Copyright (C) 2002 * Brian Gerkey, Kasper Stoy, Richard Vaughan, & Andrew Howard * Nik Melchior * * * This program 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. * * This program 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 this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * */#include <rwi_sonardevice.h>#include <stdio.h>#include <netinet/in.h>#include <string.h>#include <math.h>#ifdef HAVE_STRINGS_H #include <strings.h>#endifCDevice* RWISonar_Init(char* interface, ConfigFile* cf, int section){ return((CDevice *)(new CRWISonarDevice(interface, cf, section)));}void RWISonar_Register(DriverTable* table){ table->AddDriver("rwi_sonar", PLAYER_READ_MODE, RWISonar_Init);} CRWISonarDevice::CRWISonarDevice(char* interface, ConfigFile* cf, int section) : CRWIDevice(interface, cf, section, sizeof(player_sonar_data_t), 0 /* no commands for sonar */, 1,1){ char* tmp; tmp = (char*)cf->ReadString(section, "array", "upper"); if (!strcmp(tmp, "upper")) { upper = true; } else if(!strcmp(tmp, "lower")) { upper = false; }}intCRWISonarDevice::Setup(){#ifdef USE_MOBILITY CORBA::Object_ptr temp; char *path = upper ? "/Sonar/Segment" : "/BaseSonar/Segment"; if (RWIConnect(&temp, path) < 0) { fprintf(stderr, "rwi_sonardevice unable to connect.\n"); return -1; } else { sonar_state = MobilityGeometry::SegmentState::_narrow(temp); }#else printf("Cannot create rwi_sonar device without mobility.\n"); return -1;#endif // USE_MOBILITY // Zero the common buffer player_sonar_data_t data; memset(&data, 0, sizeof(data)); PutData((unsigned char *) &data, sizeof(data), 0, 0); StartThread(); return 0;}intCRWISonarDevice::Shutdown(){ StopThread(); return 0;} /* * RWI returns distance data in meters as doubles. * Player prefers millimeters. * Thus, values are multiplied by 1000.0 here * before they are stored. */voidCRWISonarDevice::Main(){ // start enabled bool enabled = true; // Working buffer space player_rwi_config_t cfg; player_sonar_data_t data; player_sonar_geom_t geom; double th; int i; void *client; #ifdef USE_MOBILITY MobilityGeometry::SegmentData_var sonar_data;#endif // USE_MOBILITY if (pthread_setcanceltype(PTHREAD_CANCEL_DEFERRED, NULL) != 0) { perror("rwi_sonar call to pthread_setcanceltype failed"); } while (true) { // First, check for a configuration request if (GetConfig(&client, (void *) &cfg, sizeof(cfg))) { switch (cfg.request) { case PLAYER_SONAR_POWER_REQ: // RWI does not turn off sonar power; all we can do is // stop updating the data if (cfg.value == 0) enabled = false; else enabled = true; if (PutReply(client, PLAYER_MSGTYPE_RESP_ACK, NULL, NULL, 0)) { PLAYER_ERROR("Failed to PutReply in " "rwi_sonardevice.\n"); } break; case PLAYER_SONAR_GET_GEOM_REQ: geom.subtype=PLAYER_SONAR_GET_GEOM_REQ; geom.pose_count=htons(24); for (i=0,th=7.5/180.0*M_PI;i<ntohs(geom.pose_count);i++,th+=M_PI/12.0) { geom.poses[i][0]=htons(int16_t(cos(th)*250)); geom.poses[i][1]=htons(int16_t(sin(th)*250)); geom.poses[i][2]=htons(int16_t(th/M_PI*180.0)%360); //printf("%d %d %d\n",(int16_t)ntohs(geom.poses[i][0]),(int16_t)ntohs(geom.poses[i][1]),(int16_t)ntohs(geom.poses[i][2])); } for (;i<PLAYER_SONAR_MAX_SAMPLES;i++) { geom.poses[i][0]=0; geom.poses[i][1]=0; geom.poses[i][2]=0; } if (PutReply(client, PLAYER_MSGTYPE_RESP_ACK, NULL, &geom, sizeof(geom))) { PLAYER_ERROR("Failed to PutReply in " "rwi_sonardevice.\n"); } break; default: printf("rwi_sonar device received unknown %s", "configuration request\n"); if (PutReply(client, PLAYER_MSGTYPE_RESP_NACK, NULL, NULL, 0)) { PLAYER_ERROR("Failed to PutReply in " "rwi_sonardevice.\n"); } break; } } // Sonar takes no commands to process // Finally, collect new data if (enabled) {#ifdef USE_MOBILITY sonar_data = sonar_state->get_sample(0); data.range_count = htons((uint16_t) sonar_data->org.length()); for (unsigned int i = 0; (i < sonar_data->org.length()) && (i < PLAYER_SONAR_MAX_SAMPLES); i++) { data.ranges[i] = htons((uint16_t) (1000.0 * sqrt(((sonar_data->org[i].x - sonar_data->end[i].x) * (sonar_data->org[i].x - sonar_data->end[i].x)) + ((sonar_data->org[i].y - sonar_data->end[i].y) * (sonar_data->org[i].y - sonar_data->end[i].y))))); }#else data.range_count = 0;#endif // USE_MOBILITY PutData((unsigned char *) &data, sizeof(data), 0, 0); } pthread_testcancel(); } // should not reach this point pthread_exit(NULL);}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -