Lógica/Cálculo Proposicional Clássico/Operadores e Tabelas Veritativas: mudanças entre as edições
imported>Dante Cardoso Pinto de Almeida |
|||
(23 revisões intermediárias por 9 usuários não estão sendo mostradas) | |||
Linha 1: | Linha 1: | ||
===Tabelas | |||
===Tabelas Veritativas=== | |||
Seja <math>\mathcal{L}</math> uma linguagem que contenha as proposições <math>A\,\!</math>, <math>B\,\!</math> e <math>C\,\!</math>. | Seja <math>\mathcal{L}</math> uma linguagem que contenha as proposições <math>A\,\!</math>, <math>B\,\!</math> e <math>C\,\!</math>. | ||
Linha 20: | Linha 18: | ||
Agora, o que podemos dizer sobre as proposições <math>A\,\!</math> e <math>B\,\!</math> ? | Agora, o que podemos dizer sobre as proposições <math>A\,\!</math> e <math>B\,\!</math> ? Ora, ou ambas são verdadeiras, ou a primeira é verdadeira e a segunda é falsa, ou a primeira é falsa e a segunda é verdadeira, ou ambas são falsas. Isto representamos assim: | ||
<div align="center"> | <div align="center"> | ||
Linha 87: | Linha 85: | ||
Agora, o que dizer sobre fórmulas moleculares, como <math>\neg A\,\!</math>, <math>B\lor C\,\!</math> ou <math>\left(B\land C\right)\to \left(A\leftrightarrow B\right)</math> ? Para estas, podemos estabelecer os valores que elas recebem em vista do valor de cada fórmula atômica que as compõe. Faremos isto por meio das '''tabelas | Agora, o que dizer sobre fórmulas moleculares, como <math>\neg A\,\!</math>, <math>B\lor C\,\!</math> ou <math>\left(B\land C\right)\to \left(A\leftrightarrow B\right)</math> ? Para estas, podemos estabelecer os valores que elas recebem em vista do valor de cada fórmula atômica que as compõe. Faremos isto por meio das '''tabelas veritativas'''. | ||
Os primeiros passos para construir uma tabela | Os primeiros passos para construir uma tabela veritativa consistem em: | ||
1º) Uma linha em que estão contidos todas as subfórmulas de uma fórmula e a própria fórmula. Por exemplo, a fórmula <math>\neg \left(\left( A\land B\right)\to C \right)</math> tem o seguinte conjuntos de subfórmulas: | 1º) Uma linha em que estão contidos todas as subfórmulas de uma fórmula e a própria fórmula. Por exemplo, a fórmula <math>\neg \left(\left( A\land B\right)\to C \right)</math> tem o seguinte conjuntos de subfórmulas: | ||
Linha 96: | Linha 94: | ||
2º) <math>l\!\,</math> linhas em que estão todos possíveis valores que os termos podem receber e os valores cujas as fórmulas moleculares tem dados os valores destes termos. | 2º) <math>l\!\,</math> linhas em que estão todos possíveis valores que os termos podem receber e os valores cujas as fórmulas moleculares tem dados os valores destes termos. | ||
O número destas linhas é <math>l = n^t\!\,</math> , sendo <math>n\!\,</math> o número de valores que o sistema permite (sempre 2 no caso do CPC) e <math>t\!\,</math> o número de termos que a fórmula contém. Assim, se uma fórmula contém 2 termos, o número de linhas que expressam | O número destas linhas é <math>l = n^t\!\,</math> , sendo <math>n\!\,</math> o número de valores que o sistema permite (sempre 2 no caso do CPC) e <math>t\!\,</math> o número de termos que a fórmula contém. Assim, se uma fórmula contém 2 termos, o número de linhas que expressam as permutações entre estes será 4: um caso de ambos termos serem verdadeiros (V V), dois casos de apenas um dos termos ser verdadeiro (V F , F V) e um caso no qual ambos termos são falsos (F F). Se a fórmula contiver 3 termos, o número de linhas que expressam as permutações entre estes será 8: um caso de todos termos serem verdadeiros (V V V), três casos de apenas dois termos serem verdadeiros (V V F , V F V , F V V), três casos de apenas um dos termos ser verdadeiro (V F F , F V F , F F V) e um caso no qual todos termos são falsos (F F F). | ||
Então, para a fórmula <math>\neg \left(\left( A\land B\right)\to C \right)</math>, temos: | Então, para a fórmula <math>\neg \left(\left( A\land B\right)\to C \right)</math>, temos: | ||
Linha 106: | Linha 104: | ||
|style="background-color: #DEE;" |'''B''' | |style="background-color: #DEE;" |'''B''' | ||
|style="background-color: #DEE;" |'''C''' | |style="background-color: #DEE;" |'''C''' | ||
|style="background-color: #DEE;" |''' | |style="background-color: #DEE;" |'''A^B''' | ||
|style="background-color: #DEE;" |'''( | |style="background-color: #DEE;" |'''(A^B)→C''' | ||
|style="background-color: #DEE;" |'''¬(( | |style="background-color: #DEE;" |'''¬((A^B)→C)''' | ||
|- | |- | ||
|style="background-color: #DDD;" |V | |style="background-color: #DDD;" |V | ||
Linha 162: | Linha 160: | ||
</div> | </div> | ||
*'''Interpretações''': "Não <math>A\!\,</math>", "Não é o caso de <math>A\!\,</math>", " | *'''Interpretações''': "Não <math>A\!\,</math>", "Não é o caso de <math>A\!\,</math>", "É falso que '<math>A\!\,</math>'". | ||
Assim, em uma linguagem <math>\mathcal{L}\!\,</math> na qual <math>A\!\,</math> significa "''Sócrates é mortal''", <math>\neg A\!\,</math> pode ser interpretada como "''Sócrates não é mortal''", e, se o primeiro é verdadeiro, o segundo é falso; e se o primeiro é falso, o segundo é verdadeiro. | Assim, em uma linguagem <math>\mathcal{L}\!\,</math> na qual <math>A\!\,</math> significa "''Sócrates é mortal''", <math>\neg A\!\,</math> pode ser interpretada como "''Sócrates não é mortal''", e, se o primeiro é verdadeiro, o segundo é falso; e se o primeiro é falso, o segundo é verdadeiro. | ||
Linha 189: | Linha 187: | ||
</div> | </div> | ||
“<math>\neg \neg A \,\!</math>” significa | “<math>\neg \neg A \,\!</math>” significa “É falso que <math>\neg A \,\!</math>”. | ||
“<math>\neg \neg \neg A \,\!</math>” significa | “<math>\neg \neg \neg A \,\!</math>” significa “É falso que <math>\neg \neg A \,\!</math>”. | ||
E assim por diante. | E assim por diante. | ||
Linha 197: | Linha 195: | ||
Repare que <math>\neg \neg A \,\!</math> é equivalente a <math>A \,\!</math>, assim como <math>\neg \neg \neg A \,\!</math> é equivalente a <math>\neg A \,\!</math>. | Repare que <math>\neg \neg A \,\!</math> é equivalente a <math>A \,\!</math>, assim como <math>\neg \neg \neg A \,\!</math> é equivalente a <math>\neg A \,\!</math>. | ||
A negação múltipla | A negação múltipla traz alguns problemas de interpretação. Interpretando mais uma vez <math>A \,\!</math> por "''Sócrates é mortal''", podemos perfeitamente interpretar <math>\neg \neg A \,\!</math> de diversas formas: "''Não é o caso de que Sócrates não é mortal''", "''Não é o caso de que Sócrates é imortal''", "''É falso que Sócrates não é mortal''", "''É falso que Sócrates é imortal''" etc. Contudo, nem sempre na língua portuguesa a dupla negação de uma proposição equivale à afirmação desta. Muitas vezes a dupla negação é uma ênfase na negação. Exemplos: "''Não veio ninguém''", "Não fiz nada hoje" etc. | ||
====Conjunção==== | ====Conjunção==== | ||
Linha 261: | Linha 259: | ||
</div> | </div> | ||
A comutatividade da conjunção | A comutatividade da conjunção traz um problema para formalizar proposições da linguagem natural no Cálculo Proposicional Clássico, pois a ordem em que as orações aparecem pode sugerir uma sequencia temporal. Por exemplo "''Isabela casou e teve um filho''" é bem diferente de "''Isabela teve um filho e casou''". Repare que o mesmo problema não acomete a proposição "''Isabela é casada e tem filhos''", que é equivalente a "''Isabela tem filhos e é casada''". Esta sentença é, portanto, perfeitamente formalizável no Cálculo Proposicional Clássico por meio de uma conjunção. | ||
Proposições que levam a palavra "''mas''" também podem ser formalizadas pela conjunção. Por exemplo, em uma linguagem <math>\mathcal{L}\!\,</math> na qual <math>C\!\,</math> significa "''João foi atropelado''" e <math>D\!\,</math> significa "''João sobreviveu ao atropelamento''", as sentenças "''João foi atropelado e sobreviveu''" e "''João foi atropelado, mas sobreviveu''" podem ambas serem formalizadas assim: <math>C\land D\,\!</math> | Proposições que levam a palavra "''mas''" também podem ser formalizadas pela conjunção. Por exemplo, em uma linguagem <math>\mathcal{L}\!\,</math> na qual <math>C\!\,</math> significa "''João foi atropelado''" e <math>D\!\,</math> significa "''João sobreviveu ao atropelamento''", as sentenças "''João foi atropelado e sobreviveu''" e "''João foi atropelado, mas sobreviveu''" podem ambas serem formalizadas assim: <math>C\land D\,\!</math> | ||
Afinal, ambas proposições afirmam os mesmos eventos na mesma | Afinal, ambas proposições afirmam os mesmos eventos na mesma sequencia: o atropelamento e a sobrevivência de João. A única diferença entre ambas é que aquela que leva "mas" expressa que uma expectativa subjetiva não foi satisfeita, o que, para os desenvolvedores da lógica clássica, não importa para a lógica. | ||
====Disjunção==== | ====Disjunção==== | ||
Linha 334: | Linha 332: | ||
====Implicação==== | ====Implicação==== | ||
A implicação entre duas fórmulas só é falsa se a da esquerda (antecedente) for verdadeira e da direita ( | A implicação entre duas fórmulas só é falsa se a da esquerda (antecedente) for verdadeira e da direita (consequente) for falsa. A saber: | ||
<div align="center"> | <div align="center"> | ||
Linha 391: | Linha 389: | ||
</div> | </div> | ||
*'''Interpretação''': "<math>A\to B\!\,</math>" pode ser interpretada como "''Se <math>A\!\,</math>, então <math>B\!\,</math>''", "''<math>A\!\,</math> implica em <math>B\!\,</math>''", "''Se a proposição ' <math>A\!\,</math> ' é verdade, então a proposição ' <math>B\!\,</math> ' também é verdade''", "A partir de '<math>A\!\,</math>' inferimos '<math>B\!\,</math>' ''". | *'''Interpretação''': "<math>A\to B\!\,</math>" pode ser interpretada como "''Se <math>A\!\,</math>, então <math>B\!\,</math>''", "''<math>A\!\,</math> implica em <math>B\!\,</math>''", "''Se a proposição ' <math>A\!\,</math> ' é verdade, então a proposição ' <math>B\!\,</math> ' também é verdade''", "A partir de '<math>A\!\,</math>' inferimos '<math>B\!\,</math>' ''", "<math>A\!\,</math> satisfaz <math>B\!\,</math>", "<math>A\!\,</math> é condição suficiente de <math>B\!\,</math>". | ||
Assim, se, em uma linguagem <math>\mathcal{L}</math> , <math>A\!\,</math> significa "''O botão vermelho foi apertado''" e <math>B\!\,</math> significa "''O lugar todo explode''", <math>A\to B\!\,</math> pode ser interpretada como "''Se o botão vermelho foi apertado, o lugar inteiro explode''", o que só é falso se o botão vermelho for apertado (verdade de <math>A\!\,</math>) e o lugar não explodir (falsidade de <math>B\!\,</math>): | Assim, se, em uma linguagem <math>\mathcal{L}</math> , <math>A\!\,</math> significa "''O botão vermelho foi apertado''" e <math>B\!\,</math> significa "''O lugar todo explode''", <math>A\to B\!\,</math> pode ser interpretada como "''Se o botão vermelho foi apertado, o lugar inteiro explode''", o que só é falso se o botão vermelho for apertado (verdade de <math>A\!\,</math>) e o lugar não explodir (falsidade de <math>B\!\,</math>): | ||
Linha 399: | Linha 397: | ||
Quando temos na linguagem natural uma proposição que afirma que, a partir de um evento, outro segue inexoravelmente (por exemplo: "''Se você sair na chuva sem guarda-chuva ou capa de chuva, então você vai se molhar''") ou uma proposição que afirma que podemos deduzir um fato de outro (por exemplo: "''Se todo número par é divisível por 2, então nenhum número par maior que 2 é primo''"), podemos seguramente formalizar estas proposições por meio da implicação. | Quando temos na linguagem natural uma proposição que afirma que, a partir de um evento, outro segue inexoravelmente (por exemplo: "''Se você sair na chuva sem guarda-chuva ou capa de chuva, então você vai se molhar''") ou uma proposição que afirma que podemos deduzir um fato de outro (por exemplo: "''Se todo número par é divisível por 2, então nenhum número par maior que 2 é primo''"), podemos seguramente formalizar estas proposições por meio da implicação. | ||
Mas o contrário, ou seja, interpretar uma implicação a na linguagem natural, é problemático. Podemos estar lidando com uma implicação cujo o antecedente e o | Mas o contrário, ou seja, interpretar uma implicação a na linguagem natural, é problemático. Podemos estar lidando com uma implicação cujo o antecedente e o consequente não tem relação alguma. Bastando que o antecedente seja falso ou o consequente seja verdadeiro para que a implicação seja verdadeira. Nestes casos, é bem difícil dar uma interpretação satisfatória para a implicação. | ||
====Bi-implicação==== | ====Bi-implicação==== | ||
Linha 459: | Linha 457: | ||
</div> | </div> | ||
*'''Interpretação''': "<math>A\leftrightarrow B</math>" pode ser interpretada como "''<math>A\!\,</math> se e somente se <math>B\!\,</math>''", "''<math>A\!\,</math> é equivalente a <math>B\!\,</math>''", "''<math>A\!\,</math> e <math>B\!\,</math> possuem o mesmo valor | *'''Interpretação''': "<math>A\leftrightarrow B</math>" pode ser interpretada como "''<math>A\!\,</math> se e somente se <math>B\!\,</math>''", "''<math>A\!\,</math> é equivalente a <math>B\!\,</math>''", "''<math>A\!\,</math> e <math>B\!\,</math> possuem o mesmo valor veritativo''". | ||
Assim, se <math>A\!\,</math> significa "''As luzes estão acesas''" e <math>B\!\,</math> significa "''O interruptor está voltado para cima''", <math>A\leftrightarrow B</math> pode ser interpretada como "''As luzes estão acesas se e somente se o interruptor está voltado para cima''", o que só é falso se as luzes estiverem acesas e o interruptor não estiver voltado para cima (verdade de <math>A\!\,</math> falsidade de <math>B\!\,</math>), ou se as luzes não estiverem acesas e o interruptor estiver voltado para cima (falsidade de <math>A\!\,</math> e verdade de <math>B\!\,</math>): | Assim, se <math>A\!\,</math> significa "''As luzes estão acesas''" e <math>B\!\,</math> significa "''O interruptor está voltado para cima''", <math>A\leftrightarrow B</math> pode ser interpretada como "''As luzes estão acesas se e somente se o interruptor está voltado para cima''", o que só é falso se as luzes estiverem acesas e o interruptor não estiver voltado para cima (verdade de <math>A\!\,</math> falsidade de <math>B\!\,</math>), ou se as luzes não estiverem acesas e o interruptor estiver voltado para cima (falsidade de <math>A\!\,</math> e verdade de <math>B\!\,</math>): | ||
==== | ====Outros conectivos==== | ||
Ainda há outros conectivos interessantes, mas, por motivos explicados mais para frente, não trabalharemos com eles. Vamos apenas nos familiarizar com alguns deles agora. | |||
=====Adaga de Quine===== | =====Adaga de Quine===== | ||
<math>A \downarrow B \,\!</math> é verdadeiro somente se ambos, <math>A\!\,</math> e <math>B\!\,</math>, forem falsos. Trata-se, portanto, da negação da disjunção: | |||
<div align="center"> | <div align="center"> | ||
{|style="background-color: #F8F8F8; border: 1px solid #888;" | {|style="background-color: #F8F8F8; border: 1px solid #888;" | ||
Linha 498: | Linha 497: | ||
=====Disjunção Exclusiva===== | =====Disjunção Exclusiva===== | ||
A disjunção exclusiva entre duas fórmulas é verdadeira somente se apenas uma delas for verdadeira. Trata-se, portanto, da negação da bi-implicação: | |||
<div align="center"> | <div align="center"> | ||
{|style="background-color: #F8F8F8; border: 1px solid #888;" | {|style="background-color: #F8F8F8; border: 1px solid #888;" | ||
Linha 525: | Linha 525: | ||
|style="background-color: #DDD;" |V | |style="background-color: #DDD;" |V | ||
|style="background-color: #DDD;" |F | |style="background-color: #DDD;" |F | ||
|} | |||
</div> | |||
=====Traço de Sheffer===== | |||
<math>A \mid B \,\!</math> só é falsa se ambos <math>A\,\!</math> e <math>B\,\!</math> forem verdadeiros. Trata-se, portanto, da negação da conjunção. | |||
<div align="center"> | |||
{|style="background-color: #F8F8F8; border: 1px solid #888;" | |||
|style="background-color: #DEE;" |'''A''' | |||
|style="background-color: #DEE;" |'''B''' | |||
|style="background-color: #DEE;" |'''A'''∧'''B''' | |||
|style="background-color: #DEE;" |'''A|B''' | |||
|- | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|- | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |V | |||
|- | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |V | |||
|- | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |V | |||
|} | |} | ||
</div> | </div> | ||
Linha 657: | Linha 689: | ||
===Completando a tabela de verdade=== | ===Completando a tabela de verdade=== | ||
Agora vejamos como completar a tabela de verdade da fórmula <math>\neg \left(\left( A\land B\right)\to C \right)</math>. | |||
Uma vez que já estabelecemos todas valorações de <math>A\,\!</math>, <math>B\,\!</math> e <math>C\,\!</math> vamos completar cada coluna, começando pela subfórmula mais simples até chegar à fórmula em questão. | |||
Neste caso, vamos começar por <math>A\land B\,\!</math>. Pela definição de conjunção, em cada linha nas quais tanto <math>A\,\!</math> quanto <math>B\,\!</math> forem verdadeiras, <math>A\land B\,\!</math> será verdadeira. Em todas as demais, será falsa: | |||
<div align="center"> | |||
{|style="background-color: #F8F8F8; border: 1px solid #888;" | |||
|style="background-color: #DEE;" |'''A''' | |||
|style="background-color: #DEE;" |'''B''' | |||
|style="background-color: #DEE;" |'''C''' | |||
|style="background-color: #DEE;" |'''A∧B''' | |||
|style="background-color: #DEE;" |'''(A∧B)→C''' | |||
|style="background-color: #DEE;" |'''¬((A∧B)→C)''' | |||
|- | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |V | |||
|- | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |V | |||
|- | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|- | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |F | |||
|- | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|- | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |F | |||
|- | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|- | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |F | |||
|} | |||
</div> | |||
Agora vamos considerar a coluna da subfórmula <math>\left( A\land B\right)\to C</math>. Pela definição de implicação, em cada linha na qual o antecedente <math>A\land B\,\!</math> for verdadeiro enquanto o consequente <math>C\,\!</math> for falso, <math>\left( A\land B\right)\to C</math> será falso. Em todas as demais, será verdadeira: | |||
<div align="center"> | |||
{|style="background-color: #F8F8F8; border: 1px solid #888;" | |||
|style="background-color: #DEE;" |'''A''' | |||
|style="background-color: #DEE;" |'''B''' | |||
|style="background-color: #DEE;" |'''C''' | |||
|style="background-color: #DEE;" |'''A∧B''' | |||
|style="background-color: #DEE;" |'''(A∧B)→C''' | |||
|style="background-color: #DEE;" |'''¬((A∧B)→C)''' | |||
|- | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |V | |||
|- | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|- | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |V | |||
|- | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |V | |||
|- | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |V | |||
|- | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |V | |||
|- | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |V | |||
|- | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |V | |||
|} | |||
</div> | |||
Por fim, resta a coluna da fórmula <math>\neg \left(\left( A\land B\right)\to C \right)</math>. Pela definição de negação, em cada linha na qual <math>\left( A\land B\right)\to C </math> for verdadeira, <math>\neg \left(\left( A\land B\right)\to C \right)</math> será falsa; e em cada linha na qual <math>\left( A\land B\right)\to C </math> for falsa, <math>\neg \left(\left( A\land B\right)\to C \right)</math> será verdadeira: | |||
<div align="center"> | |||
{|style="background-color: #F8F8F8; border: 1px solid #888;" | |||
|style="background-color: #DEE;" |'''A''' | |||
|style="background-color: #DEE;" |'''B''' | |||
|style="background-color: #DEE;" |'''C''' | |||
|style="background-color: #DEE;" |'''A∧B''' | |||
|style="background-color: #DEE;" |'''(A∧B)→C''' | |||
|style="background-color: #DEE;" |'''¬((A∧B)→C)''' | |||
|- | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|- | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |V | |||
|- | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|- | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|- | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|- | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|- | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|- | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |F | |||
|style="background-color: #DDD;" |V | |||
|style="background-color: #DDD;" |F | |||
|} | |||
</div> | |||
Por meio desta tabela podemos ver que a fórmula <math>\neg \left(\left( A\land B\right)\to C \right)</math> só é verdadeira em um único caso: o qual <math>A\,\!</math> e <math>B\,\!</math> são verdadeiras enquanto <math>C\,\!</math> é falsa. Esta é uma das aplicações da tabela de verdade: determinar em quais valorações de suas subfórmulas uma fórmula é verdadeira ou falsa. | |||
===Exercícios=== | ===Exercícios=== | ||
Linha 681: | Linha 906: | ||
{{AutoCat}} |
Edição atual tal como às 14h25min de 16 de janeiro de 2016
Tabelas Veritativas
Seja uma linguagem que contenha as proposições , e .
O que podemos dizer sobre proposição ? Para começar, segundo o princípio de bivalência, ela ou é verdadeira ou é falsa. Isto representamos assim:
A |
V |
F |
Agora, o que podemos dizer sobre as proposições e ? Ora, ou ambas são verdadeiras, ou a primeira é verdadeira e a segunda é falsa, ou a primeira é falsa e a segunda é verdadeira, ou ambas são falsas. Isto representamos assim:
A | B |
V | V |
V | F |
F | V |
F | F |
Como você já deve ter reparado, uma tabela para , e é assim:
A | B | C |
V | V | V |
V | V | F |
V | F | V |
V | F | F |
F | V | V |
F | V | F |
F | F | V |
F | F | F |
Cada linha da tabela (fora a primeira que contém as fórmulas) representa uma valoração.
Agora, o que dizer sobre fórmulas moleculares, como , ou ? Para estas, podemos estabelecer os valores que elas recebem em vista do valor de cada fórmula atômica que as compõe. Faremos isto por meio das tabelas veritativas.
Os primeiros passos para construir uma tabela veritativa consistem em:
1º) Uma linha em que estão contidos todas as subfórmulas de uma fórmula e a própria fórmula. Por exemplo, a fórmula tem o seguinte conjuntos de subfórmulas: { , , , , }
2º) linhas em que estão todos possíveis valores que os termos podem receber e os valores cujas as fórmulas moleculares tem dados os valores destes termos.
O número destas linhas é , sendo o número de valores que o sistema permite (sempre 2 no caso do CPC) e o número de termos que a fórmula contém. Assim, se uma fórmula contém 2 termos, o número de linhas que expressam as permutações entre estes será 4: um caso de ambos termos serem verdadeiros (V V), dois casos de apenas um dos termos ser verdadeiro (V F , F V) e um caso no qual ambos termos são falsos (F F). Se a fórmula contiver 3 termos, o número de linhas que expressam as permutações entre estes será 8: um caso de todos termos serem verdadeiros (V V V), três casos de apenas dois termos serem verdadeiros (V V F , V F V , F V V), três casos de apenas um dos termos ser verdadeiro (V F F , F V F , F F V) e um caso no qual todos termos são falsos (F F F).
Então, para a fórmula , temos:
A | B | C | A^B | (A^B)→C | ¬((A^B)→C) |
V | V | V | |||
V | V | F | |||
V | F | V | |||
V | F | F | |||
F | V | V | |||
F | V | F | |||
F | F | V | |||
F | F | F |
Para completar esta tabela precisamos definir os operadores lógicos. Ao fazê-lo, vamos aproveitar para explicar como interpretá-los.
Negação
A negação tem o valor inverso da fórmula negada. A saber:
A | ¬A |
V | F |
F | V |
- Interpretações: "Não ", "Não é o caso de ", "É falso que ''".
Assim, em uma linguagem na qual significa "Sócrates é mortal", pode ser interpretada como "Sócrates não é mortal", e, se o primeiro é verdadeiro, o segundo é falso; e se o primeiro é falso, o segundo é verdadeiro.
Interpretar a negação por meio de antônimos também é uma alternativa, mas deve-se ter cautela, pois nem sempre é aplicável em todos os casos. No exemplo acima a interpretação por meio de antônimos é perfeitamente aplicável, ou seja, se significa "Sócrates é mortal", pode ser interpretada como "Sócrates é imortal". Por outro lado, em uma linguagem na qual significa "João é bom jogador", a proposição "João é mau jogador" não é a melhor interpretação para (João poderia ser apenas um jogador mediano).
Pode-se adicionar indefinidamente o operador de negação:
A | ¬A | ¬¬A | ¬¬¬A |
V | F | V | F |
F | V | F | V |
“” significa “É falso que ”.
“” significa “É falso que ”.
E assim por diante.
Repare que é equivalente a , assim como é equivalente a .
A negação múltipla traz alguns problemas de interpretação. Interpretando mais uma vez por "Sócrates é mortal", podemos perfeitamente interpretar de diversas formas: "Não é o caso de que Sócrates não é mortal", "Não é o caso de que Sócrates é imortal", "É falso que Sócrates não é mortal", "É falso que Sócrates é imortal" etc. Contudo, nem sempre na língua portuguesa a dupla negação de uma proposição equivale à afirmação desta. Muitas vezes a dupla negação é uma ênfase na negação. Exemplos: "Não veio ninguém", "Não fiz nada hoje" etc.
Conjunção
- A conjunção entre duas fórmulas só é verdadeira quando ambas são verdadeiras. A saber:
A | B | A∧B |
V | V | V |
V | F | F |
F | V | F |
F | F | F |
- Interpretação: "" pode ser interpretada como " e ", "Tanto quanto ", "Ambas proposições '' e '' são verdadeiras" etc.
Assim, em uma linguagem na qual significa "Sou cidadão brasileiro" e significa "Sou estudante de filosofia", pode ser interpretada como "Sou cidadão brasileiro e estudante de filosofia"; o que só é verdade se é verdade e é verdade.
Repare que a conjunção é comutável, ou seja, é equivalente a , a saber:
A | B | A∧B | B∧A |
V | V | V | V |
V | F | F | F |
F | V | F | F |
F | F | F | F |
A comutatividade da conjunção traz um problema para formalizar proposições da linguagem natural no Cálculo Proposicional Clássico, pois a ordem em que as orações aparecem pode sugerir uma sequencia temporal. Por exemplo "Isabela casou e teve um filho" é bem diferente de "Isabela teve um filho e casou". Repare que o mesmo problema não acomete a proposição "Isabela é casada e tem filhos", que é equivalente a "Isabela tem filhos e é casada". Esta sentença é, portanto, perfeitamente formalizável no Cálculo Proposicional Clássico por meio de uma conjunção.
Proposições que levam a palavra "mas" também podem ser formalizadas pela conjunção. Por exemplo, em uma linguagem na qual significa "João foi atropelado" e significa "João sobreviveu ao atropelamento", as sentenças "João foi atropelado e sobreviveu" e "João foi atropelado, mas sobreviveu" podem ambas serem formalizadas assim:
Afinal, ambas proposições afirmam os mesmos eventos na mesma sequencia: o atropelamento e a sobrevivência de João. A única diferença entre ambas é que aquela que leva "mas" expressa que uma expectativa subjetiva não foi satisfeita, o que, para os desenvolvedores da lógica clássica, não importa para a lógica.
Disjunção
- A disjunção entre duas fórmulas só é verdadeira quando ao menos uma delas é verdadeira. A saber:
A | B | A∨B |
V | V | V |
V | F | V |
F | V | V |
F | F | F |
Repare que a disjunção também é comutativa:
A | B | A∨B | B∨A |
V | V | V | V |
V | F | V | V |
F | V | V | V |
F | F | F | F |
- Interpretação: "" pode ser interpretada como " ou ", "Entre as proposições e , ao menos uma é verdadeira".
Assim, se significa "Fulano estuda filosofia" e significa "Fulano estuda matemática", pode ser interpretada como "Fulano estuda filosofia ou matemática"; o que só é falso se nem nem forem verdadeiras.
Com a disjunção é preciso tomar muito cuidado tanto na interpretação de fórmulas quanto na formalização de proposições, pois na linguagem natural muitas vezes os disjuntos são excludentes. Por exemplo: "Uma moeda ao ser lançada resulta em cara ou coroa", "Nestas férias eu vou viajar ou ficar em casa".
Para estes casos usamos a disjunção exclusiva ou a bi-implicação combinada com a negação, como veremos mais adiante.
Implicação
A implicação entre duas fórmulas só é falsa se a da esquerda (antecedente) for verdadeira e da direita (consequente) for falsa. A saber:
A | B | A→B |
V | V | V |
V | F | F |
F | V | V |
F | F | V |
Repare que a implicação não é comutativa:
A | B | A→B | B→A |
V | V | V | V |
V | F | F | V |
F | V | V | F |
F | F | V | V |
- Interpretação: "" pode ser interpretada como "Se , então ", " implica em ", "Se a proposição ' ' é verdade, então a proposição ' ' também é verdade", "A partir de '' inferimos '' ", " satisfaz ", " é condição suficiente de ".
Assim, se, em uma linguagem , significa "O botão vermelho foi apertado" e significa "O lugar todo explode", pode ser interpretada como "Se o botão vermelho foi apertado, o lugar inteiro explode", o que só é falso se o botão vermelho for apertado (verdade de ) e o lugar não explodir (falsidade de ):
A interpretação da implicação é uma das mais complicadas. Talvez você tenha estranhado que a implicação seja verdadeira quando o antecedente é falso. Ou ainda, você poderia objetar "mas e se o botão for apertado, o lugar explodir, mas uma coisa não ter nada a ver com a outra?".
Quando temos na linguagem natural uma proposição que afirma que, a partir de um evento, outro segue inexoravelmente (por exemplo: "Se você sair na chuva sem guarda-chuva ou capa de chuva, então você vai se molhar") ou uma proposição que afirma que podemos deduzir um fato de outro (por exemplo: "Se todo número par é divisível por 2, então nenhum número par maior que 2 é primo"), podemos seguramente formalizar estas proposições por meio da implicação.
Mas o contrário, ou seja, interpretar uma implicação a na linguagem natural, é problemático. Podemos estar lidando com uma implicação cujo o antecedente e o consequente não tem relação alguma. Bastando que o antecedente seja falso ou o consequente seja verdadeiro para que a implicação seja verdadeira. Nestes casos, é bem difícil dar uma interpretação satisfatória para a implicação.
Bi-implicação
A bi-implicação entre duas fórmulas é verdadeira quando ambas são verdadeiras ou ambas são falsas.
A | B | A↔B |
V | V | V |
V | F | F |
F | V | F |
F | F | V |
Repare que a bi-implicação é comutativa:
A | B | A↔B | B↔A |
V | V | V | V |
V | F | F | F |
F | V | F | F |
F | F | V | V |
- Interpretação: "" pode ser interpretada como " se e somente se ", " é equivalente a ", " e possuem o mesmo valor veritativo".
Assim, se significa "As luzes estão acesas" e significa "O interruptor está voltado para cima", pode ser interpretada como "As luzes estão acesas se e somente se o interruptor está voltado para cima", o que só é falso se as luzes estiverem acesas e o interruptor não estiver voltado para cima (verdade de falsidade de ), ou se as luzes não estiverem acesas e o interruptor estiver voltado para cima (falsidade de e verdade de ):
Outros conectivos
Ainda há outros conectivos interessantes, mas, por motivos explicados mais para frente, não trabalharemos com eles. Vamos apenas nos familiarizar com alguns deles agora.
Adaga de Quine
é verdadeiro somente se ambos, e , forem falsos. Trata-se, portanto, da negação da disjunção:
A | B | A∨B | A↓B |
V | V | V | F |
V | F | V | F |
F | V | V | F |
F | F | F | V |
Disjunção Exclusiva
A disjunção exclusiva entre duas fórmulas é verdadeira somente se apenas uma delas for verdadeira. Trata-se, portanto, da negação da bi-implicação:
A | B | A↔B | A∨B |
V | V | V | F |
V | F | F | V |
F | V | F | V |
F | F | V | F |
Traço de Sheffer
só é falsa se ambos e forem verdadeiros. Trata-se, portanto, da negação da conjunção.
A | B | A∧B | A|B |
V | V | V | F |
V | F | F | V |
F | V | F | V |
F | F | F | V |
Uso de parênteses e fórmulas com mais de um operador
- Assim como na aritmética e algebra, os parênteses na lógica indicam o que considerar primeiro. Portanto, a fórmula consiste na negação da conjunção entre e , enquanto a fórmula consiste na conjunção entre a negação de e .
- A diferença entre as fórmulas fica clara na tabela de verdade:
A | B | ¬A | A∧B | ¬(A∧B) | ¬A∧B |
V | V | F | V | F | F |
V | F | F | F | V | F |
F | V | V | F | V | V |
F | F | V | F | V | F |
- Da mesma forma, é distinta de . A saber:
A | B | C | A→B | B→C | (A→B)→C | A→(B→C) |
V | V | V | V | V | V | V |
V | V | F | V | F | F | F |
V | F | V | F | V | V | V |
V | F | F | F | V | V | F |
F | V | V | V | V | V | V |
F | V | F | V | F | F | V |
F | F | V | V | V | V | V |
F | F | F | V | F | V | V |
- Contudo, tem-se que a fórmula é equivalente à , pois ambas só serão verdadeiras se , e forem verdadeiras.
- Da mesma forma, é equivalente à (ambas só são falsas quando todos termos são falsos), e é equivalente à .
- Devido a isto, vale como convenção informal as construções , e .
Completando a tabela de verdade
Agora vejamos como completar a tabela de verdade da fórmula .
Uma vez que já estabelecemos todas valorações de , e vamos completar cada coluna, começando pela subfórmula mais simples até chegar à fórmula em questão.
Neste caso, vamos começar por . Pela definição de conjunção, em cada linha nas quais tanto quanto forem verdadeiras, será verdadeira. Em todas as demais, será falsa:
A | B | C | A∧B | (A∧B)→C | ¬((A∧B)→C) |
V | V | V | V | ||
V | V | F | V | ||
V | F | V | F | ||
V | F | F | F | ||
F | V | V | F | ||
F | V | F | F | ||
F | F | V | F | ||
F | F | F | F |
Agora vamos considerar a coluna da subfórmula . Pela definição de implicação, em cada linha na qual o antecedente for verdadeiro enquanto o consequente for falso, será falso. Em todas as demais, será verdadeira:
A | B | C | A∧B | (A∧B)→C | ¬((A∧B)→C) |
V | V | V | V | V | |
V | V | F | V | F | |
V | F | V | F | V | |
V | F | F | F | V | |
F | V | V | F | V | |
F | V | F | F | V | |
F | F | V | F | V | |
F | F | F | F | V |
Por fim, resta a coluna da fórmula . Pela definição de negação, em cada linha na qual for verdadeira, será falsa; e em cada linha na qual for falsa, será verdadeira:
A | B | C | A∧B | (A∧B)→C | ¬((A∧B)→C) |
V | V | V | V | V | F |
V | V | F | V | F | V |
V | F | V | F | V | F |
V | F | F | F | V | F |
F | V | V | F | V | F |
F | V | F | F | V | F |
F | F | V | F | V | F |
F | F | F | F | V | F |
Por meio desta tabela podemos ver que a fórmula só é verdadeira em um único caso: o qual e são verdadeiras enquanto é falsa. Esta é uma das aplicações da tabela de verdade: determinar em quais valorações de suas subfórmulas uma fórmula é verdadeira ou falsa.
Exercícios
Seja uma linguagem na qual:
significa "Russell desenvolveu a teoria das descrições".
significa "Gödel é matemático".
significa "Está chovendo".
Formalize no CPC as seguintes proposições e faça a tabela de verdade de cada uma delas:
- "Não está chovendo".
- "Russell desenvolveu a teoria das descrições e Gödel é matemático".
- "Russell desenvolveu a teoria das descrições ou Gödel não é matemático".
- "Se Gödel é matemático, então está chovendo".
- "Se não está chovendo, então Gödel não é matemático".
- "Nem está chovendo, nem Russell desenvolveu a teoria das descrições".
- "Russell não desenvolveu a teoria das descrições se e somente se está chovendo".