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!