When executing the following dummy code:
P = 2
library(foreach)
library(doMC)
registerDoMC(P)
f = double(length = P)
print('=== f values in loop ===')
foreach(c = 1:P) %dopar%
{
f[c] = c
print(f[c])
}
print('### f values after loop ###')
for(c in 1:P){ print(f[c]) }
I receive the following output:
"=== f values in loop ==="
1
2
"### f values after loop ###"
0
0
Why are the f
values assigned in the foreach
loop not saved?
In particular, why are f[1]
and f[2]
equal to zero after the foreach
loop?
Thanks!