Code Examples
A repository of 155 code examples for BeepBeep
FunctionChain.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 functions;
19 
20 import ca.uqac.lif.cep.Connector;
21 import ca.uqac.lif.cep.Pullable;
22 import ca.uqac.lif.cep.functions.ApplyFunction;
23 import ca.uqac.lif.cep.tmf.QueueSource;
24 import ca.uqac.lif.cep.util.Numbers;
25 
26 /**
27  * Pipe multiple
28  * {@link ca.uqac.lif.cep.functions.ApplyFunction ApplyFunction} processors
29  * to perform a more complex computation over a stream.
30  * The chain of processors in this example can be represented
31  * graphically as:
32  * <p>
33  * <img src="./doc-files/functions/FunctionChain.png" alt="Processor graph">
34  * @author Sylvain HallĂ©
35  * @difficulty Easy
36  */
37 public class FunctionChain
38 {
39  public static void main (String[] args)
40  {
41  ///
42  QueueSource source1 = new QueueSource().setEvents(2, 7, 1, 8, 3);
43  QueueSource source2 = new QueueSource().setEvents(3, 1, 4, 1, 6);
44  QueueSource source3 = new QueueSource().setEvents(1, 1, 2, 3, 5);
45  ApplyFunction add = new ApplyFunction(Numbers.addition);
46  Connector.connect(source1, 0, add, 0);
47  Connector.connect(source2, 0, add, 1);
48  ApplyFunction mul = new ApplyFunction(Numbers.multiplication);
49  Connector.connect(source3, 0, mul, 0);
50  Connector.connect(add, 0, mul, 1);
51  Pullable p = mul.getPullableOutput();
52  for (int i = 0; i < 5; i++)
53  {
54  float x = (Float) p.pull();
55  System.out.println("The event is: " + x);
56  }
57  ///
58  }
59 }
Pipe multiple ApplyFunction processors to perform a more complex computation over a stream...