GRASS 8 Programmer's Manual 8.6.0dev(2026)-5f4f7ad06c
Loading...
Searching...
No Matches
changeprecision.c
Go to the documentation of this file.
1#include <stdio.h>
2#include <stdlib.h>
3#include <sys/types.h>
4#include <unistd.h>
5#include <grass/raster3d.h>
6
7/*---------------------------------------------------------------------------*/
8
9/*!
10 * \brief
11 *
12 * Makes a copy of <em>map</em> with name <em>nameOut</em> which is
13 * written with <em>precision</em>.
14 * The source code can be found in <em>changeprecision.c</em>.
15 *
16 * \param map
17 * \param precision
18 * \param nameOut
19 * \return void
20 */
21void Rast3d_change_precision(void *map, int precision, const char *nameOut)
22{
23 void *map2;
25 char *data;
26 RASTER3D_Region region;
27 int typeIntern;
28 int nx, ny, nz;
29 int tileXsave, tileYsave, tileZsave, tileX, tileY, tileZ, saveType;
30
32 /* Rast3d_set_file_type (Rast3d_file_type_map (map)); */
36 Rast3d_get_tile_dimensions_map(map, &tileX, &tileY, &tileZ);
37 Rast3d_set_tile_dimension(tileX, tileY, tileZ);
38
39 typeIntern = Rast3d_tile_type_map(map);
40 Rast3d_get_region_struct_map(map, &region);
41
43 &region);
44 if (map2 == NULL)
46 "Rast3d_change_precision: error in Rast3d_open_cell_new");
47
51
52 data = Rast3d_alloc_tiles(map, 1);
53 if (data == NULL)
55 "Rast3d_change_precision: error in Rast3d_alloc_tiles");
56 Rast3d_get_nof_tiles_map(map2, &nx, &ny, &nz);
57
58 for (z = 0; z < nz; z++)
59 for (y = 0; y < ny; y++)
60 for (x = 0; x < nx; x++) {
61 if (!Rast3d_read_tile(map, Rast3d_tile2tile_index(map, x, y, z),
62 data, typeIntern))
64 "Rast3d_change_precision: error in Rast3d_read_tile");
67 data, typeIntern))
69 "Rast3d_change_precision: error in Rast3d_write_tile");
70 }
71
73 if (!Rast3d_close(map2))
74 Rast3d_fatal_error("Rast3d_change_precision: error in Rast3d_close");
75}
#define NULL
Definition ccmath.h:32
void Rast3d_change_precision(void *map, int precision, const char *nameOut)
Makes a copy of map with name nameOut which is written with precision. The source code can be found i...
int Rast3d_tile_type_map(RASTER3D_Map *)
Returns the type in which tiles of map are stored in memory.
Definition headerinfo.c:150
void Rast3d_get_nof_tiles_map(RASTER3D_Map *, int *, int *, int *)
Returns the dimensions of the tile-cube used to tile the region of map. These numbers include partial...
Definition headerinfo.c:48
void Rast3d_get_tile_dimensions_map(RASTER3D_Map *, int *, int *, int *)
Returns the tile dimensions used for map.
Definition headerinfo.c:133
void Rast3d_get_tile_dimension(int *, int *, int *)
get Tile Dimension
Definition defaults.c:252
void Rast3d_get_region_struct_map(RASTER3D_Map *, RASTER3D_Region *)
Returns in region the region of map.
Definition headerinfo.c:108
void * Rast3d_alloc_tiles(RASTER3D_Map *, int)
Is equivalent to Rast3d_alloc_tiles_type (map, nofTiles, Rast3d_file_type_map (map)).
Definition tilealloc.c:47
void Rast3d_free_tiles(void *)
Is equivalent to Rast3d_free (tiles);
Definition tilealloc.c:70
void Rast3d_set_tile_dimension(int, int, int)
set Tile Dimension
Definition defaults.c:227
void * Rast3d_open_cell_new(const char *, int, int, RASTER3D_Region *)
Opens new g3d-file with name in the current mapset. Tiles are stored in memory with type which must b...
void Rast3d_set_file_type(int)
set G3d file type
Definition defaults.c:197
int Rast3d_get_file_type(void)
get G3d file type
Definition defaults.c:212
int Rast3d_tile2tile_index(RASTER3D_Map *, int, int, int)
Returns tile-index corresponding to tile-coordinates (xTile, yTile, zTile).
Definition tilemath.c:47
void Rast3d_get_compression_mode(int *, int *)
Gets compression mode.
Definition defaults.c:125
int Rast3d_read_tile(RASTER3D_Map *, int, void *, int)
Reads tile with index tileIndex into the tile buffer. The cells are stored with type type which must ...
Definition tileread.c:150
void Rast3d_set_compression_mode(int, int)
set compression mode
Definition defaults.c:93
int Rast3d_write_tile(RASTER3D_Map *, int, const void *, int)
Writes tile with index tileIndex to the file corresponding to map. It is assumed that the cells in ti...
Definition tilewrite.c:129
void Rast3d_fatal_error(const char *,...) __attribute__((format(printf
int Rast3d_close(RASTER3D_Map *)
Close 3D raster map files.
#define RASTER3D_COMPRESSION
Definition raster3d.h:14
#define RASTER3D_USE_CACHE_DEFAULT
Definition raster3d.h:19
#define x