00001 #ifndef H_LASER_DATA_DRAWING
00002 #define H_LASER_DATA_DRAWING
00003
00004 #include "laser_data.h"
00005
00006 typedef enum { Invalid = 0, Odometry = 1, Estimate = 2, True_pose = 3 } ld_reference;
00007
00008 const char*ld_reference_to_string(ld_reference);
00009 ld_reference ld_string_to_reference(const char*string);
00010
00013 double * ld_get_reference_pose_silent(LDP ld, ld_reference use_reference);
00016 double * ld_get_reference_pose(LDP ld, ld_reference use_reference);
00017
00018
00019
00020 int ld_read_some_scans_distance(FILE*file, LDP **array, int*num,
00021 ld_reference which, double d_xy, double d_th);
00022
00023 typedef struct {
00025 double pose[3];
00027 double size[2];
00028 } oriented_bbox;
00029
00030 typedef oriented_bbox* BB2;
00031
00032
00034 int ld_get_bounding_box(LDP ld, double bb_min[2], double bb_max[2],
00035 double pose[3], double horizon);
00036
00037 void lda_get_bounding_box(LDP *ld, int nld, double bb_min[2], double bb_max[2],
00038 double offset[3], ld_reference use_reference, double horizon);
00039
00040
00041
00042
00043 void oriented_bbox_compute_corners(const BB2,
00044 double ul[2], double ur[2], double ll[2], double lr[2]);
00045
00046 void ld_get_oriented_bbox(LDP ld, double horizon, BB2);
00047
00048
00049 struct bbfind_imp;
00050 typedef struct bbfind_imp bbfind;
00051 bbfind * bbfind_new();
00052
00053 int bbfind_add_point(bbfind*, double point[2]);
00054 int bbfind_add_point2(bbfind*, double x, double y);
00055 int bbfind_add_bbox(bbfind*, const BB2);
00056
00057 int bbfind_compute(bbfind*, BB2);
00058 void bbfind_free(bbfind*);
00059
00060
00061
00062 struct stroke_sequence {
00063 int begin_new_stroke;
00064 int end_stroke;
00065 int valid;
00066
00067 double p[2];
00068 };
00069
00070 void compute_stroke_sequence(LDP ld, struct stroke_sequence*,
00071 double horizon, double connect_threshold);
00072
00073
00074 #endif