20 #include <grass/N_pde.h>
79 if (rows < 1 || cols < 1)
80 G_fatal_error(
"N_alloc_array_2d: cols and rows should be > 0");
83 G_fatal_error(
"N_alloc_array_2d: Wrong data type, should be CELL_TYPE, "
84 "FCELL_TYPE or DCELL_TYPE");
102 "N_alloc_array_2d: CELL array allocated rows_intern %i "
103 "cols_intern %i offset %i",
110 "N_alloc_array_2d: FCELL array allocated rows_intern %i "
111 "cols_intern %i offset %i",
118 "N_alloc_array_2d: DCELL array allocated rows_intern %i "
119 "cols_intern %i offset %i",
136 G_debug(3,
"N_free_array_2d: free N_array_2d");
237 "N_is_array_2d_value_null: null value is of type CELL at "
246 "N_is_array_2d_value_null: null value is of type FCELL at "
255 "N_is_array_2d_value_null: null value is of type DCELL at "
266 "N_is_array_2d_value_null: null value is of type CELL at "
277 "N_is_array_2d_value_null: null value is of type FCELL at "
288 "N_is_array_2d_value_null: null value is of type DCELL at "
320 switch (data->
type) {
353 switch (data->
type) {
359 return (
FCELL)fvalue;
362 return (
FCELL)dvalue;
386 switch (data->
type) {
392 return (
DCELL)fvalue;
395 return (
DCELL)dvalue;
415 G_debug(6,
"N_put_array_2d_value: put value to array");
463 "N_put_array_2d_value_null: put null value to array pos [%i][%i]",
521 switch (data->
type) {
523 fvalue = (
FCELL)value;
527 dvalue = (
DCELL)value;
551 switch (data->
type) {
553 cvalue = (
CELL)value;
557 dvalue = (
DCELL)value;
581 switch (data->
type) {
583 cvalue = (
CELL)value;
587 fvalue = (
FCELL)value;
606 fprintf(stdout,
"N_array_2d \n");
607 fprintf(stdout,
"Cols %i\n", data->
cols);
608 fprintf(stdout,
"Rows: %i\n", data->
rows);
609 fprintf(stdout,
"Array type: %i\n", data->
type);
610 fprintf(stdout,
"Offset: %i\n", data->
offset);
611 fprintf(stdout,
"Internal cols: %i\n", data->
cols_intern);
612 fprintf(stdout,
"Internal rows: %i\n", data->
rows_intern);
613 fprintf(stdout,
"CELL array pointer: %p\n", (
void *)data->
cell_array);
614 fprintf(stdout,
"FCELL array pointer: %p\n", (
void *)data->
fcell_array);
615 fprintf(stdout,
"DCELL array pointer: %p\n", (
void *)data->
dcell_array);
634 for (j = 0 - data->
offset; j < data->rows + data->
offset; j++) {
635 for (i = 0 - data->
offset; i < data->cols + data->
offset; i++) {
643 fprintf(stdout,
"\n");
645 fprintf(stdout,
"\n");
724 if (rows < 1 || cols < 1 || depths < 1)
725 G_fatal_error(
"N_alloc_array_3d: depths, cols and rows should be > 0");
728 G_fatal_error(
"N_alloc_array_3d: Wrong data type, should be FCELL_TYPE "
749 "N_alloc_array_3d: float array allocated rows_intern %i "
750 "cols_intern %i depths_intern %i offset %i",
759 "N_alloc_array_3d: double array allocated rows_intern %i "
760 "cols_intern %i depths_intern %i offset %i",
778 G_debug(3,
"N_free_array_3d: free N_array_3d");
879 "N_is_array_3d_value_null: null value is of type "
880 "DCELL_TYPE at pos [%i][%i][%i]",
890 "N_is_array_3d_value_null: null value is of type "
891 "DCELL_TYPE at pos [%i][%i][%i]",
903 "N_is_array_3d_value_null: null value is of type "
904 "DCELL_TYPE at pos [%i][%i][%i]",
917 "N_is_array_3d_value_null: null value is of type "
918 "DCELL_TYPE at pos [%i][%i][%i]",
953 switch (data->
type) {
956 return (
float)fvalue;
959 return (
float)dvalue;
984 switch (data->
type) {
988 return (
double)fvalue;
991 return (
double)dvalue;
1014 G_debug(6,
"N_put_array_3d_value: put value to array at pos [%i][%i][%i]",
1035 (col + data->
offset)] = *((
float *)value);
1041 (col + data->
offset)] = *((
double *)value);
1064 "N_put_array_3d_value_null: put null value to array at pos "
1127 dval = (double)value;
1154 fval = (double)value;
1173 fprintf(stdout,
"N_array_3d \n");
1174 fprintf(stdout,
"Cols %i\n", data->
cols);
1175 fprintf(stdout,
"Rows: %i\n", data->
rows);
1176 fprintf(stdout,
"Depths: %i\n", data->
depths);
1177 fprintf(stdout,
"Array type: %i\n", data->
type);
1178 fprintf(stdout,
"Offset: %i\n", data->
offset);
1179 fprintf(stdout,
"Internal cols: %i\n", data->
cols_intern);
1180 fprintf(stdout,
"Internal rows: %i\n", data->
rows_intern);
1181 fprintf(stdout,
"Internal depths: %i\n", data->
depths_intern);
1182 fprintf(stdout,
"FCELL array pointer: %p\n", (
void *)data->
fcell_array);
1183 fprintf(stdout,
"DCELL array pointer: %p\n", (
void *)data->
dcell_array);
1202 for (k = 0; k < data->
depths; k++) {
1203 for (j = 0; j < data->
rows; j++) {
1204 for (i = 0; i < data->
cols; i++) {
void G_free(void *)
Free allocated memory.
void void void void G_fatal_error(const char *,...) __attribute__((format(printf
int G_debug(int, const char *,...) __attribute__((format(printf
void Rast3d_set_null_value(void *, int, int)
Fills the vector pointed to by c with nofElts NULL-values of type.
int Rast3d_is_null_value_num(const void *, int)
int Rast_is_null_value(const void *, RASTER_MAP_TYPE)
To check if a raster value is set to NULL.
void Rast_set_d_null_value(DCELL *, int)
To set a number of DCELL raster values to NULL.
void Rast_set_f_null_value(FCELL *, int)
To set a number of FCELL raster values to NULL.
void Rast_set_c_null_value(CELL *, int)
To set a number of CELL raster values to NULL.
FCELL N_get_array_2d_f_value(N_array_2d *data, int col, int row)
Returns the value of type FCELL at position col, row.
void N_put_array_3d_value_null(N_array_3d *data, int col, int row, int depth)
This function writes a null value to the N_array_3d data at position col, row, depth.
void N_print_array_3d_info(N_array_3d *data)
Write the info of the array to stdout.
CELL N_get_array_2d_c_value(N_array_2d *data, int col, int row)
Returns the value of type CELL at position col, row.
void N_put_array_2d_f_value(N_array_2d *data, int col, int row, FCELL value)
Writes a FCELL value to the N_array_2d struct at position col, row.
float N_get_array_3d_f_value(N_array_3d *data, int col, int row, int depth)
This function returns the value of type float at position col, row, depth.
void N_free_array_3d(N_array_3d *data)
Release the memory of a N_array_3d.
void N_put_array_3d_f_value(N_array_3d *data, int col, int row, int depth, float value)
This function writes a float value to the N_array_3d data at position col, row, depth.
DCELL N_get_array_2d_d_value(N_array_2d *data, int col, int row)
Returns the value of type DCELL at position col, row.
int N_get_array_2d_type(N_array_2d *array)
Return the data type of the N_array_2d struct.
void N_put_array_3d_value(N_array_3d *data, int col, int row, int depth, char *value)
This function writes a value to the N_array_3d data at position col, row, depth.
N_array_3d * N_alloc_array_3d(int cols, int rows, int depths, int offset, int type)
Allocate memory for a N_array_3d data structure.
void N_print_array_2d(N_array_2d *data)
Write info and content of the N_array_2d struct to stdout.
int N_is_array_3d_value_null(N_array_3d *data, int col, int row, int depth)
This function returns 1 if value of N_array_3d data at position col, row, depth is of type null,...
void N_get_array_2d_value(N_array_2d *data, int col, int row, void *value)
Write the value of the N_array_2d struct at position col, row to value.
void N_put_array_2d_value(N_array_2d *data, int col, int row, char *value)
Writes a value to the N_array_2d struct at position col, row.
void N_print_array_2d_info(N_array_2d *data)
This function writes the data info of the array data to stdout.
int N_is_array_2d_value_null(N_array_2d *data, int col, int row)
Returns 1 if the value of N_array_2d struct at position col, row is of type null, otherwise 0.
N_array_2d * N_alloc_array_2d(int cols, int rows, int offset, int type)
Allocate memory for a N_array_2d data structure.
void N_free_array_2d(N_array_2d *data)
Release the memory of a N_array_2d structure.
void N_put_array_3d_d_value(N_array_3d *data, int col, int row, int depth, double value)
Writes a double value to the N_array_3d struct at position col, row, depth.
double N_get_array_3d_d_value(N_array_3d *data, int col, int row, int depth)
This function returns the value of type float at position col, row, depth.
void N_get_array_3d_value(N_array_3d *data, int col, int row, int depth, void *value)
This function writes the value of N_array_3d data at position col, row, depth to the variable value.
void N_put_array_2d_value_null(N_array_2d *data, int col, int row)
Writes the null value to the N_array_2d struct at position col, row.
void N_put_array_2d_c_value(N_array_2d *data, int col, int row, CELL value)
Writes a CELL value to the N_array_2d struct at position col, row.
void N_put_array_2d_d_value(N_array_2d *data, int col, int row, DCELL value)
Writes a DCELL value to the N_array_2d struct at position col, row.
int N_get_array_3d_type(N_array_3d *array)
Return the data type of the N_array_3d.
void N_print_array_3d(N_array_3d *data)
Write info and content of the array data to stdout.