Propostas de Estágio 2012/2013

DEI - FCTUC
Gerado a 2024-11-21 19:13:54 (Europe/Lisbon).
Voltar

Titulo Estágio

J2JPar: Automatic Parallelizing Compiler for the Aeminium platform

Área Tecnológica

Engenharia de Software

Local do Estágio

Laboratórios de “Software and Systems Engineering – CISUC”

Enquadramento

Este estágio está integrado do projeto “AEminium – Freeing Programmers from the Shackles of Sequentially” financiado pelo programa CMU|Portugal. Este projeto tem por objetivo dotar os programadores de uma plataforma para o desenvolvimento de aplicações massivamente paralelas.

O projeto resulta de uma parceria entre a Universidade de Carnegie Mellon, a Universidade de Coimbra, a Universidade da Madeira e a Novabase. Os trabalhos em Coimbra centram-se no desenvolvimento do ambiente de execução (runtime) e das ferramentas necessárias para dar suporte a uma nova linguagem de programação.

Objetivo

O objetivo deste estágio é desenhar e desenvolver um compilador capaz de paralelizar automaticamente código JAVA sequencial. O código gerado deverá ser executado no runtime Aeminium. Neste estágio serão desenvolvidas e aplicadas várias técnicas que permitam aumentar a performance dos programas gerados assim como a assegurar a correção da execução. Dado que o trabalho neste compilador já se encontra iniciado, o estagiário terá como principal objetivo aumentar a a lista de funcionalidades do código JAVA suportadas pelo compilador e de desenvolver técnicas de compilação para otimizar o código gerado.

Plano de Trabalhos - Semestre 1

(ID da tarefa / Identificação / Duração (horas) / Dependências)
(1 / Integração na equipa do projeto / 5 / -)
(2 / Aprendizagem das metodologias de desenvolvimentos e processos relacionados / 16 / 1)
(3 / Aprendizagem das tecnologias e ferramentas a utilizar / 16 / 1,2)
(4 / Estudo da literatura, enquadramento e objetivos do projeto / 32 / 1)
(5 / Identificação de requisitos / 16 / 4)
(6 / Planeamento do desenvolvimento / 5 / 5)
(7 / Sprint 1 / 32 / 6)
(8 / Sprint 2 / 32 / 7)
(9 / Sprint 3 / 32 / 8)
(10 / Sprint 4 / 32 / 9)
(11 / Escrita do relatório intermédio e preparação da apresentação / 16 / 8)
(12 / Preparação de demonstração / 10 / 10)

Plano de Trabalhos - Semestre 2

(ID da tarefa / Identificação / Duração (horas) / Dependências)
(13 / Integração dos dados recolhidos na apresentação intermédia no planeamento do estágio e na preparação do relatório final / 20 / -)
(14 / Sprint 5 / 80 / 10,13)
(15 / Sprint 6 / 80 / 14)
(16 / Escrita de documentação / 40 / 15)
(17 / Preparação de testes e demonstração / 40 / 15)
(18 / Sprint 7 / 80 / 15,16,17)
(19 / Sprint 8 / 80 / 18)
(20 / Sprint 9 / 80 / 19)
(21 / Sprint 10 / 80 / 20)
(22 / Sprint 11 / 80 / 21)
(23 / Sprint 12 / 80 / 22)
(24 / Escrita de documentação / 40 / 23)
(25 / Preparação de testes e demonstração / 40 / 23)
(26 / Escrita do relatório final e preparação da apresentação / 30 / 20)

Condições

A atribuição de uma Bolsa de investigação ao aluno selecionado para a duração do estágio está dependente da aprovação da extensão do projeto Aeminium pela FCT. O subsídio de manutenção mensal tem o valor de €745, de acordo com a tabela da FCT para Bolsas de Iniciação Cientifica, pago por transferência bancária. A atribuição da bolsa não gera nem titula uma relação de natureza jurídico-laboral, é exercida em regime de dedicação exclusiva e atribuído ao Bolseiro o Estatuto de Bolseiro da UC conforme disposto no Regulamento de Bolsas de Investigação da Universidade de Coimbra (Despacho n.º 5120/2005 (2.ª), DR. n.º 48, de 9 de Março, Deliberação n.º 23/2005, de 5 de Janeiro do senado da Universidade Coimbra).

Observações

Os candidatos deverão apresentar (preferencialmente) um bom currículo académico nas áreas relacionadas com o projeto. Nomeadamente: programação orientada aos objetos; programação funcional; programação concorrente; compiladores e runtimes; e engenharia de software. A aprovação final de um candidato será realizada pelo PI do projeto AEminium na Universidade de Coimbra.

Orientador

Bruno Cabral
bcabral@dei.uc.pt 📩