test_position3d.c

来自「机器人仿真软件」· C语言 代码 · 共 109 行

C
109
字号
/*************************************************************************** * Desc: Tests for the position3d device * Author: Andrew Howard * Date: 23 May 2002 # CVS: $Id: test_position3d.c,v 1.7 2005/09/01 06:23:32 inspectorg Exp $**************************************************************************/#include <math.h>#include "test.h"#include "playerc.h"// Basic test for position3d device.int test_position3d(playerc_client_t *client, int index){  int t;  void *rdevice;  playerc_position3d_t *device;  printf("device [position3d] index [%d]\n", index);  device = playerc_position3d_create(client, index);  TEST("subscribing (read/write)");  if (playerc_position3d_subscribe(device, PLAYER_OPEN_MODE) < 0)  {    FAIL();    return -1;  }  PASS();#if 0 // TODO    TEST("getting geometry");  if (playerc_position3d_get_geom(device) == 0)    PASS();  else    FAIL();  printf("position3d geom: [%6.3f %6.3f %6.3f] [%6.3f %6.3f]\n",         device->pose[0], device->pose[1], device->pose[2], device->size[0], device->size[1]);  TEST("enabling motors");  if (playerc_position3d_enable(device, 1) == 0)    PASS();  else    FAIL();#endif    for (t = 0; t < 300; t++)  {    TEST1("reading data (attempt %d)", t);    do      rdevice = playerc_client_read(client);    while (rdevice == client);    if (rdevice == device)    {      PASS();      printf("position3d: [%14.3f] [%+7.3f %+7.3f %+7.3f] [%+7.3f %+7.3f %+7.3f]\n",             device->info.datatime,             device->pos_x, device->pos_y, device->pos_z,             device->pos_roll * 180/M_PI,             device->pos_pitch * 180/M_PI,             device->pos_yaw * 180/M_PI);    }    else    {      FAIL();      break;    }#if 0 // TODO    TEST1("writing data (attempt %d)", t);    if (playerc_position3d_set_velocity(device, 0.10, 0, 0, 0, 0, 0.2, 1) != 0)    {      FAIL();      break;    }    PASS();#endif  }#if 0 // TODO  TEST1("writing data (attempt %d)", t);  if (playerc_position3d_set_velocity(device, 0, 0, 0, 0, 0, 0, 1) != 0)    FAIL();  else    PASS();  TEST("disabling motors");  if (playerc_position3d_enable(device, 0) == 0)    PASS();  else    FAIL();  TEST("unsubscribing");  if (playerc_position3d_unsubscribe(device) != 0)    FAIL();  else    PASS();#endif    playerc_position3d_destroy(device);    return 0;}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?