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

Open MP и Несколько потоков - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Сформировать матрицу по заданному образцу http://www.cyberforum.ru/cpp-beginners/thread453952.html
Двумерный массив Получить матрицу: 1 0 … 0 1 0 1 … 1 0 . . … . . 0 1 … 1 0 1 0 … 0 1 У меня не че не получается, помогите парни...
C++ net beans и exe Добрый вечер, не так давно программирую на си и вот возникла такая проблема: использую среду netbeans и компилятор cygwin, нетбинс создает проект... как мне получить exe файл этого проекта?(после... http://www.cyberforum.ru/cpp-beginners/thread453948.html
Работа со строками, оформление в виду функции C++
#include <iostream> #include <fstream> #include <string> #include <ctype.h> using namespace std; void rere(string s) { bool a; while (getline (cin,s)) {
Expected unqualified-id before numeric constant C++
какое уменя ошибка ? #include <iostream> using namespace std; float lbstokg(float); int main() { float lbs, kgs; cout << "\nCekini futla daxil edin: "; cin >> lbs; kgs = lbstokg(lbs);
C++ Как правильно указать универсальный путь http://www.cyberforum.ru/cpp-beginners/thread453915.html
Возникла проблема, изучаю с Winapi, напил для своей проги DLL, который хранится в: папка проекта\dll_func\MyDll.dll В программе подтягиваю ее следующим образом: hDllInstance = LoadLibraryEx(...
C++ Сортировка двумерного массива Здравствуйте, вот у меня есть массив array. Какими стандартными методами можно отсортировать весь массив по ячейкам ? Или стандартными методами можно сортировать только контейнеры? Если да, то какой... подробнее

Показать сообщение отдельно
SVO
Сообщений: n/a

Open MP и Несколько потоков - C++

27.02.2012, 19:55. Просмотров 483. Ответов 0
Метки (Все метки)

Собственно вот код:
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
38
39
40
41
42
43
44
45
46
47
#include "stdafx.h"
#include "omp.h"
#include "time.h"
 
#define N 10
 
 
int main()
{
  clock_t time;
  float a[N], b[N], c[N];
  int i, Threads;
  omp_set_dynamic(0);      // запретить библиотеке openmp менять число потоков во время исполнения
  omp_set_num_threads(2); // установить число потоков в 10
 
  // инициализируем массивы
  for (i = 0; i < N; i++)
  {
      a[i] = i * 1.0;
      b[i] = i * 2.0;
  }
 
  // вычисляем сумму массивов
  /* Создание множества параллельных процессов */
#pragma omp parallel shared(a, b, c) private(i)
        Threads = omp_get_num_threads();
        #pragma omp for nowait
        for (i = 0; i < N/2; i++)
        {
        time = clock();
        c[i] = a[i] + b[i];
        printf("Threads = %d i= %d c[i]= %f\n", Threads, i, c[i]);
        time = clock() - time;
        printf("Time = %f\n", (double)time/CLOCKS_PER_SEC); //время выполнения
        }
        Threads = omp_get_num_threads();
        #pragma omp for
        for (i = N/2; i < N; i++)
        {
        time = clock();
        c[i] = a[i] + b[i];
        printf("Threads = %d i= %d c[i]= %f\n", Threads, i, c[i]);
        time = clock() - time;
        printf("Time = %f\n", (double)time/CLOCKS_PER_SEC); //время выполнения
        }
  return 0;
}
Сейчас реализовано разбитие на 2 потока с помощью #pragma omp for
Где потом с помощью Threads мы отслеживаем какое действие в каком потоке было выполнено...

Нужна помощь в следующем:
Нужно чтобы разбивалось на большее количество потоков (при этом чтобы количество потоков устанавливалось пользователем), при этом так же нужно чтобы все отслеживалось с помощью Threads.

Если кто то сталкивался подскажите.
За любые идеи тоже буду благодарен.
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru