-
Notifications
You must be signed in to change notification settings - Fork 248
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[Core][Parallelization] Making explicitily schedule(runtime)
, with dynamic
by default, in OMP loops in ParallelUtils
#12923
base: master
Are you sure you want to change the base?
Changes from 9 commits
897cd72
dc8a7e2
91374a0
83ce3e7
d7754da
7ece75a
8ba1ab5
5503861
67c4c6f
ad3f345
ddfdca6
9c95018
bc5074e
606882b
24f40aa
fea23da
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -183,7 +183,7 @@ class BlockPartition | |
{ | ||
KRATOS_PREPARE_CATCH_THREAD_EXCEPTION | ||
|
||
#pragma omp parallel for | ||
#pragma omp parallel for schedule(runtime) | ||
for (int i=0; i<mNchunks; ++i) { | ||
KRATOS_TRY | ||
for (auto it = mBlockPartition[i]; it != mBlockPartition[i+1]; ++it) { | ||
|
@@ -206,7 +206,7 @@ class BlockPartition | |
KRATOS_PREPARE_CATCH_THREAD_EXCEPTION | ||
|
||
TReducer global_reducer; | ||
#pragma omp parallel for | ||
#pragma omp parallel for schedule(runtime) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. @loumalouomega as i am telling, take a look to line 154. It does not make sense to change this unless we change what happens there. also to my understanding the runtime behaviour has potentially a very high overhead due to the need of making a syscall to fetch an env variable. not sure if that matters...but at least we need to beware of this There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. We should use the benchmark to check that it affects significantly There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. The idea of the runtime is to give flexibility, if you prefer we can define it on compiling time... There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. It is recommended by OMP itself: https://www.openmp.org/wp-content/uploads/openmp-webinar-vanderPas-20210318.pdf (And I found a master thesis saying that it doesn't penalize https://hpc.dmi.unibas.ch/wp-content/uploads/sites/87/2020/10/2019_akan_yilmaz_ma_thesisjune2019.pdf) There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. @loumalouomega aside of the comments on the opportunity of using the OMP_SCHEDULE did u take a look at what i am writing? we are doing "by hand" the chunking. If we don't change that, it makes no sense to use a different scheduling, as everyone will be working on its chunk (as of now we dot have more chunks than threads!) There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Okay...let me think this... There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. In that case we may need to rethink the chunging (to be dependent of the CPU architecture) There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. @RiccardoRossi what do you suggest exactly, because I has been studying this and our chunking conflicts with the OMP scheduling, and a priori the most efficient would be to let OMP to do the chunking. The problem is that with that we lose the parallel_utilities design and reduction utilities. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. here there is a description of the scheduling options. we could just replicate the one of choice |
||
for (int i=0; i<mNchunks; ++i) { | ||
KRATOS_TRY | ||
TReducer local_reducer; | ||
|
@@ -519,7 +519,7 @@ class IndexPartition | |
{ | ||
KRATOS_PREPARE_CATCH_THREAD_EXCEPTION | ||
|
||
#pragma omp parallel for | ||
#pragma omp parallel for schedule(runtime) | ||
for (int i=0; i<mNchunks; ++i) { | ||
KRATOS_TRY | ||
for (auto k = mBlockPartition[i]; k < mBlockPartition[i+1]; ++k) { | ||
|
@@ -541,7 +541,7 @@ class IndexPartition | |
KRATOS_PREPARE_CATCH_THREAD_EXCEPTION | ||
|
||
TReducer global_reducer; | ||
#pragma omp parallel for | ||
#pragma omp parallel for schedule(runtime) | ||
for (int i=0; i<mNchunks; ++i) { | ||
KRATOS_TRY | ||
TReducer local_reducer; | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
OMP_SCHEDULE
is a runtime env variable, it is a extremely bad idea to use it a compilation switch (IMO).There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I understand, but this is the following.
During compilation the
OMP_SCHEDULE
will setKRATOS_OMP_SCHEDULE
that will be used as default if actuallyOMP_SCHEDULE
is not defined, but ifOMP_SCHEDULE
is definedOMP_SCHEDULE
will be taken into account. Do you understand me?