Postprocesses are a feature which was recently added to MLonMCU which is intended to help with automating common tasks for benchmarking and visualizations. These processes mainly operate on the Rows and columns of the report generated after a completed run or session. Their complexity can vary from very minimal utilities to powerful evaluation scripts.
Currently postprocesses can be applied at two different stages:
- after a
Run
which means you are only operating on a single row of a report - or after a
Session
which has a variety of rows and columns
In the future it might be possible to also insert postprocesses at earlier stages.
AverageCyclesPostprocess
: average over a number of similar runs (useful for non-deterministic targets)DetailedCyclesPostprocess
: determine the number of cycles required for the model initialization and invocation from two runs with a different--num
valueFlattenConfig
: Turn each dictionary item in theConfig
column into a new Column which makes their values filterableFlattenFeatures
: Convert the list of enabled features into one column per feature with boolean values in every row
To extend the list of predefined post-processes with a custom implementation a Python class has to be developed as follows:
TODO
from mlonmcu.postproces import Postprocess, ProcessStage
class MyPostprocess(Postprocess):
def __init__(self, features=None, config=None):
super().__init__("foo", stage=ProcessStage.SESSION, features=features, config=config)
def process(self, data):
pass
It is also possible to inherit another base-class such "AggregatePostprocess" to reuse some of their functionalities.
To use the newly implemented process, it needs to be registered. There are two approaches to do so:
-
Call the registration function manually:
from mlonmcu.postprocess import register_postprocess register_postprocess("foo", MyPostprocess)
-
Use a decorator for the registration. However this option is only available when playing the new postprocess in
mlonmcu/postprocess/postprocesses.py
as the decorators are only processed in this file.@register_postprocess("foo") class MyPostprocess(Postprocess): ...
TODO: implement the registration process!