Matemática Discreta para Ciência da Computação

Documentos relacionados
Linguagens Formais e Autômatos P. Blauth Menezes

Linguagens Formais e Autômatos P. Blauth Menezes

Linguagens Formais e Autômatos P. Blauth Menezes

sumário 1 introdução e conceitos básicos 1 2 noções de lógica e técnicas de demonstração introdução à matemática discreta...

Matemática Discreta para Ciência da Computação

Matemática Discreta para Ciência da Computação

Linguagens Formais e Autômatos P. Blauth Menezes

Expressões Regulares e Gramáticas Regulares

Matemática Discreta para Ciência da Computação

IBM1088 Linguagens Formais e Teoria da

Linguagens Formais. Aula 01 - Conceitos Básicos. Prof. Othon Batista Mestre em Informática

Matemática Discreta para Computação e Informática

Teoria da Computação Aula 02 Introdução

Linguagens Formais e Autômatos P. Blauth Menezes

Linguagens Formais e Autômatos P. Blauth Menezes

IV Gramáticas Livres de Contexto

Disciplina: LINGUAGENS FORMAIS, AUTÔMATOS E COMPUTABILIDADE Prof. Jefferson Morais

Linguagens Regulares. Prof. Daniel Oliveira

Linguagens Formais e Autômatos P. Blauth Menezes

Matemática Discreta para Ciência da Computação

INE5317 Linguagens Formais e Compiladores. AULA 4: Gramáticas

1 INTRODUÇÃO E CONCEITOS BÁSICOS

Linguagens Formais e Autômatos 02/2015. LFA Aula 02. introdução 28/09/2015. Celso Olivete Júnior.

Um alfabeto é um conjunto de símbolos indivisíveis de qualquer natureza. Um alfabeto é geralmente denotado pela letra grega Σ.

Plano da aula. Compiladores. Os erros típicos são sintáticos. Análise Sintática. Usando Gramáticas. Os erros típicos são sintáticos

UNIVERSIDADE FEDERAL RURAL DO SEMI-ÁRIDO CURSO: CIÊNCIA DA COMPUTAÇÃO. Prof.ª Danielle Casillo

Linguagens Formais - Preliminares

Linguagens Formais e Autômatos

Linguagens Formais e Autômatos

LINGUAGENS FORMAIS Definições. Desenvolveram-se na História em função da necessidade dos grupos humanos que as empregavam

Modelos de Computação

LFA. Provas formais; Indução; Sintaxe e Semântica Teoria dos Conjuntos

Gramática. Prof. Yandre Maldonado e Gomes da Costa. Prof. Yandre Maldonado - 1

Gramática. Gramática. Gramática

Concurso Público para provimento de cargo efetivo de Docentes. Edital 20/2015 CIÊNCIA DA COMPUTAÇÃO II Campus Rio Pomba

Linguagens Livres de Contexto

Linguagens Formais e Autômatos. Simplificação de Gramáticas Livre do Contexto (GLC)

Linguagens Formais e Autômatos P. Blauth Menezes

Gramática regular. IBM1088 Linguagens Formais e Teoria da Computação. Evandro Eduardo Seron Ruiz Universidade de São Paulo

Apostila 05 Assunto: Linguagens dos tipos 0 e 1

LINGUAGEM LIVRE DE CONTEXTO GRAMÁTICA LIVRE DE CONTEXTO

Máquina de Turing Linguagens Sensíveis ao Contexto e Enumeráveis Recursivamente

Lista de Exercícios CT-200 Primeiro Bimestre Carlos Henrique Quartucci Forster Estagiário: Wesley Telles. Revisão de Teoria de Conjuntos

I.2 Introdução a Teoria da Computação

Compiladores. Análise lexical. Plano da aula. Motivação para análise lexical. Vocabulário básico. Estrutura de um compilador

TRANSFORMAÇÃO DE GRAMÁTICAS LIVRES DO CONTEXTO PARA EXPRESSÕES REGULARES ESTENDIDAS

Apostila 02. Objetivos: Estudar os autômatos finitos Estudar as expressões regulares Estudar as gramáticas regulares Estudar as linguagens regulares

1 introdução. capítulo. O que é uma solução computável? Quais são os limites do que pode ser computado? Existem problemas sem solução computacional?

INE5317 Linguagens Formais e Compiladores AULA 9: Propriedades e Reconhecimento das Linguagens Livres do Contexto

Procedimentos e Algorítmos Programas e Linguagens de Programação Tese de Church-Turing Formas de Representação de Linguagens

Histórico e motivação

Linguagens Formais e Autômatos 02/2016. LFA Aula 01 24/10/2016. Celso Olivete Júnior.

Capítulo 9: Linguagens sensíveis ao contexto e autômatos linearmente limitados.

V Análise Sintática. V.1.1 Gramáticas Livres de Contexto Definições de GLC

Gramáticas Livres de Contexto Parte 1

Programação em Lógica. UCPEL/CPOLI/BCC Lógica para Ciência da Computação Luiz A M Palazzo Maio de 2010

Apostila 01 Fundamentação da Teoria da Computação e Linguagens Formais

Capítulo 1: Alfabetos, cadeias, linguagens

Teoria da Computação. Unidade 1 Conceitos Básicos. Referência Teoria da Computação (Divério, 2000)

SCC Capítulo 1 Linguagens Regulares e Autômatos Finitos

LINGUAGENS FORMAIS E AUTÔMATOS. Prova 2-10/06/ Prof. Marcus Ramos

Prof. Dr. Marcos Castilho. Departamento de Informática/UFPR. 22 de Fevereiro de 2018

Aula 2, 2014/2 Sintaxe da Lógica dos Conectivos

Gramática Livre de Contexto

Linguagens Livres de Contexto

TEORIA DAS LINGUAGENS 3. GRAMÁTICAS INDEPENDENTES DE CONTEXTO

INE5403 FUNDAMENTOS DE MATEMÁTICA DISCRETA

UNIVERSIDADE FEDERAL RURAL DO SEMI-ÁRIDO CURSO: CIÊNCIA DA COMPUTAÇÃO. Prof.ª Danielle Casillo

Exemplo preliminar. Considere a linguagem dos Palíndromos Lpal:

LFA Aula 09. Gramáticas e Linguagens Livres de Contexto 18/01/2016. Linguagens Formais e Autômatos. Celso Olivete Júnior.

Notas sobre Definições Recursivas

ACH2043 INTRODUÇÃO À TEORIA DA COMPUTAÇÃO

COMPILADORES. Revisão Linguagens formais Parte 01. Geovane Griesang

SCC Capítulo 2 Linguagens Livres de Contexto e Autômatos de Pilha (versão 2)

Resolução Exe 2.12 Monolítico Recursivo

Conceitos Básicos. Vocabulário Cadeias Linguagens Expressões Regulares Problema X Linguagem

Prof. Adriano Maranhão COMPILADORES

Máquinas de Turing - Computabilidade

INE5317 Linguagens Formais e Compiladores AULA 5: Autômatos Finitos

Compiladores I Prof. Ricardo Santos (cap 3 Análise Léxica: Introdução, Revisão LFA)

Linguagens Formais e Problemas de Decisão

INE5317 Linguagens Formais e Compiladores AULA 6: Propriedades das Linguagens Regulares

Alfabeto, Cadeias, Operações e Linguagens

Demonstrações. Terminologia Métodos

Gramáticas ( [HMU00], Cap. 5.1)

Expressões regulares

Construção de Compiladores Aula 16 - Análise Sintática

Teoria de Linguagens 1 o semestre de 2018 Professor: Newton José Vieira Primeira Lista de Exercícios Data de entrega: 17/4/2018 Valor: 10 pontos

LINGUAGENS FORMAIS E AUTÔMATOS

UNIVERSIDADE FEDERAL RURAL DO SEMI-ÁRIDO CURSO: CIÊNCIA DA COMPUTAÇÃO. Prof.ª Danielle Casillo

Transcrição:

Matemática Discreta para Ciência da Computação P. Blauth Menezes blauth@inf.ufrgs.br Departamento de Informática Teórica Instituto de Informática / UFRGS Matemática Discreta para Ciência da Computação - P. Blauth Menezes 1

Matemática Discreta para Ciência da Computação P. Blauth Menezes 1 Introdução e Conceitos Básicos 2 Lógica e Técnicas de Demonstração 3 Álgebra de Conjuntos 4 Relações 5 Funções Parciais e Totais 6 Endorrelações, Ordenação e Equivalência 7 Cardinalidade de Conjuntos 8 Indução e Recursão 9 Álgebras e Homomorfismos 10 Reticulados e Álgebra Booleana 11 Conclusões Matemática Discreta para Ciência da Computação - P. Blauth Menezes 2

8 Indução e Recursão 8.1 Princípio da Indução Matemática 8.2 Prova Indutiva 8.3 Segundo Princípio da Indução Matemática 8.4 Definição Indutiva 8.5 Expressões Regulares 8.6 Computações de um Autômato Finito 8.7 Leitura Complementar: Gramática e BNF 8.8 Recursão 8.9 Leitura Complementar: Funções Recursivas Parciais Matemática Discreta para Ciência da Computação - P. Blauth Menezes 3

8 Indução e Recursão 8.1 Princípio da Indução Matemática Princípio da Indução Matemática técnica para lidar com tipos de dados que têm uma relação de boa-ordem Relação de Boa-Ordem todo conjunto não-vazio de elementos do tipo de dado tem um elemento mínimo segundo esta relação de ordem exemplo: N Matemática Discreta para Ciência da Computação - P. Blauth Menezes 4

Dada uma boa ordem pode-se aplicar indução para provar propriedades que valem para todo elemento Por simplicidade tipo de dados considerado: N ou qq outro conjunto isomorfo a N Exemplo simples que ilustra o Princípio da Indução Matemática efeito dominó Matemática Discreta para Ciência da Computação - P. Blauth Menezes 5

Efeito Dominó ao derrrubar a primeira peça todas as demais peças serão derrubadas em cadeia Matemática Discreta para Ciência da Computação - P. Blauth Menezes 6

Para estar certo que ocorrerá primeira peça é derrubada (direção das demais) (1) se qq peça está suficientemente próxima da seguinte, então, ao ser derrubada, fará com que a seguinte também seja derrubada (2) Então por (1), a primeira peça é derrubada por (2), a segunda peça é derrubada por (2), a terceira peça é derrubada e assim sucessivamente Portanto, para i tão grande quanto se queira i-ésima peça é derrubada Logo, para qq n n-ésima peça é derrubada Matemática Discreta para Ciência da Computação - P. Blauth Menezes 7

Princípio da Indução Matemática pode ser resumido como se o início é correto e se coisa alguma pode dar errada, então sempre será correto Matemática Discreta para Ciência da Computação - P. Blauth Menezes 8

Def: Princípio da Indução Matemática p(n) uma proposição sobre M = {n N n m e m N } Princípio da Indução Matemática p(m) é verdadeira para qq k M, p(k) p(k + 1) então, para qq n N, p(n) é verdadeira Base de indução p(m) Hipótese de indução p(k) Passo de indução p(k) p(k + 1) Matemática Discreta para Ciência da Computação - P. Blauth Menezes 9

Na definição forma mais tradicional denominada de Primeiro Princípio da Indução Matemática formulações alternativas: adiante Duas aplicações da Indução Matemática destacam-se Prova Indutiva ou Prova por Indução técnica de demonstração comum na CC & Informática não é do domínio da lógica pura Definição Indutiva ou Definição Recursiva comum na CC & Informática já usada anteriormente de forma informal Matemática Discreta para Ciência da Computação - P. Blauth Menezes 10

Recursão conceito próximo ao de indução e presente na grande maioria das linguagens de programação é o de recursão. Exemplos de construções baseadas em indução e recursão e de especial interesse para CC e Informática Computações de um autômato finito Gramáticas de Chomsky e a Forma de Backus Naur (ou BNF) Expressões Regulares Funções Recursivas Parciais ou Funções Recursivas de Kleene Matemática Discreta para Ciência da Computação - P. Blauth Menezes 11

8 Indução e Recursão 8.1 Princípio da Indução Matemática 8.2 Prova Indutiva 8.3 Segundo Princípio da Indução Matemática 8.4 Definição Indutiva 8.5 Expressões Regulares 8.6 Computações de um Autômato Finito 8.7 Leitura Complementar: Gramática e BNF 8.8 Recursão 8.9 Leitura Complementar: Funções Recursivas Parciais Matemática Discreta para Ciência da Computação - P. Blauth Menezes 12

8.2 Prova Indutiva Prova Indutiva ou Prova por Indução técnica de demonstração baseada no Princípio da Indução Matemática não é do domínio da lógica pura limita-se a confirmar se p(n) é correta Demonstração por indução demonstrar a base de indução p(m) fixado um k supor verdadeira a hipótese de indução p(k) demonstrar o passo de indução p(k) p(k + 1) Matemática Discreta para Ciência da Computação - P. Blauth Menezes 13

Exp: Prova por Indução - p(n): n < 2 n para qq n N, tem-se que n < 2 n Base de Indução. k = 0 0 < 1 = 2 0 Hipótese de Indução. Suponha que, para k N p(k): k < 2 k é verdadeira Passo de Indução. Prova para p(k + 1): k + 1 < 2 k+1 k + 1 < 2 k + 1 2 k + 2 k = 2 * 2k = 2 k+1 hipótese de indução Logo, para qq n N, tem-se que n < n 2 Matemática Discreta para Ciência da Computação - P. Blauth Menezes 14

Exp: Prova por Indução - p(n): 2 n < n! para qualquer n N, se n > 3, então 2 n < n! Base de Indução. k = 4 4 2 = 16 < 24 = 4! Hipótese de Indução. Suponha para k > 3 p(k): 2 k < k! é verdadeira Passo de Indução. Prova para p(k + 1): 2 k+1 < (k + 1)! 2 k+1 = 2 * 2k < 2 * k! < (k + 1) * k! = (k + 1)! hipótese de indução Logo, para qq n N, se n > 3, então 2 n < n! Matemática Discreta para Ciência da Computação - P. Blauth Menezes 15

Exp: Prova por Indução - 1 + 2 + + n = (n 2 + n)/2 para qualquer n N, tem-se que1 + 2 + + n = (n 2 + n)/2 Base de Indução. k = 0 (0 2 + 0)/2 = (0 + 0)/2 = 0/2 = 0 Hipótese de Indução. Suponha para k N p(k): 1 + 2 + + k = (k 2 + k)/2 é verdadeira Passo de Indução. p(k+1): 1+2+ +k+(k+1) = ((k+1) 2 +k+1)/2 1 + 2 + + k + (k + 1) = (1 + 2 + + k) + (k + 1) = pela hipótese de indução (k 2 + k)/2 + (k + 1) = (k 2 + k)/2 + (2k + 2)/2 = (k 2 + k + 2k + 2)/2 = ((k 2 + 2k + 1) + (k + 1))/2 = ((k + 1) 2 + (k + 1))/2 Matemática Discreta para Ciência da Computação - P. Blauth Menezes 16

Exp: Prova por Indução - #2 A = 2 #A Foi afirmado que se o cardinal de um conjunto A é n então o cardinal de 2 A é 2 n, o que justifica a notação 2 A. Teorema (versão limitada a conjuntos finitos) para qq conjunto finito A, se #A = n, então tem-se que #2 A = 2 n Considere o seguinte exemplo motivacional: P( ) = { } P({ a }) = {, { a } } P({ a, b }) = {, { a }, { b }, { a, b } } P({ a, b, c }) = {, { a }, { b }, { c }, { a, b }, { a, c }, { b, c }, { a, b, c } } Matemática Discreta para Ciência da Computação - P. Blauth Menezes 17

Observe P({ a, b }) e P({ a, b, c }) (por exemplo) metade dos elementos de P({ a, b, c }) corresponde a P({ a, b }) P({ a, b, c }) = P({ a, b }) { { c }, { a, c }, { b, c }, { a, b, c } } outra metade de P({ a, b, c }) corresponde a P({ a, b }), adicionando-se c a cada conjunto P({ a, b, c }) = P({ a, b }) { { c }, { a } { c }, { b } { c }, { a, b } { c } } Ou seja, #P({ a, b, c }) possui o dobro de elementos de #P({ a, b }) cada elemento adicionado a um conjunto duplica o cardinal do correspondente conjunto das partes Matemática Discreta para Ciência da Computação - P. Blauth Menezes 18

Base de Indução. Seja k = 0 (#A = 0). Então A = P( ) = { } p(0) é verdadeira pois #P( ) = 1 = 2 0 = 2 # Hipótese de Indução. Suponha que, para algum k N (#A = k) p(k): #P(A) = 2 #A é verdadeira Matemática Discreta para Ciência da Computação - P. Blauth Menezes 19

Passo de Indução. p(k + 1). Sem perda de generalidade, suponha os seguintes conjuntos (conjuntos com o mesmo cardinal são isomorfos) A = { 1, 2, 3,, k } B = { 1, 2, 3,, k, k + 1 } Por hipótese de indução #P(A) = 2 k P(A) são todos subconjuntos de B que não possuem o elemento k + 1 demais subconjuntos B são aqueles que contém o elemento k + 1 a união de cada conjunto de P(A) com { k + 1 } resultando em outros 2 k conjuntos #P(B) = 2 k + 2 k = 2 k+1 Logo, para qq conjunto finito A, se #A = n, então tem-se que #2 A = 2 n Matemática Discreta para Ciência da Computação - P. Blauth Menezes 20

8 Indução e Recursão 8.1 Princípio da Indução Matemática 8.2 Prova Indutiva 8.3 Segundo Princípio da Indução Matemática 8.4 Definição Indutiva 8.5 Expressões Regulares 8.6 Computações de um Autômato Finito 8.7 Leitura Complementar: Gramática e BNF 8.8 Recursão 8.9 Leitura Complementar: Funções Recursivas Parciais Matemática Discreta para Ciência da Computação - P. Blauth Menezes 21

8.3 Segundo Princípio da Indução Matemática Freqüentemente é conveniente trabalhar com outras formulações do Princípio da Indução Matemática Primeiro Princípio da Indução Matemática princípio introduzido Segundo Princípio da Indução Matemática formulação especialmente importante considera não apenas o resultado anterior p(k) mas todos os anteriores para concluir p(k + 1) Matemática Discreta para Ciência da Computação - P. Blauth Menezes 22

Lembrando Def: (Primeiro) Princípio da Indução Matemática p(n) uma proposição sobre M = {n N n m e m N } Princípio da Indução Matemática p(m) é verdadeira para qq k M, p(k) p(k + 1) então, para qq n N, p(n) é verdadeira Matemática Discreta para Ciência da Computação - P. Blauth Menezes 23

Def: Segundo Princípio da Indução Matemática Seja p(n) proposição sobre M = {n N n m e m N }. Primeira Versão. p(m) é verdadeira para qq k M: p(m) p(m + 1) p(k) p(k + 1) então, para qq n N, p(n) é verdadeira Segunda Versão. Suponha t N p(m), p(m + 1),,p(m + t), são verdadeiras; para qq k M tq k m + t: p(m) p(m + 1) p(k) p(k + 1) então, para qq n N, p(n) é verdadeira Segunda versão: prova os t primeiros casos em separado para verificar a base de indução Matemática Discreta para Ciência da Computação - P. Blauth Menezes 24

Aplicação usual do Segundo Princípio definição e prova de propriedades de expressões fórmulas árvores, etc. razão pela qual freqüentemente é denominado de indução em estrutura indução estruturada Matemática Discreta para Ciência da Computação - P. Blauth Menezes 25

Exp: Segundo Princípio: Proposição Lógica Suponha que p é uma proposição lógica a qual contém exclusivamente os conetivos lógicos, e. Se o valor verdade de todos os átomos de p é V, então o valor verdade de p é V Uma prova por indução (no número de átomos, primeira versão): Base de Indução. Seja k = 1 p é um átomo portanto, por hipótese, p é V Hipótese de Indução. Suponha que, para algum k N, e para qq u N tal que u k se o número de átomos de p é u, então o valor verdade de p é V Matemática Discreta para Ciência da Computação - P. Blauth Menezes 26

Passo de Indução. Seja p uma proposição com k + 1 átomos p pode ser reescrita (q e r possuem individualmente no máximo k átomos e, conjuntamente, k + 1 átomos): q r q r q r por hipótese de indução q e r são V portanto, em qualquer dos casos, p é V Matemática Discreta para Ciência da Computação - P. Blauth Menezes 27

Exp: Segundo Princípio: Postagem Qualquer valor de postagem igual ou maior que 12 reais pode ser formado usando exclusivamente selos de 4 e de 5 reais Uma prova por indução (no número de selos, segunda versão): Base de Indução. Seja k { 12, 13, 14, 15 } 12 reais: 3 selos de 4 13 reais: 2 selos de 4 e 1 selo de 5 14 reais: 1 selo de 4 e 2 selos de 5 15 reais: 3 selos de 5 Matemática Discreta para Ciência da Computação - P. Blauth Menezes 28

Hipótese de Indução. Suponha que, para algum k N, e para qq u N tal que 15 u k se o valor é u, então pode ser formado usando selos de 4 e 5 Passo de Indução. Seja uma postagem cujo valor é k + 1 reais tal postagem pode ser formada usando uma postagem de k - 3 reais mais um selo de 4 reais Matemática Discreta para Ciência da Computação - P. Blauth Menezes 29

8 Indução e Recursão 8.1 Princípio da Indução Matemática 8.2 Prova Indutiva 8.3 Segundo Princípio da Indução Matemática 8.4 Definição Indutiva 8.5 Expressões Regulares 8.6 Computações de um Autômato Finito 8.7 Leitura Complementar: Gramática e BNF 8.8 Recursão 8.9 Leitura Complementar: Funções Recursivas Parciais Matemática Discreta para Ciência da Computação - P. Blauth Menezes 30

8.4 Definição Indutiva Princípio da indução Matemática pode ser usado em definições Definição Indutiva ou Definição Recursiva Base de indução explicita os casos elementares (os mais simples) Passo de indução/recursão demais casos são definidos em termos dos anteriores Definição Indutiva ja foi usado informalmente Fecho transitivo Matemática Discreta para Ciência da Computação - P. Blauth Menezes 31

Exp: Definição Indutiva Fecho Transitivo Endorrelação R: A A. Fecho Transitivo Se a, b R, então a, b R + (1) Se a, b R + e b, c R +, então a, c R + (2) Os únicos elementos de R + são os construídos como acima (3) (1) base de indução (2) passo de indução (hipótese?) (3) garante que, de fato, é definição indutiva (3) pode ser omitido (subentendido) Matemática Discreta para Ciência da Computação - P. Blauth Menezes 32

Exp: Def. Indutiva Conjunto de Todas as Palavras Alfabeto Σ = { a, b } Base de Indução. ε Σ* qq x Σ, tem-se que x Σ* Σ* = { ε, a, b, aa, ab, ba, bb, aaa, } Passo de Indução. se u e v são palavras de Σ*, então a concatenação u v é palavra de Σ* Matemática Discreta para Ciência da Computação - P. Blauth Menezes 33

Exp: Definição Indutiva Fórmula Lógica Simplificada, não incluindo quantificadores, variáveis, etc. Base de Indução qq proposição atômica (incluindos V e F) é fórmula Passo de Indução. Se q e r são fórmulas então também são fórmulas ( q) (q r) (q r) (q r) (q r) Matemática Discreta para Ciência da Computação - P. Blauth Menezes 34

Exp: Definição Indutiva Princípio da Indução Mat Ilustração da relação entre o Princípio da Indução e a definição indutiva definição indutiva (no número de conetivos) de fórmula lógica usando o Segundo Princípio Base de Indução. Seja k = 0 qq proposição atômica (incluindo V e F) é uma fórmula; Hipótese de Indução. Suponha que, para algum k N, e para qq i N tal que i k se p é uma fórmula com i conetivos, então p é uma fórmula lógica Matemática Discreta para Ciência da Computação - P. Blauth Menezes 35

Passo de Indução. Seja p uma fórmula com k + 1 conetivos p pode ser reescrita q e r são fórmulas e possuem conjuntamente k conetivos ( q) (q r) (q r) (q r) (q r) Matemática Discreta para Ciência da Computação - P. Blauth Menezes 36

8 Indução e Recursão 8.1 Princípio da Indução Matemática 8.2 Prova Indutiva 8.3 Segundo Princípio da Indução Matemática 8.4 Definição Indutiva 8.5 Expressões Regulares 8.6 Computações de um Autômato Finito 8.7 Leitura Complementar: Gramática e BNF 8.8 Recursão 8.9 Leitura Complementar: Funções Recursivas Parciais Matemática Discreta para Ciência da Computação - P. Blauth Menezes 37

8.5 Expressões Regulares Autômato Finito já introduzido é especialmente importante define a classe das linguagens regulares possui diversas aplicações na Computação e Informática Expressões Regulares alternativa para definir linguagens regulares definição indutiva que segue Segundo Princípio da Indução Matemática (segunda versão) Matemática Discreta para Ciência da Computação - P. Blauth Menezes 38

Def: Expressão Regular (ER) sobre um alfabeto Σ Base de Indução. é ER e denota a linguagem vazia ε é ER e denota a linguagem { ε } qq símbolo x Σ é ER e denota a linguagem { x } Passo de Indução. Se r e s são ER e denotam as ling. R e S, então União. (r + s) é ER e denota a linguagem R S Concatenação. (rs) é ER e denota a linguagem R S = { uv u R e v S } Concatenação Sucessiva. (r*) é ER e denota a linguagem R* Matemática Discreta para Ciência da Computação - P. Blauth Menezes 39

Exp: Expressão Regular Omissão de parênteses em uma ER é usual concatenação sucessiva: precedência sobre concatenação e união concatenação: precedência sobre união ER Linguagem Representada aa somente a palavra aa ba* todas palavras iniciam por b seguido por 0 ou mais a (a + b)* todas as palavras sobre { a, b } (a + b)*aa(a + b)* todas as palavras contendo aa como subpalavra a*ba*ba* todas as palavras contendo exatamente dois b (a + b)*(aa + bb) todas as palavras que terminam com aa ou bb (a + ε)(b + ba)* todas as palavras sem dois a consecutivos Matemática Discreta para Ciência da Computação - P. Blauth Menezes 40

8 Indução e Recursão 8.1 Princípio da Indução Matemática 8.2 Prova Indutiva 8.3 Segundo Princípio da Indução Matemática 8.4 Definição Indutiva 8.5 Expressões Regulares 8.6 Computações de um Autômato Finito 8.7 Leitura Complementar: Gramática e BNF 8.8 Recursão 8.9 Leitura Complementar: Funções Recursivas Parciais Matemática Discreta para Ciência da Computação - P. Blauth Menezes 41

8.6 Computações de um Autômato Finito Exemplos de modelos computacionais introduzidos Rede de Petri, definida como uma relação Autômato Finito, definido como uma função parcial Definidos sintaticamente definições formais de sua forma Semântica?? interpretação do funcionamento ou processamento introduzida textualmente, de forma informal Matemática Discreta para Ciência da Computação - P. Blauth Menezes 42

Autômato Finito processamento de um Autômato Finito é a sucessiva aplicação de computações atômicas (transições) a b b a a q 0 b q 0 b q 1 q 1 q 2 a a b q 2 q f q f a,b q f Matemática Discreta para Ciência da Computação - P. Blauth Menezes 43

Programa de um Autômato Finito: função parcial δ: Q Σ Q δ( q, a ) = p no estado q, ao ler o símbolo a, assume o estado p Para dar semântica à sintaxe de um Autômato Finito estender a definição da função programa argumento: um estado e uma palavra definida indutivamente Matemática Discreta para Ciência da Computação - P. Blauth Menezes 44

Função Programa Estendida base de indução: entrada vazia (palavra vazia) permanece no mesmo estado passo de indução: entrada não-vazia (palavra não-vazia) processa o primeiro símbolo da entrada, usando δ mesmo raciocínio sucessivamente ao resto da palavra Função Programa Estendida definição formal δ(q, ε) = q δ(q, aw) = δ(δ(q, a), w) δ: Q Σ* Q Matemática Discreta para Ciência da Computação - P. Blauth Menezes 45

Exp: Função Programa Estendida a b b a a q 0 b q 0 b q 1 q 1 q 2 a a b q 2 q f q f a,b q f δ(q 0, abba) = δ(δ(q 0, a), bba) = δ(q 1, bba) = δ(δ(q 1, b), ba) = δ(q 2, ba) = δ(δ(q 2, b), a) = δ(q f, a) = δ(δ(q f, a), ε) = δ(q f, ε) = q f Matemática Discreta para Ciência da Computação - P. Blauth Menezes 46

8 Indução e Recursão 8.1 Princípio da Indução Matemática 8.2 Prova Indutiva 8.3 Segundo Princípio da Indução Matemática 8.4 Definição Indutiva 8.5 Expressões Regulares 8.6 Computações de um Autômato Finito 8.7 Leitura Complementar: Gramática e BNF 8.8 Recursão 8.9 Leitura Complementar: Funções Recursivas Parciais Matemática Discreta para Ciência da Computação - P. Blauth Menezes 47

8.7 Gramática e BNF Gramáticas de Chomsky formalismo universalmente aceito e usado em Computação e Informática e outras áreas Linguagens Formais definição e estudo das propriedades das linguagens Teoria da Computação limites da solucionabilidade de problemas e propriedades Linguagens Naturais linguagens como o português Sistemas Biológicos simulação do desenvolvimento de sistemas vivos Matemática Discreta para Ciência da Computação - P. Blauth Menezes 48

Prova-se: gramática é equivalente a Máq. de Turing poder computacional Hipótese de Church qq função computável pode ser especificada por uma gramática gramática: aceita como definição formal de algoritmo Gramáticas em Computação e Informática especialmente importantes para definir a sintaxe de linguagens Pascal, C, definidas usando gramáticas Matemática Discreta para Ciência da Computação - P. Blauth Menezes 49

8 Indução e Recursão 8.1 Princípio da Indução Matemática 8.2 Prova Indutiva 8.3 Segundo Princípio da Indução Matemática 8.4 Definição Indutiva 8.5 Expressões Regulares 8.6 Computações de um Autômato Finito 8.7 Leitura Complementar: Gramática e BNF 8.7.1 Gramática 8.7.2 BNF 8.8 Recursão 8.9 Leitura Compl.: Funções Recursivas Parciais Matemática Discreta para Ciência da Computação - P. Blauth Menezes 50

8.7.1 Gramática Gramática é, basicamente conjunto finito de regras aplicadas sucessivamente, geram palavras Geração de palavra indutivamente definida Linguagem conjunto de todas as palavras geradas forma finita de expressar sintaxe de linguagens eventualmente infinitas Matemática Discreta para Ciência da Computação - P. Blauth Menezes 51

Gramáticas para linguagens naturais??? mesmas Definição de Semântica??? podem ser usadas gramáticas em geral, são usados outros tipos de formalismos Matemática Discreta para Ciência da Computação - P. Blauth Menezes 52

Def: Gramática Gramática de Chomsky ou simplesmente Gramática V - conjunto finito de símbolos variáveis ou não-terminais T - conjunto finito de símbolos terminais disjunto de V P: (V T) + (V T)* relação finita regra de produção: par da relação P é finito S - elemento distinguido de V símbolo inicial ou variável inicial Matemática Discreta para Ciência da Computação - P. Blauth Menezes 53

Notação regra de produção α, β α β grupo de regras da forma α β 1, α β 2,..., α β n Regras de produção α β 1 β 2 β n definem as condições de geração das palavras da linguagem Derivação aplicação de uma regra de produção par de uma relação Matemática Discreta para Ciência da Computação - P. Blauth Menezes 54

Def: Relação de Derivação G gramática tq P: (V T) + (V T)* e S é o símbolo inicial Derivação é um par da Relação de Derivação : (V T) + (V T)* α, β da relação é denotado de forma infixada α β Relação é indutivamente definida qq regra S β de P, então S β é derivação qq derivação η ρ α σ se α β é regra de P então η ρ β σ Matemática Discreta para Ciência da Computação - P. Blauth Menezes 55

Def: Linguagem Gerada (por uma Gramática) G gramática tq S é símbolo inicial Linguagem Gerada pela gramática G Linguagem(G) = { w T* S + w } + denota o fecho transitivo da relação de derivação portanto: palavra de uma linguagem não pode conter variáveis Matemática Discreta para Ciência da Computação - P. Blauth Menezes 56

Exp: Gramática e Derivação - Números Naturais Gramática G V = { N, D }, sendo que N é o símbolo inicial T = { 0, 1, 2,, 9 } P contém as regras N D N DN D 0 1 9 Derivação de 243 (existe mais alguma geração?) N DN 2N 2DN 24N 24D 243 Distingue zeros à esquerda:123 0123 Matemática Discreta para Ciência da Computação - P. Blauth Menezes 57

Interpretação indutiva Base de Indução todo dígito é um natural Passo de Indução Se n é um natural então a concatenação de n com qq dígito também é natural Matemática Discreta para Ciência da Computação - P. Blauth Menezes 58

Exp: Gramática e Derivação - Expressão Aritmética Gramática G V = { E }, sendo que E é o símbolo inicial T = { +,, (, ), x } P contém as regras (interpretação indutiva?) E E+E E E E E (E) E x (x + x) x Linguagem(G)??? E E E (E) E (E + E) E (x + E) E (x + x) E (x + x) x Matemática Discreta para Ciência da Computação - P. Blauth Menezes 59

8 Indução e Recursão 8.1 Princípio da Indução Matemática 8.2 Prova Indutiva 8.3 Segundo Princípio da Indução Matemática 8.4 Definição Indutiva 8.5 Expressões Regulares 8.6 Computações de um Autômato Finito 8.7 Leitura Complementar: Gramática e BNF 8.7.1 Gramática 8.7.2 BNF 8.8 Recursão 8.9 Leitura Compl.: Funções Recursivas Parciais Matemática Discreta para Ciência da Computação - P. Blauth Menezes 60

8.7.2 BNF Forma de Backus Naur ou simplesmente BNF (do inglês, Backus Naur Form) BNF variáveis são delimitas por e por palavras não-delimitas: símbolos terminais representação de uma regra de produção α, β α ::= β Matemática Discreta para Ciência da Computação - P. Blauth Menezes 61

Exp: BNF - Identificador em Pascal BNF - ident é o símbolo inicial ident ::= letra ident letra ident dígito letra ::= a b z dígito ::= 0 1 9 Base de Indução toda letra é um identificador Passo de Indução se S é identificador então a concatenação de S com qq letra/dígito é identificador Matemática Discreta para Ciência da Computação - P. Blauth Menezes 62

8 Indução e Recursão 8.1 Princípio da Indução Matemática 8.2 Prova Indutiva 8.3 Segundo Princípio da Indução Matemática 8.4 Definição Indutiva 8.5 Expressões Regulares 8.6 Computações de um Autômato Finito 8.7 Leitura Complementar: Gramática e BNF 8.8 Recursão 8.9 Leitura Complementar: Funções Recursivas Parciais Matemática Discreta para Ciência da Computação - P. Blauth Menezes 63

8.8 Recursão Recursão conceito próximo ao de indução presente na grande maioria das linguagens de programação Inspirado nas Funções Recursivas de Kleene equivalente: Máquina de Turing e Gramática de Chomsky Hipótese de Church qq algoritmo pode ser expresso usando recursividade Matemática Discreta para Ciência da Computação - P. Blauth Menezes 64

Indução Recursão qq definição indutiva pode ser simulada por recursão nem toda recursão possui uma correspondente definição indutiva não necessariamente respeita a boa ordem da indução recomendável programar recursão respeitando os princípios da definição indutiva garante que o programa pára e atinge o resultado esperado Matemática Discreta para Ciência da Computação - P. Blauth Menezes 65

Exemplo importante para o entendimento da recursão Exp: Definição Indutiva Fatorial Fatorial n! n! = 1, se n = 0 n! = n * (n - 1) * (n - 2) * 1, se n > 0 Para n > 0 n * (n 1)! sendo que (n 1)! = (n - 1) * (n - 2) * 1 Da mesma forma, (n 1)! (n 1) * (n - 2)!, sendo que (n 2)! = (n - 2) * (n - 3) * 1 e assim sucessivamente Matemática Discreta para Ciência da Computação - P. Blauth Menezes 66

Base de Indução 0! = 1 Passo de Indução n! = n * (n 1)! Fatorial de 4 4! = 4 * (4 1)! = 4 * 3! = 4 * 3 * (3 1)! = 4 * 3 * 2! = 4 * 3 * 2 * (2 1)! = 4 * 3 * 2 * 1! = 4 * 3 * 2 * 1 * (1 1)! = 4 * 3 * 2 * 1 * 0! = 4 * 3 * 2 * 1 * 1 = 24 passo de indução passo de indução passo de indução base de indução Matemática Discreta para Ciência da Computação - P. Blauth Menezes 67

Exp: Função Recursiva em Pascal Fatorial function fatorial(n: integer): integer; begin if n = 0 then fatorial := 1 else fatorial := n * fatorial(n 1) end Exp: Função recursiva em Haskell Fatorial fatorial(0) = 1 fatorial(n) = n * fatorial(n 1) Matemática Discreta para Ciência da Computação - P. Blauth Menezes 68

Nem toda programação recursiva corresponde a uma definição indutiva Exp: Função Recursiva function ciclo_infinito(x: real): real; begin ciclo_infinito := x * ciclo_infinito(x) end não corresponde a noção de boa ordem não caracteriza definição indutiva Matemática Discreta para Ciência da Computação - P. Blauth Menezes 69

Obs: Eficiência da Recursão Processamento de recursão em linguagens imperativas: C, Pascal considerável demanda do recurso memória recursão expressa certos programas de forma mais elegante mas não é muito recomendado recursão escrita de forma iterativa (while, for ) em geral, mais eficiente Matemática Discreta para Ciência da Computação - P. Blauth Menezes 70

Obs: Eficiência da Recursão Recursão em Linguagens funcionais, como Haskell técnica padrão de aplicar uma operação sucessivamente base da maioria dos programas funcionais Otimizações não-usadas em linguagens imperativas estudo de tais técnica não é detalhado Matemática Discreta para Ciência da Computação - P. Blauth Menezes 71

8 Indução e Recursão 8.1 Princípio da Indução Matemática 8.2 Prova Indutiva 8.3 Segundo Princípio da Indução Matemática 8.4 Definição Indutiva 8.5 Expressões Regulares 8.6 Computações de um Autômato Finito 8.7 Leitura Complementar: Gramática e BNF 8.8 Recursão 8.9 Leitura Complementar: Funções Recursivas Parciais Matemática Discreta para Ciência da Computação - P. Blauth Menezes 72

Matemática Discreta para Ciência da Computação P. Blauth Menezes 1 Introdução e Conceitos Básicos 2 Lógica e Técnicas de Demonstração 3 Álgebra de Conjuntos 4 Relações 5 Funções Parciais e Totais 6 Endorrelações, Ordenação e Equivalência 7 Cardinalidade de Conjuntos 8 Indução e Recursão 9 Álgebras e Homomorfismos 10 Reticulados e Álgebra Booleana 11 Conclusões Matemática Discreta para Ciência da Computação - P. Blauth Menezes 73

Matemática Discreta para Ciência da Computação P. Blauth Menezes blauth@inf.ufrgs.br Departamento de Informática Teórica Instituto de Informática / UFRGS Matemática Discreta para Ciência da Computação - P. Blauth Menezes 74