Upgrade to Pro — share decks privately, control downloads, hide ads and more …

Minha visão

Minha visão

A minha visão de um curso de Cálculo Numérico para alunos de graduação. Adoto a definição de Trefethen. Discorro sobre algoritmos, sigo Polya na resolução de problemas. Foco no aspecto numérico com o IEEE 754. Apresento "softwares" para matemática no computador. Apresento o Pythonxy, ferramenta fundamental para todo o curso. Indico dois livros texto.

Paulo Bordoni

April 08, 2014
Tweet

More Decks by Paulo Bordoni

Other Decks in Education

Transcript

  1. Exponho a seguir minha visão pessoal de Cálculo Numérico. Na

    dose que entendo apropriada de teoria, exemplos e aplicações para alunos de graduação. Considero o computador uma ferramenta essencial ao Cálculo numérico.
  2. Outros nomes usuais, além de Cálculo numérico, são: • Análise

    numérica • Computação científica • Álgebra linear computacional Na biblioteca folhei livros onde tais onde apareciam tais nomes. São outros cursos?
  3. De forma curta e grossa, as associações implícitas a tais

    nomes são: Computação científica Ciência, engenharia e computadores Análise numérica Utilizar épsilons e deltas nas coisas do cálculo Álgebra Linear Computacional Matrizes, vetores e computadores Cálculo numérico Resoluções numéricas para coisas do cálculo
  4. A definição de Trefethen para Cálculo Numérico será nosso norte:

    “O estudo de algoritmos para a resolução numérica/computacional de problemas da matemática do contínuo”.
  5. Algo como uma receita de bolo. Um algoritmo é um

    procedimento passo-a-passo para efetuar cálculos. Uma sequência finita de instruções para resolver um problema Mestra, o que é um algoritmo? Um conceito fundamental em Computação.
  6. Allan M Turing 1912-1954 Nesse artigo Turing apresenta sua forma

    de entender um algoritmo. Ela passou a ser referida como “Máquina de Turing”.
  7. Leia o livro abaixo para descobrir mais sobre o conceito

    de algoritmo e outros atores que participaram ativamente do seu estabelecimento
  8. Bons problemas alavancam o conhecimento humano. A solução de um

    problema pode resultar em $$$! Resolver problemas é um esporte que me desafia! Resolver problemas!
  9. Professor, como eu faço para resolver problemas? Ah, se houvesse

    uma regra geral... Mestres chineses dizem que você tem que acertar o alvo!
  10. • Compreender o problema; • Conceber um plano para resolver

    o problema; • Executar o plano concebido; • Examinar a solução encontrada. No seu livro, Polya ensina que, para acertar o alvo, para resolver um problema, você só tem que: Donald Knuth foi aluno dele!
  11. Vamos trabalhar com números. E com aproximações numéricas! Cálculo numérico

    Muita atenção ao adjetivo que qualifica o nome do curso:
  12. O difícil é que nossos aprendizes acham que conhecem números.

    É, no 1º e no 2º grau eles só aprendem a manipular números.
  13. Por tais motivos, dedicaremos algumas aulas para estudar em detalhe

    o conceito de número real. Números naturais, inteiros, racionais, reais e complexos. Em toda sua beleza!
  14. Introdução à Computação. A disciplina que envolve o conhecimento dos

    números naturais, de recursividade e dos algoritmos. Cálculo numérico. A disciplina em que é imperioso entender muito bem números racionais, reais e complexos. É o reinado das aproximações e dos processos de discretização.
  15. Esse padrão é o IEEE 754 de 2008. Os números

    são representados nos computadores num padrão internacional. O computador é uma ferramenta imprescindível para realizar os cálculos numéricos.
  16. O IEEE 754 foi estabelecido de forma a ser independente

    tanto dos computadores como das linguagens de programação. Nele estão especificados tanto o formatos das representações numéricas como a forma de realizar as operações entre os números. Quer em “software” quer em “hardware”.
  17. Hoje em dia, um curso de Cálculo numérico sem o

    conhecimento do IEEE 754 é algo impensável. Mestres, dediquem o tempo necessário para explicitar tudo aos aprendizes. “Não há como fazer omelete sem quebrar ovos!”
  18. Você descobrirá, como eu, que todas as representações IEEE são

    finitas. Pior que isso, verá não existem conjuntos infinitos nos computadores. Thanatos impõe finitude ao homem. O computador aos números.
  19. Discretizar. É o verbo que que define o ato de

    passar do infinito ao finito em matemática. Aproximar. Caso não saiba, pergunte à sua namorada! Discretização e aproximação São palavras-chave em Cálculo numérico.
  20. Usaremos isso para traçar gráficos de funções. Aprenderemos técnicas de

    discretização de funções por interpolação.
  21. E que o formato double estabelece outra discretização. Veremos que

    o formato single do padrão IEEE 754 estabelece uma discretização do conjunto dos números reais.
  22. Porquê usaremos Python e não C, C++ ou Fortran? Vamos

    usar Python para programar. Porque Python é mais fácil de usar, porque é ensinado em Computação I na UFRJ e porque é poderoso.
  23. Mestre, fora essas linguagens, poderíamos trabalhar com o Maple, o

    Mathematica ou até o MatLab. São aplicativos muito mais amigáveis! Diga lá porque não, Filósofo!
  24. Um dos motivos é que Python é um “software livre”

    e grátis. Um outro, talvez o essencial, é que não se faz ciência com “software” comercial. Por quê Filósofo? Eles são tão mais fáceis de usar!
  25. Você entende o que está por trás da expressão “uma

    caixa preta” Loirinha? Bem, eu sei Mestra, já ouvi falar. Significa que não conseguimos acessar nem modificar o código do “software”. Isso nos impede acrescentar aspectos que necessitamos ao pacote, posto que ele é fechado.
  26. Bem, vou indicar onde encontrar o Maple, o Mathematica e

    o Matlab. Ok Professor, estamos numa democracia!
  27. Mas verá. Usaremos os pacotes NumPy, SciPy e MatPlotLib que

    lhe dão superpoderes. É a Comunidade de Software Livre em ação. Mestre, não vi nada parecido com MatLab, Maple ou Mathematica no Python.
  28. Mas não existem outros “softwares” livres que fazem o mesmo?

    Sim, nas próximas transparências, vou mostrar onde buscá-los.
  29. Muito bom Mestres. Teremos um curso prático Loirinha e não

    uma montanha de teoria!! Muita calma nessa hora, Surfista. Vamos conferir ...
  30. Usaremos os módulos NumPy, SciPy e MatPlotLib para trabalhar. De

    fato, usaremos o Python(x,y), que é um aplicativo que já trás todos eles. É “mamão com açúcar“ jovens!
  31. Após clique duplo no instalador é só concordar com as

    condições para dar a partida na instalação.
  32. Bem esta é uma pincelada rápida do que será o

    curso. Outras ideias estão por vir! Professora, alguma coisa a acrescentar? E você Surfista?
  33. Loirinha, se Cálculo já é difícil, imagine com Computação. É

    cara. Vamos ter que estudar muito. Muito mesmo!
  34. Acessem meu site para baixar o conteúdo das aulas. O

    endereço é: www.bordoni.info O cadastramento é obrigatório. O endereço eletrônico dele é [email protected]. Ele não responderá caso você use algum outro!
  35. Os erros são meus; suas correções serão benvindas. As figuras,

    eu desenhei; as ideias nem sempre! Mande suas sugestões para [email protected] Agradeço muito!
  36. A capa da 8ª edição de um bom livro para

    acompanhar nosso curso. Um enfoque mais matemático, mas apropriado para alunos de graduação, de engenharia inclusive.
  37. Um outro bom livro para acompanhar nosso curso, a capa

    é da 5ª edição. Um enfoque mais voltado para cursos de graduação em engenharia.