====== Ficha da Unidade ====== **Mestrado Integrado em Engenharia Informática e Computação\\ Fundamentos da Programação\\ Ocorrência: 2020/2021** \\ --- \\ [[https://sigarra.up.pt/feup/pt/UCURR_GERAL.FICHA_UC_VIEW?pv_ocorrencia_id=459463|Institutional page]] | [[sheet|[em inglês] ]] ===== Informação geral ===== **Unidade**: Fundamentos da Programação\\ **Código**: EIC0005\\ **Sigla**: FPRO\\ **Curso**: MIEIC\\ **Anos Curriculares**: 1º\\ **Página oficial**: [[https://sigarra.up.pt/feup/pt/UCURR_GERAL.FICHA_UC_VIEW?pv_ocorrencia_id=459463|Sigarra]]\\ **Créditos ECTS**: 6\\ **Horas de Contacto**: 70\\ **Horas Totais**: 162\\ **Ocorrência**: 2020/2021\\ **Semestre**: 1S\\ **Teóricas**: 2x1,5h: João Correia Lopes ([[https://sigarra.up.pt/feup/en/func_geral.formview?p_codigo=230756|JCL]]) \\ **Teórico-Práticas**: 8x2h: João Correia Lopes ([[https://sigarra.up.pt/feup/en/func_geral.formview?p_codigo=230756|JCL]]), Rui Camacho ([[https://sigarra.up.pt/feup/en/func_geral.formview?p_codigo=209847|RCS]]), Ricardo Cruz ([[https://sigarra.up.pt/feup/pt/func_geral.formview?p_codigo=552793|RPMC]]), Nuno Moreira Macedo \\ **Attendance**: ===== Língua de trabalho ===== Português. ===== Objetivos ===== 1. INTRODUÇÃO A fluência no processo de desenvolvimento de software é um pré-requisito básico para o trabalho dos engenheiros de informática. Para usar computadores na resolução de problemas de maneira eficaz, os estudantes devem ser competentes na leitura e escrita de programas usando linguagens de programação de Alto Nível. 2. OBJETIVOS ESPECÍFICOS O objetivo global desta Unidade é dar ao estudante a capacidade de criar algoritmos e de usar uma linguagem de programação para implementar, testar e depurar algoritmos para resolver problemas simples. O estudante será capaz de entender e usar os conceitos fundamentais de programação e a abordagem funcional da programação, especificamente a programação livre de efeitos (//effect-free//), onde as chamadas de função não têm efeitos colaterais e as variáveis são imutáveis, e de contrastar esta abordagem com a abordagem imperativa. 3. DISTRIBUIÇÃO PERCENTUAL Componente científica: 40%\\ Componente tecnológica: 60% ===== Resultados de aprendizagem e competências ===== No final da unidade, espera-se que o estudante consiga resolver problemas através do desenvolvimento de programas de complexidade média, usando as abordagens ou paradigmas de programação imperativa e funcional. Mais especificamente, o estudante deverá ser capaz de: - Projetar, implementar, testar e depurar um programa que use as construções fundamentais de programação, cálculos básicos, estruturas condicionais e iterativas padrão, entrada/saída simples, persistência (ficheiros) e exceções. - Entender a abstração de dados e usar tipos de dados simples ou compostos. - Entender a abstração procedimental e usar a definição de funções, passagem de parâmetros, recursão. - Implementar algoritmos básicos que evitem atribuir a um estado mutável ou considerar igualdade de referência. - Escrever funções úteis que aceitem e devolvam outras funções (funções de ordem mais elevada). - Entender variáveis e escopo léxico num programa (incluindo //closures//). - Definir e usar iteradores e outras operações em coleções, incluindo operações que tomam funções como argumentos (//map//, //reduce/fold// e //filter//) e compreensões em listas. - Usar as ferramentas de programação que ajudam a escrever, testar e documentar programas em computador de acordo com as melhores práticas de programação. ===== Modo de trabalho ===== Presencial. ===== Pré-requisitos (conhecimentos prévios) e co-requisitos (conhecimentos simultâneos) ===== Não são necessários conhecimentos prévios. ===== Programa ===== * Introdução ao Pensamento Computacional, algoritmos e programação com Python. * Conceitos fundamentais de programação: tipos de dados simples; variáveis, expressões e declarações; fluxo de programa, condicionais, iteração; funções, passagem de parâmetros, recursão; persistência. * Tipos de dados compostos: strings, tuplos, conjuntos, listas, dicionários. * Programação livre de efeitos usando chamadas a função sem efeitos colaterais e variáveis imutáveis. * Funções como cidadãos de primeira classe e //closures//. * Funções de ordem superior: //map//, //reduce/fold// e //filter//. * Geradores e compreensões em listas. * Estratégias de resolução de problemas. * Ferramentas de programação, teste e depuração. ===== Bibliografia Obrigatória ===== * Peter Wentworth, Jeffrey Elkner, Allen B. Downey, and Chris Meyers, //How to Think Like a Computer Scientist — Learning with Python 3//, Release 3rd Edition, 2020 [[https://media.readthedocs.org/pdf/howtothink/latest/howtothink.pdf|[PDF] ]][[http://openbookproject.net/thinkcs/python/english3e/|[HTML] ]] [[http://catalogo.up.pt/F/?func=direct&doc_number=000469776&local_base=UPB01|[Biblioteca] ]] ===== Bibliografia Complementar ===== * Steven F. Lott, Building Skills in Python - A Programmer's Introduction to Python, FreeTechBooks, 2010 [[http://www.freetechbooks.com/building-skills-in-python-a-programmer-s-introduction-to-python-t687.html|HTML]] * Allen Downey, Think Python — How to Think Like a Computer Scientist, 2nd Edition, Version 2.2.23, Green Tea Press, 2015 [[http://greenteapress.com/thinkpython2/html/index.html|HTML]] [[http://greenteapress.com/thinkpython2/thinkpython2.pdf|PDF]] [[https://github.com/AllenDowney/ThinkPython2|code]] * David Mertz, Functional Programming in Python, O’Reilly Media, 2015 [[http://www.devlang.com/static/s17/cse294/functional-prog-in-python.pdf|PDF]] * Ernesto Costa, Programação em Python – Fundamentos e Resolução de Problemas. FCA – Editora de Informática, 2015. ISBN: 978-972-722-816-4 [[http://catalogo.up.pt/F/-?func=find-b&local_base=FEUP&find_code=SYS&request=000585384|[Biblioteca] ]] ===== Métodos de ensino e atividades de aprendizagem ===== O envolvimento contínuo do estudante com a unidade é promovido, através do estudo e discussão dos tópicos (distribuídos previamente em Notebooks Jupyter) tanto em aulas teóricas e teórico-práticas, como através de trabalhos de programação dentro e fora das aulas. O estudante é encorajado a encontrar as melhores ideias para resolver problemas específicos, executá-las e implementar as soluções de programação, de forma elegante, legível e eficiente (em tempo e em espaço) usando a linguagem de programação Python. São usadas ferramentas de correção automática de código para aumentar a rapidez do feedback dado aos estudantes. As aulas teóricas (T) são usadas para apresentar e discutir os tópicos do programa, usando um computador ligado a um projetor multimédia. As aulas teórico-práticas (TP) são usadas para ajudar os estudantes a entender os tópicos do programa e a resolver as tarefas de programação semanais. As tarefas de programação em aula teórica e fora das aulas são dadas, semanalmente, para melhorar o desenvolvimento regular e eficaz dos processos de aprendizagem individual autónomo e são avaliadas em tarefas do Moodle. Tarefas em sala de aula são usadas para avaliação somativa no final de cada aula teórica através de questionários no Moodle. Os estudantes são incentivados a usar a Play web app Web (https://fpro.fe.up.pt/play) contendo exercícios de programação selecionados por tema: "fáceis" para realizar antes da aula teórica, "dificuldade média" para realizar antes das tarefas semanais (RE) e "difíceis" para realizar antes das provas práticas em computador (PE). No trabalho em sala de aula, os estudantes usam o mesmo ambiente de trabalho que é usado mais tarde nas avaliações individuais (PE) --- IDE Spyder3, Test web app (https://fpro.fe.up.pt/test) para desenvolvimento e submissão de exercícios de programação. Sempre que for considerado necessário na sala de aula, especialmente durante o primeiro mês de aulas da unidade, os alunos são incentivados a passar pela "Clínica", assegurada por monitores, para obter ajuda. ===== Software ===== * Anaconda Distribution 2020.07 for Linux (https://www.anaconda.com) * Spyder3 (incluido em Anaconda) * Python 3.8 (incluido em Anaconda) * Jupyter Notebooks ===== Palavras-chave ===== Ciências Físicas > Ciência de computadores > Programação ===== Tipo de avaliação ===== Avaliação distribuída sem exame final. ===== Componentes de Avaliação ===== ^ Designação ^ Peso (%) ^ | Teste | 80 | | Trabalho prático ou de projeto | 20 | | Total: | 100 | ===== Componentes de Ocupação ===== ^ Designação ^ Tempo (Horas) ^ | Estudo autónomo | 102 | | Frequência das aulas | 60 | | Total: | 162 | ===== Obtenção de frequência ===== Os estudantes são admitidos ao teste teórico (TE), se não excederem o limite de faltas (25% do número total de aulas teórico-práticas estimadas) e se obtiverem um mínimo de 40% na última avaliação prática em computador (PE04). ===== Fórmula de cálculo da classificação final ===== A avaliação será baseada nas seguintes componentes: **LE** = Perguntas de resposta múltipla, sobre conceitos de programação, realizadas individualmente no Moodle em sala de aula teórica (são selecionadas as melhores 20 classificações de um total de 24)// [5 perguntas, 5 minutos]//\\ **RE** = Exercícios de programação semanais para casa e nas aulas teórico-práticas (são selecionadas as melhores 10 classificações de 12) //[5 perguntas, NA]//\\ **PE** = Avaliação prática em computador a realizar, individualmente, no Moodle (são selecionadas as melhores 3 classificações de 4) //[5 perguntas, 90 minutos]//\\ **TE** = Avaliação teórica através de questionário de respostas múltiplas, a realizar individualmente no Moodle com consulta de um livro //[50 perguntas, 90 minutos]// **Classificação final** = 10% LE + 10% RE + 50% PE + 30% TE **Observações**: - É exigida classificação mínima de 40% na componente TE - É exigida a classificação mínima de 40% na última avaliação prática em computador (PE04) - Terá lugar uma segunda prova prática (PE05) para estudantes que faltem à avaliação PE04 com justificação válida, ou de recuperação para os estudantes que não obtiveram a nota mínima; no último caso, a nota nesta componente é limitada a 50% - Terá lugar uma segunda prova teórica (TE02) para estudantes admitidos e que faltem à avaliação TE01 com justificação válida, ou de recuperação para os estudantes admitidos e que não obtiveram a nota mínima; no último caso, a nota nesta componente é limitada a 50% - Se a classificação final for maior que 17, o estudante pode ser submetido a uma avaliação oral e a nota final é a média das duas classificações - Os estudantes que atingirem pelo menos 90% nas tarefas de avaliação presencial, de programação semanal e individual (LE + RE + PE), a meio do semestre podem optar por manter a nota e fazer um pequeno projeto; desta forma, ficam com as notas LE e RE atuais congeladas e, com o projeto, podem atingir a nota máxima (100%) nessas duas componentes ===== Provas e trabalhos especiais ===== A avaliação desta unidade usa quatro tipos de provas:: * Na aula teórica, através de um questionário de escolha múltipla no Moodle, sem consulta, para avaliar o acompanhamento dos tópicos expostos (LE) * Na aula teorico-práticas ou fora da aula, exercícios de programação relacionadas com os tópicos atuais, a serem submetidos no Moodle e classificados automaticamente (RE) * Avaliação prática em computador de exercícios de programação, utilizando o Moodle e classificados automaticamente, e com consulta de textos de referência (PE) * Avaliação teórica através de um questionário de escolha múltipla no Moodle, com consulta de um livro, para avaliar a aprendizagem dos conceitos fundamentais de programação e a capacidade dos estudantes usarem e discutirem os melhores algoritmos e estruturas de dados para problemas específicos (TE) ===== Melhoria de classificação ===== No ano letivo seguinte, o estudante pode solicitar melhoria de classificação que inclui a avaliação prática em computador PE04 e a avaliação teórica TE01, com consulta de apenas um livro, igual à realizada pelos estudantes inscritos. **Classificação final** = 60% PE + 40% TE **Observações**: - É exigida classificação mínima de 40% em cada um dos componentes PE e TE - Se a classificação final for maior que 17, o estudante pode ser submetido a uma avaliação oral e a nota final é a média das duas classificações ===== Avaliação especial (TE, DA, ...) ===== No caso de estudantes que não frequentem as aulas e dispensem a avaliação semanal (LE e RE), a classificação final será a média pesada da classificação das restantes componentes de avaliação: avaliação prática em computador (PE) e avaliação teórica (TE), realizadas tal como os estudantes ordinários. **Classificação final** = 60% PE + 40% TE **Observações**: - É exigida classificação mínima de 40% em cada um dos componentes PE e TE - É exigida a classificação mínima de 40% na última avaliação prática em computador (PE04) - Terá lugar uma segunda prova prática (PE05) para estudantes que faltem à avaliação PE04 com justificação válida, ou de recuperação para os estudantes que não obtiveram a nota mínima; no último caso, a nota nesta componente é limitada a 50% - Terá lugar uma segunda prova teórica (TE02) para estudantes admitidos e que faltem à avaliação TE01 com justificação válida, ou de recuperação para os estudantes admitidos e que não obtiveram a nota mínima. No último caso, a nota nesta componente é limitada a 50% - Se a classificação final for maior que 17, o estudante pode ser submetido a uma avaliação oral e a nota final é a média das duas classificações ===== Observações ===== Nenhuma classificação de componente individual (LE((**LE** = Ler o livro (e perceber) + Ver bons exemplos de programação)), RE, PE, TE((**REPETE** = Repetir o trabalho com programas e exercícios dados ou encontrados noutros lugares))) pode ser reutilizada noutra inscrição na unidade curricular. Devido às regras impostas superiormente depois da publicação desta ficha, nomeadamente o atraso de 3 semanas no arranque das aulas, este ano não é possível concluir a recuperação da componente prática (PE05), antes da prova teórica TE01, como planeado. Assim, são elegíveis para a prova teórica TE01, todos os estudantes que não tenham a classificação de RFF, por terem ultrapassado o limite de faltas. Note-se que se mantém a exigência de nota mínima de 40% em cada componente (PE, TE). \\ --- //[[jlopes@fe.up.pt|Correia Lopes]], 01/08/2020 08:55//