C ++ 23 TBB: parallel_reduce с std :: mulliplies как сокращениеC++

Программы на C++. Форум разработчиков
Ответить
Anonymous
 C ++ 23 TBB: parallel_reduce с std :: mulliplies как сокращение

Сообщение Anonymous »

Я хочу перемножить все элементы вектора. Однако следующий фрагмент кода

Код: Выделить всё

long sum = parallel_reduce(
blocked_range(0, sum1.size()), 1.0L /* Identity for Multiplication */,
[&](tbb::blocked_range r, long double running_total)
{
for (size_t i = r.begin(); i < r.end(); i++)
running_total *= sum1[i];
return running_total;
},
std::multiplies());
< /code>
дает неправильный результат. Накапливается 
дает правильный результат:

Код: Выделить всё

long sum2 = ranges::fold_left(sum1, 1, std::multiplies());
Чего мне не хватает?

Подробнее здесь: https://stackoverflow.com/questions/786 ... -reduction
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C++»