CSP for Java
(JCSP) 1.1-rc4

org.jcsp.plugNplay.ints
Class PlexInt

java.lang.Object
  extended by org.jcsp.plugNplay.ints.PlexInt
All Implemented Interfaces:
CSProcess

public final class PlexInt
extends Object
implements CSProcess

Fair multiplexes its input integer stream array into one output stream.

Process Diagram

Description

PlexInt is a process whose output stream is a fair multiplexing of its input streams. It makes no assumptions about the traffic patterns occuring on the input streams and ensures that no input stream will be starved by busy siblings. It guarantees that if an input stream has data pending, no other stream will be serviced twice before that data is serviced.

Channel Protocols

Input Channels
in[] int The input streams.
Output Channels
out int The multiplexed output stream.

Example

The following example shows how to use PlexInt in a small program.
 import org.jcsp.lang.*;
 import org.jcsp.plugNplay.ints.*;
 
 public class PlexIntExample {
 
   public static void main (String[] argv) {
 
     final One2OneChannelInt[] a = Channel.one2oneIntArray (3);
     final One2OneChannelInt b = Channel.one2oneInt ();
 
     new Parallel (
       new CSProcess[] {
         new NumbersInt (a[0].out ()),
         new FibonacciInt (a[1].out ()),
         new SquaresInt (a[2].out ()),
         new PlexInt (Channel.getInputArray (a), b.out ()),
         new PrinterInt (b.in (), "--> ", "\n")
       }
     ).run ();
 
   }
 
 }
 
Note: this example does not produce easily understandable output, since the multiplexed stream contains only numbers -- there is no indication of the streams from which they were sourced. To get that indication, we can either use MultiplexInt or sign each int stream to be multiplexed with SignInt and multiplex with Plex.

Implemntation Note

For information, here is the run method for this process:
   public void run () {
     Alternative alt = new Alternative (in);       // in is the input channel array
     while (true) {
       out.write (in[alt.fairSelect ()].read ());  // out is the output channel
     }
   }
 

Author:
P.H. Welch
See Also:
Plex2Int, MultiplexInt

Constructor Summary
PlexInt(AltingChannelInputInt[] in, ChannelOutputInt out)
          Construct a new PlexInt process with input channels in and output channel out.
 
Method Summary
 void run()
          The main body of this process.
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Constructor Detail

PlexInt

public PlexInt(AltingChannelInputInt[] in,
               ChannelOutputInt out)
Construct a new PlexInt process with input channels in and output channel out. The ordering of the input channels makes no difference to the behaviour of this process.

Parameters:
in - the input channels
out - the output channel
Method Detail

run

public void run()
The main body of this process.

Specified by:
run in interface CSProcess

CSP for Java
(JCSP) 1.1-rc4

Submit a bug or feature to jcsp-team@kent.ac.uk
Version 1.1-rc4 of the JCSP API Specification (Copyright 1997-2008 P.D.Austin and P.H.Welch - All Rights Reserved)
Java is a trademark or registered trademark of Sun Microsystems, Inc. in the US and other countries.