Студопедия Главная Случайная страница Обратная связь

Разделы: Автомобили Астрономия Биология География Дом и сад Другие языки Другое Информатика История Культура Литература Логика Математика Медицина Металлургия Механика Образование Охрана труда Педагогика Политика Право Психология Религия Риторика Социология Спорт Строительство Технология Туризм Физика Философия Финансы Химия Черчение Экология Экономика Электроника

Оператор sections





Оператор sections определяет набор программных конструкций не итерационного типа (т.е. не цикл), которые делятся между нитями в группе. Каждая секция выполняется каждой нитью один раз. Синтаксис директивы sections:

#pragma omp sections [оператор [оператор]...]

{

[#pragma omp section]

Структурированный блок

[#pragma omp section]

Структурированный блок

}

Оператор может иметь один из следующих типов:

private (список)

firstprivate (список)

lastprivate (список)

reduction (операция: список)

Nowait

Каждой секции операторов предшествует оператор sections. Каждый внутренний блок операторов должен содержать оператор section. Если оператор nowait не указан, то конструкция sections завершится барьерной синхронизацией.

Ограничения к применению директивы sections:

1. Оператор section не должен появляться вне оператора sections.

2. Только один оператор nowait может появиться в директиве sections.

Пример:каждый блок section выполняется индивидуальной нитью. Если количество нитей равно 3, то выделенные в директиве sections три блока инструкций, определенные директивой section будут выполнены параллельно.

 

int s=0, p=1;

#pragma omp parallel sections

{

#pragma omp section // блок 1, вычисляющий сумму элементов массива a

for (i=0; i<10; i++) {

s = s + b[i];

}

#pragma omp section // блок 2, вычисляющий сумму элементов массива b

for (i=0; i<10; i++) {

p = p * b[i];

}

#pragma omp section //блок 3, вычисляющий значения элементов массива c

for (i=0; i<10; i++) { // как сумму числовых значений элементов массивов a и b

c[i] = a[i] + b[i];

}

}

Пример:каждый блок выводит на экран номер нити, на котором он выполняется. В первом блоке отсутствует директива section, такой синтаксис допускается стандартом OpenMP, но только в первом блоке.

 

#pragma omp parallel sections

{ // блок инструкций 1, директива section отсутствует

printf ("Hello from thread %d\n", omp_get_thread_num());

#pragma omp section // блок инструкций 2

printf ("Hello from thread %d\n", omp_get_thread_num());

#pragma omp section // блок инструкций 3

printf ("Hello from thread %d\n", omp_get_thread_num());

}

 







Дата добавления: 2015-08-12; просмотров: 431. Нарушение авторских прав; Мы поможем в написании вашей работы!




Расчетные и графические задания Равновесный объем - это объем, определяемый равенством спроса и предложения...


Кардиналистский и ординалистский подходы Кардиналистский (количественный подход) к анализу полезности основан на представлении о возможности измерения различных благ в условных единицах полезности...


Обзор компонентов Multisim Компоненты – это основа любой схемы, это все элементы, из которых она состоит. Multisim оперирует с двумя категориями...


Композиция из абстрактных геометрических фигур Данная композиция состоит из линий, штриховки, абстрактных геометрических форм...

Тактические действия нарядов полиции по предупреждению и пресечению групповых нарушений общественного порядка и массовых беспорядков В целях предупреждения разрастания групповых нарушений общественного порядка (далееГНОП) в массовые беспорядки подразделения (наряды) полиции осуществляют следующие мероприятия...

Механизм действия гормонов а) Цитозольный механизм действия гормонов. По цитозольному механизму действуют гормоны 1 группы...

Алгоритм выполнения манипуляции Приемы наружного акушерского исследования. Приемы Леопольда – Левицкого. Цель...

Интуитивное мышление Мышление — это пси­хический процесс, обеспечивающий познание сущности предме­тов и явлений и самого субъекта...

Объект, субъект, предмет, цели и задачи управления персоналом Социальная система организации делится на две основные подсистемы: управляющую и управляемую...

Законы Генри, Дальтона, Сеченова. Применение этих законов при лечении кессонной болезни, лечении в барокамере и исследовании электролитного состава крови Закон Генри: Количество газа, растворенного при данной температуре в определенном объеме жидкости, при равновесии прямо пропорциональны давлению газа...

Studopedia.info - Студопедия - 2014-2025 год . (0.012 сек.) русская версия | украинская версия