Source code for retentioneering.eventstream.helpers.add_negative_events_helper
from __future__ import annotations
from typing import Callable, List, Optional
from retentioneering.backend.tracker import track
from ..types import EventstreamType
class AddNegativeEventsHelperMixin:
[docs] @track( # type: ignore
tracking_info={"event_name": "helper"},
scope="add_negative_events",
event_value="combine",
allowed_params=[
"targets",
"func",
],
)
def add_negative_events(self, targets: List[str], func: Optional[Callable] = None) -> EventstreamType:
"""
A method of ``Eventstream`` class that creates new synthetic
events in paths of all users having the specified events - ``negative_target_RAW_EVENT_NAME``.
Parameters
----------
See parameters description
:py:class:`.AddNegativeEvents`
Returns
-------
Eventstream
Input ``eventstream`` with new synthetic events.
"""
# avoid circular import
from retentioneering.data_processors_lib import (
AddNegativeEvents,
AddNegativeEventsParams,
)
from retentioneering.preprocessing_graph import PreprocessingGraph
from retentioneering.preprocessing_graph.nodes import EventsNode
p = PreprocessingGraph(source_stream=self) # type: ignore
params: dict[str, list[str] | Callable] = {"targets": targets}
if func:
params["func"] = func
node = EventsNode(processor=AddNegativeEvents(params=AddNegativeEventsParams(**params))) # type: ignore
p.add_node(node=node, parents=[p.root])
result = p.combine(node)
del p
return result