Lógica de primeira ordem

sistema lógico que estende a lógica proposicional

A lógica de primeira ordem (LPO), conhecida também como cálculo de predicados de primeira ordem (CPPO),[1] é um sistema lógico que estende a lógica proposicional[2] (lógica sentencial) e que é estendida pela lógica de segunda ordem.

As sentenças atômicas da lógica de primeira ordem têm o formato P (t1,…, tn) (um predicado com um ou mais "argumentos") ao invés de serem símbolos sentenciais sem estruturas.

O ingrediente novo da lógica de primeira ordem não encontrado na lógica proposicional é a quantificação: dada uma sentença φ qualquer, as novas construções e -- leia "para todo x, φ" e "para algum x, φ", respectivamente—são introduzidas. significa que φ é verdadeiro para todo valor de x e significa que há pelo menos um x tal que φ é verdadeiro. Os valores das variáveis são tirados de um universo de discurso pré-determinado. Um refinamento da lógica de primeira ordem permite variáveis de diferentes tipos, para tratar de diferentes classes de objetos.

A lógica de primeira ordem tem poder expressivo suficiente para formalizar praticamente toda a matemática. Uma teoria de primeira ordem consiste em um conjunto de axiomas (geralmente finito ou recursivamente enumerável) e de sentenças dedutíveis a partir deles. A teoria dos conjuntos de Zermelo-Fraenkel é um exemplo de uma teoria de primeira ordem, e aceita-se geralmente que toda a matemática clássica possa ser formalizada nela. Há outras teorias que são normalmente formalizadas na lógica de primeira ordem de maneira independente(embora elas admitam a implementação na teoria dos conjuntos) tais como a aritmética de Peano.

Definindo a lógica de primeira ordem editar

Um cálculo de predicados consiste em:

Os axiomas considerados aqui são os axiomas lógicos que fazem parte do cálculo de predicados. Além disso, os axiomas não-lógicos são adicionados em teorias de primeira ordem específicas: estes não são considerados como verdades da lógica, mas como verdades da teoria particular sob consideração.

Quando o conjunto dos axiomas é infinito, requer-se que haja um algoritmo que possa decidir para uma fórmula bem-formada dada, se ela é um axioma ou não. Deve também haver um algoritmo que possa decidir se uma aplicação dada de uma regra de inferência está correta ou não.

É importante notar que o cálculo de predicados pode ser formalizado de muitas maneiras equivalentes; não há nada canônico sobre os axiomas e as regras de inferência propostos aqui, mas toda a formalização dará origem aos mesmos teoremas da lógica (e deduzirá os mesmos teoremas a partir de um conjunto qualquer de axiomas não-lógicos).

Alfabeto editar

O alfabeto de primeira ordem,  , tem a seguinte constituição:

 , onde

  1.   é um conjunto enumerável de variáveis;
  2.   é um conjunto de símbolos chamados de constantes;
  3.   é um conjunto de símbolos ditos sinais funcionais;
  4.   é um conjunto de símbolos ditos sinais relacionais ou predicativos;
  5.   é o conjunto de símbolos ditos sinais lógicos;
  6.   é o conjunto de símbolos de pontuação.

As constantes, sinais funcionais e sinais predicativos constituem a coleção de sinais ditos símbolos não lógicos.

Há diversas variações menores listadas abaixo:

  • O conjunto de símbolos primitivos (operadores e quantificadores) varia frequentemente. Alguns símbolos primitivos podem ser omitidos, substituindo-os com abreviaturas adequadas; por exemplo (P ↔ Q) é uma abreviatura para (PQ) ∧ (QP). No sentido contrário, é possível incluir outros operadores como símbolos primitivos, como as constantes de verdade ⊤ para "verdadeiro" e o ⊥ para "falso" (estes são operadores do aridade 0). O número mínimo dos símbolos primitivos necessários é um, mas se nós nos restringirmos aos operadores listados acima, seria necessário três; por exemplo, o ¬, o ∧, e o ∀ bastariam.
  • Alguns livros mais antigos usam a notação φ ⊃ ψ para φ → ψ, ~φ para ¬φ, φ & ψ para φ ∧ ψ, e uma variedade de notações para os quantificadores; por exemplo, ∀xφ pode ser escrito como (x)φ.
  • A igualdade é às vezes considerada como parte da lógica de primeira ordem; Neste caso, o símbolo da igualdade será incluído no alfabeto, e comportar-se-á sintaticamente como um predicado binário. Assim a LPO será chamada de lógica de primeira ordem com igualdade.
  • As constantes são na verdade funções de aridade 0, assim seria possível e conveniente omitir constantes e usar as funções que tenham qualquer aridade. Mas é comum usar o termo "função" somente para funções de aridade 1.
  • Na definição acima, as relações devem ter pelo menos aridade 1. É possível permitir relações de aridade 0; estas seriam consideradas variáveis proposicionais.
  • Há muitas convenções diferentes sobre onde pôr parênteses; por exemplo, se pode escrever ∀x ou (∀x). Às vezes se usa dois pontos ou ponto final ao invés dos parênteses para criar fórmulas não ambíguas. Uma convenção interessante, mas incomum, é a "notação polonesa", onde se omite todos os parênteses, e escreve-se o ∧, ∨, e assim por diante na frente de seus argumentos. A notação polonesa é compacta e elegante, mas rara e de leitura complexa.
  • Uma observação técnica é que se houver um símbolo de função de aridade 2 que representa um par ordenado (ou símbolos de predicados de aridade 2 que representam as relações de projeção de um par ordenado) então se pode dispensar inteiramente as funções ou predicados de aridade > 2. Naturalmente o par ou as projeções necessitam satisfazer aos axiomas naturais.

Os conjuntos das constantes, das funções, e das relações compõem a assinatura e são geralmente considerados para dar forma a uma linguagem, enquanto as variáveis, os operadores lógicos, e os quantificadores são geralmente considerados para pertencer à lógica. Uma estrutura dá o significado semântico de cada símbolo da assinatura. Por exemplo, a linguagem da teoria dos grupos consiste de uma constante (elemento da identidade), de uma função de aridade 1 (inverso), de uma função de aridade 2 (produto), e de uma relação de aridade 2 (igualdade), que seria omitida pelos autores que incluem a igualdade na lógica subjacente.

Regras de formação editar

As regras de formação definem os termos, fórmulas, e as variáveis livres como segue. O conjunto dos termos é definido recursivamente pelas seguintes regras:

  1. Qualquer constante é um termo (sem variáveis livres).
  2. Qualquer variável é um termo (cuja única variável livre é ela mesma).
  3. Toda expressão f (t1,…, tn) de n ≥ 1 argumentos (onde cada argumento ti é um termo e f é um símbolo de função de aridade n) é um termo. Suas variáveis livres são as variáveis livres de cada um dos termos ti.
  4. Cláusula de fechamento: Nada mais é um termo.

O conjunto das fórmulas bem-formadas (chamadas geralmente FBFs ou apenas fórmulas) é definido recursivamente pelas seguintes regras:

  1. Predicados simples e complexos: se P for uma relação de aridade n ≥ 1 e os ai são os termos então P (a1,…,an) é bem formada. Suas variáveis livres são as variáveis livres de quaisquer termos ai. Se a igualdade for considerada parte da lógica, então (a1 = a2) é bem formada. Tais fórmulas são ditas atômicas.
  2. Cláusula indutiva I: Se φ for uma FBF, então ¬φ é uma FBF. Suas variáveis livres são as variáveis livres de φ.
  3. Cláusula indutiva II: Se φ e ψ são FBFs, então (ψ ∧ φ), (ψ φ), (ψ → φ), (ψ ↔ φ) são FBFs. Suas variáveis livres são as variáveis livres de φ e de ψ.
  4. Cláusula indutiva III: Se φ for uma FBF e x for um variável, então ∀xφ e ∃xφ são FBFs, cujas variáveis livres são as variáveis livres de φ com exceção de x. Ocorrências de x são ditas ligadas ou mudas (por oposição a livre) em ∀xφ e ∃xφ.
  5. Cláusula de fechamento: Nada mais é uma FBF.

Na prática, se P for uma relação de aridade 2, nós escrevemos frequentemente "a P b" em vez de "P a b"; por exemplo, nós escrevemos 1 < 2 em vez de < (1 2). Similarmente se f for uma função de aridade 2, nós escrevemos às vezes "a f b" em vez de "f (a b)"; por exemplo, nós escrevemos 1 + 2 em vez de + (1 2). É também comum omitir alguns parênteses se isto não conduzir à ambigüidade. Às vezes é útil dizer que "P (x) vale para exatamente um x", o que costuma ser denotado por ∃!xP(x). Isto também pode ser expresso por ∃x (P (x) ∀y (P (y) → (x = y))).

Exemplos: A linguagem dos grupos abelianos ordenados tem uma constante 0, uma função unária −, uma função binária +, e uma relação binária ≤. Assim:

  • 0, x, y são termos atômicos
  • + (x, y), + (x, + (y, − (z))) são termos, escritos geralmente como x + y, x + (y + (−z))
  • = (+ (x, y), 0), ≤ (+ (x, + (y, − (z))), + (x, y)) são fórmulas atômicas, escritas geralmente como x + y = 0, x + y - zx + y,
  • (∀xy ≤ (+ (x, y), z)) ∧ (∃x = (+ (x, y), 0)) é uma fórmula, escrita geralmente como (∀xy (x + yz)) ∧ (∃x (x + y = 0)).

Substituição editar

Se t é um termo e φ(x) é uma fórmula que contém possivelmente x como uma variável livre, então φ(t) se definido como o resultado da substituição de todas as instâncias livres de x por t, desde que nenhuma variável livre de t se torne ligada neste processo. Se alguma variável livre de t se tornar ligada, então para substituir t por x é primeiramente necessário mudar os nomes das variáveis ligadas de φ para algo diferente das variáveis livres de t. Para ver porque esta condição é necessária, considere a fórmula φ(x) dada por ∀y yx ("x é máximal"). Se t for um termo sem y como variável livre, então φ(t) diz apenas que t é maximal. Entretanto se t é y, a fórmula φ(y) é ∀y yy que não diz que y é máximal.O problema de que a variável livre y de t (=y) se transformou em ligada quando nós substituímos y por x em φ(x). Assim, para construir φ(y) nós devemos primeiramente mudar a variável ligada y de φ para qualquer outra coisa, por exemplo a variável z, de modo que o φ(y) seja então ∀z zy. Esquecer desta condição é uma causa notória de erros.

Igualdade editar

Há diversas convenções diferentes para se usar a igualdade (ou a identidade) na lógica de primeira ordem. Esta seção resume as principais. Todas as convenções resultam mais ou menos no mesmo com mais ou menos a mesma quantidade de trabalho, e diferem principalmente na terminologia.

  • A convenção mais comum para a igualdade é incluir o símbolo da igualdade como um símbolo lógico primitivo, e adicionar os axiomas da igualdade aos axiomas da lógica de primeira ordem. Os axiomas de igualdade são
x = x
x = y (…,x,…) =  (…,y,…) para qualquer função  
x = y → ( (…,x,…) →  (…,y,…)) para qualquer relação   (incluindo a própria igualdade)
  • A próxima convenção mais comum é incluir o símbolo da igualdade como uma das relações de uma teoria, e adicionar os axiomas da igualdade aos axiomas da teoria. Na prática isto é quase idêntico à da convenção precedente, exceto no exemplo incomum de teorias com nenhuma noção de igualdade. Os axiomas são os mesmos, e a única diferença é se eles serão chamados de axiomas lógicos ou de axiomas de teoria.
  • Nas teorias sem funções e com um número finito de relações, é possível definir a igualdade em termos de relações, definindo os dois termos s e t como iguais se qualquer relação continuar inalterada ao se substituir s por t em qualquer argumento. Por exemplo, em teoria dos conjuntos com uma relação ∈, nós definiríamos s = t como uma abreviatura para ∀x (sxtx) ∧ ∀x (xsxt). Esta definição de igualdade satisfaz automaticamente os axiomas da igualdade.
  • Em algumas teorias é possível dar definições de igualdade ad hoc. Por exemplo, em uma teoria de ordens parciais com uma relação ≤ nós poderíamos definir s = t como uma abreviatura para stts.

Regras de inferência editar

A regra de inferência modus ponens é a única necessária para a lógica proposicional de acordo com a formalização proposta aqui. Ela diz que se φ e φ → ψ são ambos demonstrados, então pode-se deduzir ψ. A regra de inferência chamada Generalização Universal é característica da lógica de primeira ordem:

se  , então  

onde se supõe que   é um teorema já demonstrado da lógica de primeira ordem. Observe que a Generalização é análoga à regra da necessitação da lógica modal, que é:

se  , então  .

Limitações editar

Apesar da Lógica de Primeira Ordem ser suficiente para formalizar uma grande parte da matemática, e também ser comumente usada em Ciência da Computação e outras áreas, ela tem as suas limitações. Suas limitações incluem limitações em sua expressividade e limitações com relação aos fragmentos das línguas naturais que pode descrever.

Expressividade editar

O teorema de Löwenheim–Skolem mostra que se uma teoria de primeira ordem tem um modelo infinito, então a teoria também tem modelos de todas as cardinalidades infinitas. Em particular, nenhuma teoria de primeira ordem com um modelo infinito pode ser categórica. Assim, não há uma teoria de primeira ordem cujo único modelo tem o conjunto dos números naturais como domínio, ou cujo único modelo tem o conjunto dos números reais como domínio. Várias extensões da Lógica de Primeira-Ordem, incluindo a Lógica de Ordem Superior e a Lógica Infinitária, são mais expressivas no sentido de que elas admitem axiomatizações categóricas dos números naturais ou reais. Essa expressividade tem um custo em relação às propriedades meta-lógicas; de acordo com o Teorema de Lindström, qualquer lógica que seja mais forte que a lógica de primeira ordem falhará em validar o teorema da compacidade ou em validar o teorema de Löwenheim–Skolem.

Formalizando as Línguas Naturais editar

A lógica de primeira ordem é capaz de formalizar vários quantificadores na língua natural, como “todas as pessoas que moram em Paris, moram na França”. Mas existem várias características que não podem ser expressas na lógica de primeira ordem. “Qualquer sistema lógico que é apropriado para analisar línguas naturais, precisa de uma estrutura muito mais rica que a lógica de primeira ordem" (Gamut 1991, p 75).

Tipo Exemplo Comentário
Quantificadores sobre as propriedades Se Rafael for satisfeito consigo mesmo, então ele tem pelo menos uma coisa em comum com Roberta Requer quantificadores sobre os predicados, os quais não podem ser implementados com a lógica de primeira ordem (unicamente ordenada): Zj→ ∃X(Xj∧Xp)
Quantificadores sobre as propriedades Papai Noel tem todos os atributos de um sadista Requer quantificadores sobre os predicados, os quais não podem ser implementados com a lógica de primeira ordem (unicamente ordenada): ∀X(∀x(Sx → Xx)→Xs)
Predicado adverbial Luiz está andando rápido Não pode ser analisado como Wj ∧ Qj; predicados adverbiais não são a mesma coisa que predicados de segunda ordem , como cores
Adjetivo Relativo Jumbo é um elefante pequeno Não podem ser analisados como Sj ∧ Ej; predicados adjetivados não são a mesma coisa que predicados de segunda ordem , como cores
Modificador do predicado adverbial Anderson está andando muito rápido -
Modificador do adjetivo relativo Roberta é extremamente pequena Uma expressão como "extremamente" , quando usado com um adjetivo relativo "pequena", resulta em um novo adjetivo relativo: "extremamente pequena"
Preposições Alberto está sentado ao lado de Danilo A preposição "ao lado de" quando aplicada a Luiz, resulta em um predicado adverbial "ao lado de Luiz"

Axiomas e regras editar

Os cinco axiomas lógicos mais as duas regras de inferência seguintes caracterizam a lógica de primeira ordem:

Axiomas:

  • (A1)  
  • (A2)  
  • (A3)  
  • (A4)  , onde   não é livre em  
  • (A5)   , onde t é livre para x em  

Regras de Inferência:

  • Modus Ponens:
  
  • Generalização Universal:
  

Estes axiomas são na realidade esquemas de axiomas. Cada letra grega pode ser uniformemente substituída, em cada um dos axiomas acima, por uma FBF qualquer, e uma expressão do tipo   denota o resultado da substituição de x por t na fórmula  .

Cálculo de predicados editar

O cálculo de predicado é uma extensão da lógica proposicional que define quais sentenças da lógica de primeira ordem são demonstráveis. É um sistema formal usado para descrever as teorias matemáticas. Se o cálculo proposicional for definido por um conjunto adequado de axiomas e a única regra de inferência modus ponens (isto pode ser feito de muitas maneiras diferentes, uma delas já ilustrada na seção anterior), então o cálculo de predicados pode ser definido adicionando-se alguns axiomas e uma regra de inferência "generalização universal" (como, por exemplo, na seção anterior). Mais precisamente, como axiomas para o cálculo de predicado, teremos:

  • Os axiomas circunstanciais do cálculo proposicional (A1, A2 e A3 na seção anterior);
  • Os axiomas dos quantificadores (A4 e A5);
  • Os axiomas para a igualdade propostos em seção anterior, se a igualdade for considerada como um conceito lógico.

Uma sentença será definida como demonstrável na lógica de primeira ordem se puder ser obtida começando com os axiomas do cálculo de predicados e aplicando-se repetidamente as regras de inferência "modus ponens" e "generalização universal". Se nós tivermos uma teoria T (um conjunto de sentenças, às vezes chamadas axiomas) então uma sentença φ se define como demonstrável na teoria T se ab ∧ … → φ é demonstrável na lógica de primeira ordem (relação de consequência formal), para algum conjunto finito de axiomas a, b,… da teoria T. Um problema aparente com esta definição de "demonstrabilidade" é que ela parece um tanto ad hoc: nós tomamos uma coleção aparentemente aleatória de axiomas e de regras de inferência, e não é óbvio que não tenhamos acidentalmente deixado de fora algum axioma ou regra fundamental. O teorema da completude de Gödel nos assegura de que este não é realmente um problema: o teorema diz que toda sentença verdadeira em todos os modelos é demonstrável na lógica de primeira ordem. Em particular, toda definição razoável de "demonstrável" na lógica de primeira ordem deve ser equivalente à definição acima (embora seja possível que os comprimentos das derivações difira bastante para diferentes definições de demonstrabilidade). Há muitas maneiras diferentes (mas equivalentes) de definir provabilidade. A definição acima é um exemplo típico do cálculo no estilo de Hilbert, que tem muitos axiomas diferentes, mas poucas regras de inferência. As definições de demonstrabilidade para a lógica de primeira ordem nos estilos de Gentzen (dedução natural e cálculo de sequentes) são baseadas em poucos ou nenhum axiomas, mas muitas regras de inferência.

Algumas equivalências editar

 
 
 
 
 
 

Algumas regras de inferência editar

 
 
 
 
  (se c for uma variável, então não deve ser quantificada em P(x))
  (x não deve aparecer livre em P(c))

Metateoremas da lógica de primeira ordem editar

Alguns metateoremas lógicos importantes listam-se abaixo:

  1. Ao contrário da lógica proposicional, a lógica de primeira ordem é indecidível, desde que a linguagem contenha ao menos um predicado de aridade ao menos 2, para além da igualdade. Pode-se demonstrar que há um procedimento de decisão para determinar se uma fórmula arbitrária P é válida (veja problema da parada). (Estes resultados foram demonstrados, independentemente, por Church e Turing).
  2. O problema da decisão para validade é semidecidível, ou seja, há uma máquina de Turing que quando recebe uma frase como entrada, parará se e somente se a sentença for válida (satisfeita em todos os modelos).
    • Como o teorema da completude de Gödel mostra, para toda fórmula válida P, P é demonstrável. Analogamente, assumindo a consistência da lógica, toda fórmula demonstrável é válida.
    • Para um conjunto finito ou semi-enumerável de axiomas, o conjunto das fórmulas demonstráveis pode ser explicitamente enumerado por uma máquina de Turing, donde segue o resultado de semidecidibilidade.
  3. A lógica de predicados monádica (i.e., a lógica de predicados somente com predicados de um argumento) é decidível.
  4. A classe de Bernays-Schönfinkel das fórmulas de primeira ordem é também decidível.

Comparação com outras lógicas editar

A maioria destas lógicas são de certa forma extensões da lógica de primeira ordem: elas incluem todos os quantificadores e operadores lógicos da lógica de primeira ordem com os mesmos significados. Lindström mostrou que a lógica de primeira ordem não tem extensões (com exceção dela própria) que satisfazem o teorema da compacidade e ao teorema de Löwenheim-Skolem descendente. Uma formulação precisa deste teorema requer a listagem de vários páginas de condições técnicas que a lógica deve satisfazer, por exemplo, a mudança dos símbolos de uma linguagem não deve fazer nenhuma diferença essencial nas sentenças que são verdadeiras.

A lógica de primeira ordem em que nenhuma sentença atômica se encontra sob o escopo de mais de três quantificadores, tem o mesmo poder expressivo que a álgebra de relação de Tarski e de Givant (1987). Estes autores também mostram que a LCPO (Lógica Clássica de Primeira Ordem) com um par ordenado primitivo, e uma relação algébrica incluindo relações de projeção sobre pares ordenados são equivalentes.

ex: pt.x (Homem(x)→Mortal(x)), que é uma fórmula válida

Ver também editar

Referências

  1. «Lógica de Primeira Ordem» (PDF). Instituto de Matemática e Estatística da Universidade de São Paulo. Consultado em 5 de janeiro de 2014 
  2. «A Lógica de Primeira Ordem» (PDF). Departamento de Ciência da Computação - Universidade de Brasília. Consultado em 22 de Janeiro de 2016 

Bibliografia editar

  • SILVA, Flávio S. Correa da; FINGER, Marcelo; MELO, Ana Cristina V. de. Lógica para Computação. ed. Thomson, 2006.
  • MORTARI, Cezar. Introdução à Lógica. 1. ed. Imprensa Oficial SP, 2001.
  • ABE, Jair Minoro; SCALZITTI, Alexandre; FILHO, João Inácio da Silva. Introdução à Lógica para a Ciência da Computação. 2. ed. Arte e Ciência, 2002.
  • SOUZA, João de. Lógica para Ciência da Computação. 1. ed. Campus, 2002.
  • DETLEFSEN, Michael; MCCARTY, David Charles; BACON, John B. Glossário de Lógica. ed. Edições 70, 2004.
  • «Bedregal» , B.R.C, and Acióly, B.M. Lógica para a Ciência da Computação. Versão preliminar, 2002.
  • Stanford Encyclopedia of Philosophy: Classical Logic — por Stewart Shapiro. Cobre a sintaxe, teoria de modelos, e a metateoria da lógica de primeira ordem no estilo de dedução natural.
  • «Forall x: an introduction to formal logic» , por P.D. Magnus, cobre a semântica formal e a teoria da demonstração para a lógica de primeira ordem.
  • «Metamath» : um projeto on-line para a reconstrução da matemática como uma enorme teoria de primeira ordem, usando lógica de primeira ordem e a teoria axiomática dos conjuntos ZFC. Principia Mathematica modernizado e feito corretamente.
  • Podnieks, Karl. Introduction to mathematical logic.