HDF5 Node.js

Node.js is a JavaScript runtime built on Chrome's V8 JavaScript engine. Using Node.js, it is possible to access HDF5 data in JavaScript language. Node.js package ecosystem, npm, provides HDF5 package as well as other packages that can run web service and visualize data on global maps.

Download

You can download the latest Node.js from here.

Installation

Install Node.js first and use npm command line tool to install hdf5 package as shown below.

$npm install hdf5

Optionally, you can download HDF5 module source code from here in case your npm fails to install hdf5 package automatically.

Usage

Usage is similar to any other scripting laguange (e.g., Python and MATLAB) usage. First, you declare required modules that call hdf5 package.

const Access = require('hdf5/lib/globals.js').Access; var hdf5 = require('hdf5').hdf5; var h5lt = require('hdf5').h5lt;

Second, you open an HDF5 file, open a group, and read data from a specific dataset under the group.

file = new hdf5.File('oco2_L2StdND_03945a_150330_B6000_150331024816.h5', Access.ACC_RDONLY); group = file.openGroup('/RetrievalGeometry'); var readBufferLat = h5lt.readDataset(group.id, 'retrieval_latitude');

Finally, you close all the resources at the end.

group.close(); file.close();

Visualization

Node.js provides many npm packages that allow you to plot data. We demonstrate two use cases with Canvas and PlanetaryJS packages. In our examples, Canvas is used for generating a PNG plot and PlanetaryJS is used for generating HTML5 served by Node.js web server.

Static Image

Although JavaScript is mainly for web browser, it is possible to generate a static PNG image as shown below using Node.js.

The complete JavaScript code is test.js. The sample HDF5 file is oco2_L2StdND_03945a_150330_B6000_150331024816.h5. To run the script, please download world-110m.json as well and run as follows.

$node test.js Then, it will create test.png file which is shown above.

Web Service

With Node.js, running a custom web service is easy and you can visualize HDF5 data from your web sever as shown below.

The above service reads the first lat/lon data point from OCO-2 HDF5 data, modifies the template HTML file that has PlanetaryJS, and sends the updated HTML file via HTTP on port 3000. The server code is index.js and the template HTML file is index.html (use right mouse click to download and save the HTML file). The sample HDF5 file is oco2_L2StdND_03945a_150330_B6000_150331024816.h5. To run the server script, please download world-110m.json as well, put all 4 files (index.js, index.html, sample oco2 HDF5, and world-110m.json) on the same directory, and run sever script as follows.

$node index.js Then, open an web browser and type URL http://localhost:3000. You will get the same screen as shown above.

See Also

  1. OCO-2 Comprehensive Examples


Last modified: 09/29/2017
About Us | Contact Info | Archive Info | Disclaimer
Sponsored by Subcontract number 4400528183 under Raytheon Contract number NNG15HZ39C, funded by NASA / Maintained by The HDF Group