⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 test_truth.c

📁 机器人仿真平台,和stage配合运行
💻 C
字号:
/*************************************************************************** * Desc: Tests for the truth device (must run Stage) * Author: Andrew Howard * Date: 26 May 2002 # CVS: $Id: test_truth.c,v 1.2.8.1 2003/05/23 21:23:44 inspectorg Exp $ **************************************************************************/#include "test.h"#include "playerc.h"// Basic test for truth device.int test_truth(playerc_client_t *client, int index){  int t;  double i_px, i_py, i_pa;  double f_px, f_py, f_pa;  void *rdevice;  playerc_truth_t *device;  printf("device [truth] index [%d]\n", index);  device = playerc_truth_create(client, index);  TEST("subscribing (read)");  if (playerc_truth_subscribe(device, PLAYER_READ_MODE) != 0)  {    FAIL();    return -1;  }  PASS();  for (t = 0; t < 3; t++)  {    TEST("getting pose (req/rep)");    if (playerc_truth_get_pose(device, &f_px, &f_py, &f_pa) != 0)    {      FAIL();      return -1;    }    PASS();    printf("truth: [%6.3f] [%6.3f] [%6.3f]\n", f_px, f_py, f_pa);  }    TEST("setting pose");  i_px = 2; i_py = 3; i_pa = M_PI/2;  if (playerc_truth_set_pose(device, i_px, i_py, i_pa) != 0)  {    FAIL();    return -1;  }  PASS();  TEST("getting pose (req/rep)");  if (playerc_truth_get_pose(device, &f_px, &f_py, &f_pa) != 0)  {    FAIL();    return -1;  }  PASS();  printf("truth: [%6.3f] [%6.3f] [%6.3f]\n", f_px, f_py, f_pa);  TEST("checking values for consitency");  if (f_px != i_px || f_py != i_py || f_pa != i_pa)  {    FAIL();    return -1;  }  PASS();  for (t = 0; t < 3; t++)  {    TEST1("reading data (attempt %d)", t);    do      rdevice = playerc_client_read(client);    while (rdevice == client);    if (rdevice == device)    {      PASS();      printf("truth: [%6.3f] [%6.3f] [%6.3f]\n",             device->px, device->py, device->pa);    }    else      FAIL();  }  TEST("unsubscribing");  if (playerc_truth_unsubscribe(device) != 0)  {    FAIL();    return -1;  }  PASS();    playerc_truth_destroy(device);    return 0;}

⌨️ 快捷键说明

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