Skip to content

Latest commit

 

History

History
111 lines (80 loc) · 4.58 KB

README.md

File metadata and controls

111 lines (80 loc) · 4.58 KB

Table of Contents

Project Overview

Project Name: Chapel Hypergraph Library (CHGL)

General Area or Topic of Investigation: High performance, parallel hypergraph metrics and algorithms

Travis CI Build Status: Build Status

Summary

Chapel Hypergraph Library (CHGL), a library for hypergraph computation in the emerging Chapel language. Hypergraphs generalize graphs, where a hypergraph edge can connect any number of vertices. Thus, hypergraphs capture high-order, high-dimensional interactions between multiple entities that are not directly expressible in graphs. CHGL is designed to provide HPC-class computation with high-level abstractions and modern language support for parallel computing on shared memory and distributed memory systems.

Environment Requirements

Programming Language: Chapel

Operating System & Version: Tested on Chapel Docker containers (Debian) and internal RHEL 7 system

Required Disk Space: Approx. 40mb for code repository and binaries

Dependencies

A compiled version of the Chapel programming language with is test virtual environment is all that is required to compile and test CHGL. Unit tests were run on the Travis CI continuous integration system using Chapel's Docker container (see included .travis.yml file for details).

Name Version Download Location Country of Origin Special Instructions
Chapel Release 1.19.0 https://github.com/chapel-lang/chapel USA Tested with release 1.19.0

Distribution Files

CHGL is released through a GitHub repository found at https://github.com/pnnl/chgl. No additional files are required.

Installation Instructions

Chapel

Chapel must be installed on the system before compiling and installing CHGL. The version required is documented above in Dependencies. Be sure to checkout the required branch, tag, or commit CHGL has been tested with as using a different version of Chapel may cause errors.

If a particular branch, tag, or commit is required, execute the following git command after cloning the Chapel GitHub repository:

git checkout <branch_name, tag_name, or commit_hash>

With the correct Chapel version checked out, continue by folloing the Chapel installation documented at https://chapel-lang.org/docs/usingchapel/QUICKSTART.html.

Alternatively if a release is used, a Chapel Docker image found at https://hub.docker.com/r/chapel/chapel/.

CHGL

In the future, CHGL will be compiled and packaged into a Mason library. For the time being, CHGL is used directly (see unit tests for examples). The code is compiled and tested simultaneously -- see the Test Cases section below for running the unit tests.

Also see the .travis.yml file for an example of our continuous integration build. Or view the current status at https://travis-ci.org/pnnl/chgl.

NOTE: The COMPOPTS files in test/unit and test/performance make use of --no-lifetime-checking --no-warnings for successful compilation. If you are compiling independent code that uses CHGL, be sure to use these options as well.

Test Cases

CHGL includes both unit & performance tests utilizing the start_test Python script supplied by Chapel. Change directories into test/unit or test/performance and execute start_test to run the tests. View the unit test README or perfomrance test README for more information.

The unit tests are best run to verify the CHGL build. Performance tests were not routinely run by a continuous integration environment and were written targeting particular hardware systems, leading them to be not as useful for verifying a CHGL build.

User Guide

A full User Guide is still under development; however, the CHGL API documentation can be generated using Chapel's chpldoc application at the root of the source tree. E.g., chpldoc src/*/*.chpl.