Simple and composable metric tracking and logging for ML
Project description
Demetric
Dead simple standard for metric logging
Logging
import demetric as dm
metrics = dm.Metrics.new('metrics/gpt2-3')
metrics.log('loss', value=loss, step=step)
metrics.log('accuracy', value=acc, step=step)
# ...
Creates:
runs/
gpt2-3/
loss.csv
accuracy.csv
Reading
# single metrics
metrics = dm.Metrics('metrics/run1.0')
metrics.read('loss') # pd.DataFrame
# all metrics
metrics.read() # pd.DataFrame with a column per metric
# comparing runs
runs = { run: dm.Metrics(run) for run in ['metrics/version1', 'metrics/version2'] }
df = dm.compare(runs, 'loss') # pd.DataFrame with columns ("loss_run1.0", "loss_run1.1", ...)
# concatenating runs (i.e. they're the same experiment but trained by steps or something)
runs = [dm.Metrics(run) for run in ['metrics/part1', 'metrics/part2']]
df = dm.concat(runs, 'loss') # pd.DataFrame with cumulative step indices
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
demetric-0.1.13.tar.gz
(3.3 kB
view hashes)
Built Distribution
Close
Hashes for demetric-0.1.13-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2bc3bcf352dd9b5b4448b139d3ee9076302c98dbe585aa6cc3056bc4bb06ba7d |
|
MD5 | 3682a20e43bda5c79c467c4dc870815e |
|
BLAKE2b-256 | 829e84908304f7dfdb10d4052d09ca4e910d0eb8ecc1391fa13030820d2f1a80 |