Code Examples
A repository of 155 code examples for BeepBeep
CumulativeSum.java
1 /*
2  BeepBeep, an event stream processor
3  Copyright (C) 2008-2016 Sylvain HallĂ©
4 
5  This program is free software: you can redistribute it and/or modify
6  it under the terms of the GNU Lesser General Public License as published
7  by the Free Software Foundation, either version 3 of the License, or
8  (at your option) any later version.
9 
10  This program is distributed in the hope that it will be useful,
11  but WITHOUT ANY WARRANTY; without even the implied warranty of
12  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13  GNU Lesser General Public License for more details.
14 
15  You should have received a copy of the GNU Lesser General Public License
16  along with this program. If not, see <http://www.gnu.org/licenses/>.
17  */
18 package basic;
19 
20 import ca.uqac.lif.cep.Connector;
21 import ca.uqac.lif.cep.Pullable;
22 import ca.uqac.lif.cep.functions.Cumulate;
23 import ca.uqac.lif.cep.functions.CumulativeFunction;
24 import ca.uqac.lif.cep.tmf.QueueSource;
25 import ca.uqac.lif.cep.util.Numbers;
26 
27 /**
28  * Use a cumulative processor to compute the sum of all events
29  * received so far.
30  * Graphically, this chain of processors can be represented as:
31  * <p>
32  * <img src="./doc-files/basic/CumulativeSum.png" alt="Processor graph">
33  *
34  * @author Sylvain HallĂ©
35  * @difficulty Easy
36  */
37 public class CumulativeSum
38 {
39  public static void main(String[] args)
40  {
41  ///
42  QueueSource source = new QueueSource().setEvents(1, 2, 3, 4, 5, 6);
43  Cumulate sum = new Cumulate(
44  new CumulativeFunction<Number>(Numbers.addition));
45  Connector.connect(source, sum);
46  Pullable p = sum.getPullableOutput();
47  for (int i = 0; i < 5; i++)
48  {
49  System.out.println("The event is: " + p.pull());
50  }
51  ///
52  }
53 
54 }
Use a cumulative processor to compute the sum of all events received so far.