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

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

Оператор 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. Нарушение авторских прав; Мы поможем в написании вашей работы!




Шрифт зодчего Шрифт зодчего состоит из прописных (заглавных), строчных букв и цифр...


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


Практические расчеты на срез и смятие При изучении темы обратите внимание на основные расчетные предпосылки и условности расчета...


Функция спроса населения на данный товар Функция спроса населения на данный товар: Qd=7-Р. Функция предложения: Qs= -5+2Р,где...

Подкожное введение сывороток по методу Безредки. С целью предупреждения развития анафилактического шока и других аллергических реак­ций при введении иммунных сывороток используют метод Безредки для определения реакции больного на введение сыворотки...

Принципы и методы управления в таможенных органах Под принципами управления понимаются идеи, правила, основные положения и нормы поведения, которыми руководствуются общие, частные и организационно-технологические принципы...

ПРОФЕССИОНАЛЬНОЕ САМОВОСПИТАНИЕ И САМООБРАЗОВАНИЕ ПЕДАГОГА Воспитывать сегодня подрастающее поколение на со­временном уровне требований общества нельзя без по­стоянного обновления и обогащения своего профессио­нального педагогического потенциала...

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

Кран машиниста усл. № 394 – назначение и устройство Кран машиниста условный номер 394 предназначен для управления тормозами поезда...

Приложение Г: Особенности заполнение справки формы ву-45   После выполнения полного опробования тормозов, а так же после сокращенного, если предварительно на станции было произведено полное опробование тормозов состава от стационарной установки с автоматической регистрацией параметров или без...

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