Skip to content

Hypergraph Exchange Format (HIF) definition and validator libraries

License

Notifications You must be signed in to change notification settings

Cobord/HIF_validators

 
 

Repository files navigation

A set of Hypergraph Exchange Format (HIF) specification & validators

(Work-in-progress)

Hypergraph Exchange Format (HIF) is a forthcoming standard for data exchange between the existing hypergaph libraries.

Initial assumptions about the core of the HIF data format:

{
"network-type": "undirected", # will indicate if directed or an asc
"metadata": {"name": "test"}, # library specific metadata to store with object
"incidences":[{"edge":edge_id, "node":node_id,...},...], # incidences are lists of records of edge node pairs along with the edge dependent node properties
"nodes":[{"node":node_id,...},...] # nodes and edges are lists of records
"edges":[{"edge":edge_id,...},...],
}
  • All fields are optional except for "incidences".
  • Keywords are indicated in the schema, these include:
    • incidences
    • nodes
    • edges
    • weight
    • network-type
    • network types : undirected, directed, asc
    • direction
    • direction keywords : head, tail
  • If a hypergraph is, for instance, directed, the edge direction will be contained in the incidences record with keyword "direction".
  • Isolated nodes and empty edges are entries in "nodes" and "edges" which are not present in the incidences.

Table of contents for this folder

This repository is organized into three folders:

  • examples: This folder contains examples of higher-order datasets in the HIF standard. For details of its contents, see the README.
  • schemas: This folder contains all schemas used for specifying the HIF standard. For details of its contents, see the README.
  • scripts: This folder contains scripts for checking that datasets match the HIF standard. For details of its contents, see the README.
  • validate_hif.py: This Python command line executable checks whether a JSON file matches the HIF standard. All errors print to the command line. More details on running this are in the next section.

Validate files against the HIF standard

validate_hif.py is an executable that checks whether a file follows the HIF standard. It can be run as follows:

python validate_hif.py <filename> [OPTIONS]

The only option is --silent, which suppresses all detailed warnings. Regardless, the script prints a 0 if the JSON file passes the HIF standard and 1 otherwise.

Validate files using HIF standard with fastjsonschema in python module

import fastjsonschema
import json

schema = json.load(open("hif_schema_v0.1.0.json","r"))
validator = fastjsonschema.compile(schema)
hiftext = json.load(open(filename,'r'))
validator(hiftext)

Hypergraph tools and packages represented

The authors, co-authors or contributors of the following software libraries are represented:

Contributors

This project is an ongoing colaborative work of the following people (alphabetical order):

About

Hypergraph Exchange Format (HIF) definition and validator libraries

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 62.6%
  • Jupyter Notebook 37.4%