1
/* Copyright 2010 ENSEIRB, INRIA & CNRS
3
** This file is part of the Scotch software package for static mapping,
4
** graph partitioning and sparse matrix ordering.
6
** This software is governed by the CeCILL-C license under French law
7
** and abiding by the rules of distribution of free software. You can
8
** use, modify and/or redistribute the software under the terms of the
9
** CeCILL-C license as circulated by CEA, CNRS and INRIA at the following
10
** URL: "http://www.cecill.info".
12
** As a counterpart to the access to the source code and rights to copy,
13
** modify and redistribute granted by the license, users are provided
14
** only with a limited warranty and the software's author, the holder of
15
** the economic rights, and the successive licensors have only limited
18
** In this respect, the user's attention is drawn to the risks associated
19
** with loading, using, modifying and/or developing or reproducing the
20
** software by the user in light of its specific status of free software,
21
** that may mean that it is complicated to manipulate, and that also
22
** therefore means that it is reserved for developers and experienced
23
** professionals having in-depth computer knowledge. Users are therefore
24
** encouraged to load and test the software's suitability as regards
25
** their requirements in conditions enabling the security of their
26
** systems and/or data to be ensured and, more generally, to use and
27
** operate it in the same conditions as regards security.
29
** The fact that you are presently reading this means that you have had
30
** knowledge of the CeCILL-C license and that you accept its terms.
32
/************************************************************/
34
/** NAME : dgraph_build_grid3d.h **/
36
/** AUTHOR : Francois PELLEGRINI **/
38
/** FUNCTION : This file contains the data **/
39
/** declarations for the distributed 3D **/
40
/** grid graph building routine. **/
42
/** DATES : # Version 5.1 : from : 06 jun 2010 **/
43
/** to : 04 nov 2010 **/
45
/************************************************************/
48
** The type and structure definitions.
51
/*+ The multinode table element, which contains
52
pairs of based indices of collapsed vertices.
53
Both values are equal for uncollapsed vertices. +*/
55
typedef struct DgraphBuildGrid3DData_ {
62
Gnum (* funcvrtptr) (const struct DgraphBuildGrid3DData_ * restrict const, const Gnum, Gnum, const Gnum, const Gnum, const Gnum);
63
struct { /* Pre-computed data for 26-neighbor torus */
71
} DgraphBuildGrid3DData;
74
** The function prototypes.
77
#ifndef DGRAPH_BUILD_GRID3D
81
static Gnum dgraphBuildGrid3Dvertex26M (const DgraphBuildGrid3DData * restrict const, const Gnum, Gnum, const Gnum, const Gnum, const Gnum);
82
static Gnum dgraphBuildGrid3Dvertex26T (const DgraphBuildGrid3DData * restrict const, const Gnum, Gnum, const Gnum, const Gnum, const Gnum);
83
static Gnum dgraphBuildGrid3Dvertex6M (const DgraphBuildGrid3DData * restrict const, const Gnum, Gnum, const Gnum, const Gnum, const Gnum);
84
static Gnum dgraphBuildGrid3Dvertex6T (const DgraphBuildGrid3DData * restrict const, const Gnum, Gnum, const Gnum, const Gnum, const Gnum);
89
** The macro definitions.
92
#define DGRAPHBUILDGRID3DNGB(d,v,e,x,y,z) { \
96
vertglbend = ((z) * (d)->dimyval + (y)) * (d)->dimxval + (x) + (d)->baseval; \
97
(d)->edgeloctax[edgeloctmp] = vertglbend; \
98
if ((d)->edloloctax != NULL) \
99
(d)->edloloctax[edgeloctmp] = ((vertglbend + (v)) % 16) + 1; \