-
Notifications
You must be signed in to change notification settings - Fork 130
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
how to implement non-invertible user-defined aggregates? #130
Comments
You can start with a simple approach like this:
Then check if you can optimize further by representing the state in a more concise (less memory) form. |
Thanks for the reply, and it is very helpful, and I successfully implement the FIR operator according to your suggestion. |
In addition to Trill’s built-in aggregates (i.e., Count, Sum, Average, Max, Min, TopK), Trill provides a
framework for users to create their own custom aggregates by implementing the IAggregate interface.
However, it looks to me that Trill assumes the user-defined aggregates are invertible and associative, as it requires users to specify the
Deaccumulate
and theDifference
methods.My question is "Is there a way to implement an aggregate that is meant to be non-invertible in Trill?"
More specifically, how can we implement an operator such as finite impulse response (FIR) filtering that follows the computation as below:
{val: double, ts: int}
, where for simplicity,ts = 1,2,3,4,...
that represents the timestamp of the measurement, andval_{t}
is the value of the measurement at the timet
.out_{t} = f1*val_{t-2} + f2*val_{t-1} + f3*val_{t} + f4*val_{t+1} + f5*val_{t+2}
.In general, the FIR filtering computes the dot product of FIR parameters and every five elements in the stream. As the first step, I think a hopping window shall be applied to the input stream. But I am stuck at designing a user-defined aggregate to address the remaining computations.
Can anyone help me to get through this problem? I will really appreciate it.
The text was updated successfully, but these errors were encountered: