Message Passing Interface - MPI
|
|
|
- Baltazar Sousa Fraga
- 9 Há anos
- Visualizações:
Transcrição
1 Message Passing Interface - Pedro de Botelho Marcos Maio/2008 1
2 Sumário Introdução; Conceitos básicos; Comunicação; Principais rotinas; Compilando e executando códigos ; Exemplos; Referências; 2
3 Introdução = Message Passing Interface; É uma biblioteca que define rotinas para comunicação entre processos paralelos; É portável para qualquer arquitetura; É compatível com as linguagens C/C++ e Fortran; O paralelismo é explicito, ou seja, o programador é responsável pela distribuição; 3
4 Estrutura do código com #include<stdio.h> #include mpi.h int main(int argc, char *argv[ ]) { _Init(&argc, &argv);.. Código usando rotinas do... _Finalize(); // Inicializa //Encerra return 0; } 4
5 Conceitos Básicos Mensagem: É o conteúdo de uma comunicação. É formado por duas partes: Endereço: Destino e origem da mensagem; Dados: A informação a ser transmitida; Rank: É o identificador único do processo. Varia de 0 a N-1; 5
6 Conceitos Básicos Grupo: É um conjunto de processos que podem se comunicar. Sempre está associado a um comunicador; Comunicador: É um objeto local que representa o domínio de uma comunicação. 6
7 Conceitos Básicos Application Buffer: É o endereço de memória que armazena um dado que o processo necessita receber ou enviar. System Buffer: É o endereço de memória reservado pelo sistema para armazenar mensagens. 7
8 Conceitos Básicos Overhead: É um desperdício de tempo que ocorre durante a execução do processo. Existem dois tipos de overhead: System Overhead: Tempo gasto pelo sistema na transferência de dados para o processso destino. Synchronization Overhead: Tempo gasto para a sincronização dos processos. 8
9 Tipos de Dados 9
10 Técnicas de Comunicação entre Processos Buffering; Blocking; Non-Blocking; Assíncrona; Síncrona; 10
11 Buffering É a cópia temporária de mensagens entre endereços de memória efetuada pelo sistema como parte de seu protocolo de comunicação. A cópia ocorre entre o buffer do usuário (application buffer) definido pelo processo e o buffer do sistema (system buffer) definido pela biblioteca. Exemplo: Processo já começou o envio, porém, o processo que recebe ainda não. 11
12 Blocking A finalização da execução da rotina é dependente de determinados eventos. O processo só prosseguirá quando tiver certeza de que o application buffer pode ser usado novamente. Exemplo: Quando se deseja obter confirmação do recebimento de dados para continuar o processamento. 12
13 Non-Blocking A finalização da rotina não é dependente de outros eventos. Exemplo: Quando não existem dependências ou necessidade de controle intensivo sobre o programa. 13
14 Assíncrona O processo que envia a mensagem não espera uma confirmação de recebimento para prosseguir. Exemplo: Usada em comunicação confiável. 14
15 Síncrona O processo que enviou uma mensagem aguarda uma confirmação de recebimento para prosseguir a sua execução. Exemplo: Utilizada quando se torna necessária a confirmação de recebimento. Por exemplo, se a rede for instável. 15
16 Tipos de Comunicação Ponto a ponto: Executa a transferência de dados entre dois processos; Coletiva: Envolve comunicação entre dois ou mais processos; 16
17 Ponto a Ponto Síncrona (Synchronus); Imediata (Ready); Bufferizada (Buffered); 17
18 Síncrona O processo não retorna sua execução enquanto não houver uma confirmação de recebimento da mensagem 18
19 Imediata Sabe-se, a priori, que o recebimento de uma mensagem já foi realizado pelo processo destino. 19
20 Bufferizada A operação de envio utiliza uma quantidade específica para buffer alocada pelo usuário. Exemplo: Se o tamanho da mensagem ultrapassar 4Kbytes(buffer padrão). 20
21 Coletiva Difusão (Broadcast); Redução (Reduction); Coleta (Gather); Espalhamento (Scatter); 21
22 Difusão Um único processo envia os mesmos dados para todos os processos com o mesmo comunicador. 22
23 Redução Um processo coleta dados nos demais processos e aplica uma determinada operação sobre estes dados. O resultado será armazenada em um processo definido pelo usuário. Exemplo: Maior valor, menor valor. 23
24 Coleta A estrutura dos dados distribuída é coletada por um único processo. 24
25 Espalhamento A estrutura dos dados que está armazenada em um único processo é distribuída para todos os processos do comunicador. 25
26 Principais Rotinas Rotinas de Inicialização/Encerramento; Rotinas de Grupo; Rotinas de Envio/Recebimento de Mensagens; 26
27 Inicialização e Encerramento _Init Inicializa o ambiente ; _Finalize Finaliza o ambiente ; 27
28 _Init Sintaxe: Em C: int _Init (int *argc, char *argv[]) Em Fortran: call _INIT (mpierr) Parâmetros: argc Apontador para a quantidade de parametros da linha de comando; argv Apontador para um vetor de strings com os comandos recebidos; 28
29 _Finalize Sintaxe: Em C: int _Finalize (void) Em Fortran: call _FINALIZE (mpierr) 29
30 Informações sobre o comunicador _Comm_rank Identifica um processo dentro de um determinado grupo; _Comm_size Retorna o número de processos dentro do grupo; 30
31 _Comm_rank Sintaxe: Em C: int _Comm_rank (_Comm comm, int *rank) Em Fortran: call _COMM_RANK (comm, rank, mpierr) Parâmetros: comm Comunicador do ; rank Variável inteira com o numero de identificação do processo. 31
32 _Comm_size Sintaxe: Em C: int _Comm_size (_Comm comm, int *size) Em Fortran: call _COMM_SIZE (comm, size, mpierr) Parâmetros: comm Comunicador do ; size Variável interna que retorna o número de processos iniciados pelo. 32
33 Troca de Mensagens _Send Rotina básica para envio de mensagens; _Recv Rotina básica para recebimento de mensegens; 33
34 _Send Sintaxe: Em C: int _Send (void *sndbuf, int count, _Datatype dtype, int dest, int tag, _Comm comm) Em Fortran: call _SEND (sndbuf, count, dtype, dest, tag, comm, mpierr) Parâmetros: sndbuf Identificação do buffer; count Número de elementos a serem enviados; dtype Tipo de dado dest Identificação do processo destino; tag Rótulo (label) da mensagem; comm Communicator 34
35 _Recv Sintaxe: Em C: int _Recv (void *recvbuf, int count, _Datatype dtype, int source, int tag, _Comm comm, _Status status) Em Fortran: call _RECV (recvbuf, count, dtype, source, tag, comm, status, mpierr) Parâmetros: recvbuf Identificação do buffer (endereço inicial do "application buffer" de onde os dados estão sendo enviados); count Número de elementos a serem recebidos; dtype Tipo de dado source Identificação do processo emissor; tag Rótulo (label) da mensagem; comm Communicator status Vetor de informações envolvendo os parâmetros source e tag. 35
36 Compilando Em C/C++ mpicc [fonte.c] -o [executável] [parâmetros] Em Fortran mpif77 [fonte.f] -o [executável] [parâmetros] 36
37 Executando Em C/C++/Fortran mpirun [argumentos] [executável] Exemplos de argumentos: -np Número de processadores; -nolocal Não executa na máquina local; -h Mostra todas opções disponíveis; -machinefile Especifica arquivo com nomes das máquinas; 37
38 Exemplo Cada processo escreve um Hello! #include "mpi.h #include <stdio.h> Int main( int argc, char * argv[ ] ) { int processid; /* rank dos processos */ int noprocesses; /* Número de processos */ int namesize; /* Tamanho do nome */ char computername[50]; _Init(&argc, &argv); _Comm_size(_COMM_WORLD, &noprocesses); _Comm_rank(_COMM_WORLD, &processid); _Get_processor_name(computerName, &namesize); fprintf(stderr,"hello from process %d on %s\n", processid, computername); _Finalize( ); return 0; } 38
39 Exemplo Master envia mensagem para demais processos #include <stddef.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include "mpi.h" main(int argc, char *argv[]) { char message[20]; int i, rank, size, type = 99; _Status status; _Init(&argc, &argv); _Comm_size(_COMM_WORLD, &size); _Comm_rank(_COMM_WORLD, &rank); if (rank == 0) { strcpy(message, "Hello, world"); for (i = 1; i < size; i++) _Send(message, 13, _CHAR, i, type, _COMM_WORLD); } else _Recv(message, 20, _CHAR, 0, type, _COMM_WORLD, &status); printf( "Message from process = %d : %.13s\n", rank,message); _Finalize(); } 39
40 Referências %7Erc/classes/intro_mpi/ 40
Parte da Tarefa. Parte da Tarefa. Parte da Tarefa SEND RECEIVE SEND RECEIVE
Produto Escalar com MPI-2 (C++) Aula Sistemas Distribuídos Prof. Dr. Marcelo Facio Palin [email protected] 1 1 O que é Paralelismo? Conceitos Paralelismo é uma técnica usada em tarefas grandes e complexas
Introdução. Programação Paralela. Motivação. Conhecimento do Hardware. Análise de Desempenho. Modelagem do Problema
Introdução Programação Paralela Profa Mariana Kolberg e Prof. Luiz Gustavo Fernandes Programação paralela é a divisão de um problema em partes, de maneira que essas partes possam ser executadas paralelamente
Programação Paralela. Profa Mariana Kolberg e Prof. Luiz Gustavo Fernandes
Programação Paralela Profa Mariana Kolberg e Prof. Luiz Gustavo Fernandes Introdução Programação paralela é a divisão de um problema em partes, de maneira que essas partes possam ser executadas paralelamente
Computação por Passagem de Mensagens
Computação por Passagem de Mensagens Programação por passagem de mensagens Programação de multiprocessadores conectados por rede pode ser realizada: criando-se uma linguagem de programação paralela especial
Introdução a Computação Paralela: Rotinas MPI em Clusters Beowulf
Introdução a Computação Paralela: Rotinas MPI em Clusters Beowulf Miguel Dias Costa João Viana Lopes Centro de Física do Porto Estrutura do Curso Motivação Estrutura do Curso Motivação Conceitos de Computação
MPI (Message Passing Interface)
MPI (Message Passing Interface) Standard desenvolvido por académicos e indústria. Define rotinas, não a implementação. Não define como se criam os processos (depende da implementação) Existem várias implementações
Paralela e Distribuída. com o MPI e o OpenMP
Programação Paralela e Distribuída Programação Híbrida com o e o OpenMP e OpenMP Uma forma de executar um programa em paralelo num cluster multiprocessor é criar um processo por cada processador. Nesse
EXERCÍCIO 1 MUDANDO AS CORES
EXERCÍCIO 1 MUDANDO AS CORES O código abaixo ilustra o uso da comunicação ponto-a-ponto e a comunicação coletiva. Nesse código, uma matriz de três cores (verde, branco, vermelho e) é distribuída para todos
Algoritmos Paralelos usando CGM/MPI. Edson Norberto Cáceres e Siang Wun Song DCT/UFMS e DCC/IME/USP Aula 05
Algoritmos Paralelos usando CGM/MPI Edson Norberto Cáceres e Siang Wun Song DCT/UFMS e DCC/IME/USP Aula 05 Algoritmos Paralelos BSP/CGM Objetivos Descrever algumas das principais técnicas para o desenvolvimento
ALGORITMOS AULA 01. Baseado nas aulas do Prof. Jorgiano Vidal
ALGORITMOS AULA 01 Baseado nas aulas do Prof. Jorgiano Vidal LINGUAGEM C Uma das grandes vantagens do C é que ele possui tanto caracterìsticas de "alto nìvel" quanto de "baixo nìvel". Linguagem de propósito
Estruturas de Dados Aula 6: Cadeias de 28/03/2010
Estruturas de Dados Aula 6: Cadeias de Caracteres 28/03/2010 Caracteres Caracteres são representados internamente por códigos numéricos Tipo char (inteiro pequeno ) 1 byte (8 bits) 256 caracteres possíveis
Arquitecturas Paralelas I Computação Paralela em Larga Escala. Passagem de Mensagens
Arquitecturas Paralelas I Computação Paralela em Larga Escala LESI/LMCC - 4º/5º Ano Passagem de Mensagens João Luís Ferreira Sobral Departamento do Informática Universidade do Minho Novembro 2004 Passagem
QUEBRA DE SENHAS MD5 UTILIZANDO MDCRACK E MPI
UNIVERSIDADE FEDERAL DE SANTA MARIA CENTRO DE TÉCNOLOGIA CURSO DE CIÊNCIA DA COMPUTAÇÃO QUEBRA DE SENHAS MD5 UTILIZANDO MDCRACK E MPI Cicero Augusto de Lara Pahins, Cristiano Reis dos Santos. Professora:
Programação Paralela com Troca de Mensagens. Profa Andréa Schwertner Charão DLSC/CT/UFSM
Programação Paralela com Troca de Mensagens Profa Andréa Schwertner Charão DLSC/CT/UFSM Sumário Modelo de programa MPI Comunicação em MPI Comunicadores Mensagens Comunicação ponto-a-ponto Comunicação coletiva
Comunicação entre Processos
Comunicação entre Processos Prof. Dr. André Carvalho [email protected] Agenda n Comunicação entre Processos n Características dos mecanismos de comunicação Comunicação direta ou indireta, sincronismos,
Tipos Básicos. Operadores de Incremento e Decremento. Operador Sizeof. Estruturas de Dados Aula 2: Estruturas Estáticas
Tipos Básicos Quantos valores distintos podemos representar com o tipo char? Estruturas de Dados Aula 2: Estruturas Estáticas 03/03/2010 Operadores de Incremento e Decremento ++ e -- Incrementa ou decrementa
PROGRAMAÇÃO PARALELA USANDO MPI
PROGRAMAÇÃO PARALELA USANDO MPI Maurílio Boaventura DCCE/IBILCE/UNESP São José do Rio Preto - SP Nos computadores convencionais, um programa é um conjunto de instruções que são transmitidas à unidade de
Aula 5 Oficina de Programação Introdução ao C. Profa. Elaine Faria UFU
Aula 5 Oficina de Programação Introdução ao C Profa. Elaine Faria UFU - 2017 Linguagem de Programação Para que o computador consiga ler um programa e entender o que fazer, este programa deve ser escrito
ALGORITMOS E ESRUTRA DE DADOS I. Ponteiros Passagem por Valor e Referência Alocação de Memória
ALGORITMOS E ESRUTRA DE DADOS I Ponteiros Passagem por Valor e Referência Alocação de Memória 2 Agenda Ponteiros Conceitos gerais O que é Ponteiro? Declaração de Ponteiros Operadores para Ponteiros Exemplos
Métodos Computacionais
Métodos Computacionais Objetivos da Disciplina e Introdução a Linguagem C Construções Básicas Objetivos da Disciplina Objetivo Geral Discutir técnicas de programação e estruturação de dados para o desenvolvimento
#include <stdio.h> Void main() { printf( Cheguei!\n"); } INTRODUÇÃO A LINGUAGEM C
#include Void main() { printf( Cheguei!\n"); } INTRODUÇÃO A LINGUAGEM C ANTES DO C ERA A LINGUAGEM B B foi essencialmente uma simplificação da linguagem BCPL. B só tinha um tipo de dado, que
Ponteiros e Tabelas. K&R: Capítulo 5
Ponteiros e Tabelas K&R: Capítulo 5 Ponteiros e Tabelas Ponteiros e endereços Ponteiros e argumentos de funções Ponteiros e tabelas Alocação dinâmica de memória Aritmética de ponteiros Tabelas de ponteiros
Programação Básica. Estrutura de um algoritmo
Programação Básica Estrutura de um algoritmo Código-fonte Como vimos na aula anterior um algoritmo pode ser representado usando um fluxograma Um algoritmo pode também ser representado usando texto Esse
O que é um apontador em C (type pointer in C)?
O que é um apontador em C (type pointer in C)? Um apontador é uma variável que contém um endereço de outra variável. int x = 10;//variável inteira iniciada com o valor 10 int *px = &x;//variável apontadora
#include <stdio.h> void Swap (int *a,int *b) { int temp; temp=*a; *a=*b; *b=temp; } main () {
422 #include void Swap (int *a,int *b) int temp; temp=*a; *a=*b; *b=temp; main () int num1,num2; printf("\nentre com o primeiro valor: "); scanf ("%d",&num1); printf("\nentre com o segundo valor:
Algoritmos e Estruturas de Dados I (DCC/003) Introdução à Programação de Computadores. Aula - Tópico 1
Algoritmos e Estruturas de Dados I (DCC/003) Introdução à Programação de Computadores Aula - Tópico 1 1 Problema 1 Considere o seguinte problema: Determinar o valor de y = seno(1,5). 2 Definições Para
Introdução à Programação
Introdução à Programação Introdução a Linguagem C Construções Básicas Programa em C #include int main ( ) { Palavras Reservadas } float celsius ; float farenheit ; celsius = 30; farenheit = 9.0/5
Instruções para uso do MPI - Relatório Técnico -
Universidade de Passo Fundo Instituto de Ciências Exatas e Geociências Curso de Ciência da Computação Instruções para uso do MPI - Relatório Técnico - ComPaDi Grupo de Pesquisa em Computação Paralela e
Classificação das linguagens de programação
Introdução Linguagem É um meio de comunicação entre pessoas. Faculdade de expressão audível e articulada do homem. Conjunto de sinais falados, escritos ou gesticulados de que se serve o homem para demonstrar
Programação Paralela em Memória Compartilhada e Distribuída
Programação Paralela em Memória Compartilhada e Distribuída Prof. Claudio Schepke [email protected] Prof. João V. F. Lima [email protected] (baseado em material elaborado por professores
Programação de Computadores II
Programação de Computadores II 1. Programação Básica 2019.1 Slides adaptados do material de Karina Mochetti Problema, Algoritmo, Programa Um programa de computador é a implementação de um algoritmo para
INTRODUÇÃO À LINGUAGEM C. Prof. Msc. Luis Filipe Alves Pereira 2015
INTRODUÇÃO À LINGUAGEM C Prof. Msc. Luis Filipe Alves Pereira 2015 INTRODUÇÃO À LINGUAGEM C 02/23 INTRODUÇÃO Criada em 1972 na AT&T Bell Labs É uma das linguagens mais populares. Existem poucas arquiteturas
Linguagem de Programação I Vetores e Strings. Thiago Leite Francisco Barretto
Linguagem de Programação I Vetores e Strings Thiago Leite Francisco Barretto Vetores são matrizes unidimensionais; Uma matriz é uma coleção de
Linguagem C. André Tavares da Silva.
Linguagem C André Tavares da Silva [email protected] Variáveis Posição nomeada de memória que é usada para guardar um valor que pode ser modificado pelo programa. Todas as variáveis devem ser
Introdução à Programação. Introdução a Linguagem C. Prof. José Honorato F. Nunes
Introdução à Programação Introdução a Linguagem C Prof. José Honorato F. Nunes [email protected] Resumo da aula Introdução Variáveis Tipos de dados Operadores e Expressões: Operadores
Linguagem C Princípios Básicos (parte 1)
Linguagem C Princípios Básicos (parte 1) Objetivos O principal objetivo deste artigo é explicar alguns conceitos fundamentais de programação em C. No final será implementado um programa envolvendo todos
Anhanguera Educacional S.A. Centro Universitário Ibero-Americano
O C++ foi inicialmente desenvolvido por Bjarne Stroustrup durante a década de 1980 com o objetivo de melhorar a linguagem de programação C, mantendo a compatibilidade com esta linguagem. Exemplos de Aplicações
Disciplina de Algoritmos e Programação
Disciplina de Algoritmos e Programação Aula Passada 1º Programa: olamundo.c #include // biblioteca padrão de E/S /* Programa Olá Mundo */ int main(void) { printf( Olá mundo\n ); //exibe Olá mundo
Modulo 12: alocação dinâmica de memória
PROGRAMAÇÃO DE COMPUTADORES V - TCC- 00.323 Modulo 12: alocação dinâmica de memória Aura - Erick [email protected], [email protected] Roteiro porque e como utilizar a alocação dinâmica funções: malloc (
Programação: Vetores
Programação de Computadores I Aula 09 Programação: Vetores José Romildo Malaquias Departamento de Computação Universidade Federal de Ouro Preto 2011-1 1/62 Motivação Problema Faça um programa que leia
Funções em C. Lucas Ferrari de Oliveira Professor Adjunto. Linguagem de Programação Estruturada I. Universidade Federal do Paraná
em C Linguagem de Programação Estruturada I Lucas Ferrari de Oliveira Professor Adjunto Universidade Federal do Paraná Sumário Funções: Conceitos; Forma Geral das funções; Regras de Escopo; Argumentos
Curso de C. Introdução by Arnaldo V. Moura e Daniel F. Ferber 3/10/ :43 AM
Curso de C Introdução 1 Introdução Roteiro: Recordando Algoritmos Linguagem de Programação O computador Instruções de Máquina Níveis de Abstração Compilação 2 Algoritmos Recordando: Algoritmo: conjunto
Ambiente de desenvolvimento
Linguagem C Ambiente de desenvolvimento Um programa em C passa por seis fases até a execução: 1) Edição 2) Pré-processamento 3) Compilação 4) Linking 5) Carregamento 6) Execução Etapa 1: Criação do programa
Introdução OpenMP. Nielsen Castelo Damasceno
Introdução OpenMP Nielsen Castelo Damasceno Computação de auto desempenho Processamento Paralelo Memória Distribuída e Compartilhada Modelo de programação OpenMP Métricas de Desempenho Computação de auto
TÉCNICAS DE LINGUAGEM DE PROGRAMAÇÃO
TÉCNICAS DE LINGUAGEM DE PROGRAMAÇÃO Ponteiros Definição Variável: área de memória que armazena dados de um certo tipo. Na memória, toda variável possui um endereço. Um Ponteiro é uma variável especial
MCTA028 Programação Estruturada Aula 01: - Introdução à linguagem C - Teste de avaliação
MCTA028 Programação Estruturada Aula 01: - Introdução à linguagem C - Teste de avaliação Prof. João Henrique Kleinschmidt Material elaborado pelo Prof. Jesús P. Mena-Chalco 3Q-2018 Linguagens de programação
Introdução a Programação. Ponteiros e Vetores, Alocação Dinâmica
Introdução a Programação Ponteiros e Vetores, Alocação Dinâmica Tópicos da Aula Hoje aprenderemos que existe uma forte relação entre ponteiros e vetores Associação entre ponteiros e vetores Ponteiros constantes
1 Exercícios com ponteiros
Computação para Informática Funções e Ponteiros1 EXERCÍCIOS COM PONTEIROS Computação para Informática - Prof. Adriano Joaquim de Oliveira Cruz Aula Prática - Funções e ponteiros O objetivo desta aula prática
Estruturas de Dados. Introdução Definição de Ponteiros Declaração de Ponteiros em C Manipulação de Ponteiros em C
Estruturas de Dados Revisão de Ponteiros Prof. Ricardo J. G. B. Campello Sumário Introdução Definição de Ponteiros Declaração de Ponteiros em C Manipulação de Ponteiros em C Operações Ponteiros e Arranjos
Alocação Dinâmica em C
Universidade de São Paulo São Carlos Instituto de Ciências Matemáticas e de Computação Alocação Dinâmica em C Profa Rosana Braga Adaptado de material preparado pela profa Silvana Maria Affonso de Lara
Programação de Alto Desempenho - 2. Prof: Carla Osthoff
Programação de Alto Desempenho - 2 Prof: Carla Osthoff E-mail: [email protected] 3- Modelos de programação paralela Shared Memory/Threads Posix Win32 treads OpenMP Message Passing MPI Data Parallel OpenCL/Cuda
Programação 1. Atribuição, operadores aritméticos, entrada de dados. Técnico em Eletrônica Semestre 5 02
Programação 1 Atribuição, operadores aritméticos, entrada de dados Técnico em Eletrônica Semestre 5 02 Armazenando na memória tipo de variável #include #include main() { int ano; Declaração
