Difference between revisions of "Habanero"
(→Loops) |
|||
Line 36: | Line 36: | ||
===forasync=== | ===forasync=== | ||
− | <nowiki> | + | <nowiki>forasync(0, N-1, (i)->{} );</nowiki> |
− | forasync(0, N-1, (i)->{} );</nowiki> | ||
can be thought of as: | can be thought of as: | ||
− | <nowiki> | + | <nowiki>for( int i=0; i<N; i++ ) { |
− | for( int i=0; i<N; i++ ) { | ||
async( ()->{ | async( ()->{ | ||
}); | }); | ||
}</nowiki> | }</nowiki> | ||
+ | |||
+ | ===forall=== | ||
+ | |||
+ | <nowiki>forall(0, N-1, (i)->{} );</nowiki> | ||
+ | |||
+ | is just forasync wrapped in a finish: | ||
+ | |||
+ | <nowiki>finish(()-> { | ||
+ | forasync(0, N-1, (i)->{} ); | ||
+ | });</nowiki> |
Revision as of 17:55, 10 March 2017
Contents
Async, Finish
Async and finish make up the fundamental building blocks of task-level parallelism in Habanero.
These concepts are first covered in RiceX Topic 1.1.
async(body) creates a new child task that can run before, after, or in parallel with all remaining statements of the parent task.
finish(body) executes body and waits for all child tasks to complete.
Future
A future is a tasks that return a value.
Futures are covered in RiceX Topic 2.1.
future(body) returns an instance of HjFuture. Invoking the get() method on that instance waits for the task to complete.
FinishAccumulator
Finish Accumulators provide a convenient way to keep track of a count (for example: the number of solutions in the n-queens problem) or perform a reduction as in the MapReduce_Assignment.
FinishAccumulators are covered in RiceX Topic 2.3.
FinishAccumulator Creation
There are several ways to create the different forms of accumulators, but the two that come up in CSE231s are:
newIntegerFinishAccumulator( NumberReductionOperator.SUM )
and
newReducerFinishAccumulator(Reducer<T> reducer)
Finish Accumulator Registration
finish(register(accumulators), body)
Loops
forasync
forasync(0, N-1, (i)->{} );
can be thought of as:
for( int i=0; i<N; i++ ) { async( ()->{ }); }
forall
forall(0, N-1, (i)->{} );
is just forasync wrapped in a finish:
finish(()-> { forasync(0, N-1, (i)->{} ); });