Code Examples
A repository of 155 code examples for BeepBeep
ToListExample.java
1 /*
2  BeepBeep, an event stream processor
3  Copyright (C) 2008-2018 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 util;
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.Bags;
25 
26 /**
27  * Create a stream of lists from the input of multiple processors,
28  * using the {@link ca.uqac.cep.util.Bags.ToList ToList} function.
29  * Graphically, this chain of processors can be represented as:
30  * <p>
31  * <img src="./doc-files/util/ToListExample.png" alt="Processor graph">
32  * <p>
33  * The output of this program is:
34  * <pre>
35  * [3, 2, 1]
36  * [1, 7, 1]
37  * [4, 1, 2]
38  * [1, 8, 3]
39  * </pre>
40  * @author Sylvain HallĂ©
41  *
42  */
43 public class ToListExample
44 {
45  public static void main(String[] args)
46  {
47  ///
48  QueueSource src1 = new QueueSource().setEvents(3, 1, 4, 1, 6);
49  QueueSource src2 = new QueueSource().setEvents(2, 7, 1, 8);
50  QueueSource src3 = new QueueSource().setEvents(1, 1, 2, 3, 5);
51  ApplyFunction to_list = new ApplyFunction(
52  new Bags.ToList(Number.class, Number.class, Number.class));
53  Connector.connect(src1, 0, to_list, 0);
54  Connector.connect(src2, 0, to_list, 1);
55  Connector.connect(src3, 0, to_list, 2);
56  Pullable p = to_list.getPullableOutput();
57  for (int i = 0; i < 4; i++)
58  {
59  System.out.println(p.pull());
60  }
61  ///
62  }
63 }
Create a stream of lists from the input of multiple processors, using the ToList function.