Funções Recursivas. Prof.: Edson Holanda Teoria da computação - Diverio e Menezes
|
|
|
- João Gabriel Coradelli Escobar
- 9 Há anos
- Visualizações:
Transcrição
1 Funções Recursivas Prof.: Edson Holanda Teoria da computação - Diverio e Menezes
2 Tipos de Formalismos Operacional Define-se uma máquina abstrata, baseada em estados, em instruções primitivas e na especificação de como cada instrução modifica cada estado. Exemplos: formalismos Máquina Norma e Máquina de Turing
3 Tipos de Formalismos Axiomático. Associam-se regras às componentes da linguagem. As regras permitem afirmar o que será verdadeiro após a ocorrência de cada cláusula, considerando o que era verdadeiro antes da ocorrência. Exemplo: Gramáticas e lógicas.
4 Tipos de Formalismos Denotacional ou Funcional Funções construídas a partir de funções elementares de modo que o algoritmo denotado pela função pode ser determinado em termos de suas funções componentes. Exemplo: Funções Recursivas Parciais (Kleene, 1936).
5 Funções Recursivas Funções naturais simples: constante zero; sucessor; projeção; Juntamente com recursão e minimização.
6 Linguagem Lambda É apresentada a notação conhecida como Linguagem Lambda (λ-linguagem, introduzida por Alonzo Church em 1941) no Cálculo Lambda (λ-cálculo), cujo principal objetivo é evitar ambigüidades de notação.
7 Funções e Funcionais Uma função parcial é uma relação f A B onde cada elemento do domínio (conjunto A) está relacionado com, no máximo, um elemento do contra-domínio (conjunto B). f A B é denotada por f: A B; o tipo de f é A B; (a, b) f é denotado por f(a) = b.
8 Exemplo: Funções e seus tipos f(x) = x f: N N g(x, y) = (x 2, y - x) h(f, x) = f( f(x) ) g: N N N N ou g: N 2 N 2 h: ( (N N) N) N
9 Definição: (Funcional) Funcional é uma função que possui uma ou mais funções como argumentos. Portanto, no exemplo anterior, a função h é um funcional.
10 Observação: funções com mais de um argumento podem ser vistas como funcionais com um argumento. funcionais constituem um dispositivo útil na simplificação de notação e facilita a manipulação de expressões.
11 Exemplo: Seja f: N N h(f, x) = f( f(x) ) h (f) (x) = f( f(x) ) h: (N N) N N h : (N N) (N N)
12 Introdução Considere novamente a função f: N N tal que: f(x) = x f(x) é o resultado da aplicação de f ao parâmetro x; f(x) não é uma função, mas uma equação (polinômio).
13 Construções da Linguagem Lambda a) Abstração Lambda. Permite abstrair a definição da função. Por exemplo, a função f acima é denotada pelo seguinte termo Lambda: λx.x função tal que, para um argumento arbitrário x, resulta em x 3 + 4
14 Construções da Linguagem Lambda b) Aplicação Lambda Determina o valor da função aplicada a um dado parâmetro. (λx.x 3 + 4)(2) aplicação da função λx.x ao valor 2
15 Construções da Linguagem Lambda Termos da Linguagem Lambda serão denotados por letras maiúsculas M, N, P, (λx.x 3 + 4)(2) M denota x (λx.m)(p) N denota λx.x P denota 2 (N)(P)
16 Construções da Linguagem Lambda Regra de Redução Beta (Regra de Redução β) (λx.m)(p) = [P/x]M substituição de x por P em M: (λx.x 3 + 4)(2) = [2/x] x = = 12
17 Construções da Linguagem Lambda Linguagem Lambda é constituída de termos lambda. Definição: (Termo Lambda) Sejam X e C conjuntos contáveis de variáveis e de constantes Então um Termo Lambda, Expressão Lambda ou Palavra Lambda sobre X e C é indutivamente definido por:
18 Construções da Linguagem Lambda a) Toda variável x X é um termo lambda; b) Toda constante c C é um termo lambda; c) Se M e N são termos lambda, e x é uma variável, então: 1) (M N) é um termo lambda; 2) (λx.m) é um termo lambda.
19 Simplificações de notação adotadas: a) Parênteses podem ser eliminados, respeitando a associatividade à esquerda. Sejam M, N e P termos. M N P é uma simplificação de ((M N) P); b) Parênteses podem ser eliminados, respeitando o escopo de uma variável em uma abstração. Sejam M, N e P termos, e x a variável. λx.m N P é uma simplificação de (λx.(m N P));
20 Simplificações de notação adotadas: c) Os seguintes termos lambda denotam a função adição equivalentemente: λ(x, y).x + y e λ(r, s).r + s
21 Definição: (Linguagem Lambda) Sejam X e C conjuntos contáveis de variáveis e de constantes, respectivamente. Uma Linguagem Lambda L sobre X e C é o conjunto de todos os termos lambda sobre esses conjuntos.
22 Observação: A Linguagem Lambda inspirou a linguagem de programação LISP. LISP é uma linguagem sem tipos, onde programas e dados não são distinguíveis.
23 Observação: Até hoje são discutidas as vantagens e desvantagens das linguagens tipadas e das linguagens não-tipadas, ou seja se: Tipos devem constituir um esquema básico do conhecimento; Entidades devem ser organizadas em subconjuntos com propriedades uniformes a partir de um universo não-tipado.
24 Observação: Após a introdução da linguagem Algol, onde variáveis são associadas a tipos quando de suas declarações, permitindo verificações sintáticas e semânticas de suas instâncias no programa em tempo de compilação, foi verificado que tipos têm sido considerados uma facilidade essencial para o desenvolvimento de programas.
25 Observação: A associação de tipo a um termo lambda é como em uma definição tradicional de função. Exemplo: Tipos das funções parciais, onde as variáveis x e y têm seus valores em N: f(x) =x f = λx.x 3 + 4: N N
26 Definição: (Var. Ligada e Var. Livre) Uma variável em um termo lambda é denominada: a) Variável Ligada, se está dentro do escopo de uma abstração lambda; b) Variável Livre, caso contrário.
27 Exemplo: a)no termo λx.x k, as variáveis x e k são ditas ligada e livre, respectivamente. b) No termo λk.λx.x k, as variáveis x e k são ditas ligadas.
28 Definição: (Substituição de Var. Livre) Sejam x uma variável e M, P termos lambda. A Substituição de uma Variável Livre x por P em M, denotada por: [P/x]M é simplesmente a substituição de todas as ocorrências de x em M pelo termo P.
29 Exemplo: A substituição da variável livre x por 5 em λk.x k é [5/x] λk.x k = λk.5 k
30 Definição: Regra de Redução Beta Sejam x uma variável e, M e P termos lambda. A Regra de Redução Beta de um termo (λx.m)(p) é dada pela substituição de x por P em M, ou seja: [P/x]M Note-se que x é variável ligada em λx.m, mas é livre em M, o que garante a coerência da definição acima.
31 Semântica de um Termo Lambda A semântica de um Termo Lambda dado por uma função aplicada a um parâmetro é dada pelas aplicações sucessivas possíveis da regra de redução beta.
32 Exemplo: A semântica do termo (λk.(λx.xk)(5))(2) é dada pela sucessiva aplicação da regra de redução beta como segue: (λk.(λx.x k )(5))(2) aplicação da rb em k = [2/k](λx.x k )(5) substituição da var. livre k = (λx.x 2 )(5) aplicação da rb em x = [5/x](x 2 ) substituição da var. livre x = 5 2 = 25
33 Funções Recursivas de Kleene As funções recursivas parciais propostas por Kleene são funções construídas sobre funções básicas usando três tipos de construções: Composição; Recursão; Minimização.
34 Definição: Composição de Funções Sejam g, f 1, f 2,, f k funções parciais tais que: g = λ(y 1, y 2,, y k ).g(y 1, y 2,, y k ): N k N f i = λ(x 1, x 2,, x n ).f i (x 1, x 2,, x n ): N n N, para i { 1, 2,, k }
35 Definição: Composição de Funções A função parcial h tal que: h = λ(x 1, x 2,, x n ).h(x 1, x 2,, x n ): N n N é a Composição de Funções definida a partir de g, f 1, f 2,, f k por: h(x 1,x 2,, x n )= g( f 1 (x 1, x 2,, x n ), f 2 (x 1, x 2,, x n ),, f k (x 1,x 2,, x n ) )
36 Definição: Composição de Funções A função parcial h é dita definida para (x 1,x 2, x n ) se, e somente se: f i (x 1, x 2,, x n ) é definida para todo i { 1, 2,, k } g(f 1 (x 1, x 2,, x n ), f 2 (x 1, x 2,, x n ),, f k (x 1, x 2,, x n ) ) é definida.
37 Exemplo: Suponha as seguintes funções: zero() = λx.0: N N (constante zero) suc(x) = λx.x + 1: N N (sucessor) A seguinte função é definidas usando composição de funções: um = λx.suc( zero(x) ): N N (constante um)
38 Definição: Recursão Sejam f e g funções parciais tais que: f = λ(x 1, x 2,, x n ).f(x 1, x 2,, x n ): N n N g = λ( x 1, x 2,, x n, y, z).g(x 1, x 2,, x n, y, z): N n+2 N A função parcial h tal que: h = λ( x 1, x 2,, x n, y).h(x 1, x 2,, x n, y): N n+1 N é definida por Recursão a partir de f e g como segue:
39 Definição: Recursão h(x 1, x 2,, x n, 0) = f(x 1, x 2,, x n ) h(x 1, x 2,, x n, y + 1) = g( x 1, x 2,, x n, y, h(x 1, x 2,, x n, y) ) A função h é dita definida para (x 1, x 2,, x n, y) se, e somente se: f(x 1, x 2,, x n ) é definida; g( x 1, x 2,, x n, i, h(x 1, x 2,, x n, i) ) é definida para todo i { 1, 2,, y }
40 Exemplo: Suponha as seguintes funções: (identidade) id = λx.x: N N (sucessor) suc = λx.x + 1: N N (projeção da 3ª componente da tripla) proj3 3 = λ(x,y,z).z: N 3 N
41 Exemplo: adição A função adição nos naturais tal que: (adição) ad = λ(x,y).x + y: N 2 N é definida usando recursão, como: ad(x,0) = id(x) ad(x,y+1)=proj3 3 (x,y, suc(ad(x,y))
42 Exemplo: Por exemplo, ad(3, 2) é como segue: ad(3, 2) = proj3 3 (3, 1, suc(ad(3,1))) = proj3 3 (3, 1, suc(proj3 3 (3, 0, suc(ad(3, 0))))) = proj3 3 (3, 1, suc(proj3 3 (3,0, suc(id(3))))) = proj3 3 (3, 1, suc(proj3 3 ( 3,0, suc(3)))) = proj3 3 ( 3, 1, suc( proj3 3 ( 3,0,4 ) ) ) = proj3 3 ( 3, 1, suc(4)) = proj3 3 (3, 1, 5) = 5
43 Definição: Minimização Seja f uma função parcial tal que: f = λ(x 1, x 2,, x n, y).f(x 1, x 2,, x n, y ): N n+1 N A função parcial h tal que: h = λ( x 1, x 2,, x n ).h(x 1, x 2,, x n ): N n N
44 Definição: Minimização é dita definida por Minimização de f e é tal que: h = λ(x 1..x n ).min{ y f(x 1,,x n, y)=0 e, ( z) z<y, f(x 1,, x n,z) é definida }
45 Exemplo: Suponha a função constante zero = λx.0: N N. Considere a seguinte função que identifica o número zero nos naturais: const zero : N Note-se que é uma função sem variáveis, ou seja, é uma constante. A constante const zero é definida usando minimização como segue: const zero = min{ y zero(y) = 0 }
46 Exemplo: Sejam a constante zero const zero, e a função de projeção: proj2 1 = λ(x,y).x: N 2 N A seguinte função antecessor nos naturais: ant = λx.ant(x): N N
47 Exemplo: pode ser definida usando recursão (supondo que antecessor de 0 é 0) ant(0) = const zero ant(y+1) = proj2 1 (y,ant(y))
48 Exercício: 1) Calcule ant(3)
49 Exemplo: A seguinte função subtração naturais: sub = λ(x,y).sub(x, y): N 2 N pode ser definida, usando recursão: sub(x, 0) = id(x) sub(x, y + 1) = proj3 3 ( x, y, ant(sub(x, y)) )
50 Exemplo: sub(3, 2) = = proj3 3 (3, 1, ant (sub(3, 1))) =proj3 3 (3, 1,ant (proj3 3 (3,0,ant (sub(3, 0))))) = proj3 3 ( 3, 1, ant (proj3 3 (3, 0, ant (id(3))))) = proj3 3 ( 3, 1, ant (proj3 3 ( 3, 0, ant (3)))) = proj3 3 ( 3, 1, ant (proj3 3 ( 3, 0, 2))) = proj3 3 ( 3, 1, ant (2)) = proj3 3 (3, 1,1) = 1
51 Função Recursiva Parcial e Total Funções recursivas parciais são definidas a partir de três funções básicas: constante zero, sucessor e projeção sobre o conjunto dos números naturais
52 Função Recursiva Parcial e Total Projeção não é uma função, mas uma família de funções, pois depende do número de componentes, bem como de qual a componente que se deseja projetar.
53 Definição: Função Recursiva Parcial Uma Função Recursiva Parcial é indutivamente definida como segue: a) Funções Básicas. As seguintes funções são recursivas parciais: const zero = λx.0: N N (função constante zero) suc = λx.x + 1: N N projn i = λ(x 1,x 2,,x n ).x i : N n N (função sucessor) (projeção: i-ésima componente da n-upla)
54 Definição: Função Recursiva Parcial b) Se f 1,..., f n são Funções Recursivas Parciais então a Composição, a Recursão e a Minimização das funções dadas também são.
55 Exemplo: a) Função Identidade A função identidade, definida como segue: id = λx.x: N N é recursiva parcial, pois é uma função básica de projeção, ou seja: id = proj1 1
56 Exemplo: b) Função Zero A função Zero, definida como segue: zero = λx.0: N N é recursiva parcial, pois é uma função básica de projeção, ou seja: zero(0) = conts zero zero(y+1) = Proj2 2 (y, zero(y))
57 Exemplo: c) Função adição (ad) A função adição, definida como segue: ad = λ(x,y).x + y: N 2 N é recursiva parcial, pois é uma função recursiva parcial, ou seja: ad(x, 0) = id(x) ad(x, y + 1) = proj3 3 ( x, y, suc( ad(x, y) ))
58 Exemplo: d) Função antecessor (ant) A função antecessor, definida como segue: ant = λ(x).x - 1: N N é recursiva parcial, pois é uma função recursiva parcial, ou seja: ant(0) = const zero ant(y+1) = proj2 1 (y,ant(y))
59 Exemplo: e) Função subtração (sub) A função subtração, definida como segue: sub = λ(x,y).x - y: N 2 N é recursiva parcial, pois é uma função recursiva parcial, ou seja: sub(x, 0) = id(x) sub(x, y + 1) = proj3 3 ( x, y, ant(sub(x, y)) )
60 Exemplo: f) Função multiplicação (mul) A função subtração, definida como segue: mul = λ(x,y).x * y: N 2 N é recursiva parcial, pois é uma função recursiva parcial, ou seja: mul(x, 0) = zero(x) mul(x, y + 1) = ad( proj3 1 (x, y, mul(x,y)), proj3 3 (x, y, mul(x,y)))
61 Exemplo: g) Função exponenciação (exp) A função subtração, definida como segue: exp = λ(x,y).x y : N 2 N é recursiva parcial, pois é uma função recursiva parcial, ou seja: exp(x, 0) = suc(zero(x)) exp(x, y + 1) = mul( proj3 1 (x, y, exp(x,y)), proj3 3 (x, y, exp(x,y)))
62 Exercício: a) Mostre que a função fatorial é recursiva parcial.
63 Definição: (Função Recursiva Total) Uma Função Recursiva Total é uma função recursiva parcial definida para todos os elementos do domínio.
64 Teorema: As seguintes classes de funções são equivalentes: a) Funções Recursivas Parciais e Funções Turing-Computáveis; b) Funções Recursivas Totais e Funções Turing-Computáveis Totais.
65 Importante: A relação entre classes também pode ser estabelecida: Funções Recursivas Parciais Linguagens Enumeráveis Recursivamente; Funções Recursivas Totais Funções Turing- Computáveis Totais Linguagens Recursivas.
Centro Universitário do Triângulo
Centro Universitário do Triângulo Cálculo Lambda 1. Introdução A elaboração de modelos de computação (resolução de problemas por uma máquina) baseia-se em trabalhos de dois pesquisadores com enfoques bastante
Teoria da Computação
Ciência da Computação Teoria da Computação (ENG10395) Profa. Juliana Pinheiro Campos E-mail: [email protected] Funções recursivas Os formalismos usados para especificar algoritmos podem ser classificados
Linguagens Formais e Autômatos P. Blauth Menezes
Linguagens Formais e Autômatos P. Blauth Menezes [email protected] Departamento de Informática Teórica Instituto de Informática / UFRGS Matemática Discreta para Ciência da Computação - P. Blauth Menezes
Cálculo Lambda Sem Tipos
Cálculo Lambda Sem Tipos Cálculo lambda sem tipos Peter Landin (60 s) observou que uma linguagem de programação pode ser compreendida formulando-a em um pequeno núcleo capturando suas características essenciais
Programação Funcional - Introdução a Cálculo Lambda
Programação Funcional - Introdução a Cálculo Lambda Cristiano Damiani Vasconcellos Universidade do Estado de Santa Catarina 1. Definição Cálculo lambda (λ-cálculo) é um modelo matemático capaz de ilustrar
Juliana Kaizer Vizzotto. Universidade Federal de Santa Maria. Disciplina de Teoria da Computação
Universidade Federal de Santa Maria Disciplina de Teoria da Computação Quais são as capacidades e limitações fundamentais dos computadores? Funções Computáveis Algoritmo: descrição finitade uma computação
Resolução Exe 2.12 Monolítico Recursivo
Resolução Exe 2.12 Monolítico Recursivo Recursivo P R é R 1 onde R 1 def (se T1 então R 2 senão R 3 ) R 2 def F; R 3 R 3 def (se T2 então R 4 senão R 7 ) R 4 def G; R 5 R 5 def (se T1 então R 7 senão R
Matemática Discreta para Ciência da Computação
Matemática Discreta para Ciência da Computação P. Blauth Menezes [email protected] Departamento de Informática Teórica Instituto de Informática / UFRGS Matemática Discreta para Ciência da Computação
Aulas Práticas. 1ª Aula Prática Perguntas sobre a Implementação de Funções Simples na Máquina URM...1
Aulas Práticas 1ª Aula Prática Perguntas sobre a Implementação de Funções Simples na Máquina URM...1 2ª Aula Prática Perguntas sobre a Implementação de Funções Recursivas na Máquina URM...2 3ª Aula Prática
1 INTRODUÇÃO E CONCEITOS BÁSICOS
1 INTRODUÇÃO E CONCEITOS BÁSICOS Inicia com uma breve história do surgimento e do desenvolvimento dos conceitos, resultados e formalismos nos quais a Teoria da Computação é baseada. Formalização dos conceitos
COMPUTABILIDADE 3. Funções Parciais Recursivas
José Carlos Costa DMA-UMinho 2 de Dezembro de 2011 1/17 Licenciatura em Ciências da Computação COMPUTABILIDADE 3. Funções Parciais Recursivas José Carlos Costa Dep. Matemática e Aplicações Universidade
Lambda Cálculo e Programação Funcional. Programação Funcional Bacharelado em Sistemas de Informação Maio
Lambda Cálculo e Programação Funcional Programação Funcional Bacharelado em Sistemas de Informação Maio - 2009 Alonzo Church (1903 1995) Professor em Princeton, EUA (1929 1967) e UCLA (1967 1990) Inventou
SEMÂNTICA. Rogério Rocha. rode = program simples = var x : int := 3 in x := x + 5 end.
SEMÂNTICA program simples = var x : int := 3 in x := x + 5 end. rode =? Rogério Rocha Roteiro Introdução Sintaxe Semântica Dinâmica (Métodos formais) Operacional Axiomática Denotacional Estática Conclusão
I.2 Introdução a Teoria da Computação
I.2 Introdução a Teoria da Computação O que é? Fundamento da Ciência da Computação Tratamento Matemático da Ciência da Computação Estudo Matemático da Transformação da Informação Qual sua importância?
UNIVERSIDADE FEDERAL RURAL DO SEMI-ÁRIDO CURSO: CIÊNCIA DA COMPUTAÇÃO. Prof.ª Danielle Casillo
UNIVERSIDADE FEDERAL RURAL DO SEMI-ÁRIDO CURSO: CIÊNCIA DA COMPUTAÇÃO TEORIA DA COMPUTAÇÃO Aula 04 Programa Recursivo e Máquinas Prof.ª Danielle Casillo Funções recursivas Alguma função é recursiva quando
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...
sumário 1 introdução e conceitos básicos 1 1.1 introdução à matemática discreta... 2 1.2 conceitos básicos de teoria dos conjuntos... 3 1.2.1 conjuntos...3 1.2.2 pertinência...5 1.2.3 alguns conjuntos
Introdução à Programação Funcional
Introdução à Programação Funcional PPGIA - PUCPR Prof. Fabrício Enembreck 1 Conteúdo Introdução ao Cálculo Lambda e à Programação Funcional Introdução ao LISP e ao CLisp Funções Lambda e binding Funções
INE5416 Paradigmas de Programação. Ricardo Azambuja Silveira INE CTC UFSC E Mail: URL:
INE5416 Paradigmas de Programação Ricardo Azambuja Silveira INE CTC UFSC E Mail: [email protected] URL: www.inf.ufsc.br/~silveira Conceitos Léxica estudo dos símbolos que compõem uma linguagem Sintaxe
Linguagens Formais e Autômatos P. Blauth Menezes
Linguagens Formais e Autômatos P. Blauth Menezes [email protected] Departamento de Informática Teórica Instituto de Informática / UFRGS Matemática Discreta para Ciência da Computação - P. Blauth Menezes
Sintaxe e Semântica. George Darmiton da Cunha Cavalcanti.
Sintaxe e Semântica George Darmiton da Cunha Cavalcanti ([email protected]) Tópicos Introdução O problema de descrever a sintaxe Métodos formais para descrever a sintaxe Gramáticas de atributos Descrevendo
Universidade da Madeira Ano lectivo 2006/07-2º semestre Responsável: Prof. José Carmo
TEORIA DA COMPUTABILIDADE E COMPLEXIDADE Licenciatura em Engenharia Informática (2ª ano) Licenciatura em Ensino da Informática (2ª ano) Licenciatura em Matemática (2ª ano) Universidade da Madeira Ano lectivo
INE5317 Linguagens Formais e Compiladores AULA 3: Introdução a Teoria da Computação
INE5317 Linguagens Formais e Compiladores AULA 3: Introdução a Teoria da Computação bas eado em material produzido pelo prof Olinto Jos é Varela Furtado Ricardo Azambuja Silveira INE-CTC-UFSC E-Mail: [email protected]
Máquinas Universais. Máquina de Turing. Celso Olivete Júnior.
Máquinas Universais Máquina de Celso Olivete Júnior [email protected] http://www2.fct.unesp.br/docentes/dmec/olivete/ Roteiro Hipótese de Church - Máquinas Universais: Máquina de Máquina de : Noção
Matemática Discreta para Ciência da Computação
Matemática Discreta para Ciência da Computação P. Blauth Menezes [email protected] Departamento de Informática Teórica Instituto de Informática / UFRGS Matemática Discreta para Ciência da Computação
UNIVERSIDADE FEDERAL RURAL DO SEMI-ÁRIDO CURSO: CIÊNCIA DA COMPUTAÇÃO. Prof.ª Danielle Casillo
UNIVERSIDADE FEDERAL RURAL DO SEMI-ÁRIDO CURSO: CIÊNCIA DA COMPUTAÇÃO Prof.ª Danielle Casillo Diferentes computadores podem ter diferentes arquiteturas e os diversos tipos de linguagem de programação.
Aula prática 5. Funções Recursivas
Programação Funcional UFOP DECOM 2014.1 Aula prática 5 Funções Recursivas Resumo Definições recursivas são comuns na programação funcional. Nesta aula vamos aprender a definir funções recursivas. Sumário
Procedimentos e Algorítmos Programas e Linguagens de Programação Tese de Church-Turing Formas de Representação de Linguagens
Procedimentos e Algorítmos Programas e Linguagens de Programação Tese de Church-Turing Formas de Representação de Linguagens 1 Introdução Estudar computação do ponto de vista teórico é sinônimo de caracterizar
Linguagens de Programação Programação Funcional (Haskell)
Linguagens de Programação Programação Funcional (Haskell) Andrei Rimsa Álvares Sumário Introdução Programação funcional Linguagens funcionais Haskell Casamento de padrões Funções de ordem superior Avaliação
CAP. VI ANÁLISE SEMÂNTICA
CAP. VI ANÁLISE SEMÂNTICA VI.1 Introdução Semântica SIGNIFICADO, SENTIDO LÓGICO, COERÊNCIA,... Diferença entre SINTAXE e SEMÂNTICA Sintaxe : descreve as estruturas de uma linguagem; Semântica : descreve
TRANSFORMAÇÃO DE GRAMÁTICAS LIVRES DO CONTEXTO PARA EXPRESSÕES REGULARES ESTENDIDAS
TRANSFORMAÇÃO DE GRAMÁTICAS LIVRES DO CONTEXTO PARA EXPRESSÕES REGULARES ESTENDIDAS Acadêmico: Cleison Vander Ambrosi Orientador: José Roque Voltolini da Silva Roteiro da Apresentação Introdução Motivação
Compiladores. Análise Semântica
Compiladores Análise Semântica Cristiano Lehrer, M.Sc. Atividades do Compilador Arquivo de origem Análise léxica Análise semântica Síntese Análise sintática Análise Gramáticas Estruturas internas Arquivo
USANDO UM MÉTODO INDUTIVO PARA RESOLVER PROBLEMAS. Bruno Maffeo Departamento de Informática PUC-Rio
USANDO UM MÉTODO INDUTIVO PARA RESOLVER PROBLEMAS Bruno Maffeo Departamento de Informática PUC-Rio MÉTODO INDUTIVO O método indutivo para resolver problemas aqui empregado inspira-se na formulação mais
Apostila 01 Fundamentação da Teoria da Computação e Linguagens Formais
Cursos: Bacharelado em Ciência da Computação e Bacharelado em Sistemas de Informação Disciplinas: (1493A) Teoria da Computação e Linguagens Formais, (4623A) Teoria da Computação e Linguagens Formais e
IBM1088 Linguagens Formais e Teoria da Computação
IBM1088 Linguagens Formais e Teoria da Computação Apresentação da disciplina Evandro Eduardo Seron Ruiz [email protected] Universidade de São Paulo E.E.S. Ruiz (USP) LFA 1 / 16 IBM1088 Objetivos Fornecer
Linguagens Formais e Autômatos P. Blauth Menezes
Linguagens Formais e Autômatos P. Blauth Menezes [email protected] Departamento de Informática Teórica Instituto de Informática / UFRGS Linguagens Formais e Autômatos - P. Blauth Menezes 1 Linguagens
O que é Linguagem Regular. Um teorema sobre linguagens regulares. Uma aplicação do Lema do Bombeamento. Exemplo de uso do lema do bombeamento
O que é Linguagem Regular Um teorema sobre linguagens regulares Linguagem regular Uma linguagem é dita ser uma linguagem regular se existe um autômato finito que a reconhece. Dada uma linguagem L: É possível
UNIVERSIDADE FEDERAL RURAL DO SEMI-ÁRIDO CURSO: CIÊNCIA DA COMPUTAÇÃO. Prof.ª Danielle Casillo
UNIVERSIDADE FEDERAL RURAL DO SEMI-ÁRIDO CURSO: CIÊNCIA DA COMPUTAÇÃO TEORIA DA COMPUTAÇÃO Aula 08 Equivalência de programas Parte 2 Prof.ª Danielle Casillo Poder computacional dos diversos tipos de programas
Linguagens de Programação Funcional
Linguagens de Programação Funcional Conceitos de Linguagens de Programação Pedro Libório Setembro de 2013 2 Roteiro Introdução Funções matemáticas Fundamentos das linguagens de programação funcionais A
Máquina de Turing Linguagens Sensíveis ao Contexto e Enumeráveis Recursivamente
ESIN/UCPel 058814 Linguagens Formais e Autômatos TEXTO 5 Máquina de Turing Linguagens Sensíveis ao Contexto e Enumeráveis Recursivamente Prof. Luiz A M Palazzo Maio de 2007 0. Introdução A Ciência da Computação
Introdução à Programação
Introdução à Programação Linguagens de Programação: sintaxe e semântica de linguagens de programação e conceitos de linguagens interpretadas e compiladas Engenharia da Computação Professor: Críston Pereira
SEMÂNTICA 02/09/2013. Conceitos de LPs - Semântica
UNIVERSIDADE ESTADUAL DE SANTA CRUZ CURSO: CIÊNCIA DA COMPUTAÇÃO DISCIPLINA: CONCEITOS DE LINGUAGENS DE PROGRAMAÇÃO DOCENTE: ROGÉRIO VARGAS DISCENTE: MARIANNA NOVAES Semântica SEMÂNTICA Semântica é a área
Teoria da Computação. Unidade 1 Conceitos Básicos. Referência Teoria da Computação (Divério, 2000)
Unidade 1 Conceitos Básicos Referência (Divério, 2000) Conceitos Básicos Linguagem Conceito fundamental Forma precisa de expressar problemas Permite um desenvolvimento formal adequado ao estudo da computabilidade
UNIVERSIDADE FEDERAL RURAL DO SEMI-ÁRIDO CURSO: CIÊNCIA DA COMPUTAÇÃO. Prof.ª Danielle Casillo
UNIVERSIDADE FEDERAL RURAL DO SEMI-ÁRIDO CURSO: CIÊNCIA DA COMPUTAÇÃO Prof.ª Danielle Casillo NORMA (NumberTheOreticRegisterMAchine) Possui como memória um conjunto infinito de registradores naturais e
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?
capítulo 1 introdução A ciência da computação é o conhecimento sistematizado da computação. Sua origem é milenar, tendo se desenvolvido em diferentes regiões e épocas. A teoria da computação é a base fundamental
INE5622 INTRODUÇÃO A COMPILADORES
INE5622 INTRODUÇÃO A COMPILADORES PLANO DE ENSINO Objetivo geral Conhecer o processo de especificação e implementação de linguagens de programação, a partir do estudo dos conceitos, modelos, técnicas e
ao paradigma imperativo
PARADIGMA FUNCIONAL PARADIGMA FUNCIONAL: INTRODUÇÃO G Exemplos de linguagens funcionais LISP - Início: LP puramente funcional - Depois: acréscimo de alguns recursos imperativos (aumentaram eficiência de
Cálculo Numérico. que é denominado erro relativo. Temos então para os dados acima:
Cálculo Numérico 1 Erros Nenhum resultado obtido através de cálculos eletrônicos ou métodos numéricos tem valor se não tivermos conhecimento e controle sobre os possíveis erros envolvidos no processo.
Programação em Lógica. UCPEL/CPOLI/BCC Lógica para Ciência da Computação Luiz A M Palazzo Maio de 2010
Programação em Lógica UCPEL/CPOLI/BCC Lógica para Ciência da Computação Luiz A M Palazzo Maio de 2010 Roteiro Introdução Conceitos Básicos Linguagens Lógicas Semântica de Modelos Semântica de Prova Programação
6. OPERADORES E ARITMÉTICA
6. OPERADORES E ARITMÉTICA 6.1 OPERADORES Na matemática costuma-se escrever expressões como 2*a + b*c onde + e * são operadores e 2, a, b e c são argumentos. Em particular, + e * são denominados operadores
Teoria da Computação
Ciência da Computação Teoria da Computação (ENG10395) Profa. Juliana Pinheiro Campos E-mail: [email protected] Máquinas Universais Máquinas Universais podem ser entendidas de duas formas: Se é capaz
Recursão PROGRAMAÇÃO EM LÓGICA. Recursão. Sonho Recursivo. Recursão. Recursão. Linguagem Prolog Parte IV
PROGRAMAÇÃO EM LÓGICA Recursão CIÊNCIA DA COMPUTAÇÃO FACAPE Faculdade de Ciências Aplicadas e Sociais de Petrolina Linguagem Prolog Parte IV Usado desde a arte (em figuras, telas, etc) como também em Matemática
2 Espaços Vetoriais. 2.1 Espaços Vetoriais Euclidianos
2 Espaços Vetoriais 2.1 Espaços Vetoriais Euclidianos Definição: Dado n N, considere-se o conjunto de todos os n-uplos ordenados de elementos reais, isto é o conjunto de elementos da forma x = (x 1,, x
Linguagens de Programação
Linguagens de Programação Prof a Jerusa Marchi Departamento de Informática e Estatística Universidade Federal de Santa Catarina e-mail: [email protected] Linguagens de Programação p. 1/5 Linguagens de
Primeira Prova de Linguagens de Programação - DCC024 -
Primeira Prova de Linguagens de Programação - DCC024 - Ciência da Computação Nome: Eu dou minha palavra de honra que não trapacearei neste exame. Número de matrícula: As regras do jogo: A prova é sem consulta.
Um alfabeto é um conjunto de símbolos indivisíveis de qualquer natureza. Um alfabeto é geralmente denotado pela letra grega Σ.
Linguagens O conceito de linguagem engloba uma variedade de categorias distintas de linguagens: linguagens naturais, linguagens de programação, linguagens matemáticas, etc. Uma definição geral de linguagem
Exercícios de Teoria da Computação Computabilidade
Licenciatura em Engenharia Informática e de Computadores - LEIC Licenciatura em Engenharia de Redes de Comunicação e Informação -LERCI Exercícios de Teoria da Computação Computabilidade Paula Gouveia Secção
Compiladores - Gramáticas
Compiladores - Gramáticas Fabio Mascarenhas - 2013.1 http://www.dcc.ufrj.br/~fabiom/comp Análise Sintática A análise sintática agrupa os tokens em uma árvore sintática de acordo com a estrutura do programa
Apostila 06. Objetivos: Estudar a Computabilidade Estudar a Decidibilidade Estudar a Redutibilidade
Cursos: Bacharelado em Ciência da Computação e Bacharelado em Sistemas de Informação Disciplinas: (1493A) Teoria da Computação e Linguagens Formais, (4623A) Teoria da Computação e Linguagens Formais e
UNIVERSIDADE FEDERAL RURAL DO SEMI-ÁRIDO CURSO: CIÊNCIA DA COMPUTAÇÃO. Prof.ª Danielle Casillo
UNIVERSIDADE FEDERAL RURAL DO SEMI-ÁRIDO CURSO: CIÊNCIA DA COMPUTAÇÃO TEORIA DA COMPUTAÇÃO Aula 03 Programas (Monolítico e Iterativo) Prof.ª Danielle Casillo Programas, Máquinas e Computações Diferentes
Principais paradigmas de programação. Programação imperativa Programação funcional Programação lógica Programação OO
Principais paradigmas de programação Programação imperativa Programação funcional Programação lógica Programação OO Programação Imperativa É o paradigma mais usado. Programas são definidos através de sequências
Aula 1. e o conjunto dos inteiros é :
Aula 1 1. Números reais O conjunto dos números reais, R, pode ser visto como o conjunto dos pontos da linha real, que serão em geral denotados por letras minúsculas: x, y, s, t, u, etc. R é munido de quatro
1 Operações com conjuntos
Notas sobre Conjuntos (2) Anjolina Grisi de Oliveira 1 Operações com conjuntos Definição 1 (União) Sejam A e B dois conjuntos arbitrários. A união dos conjuntos A e B, denotada por A B, é o conjunto que
Modelos de Computação
Modelos de Computação 2.ano LCC e LERSI URL: http://www.ncc.up.pt/~nam/aulas/0405/mc Escolaridade: 3.5T e 1P Frequência:Semanalmente serão propostos trabalhos aos alunos, que serão entregues nas caixas
Fundamentos de Cálculo Lambda
Instituto Superior Técnico Universidade Técnica de Lisboa Lisboa, 2 de Novembro de 2006 Índice Introdução Aplicação e Abstracção Axiomática Aplicação Introdução Aplicação e Abstracção Axiomática FA F é
Linguagens Formais e Autômatos. Conceitos Básicos Prof. Anderson Belgamo
Linguagens Formais e Autômatos Conceitos Básicos Prof. Anderson Belgamo Introdução Teoria das Linguagens Formais Originariamente desenvolvida na década de 1950. Objetivo inicial: desenvolver teorias relacionadas
Sintaxe e Semântica. George Darmiton da Cunha Cavalcanti.
Sintaxe e Semântica George Darmiton da Cunha Cavalcanti ([email protected]) Tópicos Introdução O problema de descrever a sintaxe Métodos formais para descrever a sintaxe Gramáticas de atributos Descrevendo
Curso: Ciência da Computação Turma: 6ª Série. Teoria da Computação. Aula 6. Programas, Máquinas e Computações
Curso: Ciência da Computação Turma: 6ª Série Aula 6 Programas, Máquinas e Computações Avisos Hoje tem dúvidas sobre a segunda etapa da ATPS. Somente 28 alunos/alunas entregaram a ATPS etapa 1. Ainda dá
Paradigmas de Linguagens de Programação. Descrevendo a Sintaxe e a Semântica
Descrevendo a Sintaxe e a Semântica Cristiano Lehrer Introdução Descrição, compreensível, de uma linguagem de programação é difícil e essencial. Capacidade de determinar como as expressões, instruções
Introdução Maquinas de Turing universais O problema da parada. Indecidibilidade. Rodrigo Gabriel Ferreira Soares DEINFO - UFRPE.
DEINFO - UFRPE Julho, 2014 Motivação Introdução O que pode ser computado? E mais intrigantemente, o que não pode ser computado? Motivação Introdução O que pode ser computado? E mais intrigantemente, o
Cálculo Numérico. que é denominado erro relativo. Temos então para os dados acima:
Cálculo Numérico 1 Erros Nenhum resultado obtido através de cálculos eletrônicos ou métodos numéricos tem valor se não tivermos conhecimento e controle sobre os possíveis erros envolvidos no processo.
Marcos Castilho. DInf/UFPR. 16 de maio de 2019
16 de maio de 2019 Motivação Quais são os limites da computação? O que é um Problema de decisão? Um problema de decisão é um conjunto de perguntas, cada uma das quais tem um SIM ou um NÃO como resposta.
Gramáticas Livres de Contexto
Gramáticas Livres de Contexto IBM1088 Linguagens Formais e Teoria da Computação Evandro Eduardo Seron Ruiz [email protected] Universidade de São Paulo E.E.S. Ruiz (USP) LFA 1 / 42 Frase do dia Quando vires
Capítulo 2: Procedimentos e algoritmos
Capítulo 2: Procedimentos e algoritmos Para estudar o processo de computação de um ponto de vista teórico, com a finalidade de caracterizar o que é ou não é computável, é necessário introduzir um modelo
Derivadas Parciais Capítulo 14
Derivadas Parciais Capítulo 14 DERIVADAS PARCIAIS 14.2 Limites e Continuidade Nesta seção, aprenderemos sobre: Limites e continuidade de vários tipos de funções. LIMITES E CONTINUIDADE Vamos comparar o
Análise semântica. Função, interação com o compilador Tabela de símbolos Análise semântica. Prof. Thiago A. S. Pardo
Análise semântica Função, interação com o compilador Tabela de símbolos Análise semântica Prof. Thiago A. S. Pardo [email protected] 1 Estrutura geral de um compilador programa-fonte analisador léxico
Linguagens Formais e Autômatos Apresentação da Disciplina
Linguagens Formais e Autômatos Apresentação da Disciplina Andrei Rimsa Álvares Computação Histórico da Computação O que pode ser computado? Ábaco China Aprox. 3500 a.c. Máquina de Babbage Inglaterra 1823
Expressões Regulares. Linguagens Formais e Autômatos. Andrei Rimsa Álvares
Linguagens Formais e Autômatos Expressões Regulares Andrei Rimsa Álvares Material extraído do livro e slides do Prof. Newton Vieira (hcp://dcc.ufmg.br/~nvieira) Expressões Regulares Até agora foram vistas
