TData.h
1 /***************************************************/
2 /* Last Revised:
3 $Id$
4 */
5 /***************************************************/
6 /*
7  * This program is free software; you can redistribute it and/or modify
8  * it under the terms of the GNU General Public License as published by
9  * the Free Software Foundation; either version 2 of the License, or
10  * (at your option) any later version.
11  *
12  * This program is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15  * GNU General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License
18  * along with this program; if not, write to the Free Software
19  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20  *
21  */
22 #ifndef TData
23 #define TData
24 
25 #ifdef __cplusplus
26 extern "C" {
27 #endif
28 
29 /*
30  Este fichero contiene los tipos de datos utilizados por todos
31 */
32 
33 #ifndef M_PI
34 #define M_PI 3.14159265358979323846
35 #endif
36 
37 #define MAXLASERPOINTS 361
38 
39 #define RADIO 0.4F /* Radio del robot */
40 
41 typedef struct {
42  float x;
43  float y;
44 }Tpf;
45 
46 
47 typedef struct {
48  float r;
49  float t;
50 }Tpfp;
51 
52 typedef struct {
53  int x;
54  int y;
55 }Tpi;
56 
57 typedef struct {
58  float x;
59  float y;
60  float tita;
61 }Tsc;
62 
63 typedef struct {
64  int numPuntos;
65  Tpf laserC[MAXLASERPOINTS]; // Cartesian coordinates
66  Tpfp laserP[MAXLASERPOINTS]; // Polar coordinates
67 }Tscan;
68 
69 
70 
71 
72 // Associations information
73 typedef struct{
74  float rx,ry,nx,ny,dist; // Point (nx,ny), static corr (rx,ry), dist
75  int numDyn; // Number of dynamic associations
76  float unknown; // Unknown weight
77  int index; // Index within the original scan
78  int L,R;
79 }TAsoc;
80 
81 #ifdef __cplusplus
82 }
83 #endif
84 
85 #endif
Request to get an integer property.
Definition: player.h:459
String Property Class.
Definition: property.h:171
#define PLAYER_MSG1(level, msg, a)
Definition: error.h:106
static bool MatchMessage(player_msghdr_t *hdr, int type, int subtype, player_devaddr_t addr)
Helper for message processing.
Definition: message.h:159
double ReadFloat(int section, const char *name, double value)
Read a floating point (double) value.
int AddInterface(player_devaddr_t addr)
Add an interface.
Generic message header.
Definition: player.h:162
virtual int MainSetup(void)
Sets up the resources needed by the driver thread.
Definition: driver.h:658
virtual void MainQuit(void)
Cleanup method for driver thread (called when main exits)
Definition: driver.h:664
uint8_t type
Message type; must be one of PLAYER_MSGTYPE_*.
Definition: player.h:166
Encapsulates a device (i.e., a driver bound to an interface)
Definition: device.h:75
const char * ReadString(int section, const char *name, const char *value)
Read a string value.
uint8_t subtype
Message subtype; interface specific.
Definition: player.h:168
virtual void Main(void)=0
Main method for driver thread.
int ReadInt(int section, const char *name, int value)
Read an integer value.
#define PLAYER_MSGTYPE_DATA
A data message.
Definition: player.h:95
Definition: TData.h:73
#define PLAYER_ERROR2(msg, a, b)
Definition: error.h:83
int32_t value
The property value.
Definition: player.h:465
#define PLAYER_MSGTYPE_RESP_ACK
A positive response message.
Definition: player.h:112
virtual int ProcessMessage(QueuePointer &resp_queue, player_msghdr *hdr, void *data)
Message handler.
static bool MatchDeviceAddress(player_devaddr_t addr1, player_devaddr_t addr2)
Compare two addresses.
Definition: device.h:201
#define PLAYER_MSGTYPE_REQ
A request message.
Definition: player.h:106
#define PLAYER_MSGTYPE_RESP_NACK
A negative response message.
Definition: player.h:125
Integer property class.
Definition: property.h:115
#define PLAYER_GET_INTPROP_REQ
Integer property get request subtype.
Definition: player.h:430
int ReadDeviceAddr(player_devaddr_t *addr, int section, const char *name, int code, int index, const char *key)
Read a device id.
Class for loading configuration file information.
Definition: configfile.h:197
Definition: TData.h:52
virtual int Setup()
Initialize the driver.
Definition: driver.h:386
A device address.
Definition: player.h:146
An autopointer for the message queue.
Definition: message.h:74
void SetError(int code)
Set/reset error code.
Definition: driver.h:145
Definition: TData.h:41
virtual bool RegisterProperty(const char *key, Property *property, ConfigFile *cf, int section)
Property registration.
#define PLAYER_ERROR(msg)
Definition: error.h:81
Base class for drivers which oeprate with a thread.
Definition: driver.h:553
double timestamp
Time associated with message contents (seconds since epoch)
Definition: player.h:170
uint32_t size
Size in bytes of the payload to follow.
Definition: player.h:174
char * key
The property key.
Definition: player.h:463
Definition: TData.h:63
#define PLAYER_WARN(msg)
Warning message macros.
Definition: error.h:89
#define PLAYER_MSGTYPE_CMD
A command message.
Definition: player.h:99
virtual int Shutdown()
Finalize the driver.
Definition: driver.h:393
Base class for all drivers.
Definition: driver.h:109
Definition: TData.h:57
#define PLAYER_MSG0(level, msg)
General messages.
Definition: error.h:105
#define PLAYER_SET_INTPROP_REQ
Integer property set request subtype.
Definition: player.h:432
Definition: TData.h:47
player_devaddr_t addr
Device to which this message pertains.
Definition: player.h:164
#define PLAYER_MSGQUEUE_DEFAULT_MAXLEN
Default maximum length for a message queue.
Definition: player.h:76