Форум программистов, компьютерный форум CyberForum.ru

Распараллелить скалярное произведение векторов - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Почему strtok неправильно делит строку http://www.cyberforum.ru/cpp-beginners/thread692631.html
Он должен делить по словах("делитель" - пробел) а он делит по-символьно. #include <iostream> #include <string.h> #include <conio.h> #include <stdio.h> using namespace std; void inp(char); void tok(char, int); int main() {
C++ Разворот матрицы на 90 градусов Заполнить матрицу случайными числами. Развернуть матрицу на 90o по часовой стрелке. Добавлено через 46 секунд ПОМОГИТЕ СДЕЛАТЬ НЕ ВЫХОДИТ...СРОЧНО НАДО БЫ...ДО ЗАВТРА http://www.cyberforum.ru/cpp-beginners/thread692622.html
C++ _FindFirst _findnext
Прошу помочь разобраться с функциями _FindFirst и _findnext. не могу понять как с ними работать. если можно в виде примера простой программы с пояснениями. Пытался написать код который ищет все текстовые файлы в каталоге с помощью этих функций ничего не выходит. Заранее спасибо.
C++ Структуры и ввод данных
const int len_name=20; //длинна ФИО const int b=8; struct NOTE{ char name; //ФИО int phone; //номер телефона char birth; //дата рождения }; /*Запись в файл*/
C++ Сколько различных символов встречаются в строке http://www.cyberforum.ru/cpp-beginners/thread692616.html
Дана строка.Посчитать и вывести сколько различных символов встречаются в ней
C++ Как исправить эти ошибки как исправить ети ошибки Код: #include<iostream.h> #include<conio.h> #include<string.h> #define n 10 struct Krainy { string N_Krainy; подробнее

Показать сообщение отдельно
OstapBender
583 / 521 / 35
Регистрация: 22.03.2011
Сообщений: 1,585

Распараллелить скалярное произведение векторов - C++

08.11.2012, 23:22. Просмотров 2525. Ответов 4
Метки (Все метки)

Задание - распараллелить скалярное произведение векторов.
вектора vec1 и vec2 заполняются не рандомом для однозначности результата.

в общем все работает,но препод впихнул симуляцию задержки 1го потока (в нашем случае который выполняет 10ую итерацию), и все накрывается. не знаю как это исправить (место обозначено (!!!)).
пробывал поставить барьеры - не работает.
как решить проблему? нельзя убирать слип.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
const int N = 20;
 
int res = 0;
short vec1[N], vec2[N];
 
srand(time(0));
 
for (int i=0; i<N; i++) {
    vec1[i] = 1;
    vec2[i] = 2;
    printf("%3d %3d\n",vec1[i], vec2[i]);
}
 
::omp_set_num_threads(omp_get_num_procs()); // ?
 
int chunk = 1;
 
int tmp2, tmp;
 
#pragma omp parallel shared(N, res) private(tmp, tmp2)
 {
     #pragma omp for schedule(dynamic, chunk) nowait
     for (int i=0; i<N; i++) {
 
         tmp = vec1[i] * vec2[i];
         tmp2 = res + tmp;
         if (i == 10)  {          // !!!
             Sleep(1000);
         }
 
         res = tmp2;
     }
 
 }
 
 
 printf("\n\nres: %d\n", res);
спс.
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru