12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394 |
- /****************************************************************************
- *
- * MODULE: r.in.Lidar
- *
- * AUTHOR(S): Markus Metz
- * Based on r.in.xyz by Hamish Bowman, Volker Wichmann
- *
- * PURPOSE: Imports LAS LiDAR point clouds to a raster map using
- * aggregate statistics.
- *
- * COPYRIGHT: (C) 2011 Markus Metz and the The GRASS Development Team
- *
- * This program is free software under the GNU General Public
- * License (>=v2). Read the file COPYING that comes with GRASS
- * for details.
- *
- *****************************************************************************/
- #ifndef __LOCAL_PROTO_H__
- #define __LOCAL_PROTO_H__
- #include <grass/gis.h>
- #include <grass/raster.h>
- #include <liblas/capi/liblas.h>
- #define BUFFSIZE 256
- #define METHOD_NONE 0
- #define METHOD_N 1
- #define METHOD_MIN 2
- #define METHOD_MAX 3
- #define METHOD_RANGE 4
- #define METHOD_SUM 5
- #define METHOD_MEAN 6
- #define METHOD_STDDEV 7
- #define METHOD_VARIANCE 8
- #define METHOD_COEFF_VAR 9
- #define METHOD_MEDIAN 10
- #define METHOD_PERCENTILE 11
- #define METHOD_SKEWNESS 12
- #define METHOD_TRIMMEAN 13
- #define LAS_ALL 0
- #define LAS_FIRST 1
- #define LAS_MID 2
- #define LAS_LAST 3
- /* info.c */
- void print_lasinfo(LASHeaderH, LASSRSH);
- int scan_bounds(LASReaderH, int, int, int, double, struct Cell_head *);
- /* support.c */
- int blank_array(void *, int, int, RASTER_MAP_TYPE, int);
- int update_n(void *, int, int, int);
- int update_min(void *, int, int, int, RASTER_MAP_TYPE, double);
- int update_max(void *, int, int, int, RASTER_MAP_TYPE, double);
- int update_sum(void *, int, int, int, RASTER_MAP_TYPE, double);
- int update_sumsq(void *, int, int, int, RASTER_MAP_TYPE, double);
- /* projection.c */
- void projection_mismatch_report(struct Cell_head cellhd,
- struct Cell_head loc_wind,
- struct Key_Value *loc_proj_info,
- struct Key_Value *loc_proj_units,
- struct Key_Value *proj_info,
- struct Key_Value *proj_units,
- int err);
- void projection_check_wkt(struct Cell_head cellhd,
- struct Cell_head loc_wind,
- const char *projstr,
- int override,
- int verbose);
- /* raster reading */
- int row_array_get_value_row_col(void *array, int arr_row, int arr_col,
- int cols, RASTER_MAP_TYPE rtype, double *value);
- /* multiple files */
- struct StringList
- {
- int num_items;
- int max_items;
- char **items;
- };
- void string_list_from_file(struct StringList *string_list, char *filename);
- void string_list_from_one_item(struct StringList *string_list, char *item);
- void string_list_free(struct StringList *string_list);
- #endif /* __LOCAL_PROTO_H__ */
|