Releases: LLNL/conduit
0.8.1
0.8.1 Release Highlights
(adapted from Conduit's Changelog)
Added
General
- Added
CONDUIT_DLL_DIR
env var support on windows, for cases where Conduit DLLs are not installed directly inside the Python Module.
Blueprint
- Allow adjsets to be used in
blueprint::mesh::partition
to determine global vertex ids. - Added partial matset support to
blueprint::mesh::partition
andblueprint::mesh::combine
.
Fixed
General
- Fixed CMake bug with
ENABLE_RELAY_WEBSERVER
option. - Fixed build and test issues with Python >= 3.8 on Windows.
Blueprint
- Fixed a bug in
blueprint::mesh::partition
where adjsets could be missing in new domains. - Fixed a bug with
blueprint::mesh::matset::to_silo
and uni-buffer matsets.
0.8.0
0.8.0 Release Highlights
(adapted from Conduit's Changelog)
Added
General
- Added
setup.py
for building and installing Conduit and its Python module via pip - Added DataAccessor class that helps write generic algorithms that consume data arrays using expected types.
- Added support to register custom memory allocators and a custom data movement handler. This allows conduit to move trees of data between heterogenous memory spaces (e.g. CPU and GPU memory). See conduit_utils.hpp for API details.
Blueprint
- Added
conduit::blueprint::{mpi}::partition
function that provides a general N-to-M partition capability for Blueprint Meshes. This helps with load balancing and other use cases, including fusing multi-domain data to simplifying post processing. This capability supports several options, see (https://llnl-conduit.readthedocs.io/en/latest/blueprint_mesh_partition.html) for more details. - Added a
Table
blueprint used to represent tables of numeric data. See (https://llnl-conduit.readthedocs.io/en/latest/blueprint_table.html) more details. - Added
conduit::blueprint::{mpi}::flatten
which transforms Blueprint Meshes into Blueprint Tables. This transforms Mesh Blueprint data into a form that is more easily digestible in machine learning applications. - Added
conduit::blueprint::mpi::generate_partition_field
, which uses Parmetis to create a field that identifies how to load balance an input mesh elements. This field can be used as a Field selection input toconduit::blueprint::mpi::partition
function. - Added the
blueprint::mesh::examples::polychain
example. It is an example of a polyhedral mesh. See Mesh Blueprint Examples docs (https://llnl-conduit.readthedocs.io/en/latest/blueprint_mesh.html#polychain) for more details. - Added a new function signature for
blueprint::mesh::topology::unstructured::generate_sides
, which performs the same task as the original and also takes fields from the original topology and maps them onto the new topology. - Added
blueprint::mpi::mesh::to_polygonal
, which provides a MPI aware conversion Blueprint Structured AMR meshes to a Blueprint Polyhedral meshes. - Added a host of
conduit::blueprint::mpi::mesh::generate_*
methods, which are the MPI parallel equivalents of theconduit::blueprint::mesh::topology::unstructured::generate_*
functions. - Added the
conduit::blueprint::mpi::mesh::find_delegate_domain
function, which returns a single delegate domain for the given mesh across MPI ranks (useful when all ranks need mesh information and some ranks can have empty meshes). - Added check and transform functions for the newly-designated
pairwise
andmaxshare
variants ofadjsets
. For more information, see theconduit::blueprint::mesh::adjset
namespace. - Added
mesh::topology::unstructured::to_polytopal
as an alias tomesh::topology::unstructured::to_polygonal
, to reflect that both polygonal and polyhedral are supported. - Added
conduit::blueprint::mpi::mesh::to_polytopal
as an alias toconduit::blueprint::mpi::mesh::to_polygonal
andconduit::blueprint::mpi::mesh::to_polyhedral
.
Relay
- Added
conduit::relay::io::hdf5_identifier_report
methods, which create conduit nodes that describes active hdf5 resource handles.
Changed
General
- Updated CMake logic to provide more robust Python detection and better support for HDF5 installs that were built with CMake.
- Improved Node::diff and Node::diff_compatible to show string values when strings differ.
conduit::Node::print()
and in Python Noderepr
andstr
now useto_summary_string()
. This reduces the output for large Nodes. Full output is still supported viato_string()
,to_yaml()
, etc methods.
Blueprint
- The
blueprint::mesh::examples::polytess
function now takes a new argument, callednz
, which allows it to be extended into 3 dimensions. See Mesh Blueprint Examples docs (https://llnl-conduit.readthedocs.io/en/latest/blueprint_mesh.html#polytess) for more details. - Added support for both
const
and non-const
inputs to theconduit::blueprint::mesh::domains
function. - Improved mesh blueprint index generation logic (local and MPI) to support domains with different topos, fields, etc.
- Deprecated accepting
npts_z !=0
for 2D shape types inconduit::blueprint::mesh::examples::{braid,basic,grid}
. They issue aCONDUIT_INFO
message when this detected and future versions will issue aCONDUIT_ERROR
. - An empty Conduit Node is now considered a valid multi-domain mesh. This change was made to make serial uses cases better match sparse MPI multi-domain use cases. Existing code that relied
mesh::verify
to exclude empty Nodes will now need an extra check to see if an input mesh has data. - Added MPI communicator argument to
conduit::blueprint::mpi::mesh::to_polygonal
andconduit::blueprint::mpi::mesh::to_polyhedral
.
Relay
- Added CMake option (
ENABLE_RELAY_WEBSERVER
, default =ON
) to control if Conduit's Relay Web Server support is built. Down stream codes can check for support via header ifdefCONDUIT_RELAY_WEBSERVER_ENABLED
or at runtime inconduit::relay::about
. - Added support to compile against HDF5 1.12.
Fixed
General
- Avoid compile issue with using
_Pragma()
with Python 3.8 on Windows conduit_node
andconduit_datatype
in the C API are no longer aliases tovoid
so that callers cannot pass just any pointer to the APIs.- Fixed memory over read issue with Fortran API due to int vs bool binding error. Fortran API still provides logical returns for methods like conduit_node_has_path() however the binding implementation now properly translates C_INT return codes into logical values.
- Fixed a subtle bug with Node fetch and Object role initialization.
Blueprint
- Fixed a bug that was causing the
conduit::blueprint::mesh::topology::unstructured::generate_*
functions to produce bad results for polyhedral input topologies with heterogeneous elements (e.g. tets and hexs). - Fixed a bug with
conduit::relay::io::blueprint::write_mesh
that underminedtruncate=true
option for root-only style output. - Fixed options parsing bugs and improved error messages for the
conduit_blueprint_verify
exe.
Relay
- Changed HDF5 offset support to use 64-bit unsigned integers for offsets, strides, and sizes.
- Fixed a bug with
conduit::relay::mpi::io::blueprint::save_mesh
wherefile_style=root_only
could crash or truncate output files. - Fixed a bug with inconsistent HDF5 handles being used in some cases when converting existing HDF5 Datasets from fixed to extendable.
0.7.2
0.7.2 Release Highlights
(adapted from Conduit's Changelog)
Added
General
- Added the
cpp_fort_and_py
standalone example. It demos passing Conduit Nodes between C++, Fortran, and Python. See the related tutorial docs (https://llnl-conduit.readthedocs.io/en/latest/tutorial_cpp_fort_and_py.html) for more details. - Added
conduit::utils::info_handler()
,conduit::utils::warning_handler()
, andconduit::utils::error_handler()
methods, which provide access to the currently registered info, warning, and error handlers. - Added DataType::index_t method. Creates a DataType instance that describes an
index_t
, which is an alias to eitherint32
, orint 64
controlled by theCONDUIT_INDEX_32
compile time option. - Added several more methods to Python DataType interface
- Removed duplicate install of CMake exported target files that served as a bridge for clients using old style paths.
Changed
General
- Updated to newer version of uberenv and changed to track spack fork https://github.com/alpine-dav/spack (branch: conduit/develop).
- Updated to newer version of BLT to leverage CMake's FindMPI defined targets when using CMake 3.15 or newer.
- Changed
rapidjson
namespace toconduit_rapidjson
to avoid symbol collisions with other libraries using RapidJSON.
Blueprint
- The semantics of
conduit::blueprint::mesh::verify
changed. An empty conduit Node is now considered a valid multi-domain mesh with zero domains. If you always expect mesh data, you can add an additional check for empty to craft code that works for both the old and new verify semantics.
Relay
- Added Relay HDF5 support for reading and writing to an HDF5 dataset with offset.
- Added
conduit::relay::io::hdf5::read_info
which allows you to obtain metadata from an HDF5 file. - Added configure error when conduit lacks MPI support and HDF5 has MPI support
Fixed
General
- Fixed missing implementation of DataType::is_index_t
- Fixed issue with compiling t_h5z_zfp_smoke.cpp against an MPI-enabled HDF5.
Blueprint
- Fixed a bug that caused HDF5 reference paths to appear twice in Relay HDF5 Error messages.
Blueprint
conduit::relay::io::blueprint.read_mesh
now uses read only I/O handles.
0.7.1
0.7.1 Release Highlights
(adapted from Conduit's Changelog)
Fixed
General
- Fixed a bug with Conduit's C interface including C++ headers.
Blueprint
- Fixed a bug with
blueprint::mesh::matset::to_silo
andblueprint::mesh::field::to_silo
that could modify input values.
0.7.0
0.7.0 Release Highlights
(adapted from Conduit's Changelog)
Changed
General
- Conduit now requires C++11 support.
- Python Node repr string construction now uses
Node.to_summary_string()
Added
- CMake: Added extra check for include dir vs fully resolved hdf5 path.
General
- Added a builtin sandboxed header-only version of fmt. The namespace and directory paths were changed to
conduit_fmt
to avoid potential symbol collisions with other codes using fmt. Downstream software can use by includingconduit_fmt/conduit_fmt.h
. - Added support for using C++11 initializer lists to set Node and DataArray values from numeric arrays. See C++ tutorial docs (https://llnl-conduit.readthedocs.io/en/latest/tutorial_cpp_numeric.html#c-11-initializer-lists) for more details.
- Added a Node::describe() method. This method creates a new node that mirrors the current Node, however each leaf is replaced by summary stats and a truncated display of the values. For use cases with large leaves, printing the describe() output Node is much more helpful for debugging and understanding vs wall of text from other to_string() methods.
- Added conduit::utils::format methods. These methods use fmt to format strings that include fmt style patterns. The formatting arguments are passed as a conduit::Node tree. The
args
case allows named arguments (args passed as object) or ordered args (args passed as list). Themaps
case also supports named or ordered args and works in conjunction with amap_index
. Themap_index
is used to fetch a value from an array, or list of strings, which is then passed to fmt. Themaps
style of indexed indirection supports generating path strings for non-trivial domain partition mappings in Blueprint. This functionality is also available in Python, via theconduit.utils.format
method. - Added
DataArray::fill
method, which set all elements of a DataArray to a given value. - Added
Node::to_summary_string
methods, which allow you to create truncated strings that describe a node tree, control the max number of children and max number of elements shown. - Added python support for
Node.to_summary_string
Relay
- Added Relay IO Handle mode support for
a
(append) andt
(truncate). Truncate allows you to overwrite files when the handle is opened. The default is append, which preserves prior IO Handle behavior. - Added
conduit::relay::io::blueprint::save_mesh
variants, these overwrite existing files (providing relay save semantics) instead of adding mesh data to existing files. We recommend usingsave_mesh
for most uses cases, b/c in many caseswrite_mesh
to an existing HDF5 file set can fail due to conflicts with the current HDF5 tree. - Added
conduit::relay::io::blueprint::load_mesh
variants, these reset the passed node before reading mesh data (providing relay load semantics). We recommend usingload_mesh
for most uses cases. - Added
truncate
option toconduit::relay::io::blueprint::write_mesh
, this is used bysave_mesh
. - Improve capture and reporting of I/O errors in
conduit::relay::[mpi::]io::blueprint::{save_mesh|write_mesh}
. Now in the MPI case, If any rank fails to open or write to a file all ranks will throw an exception. - Added yaml detection support to
conduit::relay::io:identify_file_type
.
Blueprint
- Added
conduit::blueprint::mesh::matset::to_silo()
which converts a valid blueprint matset to a node that contains arrays that follow Silo's sparse mix slot volume fraction representation. - Added
conduit::blueprint::mesh::field::to_silo()
which converts a valid blueprint field and matset to a node that contains arrays that follow Silo's sparse mix slot volume fraction representation. - Added
material_map
toconduit::blueprint::mesh:matset::index
, to provide an explicit material name to id mapping. - Added
mat_check
field toblueprint::mesh::examples::venn
. This field encodes the material info in a scalar field and in thematset_values
in a way that can be used to easily compare and verify proper construction in other tools.
Fixed
Relay
- Fixed bug in the Relay IOHandle Basic that would create unnecessary "_json" schema files to be written to disk upon open().
Removed
General
- Removed
Node::fetch_child
andSchema::fetch_child
methods for v0.7.0. (Deprecated in v0.6.0 -- preferfetch_existing
) - Removed
Schema::to_json
method variants withdetailed
for v0.7.0. (Deprecated in v0.6.0 -- prefer standardto_json
) - Removed
Schema::save
method variant withdetailed
for v0.7.0. (Deprecated in v0.6.0 -- prefer standardsave
) - The
master
branch was removed from GitHub (Deprecated in v0.6.0 -- replaced by thedevelop
branch)
Relay
- Removed
conduit::relay::io_blueprint::save
methods for v0.7.0. (Deprecated in v0.6.0 -- preferconduit::relay::io::blueprint::save_mesh
)
0.6.0
0.6.0 Release Highlights
(adapted from Conduit's Changelog)
Added
General
- Added support for children with names that include
/
. Since slashes are part of Conduit's hierarchical path mechanism, you must use explicit methods (add_child(), child(), etc) to create and access children with these types of names. These names are also supported in all basic i/o cases (JSON, YAML, Conduit Binary). - Added Node::child and Schema::child methods, which provide access to existing children by name.
- Added Node::fetch_existing and Schema::fetch_existing methods, which provide access to existing paths or error when given a bad path.
- Added Node::add_child() and Node::remove_child() to support direct operations and cases where names have
/
s. - Added a set of conduit::utils::log::remove_* filtering functions, which process conduit log/info nodes and strip out the requested information (useful for focusing the often verbose output in log/info nodes).
- Added to_string() and to_string_default() methods to Node, Schema, DataType, and DataArray. These methods alias either to_yaml() or to_json(). Long term yaml will be preferred over json.
- Added helper script (scripts/regen_docs_outputs.py) that regenerates all example outputs used Conduit's Sphinx docs.
- Added to_yaml() and to_yaml_stream methods() to Schema, DataType, and DataArray.
- Added support for C++-style iterators on node children. You can now do
for (Node &node : node.children()) {}
. You can also donode.children.begin()
andnode.children.end()
to work with the iterators directly.
Relay
- Added an open mode option to Relay IOHandle. See Relay IOHandle docs (https://llnl-conduit.readthedocs.io/en/latest/relay_io.html#relay-i-o-handle-interface) for more details.
- Added the conduit.relay.mpi Python module to support Relay MPI in Python.
- Added support to write and read Conduit lists to HDF5 files. Since HDF5 Groups do not support unnamed indexed children, each list child is written using a string name that represents its index and a special attribute is written to the HDF5 group to mark the list case. On read, the special attribute is used to detect and read this style of group back into a Conduit list.
- Added preliminary support to read Sidre Datastore-style HDF5 using Relay IOHandle, those grouped with a root file.
- Added
conduit::relay::io::blueprint::read_mesh
functions, were pulled in from Ascent's Blueprint import logic. - Added
conduit::relay::mpi::wait
andconduit::relay::mpi::wait_all
functions. These functions consolidate the logic supporting bothisend
andirecv
requests.wait_all
supports cases where both sends and receives were posted, which is a common for non-trivial point-to-point communication use cases.
Blueprint
- Added support for sparse one-to-many relationships with the new
blueprint::o2mrelation
protocol. See theblueprint::o2mrelation::examples::uniform
example for details. - Added sparse one-to-many, uni-buffer, and material-dominant specification support to Material sets. See the Material sets documentation
(https://llnl-conduit.readthedocs.io/en/latest/blueprint_mesh.html#material-sets) for more details. - Added support for Adjacency sets for Structured Mesh Topologies. See the
blueprint::mesh::examples::adjset_uniform
example. - Added
blueprint::mesh::examples::julia_nestsets_simple
andblueprint::mesh::examples::julia_nestsets_complex
examples represent Julia set fractals using patch-based AMR meshes and the Mesh Blueprint Nesting Set protocol. See the Julia AMR Blueprint docs
(https://llnl-conduit.readthedocs.io/en/latest/blueprint_mesh.html#julia-amr-examples) for more details. - Added
blueprint::mesh::examples::venn
example that demonstrates different ways to encode volume fraction based multi-material fields. See the Venn Blueprint docs
(https://llnl-conduit.readthedocs.io/en/latest/blueprint_mesh.html#venn) for more details. - Added
blueprint::mesh::number_of_domains
property method for trees that conform to the mesh blueprint. - Added MPI mesh blueprint methods,
blueprint::mpi::mesh::verify
andblueprint::mpi::mesh::number_of_domains
(available in theconduit_blueprint_mpi
library) - Added
blueprint::mpi::mesh::examples::braid_uniform_multi_domain
andblueprint::mpi::mesh::examples::spiral_round_robin
distributed-memory mesh examples to theconduit_blueprint_mpi
library. - Added
state/path
to the Mesh Blueprint index, needed for consumers to know the proper path to read extended state info (such asdomain_id
)
Fixed
General
- Updated to newer BLT to resolve BLT/FindMPI issues with rpath linking commands when using OpenMPI.
- Fixed internal object name string for the Python Iterator object. It used to report
Schema
, which triggered both puzzling and concerned emotions. - Fixed a bug with
Node.set
in the Python API that undermined setting NumPy arrays with sliced views and complex striding. General slices should now work withset
. No changes to theset_external
case, which requires 1-D effective striding and throws an exception when more complex strides are presented. - Fixed a bug with auto detect of protocol for Node.load
- Fixed bugs with auto detect of protocol for Node.load and Node.save in the Python interface
Relay
- Use H5F_ACC_RDONLY in relay::io::is_hdf5_file to avoid errors when checking files that already have open HDF5 handles.
- Fixed compatibility check for empty Nodes against HDF5 files with existing paths
Changed
General
- Conduit's main git branch was renamed from
master
todevelop
. To allow time for folks to migrate, themaster
branch is active but frozen and will be removed during the0.7.0
release. - We recommend a C++11 (or newer) compiler, support for older C++ standards is deprecated and will be removed in a future release.
- Node::fetch_child and Schema::fetch_child are deprecated in favor of the more clearly named Node::fetch_existing and Schema::fetch_existing. fetch_child variants still exist, but will be removed in a future release.
- Python str() methods for Node, Schema, and DataType now use their new to_string() methods.
- DataArray::to_json(std::ostring &) is deprecated in favor DataArray::to_json_stream. to_json(std::ostring &) will be removed in a future release.
- Schema::to_json and Schema::save variants with detailed (bool) arg are deprecated. The detailed arg was never used. These methods will be removed in a future release.
- Node::print() now prints yaml instead of json.
- The string return variants of
about
methods now return yaml strings instead of json strings. - Sphinx Docs code examples and outputs are now included using start-after and end-before style includes.
- Schema to_json() and to_json_stream() methods were expanded to support indent, depth, pad and end-of-element args.
- In Python, conduit.Node() repr now returns the YAML string representation of the Node. Perviously verbose
conduit_json
was used, which was overwhelming. - conduit.about() now reports the git tag if found, and
version
was changed to add git sha and status (dirty) info to avoid confusion between release and development installs.
Relay
- Provide more context when a Conduit Node cannot be written to a HDF5 file because it is incompatible with the existing HDF5 tree. Error messages now provide the full path and details about the incompatibility.
conduit::relay::io_blueprint::save
functions are deprecated in favor ofconduit::relay::io::blueprint::write_mesh
conduit::relay::io::blueprint::write_mesh
functions were pulled in from Ascent's Blueprint export logic.conduit_relay_io_mpi
lib now depends onconduit_relay_io
. Due to this change, a single build supports either ADIOS serial (no-mpi) or ADIOS with MPI support, but not both. If conduit is configured with MPI support, ADIOS MPI is used.- The functions
conduit::relay::mpi::wait_send
andconduit::relay::mpi::wait_recv
now useconduit::relay::mpi::wait
. The functionswait_send
andwait_recv
exist to preserve the old API, there is no benefit to use them overwait
. - The functions
conduit::relay::mpi::wait_all_send
andconduit::relay::mpi::wait_all_recv
now useconduit::relay::mpi::wait_all
. The functionswait_all_send
andwait_all_recv
exist to preserve the old API, there is no benefit to use them overwait_all
.
Blueprint
- Refactored the Polygonal and Polyhedral mesh blueprint specification to leverage one-to-many concepts and to allow more zero-copy use cases.
- The
conduit_blueprint_mpi
library now depends onconduit_relay_mpi
. - The optional Mesh Blueprint structured topology logical element origin is now specified using
{i,j,k}
instead of{i0,j0,k0}
.
0.5.1
0.5.1 Release Highlights
(adapted from Conduit's Changelog)
Added
General
- Added Node::parse() method, (C++, Python and Fortran) which supports common json and yaml parsing use cases without creating a generator instance.
- Use FOLDER target property to group targets for Visual Studio
- Added Node load(), and save() support to the C and Fortran APIs
Changed
General
- Node::load() and Node::save() now auto detect which protocol to use when protocol argument is an empty string
- Changed Node::load() and Node::save() default protocol value to empty (default now is to auto detect)
- Changed Python linking strategy to defer linking for our compiler modules
- Conduit Error Exception message strings now print cleaner (avoiding nesting doll string escaping headaches)
- Build system improvements to support conda-forge builds for Linux, macOS, and Windows
Fixed
General
- Fixed install paths for CMake exported target files to follow standard CMake find_package() search conventions. Also perserved duplicate files to support old import path structure for this release.
- python: Fixed Node.set_external() to accept conduit nodes as well as numpy arrays
- Fixed dll install locations for Windows
0.5.0
0.5.0 Release Highlights
(adapted from Conduit's Changelog)
Added
-
Added support to parse YAML into Conduit Nodes and to create YAML from Conduit Nodes. Support closely follows the "json" protocol, making similar choices related to promoting YAML string leaves to concrete data types.
-
Added several more Conduit Node methods to the C and Fortran APIs. Additions are enumerated here: #426
-
Added Node set support for Python Tuples and Lists with numeric and string entires
-
Added Node set support for Numpy String Arrays. String Arrays become Conduit lists with child char8_str arrays
-
Blueprint: Added support for a "zfparray" blueprint that holds ZFP compressed array data.
-
Blueprint: Added the the "specsets" top-level section to the Blueprint schema, which can be used to represent multi-dimensional per-material quantities (most commonly per-material atomic composition fractions).
-
Blueprint: Added explicit topological data generation functions for points, lines, and faces
-
Blueprint: Added derived topology generation functions for element centroids, sides, and corners
-
Blueprint: Added the basic example function to the conduit.mesh.blueprint.examples module
-
Relay: Added optional ZFP support to relay, that enables wrapping and unwraping zfp arrays into conduit Nodes.
-
Relay: Extended relay HDF5 I/O support to read a wider range of HDF5 string representations including H5T_VARIABLE strings.
-
Relay: Added is_open() method to IOHandle in the C++ and Python interfaces
Changed
-
Conduit's automatic build process (uberenv + spack) now defaults to using Python 3
-
Improved CMake export logic to make it easier to find and use Conduit install in a CMake-based build system. (See using-with-cmake example for new recipe)
-
Relay: Added file name information to Relay HDF5 error messages
Fixed
-
Fixed bug that caused memory access after free during Node destruction
-
Relay: Fixed crash with mpi broadcast_using_schema() when receiving tasks pass a non empty Node.
-
Relay: Fixed a few Windows API export issues for relay io
0.4.0
0.4.0 Release Highlights
(adapted from Conduit's Changelog)
Added
-
Added Generic IO Handle class (relay::io::IOHandle) with C++ and Python APIs, tests, and docs.
-
Added
rename_child
method to Schema and Node -
Added generation and install of conduit_config.mk for using-with-make example
-
Added datatype helpers for long long and long double
-
Added error for empty path fetch
-
Added C functions for setting error, warning, info handlers.
-
Added limited set of C bindings for DataType
-
Added C bindings for relay IO
-
Added several more functions to conduit node python interfaces
-
Blueprint: Added implicit point topology docs and example
-
Blueprint: Added julia and spiral mesh bp examples
-
Blueprint: Added mesh topology transformations to blueprint
-
Blueprint: Added polygonal mesh support to mesh blueprint
-
Blueprint: Added verify method for mesh blueprint nestset
-
Relay: Added ADIOS Support, enabling ADIOS read and write of Node objects.
-
Relay: Added a relay::mpi::io library that mirrors the API of relay::io, except that all functions take an MPI communicator. The functions are implemented in parallel for the ADIOS protocol. For other protocols, they will behave the same as the serial functions in relay::io. For the ADIOS protocol, the save() and save_merged() functions operate collectively within a communicator to enable multiple MPI ranks to save data to a single file as separate "domains".
-
Relay: Added an add_time_step() function to that lets the caller append data collectively to an existing ADIOS file
-
Relay: Added a function to query the number of time steps and the number of domains in a ADIOS file.
-
Relay: Added versions of save and save_merged that take an options node.
-
Relay: Added C API for new save, save_merged functions.
-
Relay: Added method to list an HDF5 group's child names
-
Relay: Added save and append methods to the HDF5 I/O interface
-
Relay: Added docs and examples for relay io
Changed
-
Changed mapping of c types to bit-width style to be compatible with C++11 std bit-width types when C++11 is enabled
-
Several improvements to uberenv, our automated build process, and building directions
-
Upgraded the type system with more explicit signed support
-
Relay: Improvements to the Silo mesh writer
-
Relay: Refactor to support both relay::io and relay::mpi::io namespaces.
-
Relay: Refactor to add support for steps and domains to I/O interfaces
-
Relay: Changed to only use
libver latest
setting for for hdf5 1.8 to minimize compatibility issues
Fixed
-
Fixed bugs with std::vector gap methods
-
Fixed A few C function names in conduit_node.h
-
Fixed bug in python that was requesting unsigned array for signed cases
-
Fixed issue with Node::diff failing for string data with offsets
-
Fixes for building on BlueOS with the xl compiler
-
Blueprint: Fixed validity status for blueprint functions
-
Blueprint: Fixed improper error reporting for Blueprint references
-
Relay: Relay I/O exceptions are now forwarded to python
-
Relay: Fixed MPI send_with_schema bug when data was compact but not contiguous
-
Relay: Switched to use MPI bit-width style data type enums in
relay::mpi
0.3.1
0.3.1 Release Highlights
General:
- Added new
Node::diff
andNode::diff_compatible
methods - Updated uberenv to use a newer spack and removed several custom packages
- C++
Node::set
methods now take const pointers for data - Added Python version of basic tutorial
- Expanded the Node Python Capsule API
- Added Python API bug fixes
- Fixed API exports for static libs on Windows
Blueprint:
-
Mesh Protocol
- Removed unnecessary state member in the braid example
-
Added Multi-level Array Protocol (conduit::blueprint::mlarray)
Relay:
- Added bug fixes for Relay HDF5 support on Windows