- Implicit parallelism
In
computer science , implicit parallelism is a characteristic of a programming language that allows acompiler to automatically exploit the parallelism inherent to the computations expressed by some of the language's constructs. A pure implicitly parallel languagedoes not need special directives, operators or functions to enable parallel execution.Some parallel programming languages with implicit parallelism are:
LabVIEW , HPF, ZPL,NESL andSISAL .Advantages
A programmer that writes implicitly parallel code does not need to worry about task division or process communication, focusing instead in the problem that his or her program is intended to solve. Implicit parallelism generally facilitates the design of parallel programs and therefore results in a substantial improvement of programmer productivity.
Disadvantages
Languages with implicit parallelism reduce the control that the programmer has over the parallel execution of the program, resulting sometimes in less-than-optimal
parallel efficiency . The makers of theOz programming language also note that their early experiments with implicit parallelism showed that implicit parallelism made debugging difficult and object models unnecessarily awkward. [cite web|author=Seif Haridi|title=Introduction| url=http://www.mozart-oz.org/documentation/tutorial/node1.html#chapter.introduction|work=Tutorial of Oz|accessdate=2007-09-20|date=2006-06-14]Notes
Wikimedia Foundation. 2010.