GRASS GIS 8 Programmer's Manual
8.5.0dev(2025)-fbabf32052
|
Go to the source code of this file.
Functions | |
struct BM * | BM_create (int, int) |
Create bitmap of dimension x/y and return structure token. More... | |
int | BM_destroy (struct BM *) |
Destroy bitmap and free all associated memory. More... | |
int | BM_set_mode (int, int) |
Specify the type of data structure to use for bitmap. 'mode' can be either BM_FLAT or BM_SPARSE: More... | |
int | BM_set (struct BM *, int, int, int) |
Sets bitmap value to 'val' at location 'x' 'y'. More... | |
int | BM_get (struct BM *, int, int) |
Gets 'val' from the bitmap. More... | |
size_t | BM_get_map_size (struct BM *) |
Returns size in bytes that bitmap is taking up. More... | |
int | BM_file_write (FILE *, struct BM *) |
Write bitmap out to file. More... | |
struct BM * | BM_file_read (FILE *) |
Create map structure and load it from file. More... | |
struct BM * | BM_create_sparse (int, int) |
Create a sparse bitmap of dimension 'x'/'y'. More... | |
int | BM_destroy_sparse (struct BM *) |
Destroy sparse bitmap and free all associated memory. More... | |
int | BM_set_sparse (struct BM *, int, int, int) |
Set sparse bitmap value to 'val' at location 'x'/'y'. More... | |
int | BM_get_sparse (struct BM *, int, int) |
Returns sparse bitmap value at location 'x'/'y'. More... | |
size_t | BM_get_map_size_sparse (struct BM *) |
Returns size of sparse bitmap in bytes. More... | |
int | BM_dump_map_sparse (struct BM *) |
Debugging code to dump out structure of links. More... | |
int | BM_dump_map_row_sparse (struct BM *, int) |
Debugging code to dump out structure of links for single row. More... | |
int | BM_file_write_sparse (FILE *, struct BM *) |
Write sparse bitmap matrix out to disk file 'fp'. NOTE: 'fp' must already be opened and later closed by user. More... | |
struct BM* BM_create | ( | int | x, |
int | y | ||
) |
Create bitmap of dimension x/y and return structure token.
Bitmap is initialized to all zeros
x | x dimension |
y | y dimension |
Definition at line 58 of file bitmap.c.
Referenced by gs_update_curmask(), gsbm_make_mask(), IL_create_bitmask(), and main().
struct BM* BM_create_sparse | ( | int | x, |
int | y | ||
) |
Create a sparse bitmap of dimension 'x'/'y'.
Returns bitmap structure or NULL on error
x | |
y |
Definition at line 42 of file sparse.c.
References BM::bytes, BM::cols, count, BM::data, free(), link_init(), link_new(), link_set_chunk_size(), malloc(), NULL, BM::rows, BM::sparse, BM::token, BMlink::val, and x.
Referenced by main().
int BM_destroy | ( | struct BM * | map | ) |
Destroy bitmap and free all associated memory.
map |
Definition at line 89 of file bitmap.c.
References BM_destroy_sparse(), BM::data, free(), and BM::sparse.
Referenced by gs_update_curmask().
int BM_destroy_sparse | ( | struct BM * | map | ) |
Destroy sparse bitmap and free all associated memory.
Returns 0
map |
Definition at line 88 of file sparse.c.
Referenced by BM_destroy().
int BM_dump_map_row_sparse | ( | struct BM * | map, |
int | y | ||
) |
Debugging code to dump out structure of links for single row.
Returns 0
map | |
y |
Definition at line 323 of file sparse.c.
References BMlink::count, BM::data, BMlink::next, NULL, and BMlink::val.
int BM_dump_map_sparse | ( | struct BM * | map | ) |
Debugging code to dump out structure of links.
Returns 0
map |
Definition at line 294 of file sparse.c.
References BMlink::count, BM::data, BMlink::next, NULL, BM::rows, and BMlink::val.
struct BM* BM_file_read | ( | FILE * | fp | ) |
Create map structure and load it from file.
'fp' should previously been created by BM_file_write()
Returns struct BM * or NULL on error
fp |
int BM_file_write | ( | FILE * | fp, |
struct BM * | map | ||
) |
int BM_file_write_sparse | ( | FILE * | fp, |
struct BM * | map | ||
) |
int BM_get | ( | struct BM * | map, |
int | x, | ||
int | y | ||
) |
Gets 'val' from the bitmap.
Returns 0 or 1 on success or -1 on error
map | |
x | |
y |
Definition at line 217 of file bitmap.c.
References BM_col_to_bit, BM_col_to_byte, BM_get_sparse(), BM::bytes, BM::cols, BM::data, BM::rows, BM::sparse, and x.
Referenced by calc_norm(), get_mapatt(), gs_masked(), gs_point_is_masked(), gsbm_make_mask(), gsd_wire_arrows(), gsd_wire_surf_const(), gsd_wire_surf_map(), IL_secpar_loop_2d(), and print_bm().
size_t BM_get_map_size | ( | struct BM * | map | ) |
Returns size in bytes that bitmap is taking up.
map |
Definition at line 241 of file bitmap.c.
References BM_get_map_size_sparse(), BM::bytes, BM::rows, and BM::sparse.
size_t BM_get_map_size_sparse | ( | struct BM * | map | ) |
Returns size of sparse bitmap in bytes.
map |
Definition at line 265 of file sparse.c.
References BM::data, BMlink::next, NULL, and BM::rows.
Referenced by BM_get_map_size().
int BM_get_sparse | ( | struct BM * | map, |
int | x, | ||
int | y | ||
) |
Returns sparse bitmap value at location 'x'/'y'.
Returns value or -1 on error
map | |
x | |
y |
Definition at line 240 of file sparse.c.
References BMlink::count, cur_x, BM::data, BMlink::next, NULL, BMlink::val, and x.
Referenced by BM_get().
int BM_set | ( | struct BM * | map, |
int | x, | ||
int | y, | ||
int | val | ||
) |
Sets bitmap value to 'val' at location 'x' 'y'.
Returns 0 on success
map | |
x | |
y | |
val |
Definition at line 185 of file bitmap.c.
References BM_col_to_bit, BM_col_to_byte, BM_set_sparse(), BM::bytes, BM::cols, BM::data, BM::rows, BM::sparse, and x.
Referenced by gs_update_curmask(), gsbm_make_mask(), IL_create_bitmask(), and main().
int BM_set_mode | ( | int | mode, |
int | size | ||
) |
Specify the type of data structure to use for bitmap. 'mode' can be either BM_FLAT or BM_SPARSE:
BM_FLAT is a basic packed bitmap - eight values stored per byte thus creating a 1:8 compression over using char arrays and a 1:32 compression over using CELL arrays.
BM_SPARSE is a linked array of values. This is much more efficient for large, very sparse arrays. It is slower to access, especially for writing, but can save several orders of magnitude of memory on large bitmaps.
NOTE: At this time 'size' must be passed a value of 1
returns 0 on success or -1 on error
mode | |
size |
int BM_set_sparse | ( | struct BM * | map, |
int | x, | ||
int | y, | ||
int | val | ||
) |
Set sparse bitmap value to 'val' at location 'x'/'y'.
Returns 0
map | |
x | |
y | |
val |
Definition at line 125 of file sparse.c.
References BMlink::count, cur_x, BM::data, link_dispose(), link_new(), BMlink::next, NULL, BM::token, BMlink::val, VOID_T, and x.
Referenced by BM_set().