use super::{EventProcessorTraining, ItemLazy, LearnerEvent, MetricsTraining};
use crate::{
metric::store::{EpochSummary, EventStoreClient, Split},
renderer::cli::CliMetricsRenderer,
};
use std::sync::Arc;
#[allow(dead_code)]
#[derive(new)]
pub(crate) struct MinimalEventProcessor<T: ItemLazy, V: ItemLazy> {
metrics: MetricsTraining<T, V>,
store: Arc<EventStoreClient>,
}
impl<T: ItemLazy, V: ItemLazy> EventProcessorTraining<LearnerEvent<T>, LearnerEvent<V>>
for MinimalEventProcessor<T, V>
{
fn process_train(&mut self, event: LearnerEvent<T>) {
match event {
LearnerEvent::Start => {
let definitions = self.metrics.metric_definitions();
self.store
.add_event_train(crate::metric::store::Event::MetricsInit(definitions));
}
LearnerEvent::ProcessedItem(item) => {
let item = item.sync();
let metadata = (&item).into();
let update = self.metrics.update_train(&item, &metadata);
self.store
.add_event_train(crate::metric::store::Event::MetricsUpdate(update));
}
LearnerEvent::EndEpoch(epoch) => {
self.metrics.end_epoch_train();
self.store
.add_event_train(crate::metric::store::Event::EndEpoch(EpochSummary::new(
epoch,
Split::Train,
)));
}
LearnerEvent::End(_summary) => {} }
}
fn process_valid(&mut self, event: LearnerEvent<V>) {
match event {
LearnerEvent::Start => {} LearnerEvent::ProcessedItem(item) => {
let item = item.sync();
let metadata = (&item).into();
let update = self.metrics.update_valid(&item, &metadata);
self.store
.add_event_valid(crate::metric::store::Event::MetricsUpdate(update));
}
LearnerEvent::EndEpoch(epoch) => {
self.metrics.end_epoch_valid();
self.store
.add_event_valid(crate::metric::store::Event::EndEpoch(EpochSummary::new(
epoch,
Split::Valid,
)));
}
LearnerEvent::End(_) => {} }
}
fn renderer(self) -> Box<dyn crate::renderer::MetricsRenderer> {
Box::new(CliMetricsRenderer::new())
}
}