-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathparse.py
More file actions
42 lines (40 loc) · 1.82 KB
/
parse.py
File metadata and controls
42 lines (40 loc) · 1.82 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
import pandas as pd
import sqlite3
import json
from pathlib import Path
db_entries = []
files = Path("databases").glob("*.sqlite")
for file in files:
with sqlite3.connect(file) as conn:
cur = conn.cursor()
cur.execute("SELECT Entries.value, Results.field, Metrics.value, Compressors.config from Entries INNER JOIN Metrics on Entries.metric = Metrics.id INNER JOIN Results on Entries.result = Results.id INNER JOIN Compressors on Compressors.id = Results.compressor;")
for result in cur.fetchall():
metric, field_id, metric_name, config_json = result
config = json.loads(config_json)
abs_bound = config['/pressio:pressio:abs']
method = config['/pressio:pressio:metric']
compressor_name = config['/pressio:pressio:compressor']
if "ratio" not in metric_name:
continue
if method == "tao2019":
block_size = config['/pressio/tao2019:tao2019:block_size']['value']['values'][0]
block_count = config['/pressio/tao2019:tao2019:n']['value']
elif method == "sian2022":
block_size = config['/pressio/sian2022:sian2022:block_size']['value']
block_count = 0
elif method == "khan2023_sz3":
block_size = 0
block_count = config['/pressio/khan2023_sz3:khan2023_sz3:stride']['value']
db_entry = {
"compressor": compressor_name,
"metric": metric,
"method": method,
"field": field_id,
"abs_bound": abs_bound,
"block_size": block_size,
"block_count": block_count,
"filename": str(file),
}
db_entries.append(db_entry)
df = pd.DataFrame(db_entries)
df.to_csv("results.csv")