Skip to content

Commit

Permalink
PRJ: start hosting data on quilt #55
Browse files Browse the repository at this point in the history
  • Loading branch information
DavidLP committed Sep 19, 2017
1 parent ca427c6 commit 23b92ed
Show file tree
Hide file tree
Showing 3 changed files with 41 additions and 0 deletions.
2 changes: 2 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -53,3 +53,5 @@ data_clusterizer.cpp
testbeam_analysis/examples/data/*.h5
# Temp files
tmp*.*
# Data files
quilt_packages/*
1 change: 1 addition & 0 deletions requirements.txt
Original file line number Diff line number Diff line change
Expand Up @@ -9,3 +9,4 @@ pixel_clusterizer>=3.0 # to cluster pixel hits
pylandau>2.0.0 # for charge deposition simulation
progressbar-latest # to show a progress bar
numexpr # for fast c compiled loops on numpy arrays
quilt # Online data storage for example data and test fixtures
38 changes: 38 additions & 0 deletions testbeam_analysis/tools/test_tools.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
''' Helper functions for the unittests are defined here.
'''

import logging
import os
import inspect
import itertools
Expand Down Expand Up @@ -227,3 +228,40 @@ def check_with_fixture(function, **kwargs):
data = _call_function_with_args(function, **kwargs)

return np.allclose(data_fixture, data)


def install_quilt_data(package, hash):
''' Download data package from https://quiltdata.com and install
package : str
Package string in USER/PACKAGE format
'''

try:
import quilt
from quilt.tools import command, store
except ImportError:
logging.error('Install quilt to access data packa %s from https://quiltdata.com', package)

owner, pkg, _ = command._parse_package(package, allow_subpath=True)
s = store.PackageStore()
existing_pkg = s.get_package(owner, pkg)

if existing_pkg:
return True
quilt.install(package, hash=hash)
return s.get_package(owner, pkg)


def get_quilt_data(root, name):
''' Access quilt node data by name.
root: group node that has data node with name
name: name of node
'''

for n, node in root._items():
if n == name:
return node._data()

raise ValueError('Data %s not found', name)

0 comments on commit 23b92ed

Please sign in to comment.