GRASS GIS 8 Programmer's Manual  8.4.0dev(2024)-761b3a08c9
gvl_calc.c File Reference

OGSF library - loading and manipulating volumes (lower level functions) More...

#include <math.h>
#include <grass/gis.h>
#include <grass/ogsf.h>
#include "rgbpack.h"
#include "mc33_table.h"
Include dependency graph for gvl_calc.c:

Go to the source code of this file.

Macros

#define BUFFER_SIZE   1000000
 memory buffer for writing More...
 
#define LINTERP(d, a, b)   (a + d * (b - a))
 
#define TINTERP(d, v)
 
#define FOR_VAR   i_for
 
#define FOR_0_TO_N(n, cmd)
 
#define WRITE(c)   gvl_write_char(dbuff->ndx_new++, &(dbuff->new), c)
 writing and reading isosurface data More...
 
#define READ()   gvl_read_char(dbuff->ndx_old++, dbuff->old)
 
#define SKIP(n)   dbuff->ndx_old = dbuff->ndx_old + n
 
#define IS_IN_DATA(att)   ((isosurf->data_desc >> att) & 1)
 check and set data descriptor More...
 
#define SET_IN_DATA(att)   isosurf->data_desc = (isosurf->data_desc | (1 << att))
 
#define DISTANCE_2(x1, y1, x2, y2)    sqrt((x1 - x2) * (x1 - x2) + (y1 - y2) * (y1 - y2))
 
#define SLICE_MODE_INTERP_NO   0
 
#define SLICE_MODE_INTERP_YES   1
 

Functions

int mc33_process_cube (int c_ndx, float *v)
 ADD. More...
 
void iso_w_cndx (int ndx, data_buffer *dbuff)
 Write cube index. More...
 
int iso_r_cndx (data_buffer *dbuff)
 Read cube index. More...
 
int iso_get_cube_value (geovol_isosurf *isosurf, int desc, int x, int y, int z, float *v)
 Get value from data input. More...
 
void iso_get_range (geovol_isosurf *isosurf, int desc, double *min, double *max)
 Get volume file values range. More...
 
int iso_get_cube_values (geovol_isosurf *isosurf, int desc, int x, int y, int z, float *v)
 Read values for cube. More...
 
void iso_get_cube_grads (geovol_isosurf *isosurf, int x, int y, int z, float(*grad)[3])
 Calculate cube grads. More...
 
void iso_calc_cube (geovol_isosurf *isosurf, int x, int y, int z, data_buffer *dbuff)
 Process cube. More...
 
int gvl_isosurf_calc (geovol *gvol)
 Fill data structure with computed isosurfaces polygons. More...
 
void gvl_write_char (int pos, unsigned char **data, unsigned char c)
 ADD. More...
 
unsigned char gvl_read_char (int pos, const unsigned char *data)
 Read char. More...
 
void gvl_align_data (int pos, unsigned char **data)
 Append data to buffer. More...
 
float slice_get_value (geovol *gvl, int x, int y, int z)
 Get volume value. More...
 
int slice_calc (geovol *gvl, int ndx_slc, void *colors)
 Calculate slices. More...
 
int gvl_slices_calc (geovol *gvol)
 Calculate slices for given volume set. More...
 

Variables

int Rows
 
int Cols
 
int Depths
 
double ResX
 
double ResY
 
double ResZ
 

Detailed Description

OGSF library - loading and manipulating volumes (lower level functions)

GRASS OpenGL gsurf OGSF Library

(C) 1999-2008 by 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.

Author
Tomas Paudits (February 2004)
Doxygenized by Martin Landa <landa.martin gmail.com> (May 2008)

Definition in file gvl_calc.c.

Macro Definition Documentation

◆ BUFFER_SIZE

#define BUFFER_SIZE   1000000

memory buffer for writing

Definition at line 31 of file gvl_calc.c.

◆ DISTANCE_2

#define DISTANCE_2 (   x1,
  y1,
  x2,
  y2 
)     sqrt((x1 - x2) * (x1 - x2) + (y1 - y2) * (y1 - y2))

Definition at line 802 of file gvl_calc.c.

◆ FOR_0_TO_N

#define FOR_0_TO_N (   n,
  cmd 
)
Value:
{ \
int FOR_VAR; \
for (FOR_VAR = 0; FOR_VAR < n; FOR_VAR++) { \
cmd; \
} \
}
#define FOR_VAR
Definition: gvl_calc.c:46

Definition at line 47 of file gvl_calc.c.

◆ FOR_VAR

#define FOR_VAR   i_for

Definition at line 46 of file gvl_calc.c.

◆ IS_IN_DATA

#define IS_IN_DATA (   att)    ((isosurf->data_desc >> att) & 1)

check and set data descriptor

Definition at line 65 of file gvl_calc.c.

◆ LINTERP

#define LINTERP (   d,
  a,
  b 
)    (a + d * (b - a))

Definition at line 36 of file gvl_calc.c.

◆ READ

#define READ ( )    gvl_read_char(dbuff->ndx_old++, dbuff->old)

Definition at line 59 of file gvl_calc.c.

◆ SET_IN_DATA

#define SET_IN_DATA (   att)    isosurf->data_desc = (isosurf->data_desc | (1 << att))

Definition at line 66 of file gvl_calc.c.

◆ SKIP

#define SKIP (   n)    dbuff->ndx_old = dbuff->ndx_old + n

Definition at line 60 of file gvl_calc.c.

◆ SLICE_MODE_INTERP_NO

#define SLICE_MODE_INTERP_NO   0

Definition at line 805 of file gvl_calc.c.

◆ SLICE_MODE_INTERP_YES

#define SLICE_MODE_INTERP_YES   1

Definition at line 806 of file gvl_calc.c.

◆ TINTERP

#define TINTERP (   d,
 
)
Value:
((v[0] * (1. - d[0]) * (1. - d[1]) * (1. - d[2])) + \
(v[1] * d[0] * (1. - d[1]) * (1. - d[2])) + \
(v[2] * d[0] * d[1] * (1. - d[2])) + \
(v[3] * (1. - d[0]) * d[1] * (1. - d[2])) + \
(v[4] * (1. - d[0]) * (1. - d[1]) * d[2]) + \
(v[5] * d[0] * (1. - d[1]) * d[2]) + (v[6] * d[0] * d[1] * d[2]) + \
(v[7] * (1. - d[0]) * d[1] * d[2]))

Definition at line 37 of file gvl_calc.c.

◆ WRITE

#define WRITE (   c)    gvl_write_char(dbuff->ndx_new++, &(dbuff->new), c)

writing and reading isosurface data

Definition at line 58 of file gvl_calc.c.

Function Documentation

◆ gvl_align_data()

void gvl_align_data ( int  pos,
unsigned char **  data 
)

Append data to buffer.

Parameters
posposition index
datadata buffer

Definition at line 776 of file gvl_calc.c.

◆ gvl_isosurf_calc()

int gvl_isosurf_calc ( geovol gvol)

Fill data structure with computed isosurfaces polygons.

Parameters
gvolpointer to geovol struct
Returns
1

Definition at line 585 of file gvl_calc.c.

References x.

Referenced by gvld_vol().

◆ gvl_read_char()

unsigned char gvl_read_char ( int  pos,
const unsigned char *  data 
)

Read char.

Parameters
posposition index
datadata buffer
Returns
char on success
NULL on failure

Definition at line 762 of file gvl_calc.c.

◆ gvl_slices_calc()

int gvl_slices_calc ( geovol gvol)

Calculate slices for given volume set.

Parameters
gvolpointer to geovol struct
Returns
1

Definition at line 1034 of file gvl_calc.c.

Referenced by gvld_vol().

◆ gvl_write_char()

void gvl_write_char ( int  pos,
unsigned char **  data,
unsigned char  c 
)

ADD.

Parameters
pos
data
c

Definition at line 735 of file gvl_calc.c.

◆ iso_calc_cube()

void iso_calc_cube ( geovol_isosurf isosurf,
int  x,
int  y,
int  z,
data_buffer *  dbuff 
)

Process cube.

Parameters
isosurf
x,y,z
dbuff

Definition at line 328 of file gvl_calc.c.

◆ iso_get_cube_grads()

void iso_get_cube_grads ( geovol_isosurf isosurf,
int  x,
int  y,
int  z,
float(*)  grad[3] 
)

Calculate cube grads.

Parameters
isosurf
x,y,z
grad

Definition at line 251 of file gvl_calc.c.

References ATT_TOPO, Cols, Depths, iso_get_cube_value(), Rows, and x.

◆ iso_get_cube_value()

int iso_get_cube_value ( geovol_isosurf isosurf,
int  desc,
int  x,
int  y,
int  z,
float *  v 
)

Get value from data input.

Parameters
isosurf
desc
x,y,z
[out]value
Returns
0
?

Definition at line 161 of file gvl_calc.c.

Referenced by iso_get_cube_grads(), and iso_get_cube_values().

◆ iso_get_cube_values()

int iso_get_cube_values ( geovol_isosurf isosurf,
int  desc,
int  x,
int  y,
int  z,
float *  v 
)

Read values for cube.

Parameters
isosurf
desc
x,y,z
[out]v
Returns

Definition at line 228 of file gvl_calc.c.

References iso_get_cube_value(), and x.

◆ iso_get_range()

void iso_get_range ( geovol_isosurf isosurf,
int  desc,
double *  min,
double *  max 
)

Get volume file values range.

Parameters
isosurf
desc
[out]min
[out]max

Definition at line 212 of file gvl_calc.c.

References geovol_isosurf::att, gvl_file_get_min_max(), gvl_file_get_volfile(), geovol_isosurf_att::hfile, max, and min.

◆ iso_r_cndx()

int iso_r_cndx ( data_buffer *  dbuff)

Read cube index.

Parameters
dbuff

Definition at line 126 of file gvl_calc.c.

References READ, and WRITE.

◆ iso_w_cndx()

void iso_w_cndx ( int  ndx,
data_buffer *  dbuff 
)

Write cube index.

Parameters
ndx
dbuff

Definition at line 91 of file gvl_calc.c.

References WRITE.

◆ mc33_process_cube()

int mc33_process_cube ( int  c_ndx,
float *  v 
)

ADD.

Parameters
c_ndx
v
Returns

Definition at line 307 of file gvl_calc2.c.

References m_case.

◆ slice_calc()

int slice_calc ( geovol gvl,
int  ndx_slc,
void *  colors 
)

Calculate slices.

Parameters
gvlpointer to geovol struct
ndx_slc
colors
Returns
1

Definition at line 855 of file gvl_calc.c.

◆ slice_get_value()

float slice_get_value ( geovol gvl,
int  x,
int  y,
int  z 
)

Get volume value.

Parameters
gvlpointer to geovol struct
x,y,z
Returns
value

Definition at line 816 of file gvl_calc.c.

Variable Documentation

◆ Cols

int Cols

◆ Depths

int Depths

Definition at line 79 of file gvl_calc.c.

Referenced by alloc_vol_buff(), and iso_get_cube_grads().

◆ ResX

double ResX

Definition at line 80 of file gvl_calc.c.

◆ ResY

double ResY

Definition at line 80 of file gvl_calc.c.

◆ ResZ

double ResZ

Definition at line 80 of file gvl_calc.c.

◆ Rows

int Rows

Definition at line 79 of file gvl_calc.c.

Referenced by alloc_slice_buff(), alloc_vol_buff(), get_vol_value(), and iso_get_cube_grads().