Skip to main content

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [List Home]
Re: [epsilon-dev] Automatic substitution for parallel operations

Hi Sina,

Auto-detecting when parallel operations can be safely used would be
very useful indeed! I'm only wondering whether
Thread.currentThread().getName().equals(“main”) is a reliable way of
determining whether we're in a "top-level" thread. Does this hold when
an Epsilon program is ran through the Eclipse-based development tools
or e.g. through Tomcat? [1]

Cheers,
Dimitris

[1] https://www.eclipse.org/epsilon/doc/articles/egl-server-side/

On Sat, 13 Apr 2019 at 20:19, Sina Madani <sinadoom@xxxxxxxxxxxxxx> wrote:
>
> Hi everyone,
>
>
>
> I’ve recently been experimenting with a way to eliminate the need for users to explicitly specify when to use parallel operations. The only reason to avoid using parallel operations, except for the rare case where selectOne must return the first element which matches the criteria in an ordered collection and where global state is mutated, is to avoid nesting. However since IEolContextParallel can already detect illegal nesting and throw an exception, would it not make sense to only apply parallelisation when there is no nesting?
>
>
>
> More concretely, the only change required is to AbstractOperation.getOperationFor as shown in [1]. From the user’s point of view, there would be three ways of invoking an operation. To demonstrate, consider “select” as an example:
>
>
>
> .parallelSelect -> delegates to ParallelSelectOperation
> .sequentialSelect -> delegates to SelectOperation
> . select -> delegates to ParallelSelectOperation if it is not being invoked from a parallel operation – in simpler terms, if Thread.currentThread().getName().equals(“main”) – otherwise delegates to SelectOperation.
>
>
>
> Therefore the default automatically chooses the appropriate one. However the user can also explicitly specify which implementation they want if they desire. Currently I have a prototype with additional tests (specifically org.eclipse.epsilon.eol.engine.test.acceptance.firstOrder.nested.AutoParallelOperationTests) in the parallel-epsilon branch.
>
>
>
> Please let me know if there are any suggestions. If there are no objections I propose to merge this into the main branch.
>
>
>
> Thanks,
>
> Sina
>
>
>
> [1] https://git.eclipse.org/c/epsilon/org.eclipse.epsilon.git/tree/plugins/org.eclipse.epsilon.eol.engine/src/org/eclipse/epsilon/eol/execute/operations/EolOperationFactory.java?h=parallel-epsilon
>
>
>
> _______________________________________________
> epsilon-dev mailing list
> epsilon-dev@xxxxxxxxxxx
> To change your delivery options, retrieve your password, or unsubscribe from this list, visit
> https://www.eclipse.org/mailman/listinfo/epsilon-dev



-- 
Dimitris Kolovos
Professor of Software Engineering
Department of Computer Science
University of York
http://www.cs.york.ac.uk/~dkolovos

EMAIL DISCLAIMER http://www.york.ac.uk/docs/disclaimer/email.htm


Back to the top