Tabela de conteúdos

Marianne Azevedo Silva

foto.jpg

Sou Graduada em Ciências Biológicas pela UNICAMP e mestre pelo Programa de Pós Graduação em Ecologia da UNICAMP sob orientação do Prof. Paulo S. Oliveira. Atualmente sou doutoranda pelo mesmo Programa e orientador. Tenho minha formação voltada a ecologia molecular. Em minhas pesquisas tenho especial interesse em descrever os padrões locais de distribuição da diversidade genética intraespecífica, bem como entender os fatores que a determinam e a mantém em sistemas naturais. Atualmente, o sistema biológico com a qual trabalho inclui formigas do Cerrado, embora também tenha interesse em outros sistemas.



I. Meus Exercícios

Link para a página com os meus exercícios resolvidos Exercícios



II. Trabalho Final - Propostas

II.I Proposta A: Suficiência amostral em trabalhos com diversidade genética

Contextualização

Tamanho amostral adequado é essencial em qualquer estudo empírico cujo objetivo seja fazer inferências sobre a população a partir de uma amostragem1). Em geral, avaliar a suficiência amostral é uma prática frequente em trabalhos de ecologia. No entanto, em outras áreas, como genética de populações, tal abordagem ainda é dificilmente incorporada às análises de dados. Alguns trabalhos tem buscado estabelecer generalizações a respeito do tamanho amostral adequado para estimativa de diversidade genética das populações (e.g. Hale et al. 2012). Apesar desse esforço, é sabido que essa suficiência amostral pode variar com o tipo de marcador molecular, nível de polimorfismo dos loci e história natural das espécies. Sendo assim, esta proposta tem como objetivo desenvolver uma função que permita aos pesquisadores interessados em genética de populações avaliar se, dado o conjunto de loci microssatélites genotipado, seu esforço amostral foi suficiente para inferir a diversidade genética das populações ou grupos de indivíduos diplóides sob estudo.

Planejamento da Função

Entrada: sample.suff (dados, col.ID, col.pop, col.loci, na.code, IC.plot, gen.div, nsim)

Verificando os parâmetros

Pseudo-código

  1. Carregar pacotes necessários (PopGenReport2) e Adegenet3))
  2. Transformar dados (data frame) em objeto genind (para isso, os argumentos col.ID, col.pop e col.loci serão usados
  3. Criar um objeto simula.allpop como sendo uma lista vazia (permite inserção de quantos objetos forem necessários dentro da lista)
  4. Entrar em um ciclo (1) for com contador i de 1 até o número total de populações. Ou seja, para cada população irá fazer:
    1. Criar objeto simula.media com NAs correspondente ao número de indivíduos da população
    2. Criar objeto simula.ICsup com NAs correspondente ao número de indivíduos da população
    3. Criar objeto simula.ICinf com NAs correspondente ao número de indivíduos da população
    4. Entrar em um ciclo (2) for com contador j de 1 até número de indivíduos da população
      1. Criar objeto simula.nind com NAs correspondente a nsim
      2. Entrar em um ciclo(3) 'for' com contador k de 1 até nsim
        1. simular a estimativa escolhida de gen.div para uma subamostragem de tamanho j da população (usar função sample com size=j e replace=T). Cada simulação é armazenada no objetosimula.nind na posição k
      3. Armazenar a média de simula.nind no objeto simula.media na posição j
      4. Armazenar o intervalo de confiança superior de simula.nind no objeto simula.ICsup na posição j
      5. Armazenar o intervalo de confiança inferior de simula.nind no objeto simula.ICinf na posição j
    5. Armazenar no objeto simula.allpop na posição i um data frame com 5 colunas sendo elas: numero de individuos amostrados (de 1 até número total de indivíduos na população), populacao (nome da população repetido em todas as linhas), media (médias armazenadas no objeto simula.media), ICsup (intervalos de confiança superiores armazenados no objeto simula.ICsup), ICinf (ntervalos de confiança inferiores armazenados no objeto simula.ICinf)
  5. Juntar todos os data frames do objeto simula.allpop em um único data frame gen.div.rarefaction
  6. Plotar gráfico da estimativa de diversidade genética em função do número de indivíduos. Para o plot usar: (i) função layout() - no lado esquerdo o gráfico e no direito legenda com as cores de cada população; (ii) uma cor para cada população
  7. Se IC.plot for igual a TRUE, plotar no gráfico as linhas correspondentes aos intervalos de confiança superiores e inferiores das simulações. Nesse caso, as linhas devem ser da cor da população correspondente, mas com um tipo diferente. Legenda deve conter as cores das populações e o que cada tipo de linha indica.
  8. Retornar uma lista sendo que o primeiro objeto é a estimativa de diversidade genética observada para as populações e o segundo objeto é o data frame gen.div.rarefaction

Saída


Comentários Vitor Rios

Mariana, parabéns pelas propostas, bem pensadas e bem estruturadas. Você pode seguir com qualquer uma das duas, mas eu gostei mais da primeira, me parece que seria útil para quem trabalha com genética de populações Vitor

Resposta aos Comentários

Oi Vitor! Obrigada por ler as propostas e pelo feedback! Vou seguir com a primeira proposta. Em caso de dúvidas, escrevo para você =)

II.II Proposta B: Adequação alimentar

Contextualização

A população brasileira tem sido, com alta frequência, alvo de doenças como desnutrição, obesidade, diabetes e hipertensão, todas amplamente associadas a hábitos alimentares inadequados. Frente a isso, esforços governamentais tem sido aplicados a fim de de orientar os brasileiros a terem uma alimentação mais saudável e com escolhas alimentares adequadas. Para atingir esse objetivo, o Ministério da Saúde lançou o “Guia alimentar para uma alimentação saudável”4)5), o qual é atualizado periodicamente. Com o intuito de auxiliar a adequação alimentar de brasileiros adultos, essa proposta tem a finalidade de desenvolver uma função que avalie se uma pessoa:

  1. está dentro do limite de peso ideal para seu sexo e altura
  2. está tendo uma ingestão adequada de macronutrientes segundo as diretrizes da Organização Mundial da Saúde (diretrizes estas também presentes no guia alimentar do Ministério da Saúde)

Caso o peso e alimentação não estejam de acordo com as estimativas ideais, e se for do desejo da usuário, a função pode retornar um objeto com sugestões de consumo diário variado para uma alimentação saudável que esteja de acordo com as orientações do Ministério da Saúde.

Planejamento da função

Entrada: adeq.alimentar (recordatorio.semanal, peso, altura, idade, sexo, ativ.fisica, cardapio)

Verificando parâmetros

Pseudo-código

  1. Estimar peso ideal pi6)
    1. se sexo = “H”, IMC desejável = 22 Kg/m2
    2. se sexo = “M”, IMC desejável = 21 Kg/m2
  2. Estimar adequação de peso apap = (peso/pi)*100
  3. Plotar peso e pi com intervalos de confiança de mais ou menos 10% de pi7)
    1. se ap ≤ 70, colocar um texto no gráfico “Desnutrição grave”
    2. se 70.1 ≤ ap ≤ 80, colocar um texto no gráfico “Desnutrição moderada”
    3. se 80.1 ≤ ap ≤ 90, colocar um texto no gráfico “Desnutrição leve”
    4. se 90.1 ≤ ap ≤ 110, colocar um texto no gráfico “Eutrofia (dentro do peso ideal)”
    5. se 110.1 ≤ ap ≤ 120, colocar um texto no gráfico “Soprepeso”
    6. se ap > 120, colocar um texto no gráfico “Obesidade”
  4. Substituir a string de ativ.fisica por valor correspondente
    1. se sexo = “H”:
      1. se ativ.fisica = “sedentario” substitui pelo valor 1
      2. se ativ.fisica = “pouco ativo” substitui pelo valor 1.11
      3. se ativ.fisica = “ativo” substitui pelo valor 1.25
      4. se ativ.fisica = “muito ativo” substitui pelo valor 1.48
    2. se sexo = “M”:
      1. se ativ.fisica = “sedentario” substitui pelo valor 1
      2. se ativ.fisica = “pouco ativo” substitui pelo valor 1.12
      3. se ativ.fisica = “ativo” substitui pelo valor 1.27
      4. se ativ.fisica = “muito ativo” substitui pelo valor 1.45
  5. Calcular necessidade de energia estimada nee para o peso
    1. se sexo = “H” usar a fórmula: 662 - (9.53 * idade) + ativ.fisica * (15.9 * peso) + (539.6 * altura)
    2. se sexo = “M” usar a fórmula: 354 - (6.91 * idade) + ativ.fisica * (9.36 * peso) + (726 * altura)
  6. Calcular média de recordatorio.semanal$n.refeicoes e armazenar no objeto mean.n.refeicoes
  7. Fazer um teste t para ver se mean.n.refeicoes é significativamente diferente de 58)
    1. se teste t for significativo, escrever na tela “Você deve ajustar seu número de refeições para 5 refeições ao dia, incluindo café da manhã, lanche da manhã, almoço, lanche da tarde e janta”
  8. Calcular intervalos de confiança superior e inferior da média das porcentagens diárias de recordatorio.semanal$P em relação a nee e armazenar nos objetos ICsup.p e ICinf.p, respectivamente
    1. se ICsup.p e ICinf.p estiverem contidos no intervalo de 15% a 20%9), escrever “Seu consumo diário de proteínas está bom!”
    2. caso contrário, escrever “Seu consumo diário de proteínas precisa ser ajustado”
  9. Calcular intervalos de confiança superior e inferior da média das porcentagens diárias de recordatorio.semanal$L em relação a nee e armazenar nos objetos ICsup.l e ICinf.l, respectivamente
    1. se ICsup.l e ICinf.l estiverem contidos no intervalo de 20% a 30%10), escrever “Seu consumo diário de lipídios está bom!”
    2. caso contrário, escrever “Seu consumo diário de lipídios precisa ser ajustado”
  10. Calcular intervalos de confiança superior e inferior da média das porcentagens diárias de recordatorio.semanal$C em relação a nee e armazenar nos objetos ICsup.c e ICinf.c, respectivamente
    1. se ICsup.c e ICinf.c estiverem contidos no intervalo de 45% a 65%11), escrever “Seu consumo diário de carboidratos complexos está bom!”
    2. caso contrário, escrever “Seu consumo diário de carboidratos complexos precisa ser ajustado”
  11. Calcular intervalos de confiança superior e inferior da média das porcentagens diárias de recordatorio.semanal$A em relação a nee e armazenar nos objetos ICsup.a e ICinf.a, respectivamente
    1. se ICsup.a e ICinf.a estiverem contidos no intervalo de 0% a 10%12), escrever “Seu consumo diário de açucares simples está bom!”
    2. caso contrário, escrever “Seu consumo diário de açucares simples precisa ser ajustado”
  12. Se cardapio = TRUE
    1. Carregar uma base de dados de alimentos disponibilizado no Anexo C deste guia13)
    2. Calcular necessidade de energia estimada ideal nee.ideal para o pi
      1. se sexo = “H” usar a fórmula: 662 - (9.53 * idade) + ativ.fisica * (15.9 * pi) + (539.6 * altura)
      2. se sexo = “M” usar a fórmula: 354 - (6.91 * idade) + ativ.fisica * (9.36 * pi) + (726 * altura)
    3. criar um objeto sugestoes.diarias da classe lista vazio
    4. se 90.1 ≤ ap ≤ 110, entrar em um ciclo for com contador i de 1 até 7
      1. para cada i amostrar alimentos (com reposição) tal que a soma total de kcal seja igual a nee e cuja partição respeite as porcentagens de cada grupo de alimentos sugeridas pelo Ministério da saúde14). Armazenar cada ciclo em sugestoes.diarias[i]
    5. se ap < 90, entrar em um ciclo for com contador i de 1 até 7
      1. para cada i amostrar alimentos (com reposição) tal que a soma total de kcal seja igual a nee.ideal+ 500 cal e cuja partição respeite as porcentagens de cada grupo de alimentos sugeridas pelo Ministério da saúde. Armazenar cada ciclo em sugestoes.diarias[i]
    6. se ap > 110, entrar em um ciclo for com contador i de 1 até 7
      1. para cada i amostrar alimentos (com reposição) tal que a soma total de kcal seja igual a nee.ideal- 500 cal e cuja partição respeite as porcentagens de cada grupo de alimentos sugeridas pelo Ministério da saúde. Armazenar cada ciclo em sugestoes.diarias[i]
  13. Retornar o objeto sugestoes.diarias

Saída

Observações adicionais: Dadas as condições que devem ser respeitadas em cada ciclo for da proposta B e minhas limitações como usuária do R, para desenvolver tais ciclos provavelmente será necessário ajuda dos monitores. Por isso, os ciclos não estão bem desenvolvidos nesta proposta.



III. Trabalho Final - Versão Final

III.I Proposta escolhida

Link para a página com a proposta escolhida, incluindo alterações e respectivas justificativas: Proposta escolhida

III.II Código da função e arquivo da função

Link para a página com o código e o arquivo da função: Função sample.suff

III.III Página de ajuda (help) da função

Link para a página com o help e o arquivo contendo o conjunto de dados de exemplo para executar a função: Página de ajuda (help) da função sample.suff

6)
pi = IMC desejável para adultos * altura2
7)
variação de pi que ainda é considerada como peso ideal
8)
número ideal de refeições ao dia(café, lanche da manhã, almoço, lanche da tarde e janta
9)
consumo diário de proteínas em relação ao NEE segundo a OMS
10)
consumo diário de lipídios em relação ao NEE segundo a OMS
11)
consumo diário de carboidratos complexos em relação ao NEE segundo a OMS
12)
consumo diário de açucares simples em relação ao NEE segundo a OMS
13)
será reorganizada em um único data frame que inclua uma coluna $tipo correspondente ao grupo de alimentos
14)
45% cereais/tubérculos/raízes; 3% feijões; 11% frutas; 3% legumes e verduras; 18% leite e derivados; 10% carnes e ovos; 4% óleo e gordura; 6% açucares simples