Cloned SEACAS for EXODUS library with extra build files for internal package management.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

1769 lines
76 KiB

2 years ago
/*
* Copyright(C) 1999-2020, 2022, 2023 National Technology & Engineering Solutions
* of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with
* NTESS, the U.S. Government retains certain rights in this software.
*
* See packages/seacas/LICENSE for details
*/
#include "exodusII.h"
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define EX_TEST_GOLD_FILENAME "edge-face-gold.exo"
#define EX_TEST_NO_DIFF_FILENAME "edge-face-no-diff.exo"
#define EX_TEST_EDGE_DIFF_FILENAME "edge-diff.exo"
#define EX_TEST_FACE_DIFF_FILENAME "face-diff.exo"
/* ======== Coordinates and connectivity ========= */
double coordsX[] = {0., 0., 0., 0., 3., 3., 3., 3., -3., -3., -3., -3.};
double coordsY[] = {-1., 1., 1., -1., -3., 3., 3., -3., -3., 3., 3., -3.};
double coordsZ[] = {-1., -1., 1., 1., -3., -3., 3., 3., -3., -3., 3., 3.};
const char *coordsNames[] = {"X", "Y", "Z"};
int conn1[] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 1, 2, 3, 4};
int conn2[] = {1, 2, 3, 5};
int econn1[] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 1, 2, 3, 4, 17, 18, 19, 20};
int fconn1[] = {4, 5, 7, 6, 3, 2, 8, 9, 11, 10, 1, 3};
int ebconn1[] = {1, 2, 2, 3, 3, 4, 4, 1, 5, 6, 6, 7, 7, 8, 8, 5, 1, 5, 2, 6,
4, 8, 3, 7, 9, 10, 10, 11, 11, 12, 12, 9, 9, 1, 10, 2, 12, 4, 11, 3};
int fbconn1[] = {12, 11, 10, 9, 5, 6, 7, 8};
int fbconn2[] = {1, 2, 3, 4};
int fbconn3[] = {1, 5, 6, 2, 3, 7, 8, 4, 2, 6, 7, 3, 4, 8, 5, 1,
9, 1, 2, 10, 11, 3, 4, 12, 10, 2, 3, 11, 12, 4, 1, 9};
int nmap1[] = {12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1};
int edmap1[] = {1, 3, 5, 7, 9, 11, 13, 15, 17, 19, 2, 4, 6, 8, 10, 12, 14, 16, 18, 20};
int famap1[] = {2, 1, 4, 3, 6, 5, 7, 8, 9, 10, 11};
int emap1[] = {1, 2};
const char *eblk_names[] = {"Eli_WALLACH", "Angelo_NOVI"};
const char *edblk_names[] = {"Aldo_GIUFFRE"};
const char *fablk_names[] = {"Livio_LORENZON", "Claudio_SCARCHILLI", "John_BARTHA"};
const char *nmap_names[] = {"Luigi_PISTILLI"};
const char *edmap_names[] = {"Antonio_CASALE"};
const char *famap_names[] = {"Sandro_SCARCHILLI"};
const char *emap_names[] = {"Benito_STEFANELLI"};
/* ======== Sets ========= */
int nset_nodes[] = {5, 6, 9};
int eset_edges[] = {1, 2, 4, 15, 19, 20};
int eset_orient[] = {+1, +1, +1, +1, +1, -1};
double eset_df[] = {2., 2., 0.5, 0.5, 1., 1.};
int fset_faces[] = {3, 9};
int fset_orient[] = {+1, -1};
int sset_elems[] = {1, 1, 1, 2, 2};
int sset_sides[] = {1, 3, 5, 2, 4};
int elset_elems[] = {1, 2};
const char *elset_names[] = {"Clint_EASTWOOD", "Lee_VAN_CLEEF"};
const char *nset_names[] = {"Ennio_MORRICONE"};
const char *eset_names[] = {"Rada_RASSIMOV"};
const char *fset_names[] = {"Enzo_PETITO"};
const char *sset_names[] = {"Luciano_VINCENZONI"};
/* ======== Attributes ========= */
const char *edge_attr_names1[] = {"Sergio_LEONE"};
const char *face_attr_names1[] = {"GOOD"};
const char *face_attr_names2[] = {"BAD"};
const char *face_attr_names3[] = {"UGLY"};
const char *elem_attr_names1[] = {"SPAGHETTI", "WESTERN"};
double edge_attr_values1[] = {1., 2., 3., 5., 7., 11., 13., 17., 19., 23.,
29., 31., 37., 41., 43., 47., 53., 59., 61., 67.};
double face_attr_values1[] = {71., 73.};
double face_attr_values2[] = {79.};
double face_attr_values3[] = {83., 89., 97., 101., 103., 107., 109., 113.};
double elem_attr_values1[] = {127., 101., 137., 139.};
/* ======== Results variables ========= */
/* (2 time steps) */
double vals_glo_var[2][2] = {{36., 37.}, {42., 43.}};
double vals_nod_var[2][12] = {{0.1, 0.8, 0.0, 0.4, 0.3, 0.9, 0.8, 0.5, 0.3, 0.7, 0.4, 0.6},
{0.7, 0.5, 0.3, 0.5, 0.2, 0.7, 0.9, 0.8, 0.0, 0.2, 0.3, 0.5}};
double vals_edge_var1eb1[2][20] = {
{20., 19., 18., 17., 16., 15., 14., 13., 12., 11., 10., 9., 8., 7., 6., 5., 4., 3., 2., 1.},
{21., 20., 19., 18., 17., 16., 15., 14., 13., 12., 11., 10., 9., 8., 7., 6., 5., 4., 3., 2.}};
double diff_vals_edge_var1eb1[2][20] = {
{21., 20., 19., 18., 17., 16., 15., 14., 13., 12., 11., 10., 9., 8., 7., 6., 5., 4., 3., 2.},
{20., 19., 18., 17., 16., 15., 14., 13., 12., 11., 10., 9., 8., 7., 6., 5., 4., 3., 2., 1.}};
double vals_edge_var2eb1[2][20] = {
{1., 1., 0., 0., 1., 1., 2., 0., 2., 0., 1., 1., 1., 1., 0., 0., 2., 2., 2., 2.},
{1., 1., 0., 0., 1., 1., 2., 0., 2., 0., 1., 1., 1., 1., 0., 0., 2., 2., 2., 2.}};
double vals_face_var1fb1[2][2] = {{0, 1}, {2, 0}};
double diff_vals_face_var1fb1[2][2] = {{2, 0}, {0, 1}};
double vals_face_var1fb3[2][8] = {{1, 0, 2, 0, 3, 0, 4, 0}, {0, 1, 0, 2, 0, 3, 0, 4}};
double vals_elem_var1eb1[2][2] = {{8, 8}, {0, -8}};
double vals_fset_var1fs1[2][2] = {{1., 3.}, {9., 27.}};
#define EXCHECK(funcall, errmsg) \
do { \
if ((funcall) < 0) { \
fprintf(stderr, errmsg); \
free(varParams.edge_var_tab); \
free(varParams.face_var_tab); \
free(varParams.elem_var_tab); \
free(varParams.fset_var_tab); \
return 1; \
} \
} while (0)
int ex_have_arg(int argc, char *argv[], const char *aname)
{
int i;
for (i = 0; i < argc; ++i) {
if (!strcmp(argv[i], aname)) {
return 1;
}
}
return 0;
}
int create_gold_file(int argc, char *argv[])
{
int exoid;
int appWordSize = 8;
int diskWordSize = 8;
/* int concatBlocks = ex_have_arg( argc, argv, "-pcab" ); */
int concatSets = ex_have_arg(argc, argv, "-pcset");
int concatResult = ex_have_arg(argc, argv, "-pvpax");
double t;
ex_init_params modelParams = {
"CreateEdgeFace Test", /* title */
3, /* num_dim */
12, /* num_nodes */
20, /* num_edge */
1, /* num_edge_blk */
11, /* num_face */
3, /* num_face_blk */
3, /* num_elem */
2, /* num_elem_blk */
1, /* num_node_sets */
1, /* num_edge_sets */
1, /* num_face_sets */
1, /* num_side_sets */
2, /* num_elem_sets */
1, /* num_node_map */
1, /* num_edge_map */
1, /* num_face_map */
1, /* num_elem_map */
};
ex_block edgeBlocks[1];
ex_block faceBlocks[3];
ex_block elemBlocks[2];
ex_var_params varParams;
ex_opts(EX_VERBOSE | EX_ABORT);
exoid = ex_create(EX_TEST_GOLD_FILENAME, EX_CLOBBER, &appWordSize, &diskWordSize);
if (exoid <= 0) {
fprintf(stderr, "Unable to open \"%s\" for writing.\n", EX_TEST_GOLD_FILENAME);
return 1;
}
edgeBlocks[0].type = EX_EDGE_BLOCK;
edgeBlocks[0].id = 100;
edgeBlocks[0].num_entry = 20;
edgeBlocks[0].num_nodes_per_entry = 2;
edgeBlocks[0].num_attribute = 1;
ex_copy_string(edgeBlocks[0].topology, "EDGE2", MAX_STR_LENGTH + 1);
faceBlocks[0].type = EX_FACE_BLOCK;
faceBlocks[0].id = 500;
faceBlocks[0].num_entry = 2;
faceBlocks[0].num_nodes_per_entry = 4;
faceBlocks[0].num_attribute = 1;
ex_copy_string(faceBlocks[0].topology, "QUAD4", MAX_STR_LENGTH + 1);
faceBlocks[1].type = EX_FACE_BLOCK;
faceBlocks[1].id = 600;
faceBlocks[1].num_entry = 1;
faceBlocks[1].num_nodes_per_entry = 4;
faceBlocks[1].num_attribute = 1;
ex_copy_string(faceBlocks[1].topology, "QUAD4", MAX_STR_LENGTH + 1);
faceBlocks[2].type = EX_FACE_BLOCK;
faceBlocks[2].id = 700;
faceBlocks[2].num_entry = 8;
faceBlocks[2].num_nodes_per_entry = 4;
faceBlocks[2].num_attribute = 1;
ex_copy_string(faceBlocks[2].topology, "QUAD4", MAX_STR_LENGTH + 1);
elemBlocks[0].type = EX_ELEM_BLOCK;
elemBlocks[0].id = 200;
elemBlocks[0].num_entry = 2;
elemBlocks[0].num_nodes_per_entry = 8;
elemBlocks[0].num_edges_per_entry = 12;
elemBlocks[0].num_faces_per_entry = 6;
elemBlocks[0].num_attribute = 2;
ex_copy_string(elemBlocks[0].topology, "HEX8", MAX_STR_LENGTH + 1);
elemBlocks[1].type = EX_ELEM_BLOCK;
elemBlocks[1].id = 201;
elemBlocks[1].num_entry = 1;
elemBlocks[1].num_nodes_per_entry = 4;
elemBlocks[1].num_edges_per_entry = 0;
elemBlocks[1].num_faces_per_entry = 0;
elemBlocks[1].num_attribute = 0;
ex_copy_string(elemBlocks[1].topology, "TET4", MAX_STR_LENGTH + 1);
varParams.edge_var_tab = (int *)malloc(2 * sizeof(int));
varParams.face_var_tab = (int *)malloc(3 * sizeof(int));
varParams.elem_var_tab = (int *)malloc(2 * sizeof(int));
varParams.nset_var_tab = NULL;
varParams.eset_var_tab = NULL;
varParams.fset_var_tab = (int *)malloc(1 * sizeof(int));
varParams.sset_var_tab = NULL;
varParams.elset_var_tab = NULL;
varParams.num_glob = 2;
varParams.num_node = 1;
varParams.num_edge = 2;
varParams.edge_var_tab[0] = 1;
varParams.edge_var_tab[1] = 1;
varParams.num_face = 1;
varParams.face_var_tab[0] = 1;
varParams.face_var_tab[1] = 1;
varParams.face_var_tab[2] = 1;
varParams.num_elem = 1;
varParams.elem_var_tab[0] = 1;
varParams.elem_var_tab[1] = 0;
varParams.num_nset = 0;
varParams.num_eset = 0;
varParams.num_fset = 1;
varParams.fset_var_tab[0] = 1;
varParams.num_sset = 0;
varParams.num_elset = 0;
EXCHECK(ex_put_init_ext(exoid, &modelParams), "Unable to initialize database.\n");
{
int blk;
for (blk = 0; blk < modelParams.num_edge_blk; ++blk) {
EXCHECK(ex_put_block_param(exoid, edgeBlocks[blk]), "Unable to write edge block");
}
for (blk = 0; blk < modelParams.num_face_blk; ++blk) {
EXCHECK(ex_put_block_param(exoid, faceBlocks[blk]), "Unable to write face block");
}
for (blk = 0; blk < modelParams.num_elem_blk; ++blk) {
EXCHECK(ex_put_block_param(exoid, elemBlocks[blk]), "Unable to write elem block");
}
}
EXCHECK(ex_put_coord(exoid, (void *)coordsX, (void *)coordsY, (void *)coordsZ),
"Unable to write coordinates.\n");
EXCHECK(ex_put_coord_names(exoid, (char **)coordsNames), "Unable to write coordinate names.\n");
/* =============== Connectivity ================== */
/* *** NEW API *** */
EXCHECK(ex_put_conn(exoid, EX_EDGE_BLOCK, edgeBlocks[0].id, ebconn1, 0, 0),
"Unable to write edge block connectivity.\n");
/* *** NEW API *** */
EXCHECK(ex_put_conn(exoid, EX_FACE_BLOCK, faceBlocks[0].id, fbconn1, 0, 0),
"Unable to write face block 1 connectivity.\n");
EXCHECK(ex_put_conn(exoid, EX_FACE_BLOCK, faceBlocks[1].id, fbconn2, 0, 0),
"Unable to write face block 2 connectivity.\n");
EXCHECK(ex_put_conn(exoid, EX_FACE_BLOCK, faceBlocks[2].id, fbconn3, 0, 0),
"Unable to write face block 3 connectivity.\n");
/* *** NEW API *** */
EXCHECK(ex_put_conn(exoid, EX_ELEM_BLOCK, elemBlocks[0].id, conn1, econn1, fconn1),
"Unable to write elem block 1 connectivity.\n");
/* *** NEW API *** */
EXCHECK(ex_put_conn(exoid, EX_ELEM_BLOCK, elemBlocks[1].id, conn2, 0, 0),
"Unable to write elem block 2 connectivity.\n");
/* *** NEW API *** */
EXCHECK(ex_put_names(exoid, EX_EDGE_BLOCK, (char **)edblk_names),
"Unable to write edge block names.\n");
EXCHECK(ex_put_names(exoid, EX_FACE_BLOCK, (char **)fablk_names),
"Unable to write face block names.\n");
EXCHECK(ex_put_names(exoid, EX_ELEM_BLOCK, (char **)eblk_names),
"Unable to write element block names.\n");
/* =============== Number Maps ================== */
/* *** NEW API *** */
EXCHECK(ex_put_num_map(exoid, EX_NODE_MAP, 300, nmap1), "Unable to write node map.\n");
EXCHECK(ex_put_num_map(exoid, EX_EDGE_MAP, 800, edmap1), "Unable to write edge map.\n");
EXCHECK(ex_put_num_map(exoid, EX_FACE_MAP, 900, famap1), "Unable to write face map.\n");
EXCHECK(ex_put_num_map(exoid, EX_ELEM_MAP, 400, emap1), "Unable to write element map.\n");
/* *** NEW API *** */
EXCHECK(ex_put_names(exoid, EX_NODE_MAP, (char **)nmap_names),
"Unable to write node map names.\n");
EXCHECK(ex_put_names(exoid, EX_EDGE_MAP, (char **)edmap_names),
"Unable to write edge map names.\n");
EXCHECK(ex_put_names(exoid, EX_FACE_MAP, (char **)famap_names),
"Unable to write face map names.\n");
EXCHECK(ex_put_names(exoid, EX_ELEM_MAP, (char **)emap_names),
"Unable to write element map names.\n");
/* =============== Attribute names ================ */
/* *** NEW API *** */
EXCHECK(ex_put_attr_names(exoid, EX_EDGE_BLOCK, edgeBlocks[0].id, (char **)edge_attr_names1),
"Unable to write edge block 1 attribute names.\n");
/* *** NEW API *** */
EXCHECK(ex_put_attr_names(exoid, EX_FACE_BLOCK, faceBlocks[0].id, (char **)face_attr_names1),
"Unable to write face block 1 attribute names.\n");
EXCHECK(ex_put_attr_names(exoid, EX_FACE_BLOCK, faceBlocks[1].id, (char **)face_attr_names2),
"Unable to write face block 1 attribute names.\n");
EXCHECK(ex_put_attr_names(exoid, EX_FACE_BLOCK, faceBlocks[2].id, (char **)face_attr_names3),
"Unable to write face block 1 attribute names.\n");
/* *** NEW API *** */
EXCHECK(ex_put_attr_names(exoid, EX_ELEM_BLOCK, elemBlocks[0].id, (char **)elem_attr_names1),
"Unable to write elem block 1 attribute names.\n");
/* =============== Attribute values =============== */
/* *** NEW API *** */
EXCHECK(ex_put_attr(exoid, EX_EDGE_BLOCK, edgeBlocks[0].id, edge_attr_values1),
"Unable to write edge block 1 attribute values.\n");
/* *** NEW API *** */
EXCHECK(ex_put_attr(exoid, EX_FACE_BLOCK, faceBlocks[0].id, face_attr_values1),
"Unable to write face block 1 attribute values.\n");
EXCHECK(ex_put_attr(exoid, EX_FACE_BLOCK, faceBlocks[1].id, face_attr_values2),
"Unable to write face block 1 attribute values.\n");
EXCHECK(ex_put_attr(exoid, EX_FACE_BLOCK, faceBlocks[2].id, face_attr_values3),
"Unable to write face block 1 attribute values.\n");
/* *** NEW API *** */
EXCHECK(ex_put_attr(exoid, EX_ELEM_BLOCK, elemBlocks[0].id, elem_attr_values1),
"Unable to write elem block 1 attribute values.\n");
/* =============== Set parameters ================= */
/* *** NEW API *** */
EXCHECK(ex_put_names(exoid, EX_NODE_SET, (char **)nset_names),
"Unable to write node set names.\n");
EXCHECK(ex_put_names(exoid, EX_EDGE_SET, (char **)eset_names),
"Unable to write edge set names.\n");
EXCHECK(ex_put_names(exoid, EX_FACE_SET, (char **)fset_names),
"Unable to write face set names.\n");
EXCHECK(ex_put_names(exoid, EX_SIDE_SET, (char **)sset_names),
"Unable to write side set names.\n");
EXCHECK(ex_put_names(exoid, EX_ELEM_SET, (char **)elset_names),
"Unable to write element set names.\n");
{
ex_set allSets[1 + 1 + 1 + 1 + 2];
ex_set *nodeSets = &allSets[0];
ex_set *edgeSets = &allSets[1];
ex_set *faceSets = &allSets[2];
ex_set *sideSets = &allSets[3];
ex_set *elemSets = &allSets[4];
nodeSets[0].type = EX_NODE_SET;
nodeSets[0].id = 1000;
nodeSets[0].num_entry = 3;
nodeSets[0].num_distribution_factor = 0;
nodeSets[0].entry_list = nset_nodes;
nodeSets[0].extra_list = NULL;
nodeSets[0].distribution_factor_list = NULL;
edgeSets[0].type = EX_EDGE_SET;
edgeSets[0].id = 1200;
edgeSets[0].num_entry = 6;
edgeSets[0].num_distribution_factor = 6;
edgeSets[0].entry_list = eset_edges;
edgeSets[0].extra_list = eset_orient;
edgeSets[0].distribution_factor_list = eset_df;
faceSets[0].type = EX_FACE_SET;
faceSets[0].id = 1400;
faceSets[0].num_entry = 2;
faceSets[0].num_distribution_factor = 0;
faceSets[0].entry_list = fset_faces;
faceSets[0].extra_list = fset_orient;
faceSets[0].distribution_factor_list = NULL;
sideSets[0].type = EX_SIDE_SET;
sideSets[0].id = 1400;
sideSets[0].num_entry = 5;
sideSets[0].num_distribution_factor = 0;
sideSets[0].entry_list = sset_elems;
sideSets[0].extra_list = sset_sides;
sideSets[0].distribution_factor_list = NULL;
elemSets[0].type = EX_ELEM_SET;
elemSets[0].id = 1800;
elemSets[0].num_entry = 1;
elemSets[0].num_distribution_factor = 0;
elemSets[0].entry_list = &elset_elems[0];
elemSets[0].extra_list = NULL;
elemSets[0].distribution_factor_list = NULL;
elemSets[1].type = EX_ELEM_SET;
elemSets[1].id = 1900;
elemSets[1].num_entry = 1;
elemSets[1].num_distribution_factor = 0;
elemSets[1].entry_list = &elset_elems[1];
elemSets[1].extra_list = NULL;
elemSets[1].distribution_factor_list = NULL;
if (concatSets) {
EXCHECK(ex_put_sets(exoid, 1 + 2 + 1 + 1 + 1, allSets),
"Unable to output concatenated sets.\n");
}
else {
EXCHECK(ex_put_sets(exoid, 1, nodeSets), "Unable to write node sets.\n");
EXCHECK(ex_put_sets(exoid, 1, edgeSets), "Unable to write edge sets.\n");
EXCHECK(ex_put_sets(exoid, 1, faceSets), "Unable to write face sets.\n");
EXCHECK(ex_put_sets(exoid, 1, sideSets), "Unable to write side sets.\n");
EXCHECK(ex_put_sets(exoid, 2, elemSets), "Unable to write element sets.\n");
}
}
/* =============== Result variable params ========= */
/* *** NEW API *** */
if (concatResult) {
EXCHECK(ex_put_all_var_param_ext(exoid, &varParams),
"Unable to write result variable parameter information.\n");
}
else {
EXCHECK(ex_put_variable_param(exoid, EX_GLOBAL, 2),
"Unable to write global result variable parameters.\n");
EXCHECK(ex_put_variable_param(exoid, EX_NODAL, 1),
"Unable to write nodal result variable parameters.\n");
EXCHECK(ex_put_variable_param(exoid, EX_ELEM_BLOCK, 1),
"Unable to write element result variable parameters.\n");
EXCHECK(ex_put_variable_param(exoid, EX_EDGE_BLOCK, 2),
"Unable to write edge result variable parameters.\n");
// EXCHECK(ex_put_variable_param(exoid, EX_FACE_BLOCK, 2),
// "Unable to write face result variable parameters.\n");
EXCHECK(ex_put_variable_param(exoid, EX_FACE_BLOCK, 1),
"Unable to write face result variable parameters.\n");
EXCHECK(ex_put_variable_param(exoid, EX_FACE_SET, 1),
"Unable to write faceset result variable parameters.\n");
}
/* =============== Result variable names ========== */
/* *** NEW API *** */
EXCHECK(ex_put_variable_name(exoid, EX_GLOBAL, 1, "CALIBER"), "Unable to write variable name.\n");
EXCHECK(ex_put_variable_name(exoid, EX_GLOBAL, 2, "GUNPOWDER"),
"Unable to write variable name.\n");
EXCHECK(ex_put_variable_name(exoid, EX_NODAL, 1, "RHO"), "Unable to write variable name.\n");
EXCHECK(ex_put_variable_name(exoid, EX_EDGE_BLOCK, 1, "GAMMA1"),
"Unable to write variable name.\n");
EXCHECK(ex_put_variable_name(exoid, EX_EDGE_BLOCK, 2, "GAMMA2"),
"Unable to write variable name.\n");
EXCHECK(ex_put_variable_name(exoid, EX_FACE_BLOCK, 1, "PHI"), "Unable to write variable name.\n");
// EXCHECK(ex_put_variable_name(exoid, EX_FACE_BLOCK, 2, "PHI"), "Unable to write variable
// name.\n");
EXCHECK(ex_put_variable_name(exoid, EX_ELEM_BLOCK, 1, "EPSTRN"),
"Unable to write variable name.\n");
EXCHECK(ex_put_variable_name(exoid, EX_FACE_SET, 1, "PHI0"), "Unable to write variable name.\n");
/* =============== Result variable values ========= */
t = 1.;
/* *** NEW API *** */
EXCHECK(ex_put_time(exoid, 1, &t), "Unable to write time value.\n");
EXCHECK(ex_put_var(exoid, 1, EX_GLOBAL, 1, 0 /*N/A*/, 2, vals_glo_var[0]),
"Unable to write global var 1.\n");
EXCHECK(ex_put_var(exoid, 1, EX_EDGE_BLOCK, 1, 100, 20, vals_edge_var1eb1[0]),
"Unable to write edge block 1 var 1.\n");
EXCHECK(ex_put_var(exoid, 1, EX_EDGE_BLOCK, 2, 100, 20, vals_edge_var2eb1[0]),
"Unable to write edge block 1 var 2.\n");
EXCHECK(ex_put_var(exoid, 1, EX_FACE_BLOCK, 1, 500, 2, vals_face_var1fb1[0]),
"Unable to write face block 1 var 1.\n");
// EXCHECK(ex_put_var(exoid, 1, EX_FACE_BLOCK, 2, 700, 8, vals_face_var1fb3[0]),
// "Unable to write face block 3 var 1.\n");
EXCHECK(ex_put_var(exoid, 1, EX_FACE_BLOCK, 1, 700, 8, vals_face_var1fb3[0]),
"Unable to write face block 3 var 1.\n");
EXCHECK(ex_put_var(exoid, 1, EX_ELEM_BLOCK, 1, 200, 2, vals_elem_var1eb1[0]),
"Unable to write elem block 1 var 1.\n");
EXCHECK(ex_put_var(exoid, 1, EX_FACE_SET, 1, 1400, 2, vals_fset_var1fs1[0]),
"Unable to write face set 1 var 1.\n");
t = 2.;
EXCHECK(ex_put_time(exoid, 2, &t), "Unable to write time value.\n");
EXCHECK(ex_put_var(exoid, 2, EX_GLOBAL, 1, 0 /*N/A*/, 2, vals_glo_var[1]),
"Unable to write global var 1.\n");
EXCHECK(ex_put_var(exoid, 2, EX_EDGE_BLOCK, 1, 100, 20, vals_edge_var1eb1[1]),
"Unable to write edge block 1 var 1.\n");
EXCHECK(ex_put_var(exoid, 2, EX_EDGE_BLOCK, 2, 100, 20, vals_edge_var2eb1[1]),
"Unable to write edge block 1 var 2.\n");
EXCHECK(ex_put_var(exoid, 2, EX_FACE_BLOCK, 1, 500, 2, vals_face_var1fb1[1]),
"Unable to write face block 1 var 1.\n");
// EXCHECK(ex_put_var(exoid, 2, EX_FACE_BLOCK, 2, 700, 8, vals_face_var1fb3[1]),
// "Unable to write face block 3 var 1.\n");
EXCHECK(ex_put_var(exoid, 2, EX_FACE_BLOCK, 1, 700, 8, vals_face_var1fb3[1]),
"Unable to write face block 3 var 1.\n");
EXCHECK(ex_put_var(exoid, 2, EX_ELEM_BLOCK, 1, 200, 2, vals_elem_var1eb1[1]),
"Unable to write elem block 1 var 1.\n");
EXCHECK(ex_put_var(exoid, 2, EX_FACE_SET, 1, 1400, 2, vals_fset_var1fs1[1]),
"Unable to write face set 1 var 1.\n");
EXCHECK(ex_put_var(exoid, 1, EX_NODAL, 1, 1, 12, vals_nod_var[0]),
"Unable to write nodal var 1.\n");
EXCHECK(ex_put_var(exoid, 2, EX_NODAL, 1, 1, 12, vals_nod_var[1]),
"Unable to write nodal var 1.\n");
EXCHECK(ex_close(exoid), "Unable to close database.\n");
free(varParams.edge_var_tab);
free(varParams.face_var_tab);
free(varParams.elem_var_tab);
free(varParams.fset_var_tab);
return 0;
}
int create_no_diff_file(int argc, char *argv[])
{
int exoid;
int appWordSize = 8;
int diskWordSize = 8;
/* int concatBlocks = ex_have_arg( argc, argv, "-pcab" ); */
int concatSets = ex_have_arg(argc, argv, "-pcset");
int concatResult = ex_have_arg(argc, argv, "-pvpax");
double t;
ex_init_params modelParams = {
"CreateEdgeFace Test", /* title */
3, /* num_dim */
12, /* num_nodes */
20, /* num_edge */
1, /* num_edge_blk */
11, /* num_face */
3, /* num_face_blk */
3, /* num_elem */
2, /* num_elem_blk */
1, /* num_node_sets */
1, /* num_edge_sets */
1, /* num_face_sets */
1, /* num_side_sets */
2, /* num_elem_sets */
1, /* num_node_map */
1, /* num_edge_map */
1, /* num_face_map */
1, /* num_elem_map */
};
ex_block edgeBlocks[1];
ex_block faceBlocks[3];
ex_block elemBlocks[2];
ex_var_params varParams;
ex_opts(EX_VERBOSE | EX_ABORT);
exoid = ex_create(EX_TEST_NO_DIFF_FILENAME, EX_CLOBBER, &appWordSize, &diskWordSize);
if (exoid <= 0) {
fprintf(stderr, "Unable to open \"%s\" for writing.\n", EX_TEST_NO_DIFF_FILENAME);
return 1;
}
edgeBlocks[0].type = EX_EDGE_BLOCK;
edgeBlocks[0].id = 100;
edgeBlocks[0].num_entry = 20;
edgeBlocks[0].num_nodes_per_entry = 2;
edgeBlocks[0].num_attribute = 1;
ex_copy_string(edgeBlocks[0].topology, "EDGE2", MAX_STR_LENGTH + 1);
faceBlocks[0].type = EX_FACE_BLOCK;
faceBlocks[0].id = 500;
faceBlocks[0].num_entry = 2;
faceBlocks[0].num_nodes_per_entry = 4;
faceBlocks[0].num_attribute = 1;
ex_copy_string(faceBlocks[0].topology, "QUAD4", MAX_STR_LENGTH + 1);
faceBlocks[1].type = EX_FACE_BLOCK;
faceBlocks[1].id = 600;
faceBlocks[1].num_entry = 1;
faceBlocks[1].num_nodes_per_entry = 4;
faceBlocks[1].num_attribute = 1;
ex_copy_string(faceBlocks[1].topology, "QUAD4", MAX_STR_LENGTH + 1);
faceBlocks[2].type = EX_FACE_BLOCK;
faceBlocks[2].id = 700;
faceBlocks[2].num_entry = 8;
faceBlocks[2].num_nodes_per_entry = 4;
faceBlocks[2].num_attribute = 1;
ex_copy_string(faceBlocks[2].topology, "QUAD4", MAX_STR_LENGTH + 1);
elemBlocks[0].type = EX_ELEM_BLOCK;
elemBlocks[0].id = 200;
elemBlocks[0].num_entry = 2;
elemBlocks[0].num_nodes_per_entry = 8;
elemBlocks[0].num_edges_per_entry = 12;
elemBlocks[0].num_faces_per_entry = 6;
elemBlocks[0].num_attribute = 2;
ex_copy_string(elemBlocks[0].topology, "HEX8", MAX_STR_LENGTH + 1);
elemBlocks[1].type = EX_ELEM_BLOCK;
elemBlocks[1].id = 201;
elemBlocks[1].num_entry = 1;
elemBlocks[1].num_nodes_per_entry = 4;
elemBlocks[1].num_edges_per_entry = 0;
elemBlocks[1].num_faces_per_entry = 0;
elemBlocks[1].num_attribute = 0;
ex_copy_string(elemBlocks[1].topology, "TET4", MAX_STR_LENGTH + 1);
varParams.edge_var_tab = (int *)malloc(2 * sizeof(int));
varParams.face_var_tab = (int *)malloc(3 * sizeof(int));
varParams.elem_var_tab = (int *)malloc(2 * sizeof(int));
varParams.nset_var_tab = NULL;
varParams.eset_var_tab = NULL;
varParams.fset_var_tab = (int *)malloc(1 * sizeof(int));
varParams.sset_var_tab = NULL;
varParams.elset_var_tab = NULL;
varParams.num_glob = 2;
varParams.num_node = 1;
varParams.num_edge = 2;
varParams.edge_var_tab[0] = 1;
varParams.edge_var_tab[1] = 1;
varParams.num_face = 1;
varParams.face_var_tab[0] = 1;
varParams.face_var_tab[1] = 1;
varParams.face_var_tab[2] = 1;
varParams.num_elem = 1;
varParams.elem_var_tab[0] = 1;
varParams.elem_var_tab[1] = 0;
varParams.num_nset = 0;
varParams.num_eset = 0;
varParams.num_fset = 1;
varParams.fset_var_tab[0] = 1;
varParams.num_sset = 0;
varParams.num_elset = 0;
EXCHECK(ex_put_init_ext(exoid, &modelParams), "Unable to initialize database.\n");
{
int blk;
for (blk = 0; blk < modelParams.num_edge_blk; ++blk) {
EXCHECK(ex_put_block_param(exoid, edgeBlocks[blk]), "Unable to write edge block");
}
for (blk = 0; blk < modelParams.num_face_blk; ++blk) {
EXCHECK(ex_put_block_param(exoid, faceBlocks[blk]), "Unable to write face block");
}
for (blk = 0; blk < modelParams.num_elem_blk; ++blk) {
EXCHECK(ex_put_block_param(exoid, elemBlocks[blk]), "Unable to write elem block");
}
}
EXCHECK(ex_put_coord(exoid, (void *)coordsX, (void *)coordsY, (void *)coordsZ),
"Unable to write coordinates.\n");
EXCHECK(ex_put_coord_names(exoid, (char **)coordsNames), "Unable to write coordinate names.\n");
/* =============== Connectivity ================== */
/* *** NEW API *** */
EXCHECK(ex_put_conn(exoid, EX_EDGE_BLOCK, edgeBlocks[0].id, ebconn1, 0, 0),
"Unable to write edge block connectivity.\n");
/* *** NEW API *** */
EXCHECK(ex_put_conn(exoid, EX_FACE_BLOCK, faceBlocks[0].id, fbconn1, 0, 0),
"Unable to write face block 1 connectivity.\n");
EXCHECK(ex_put_conn(exoid, EX_FACE_BLOCK, faceBlocks[1].id, fbconn2, 0, 0),
"Unable to write face block 2 connectivity.\n");
EXCHECK(ex_put_conn(exoid, EX_FACE_BLOCK, faceBlocks[2].id, fbconn3, 0, 0),
"Unable to write face block 3 connectivity.\n");
/* *** NEW API *** */
EXCHECK(ex_put_conn(exoid, EX_ELEM_BLOCK, elemBlocks[0].id, conn1, econn1, fconn1),
"Unable to write elem block 1 connectivity.\n");
/* *** NEW API *** */
EXCHECK(ex_put_conn(exoid, EX_ELEM_BLOCK, elemBlocks[1].id, conn2, 0, 0),
"Unable to write elem block 2 connectivity.\n");
/* *** NEW API *** */
EXCHECK(ex_put_names(exoid, EX_EDGE_BLOCK, (char **)edblk_names),
"Unable to write edge block names.\n");
EXCHECK(ex_put_names(exoid, EX_FACE_BLOCK, (char **)fablk_names),
"Unable to write face block names.\n");
EXCHECK(ex_put_names(exoid, EX_ELEM_BLOCK, (char **)eblk_names),
"Unable to write element block names.\n");
/* =============== Number Maps ================== */
/* *** NEW API *** */
EXCHECK(ex_put_num_map(exoid, EX_NODE_MAP, 300, nmap1), "Unable to write node map.\n");
EXCHECK(ex_put_num_map(exoid, EX_EDGE_MAP, 800, edmap1), "Unable to write edge map.\n");
EXCHECK(ex_put_num_map(exoid, EX_FACE_MAP, 900, famap1), "Unable to write face map.\n");
EXCHECK(ex_put_num_map(exoid, EX_ELEM_MAP, 400, emap1), "Unable to write element map.\n");
/* *** NEW API *** */
EXCHECK(ex_put_names(exoid, EX_NODE_MAP, (char **)nmap_names),
"Unable to write node map names.\n");
EXCHECK(ex_put_names(exoid, EX_EDGE_MAP, (char **)edmap_names),
"Unable to write edge map names.\n");
EXCHECK(ex_put_names(exoid, EX_FACE_MAP, (char **)famap_names),
"Unable to write face map names.\n");
EXCHECK(ex_put_names(exoid, EX_ELEM_MAP, (char **)emap_names),
"Unable to write element map names.\n");
/* =============== Attribute names ================ */
/* *** NEW API *** */
EXCHECK(ex_put_attr_names(exoid, EX_EDGE_BLOCK, edgeBlocks[0].id, (char **)edge_attr_names1),
"Unable to write edge block 1 attribute names.\n");
/* *** NEW API *** */
EXCHECK(ex_put_attr_names(exoid, EX_FACE_BLOCK, faceBlocks[0].id, (char **)face_attr_names1),
"Unable to write face block 1 attribute names.\n");
EXCHECK(ex_put_attr_names(exoid, EX_FACE_BLOCK, faceBlocks[1].id, (char **)face_attr_names2),
"Unable to write face block 1 attribute names.\n");
EXCHECK(ex_put_attr_names(exoid, EX_FACE_BLOCK, faceBlocks[2].id, (char **)face_attr_names3),
"Unable to write face block 1 attribute names.\n");
/* *** NEW API *** */
EXCHECK(ex_put_attr_names(exoid, EX_ELEM_BLOCK, elemBlocks[0].id, (char **)elem_attr_names1),
"Unable to write elem block 1 attribute names.\n");
/* =============== Attribute values =============== */
/* *** NEW API *** */
EXCHECK(ex_put_attr(exoid, EX_EDGE_BLOCK, edgeBlocks[0].id, edge_attr_values1),
"Unable to write edge block 1 attribute values.\n");
/* *** NEW API *** */
EXCHECK(ex_put_attr(exoid, EX_FACE_BLOCK, faceBlocks[0].id, face_attr_values1),
"Unable to write face block 1 attribute values.\n");
EXCHECK(ex_put_attr(exoid, EX_FACE_BLOCK, faceBlocks[1].id, face_attr_values2),
"Unable to write face block 1 attribute values.\n");
EXCHECK(ex_put_attr(exoid, EX_FACE_BLOCK, faceBlocks[2].id, face_attr_values3),
"Unable to write face block 1 attribute values.\n");
/* *** NEW API *** */
EXCHECK(ex_put_attr(exoid, EX_ELEM_BLOCK, elemBlocks[0].id, elem_attr_values1),
"Unable to write elem block 1 attribute values.\n");
/* =============== Set parameters ================= */
/* *** NEW API *** */
EXCHECK(ex_put_names(exoid, EX_NODE_SET, (char **)nset_names),
"Unable to write node set names.\n");
EXCHECK(ex_put_names(exoid, EX_EDGE_SET, (char **)eset_names),
"Unable to write edge set names.\n");
EXCHECK(ex_put_names(exoid, EX_FACE_SET, (char **)fset_names),
"Unable to write face set names.\n");
EXCHECK(ex_put_names(exoid, EX_SIDE_SET, (char **)sset_names),
"Unable to write side set names.\n");
EXCHECK(ex_put_names(exoid, EX_ELEM_SET, (char **)elset_names),
"Unable to write element set names.\n");
{
ex_set allSets[1 + 1 + 1 + 1 + 2];
ex_set *nodeSets = &allSets[0];
ex_set *edgeSets = &allSets[1];
ex_set *faceSets = &allSets[2];
ex_set *sideSets = &allSets[3];
ex_set *elemSets = &allSets[4];
nodeSets[0].type = EX_NODE_SET;
nodeSets[0].id = 1000;
nodeSets[0].num_entry = 3;
nodeSets[0].num_distribution_factor = 0;
nodeSets[0].entry_list = nset_nodes;
nodeSets[0].extra_list = NULL;
nodeSets[0].distribution_factor_list = NULL;
edgeSets[0].type = EX_EDGE_SET;
edgeSets[0].id = 1200;
edgeSets[0].num_entry = 6;
edgeSets[0].num_distribution_factor = 6;
edgeSets[0].entry_list = eset_edges;
edgeSets[0].extra_list = eset_orient;
edgeSets[0].distribution_factor_list = eset_df;
faceSets[0].type = EX_FACE_SET;
faceSets[0].id = 1400;
faceSets[0].num_entry = 2;
faceSets[0].num_distribution_factor = 0;
faceSets[0].entry_list = fset_faces;
faceSets[0].extra_list = fset_orient;
faceSets[0].distribution_factor_list = NULL;
sideSets[0].type = EX_SIDE_SET;
sideSets[0].id = 1400;
sideSets[0].num_entry = 5;
sideSets[0].num_distribution_factor = 0;
sideSets[0].entry_list = sset_elems;
sideSets[0].extra_list = sset_sides;
sideSets[0].distribution_factor_list = NULL;
elemSets[0].type = EX_ELEM_SET;
elemSets[0].id = 1800;
elemSets[0].num_entry = 1;
elemSets[0].num_distribution_factor = 0;
elemSets[0].entry_list = &elset_elems[0];
elemSets[0].extra_list = NULL;
elemSets[0].distribution_factor_list = NULL;
elemSets[1].type = EX_ELEM_SET;
elemSets[1].id = 1900;
elemSets[1].num_entry = 1;
elemSets[1].num_distribution_factor = 0;
elemSets[1].entry_list = &elset_elems[1];
elemSets[1].extra_list = NULL;
elemSets[1].distribution_factor_list = NULL;
if (concatSets) {
EXCHECK(ex_put_sets(exoid, 1 + 2 + 1 + 1 + 1, allSets),
"Unable to output concatenated sets.\n");
}
else {
EXCHECK(ex_put_sets(exoid, 1, nodeSets), "Unable to write node sets.\n");
EXCHECK(ex_put_sets(exoid, 1, edgeSets), "Unable to write edge sets.\n");
EXCHECK(ex_put_sets(exoid, 1, faceSets), "Unable to write face sets.\n");
EXCHECK(ex_put_sets(exoid, 1, sideSets), "Unable to write side sets.\n");
EXCHECK(ex_put_sets(exoid, 2, elemSets), "Unable to write element sets.\n");
}
}
/* =============== Result variable params ========= */
/* *** NEW API *** */
if (concatResult) {
EXCHECK(ex_put_all_var_param_ext(exoid, &varParams),
"Unable to write result variable parameter information.\n");
}
else {
EXCHECK(ex_put_variable_param(exoid, EX_GLOBAL, 2),
"Unable to write global result variable parameters.\n");
EXCHECK(ex_put_variable_param(exoid, EX_NODAL, 1),
"Unable to write nodal result variable parameters.\n");
EXCHECK(ex_put_variable_param(exoid, EX_ELEM_BLOCK, 1),
"Unable to write element result variable parameters.\n");
EXCHECK(ex_put_variable_param(exoid, EX_EDGE_BLOCK, 2),
"Unable to write edge result variable parameters.\n");
// EXCHECK(ex_put_variable_param(exoid, EX_FACE_BLOCK, 2),
// "Unable to write face result variable parameters.\n");
EXCHECK(ex_put_variable_param(exoid, EX_FACE_BLOCK, 1),
"Unable to write face result variable parameters.\n");
EXCHECK(ex_put_variable_param(exoid, EX_FACE_SET, 1),
"Unable to write faceset result variable parameters.\n");
}
/* =============== Result variable names ========== */
/* *** NEW API *** */
EXCHECK(ex_put_variable_name(exoid, EX_GLOBAL, 1, "CALIBER"), "Unable to write variable name.\n");
EXCHECK(ex_put_variable_name(exoid, EX_GLOBAL, 2, "GUNPOWDER"),
"Unable to write variable name.\n");
EXCHECK(ex_put_variable_name(exoid, EX_NODAL, 1, "RHO"), "Unable to write variable name.\n");
EXCHECK(ex_put_variable_name(exoid, EX_EDGE_BLOCK, 1, "GAMMA1"),
"Unable to write variable name.\n");
EXCHECK(ex_put_variable_name(exoid, EX_EDGE_BLOCK, 2, "GAMMA2"),
"Unable to write variable name.\n");
EXCHECK(ex_put_variable_name(exoid, EX_FACE_BLOCK, 1, "PHI"), "Unable to write variable name.\n");
// EXCHECK(ex_put_variable_name(exoid, EX_FACE_BLOCK, 2, "PHI"), "Unable to write variable
// name.\n");
EXCHECK(ex_put_variable_name(exoid, EX_ELEM_BLOCK, 1, "EPSTRN"),
"Unable to write variable name.\n");
EXCHECK(ex_put_variable_name(exoid, EX_FACE_SET, 1, "PHI0"), "Unable to write variable name.\n");
/* =============== Result variable values ========= */
t = 1.;
/* *** NEW API *** */
EXCHECK(ex_put_time(exoid, 1, &t), "Unable to write time value.\n");
EXCHECK(ex_put_var(exoid, 1, EX_GLOBAL, 1, 0 /*N/A*/, 2, vals_glo_var[0]),
"Unable to write global var 1.\n");
EXCHECK(ex_put_var(exoid, 1, EX_EDGE_BLOCK, 1, 100, 20, vals_edge_var1eb1[0]),
"Unable to write edge block 1 var 1.\n");
EXCHECK(ex_put_var(exoid, 1, EX_EDGE_BLOCK, 2, 100, 20, vals_edge_var2eb1[0]),
"Unable to write edge block 1 var 2.\n");
EXCHECK(ex_put_var(exoid, 1, EX_FACE_BLOCK, 1, 500, 2, vals_face_var1fb1[0]),
"Unable to write face block 1 var 1.\n");
// EXCHECK(ex_put_var(exoid, 1, EX_FACE_BLOCK, 2, 700, 8, vals_face_var1fb3[0]),
// "Unable to write face block 3 var 1.\n");
EXCHECK(ex_put_var(exoid, 1, EX_FACE_BLOCK, 1, 700, 8, vals_face_var1fb3[0]),
"Unable to write face block 3 var 1.\n");
EXCHECK(ex_put_var(exoid, 1, EX_ELEM_BLOCK, 1, 200, 2, vals_elem_var1eb1[0]),
"Unable to write elem block 1 var 1.\n");
EXCHECK(ex_put_var(exoid, 1, EX_FACE_SET, 1, 1400, 2, vals_fset_var1fs1[0]),
"Unable to write face set 1 var 1.\n");
t = 2.;
EXCHECK(ex_put_time(exoid, 2, &t), "Unable to write time value.\n");
EXCHECK(ex_put_var(exoid, 2, EX_GLOBAL, 1, 0 /*N/A*/, 2, vals_glo_var[1]),
"Unable to write global var 1.\n");
EXCHECK(ex_put_var(exoid, 2, EX_EDGE_BLOCK, 1, 100, 20, vals_edge_var1eb1[1]),
"Unable to write edge block 1 var 1.\n");
EXCHECK(ex_put_var(exoid, 2, EX_EDGE_BLOCK, 2, 100, 20, vals_edge_var2eb1[1]),
"Unable to write edge block 1 var 2.\n");
EXCHECK(ex_put_var(exoid, 2, EX_FACE_BLOCK, 1, 500, 2, vals_face_var1fb1[1]),
"Unable to write face block 1 var 1.\n");
// EXCHECK(ex_put_var(exoid, 2, EX_FACE_BLOCK, 2, 700, 8, vals_face_var1fb3[1]),
// "Unable to write face block 3 var 1.\n");
EXCHECK(ex_put_var(exoid, 2, EX_FACE_BLOCK, 1, 700, 8, vals_face_var1fb3[1]),
"Unable to write face block 3 var 1.\n");
EXCHECK(ex_put_var(exoid, 2, EX_ELEM_BLOCK, 1, 200, 2, vals_elem_var1eb1[1]),
"Unable to write elem block 1 var 1.\n");
EXCHECK(ex_put_var(exoid, 2, EX_FACE_SET, 1, 1400, 2, vals_fset_var1fs1[1]),
"Unable to write face set 1 var 1.\n");
EXCHECK(ex_put_var(exoid, 1, EX_NODAL, 1, 1, 12, vals_nod_var[0]),
"Unable to write nodal var 1.\n");
EXCHECK(ex_put_var(exoid, 2, EX_NODAL, 1, 1, 12, vals_nod_var[1]),
"Unable to write nodal var 1.\n");
EXCHECK(ex_close(exoid), "Unable to close database.\n");
free(varParams.edge_var_tab);
free(varParams.face_var_tab);
free(varParams.elem_var_tab);
free(varParams.fset_var_tab);
return 0;
}
int create_edge_block_diff_file(int argc, char *argv[])
{
int exoid;
int appWordSize = 8;
int diskWordSize = 8;
/* int concatBlocks = ex_have_arg( argc, argv, "-pcab" ); */
int concatSets = ex_have_arg(argc, argv, "-pcset");
int concatResult = ex_have_arg(argc, argv, "-pvpax");
double t;
ex_init_params modelParams = {
"CreateEdgeFace Test", /* title */
3, /* num_dim */
12, /* num_nodes */
20, /* num_edge */
1, /* num_edge_blk */
11, /* num_face */
3, /* num_face_blk */
3, /* num_elem */
2, /* num_elem_blk */
1, /* num_node_sets */
1, /* num_edge_sets */
1, /* num_face_sets */
1, /* num_side_sets */
2, /* num_elem_sets */
1, /* num_node_map */
1, /* num_edge_map */
1, /* num_face_map */
1, /* num_elem_map */
};
ex_block edgeBlocks[1];
ex_block faceBlocks[3];
ex_block elemBlocks[2];
ex_var_params varParams;
ex_opts(EX_VERBOSE | EX_ABORT);
exoid = ex_create(EX_TEST_EDGE_DIFF_FILENAME, EX_CLOBBER, &appWordSize, &diskWordSize);
if (exoid <= 0) {
fprintf(stderr, "Unable to open \"%s\" for writing.\n", EX_TEST_EDGE_DIFF_FILENAME);
return 1;
}
edgeBlocks[0].type = EX_EDGE_BLOCK;
edgeBlocks[0].id = 100;
edgeBlocks[0].num_entry = 20;
edgeBlocks[0].num_nodes_per_entry = 2;
edgeBlocks[0].num_attribute = 1;
ex_copy_string(edgeBlocks[0].topology, "EDGE2", MAX_STR_LENGTH + 1);
faceBlocks[0].type = EX_FACE_BLOCK;
faceBlocks[0].id = 500;
faceBlocks[0].num_entry = 2;
faceBlocks[0].num_nodes_per_entry = 4;
faceBlocks[0].num_attribute = 1;
ex_copy_string(faceBlocks[0].topology, "QUAD4", MAX_STR_LENGTH + 1);
faceBlocks[1].type = EX_FACE_BLOCK;
faceBlocks[1].id = 600;
faceBlocks[1].num_entry = 1;
faceBlocks[1].num_nodes_per_entry = 4;
faceBlocks[1].num_attribute = 1;
ex_copy_string(faceBlocks[1].topology, "QUAD4", MAX_STR_LENGTH + 1);
faceBlocks[2].type = EX_FACE_BLOCK;
faceBlocks[2].id = 700;
faceBlocks[2].num_entry = 8;
faceBlocks[2].num_nodes_per_entry = 4;
faceBlocks[2].num_attribute = 1;
ex_copy_string(faceBlocks[2].topology, "QUAD4", MAX_STR_LENGTH + 1);
elemBlocks[0].type = EX_ELEM_BLOCK;
elemBlocks[0].id = 200;
elemBlocks[0].num_entry = 2;
elemBlocks[0].num_nodes_per_entry = 8;
elemBlocks[0].num_edges_per_entry = 12;
elemBlocks[0].num_faces_per_entry = 6;
elemBlocks[0].num_attribute = 2;
ex_copy_string(elemBlocks[0].topology, "HEX8", MAX_STR_LENGTH + 1);
elemBlocks[1].type = EX_ELEM_BLOCK;
elemBlocks[1].id = 201;
elemBlocks[1].num_entry = 1;
elemBlocks[1].num_nodes_per_entry = 4;
elemBlocks[1].num_edges_per_entry = 0;
elemBlocks[1].num_faces_per_entry = 0;
elemBlocks[1].num_attribute = 0;
ex_copy_string(elemBlocks[1].topology, "TET4", MAX_STR_LENGTH + 1);
varParams.edge_var_tab = (int *)malloc(2 * sizeof(int));
varParams.face_var_tab = (int *)malloc(3 * sizeof(int));
varParams.elem_var_tab = (int *)malloc(2 * sizeof(int));
varParams.nset_var_tab = NULL;
varParams.eset_var_tab = NULL;
varParams.fset_var_tab = (int *)malloc(1 * sizeof(int));
varParams.sset_var_tab = NULL;
varParams.elset_var_tab = NULL;
varParams.num_glob = 2;
varParams.num_node = 1;
varParams.num_edge = 2;
varParams.edge_var_tab[0] = 1;
varParams.edge_var_tab[1] = 1;
varParams.num_face = 1;
varParams.face_var_tab[0] = 1;
varParams.face_var_tab[1] = 1;
varParams.face_var_tab[2] = 1;
varParams.num_elem = 1;
varParams.elem_var_tab[0] = 1;
varParams.elem_var_tab[1] = 0;
varParams.num_nset = 0;
varParams.num_eset = 0;
varParams.num_fset = 1;
varParams.fset_var_tab[0] = 1;
varParams.num_sset = 0;
varParams.num_elset = 0;
EXCHECK(ex_put_init_ext(exoid, &modelParams), "Unable to initialize database.\n");
{
int blk;
for (blk = 0; blk < modelParams.num_edge_blk; ++blk) {
EXCHECK(ex_put_block_param(exoid, edgeBlocks[blk]), "Unable to write edge block");
}
for (blk = 0; blk < modelParams.num_face_blk; ++blk) {
EXCHECK(ex_put_block_param(exoid, faceBlocks[blk]), "Unable to write face block");
}
for (blk = 0; blk < modelParams.num_elem_blk; ++blk) {
EXCHECK(ex_put_block_param(exoid, elemBlocks[blk]), "Unable to write elem block");
}
}
EXCHECK(ex_put_coord(exoid, (void *)coordsX, (void *)coordsY, (void *)coordsZ),
"Unable to write coordinates.\n");
EXCHECK(ex_put_coord_names(exoid, (char **)coordsNames), "Unable to write coordinate names.\n");
/* =============== Connectivity ================== */
/* *** NEW API *** */
EXCHECK(ex_put_conn(exoid, EX_EDGE_BLOCK, edgeBlocks[0].id, ebconn1, 0, 0),
"Unable to write edge block connectivity.\n");
/* *** NEW API *** */
EXCHECK(ex_put_conn(exoid, EX_FACE_BLOCK, faceBlocks[0].id, fbconn1, 0, 0),
"Unable to write face block 1 connectivity.\n");
EXCHECK(ex_put_conn(exoid, EX_FACE_BLOCK, faceBlocks[1].id, fbconn2, 0, 0),
"Unable to write face block 2 connectivity.\n");
EXCHECK(ex_put_conn(exoid, EX_FACE_BLOCK, faceBlocks[2].id, fbconn3, 0, 0),
"Unable to write face block 3 connectivity.\n");
/* *** NEW API *** */
EXCHECK(ex_put_conn(exoid, EX_ELEM_BLOCK, elemBlocks[0].id, conn1, econn1, fconn1),
"Unable to write elem block 1 connectivity.\n");
/* *** NEW API *** */
EXCHECK(ex_put_conn(exoid, EX_ELEM_BLOCK, elemBlocks[1].id, conn2, 0, 0),
"Unable to write elem block 2 connectivity.\n");
/* *** NEW API *** */
EXCHECK(ex_put_names(exoid, EX_EDGE_BLOCK, (char **)edblk_names),
"Unable to write edge block names.\n");
EXCHECK(ex_put_names(exoid, EX_FACE_BLOCK, (char **)fablk_names),
"Unable to write face block names.\n");
EXCHECK(ex_put_names(exoid, EX_ELEM_BLOCK, (char **)eblk_names),
"Unable to write element block names.\n");
/* =============== Number Maps ================== */
/* *** NEW API *** */
EXCHECK(ex_put_num_map(exoid, EX_NODE_MAP, 300, nmap1), "Unable to write node map.\n");
EXCHECK(ex_put_num_map(exoid, EX_EDGE_MAP, 800, edmap1), "Unable to write edge map.\n");
EXCHECK(ex_put_num_map(exoid, EX_FACE_MAP, 900, famap1), "Unable to write face map.\n");
EXCHECK(ex_put_num_map(exoid, EX_ELEM_MAP, 400, emap1), "Unable to write element map.\n");
/* *** NEW API *** */
EXCHECK(ex_put_names(exoid, EX_NODE_MAP, (char **)nmap_names),
"Unable to write node map names.\n");
EXCHECK(ex_put_names(exoid, EX_EDGE_MAP, (char **)edmap_names),
"Unable to write edge map names.\n");
EXCHECK(ex_put_names(exoid, EX_FACE_MAP, (char **)famap_names),
"Unable to write face map names.\n");
EXCHECK(ex_put_names(exoid, EX_ELEM_MAP, (char **)emap_names),
"Unable to write element map names.\n");
/* =============== Attribute names ================ */
/* *** NEW API *** */
EXCHECK(ex_put_attr_names(exoid, EX_EDGE_BLOCK, edgeBlocks[0].id, (char **)edge_attr_names1),
"Unable to write edge block 1 attribute names.\n");
/* *** NEW API *** */
EXCHECK(ex_put_attr_names(exoid, EX_FACE_BLOCK, faceBlocks[0].id, (char **)face_attr_names1),
"Unable to write face block 1 attribute names.\n");
EXCHECK(ex_put_attr_names(exoid, EX_FACE_BLOCK, faceBlocks[1].id, (char **)face_attr_names2),
"Unable to write face block 1 attribute names.\n");
EXCHECK(ex_put_attr_names(exoid, EX_FACE_BLOCK, faceBlocks[2].id, (char **)face_attr_names3),
"Unable to write face block 1 attribute names.\n");
/* *** NEW API *** */
EXCHECK(ex_put_attr_names(exoid, EX_ELEM_BLOCK, elemBlocks[0].id, (char **)elem_attr_names1),
"Unable to write elem block 1 attribute names.\n");
/* =============== Attribute values =============== */
/* *** NEW API *** */
EXCHECK(ex_put_attr(exoid, EX_EDGE_BLOCK, edgeBlocks[0].id, edge_attr_values1),
"Unable to write edge block 1 attribute values.\n");
/* *** NEW API *** */
EXCHECK(ex_put_attr(exoid, EX_FACE_BLOCK, faceBlocks[0].id, face_attr_values1),
"Unable to write face block 1 attribute values.\n");
EXCHECK(ex_put_attr(exoid, EX_FACE_BLOCK, faceBlocks[1].id, face_attr_values2),
"Unable to write face block 1 attribute values.\n");
EXCHECK(ex_put_attr(exoid, EX_FACE_BLOCK, faceBlocks[2].id, face_attr_values3),
"Unable to write face block 1 attribute values.\n");
/* *** NEW API *** */
EXCHECK(ex_put_attr(exoid, EX_ELEM_BLOCK, elemBlocks[0].id, elem_attr_values1),
"Unable to write elem block 1 attribute values.\n");
/* =============== Set parameters ================= */
/* *** NEW API *** */
EXCHECK(ex_put_names(exoid, EX_NODE_SET, (char **)nset_names),
"Unable to write node set names.\n");
EXCHECK(ex_put_names(exoid, EX_EDGE_SET, (char **)eset_names),
"Unable to write edge set names.\n");
EXCHECK(ex_put_names(exoid, EX_FACE_SET, (char **)fset_names),
"Unable to write face set names.\n");
EXCHECK(ex_put_names(exoid, EX_SIDE_SET, (char **)sset_names),
"Unable to write side set names.\n");
EXCHECK(ex_put_names(exoid, EX_ELEM_SET, (char **)elset_names),
"Unable to write element set names.\n");
{
ex_set allSets[1 + 1 + 1 + 1 + 2];
ex_set *nodeSets = &allSets[0];
ex_set *edgeSets = &allSets[1];
ex_set *faceSets = &allSets[2];
ex_set *sideSets = &allSets[3];
ex_set *elemSets = &allSets[4];
nodeSets[0].type = EX_NODE_SET;
nodeSets[0].id = 1000;
nodeSets[0].num_entry = 3;
nodeSets[0].num_distribution_factor = 0;
nodeSets[0].entry_list = nset_nodes;
nodeSets[0].extra_list = NULL;
nodeSets[0].distribution_factor_list = NULL;
edgeSets[0].type = EX_EDGE_SET;
edgeSets[0].id = 1200;
edgeSets[0].num_entry = 6;
edgeSets[0].num_distribution_factor = 6;
edgeSets[0].entry_list = eset_edges;
edgeSets[0].extra_list = eset_orient;
edgeSets[0].distribution_factor_list = eset_df;
faceSets[0].type = EX_FACE_SET;
faceSets[0].id = 1400;
faceSets[0].num_entry = 2;
faceSets[0].num_distribution_factor = 0;
faceSets[0].entry_list = fset_faces;
faceSets[0].extra_list = fset_orient;
faceSets[0].distribution_factor_list = NULL;
sideSets[0].type = EX_SIDE_SET;
sideSets[0].id = 1400;
sideSets[0].num_entry = 5;
sideSets[0].num_distribution_factor = 0;
sideSets[0].entry_list = sset_elems;
sideSets[0].extra_list = sset_sides;
sideSets[0].distribution_factor_list = NULL;
elemSets[0].type = EX_ELEM_SET;
elemSets[0].id = 1800;
elemSets[0].num_entry = 1;
elemSets[0].num_distribution_factor = 0;
elemSets[0].entry_list = &elset_elems[0];
elemSets[0].extra_list = NULL;
elemSets[0].distribution_factor_list = NULL;
elemSets[1].type = EX_ELEM_SET;
elemSets[1].id = 1900;
elemSets[1].num_entry = 1;
elemSets[1].num_distribution_factor = 0;
elemSets[1].entry_list = &elset_elems[1];
elemSets[1].extra_list = NULL;
elemSets[1].distribution_factor_list = NULL;
if (concatSets) {
EXCHECK(ex_put_sets(exoid, 1 + 2 + 1 + 1 + 1, allSets),
"Unable to output concatenated sets.\n");
}
else {
EXCHECK(ex_put_sets(exoid, 1, nodeSets), "Unable to write node sets.\n");
EXCHECK(ex_put_sets(exoid, 1, edgeSets), "Unable to write edge sets.\n");
EXCHECK(ex_put_sets(exoid, 1, faceSets), "Unable to write face sets.\n");
EXCHECK(ex_put_sets(exoid, 1, sideSets), "Unable to write side sets.\n");
EXCHECK(ex_put_sets(exoid, 2, elemSets), "Unable to write element sets.\n");
}
}
/* =============== Result variable params ========= */
/* *** NEW API *** */
if (concatResult) {
EXCHECK(ex_put_all_var_param_ext(exoid, &varParams),
"Unable to write result variable parameter information.\n");
}
else {
EXCHECK(ex_put_variable_param(exoid, EX_GLOBAL, 2),
"Unable to write global result variable parameters.\n");
EXCHECK(ex_put_variable_param(exoid, EX_NODAL, 1),
"Unable to write nodal result variable parameters.\n");
EXCHECK(ex_put_variable_param(exoid, EX_ELEM_BLOCK, 1),
"Unable to write element result variable parameters.\n");
EXCHECK(ex_put_variable_param(exoid, EX_EDGE_BLOCK, 2),
"Unable to write edge result variable parameters.\n");
// EXCHECK(ex_put_variable_param(exoid, EX_FACE_BLOCK, 2),
// "Unable to write face result variable parameters.\n");
EXCHECK(ex_put_variable_param(exoid, EX_FACE_BLOCK, 1),
"Unable to write face result variable parameters.\n");
EXCHECK(ex_put_variable_param(exoid, EX_FACE_SET, 1),
"Unable to write faceset result variable parameters.\n");
}
/* =============== Result variable names ========== */
/* *** NEW API *** */
EXCHECK(ex_put_variable_name(exoid, EX_GLOBAL, 1, "CALIBER"), "Unable to write variable name.\n");
EXCHECK(ex_put_variable_name(exoid, EX_GLOBAL, 2, "GUNPOWDER"),
"Unable to write variable name.\n");
EXCHECK(ex_put_variable_name(exoid, EX_NODAL, 1, "RHO"), "Unable to write variable name.\n");
EXCHECK(ex_put_variable_name(exoid, EX_EDGE_BLOCK, 1, "GAMMA1"),
"Unable to write variable name.\n");
EXCHECK(ex_put_variable_name(exoid, EX_EDGE_BLOCK, 2, "GAMMA2"),
"Unable to write variable name.\n");
EXCHECK(ex_put_variable_name(exoid, EX_FACE_BLOCK, 1, "PHI"), "Unable to write variable name.\n");
// EXCHECK(ex_put_variable_name(exoid, EX_FACE_BLOCK, 2, "PHI"), "Unable to write variable
// name.\n");
EXCHECK(ex_put_variable_name(exoid, EX_ELEM_BLOCK, 1, "EPSTRN"),
"Unable to write variable name.\n");
EXCHECK(ex_put_variable_name(exoid, EX_FACE_SET, 1, "PHI0"), "Unable to write variable name.\n");
/* =============== Result variable values ========= */
t = 1.;
/* *** NEW API *** */
EXCHECK(ex_put_time(exoid, 1, &t), "Unable to write time value.\n");
EXCHECK(ex_put_var(exoid, 1, EX_GLOBAL, 1, 0 /*N/A*/, 2, vals_glo_var[0]),
"Unable to write global var 1.\n");
EXCHECK(ex_put_var(exoid, 1, EX_EDGE_BLOCK, 1, 100, 20, diff_vals_edge_var1eb1[0]),
"Unable to write edge block 1 var 1.\n");
EXCHECK(ex_put_var(exoid, 1, EX_EDGE_BLOCK, 2, 100, 20, vals_edge_var2eb1[0]),
"Unable to write edge block 1 var 2.\n");
EXCHECK(ex_put_var(exoid, 1, EX_FACE_BLOCK, 1, 500, 2, vals_face_var1fb1[0]),
"Unable to write face block 1 var 1.\n");
// EXCHECK(ex_put_var(exoid, 1, EX_FACE_BLOCK, 2, 700, 8, vals_face_var1fb3[0]),
// "Unable to write face block 3 var 1.\n");
EXCHECK(ex_put_var(exoid, 1, EX_FACE_BLOCK, 1, 700, 8, vals_face_var1fb3[0]),
"Unable to write face block 3 var 1.\n");
EXCHECK(ex_put_var(exoid, 1, EX_ELEM_BLOCK, 1, 200, 2, vals_elem_var1eb1[0]),
"Unable to write elem block 1 var 1.\n");
EXCHECK(ex_put_var(exoid, 1, EX_FACE_SET, 1, 1400, 2, vals_fset_var1fs1[0]),
"Unable to write face set 1 var 1.\n");
t = 2.;
EXCHECK(ex_put_time(exoid, 2, &t), "Unable to write time value.\n");
EXCHECK(ex_put_var(exoid, 2, EX_GLOBAL, 1, 0 /*N/A*/, 2, vals_glo_var[1]),
"Unable to write global var 1.\n");
EXCHECK(ex_put_var(exoid, 2, EX_EDGE_BLOCK, 1, 100, 20, diff_vals_edge_var1eb1[1]),
"Unable to write edge block 1 var 1.\n");
EXCHECK(ex_put_var(exoid, 2, EX_EDGE_BLOCK, 2, 100, 20, vals_edge_var2eb1[1]),
"Unable to write edge block 1 var 2.\n");
EXCHECK(ex_put_var(exoid, 2, EX_FACE_BLOCK, 1, 500, 2, vals_face_var1fb1[1]),
"Unable to write face block 1 var 1.\n");
// EXCHECK(ex_put_var(exoid, 2, EX_FACE_BLOCK, 2, 700, 8, vals_face_var1fb3[1]),
// "Unable to write face block 3 var 1.\n");
EXCHECK(ex_put_var(exoid, 2, EX_FACE_BLOCK, 1, 700, 8, vals_face_var1fb3[1]),
"Unable to write face block 3 var 1.\n");
EXCHECK(ex_put_var(exoid, 2, EX_ELEM_BLOCK, 1, 200, 2, vals_elem_var1eb1[1]),
"Unable to write elem block 1 var 1.\n");
EXCHECK(ex_put_var(exoid, 2, EX_FACE_SET, 1, 1400, 2, vals_fset_var1fs1[1]),
"Unable to write face set 1 var 1.\n");
EXCHECK(ex_put_var(exoid, 1, EX_NODAL, 1, 1, 12, vals_nod_var[0]),
"Unable to write nodal var 1.\n");
EXCHECK(ex_put_var(exoid, 2, EX_NODAL, 1, 1, 12, vals_nod_var[1]),
"Unable to write nodal var 1.\n");
EXCHECK(ex_close(exoid), "Unable to close database.\n");
free(varParams.edge_var_tab);
free(varParams.face_var_tab);
free(varParams.elem_var_tab);
free(varParams.fset_var_tab);
return 0;
}
int create_face_block_diff_file(int argc, char *argv[])
{
int exoid;
int appWordSize = 8;
int diskWordSize = 8;
/* int concatBlocks = ex_have_arg( argc, argv, "-pcab" ); */
int concatSets = ex_have_arg(argc, argv, "-pcset");
int concatResult = ex_have_arg(argc, argv, "-pvpax");
double t;
ex_init_params modelParams = {
"CreateEdgeFace Test", /* title */
3, /* num_dim */
12, /* num_nodes */
20, /* num_edge */
1, /* num_edge_blk */
11, /* num_face */
3, /* num_face_blk */
3, /* num_elem */
2, /* num_elem_blk */
1, /* num_node_sets */
1, /* num_edge_sets */
1, /* num_face_sets */
1, /* num_side_sets */
2, /* num_elem_sets */
1, /* num_node_map */
1, /* num_edge_map */
1, /* num_face_map */
1, /* num_elem_map */
};
ex_block edgeBlocks[1];
ex_block faceBlocks[3];
ex_block elemBlocks[2];
ex_var_params varParams;
ex_opts(EX_VERBOSE | EX_ABORT);
exoid = ex_create(EX_TEST_FACE_DIFF_FILENAME, EX_CLOBBER, &appWordSize, &diskWordSize);
if (exoid <= 0) {
fprintf(stderr, "Unable to open \"%s\" for writing.\n", EX_TEST_FACE_DIFF_FILENAME);
return 1;
}
edgeBlocks[0].type = EX_EDGE_BLOCK;
edgeBlocks[0].id = 100;
edgeBlocks[0].num_entry = 20;
edgeBlocks[0].num_nodes_per_entry = 2;
edgeBlocks[0].num_attribute = 1;
ex_copy_string(edgeBlocks[0].topology, "EDGE2", MAX_STR_LENGTH + 1);
faceBlocks[0].type = EX_FACE_BLOCK;
faceBlocks[0].id = 500;
faceBlocks[0].num_entry = 2;
faceBlocks[0].num_nodes_per_entry = 4;
faceBlocks[0].num_attribute = 1;
ex_copy_string(faceBlocks[0].topology, "QUAD4", MAX_STR_LENGTH + 1);
faceBlocks[1].type = EX_FACE_BLOCK;
faceBlocks[1].id = 600;
faceBlocks[1].num_entry = 1;
faceBlocks[1].num_nodes_per_entry = 4;
faceBlocks[1].num_attribute = 1;
ex_copy_string(faceBlocks[1].topology, "QUAD4", MAX_STR_LENGTH + 1);
faceBlocks[2].type = EX_FACE_BLOCK;
faceBlocks[2].id = 700;
faceBlocks[2].num_entry = 8;
faceBlocks[2].num_nodes_per_entry = 4;
faceBlocks[2].num_attribute = 1;
ex_copy_string(faceBlocks[2].topology, "QUAD4", MAX_STR_LENGTH + 1);
elemBlocks[0].type = EX_ELEM_BLOCK;
elemBlocks[0].id = 200;
elemBlocks[0].num_entry = 2;
elemBlocks[0].num_nodes_per_entry = 8;
elemBlocks[0].num_edges_per_entry = 12;
elemBlocks[0].num_faces_per_entry = 6;
elemBlocks[0].num_attribute = 2;
ex_copy_string(elemBlocks[0].topology, "HEX8", MAX_STR_LENGTH + 1);
elemBlocks[1].type = EX_ELEM_BLOCK;
elemBlocks[1].id = 201;
elemBlocks[1].num_entry = 1;
elemBlocks[1].num_nodes_per_entry = 4;
elemBlocks[1].num_edges_per_entry = 0;
elemBlocks[1].num_faces_per_entry = 0;
elemBlocks[1].num_attribute = 0;
ex_copy_string(elemBlocks[1].topology, "TET4", MAX_STR_LENGTH + 1);
varParams.edge_var_tab = (int *)malloc(2 * sizeof(int));
varParams.face_var_tab = (int *)malloc(3 * sizeof(int));
varParams.elem_var_tab = (int *)malloc(2 * sizeof(int));
varParams.nset_var_tab = NULL;
varParams.eset_var_tab = NULL;
varParams.fset_var_tab = (int *)malloc(1 * sizeof(int));
varParams.sset_var_tab = NULL;
varParams.elset_var_tab = NULL;
varParams.num_glob = 2;
varParams.num_node = 1;
varParams.num_edge = 2;
varParams.edge_var_tab[0] = 1;
varParams.edge_var_tab[1] = 1;
varParams.num_face = 1;
varParams.face_var_tab[0] = 1;
varParams.face_var_tab[1] = 1;
varParams.face_var_tab[2] = 1;
varParams.num_elem = 1;
varParams.elem_var_tab[0] = 1;
varParams.elem_var_tab[1] = 0;
varParams.num_nset = 0;
varParams.num_eset = 0;
varParams.num_fset = 1;
varParams.fset_var_tab[0] = 1;
varParams.num_sset = 0;
varParams.num_elset = 0;
EXCHECK(ex_put_init_ext(exoid, &modelParams), "Unable to initialize database.\n");
{
int blk;
for (blk = 0; blk < modelParams.num_edge_blk; ++blk) {
EXCHECK(ex_put_block_param(exoid, edgeBlocks[blk]), "Unable to write edge block");
}
for (blk = 0; blk < modelParams.num_face_blk; ++blk) {
EXCHECK(ex_put_block_param(exoid, faceBlocks[blk]), "Unable to write face block");
}
for (blk = 0; blk < modelParams.num_elem_blk; ++blk) {
EXCHECK(ex_put_block_param(exoid, elemBlocks[blk]), "Unable to write elem block");
}
}
EXCHECK(ex_put_coord(exoid, (void *)coordsX, (void *)coordsY, (void *)coordsZ),
"Unable to write coordinates.\n");
EXCHECK(ex_put_coord_names(exoid, (char **)coordsNames), "Unable to write coordinate names.\n");
/* =============== Connectivity ================== */
/* *** NEW API *** */
EXCHECK(ex_put_conn(exoid, EX_EDGE_BLOCK, edgeBlocks[0].id, ebconn1, 0, 0),
"Unable to write edge block connectivity.\n");
/* *** NEW API *** */
EXCHECK(ex_put_conn(exoid, EX_FACE_BLOCK, faceBlocks[0].id, fbconn1, 0, 0),
"Unable to write face block 1 connectivity.\n");
EXCHECK(ex_put_conn(exoid, EX_FACE_BLOCK, faceBlocks[1].id, fbconn2, 0, 0),
"Unable to write face block 2 connectivity.\n");
EXCHECK(ex_put_conn(exoid, EX_FACE_BLOCK, faceBlocks[2].id, fbconn3, 0, 0),
"Unable to write face block 3 connectivity.\n");
/* *** NEW API *** */
EXCHECK(ex_put_conn(exoid, EX_ELEM_BLOCK, elemBlocks[0].id, conn1, econn1, fconn1),
"Unable to write elem block 1 connectivity.\n");
/* *** NEW API *** */
EXCHECK(ex_put_conn(exoid, EX_ELEM_BLOCK, elemBlocks[1].id, conn2, 0, 0),
"Unable to write elem block 2 connectivity.\n");
/* *** NEW API *** */
EXCHECK(ex_put_names(exoid, EX_EDGE_BLOCK, (char **)edblk_names),
"Unable to write edge block names.\n");
EXCHECK(ex_put_names(exoid, EX_FACE_BLOCK, (char **)fablk_names),
"Unable to write face block names.\n");
EXCHECK(ex_put_names(exoid, EX_ELEM_BLOCK, (char **)eblk_names),
"Unable to write element block names.\n");
/* =============== Number Maps ================== */
/* *** NEW API *** */
EXCHECK(ex_put_num_map(exoid, EX_NODE_MAP, 300, nmap1), "Unable to write node map.\n");
EXCHECK(ex_put_num_map(exoid, EX_EDGE_MAP, 800, edmap1), "Unable to write edge map.\n");
EXCHECK(ex_put_num_map(exoid, EX_FACE_MAP, 900, famap1), "Unable to write face map.\n");
EXCHECK(ex_put_num_map(exoid, EX_ELEM_MAP, 400, emap1), "Unable to write element map.\n");
/* *** NEW API *** */
EXCHECK(ex_put_names(exoid, EX_NODE_MAP, (char **)nmap_names),
"Unable to write node map names.\n");
EXCHECK(ex_put_names(exoid, EX_EDGE_MAP, (char **)edmap_names),
"Unable to write edge map names.\n");
EXCHECK(ex_put_names(exoid, EX_FACE_MAP, (char **)famap_names),
"Unable to write face map names.\n");
EXCHECK(ex_put_names(exoid, EX_ELEM_MAP, (char **)emap_names),
"Unable to write element map names.\n");
/* =============== Attribute names ================ */
/* *** NEW API *** */
EXCHECK(ex_put_attr_names(exoid, EX_EDGE_BLOCK, edgeBlocks[0].id, (char **)edge_attr_names1),
"Unable to write edge block 1 attribute names.\n");
/* *** NEW API *** */
EXCHECK(ex_put_attr_names(exoid, EX_FACE_BLOCK, faceBlocks[0].id, (char **)face_attr_names1),
"Unable to write face block 1 attribute names.\n");
EXCHECK(ex_put_attr_names(exoid, EX_FACE_BLOCK, faceBlocks[1].id, (char **)face_attr_names2),
"Unable to write face block 1 attribute names.\n");
EXCHECK(ex_put_attr_names(exoid, EX_FACE_BLOCK, faceBlocks[2].id, (char **)face_attr_names3),
"Unable to write face block 1 attribute names.\n");
/* *** NEW API *** */
EXCHECK(ex_put_attr_names(exoid, EX_ELEM_BLOCK, elemBlocks[0].id, (char **)elem_attr_names1),
"Unable to write elem block 1 attribute names.\n");
/* =============== Attribute values =============== */
/* *** NEW API *** */
EXCHECK(ex_put_attr(exoid, EX_EDGE_BLOCK, edgeBlocks[0].id, edge_attr_values1),
"Unable to write edge block 1 attribute values.\n");
/* *** NEW API *** */
EXCHECK(ex_put_attr(exoid, EX_FACE_BLOCK, faceBlocks[0].id, face_attr_values1),
"Unable to write face block 1 attribute values.\n");
EXCHECK(ex_put_attr(exoid, EX_FACE_BLOCK, faceBlocks[1].id, face_attr_values2),
"Unable to write face block 1 attribute values.\n");
EXCHECK(ex_put_attr(exoid, EX_FACE_BLOCK, faceBlocks[2].id, face_attr_values3),
"Unable to write face block 1 attribute values.\n");
/* *** NEW API *** */
EXCHECK(ex_put_attr(exoid, EX_ELEM_BLOCK, elemBlocks[0].id, elem_attr_values1),
"Unable to write elem block 1 attribute values.\n");
/* =============== Set parameters ================= */
/* *** NEW API *** */
EXCHECK(ex_put_names(exoid, EX_NODE_SET, (char **)nset_names),
"Unable to write node set names.\n");
EXCHECK(ex_put_names(exoid, EX_EDGE_SET, (char **)eset_names),
"Unable to write edge set names.\n");
EXCHECK(ex_put_names(exoid, EX_FACE_SET, (char **)fset_names),
"Unable to write face set names.\n");
EXCHECK(ex_put_names(exoid, EX_SIDE_SET, (char **)sset_names),
"Unable to write side set names.\n");
EXCHECK(ex_put_names(exoid, EX_ELEM_SET, (char **)elset_names),
"Unable to write element set names.\n");
{
ex_set allSets[1 + 1 + 1 + 1 + 2];
ex_set *nodeSets = &allSets[0];
ex_set *edgeSets = &allSets[1];
ex_set *faceSets = &allSets[2];
ex_set *sideSets = &allSets[3];
ex_set *elemSets = &allSets[4];
nodeSets[0].type = EX_NODE_SET;
nodeSets[0].id = 1000;
nodeSets[0].num_entry = 3;
nodeSets[0].num_distribution_factor = 0;
nodeSets[0].entry_list = nset_nodes;
nodeSets[0].extra_list = NULL;
nodeSets[0].distribution_factor_list = NULL;
edgeSets[0].type = EX_EDGE_SET;
edgeSets[0].id = 1200;
edgeSets[0].num_entry = 6;
edgeSets[0].num_distribution_factor = 6;
edgeSets[0].entry_list = eset_edges;
edgeSets[0].extra_list = eset_orient;
edgeSets[0].distribution_factor_list = eset_df;
faceSets[0].type = EX_FACE_SET;
faceSets[0].id = 1400;
faceSets[0].num_entry = 2;
faceSets[0].num_distribution_factor = 0;
faceSets[0].entry_list = fset_faces;
faceSets[0].extra_list = fset_orient;
faceSets[0].distribution_factor_list = NULL;
sideSets[0].type = EX_SIDE_SET;
sideSets[0].id = 1400;
sideSets[0].num_entry = 5;
sideSets[0].num_distribution_factor = 0;
sideSets[0].entry_list = sset_elems;
sideSets[0].extra_list = sset_sides;
sideSets[0].distribution_factor_list = NULL;
elemSets[0].type = EX_ELEM_SET;
elemSets[0].id = 1800;
elemSets[0].num_entry = 1;
elemSets[0].num_distribution_factor = 0;
elemSets[0].entry_list = &elset_elems[0];
elemSets[0].extra_list = NULL;
elemSets[0].distribution_factor_list = NULL;
elemSets[1].type = EX_ELEM_SET;
elemSets[1].id = 1900;
elemSets[1].num_entry = 1;
elemSets[1].num_distribution_factor = 0;
elemSets[1].entry_list = &elset_elems[1];
elemSets[1].extra_list = NULL;
elemSets[1].distribution_factor_list = NULL;
if (concatSets) {
EXCHECK(ex_put_sets(exoid, 1 + 2 + 1 + 1 + 1, allSets),
"Unable to output concatenated sets.\n");
}
else {
EXCHECK(ex_put_sets(exoid, 1, nodeSets), "Unable to write node sets.\n");
EXCHECK(ex_put_sets(exoid, 1, edgeSets), "Unable to write edge sets.\n");
EXCHECK(ex_put_sets(exoid, 1, faceSets), "Unable to write face sets.\n");
EXCHECK(ex_put_sets(exoid, 1, sideSets), "Unable to write side sets.\n");
EXCHECK(ex_put_sets(exoid, 2, elemSets), "Unable to write element sets.\n");
}
}
/* =============== Result variable params ========= */
/* *** NEW API *** */
if (concatResult) {
EXCHECK(ex_put_all_var_param_ext(exoid, &varParams),
"Unable to write result variable parameter information.\n");
}
else {
EXCHECK(ex_put_variable_param(exoid, EX_GLOBAL, 2),
"Unable to write global result variable parameters.\n");
EXCHECK(ex_put_variable_param(exoid, EX_NODAL, 1),
"Unable to write nodal result variable parameters.\n");
EXCHECK(ex_put_variable_param(exoid, EX_ELEM_BLOCK, 1),
"Unable to write element result variable parameters.\n");
EXCHECK(ex_put_variable_param(exoid, EX_EDGE_BLOCK, 2),
"Unable to write edge result variable parameters.\n");
// EXCHECK(ex_put_variable_param(exoid, EX_FACE_BLOCK, 2),
// "Unable to write face result variable parameters.\n");
EXCHECK(ex_put_variable_param(exoid, EX_FACE_BLOCK, 1),
"Unable to write face result variable parameters.\n");
EXCHECK(ex_put_variable_param(exoid, EX_FACE_SET, 1),
"Unable to write faceset result variable parameters.\n");
}
/* =============== Result variable names ========== */
/* *** NEW API *** */
EXCHECK(ex_put_variable_name(exoid, EX_GLOBAL, 1, "CALIBER"), "Unable to write variable name.\n");
EXCHECK(ex_put_variable_name(exoid, EX_GLOBAL, 2, "GUNPOWDER"),
"Unable to write variable name.\n");
EXCHECK(ex_put_variable_name(exoid, EX_NODAL, 1, "RHO"), "Unable to write variable name.\n");
EXCHECK(ex_put_variable_name(exoid, EX_EDGE_BLOCK, 1, "GAMMA1"),
"Unable to write variable name.\n");
EXCHECK(ex_put_variable_name(exoid, EX_EDGE_BLOCK, 2, "GAMMA2"),
"Unable to write variable name.\n");
EXCHECK(ex_put_variable_name(exoid, EX_FACE_BLOCK, 1, "PHI"), "Unable to write variable name.\n");
// EXCHECK(ex_put_variable_name(exoid, EX_FACE_BLOCK, 2, "PHI"), "Unable to write variable
// name.\n");
EXCHECK(ex_put_variable_name(exoid, EX_ELEM_BLOCK, 1, "EPSTRN"),
"Unable to write variable name.\n");
EXCHECK(ex_put_variable_name(exoid, EX_FACE_SET, 1, "PHI0"), "Unable to write variable name.\n");
/* =============== Result variable values ========= */
t = 1.;
/* *** NEW API *** */
EXCHECK(ex_put_time(exoid, 1, &t), "Unable to write time value.\n");
EXCHECK(ex_put_var(exoid, 1, EX_GLOBAL, 1, 0 /*N/A*/, 2, vals_glo_var[0]),
"Unable to write global var 1.\n");
EXCHECK(ex_put_var(exoid, 1, EX_EDGE_BLOCK, 1, 100, 20, vals_edge_var1eb1[0]),
"Unable to write edge block 1 var 1.\n");
EXCHECK(ex_put_var(exoid, 1, EX_EDGE_BLOCK, 2, 100, 20, vals_edge_var2eb1[0]),
"Unable to write edge block 1 var 2.\n");
EXCHECK(ex_put_var(exoid, 1, EX_FACE_BLOCK, 1, 500, 2, diff_vals_face_var1fb1[0]),
"Unable to write face block 1 var 1.\n");
// EXCHECK(ex_put_var(exoid, 1, EX_FACE_BLOCK, 2, 700, 8, vals_face_var1fb3[0]),
// "Unable to write face block 3 var 1.\n");
EXCHECK(ex_put_var(exoid, 1, EX_FACE_BLOCK, 1, 700, 8, vals_face_var1fb3[0]),
"Unable to write face block 3 var 1.\n");
EXCHECK(ex_put_var(exoid, 1, EX_ELEM_BLOCK, 1, 200, 2, vals_elem_var1eb1[0]),
"Unable to write elem block 1 var 1.\n");
EXCHECK(ex_put_var(exoid, 1, EX_FACE_SET, 1, 1400, 2, vals_fset_var1fs1[0]),
"Unable to write face set 1 var 1.\n");
t = 2.;
EXCHECK(ex_put_time(exoid, 2, &t), "Unable to write time value.\n");
EXCHECK(ex_put_var(exoid, 2, EX_GLOBAL, 1, 0 /*N/A*/, 2, vals_glo_var[1]),
"Unable to write global var 1.\n");
EXCHECK(ex_put_var(exoid, 2, EX_EDGE_BLOCK, 1, 100, 20, vals_edge_var1eb1[1]),
"Unable to write edge block 1 var 1.\n");
EXCHECK(ex_put_var(exoid, 2, EX_EDGE_BLOCK, 2, 100, 20, vals_edge_var2eb1[1]),
"Unable to write edge block 1 var 2.\n");
EXCHECK(ex_put_var(exoid, 2, EX_FACE_BLOCK, 1, 500, 2, diff_vals_face_var1fb1[1]),
"Unable to write face block 1 var 1.\n");
// EXCHECK(ex_put_var(exoid, 2, EX_FACE_BLOCK, 2, 700, 8, vals_face_var1fb3[1]),
// "Unable to write face block 3 var 1.\n");
EXCHECK(ex_put_var(exoid, 2, EX_FACE_BLOCK, 1, 700, 8, vals_face_var1fb3[1]),
"Unable to write face block 3 var 1.\n");
EXCHECK(ex_put_var(exoid, 2, EX_ELEM_BLOCK, 1, 200, 2, vals_elem_var1eb1[1]),
"Unable to write elem block 1 var 1.\n");
EXCHECK(ex_put_var(exoid, 2, EX_FACE_SET, 1, 1400, 2, vals_fset_var1fs1[1]),
"Unable to write face set 1 var 1.\n");
EXCHECK(ex_put_var(exoid, 1, EX_NODAL, 1, 1, 12, vals_nod_var[0]),
"Unable to write nodal var 1.\n");
EXCHECK(ex_put_var(exoid, 2, EX_NODAL, 1, 1, 12, vals_nod_var[1]),
"Unable to write nodal var 1.\n");
EXCHECK(ex_close(exoid), "Unable to close database.\n");
free(varParams.edge_var_tab);
free(varParams.face_var_tab);
free(varParams.elem_var_tab);
free(varParams.fset_var_tab);
return 0;
}
#if !defined(USING_CMAKE)
int main(int argc, char *argv[])
{
int rc = 0;
rc = create_gold_file(argc, argv);
if (rc != 0)
return rc;
rc = create_no_diff_file(argc, argv);
if (rc != 0)
return rc;
rc = create_edge_block_diff_file(argc, argv);
if (rc != 0)
return rc;
rc = create_face_block_diff_file(argc, argv);
if (rc != 0)
return rc;
return 0;
}
#endif