SIGMA

Scalable Interfaces for Geometry and Mesh based Applications

SIGMA Release 1.0

Posted by in News, SIGMA

SIGMA v1.0 introduces a consolidated one-stop website for all information regarding tools contained under its umbrella of tools. Details on compatibility of the different tools and dependent libraries are available here and all questions can be directed to <package>[email protected].

Current release contains the following SIGMA tools:

  1. Common Geometry Module (CGM) – Version 14.0.0
  2. Mesh Oriented datABase (MOAB) – Version 4.7.0
  3. Lasso Relations tool (Lasso) – Version 3.1.0
  4. MeshKit library (MeshKit) – Version 1.2.0

Source tarballs can be obtained from either the Bitbucket repository or from the ftp site. For more build instructions, go to the downloads page.

Several combination of compilers, dependencies and versions are constantly being tested after every commit and nightly with Buildbot. Continuous Integration (CI) support through dynamic Buildbot reconfiguration is being enabled to improve the workflow of both the developers and contributors to SIGMA.

Individual release notes for each of the tools are available below.


CGM

A. BUG FIXES

  1. Fix stack smashing issues found on Intel builds while loading using function: iGeom_load_cub_geometry.
  2. Fix various warnings found on Ubuntu and OSX.
  3. Fixed the non-debug mode testcase ‘modify’ failure issue. Here the DLIList functions are not working as expected, and so rewrote the member accessing call.

B. NEW FEATURES

  1. CMake-based builds are now supported. Note that CMake scripts do not yet support parallel/MPI builds.
  2. Enhanced Doxygen-based API documentation, users and developers guide for CGM.

C. API CHANGES

  1. iGeom_iface_correction

D. FUTURE WORK

  1. Fix OCC builds that trigger test failures
  2. Improve OCE support
  3. Improve compatibility with Cubit 14.1

MOAB

A. BUG FIXES

  1. Remove memory leak for point-to-point communication (issue #7) caused due to reuse of MPIRequest structures
  2. Reading sets in parallel (ticket 273)
  3. Parallel mbconvert bug (ticket 274, material sets compromised before writing)
  4. Fix memory leak for tracked sets (ticket 285)
  5. Fix issue #8 for merging higher dimensional entities
  6. Fix edge adjacency and skinner to operate on Polygon and Polyhedra
  7. Eliminated miscellaneous compiler warnings (tested on GCC-4.6.3, clang-3.0, Intel-13.1, PGI-13.6)

B. NEW FEATURES

Primary

  1. Implemented the Array-based Half Facet data structures in MOAB to improve adjacency querying and efficient traversals between related entities (use –enable-ahf during configure)
  2. Co-developed (MOAB and PETSc) to introduce a new native MOAB-mesh based Discretization Manager (DM) implementation in PETSc that supports parallel solution to PDE problems on unstructured grids.

Readers/Writers

  1. New reader/writer formats (CGNS, MPAS, GCRM); Improve support for several existing formats (Climate-NC, HOMME, CAM-Euler, CAM-FV)
  2. Introduce padded polygons option for lower memory fragmentation in MPAS and GCRM climate readers
  3. Add climate data NC writer, in serial and parallel, for all data formats supported by the NC reader with options to append, read time-series with concatenation
  4. Add Zoltan repartitioning for MPAS reader
  5. Improvements in CUBIT reader for boundary conditions data, support CUBIT 14.0 format changes, endianness for BG/Q, variable length tags for saving block attributes and headers
  6. Add TET4 as supported element in Exodus reader

General

  1. Enhanced Doxygen-based documentation support for API, user guide, developer guide and examples.
  2. Create several new examples to demonstrate the usage of the API for different applications; More to be added here.
  3. Added robust CMake build support for MOAB; Preliminary fixes for Windows systems.

Tools

  1. Enhancements and refactoring to support reading the CGM geometry models for DagMC
  2. Parallelization of the MOAB based conservative intersection (CSLAM) algorithm for advection/transport applications
  3. Refactoring of MBCoupler and refactoring to support dynamic usage of new search tree algorithms (Kd, BVH)
  4. Update VTKReader Paraview plugin for MOAB; Removed the old vtkMOABReader and replaced it with vtkMOABReaderNew.

C. API CHANGES

  1. Added meshset argument for methods in ParallelComm and Skinner
  2. New options for NC reader
    • rename PARTITION_METHOD=TRIVIAL_PARTITION to PARTITION_METHOD=TRIVIAL
    • add NO_MIXED_ELEMENTS option fo reading polygon data (it means padded)
    • add NO_EDGES option for MPAS reader
    • RENAME option for renaming a variable at writing an nc file
    • TIMESTEP option for reading nc files
  3. Changes in Core::list_entities to print dense tag information
  4. Changes in memory evaluators, move from type long to type long long
  5. Changes to ScdInterface, mostly to support new partitioning method (sqijk) but also to allow for periodic meshes in all 3 directions
  6. Install TupleList for serial builds also
  7. New method in MergeMesh that allows stitching a mesh based on an integer tag defined on vertices (GLOBAL_ID)
  8. Introduced interface to delete entities in ParallelComm

D. FUTURE WORK

  1. Add more examples
  2. Refactor LocalDiscretization support to enable better solver interfaces for solving PDEs
  3. Contribute to DMMoab in PETSc to leverage efforts in (2)
  4. Refactor and verify normalization in MBCoupler

MESHKIT

A. BUG FIXES

  1. Various RGG (AssyGen/CoreGen) bugfixes and enhancements: common keywords inputs, superblocks, automated multiple file creation, automatic mesh size specification, scheme spefication for hole surfaces etc.
  2. Fixes to OneToOneSweep: new test case added
  3. Fixes to PostBL along with addition of methods to create mixed element meshes.
  4. Fixes to quadmesher and dependency on BOOST.

B. NEW FEATURES

  1. A new version of make_watertight for sealing faceted CAD Geometry, see link.
    Note: Use with MOAB 4.7.0 or higher. A program called check_watertight for evaluating model integrity for use with ray-firing has been included as well.
  2. RGG AssyGen feature to “CreateFiles” and “CreateMatFiles”. CoreGen feature “same_as” to shift material/boundaries while loading the same mesh file.
  3. Load file with geometry group sets (see: test/core/test_load_grps.cpp)
  4. Routines with 21 options for quad mesh cleanup (test/algs/test_quadmeshcleanup)
  5. RGG GUI has been developed by Kitware and is available for downloaded from their website. CMB website.

C. API CHANGES

  1. Fixes to get_entities_by_dimension and get_entities_by_handle. These functions will now return ModelEnts of dimension 4 if requested. If the dimension passed in is -1, the function will return all ModelEnts in the MK instance.
  2. Correction to the ModelEnt constructor for iGeom EntSets.

D. FUTURE WORK

  1. B-Rep(OCC)-based mesh generation, Solid Geometry Mesher-based on CGM, this will add the capability of meshing and manipulating solid geometry models based on OpenCascade and CUBIT.
  2. Open source tri-mesher
  3. Integration of verdict-mesh quality evalulation library
  4. Interval assignment integration with existing algorithms
  5. New parallel schemes and optimization of RGG tools: AssyGen and CoreGen.
  6. Parallel mesh generation

LASSO

A. BUG FIXES

  1. Miscellaneous warning fixes exposed through Buildbot
  2. Fix some stack smashing bugs
  3. Added Doxygen support with nightly API built from repository
  4. Better flag determination during configuration

B. NEW FEATURES

None

C. API CHANGES

None


Copyright © 2014--2023 SIGMA. All Rights Reserved.