#include "cs_config.h"
#include <mpi.h>
#include <omp.h>
#include <stdlib.h>
#include <sys/types.h>
Go to the source code of this file.
Data Structures | |
struct | cs_double_int_t |
struct | cs_nvec3_t |
Macros | |
#define | _LIBINTL_H |
#define | _(String) |
#define | N_(String) |
#define | textdomain(String) |
#define | gettext(String) |
#define | dgettext(Domain, String) |
#define | dcgettext(Domain, String, Type) |
#define | bindtextdomain(Domain, Directory) |
#define | MPI_VERSION 1 |
#define | __STDC_VERSION__ 1989 |
#define | inline |
#define | restrict |
#define | bool _Bool |
#define | false 0 |
#define | true 1 |
#define | __bool_true_false_are_defined 1 |
#define | CS_MPI_REAL MPI_DOUBLE /* If cs_real_t is a double */ |
#define | CS_MPI_LNUM MPI_INT |
#define | CS_MPI_EFLAG MPI_UNSIGNED /* MPI type for cs_mflag_t type */ |
#define | CS_MPI_FLAG MPI_UNSIGNED_SHORT /* MPI type for cs_flag_t type */ |
#define | CS_MPI_COORD MPI_DOUBLE /* MPI type for cs_coord_t type */ |
#define | CS_GNUM_TYPE CS_UINT64 |
#define | CS_LNUM_TYPE CS_INT32 |
#define | CS_INT_TYPE CS_INT32 |
#define | CS_UINT_TYPE CS_UINT32 |
#define | CS_FLAG_TYPE CS_UINT16 |
#define | CS_EFLAG_TYPE CS_UINT_TYPE |
#define | CS_REAL_TYPE CS_DOUBLE |
#define | CS_COORD_TYPE CS_DOUBLE |
#define | CS_THR_MIN 128 |
#define | CS_CL_SIZE 64 |
#define | CS_ABS(a) |
#define | CS_MIN(a, b) |
#define | CS_MAX(a, b) |
#define | CS_UNUSED(x) |
#define | CS_NO_WARN_IF_UNUSED(x) |
#define | BEGIN_C_DECLS |
#define | END_C_DECLS |
#define | CS_PROCF(x, y) |
#define | CS_ARGF_SUPP_CHAINE , ... |
Typedefs | |
typedef int | cs_lnum_t |
local mesh entity id | |
typedef double | cs_coord_t |
typedef double | cs_real_t |
Floating-point value. | |
typedef char | cs_byte_t |
typedef unsigned short int | cs_flag_t |
typedef cs_lnum_t | cs_lnum_2_t[2] |
vector of 2 local mesh-entity ids | |
typedef cs_lnum_t | cs_lnum_3_t[3] |
typedef cs_coord_t | cs_coord_3_t[3] |
typedef cs_real_t | cs_real_2_t[2] |
vector of 2 floating-point values | |
typedef cs_real_t | cs_real_3_t[3] |
vector of 3 floating-point values | |
typedef cs_real_t | cs_real_4_t[4] |
vector of 4 floating-point values | |
typedef cs_real_t | cs_real_6_t[6] |
vector of 6 floating-point values | |
typedef cs_real_t | cs_real_9_t[9] |
typedef cs_real_t | cs_real_10_t[10] |
typedef cs_real_t | cs_real_23_t[2][3] |
typedef cs_real_t | cs_real_33_t[3][3] |
3x3 matrix of floating-point values | |
typedef cs_real_t | cs_real_66_t[6][6] |
6x6 matrix of floating-point values | |
typedef cs_real_t | cs_real_99_t[9][9] |
typedef cs_real_t | cs_real_333_t[3][3][3] |
typedef cs_real_t | cs_real_34_t[3][4] |
typedef cs_real_t | cs_real_63_t[6][3] |
typedef cs_real_t | cs_real_69_t[6][9] |
typedef cs_real_33_t | cs_real_332_t[2] |
vector of 2 3x3 matrices of floating-point values | |
typedef cs_real_66_t | cs_real_662_t[2] |
Enumerations | |
enum | cs_datatype_t { CS_DATATYPE_NULL , CS_CHAR , CS_FLOAT , CS_DOUBLE , CS_UINT16 , CS_INT32 , CS_INT64 , CS_UINT32 , CS_UINT64 } |
enum | cs_interlace_t { CS_INTERLACE , CS_NO_INTERLACE } |
Functions | |
static cs_lnum_t | cs_align (cs_lnum_t i, cs_lnum_t m) |
Given a base index i, return the next index aligned with a size m. | |
static int | cs_get_thread_id (void) |
Retrieve the associated thread id (0 if no OpenMP or if outside an OpenMP region) |
Variables | |
const char | cs_empty_string [] |
const size_t | cs_datatype_size [] |
const char * | cs_datatype_name [] |
MPI_Datatype | cs_datatype_to_mpi [] |
int | cs_glob_n_threads |
int | cs_glob_rank_id |
int | cs_glob_n_ranks |
int | cs_glob_node_rank_id |
int | cs_glob_node_n_ranks |
MPI_Comm | cs_glob_mpi_comm |
Base macro and typedef definitions for system portability.
#define _ | ( | String | ) |
#define __bool_true_false_are_defined 1 |
#define __STDC_VERSION__ 1989 |
#define _LIBINTL_H |
#define BEGIN_C_DECLS |
#define bindtextdomain | ( | Domain, | |
Directory ) |
#define bool _Bool |
#define CS_ABS | ( | a | ) |
Absolute value of a
#define CS_ARGF_SUPP_CHAINE , ... |
#define CS_CL_SIZE 64 |
#define CS_COORD_TYPE CS_DOUBLE |
#define CS_EFLAG_TYPE CS_UINT_TYPE |
#define CS_FLAG_TYPE CS_UINT16 |
#define CS_GNUM_TYPE CS_UINT64 |
#define CS_INT_TYPE CS_INT32 |
#define CS_LNUM_TYPE CS_INT32 |
#define CS_MAX | ( | a, | |
b ) |
Maximum of a et b
#define CS_MIN | ( | a, | |
b ) |
Minimum of a et b
#define CS_MPI_COORD MPI_DOUBLE /* MPI type for cs_coord_t type */ |
#define CS_MPI_EFLAG MPI_UNSIGNED /* MPI type for cs_mflag_t type */ |
#define CS_MPI_FLAG MPI_UNSIGNED_SHORT /* MPI type for cs_flag_t type */ |
#define CS_MPI_LNUM MPI_INT |
#define CS_MPI_REAL MPI_DOUBLE /* If cs_real_t is a double */ |
#define CS_NO_WARN_IF_UNUSED | ( | x | ) |
#define CS_REAL_TYPE CS_DOUBLE |
#define CS_THR_MIN 128 |
#define CS_UINT_TYPE CS_UINT32 |
#define CS_UNUSED | ( | x | ) |
#define dcgettext | ( | Domain, | |
String, | |||
Type ) |
#define dgettext | ( | Domain, | |
String ) |
#define END_C_DECLS |
#define false 0 |
#define gettext | ( | String | ) |
#define inline |
#define MPI_VERSION 1 |
#define N_ | ( | String | ) |
#define restrict |
#define textdomain | ( | String | ) |
#define true 1 |
typedef cs_coord_t cs_coord_3_t[3] |
typedef double cs_coord_t |
typedef unsigned short int cs_flag_t |
typedef cs_lnum_t cs_lnum_2_t[2] |
vector of 2 local mesh-entity ids
typedef cs_lnum_t cs_lnum_3_t[3] |
typedef int cs_lnum_t |
local mesh entity id
Local mesh-entity ids are signed integers, and be either 0 to n-1 or 1 to n based. When 0-based, the id prefix or postfix is preferred for associated variable names, while num is preferred when 1-based. In C code, using this type is recommended over using simple int
integers, as 64-bit variants could be used in the future for shared-memory machines with large memory. This type should not be used to declare identifiers which are not mesh entities, such as groups, fields, or any other entity whose count does not depend on mesh size, so as not to pollute the readability and comprehensibility of the code.
typedef cs_real_t cs_real_10_t[10] |
typedef cs_real_t cs_real_23_t[2][3] |
typedef cs_real_t cs_real_2_t[2] |
vector of 2 floating-point values
typedef cs_real_33_t cs_real_332_t[2] |
vector of 2 3x3 matrices of floating-point values
typedef cs_real_t cs_real_333_t[3][3][3] |
typedef cs_real_t cs_real_33_t[3][3] |
3x3 matrix of floating-point values
typedef cs_real_t cs_real_34_t[3][4] |
typedef cs_real_t cs_real_3_t[3] |
vector of 3 floating-point values
typedef cs_real_t cs_real_4_t[4] |
vector of 4 floating-point values
typedef cs_real_t cs_real_63_t[6][3] |
typedef cs_real_66_t cs_real_662_t[2] |
typedef cs_real_t cs_real_66_t[6][6] |
6x6 matrix of floating-point values
typedef cs_real_t cs_real_69_t[6][9] |
typedef cs_real_t cs_real_6_t[6] |
vector of 6 floating-point values
typedef cs_real_t cs_real_99_t[9][9] |
typedef cs_real_t cs_real_9_t[9] |
typedef double cs_real_t |
Floating-point value.
enum cs_datatype_t |
enum cs_interlace_t |
Given a base index i, return the next index aligned with a size m.
[in] | i | base index |
[in] | m | block size to align with |
This index is computed as follows:
if i > 0: ((i - 1) / m + 1) * m if i = 0: 0
[in] | i | base index |
[in] | m | block size to align with |
|
inlinestatic |
Retrieve the associated thread id (0 if no OpenMP or if outside an OpenMP region)
|
extern |
|
extern |
|
extern |
|
extern |
|
extern |
|
extern |
Number of processes in communicator
|
extern |
|
extern |
Number of ranks on node of main MPI communicator
|
extern |
Rank on node in main MPI communicator
|
extern |
Rank of process in communicator