Difference between revisions of "Scatter"

From Mesham
Jump to navigationJump to search
m
Line 9: Line 9:
 
== Example ==
 
== Example ==
  
  var x:array[Int,3]::allocated[multiple[]];
+
  function void main() {
var r:array[Int,12]::allocated[multiple[]];
+
    var x:array[Int,3]::allocated[multiple[]];
var p;
+
    var r:array[Int,12]::allocated[multiple[]];
par p from 0 to 3
+
    var p;
{
+
    par p from 0 to 3 {
    x:(x::scatter[3,1]);
+
      x:(x::scatter[3,1]);
    x:=r;
+
      x:=r;
 +
    };
 
  };
 
  };
  

Revision as of 14:26, 15 April 2013

Syntax

scatter[elements,root]

Semantics

Will send a number of elements (equal to elements) from the root process to all other processes.

Example

function void main() {
   var x:array[Int,3]::allocated[multiple[]];
   var r:array[Int,12]::allocated[multiple[]];
   var p;
   par p from 0 to 3 {
      x:(x::scatter[3,1]);
      x:=r;
   };
};

In this example, three elements of array r, on process 1, are scattered to each other process and placed in their copy of r.

Since: Version 0.41b