From 27b07d75ace268ea680a66ef905c02361ccc18b5 Mon Sep 17 00:00:00 2001 From: Frank Baker Date: Mon, 23 Jun 2003 15:32:50 -0500 Subject: [svn-r7085] Purpose: Complete "compression" to "filters" revisions. H5Zregister review feedback. Description: Intro -- Finish the "Compression" ==> "Filters" changes. H5Zregister -- Clarify that the can_apply_func and set_local_func can be set to null. -- Define value of filter_id -- Other smaller revisions. (all based on review feedback) Platforms tested: IE 5, Safari --- doc/html/RM_H5Z.html | 35 ++++++++++++++++++++--------------- 1 file changed, 20 insertions(+), 15 deletions(-) diff --git a/doc/html/RM_H5Z.html b/doc/html/RM_H5Z.html index a6ebe20..f3f3964 100644 --- a/doc/html/RM_H5Z.html +++ b/doc/html/RM_H5Z.html @@ -74,15 +74,15 @@ and customized raw data processing during I/O operations. HDF5 is distributed with a small set of standard filters such as compression (gzip and a shuffling algorithm) and error checking (Fletcher32 checksum). -For further flexibility, the library includes tools enabling a +For further flexibility, the library allows a user application to extend the pipeline through the creation and registration of customized filters.

As mentioned above, one set of filters distributed with HDF5 provides built-in methods for raw data compression. The flexibility of the filter pipeline implementation enables the -definition of additional compression methods by a user application. -A compression method
+definition of additional filters by a user application. +A filter
 —  is associated with a dataset when the dataset is created,
 —  @@ -91,9 +91,9 @@ A compression method
 —  is applied independently to each chunk of the dataset.

-The HDF5 library does not support compression for contiguous datasets +The HDF5 library does not support filters for contiguous datasets because of the difficulty of implementing random access for partial I/O. -Compact dataset compression is not supported because it would not produce +Compact dataset filters are not supported because it would not produce significant results.

See The Dataset Interface (H5D) @@ -146,16 +146,16 @@ facilitate moving easily between them. HDF5 library.

Making a new filter available to an application is a two-step - process. The first step is to define - the three filter callback filter functions described below: - can_applyr_func, set_local_func, and + process. The first step is to write + the three filter callback functions described below: + can_apply_func, set_local_func, and filter_func. - This step can be skipped only when the filter is predefined, as is - the case with the Fletcher32 checksum and shuffle filters that - are distributed with the HDF5 Library. This call to H5Zregister, registering the filter with the library, is the second step. + The can_apply_func and set_local_func + fields can be set to NULL + if they are not required for the filter being registered.

H5Zregister accepts a single parameter, the filter_class data structure, @@ -172,13 +172,18 @@ facilitate moving easily between them.

filter_id is the identifier for the new filter. + This is a user-defined value between + H5Z_FILTER_RESERVED and H5Z_FILTER_MAX, + both of which are defined in the HDF5 source file + H5Zpublic.h.

- comment is used for debugging and may be - the null pointer. + comment is used for debugging, + may contain a descriptive name for the filter, + and may be the null pointer.

can_apply_func, described in detail below, is a user-defined callback function which determines whether - the combination of the dataset creation property list setting, + the combination of the dataset creation property list values, the datatype, and the dataspace represent a valid combination to apply this filter to.

@@ -257,7 +262,7 @@ facilitate moving easily between them. space_id, a dataspace describing the chunk (for chunked dataset storage), which should also not be modified.

- The set local callback must set any parameters that are + The set local callback must set any filter parameters that are specific to this dataset, based on the combination of the dataset creation property list values, the datatype, and the dataspace. For example, some filters perform different actions based on -- cgit v0.12