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

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

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




Важнейшие способы обработки и анализа рядов динамики Не во всех случаях эмпирические данные рядов динамики позволяют определить тенденцию изменения явления во времени...


ТЕОРЕТИЧЕСКАЯ МЕХАНИКА Статика является частью теоретической механики, изучающей условия, при ко­торых тело находится под действием заданной системы сил...


Теория усилителей. Схема Основная масса современных аналоговых и аналого-цифровых электронных устройств выполняется на специализированных микросхемах...


Логические цифровые микросхемы Более сложные элементы цифровой схемотехники (триггеры, мультиплексоры, декодеры и т.д.) не имеют...

Тема: Изучение фенотипов местных сортов растений Цель: расширить знания о задачах современной селекции. Оборудование:пакетики семян различных сортов томатов...

Тема: Составление цепи питания Цель: расширить знания о биотических факторах среды. Оборудование:гербарные растения...

В эволюции растений и животных. Цель: выявить ароморфозы и идиоадаптации у растений Цель: выявить ароморфозы и идиоадаптации у растений. Оборудование: гербарные растения, чучела хордовых (рыб, земноводных, птиц, пресмыкающихся, млекопитающих), коллекции насекомых, влажные препараты паразитических червей, мох, хвощ, папоротник...

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

Тема: Кинематика поступательного и вращательного движения. 1. Твердое тело начинает вращаться вокруг оси Z с угловой скоростью, проекция которой изменяется со временем 1. Твердое тело начинает вращаться вокруг оси Z с угловой скоростью...

Условия приобретения статуса индивидуального предпринимателя. В соответствии с п. 1 ст. 23 ГК РФ гражданин вправе заниматься предпринимательской деятельностью без образования юридического лица с момента государственной регистрации в качестве индивидуального предпринимателя. Каковы же условия такой регистрации и...

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