2024.2 FMC1, turma de Thanos

Horários de aula: 246M56♭ [10h35–12h15]
Sala: B203
Contato:thanos@imd.ufrn.br
Playlists: ( IntroProof | IDMa | IDMb | IRI )
Monitoria/TA: fmc.imd.ufrn.br
Turmas anteriores: ..

Info

Pré-requisitos

  • É necessário que os alunos matriculados têm tempo e vontade para estudar, fazer os trabalhos atribuídos, etc.

(Obs.: estudarler.)

Veja minhas dicas para estudantes, que inclui pré-requisitos para esta disciplina.

Alunos que não aprenderam o conteúdo das disciplinas de matemática do primeiro semestre e (obviamente) do ensino médio podem consultar as referências seguintes:

(Obs.: aprenderpassar.)

  • Lang: Basic Mathematics (de uma olhada nesta playlist no YouTube que tem um curto videozinho para cada secção deste livro)
  • Lima et al: A Matemática do Ensino Médio, vol I (para esta disciplina os mais relevantes pré-requisitos são os Cap. 1–4)

Conteúdo

A disciplina FMC1 será dividida em 3 módulos–unidades. Podem considerar cada tal módulo como um componente curricular independente (e sem pré-requisitos entre si). Essa divisão é influenciada pelos módulos correspondentes à FMC1 baseados nos módulos correspondentes desta proposta.

IDMa: Elementos da teoria dos números inteiros

(Lecionado 4h/semana, durante a primeira metade do semestre.)

Axiomas sobre os inteiros (domínio de integridade bem ordenado). Demonstrações de teoremas pelos axiomas, sobre as operações e as relações de ordem nos inteiros. A relação de divisibilidade e a verificação de suas principais propriedades. Teorema de Euclides sobre infinidade de primos e sua demonstração construtiva. Lema de divisão de Euclides. Números, numerais, dígitos: demonstração que qualquer inteiro $b > 1$, serve como base para um sistema posicional de numerais para inteiros. Lema de Euclides e sua generalização. Teorema Fundamental da Aritmética. mdc e mmc e demonstrações das suas propriedades Algoritmo de Euclides: corretude e terminação Algoritmo estendido de Euclides Demonstração do teorema Fundamental de Aritmética Congruência módulo um inteiro e demonstrações das suas propriedades Aritmética modular e propriedades do ℤ/mℤ. Algumas conjecturas da teoria dos números: o teorema pequeno de Fermat; a função totiente de Euler; o teorema de Euler.

IRI: Introdução à Recursão e Indução

(Lecionado 2h/semana, durante o semestre inteiro.)

Os naturais e o tipo Nat; seus construtores (zero, sucessor) e sua teoria: implementação recursiva das suas principais operações, e verificação indutiva das suas principais propriedades. O tipo dos booleanos, Bool. Ordens sobre os naturais: especificação e verificação de suas propriedades. Outras funções e relações, e suas propriedades. Indução como princípio e técnica de demonstração em matemática. A unicidade dos naturais (a menos de isomorfismo). List Nat e List α: tipos de dados de listas: implementação recursiva e verificação indutiva de suas principais propriedades. Outros tipos de dados recursivos: tipos de árvores; tipos de expressões aritméticas; tipos de fórmulas; termos de cálculo-λ. Numerais binários, definição de semântica e seu uso para verificação de corretude.

IDMb: Elementos da teoria dos números reais

(Lecionado 4h/semana, durante a segunda metade do semestre.)

Axiomas de corpo e suas consequências. Axiomas de corpo ordenado e suas consequências. Representação geométrica. Algumas noções métricas e topológicas da reta real. Subconjuntos notáveis do ℝ: N, Z, Q. Racionais e irracionais. Conjuntos cotados, cota superior, cota inferior. Ínfimo, supremo. Seqüências e seus limites. O axioma da completude. Séries.

Objetivos de aprendizagem

IRI: Introdução à Recursão e Indução

Neste módulo estudamos como definir tipos de dados, funções, e relações recursivamente, e como demonstrar propriedades sobre tais coleções de dados por indução.

Prática com o uso da linguagem matemática e das principais técnicas de demonstração e refutação. Prática com a escrita de definições por recursão e demonstrações por indução. Recursão e indução estrutural sobre tipos de dados recursivos. Apreciação de coleções potencialmente infinitas do ponto de vista implementacional, recursivo, e verificação matemática de suas propriedades de interesse. Casamento de padrões e seu uso em definições, demonstrações, e cálculos. Recursão mútua, indução aninhada. Ganhar familiaridade com inferência de tipos e evitar erros de tipagem. Notação e nomenclatura matemática e computacional. Apreciar a diferença e a conexão entre sintaxe e semântica.

IDM: Introdução à Demonstração Matemática

Nestes módulos usamos elementos da teoria dos números inteiros (IDMa) e da teoria axiomática dos números reais (IDMb) para introduzir o aluno ao pensamento matemático e o processo de definir conceitos, enunciar e demonstrar teoremas. Aproveitamos o desenvolvimento do conteúdo concreto para chegar até os seguintes conceitos fundamentais:

  • congruência e aritmética modular (IDMa)
  • ínfimo, supremo, sequência, limite (IDMb)

Familiarizar com a linguagem usada em definições e demonstrações matemáticas: aprender ler e escrever (usar e interpretar corretamente a linguagem matemática, sua nomenclatura e notação). Apreciar a diferença entre intensional e extensional (sobre igualdades e equivalências). Uso de (meta)variáveis em matemática; ocorrência de variável ligada vs livre; α-conversão (renomeamento); substituição de variável por termos; linguagem vs metalinguagem. Introduzir o lado computacional de uma demonstração, como sequência de comandos que alteram o estado de Dados/Alvos. Entender dois lados de matemática: intuitivo e formal. Propriedades da igualdade e seu uso no raciocínio equacional. Aprender como usar e escrever cálculos dentro de uma demonstração. Apreciar a demonstração como justificativa da veracidade de proposições matemáticas (incluindo de proposições como $p\to p$, leis de distributividade, de De Morgan, frequentemente chamadas «leis» de lógica). Aprender para cada um dos ¬,⇒,∨,∧,∃,∀: como introduzi-lo e como eliminá-lo no texto de uma demonstração. Apreciar a lógica construtiva e os usos dos princípios da lógica clássica (terceiro excluído, redução ao absurdo, dupla negação, contrapositivo); apreciar a diferença entre redução ao absurdo e demonstração direta de negação. Desenvolver definições e teorias matemáticas a partir de noções primitivas e axiomas. Familiarizar com definições e demonstrações que envolvem conjuntos, sequências, funções, e relações. Ter um primeiro contato com conjuntos estruturados e estruturas algébricas e as propriedades das suas operações. Entender como e por quê os sistemas posicionais de numerais funcionam.

Bibliografia e referências

Conhece o libgen?

Principal

IRI: Introdução a Recursão e Indução

  • Bird & Wadler (1986): Introduction to Functional Programming (Cap. 1,2,3,5,9)
  • Mendelson (1973): Number Systems and the Foundations of Analysis (Cap. 2)
  • Christiansen (2023) Functional programming in Lean (Cap: 7,8)
  • Steffen, Rüthing, Huth (2018): Mathematical Foundations of Advanced Informatics, vol 1 (Cap: 4, 5)
  • Hutton (2016): Programming in Haskell, 2nd ed.
  • Pierce et al.: Software Foundations, Vol 1 (Cap: Basics, Induction, Lists)
  • Fejer, Simovici (1991): Mathematical Foundations of Computer Science, Vol 1 (Cap. 4)
  • Avigad, Leonardo de Moura, and Soonho Kong (2017): Theorem proving in Lean (Cap: 7,8)
  • Avigad, Lewis, van Doorn (2017): Logic and Proof (Cap. 17)

IDMa: Introdução à teoria dos números inteiros

  • Birkhoff & Mac Lane (1977): A Survey of Modern Algebra, 4th ed. (Cap: 1)
  • Mendelson (1973): Number Systems and the Foundations of Analysis (Cap: 3)
  • Avigad, Lewis, van Doorn (2017): Logic and Proof (Cap. 19)
  • Tao (2016): Analysis I, 3rd ed. (Cap: B1)
  • Dasgupta, Papadimitriou, Vazirani: Algorithms [DPV]

IDMb: Introdução à teoria dos números reais

  • Abbott (2015): Understanding Analysis, 2nd ed. (Cap: 1, 2, 4)
  • Mendelson (1973): Number Systems and the Foundations of Analysis (Cap: 5)
  • Rudin (1976): Principles of Mathematical Analysis, 3rd ed. (Cap: 1, 3)
  • Tao (2016): Analysis I, 3rd ed. (Cap: 6,7,9,B2)

Comum & Auxiliar

  • Avigad, de Moura, Kong (2017): Theorem proving in Lean
  • Abbott (2015): Understanding Analysis, 2nd ed. (Cap: 3)
  • Daepp, Gorkin (2011): Reading, Writing, and Proving, 2nd ed.
  • Devlin (2012): Introduction to Mathematical Thinking (Cap: 4)
  • Spivak (2008): Calculus, 4th ed. (Cap: 1)

Para cada um dos assuntos que tratamos, procure também a secção «Leitura complementar» no capítulo correspondente do fmcbook para mais referências.

Dicas

Veja minha página de dicas para estudantes.

Links

Tecnologias & ferramentas

Obs.: As tecnologías/ferramentas seguintes podem mudar durante a disciplina—exceto a primeira. (Instalem e/ou criem uma conta para usar onde necessário.)

  1. PAPEL (um caderno para dedicar à disciplina) e LAPIS/CANETA.
  2. Zulip (leia o FAQ).
  3. O proof assistant Lean para algumas atividades (leia o FAQ).
  4. A linguagem de programação funcional Lean para algumas atividades.
  5. A linguagem de programação funcional Haskell para algumas atividades.
  6. Git (leia o FAQ).
  7. Muito recomendado mas não necessário: um sistema Unix (veja o minicurso Unix 2019.2).
  8. Muito recomendado mas não necessário: (neo)vim e Emacs (alternativa popular: VS Code).
  9. Pouco de (La)TeX (veja o minicurso TeX 2018.2). Online editor/compilador: Overleaf.

O módulo IRI será auxiliado pelo uso da linguagem de programação funcional Lean e Haskell (e talvez Agda), e pelo proof assistant Lean. Usando uma linguagem de programação funcional é imediato implementar todas as suas definições para rodá-las no computador. Usando um proof assistant, formalizamos tanto as definições recursivas, quanto as demonstrações indutivas usando a mesma linguagem. (Mas o foco continua sendo o papel; não o computador!)

O módulo IDMa será auxiliado pelo uso do proof assistant Lean.

O módulo IDMb não será auxiliado por nenhum proof assistant. Ficará só no papel mesmo. (Dependendo do progresso no início do semestre, isso pode mudar.)

Regras

  1. Nunca escreva ou diga algo que você mesmo não sabe explicar: (i) o que significa; (ii) seu papel na tua resolução. Por exemplo: um aluno escreveu a frase seguinte na sua demonstração: «Como f é cancelável pela esquerda temos que g=h». Ele deve saber o que significa ser cancelável pela esquerda e também explicar como isso foi usado e/ou o que isso tem a ver com essa parte da sua demonstração.
  2. Qualquer trabalho ou resposta dada poderá ser questionado em forma de prova oral, em modo privado ou aberto. Se um aluno não consegue explicar o que ele mesmo escreveu numa resolução, será considerado plágio (veja abaixo).
  3. Participando, nunca dê uma resposta que tu não pensou sozinho, exceto dando os devidos créditos correspodentes.
  4. Não tente “forçar a barra” perguntando ou respondendo coisas aleatórias com objetivo de ganhar pontos. Os pontos de participação não correspondem em apenas perguntas ou dúvidas que mostram interesse. O interesse é implícito pelo fato que tu escolheu matricular nesta turma—não vale pontos.
  5. Não procurem resoluções em qualquer lugar fora dos indicados em cada homework. O único recurso automaticamente aceitável para procurar ajuda é no nosso Zulip (especificamente seus canáis públicos—não DM) e a monitoria.
  6. Proibido consultar o apêndice de resoluções do fmcbook durante a disciplina exceto quando for explicitamente permitido por mim. (Os apêndices de dicas são permitidos sim!)

Uns deveres dos alunos

  1. Visitar este site e o Zulip da disciplina pelo menos uma vez por dia durante o semestre. (Qualquer coisa postada no site ou no Zulip da disciplina será considerada como conhecida por todos os alunos da turma.)
  2. Estudar o conteúdo lecionado e tentar resolver todos os trabalhos atribuidos.
  3. Participar no Zulip diariamente, compartilhando tuas resoluções para receber feedback, e checando as resoluções de outros colegas para dar feedback.
  4. Checar e atender seu email cadastrado no SIGAA pelo menos uma vez por dia durante o semestre.
  5. Participar nas aulas! Obs.: tendo uma dúvida durante a aula, levante a mão para solicitar “a fala” e assim que a receber, pergunte! Não espere o fim da aula para discutir tua dúvida em “modo particular”! A maioria das vezes eu vou negar isso e pedir ao aluno iniciar a discussão no Zulip ou na próxima aula.
  6. Participar nas aulas de exercícios de monitoria e utilizar seus horários de atendimento para tirar dúvidas.

(Veja também os FAQs relevantes.)

Sobre plágio

  1. Plágio detectado implica que o aluno será reprovado na disciplina imediatamente por nota e por faltas.
  2. Entregar tuas resoluções para um aluno copiar é proibido do mesmo jeito, e também não ajuda mesmo ninguém.

Cadernos vs. celulares

Não faz sentido aparecer na aula sem caderno. E não faz sentido aparecer na aula com celular ligado; bote no modo avião antes de entrar na sala. As aulas são interativas e se não pretende participar e concentrar nesses 100 minutos, sugiro ficar fora e escolher uma outra maneira de passar teu tempo. Não é necessário (e obviamente nem suficiente) aparecer nas minhas aulas para passar.

Avaliação e faltas

Disclaimer. Eu suponho que os alunos desta turma escolheram se matricular por interesse em aprender seu conteúdo. O ideal seria ignorar assuntos irrelevantes de avaliação, presenças, carga horária, etc., e se jogar nos estudos e nas brigas (nas aulas, no Zulip, e na monitoria).

Avaliação

A nota final de cada aluno vai ser principalmente baseada em um ou mais dos: (i) provas escritas; (ii) sua participação; (iii) trabalhos atribuidos; (iv) hw resolvidos (veja o FAQ relevante).

Cada aluno será responsável para manter organizado e bem escrito o seu caderno com todos os teoremas e exercícios que estudou durante a disciplina.

Presenças e faltas

A presença pela regulação da UFRN é obrigatória. Os alunos que não gostam/querem/podem aparecer nas minhas aulas ainda têm chances de ganhar até nota máxima e aprovar na disciplina. Ou seja: alunos que escolhem não participar ou aparecer nas aulas, e mesmo assim aparecem nas provas escritas e conseguem nota final de aprovação vão ter sua porcentagem de faltas ajustada para não reprovar por faltas. Esclarecimento: alunos que não conseguem nota final de aprovação não terão sua porcentagem de presença ajustada de jeito nenhum e por nenhum motivo.

Obviamente, alunos que não aparecem nas aulas não terão como ganhar pontos de participação em aula—duh!—nem pontos de possíveis provas-surpresas.

As presenças/faltas serão cadastradas usando o sistema Plickers (veja o FAQ relevante).

Atrasados

Definição (atrasado). Seja $a$ aluno desta turma. Dizemos que $a$ é atrasado sse $a$ não está já sentado na sua mesa, com seu caderno já aberto, seu celular já desligado e na mochila, no momento que a aula começa.

Tentem estar presentes na sala da aula ANTES do horário do seu começo, e fiquem até o fim da aula.

Caso que alguém chega atrasado: não faz sentido bater na porta da sala de aula; não faz sentido cumprimentar nem o professor (não é mostra educação cumprimentar nesse caso—pelo contrário!) nem os amigos/colegas da aula. Entrando numa sala onde a aula já começou, tentem fazer sua entrada o menos possível notada por os participantes pois atrapalha a concentração de todos.

FAQs

Dynamic content

Pontos de participação

Provas

Provas surpresa. Note que em qualquer aula pode ter prova surpresa, cujos pontos são considerados «pontos extra», assim sendo possível tirar nota máxima (100), mesmo perdendo todas as provas surpresas.

Provas não-surpresa. Tais provas serão avisadas com curtíssima antecedência (de pelo menos 16h). A melhor maneira de lidar com isso é tratar todo dia de aula como possível dia de prova.

U1 (IDMa)

U2 (IRI)

U3 (IDMb)

U3 (IDMb)

  • Prova IDMb.1 / 100pts (2025-01-24) { censored , uncensored , answers , correções }

Homework (HW)

Leia bem o FAQ sobre hw. Note também que:

  • Homeworks são atribuidos também durante as aulas e no Zulip.
  • Homeworks marcados assim são auxiliares; tente apenas se tu tem resolvido uma parte satisfatória dos outros.

2024-09-18: IntroProof (hw1)

  1. Capítulo 1
  2. Para cada um dos ¬,⇒,&,ou,⇔,∀,∃,= pense como que pode ser usado (sendo nos DADOS) ou atacado (sendo no ALVO). Escreva os comandos correspondentes e para cada um deles, esclareça: qual é o efeito no tabuleiro da demonstração (tanto na parte dos DADOS quanto no ALVO), como e quando é que tal comando pode ser executado.

2024-09-22: IntroProof (hw2)

  1. Capítulo 2: até o primeiro intervalo de problemas
  2. Para cada uma das proposições seguintes tente demonstrar escrevendo na linguagem de demonstrações que elaboramos nas aulas até agora. Se travar em algum sem conseguir fechar, mostre teu progresso no zulip e peça ajuda; enquanto isso, continua para a próxima!
    1. Proposições de dupla negaço:
      1. P ⇒ ¬¬P
      2. ¬¬P ⇒ P
    2. Comutatividade dos ∨,∧:
      1. (P ∨ Q) ⇒ (Q ∨ P)
      2. (P ∧ Q) ⇒ (Q ∧ P)
    3. Proposições de interdefinabilidade dos ⇒,∨:
      1. (P ⇒ Q) ⇒ (¬P ∨ Q)
      2. (P ⇒ Q) ⇐ (¬P ∨ Q)
      3. (P ∨ Q) ⇒ (¬P ⇒ Q)
      4. (P ∨ Q) ⇐ (¬P ⇒ Q)
    4. Proposições de contraposição:
      1. (P ⇒ Q) ⇒ (¬Q ⇒ ¬P)
      2. (¬Q ⇒ ¬P) ⇒ (P ⇒ Q)
    5. A irrefutabilidade do LEM:
      1. ¬¬(P∨¬P)
    6. A lei de Peirce e sua versão “fraca”:
      1. ((P ⇒ Q) ⇒ P) ⇒ P
      2. ((P ⇒ Q) ⇒ P) ⇒ ¬¬P
    7. Proposições de interdefinabilidade dos ∨,∧:
      1. P∨Q ⇒ ¬(¬P∧¬Q)
      2. P∨Q ⇐ ¬(¬P∧¬Q)
      3. P∧Q ⇒ ¬(¬P∨¬Q)
      4. P∧Q ⇐ ¬(¬P∨¬Q)
    8. As leis de De Morgan para ∨,∧:
      1. ¬(P∨Q) ⇒ (¬P ∧ ¬Q)
      2. ¬(P∨Q) ⇐ (¬P ∧ ¬Q)
      3. ¬(P∧Q) ⇒ (¬Q ∨ ¬P)
      4. ¬(P∧Q) ⇐ (¬Q ∨ ¬P)
    9. Proposições de distributividade dos ∨,∧:
      1. P∧(Q∨R) ⇒ (P∧Q)∨(P∧R)
      2. P∧(Q∨R) ⇐ (P∧Q)∨(P∧R)
      3. P∨(Q∧R) ⇒ (P∨Q)∧(P∨R)
      4. P∨(Q∧R) ⇐ (P∨Q)∧(P∨R)
    10. Currificação
      1. ((P∧Q)⇒R) ⇒ (P⇒(Q⇒R))
      2. ((P∧Q)⇒R) ⇐ (P⇒(Q⇒R))
    11. Reflexividade da ⇒:
      1. P ⇒ P
    12. Weakening and contraction:
      1. P ⇒ (P∨Q)
      2. Q ⇒ (P∨Q)
      3. (P∧Q) ⇒ P
      4. (P∧Q) ⇒ Q
      5. P ⇒ (P∧P)
      6. (P∨P) ⇒ P
    13. As leis de De Morgan para ∃,∀:
      1. ¬(∀x)[φ(x)] ⇒ (∃x)[¬φ(x)]
      2. ¬(∀x)[φ(x)] ⇐ (∃x)[¬φ(x)]
      3. ¬(∃x)[φ(x)] ⇒ (∀x)[¬φ(x)]
      4. ¬(∃x)[φ(x)] ⇐ (∀x)[¬φ(x)]
    14. Proposições de interdefinabilidade dos ∃,∀:
      1. (∃x)[φ(x)] ⇒ ¬(∀x)[¬φ(x)]
      2. (∃x)[φ(x)] ⇐ ¬(∀x)[¬φ(x)]
      3. (∀x)[φ(x)] ⇒ ¬(∃x)[¬φ(x)]
      4. (∀x)[φ(x)] ⇐ ¬(∃x)[¬φ(x)]
    15. Proposições de distributividade de quantificadores:
      1. (∃x)[φ(x) ∧ ψ(x)] ⇒ (∃x)[φ(x)] ∧ (∃x)[ψ(x)]
      2. (∃x)[φ(x) ∧ ψ(x)] ⇐ (∃x)[φ(x)] ∧ (∃x)[ψ(x)]
      3. (∃x)[φ(x) ∨ ψ(x)] ⇒ (∃x)[φ(x)] ∨ (∃x)[ψ(x)]
      4. (∃x)[φ(x) ∨ ψ(x)] ⇐ (∃x)[φ(x)] ∨ (∃x)[ψ(x)]
      5. (∀x)[φ(x) ∧ ψ(x)] ⇒ (∀x)[φ(x)] ∧ (∀x)[ψ(x)]
      6. (∀x)[φ(x) ∧ ψ(x)] ⇐ (∀x)[φ(x)] ∧ (∀x)[ψ(x)]
      7. (∀x)[φ(x) ∨ ψ(x)] ⇒ (∀x)[φ(x)] ∨ (∀x)[ψ(x)]
      8. (∀x)[φ(x) ∨ ψ(x)] ⇐ (∀x)[φ(x)] ∨ (∀x)[ψ(x)]

2024-09-27: IntroProof (hw3)

  1. Mostre que, tendo qualquer um dos 3 comandos “mágicos” (LEM, RAA, Contrapositive), consegue inferir os outros dois assim os ganhando como açúcares sintácticos sem precisar tê-los como comandos primitivos no sistema.
  2. Volte às proposições que não conseguiu demonstrar, mas essa vez use ⛤: LEM, RAA, Contrapositive. Conseguindo fechar, altere o enunciado para ficar mais honesto (e fraco) mas compilável sem ⛤.

2024-09-30: IDMa (hw1)

  1. Demonstre (nos ? precisa enunciar também)
    1. (+)-id: (∀x)[ 0+x = x & x+0 = x ]
    2. (+)-inv: ?
    3. (·)-id: ?
    4. (+)-id-!: ? (unicidade de (+)-identidade)
    5. (·)-id-!: ?
    6. (+)-inv-!: ?
    7. (+)-canR: (∀c,x,y)[ x + c = y + c ⇒ x = y ]
    8. (+)-canL: ?
    9. (·)-can: ?
    10. (+)-ann-0: (∀x)[ 0·x = 0 & x·0 = 0 ]
    11. (+),(·)-distR: (∀x,y,d)[ (x+y)d = xd + yd ]
    12. neg-1: (∀x)[x·(-1) = ?]
    13. neg-0: ?
    14. neg-neg: (∀x)[-(-x) = ?]
    15. neg-(+): ?
    16. neg-(·): ?

2024-10-03: IRI (hw1)

  1. Defina (sem consulta) a adição, a multiplicação, e a exponenciação (nos Nats).
  2. Calcule os:
    1. 2 + 3
    2. 3 + 2
    3. um dos: 4 · 1; 1 · 4
  3. Defina uma função double que retorna o dobro da sua entrada.
  4. Calcule os:
    1. double (double (S O))
    2. double ((S O) + (S (S O)))
  5. Demonstre uma das: (·)-idL, (·)-idR
  6. Demonstre uma das: (^)-idL, (^)-idR
  7. Defina a função pred : Nat → Nat de “predecessor”, onde consideramos que o predecessor de zero é o próprio zero mesmo: AVISO: a maioria das vezes que um aluno de 2022.1 e de 2022.2 usou a pred em outras definições, estava errando
  8. Defina as funções:
    1. fact : Nat → Nat
    2. fib  : Nat → Nat
    3. min  : Nat × Nat → Nat
    4. max  : Nat × Nat → Nat
    5. div  : Nat × Nat → Nat × Nat
    6. quot : Nat × Nat → Nat
    7. rem  : Nat × Nat → Nat
    8. gcd  : Nat × Nat → Nat
    9. lcm  : Nat × Nat → Nat

2024-10-07: IDMa (hw2)

  1. Instale Lean e Haskell no teu computador (veja o FAQ de instalações).
  2. Demonstre?:
    1. (·),(+)-distr: ?
    2. (+)-res: ?
    3. (·)-res: ?
    4. (·)-can∗: ?
    5. nzd: (∀a,b)[ ab = 0 ⇒ a = 0 ou b = 0 ]

2024-10-08: IRI (hw2)

  1. Jogue (complete) o nng. (Recomendo trabalhar no «editor mode» (botão na top-right corner do jogo).)

2024-10-11: IDMa (hw3)

  1. Cap «Os interios»: §«Primeiros passos»
  2. Demonstre, ainda com os 8 primeiros axiomas (4 aditivos, 3 multiplicativos, e a distributividade) a equivalência: nzd ⊣⊢ (·)-can*R

2024-10-11: IRI (hw3)

  1. Cap «Recursão; Indução»: até a §«Demonstrando propriedades de naturais sem indução»

2024-10-14: IDMa (hw4)

  1. Cap «Os inteiros»: até a §«Conjuntos fechados sob operações»

2024-10-16: IRI (hw4)

  1. Cap «Recursão; Indução»: até a §«Por que aceitar o princípio da indução?»

2024-10-18: IDMa (hw4)

  1. Resolva tudo que não resolveu na Prova IDMa.1.

2024-10-21: IDMa (hw5)

  1. Cap «Inteiros»: até o §«Mínima e máxima»

2024-10-24: IDMa (hw6)

  1. Cap «Inteiros»: até o primeiro intervalo de problemas

2024-11-18: IDMa (hw7)

  1. Cap «Inteiros»: até a §«Melhor divisor comum»

2024-11-25: IRI (hw5)

  1. Implemente como novo tipos, tendo já definido o Nat:
    1. os parzinhos-de-Nats
    2. listas-finitas-de-Nats como Nat
  2. Defina as:
    1. length      : List α → Nat
    2. elem        : Nat → List Nat → Bool
    3. sum         : List Nat → Nat
    4. product     : List Nat → Nat
    5. (⧺)         : List Nat → List Nat → List Nat
    6. reverse     : List α → List α
    7. min         : Nat → Nat → Nat
    8. max         : Nat → Nat → Nat
    9. allEven     : List Nat → Bool
    10. anyEven     : List Nat → Bool
    11. allOdd      : List Nat → Bool
    12. anyOdd      : List Nat → Bool
    13. allZero     : List Nat → Bool
    14. anyZero     : List Nat → Bool
    15. addNat      : Nat → List Nat → List Nat
    16. multNat     : Nat → List Nat → List Nat
    17. expNat      : Nat → List Nat → List Nat
    18. enumFromTo  : Nat → Nat → List Nat
    19. enumTo      : Nat → List Nat
    20. take        : Nat → List α → List α
    21. drop        : Nat → List α → List α
    22. elemIndices : α → List α → List Nat
    23. pwAdd       : List Nat → List Nat → List Nat
    24. pwMult      : List Nat → List Nat → List Nat
    25. isSorted    : List Nat → Bool
    26. filterEven  : List Nat → List Nat
    27. filterOdd   : List Nat → List Nat
    28. minimum     : List Nat ⇀ Nat
    29. maximum     : List Nat ⇀ Nat
    30. isPrefixOf  : List Nat → List Nat → Bool
    31. mix         : List α → List α → List α
    32. intersperse : α → List α → List α
  3. Defina as:
    1. head        : List α → α
    2. tail        : List α → List α
    3. init        : List α → List α
    4. last        : List α → α
  4. Demonstre os teoremas (escolhe algo interessante para botar nos ??)
    1. (∀xs,ys:ListNat)        [ sum (xs ⧺ ys) = ?? ]
    2. (∀xs,ys:ListNat)        [ product (xs ⧺ ys) = ?? ]
    3. (∀ℓ:ListNat)            [ length (filterEven ℓ ⧺ filterOdd ℓ) = ?? ]
    4. (∀ℓ:ListNat)            [ reverse (filterEven ℓ) = ?? ]
    5. (∀n:Nat)(∀ℓ:ListNat)    [ length (addNat n ℓ) = ?? ]
    6. (∀n:Nat)(∀ℓ:ListNat)    [ sum (addNat n ℓ) = ?? ]
    7. (∀n:Nat)(∀ℓ:ListNat)    [ sum (multNat n ℓ) = ?? ]
    8. (∀n:Nat)(∀ℓ:ListNat)    [ product (multNat n ℓ) = ?? ]
    9. (∀n:Nat)(∀ℓ:ListNat)    [ product (expNat n ℓ) = ?? ]
    10. (∀n:Nat)(∀ℓ:ListNat)    [ isSorted (addNat n ℓ) = ?? ]
    11. (∀ℓ:ListNat)            [ isEven (product ℓ) = anyEven ℓ ]
    12. (∀ℓ:ListNat)            [ isEven (sum ℓ) = isEven (length (filterOdd ℓ)) ]
    13. (∀ℓ:ListNat)            [ isZero (sum ℓ) = ?? ]
    14. (∀ℓ:ListNat)            [ isZero (product ℓ) = ?? ]
    15. (∀n,m:Nat)(∀ℓ:List Nat) [ addNat (n + m) ℓ = ?? ]
    16. (∀n,m:Nat)(∀ℓ:List Nat) [ multNat (n · m) ℓ = ?? ]
  5. Demonstre também:
    1. (∀xs,ys:ListNat)        [ length (xs ⧺ ys) = ?? ]
    2. (∀xs,ys:ListNat)        [ reverse (xs ⧺ ys) = ?? ]
    3. (∀n:Nat)(∀xs,ys:ListNat)[ addNat n (xs ⧺ ys) = ?? ]
    4. (∀ℓ:ListNat)            [ reverse (reverse ℓ) = ?? ]
    5. (∀ℓ:ListNat)            [ length (reverse ℓ) = ?? ]
    6. Associatividade da (⧺)
    7. [] é uma (⧺)-identidade
  6. Pense em mais propriedades, enuncie, e demonstre!

2024-11-27: IDMa (hw8)

  1. Resolva em condições de prova as provas seguintes:
    1. Prova 2.X de 2019.2
    2. Prova 2.Y de 2019.2
    3. Prova 2.Z de 2019.2
  2. Resolva em condições tranqüilas as mesmas provas.
  3. Escreva sozinho a definição de m.d.c.
  4. Troque o que precisa trocar para virar a definição de mínimo.
  5. Troque o que precisa trocar para virar a definição de máximo.
  6. Troque o que precisa trocar para virar a definição de m.m.c.
  7. Dados inteiros a,b, demonstre a existência dum m.d.c. deles, e mostre que ele pode ser escrito como combinação linear dos a,b.
  8. Demonstre as propriedades básicas dum m.d.c., que denotamos aqui simplesmente por (_,_), exceto uma, que é refutável (e logo refute e depois obviamente tente a ajustar para virar demonstrável, e demonstre–phew!):
    1. (a,b) = (a,-b) = (-a,b) = (-a,-b)
    2. (a,a) = ?
    3. (a,0) = ?
    4. (a,1) = ?
    5. (a,b) = (b,a)
    6. ((a,b),c) = ?
    7. (a,b) = (a, a + b)
    8. (a,b) = (a, a - b)
    9. (ca,cb) = c(a,b)
    10. (uv,a) = (u,a)(v,a)
    11. (a,b) = (b, rem(a,b))
  9. Demonstre: Invertible(x) ⇔ Unit(x)
  10. Demonstre: Irreducible(x) ⇔ Prime(x)
  11. Demonstre ou refute: para quaisquer primos distintos p,q, pq | n² ⇒ pq | n.
  12. 🚀 Bora viajar legal!
    1. Num universo de conjuntos (por exemplo no Set(Int)) considere a mesma definição de m.d.c., mas essa vez usando como guia a ordem de (⊆). Qual conceito definiu? O que acontece se virar as direções? (⊇).
    2. Tendo P, Q : Prop, escrevemos P ⊢ Q para a (meta)proposição «Dado a P, podemos demonstrar a Q.». No universo de proposições, mostre que (⊢) é uma pré-ordem. Qual seria o “m.d.c.” de duas props, e qual o “m.m.c” delas?

2024-12-06: IDMa (hw9)

  1. Cap «Inteiros»: até o terceiro intervalo de problemas

2024-12-10: IDMa (hw10)

  1. Investiga a aritmética dos planetas 1–6:
    1. Completa as tabelas de adição e de multiplicação.
    2. Para quais deles temos: (·)-inversos, (+)-inversos, (·)-cancelamento, (·)-inversos, zerodivisores, resoluções únicas
    3. Os inversos (quando tem) são únicos?

2024-12-16: IRI (hw6)

  1. Defina as:
    • replicate  : Nat → α → List α
    • map        : (α → β) → List α → List β
    • filter     : (α → Bool) → List α → List α
    • a generalização all das: allZero, allEven, allOdd
    • a generalização any das: anyZero, anyEven, anyOdd
    • a generalização pointwise das: pwAdd, pwMult
    • a generalização fold das: sum, product, and, or, concat
    • simplifique as definições antigas para aproveitar essas funções poderosas
    • takeWhile   : (α → Bool) → List α → List α
    • dropWhile   : (α → Bool) → List α → List α
    • head        : List α → Maybe α
    • tail        : List α → Maybe (List α)
    • init        : List α → Maybe (List α)
    • last        : List α → Maybe α
    • pick        : Nat → List α → Maybe α
    • findFirst   : α → List α → Maybe Nat
    • find        : α → List α → List Nat
    • curry       : ?
    • uncurry     : ?
    • flip        : ?
  2. Qual seria uma melhor tipágem para a pw : (α → α → α) → List α → List α → List α?

2025-01-08: IDMa (hw11)

  1. Capítulo «os Inteiros»: §«Sistémas de resíduos»; §«Euler entra»; o intervalo de problemas logo depois

2025-01-10: IDMb (hw1)

  1. Capítulo «os Reais»: ate §«Mínima e máxima»

2025-01-13: IDMa (hw11)

  1. Capítulo «os Inteiros»: Tudo até o último intervalo de problemas.

2025-01-14: IRI (hw7)

  1. Resolva tudo que consegues da prova 2.1 de Programação Funcional 2024.2

2025-01-15

  1. Lembrete: há HWs (= cor rosa) nos quadros das aulas (IDMa/IRI/IDMb)!

2025-01-20: IDMb (hw2)

  1. Até o §«Uniões e interseções»

Histórico

Quadros das aulas

2024-09-16: Meta & IntroProof (1)

  • Overview
  • tipos e type errors
  • intensão vs extensão
  • (=) vs (≡)
  • type inference
  • Os construtores de tipos (→) e (×)
  • diss valores-de-verdade
  • açúcar sintáctico

2024-09-18: IntroProof (2)

  • umas definições bugadas de «_ é par»
  • duas maneiras que uma definição pode ser errada
  • REPLs e demonstrações
  • proposiões vs objetos
  • Prop vs Bool
  • juízos (judgements) vs proposições
  • comandos vs proposições
  • Exemplos de teoremas e seus tabuleiros (estados) iniciais
  • Dados e Alvo
  • construtores de props e seus tipos
  • os ¬,⇒,⇔,&,ou,∀,∃,=
  • (∃): como usar
  • variáveis frescas e nomes bons
  • ocorrência de variável ligada e livre

2024-09-20: IntroProof (3)

  • (∀): como atacar
  • (⇒): como atacar
  • (∃): como usar
  • (ou): como atacar
  • (&): como usar
  • (=): como usar (substituição)
  • contra o poeminha: «não podes supor seu próprio alvo»
  • nomes bons e bairros
  • mais açúcar sintáctico (Sejam …, (∀,,)[…])
  • precedências entre (⇒),(&),(ou)

2024-09-23: IntroProof (4)

  • o resto dos conectivos para nossa linguagem de demonstrações
  • os ⇒,&,ou,∀,∃,=,⊥ como primitivos
  • os ⇔,¬,⇐ como açúcar sintáctico
  • como usar e como atacar (cada um dos conectivos)
  • quando e como aceitar uma suposta “lei de lógica”
  • conexões entre ataques/usos de disjunção/conjunção e usos/ataques de conjunção/disjunção
  • conexões entre disjunção/conjunção e quantificação existencial/universal
  • conexões entre implicação e quantificação universal
  • umas “leis de lógica” e como demonstrá-las
  • a linguagem low-level
  • o «xou»

2024-09-25: IntroProof (5)

2024-09-27: IntroProof (6)

  • Vou demonstrar _.
  • Θ. a irrefutabilidade do LEM
  • magias ⛤
  • LEM
  • RAA
  • Contrapositiva
  • a briga Brouwer vs Hilbert

2024-09-30: IDMa (1)

  • Convenção sobre (∀)[…]
  • «_ é um _-inverso de _» e predicados similares
  • Igualdade: refl, sym, trans, subst/repl
  • refl e subst são suficientes para inferir as sym e trans
  • Θ. (+)-idL
  • Calculamos: notação, efeitos, convenções

2024-10-02: IRI (1)

IntroProof

  • IntroProof: existência e unicidade
  • IntroProof: (∃!x:α)[φ(x)] como açúcar sintáctico
  • IntroProof: $\exists_{\geq n} x : \alpha)[ \varphi(x) ]$
  • IntroProof: $\exists_{\leq n} x : \alpha)[ \varphi(x) ]$
  • IntroProof: definição vs especificação: Nat de IRI vs Int de IDMa
  • IntroProof: números vs numerais
  • 4 maneiras de definir o tipo de dados Nat
  • casamento de padrões
  • notação de cálculos e suas justificativas
  • 2 + 3 = 5
  • 2 + 3 ≢ 3 + 2

2024-10-04: IDMa (2)

  • IntroProof: (≝) vs (=)
  • funções anônimas
  • muitos teoremas parecidos e como demonstrá-los
  • (+)-id vs (+)-id-0
  • currificação teaser: α×β→γ vs α→β→γ
  • duas maneiras de demonstrar o (+)-canR
  • como justificar o «aplique a (+ (-c)) nos dois lados»

2024-10-07: IDMa (3)

  • IntroProof: açúcar: (∀x legal)[φ(x)] e (∃x legal)[φ(x)]
  • IntroProof: zoom-in/out de modo rua para modo formal e vice-versa
  • IntroProof: DRY: não re-demonstre as mesmas idéias em novas demonstrações
  • (·)-canR*: 3 intensões
  • subtração como operação definida: _-_ : Int × Int → Int
  • mais uma convenção sintáctica: justaposição
  • mundo aditivo vs mundo aplicativo
  • necessidade de algum axioma os conectando
  • specification update: (·),(+)-distrR
  • 3 proposições difíceis de demonstrar
    • (·)-annR-0
    • (·)-canR∗
    • nzd
  • Θ. (·)-annR-0

2024-10-09: IRI (2)

  • pattern-matching com match-with expressions
  • definição da (·)
  • especificação vs implementação: por que não podemos considerar o (+)-ass como axioma aqui
  • tentativa sem sucesso: demonstrar o (+)-ass
  • dois princípios sobre construtores
  • lazy vs strict evaluation

2024-10-11: IRI (3); IDMa (3⁺)

  • buraquizando subexpressões
  • limitações da notação de buracos
  • a notação ↦
  • a notação λ
  • currificação
  • nzd e (·)-can*R: axiomas ou teoremas?

2024-10-14: IDMa (4)

  • terminologia de ordens
  • D. (|) : Int × Int → Prop
  • divide, mede, é multiplo de, é (|)-maior de, é (|)-menor de, …
  • Θ. (|)-refl
  • Θ. (|)-trans
  • Θ. (|)-bottom-1
  • Θ. (|)-top-0
  • maneiras alternativas de rotular dados
  • criando dados on the fly
  • «pela escolha de»
  • notação de conjuntos; set comprehension
  • conjunto fechado sobre operação binária
  • novamente: os açúcares (∀x∈A)[φ(x)] e (∃x∈A)[φ(x)]

2024-10-16: IRI (4)

  • Indução
  • O comando Por indução.
  • 3 demonstrações da associatividade da (+)
  • Indução como regra de inferência
  • Base & Passo indutivo como regras de inferência

2024-10-18: IDMa (5⁻); Prova IDMa.1

  • Conjuntos e sua notação, incluindo o set builder (comprehension)
  • gerador x ∈ A vs proposição x ∈ A
  • Prova IDMa.1

2024-10-21: IDMa (5)

  • Set : Type → Type
  • Positividade e ordem, e sua “equivalência”
  • Especificação de inteiros v3/?: Pos & seus axiomas
  • Θ. (∀a ≠ 0)[ a² positivo ]
  • Θ?. 1 é positivo

2024-10-23: IDMa (6); IRI (5)

  • 0≠1?
  • (Meta)demonstrando a não-demonstrabilidade e a não-refutabilidade de proposições
  • Inteiros, especificação v4/?
  • Entendendo o princípio da indução em mais uma forma
  • Os construtores preservam/respeitam uma propriedade
  • teoremas sobre Nats, suas operações, e suas relações principais
  • implementando as ev e od
  • Não abusarás tipos e seus habitantes.
  • reimplementando as ev e od
  • O tipo Bool

2024-10-25: IDMa (7)

  • valor absoluto
  • mínima e máxima
  • unicidade de mínimo de conjunto
  • valor absoluto

2024-10-30: IRI (6)

  • Internalização de conceitos
  • Corretude (soundess and completeness)
  • leq : Nat → Nat → Bool
  • eq : Nat → Nat → Bool
  • 3 maneiras diferentes de implementar os ev e od
  • Recursão mútua
  • O tipo ListNat

2024-11-01: IRI (7)

  • List : Type → Type
  • length, sum, prod
  • abstraindo de doubles e triples para mults e para map

2024-11-04: IDMa (8)

  • Especificação de inteiros (v5/5)
  • O princípio da indução
  • O princípio da boa ordem

2024-11-06: IRI (8)

  • recursão/indução de ListNat
  • presentes de recursão
  • index : Nat → ListNat → Nat
  • head, last : ListNat → Nat
  • init, tail : ListNat → ListNat
  • Θ. (∀f : Nat → Nat)(∀ℓ : ListNat)[ length (map f ℓ) = length ℓ ]

2024-11-08: IDMa (9)

  • Justificando versões de indução nos inteiros
  • Indução «a partir de c»
  • Indução para os negativos
  • Indução para os pares
  • Indução com b bases
  • Indução forte

2024-11-11: IRI (9)

  • Tentativas de implementar os inteiros
  • Polimorfismo
  • de ListNat para List α

2024-11-13: IDMa (10)

  • PBO e versões inferíveis
  • Como usar o PBO na prática
  • Θ. ¬(∃x)[ 0 < x < 1 ]
  • Wishlist

2024-11-18: IDMa (11)

  • Sistemas posicionais de numerais
  • Θ. Divisão (de Euclides)
  • mdc: melhor divisor comum
  • Desenhando a (|) no $\mathbb Z_{\geq 0}$

2024-11-22: IDMa (12)

  • Desenhando a (|) nos inteiros
  • Vocabulário: associados, invertíveis, unidades, irredutíveis, primos
  • Propriedades da (|)
  • Desenhar a busca de mdc
  • mais 3 teoremas de Euclides:
    • infinitude dos irredutíveis
    • irredutível ⇔ primo
    • existência de mdc

2024-11-25: IRI (10)

  • Recursão e indução em listas
  • (⧺) : L α → L α → L α
  • Θ. sum (xs ⧺ ys) = sum xs + sum ys

2024-11-27: IDMa (13)

  • existência de mdc
  • conjuntos fechados sob operações
  • membros arbitrários
  • propriedades de mdc
  • algoritmo de Euclides para mdc

2024-11-29: IDMa (14)

  • Θ. (a,b) = (b,r)
  • teorema de existência mdc (com PBO)
  • teorema de existência mdc (de Euclides)
  • algoritmo de Euclides para mdc
  • corretude e terminação
  • eficiência: criança-BR vs euclides
  • Lemma de Euclides: p irredutível ⇒ p primo

2024-12-02: IRI (11)

  • abstraindo
  • pw (pointwise)
  • fold
  • let-in expressions

2024-12-04: IDMa (15)

  • Teorema de Euclides (infinidade de irredutíveis)
  • Teorema Fundamental de Aritmética

2024-12-06: IDMa (16)

  • Logaritmos
  • Θ. Sistemas posicionais de numerais
  • Somatórios e produtórios, notação Σ–Π
  • Lemmas spoilerosos de irracionalidades

2024-12-09: IDMa (17)

  • comb(r,n): definição
  • Teorema binomial
  • “planetas” e aritmética modular

2024-12-11: IDMa (18)

  • tabelas de operações
  • planetas com zerodivisores
  • planetas sem (·)-cancelamento*
  • congruência modulo um inteiro
  • (≡ₘ) é uma congruência
  • compatibilidade com operações
  • o planeta 0

2024-12-13: IDMa (19)

  • invertibilidade modulo m
  • critéria de divisibilidade

2024-12-16: IRI (12)

  • a verdadeira cara do void da C
  • a verdadeira interpretação da f() da C
  • o tipo Unit (𝟙)
  • o tipo Empty (𝟘)
  • funções saindo e entrando de 𝟙
  • funções saindo e entrando de 𝟘
  • teaser: aritmética de tipos
  • Maybe α
  • Either α β
  • soma de tipos
  • billion dollar mistake

2024-12-18: IDMa (20)

  • exponenciação modulo m
  • Θ. Sonho do calouro
  • Θ. Fermatinho
  • Sistemas (completos e reduzidos) de resíduos

2024-12-20: Prova IRI.1

2025-01-08: IDMa (21); IDMb (1)

  • Recap
  • Mais sobre sistemas de resíduos
  • Equinumerosidade de conjuntos
  • A função totiente de Euler (φ)
  • Θ. (Euler): enunciado
  • Os racionais
  • FTA de inteiros para racionais
  • Θ. Há irracionais

2025-01-10: IDMb (2)

  • Especificação dos reais (1/3): parte algébrica (aditiva e multiplicativa)
  • açúcar sintáctico
  • primeiros teoremas/conseqüências
  • tipos dependentes: tuplas e funções
  • Uma grande mentira
  • type casting, type coertion
  • Conjuntos “sistemais” de reais
  • números algébricos
  • potências de um real elavado a um natural
  • potências de um real elavado a um inteiro

2025-01-13: IDMa (20)

  • Θ. (Euler): demonstração
  • Θ. Teorema chinês do resto
  • Primalidade: Wilson, Chineses, Fermatinho
  • Θ. A sorte de Fermat

2025-01-15: IDMb (3)

  • De √2 para √3
  • E sobre o √4?
  • Tentativa de generalização para outros √n
  • Especificação dos reais (2/3): parte relacional (ordem)
  • valor absoluto nos reais: definição e sua interpretação geométrica
  • distância: especificação e implementação
  • distância euclideana e distância discreta
  • a desigualdade triangular e sua interpretação geométrica
  • demonstração de (∀a,b,c)[ |a - c| ≤ |a - b| + |b - c| ]

2025-01-17: Prova IDMa.2

2025-01-20: IDMb (4)

Futuro (fluido)

2025-01-22: IDMb (5)

2025-01-24: Prova IRI.2; Prova IDMb.1

2025-01-27: ?

2025-01-29: ?

2025-01-31: ?

Last update: Tue Jan 21 15:57:02 -03 2025