Code Examples
A repository of 155 code examples for BeepBeep
PipingBinaryWait.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 java.util.Queue;
21 
22 import ca.uqac.lif.cep.Adder;
23 import ca.uqac.lif.cep.Connector;
24 import ca.uqac.lif.cep.Pullable;
25 import ca.uqac.lif.cep.UtilityMethods;
26 import ca.uqac.lif.cep.tmf.QueueSource;
27 
28 /**
29  * Pipe processors together using the {@link ca.uqac.lif.cep.Connector Connector}
30  * object.
31  * The chain of processors in this example is almost identical to
32  * {@link PipingBinary}, and can be represented graphically as:
33  * <p>
34  * <img src="./doc-files/basic/PipingBinaryWait.png" alt="Processor graph">
35  * <p>
36  * The difference is that the first queue source has been replaced by a
37  * "slow" queue source, that waits 5 seconds before outputting an event.
38  * @see PipingBinary
39  * @author Sylvain HallĂ©
40  * @difficulty Easy
41  */
42 public class PipingBinaryWait
43 {
44  public static void main (String[] args)
45  {
46  ///
47  SlowQueueSource source1 = new SlowQueueSource();
48  source1.setEvents(2, 7, 1, 8, 3);
49  QueueSource source2 = new QueueSource();
50  source2.setEvents(3, 1, 4, 1, 6);
51  Adder add = new Adder();
52  Connector.connect(source1, 0, add, 0);
53  Connector.connect(source2, 0, add, 1);
54  Pullable p = add.getPullableOutput();
55  for (int i = 0; i < 5; i++)
56  {
57  float x = (Float) p.pull();
58  System.out.println("The event is: " + x);
59  }
60  ///
61  }
62 
63  /**
64  * A queue source object that waits 5 seconds before outputting
65  * each event.
66  */
67  public static class SlowQueueSource extends QueueSource
68  {
69  @Override
70  public boolean compute(Object[] inputs, Queue<Object[]> outputs)
71  {
72  UtilityMethods.pause(5000);
73  return super.compute(inputs, outputs);
74  }
75  }
76 }
Pipe processors together using the Connector object.