mitsuba/data/scripts/rendertime.py

41 lines
1.1 KiB
Python
Raw Permalink Normal View History

#!/usr/bin/env python
2014-04-15 05:54:07 +08:00
import subprocess, sys, re
if len(sys.argv) == 1:
print('rendertime.py: Simple utility to extract the rendering time of an EXR file created using Mitsuba')
print('Syntax: rendertime.py <one or more EXR files>')
for arg in sys.argv[1:]:
sys.stdout.write("%s: " % arg)
p = subprocess.Popen(["exrheader", arg], stdout=subprocess.PIPE, stderr=subprocess.PIPE)
matches = re.findall('Render time: ([^\n]*)', p.communicate()[0])
if len(matches) != 1:
sys.stdout.write('error reading metadata!\n')
continue
value = matches[0]
units = [
['d', 60*60*24],
['h', 60*60],
['m', 60],
['s', 1],
['ms', 0.001]
2014-04-15 05:54:07 +08:00
];
for unit in units:
if value[-len(unit[0]):] == unit[0]:
value = float(value[0:-len(unit[0])]) * unit[1]
2014-04-15 05:54:07 +08:00
break
force = False
for unit in units:
if value > unit[1] or force:
amount = int(value / unit[1])
value -= amount * unit[1]
force = True
sys.stdout.write('%i%s ' % (amount, unit[0]))
sys.stdout.write('\n')