Mestrando em Ecologia e Evolução pela Universidade Federal de São Paulo (UNIFESP). Tenho interesse na área de ecologia evolutiva, atuando em pesquisas que visam entender o comportamento animal e modelar a evolução da coloração em répteis.
https://www.facebook.com/labanimal15/
diver()
Introdução
Ao entrarmos no Antropoceno, a humanidade está reorganizando a biosfera. Processos que vão desde a caça excessiva de grandes vertebrados e a deslocação de espécies exóticas através das barreiras biogeográficas até à eliminação indiscriminada de habitats naturais para a agricultura continuam a corroer a biodiversidade. A sociedade valoriza a biodiversidade em múltiplas escalas espaciais, com preocupações que variam desde a provisão local de serviços ecossistêmicos até a preservação global do valor intrínseco e instrumental das espécies. Por exemplo, a Convenção das Nações Unidas sobre Diversidade Biológica procura deter a perda de biodiversidade a nível regional, nacional e global. Para avaliar a melhor forma de conservar a biodiversidade em escalas espaciais, precisamos entender a relação entre dados de monitoramento coletados localmente e dinâmicas de diversidade regional e como os mecanismos que mantêm a diversidade variam de escalas espaciais locais a regionais. Os conservacionistas, portanto, enfrentam uma questão fundamental: como as mudanças medidas localmente aumentam até os impactos regionais?
A solução está na nossa compreensão da diversidade alfa, beta e gama. Portanto, o desenvolvimento de uma ferramenta que possa quantificar essas propriedades das comunidades e ecossistemas se torna muito importante.
A importancia central desta funcao reside no calculo dos “numeros efeitivos” ou “numeros equivalentes” dos indices de diversidade convencionalmente usados (shannon entropy ou simpson concentration) para estimar riqueza de especies. Os números equivalentes de um índice de diversidade correspondem ao número de elementos igualmente prováveis necessarios para produzir o valor dado do índice de diversidade. Os números equivalentes do índice de Shannon e o Índice de Simpson são calculados da seguinte forma:
onde:
Para cada medida dos anteriores indices se estimará a incerteza por meio de reamostragem com reposição (BOOSTRAP). Assim, os intervalos de confiança ao 95% serão calculados por cada valor observado do índice.
A diversidade beta será calculada usando o índice de similaridade de Bray-Curtis:
onde:
Porfim, a diversidade gama será calculada como o numero total de especies da paisagem em estudo.
Planejamento da função
pi =
matriz contendo as amostras nas colunas e as espécies nas linhas (classe matrix()
).alfa =
índice de diversidade a ser usado, fica a escolha do usuário. Pode ser o exponencial do shannon ou o inverso do simpson.beta.gam =
diversidade beta calculada por meio da equação definida na introdução (o default é TRUE) e calcula também o valor da diversidade gama.perm =
número de permutações usado na reamostragem para estimar os intervalos de confiança de cada valor do índice calculado no argumento alfa
.Verificando os parâmetros
pi
dever ser um objeto da classe matrix
, pode conter 0 ou NA's.alfa
pode ser “shannon” ou “simpson”, para calculá-los deve-se especificar alguns deles. Pode-se usar letras iniciais de cada índice.beta.gam
se TRUE, será calculado. Se FALSE, não será calculado.perm
deve ser um numero inteiro (classe integer
).Pseudo-código
alfa
poderão ser especificados por meio das letras inicias.gam
e calcula o valor da diversidade gamaif(alfa==“shannon” | alfa==“simpson”)
, cria objeto shannon
ou simpson
e calcula o exponencial do shannon ou o inverso do simpson para cada coluna de pi
.res
e constrói uma matriz preenchida de NA's cujas colunas correspondem as amostras e as linhas correspondem ao numero de permutações usado para calcular os intervalos de confiança.for (i in 1:perm)
.pi
com reposição.res
.if(beta.gam==TRUE)
:for (i in 1:(dim(pi)[2]-1))
for (j in (i+1):dim(pi)[2])
matrix
criado antes do ciclo, onde o upper.tri
corresponde aos cálculos da diversidade beta.if
para maior flexibilidade da função.Saída
A função retorna uma lista contendo os seguintes objetos:
shan
ou simp
: Valores do exponencial do indice shannon ou o inverso do simpson por cada amostra (colunas) de pi
.confidence.inter
: Os valores dos intervalos de confiança ao 95%.beta
: Um objeto da classe matrix
contendo os valores de diversidade beta por pares de amostras.gam
: O valor da diversidade gama.Bibliografia
Oi Dylan,
A proposta A parece interessante, mas não consigo entender o que há de original além de chamar o pacote vegan pra fazer as partes interesantes. Do jeito que está, parece que a função só facilita que o usuário escolha o tipo de análise, mas o trabalho é feito pelas funções do vegan. Isso não é o objetivo da função a programar.
De maneira alternativa, eu sugiro manter o tópico sobre estimadores de diversidade mas tentando propor uma implementação de algum estimador para alguma escala de diversidade, e talvez se desafiar tentando implementar estimação de incerteza sobre a mesma por meio de alguma ferramenta (e.g., reamostragem).
Dito isto, você deve propor uma modificação radical da proposta A para poder continuar com ela como trabalho final. Por favor lembre-se que o aceite da proposta B é obrigatorio, então, veja meus comentários sobre a mesma na seção a seguir. Próximas conversas terão lugar pelo email e uma vez a gente consiga um consenso você deverá fazer as mudanças que tenham lugar no seu wiki.
darwin()
Introdução
A idéia básica da evolução biológica é que populações de espécies de organismos mudam com o tempo. Hoje, quando pensamos em evolução, é provável que vinculemos essa ideia a uma pessoa específica: o naturalista britânico Charles Darwin.
Na década de 1850, Darwin escreveu um livro influente e controverso chamado A origem das Espécies. Nele, sugeriu um mecanismo para a evolução: a seleção natural, na qual traços hereditários que ajudam os organismos a sobreviver e se reproduzir se tornam mais comuns em uma população ao longo do tempo.
Existem vários tipos de seleção como a seleção direcional, seleção disruptiva, seleção estabilizadora, entre outros. Por meio do uso da função darwin
será possível simular só o primeiro tipo de seleção. Este é um dos tipos mais frequente de seleção no qual o ótimo do traço é deslocado por uma pressão de seleção (p.e., predação).
Planejamento da função
N
tamanho populacional (classe integer
≥ 0)optimal
ótimo do traço (classe integer
≥ 0)pressure
intensidade de seleção (classe integer
≥ 0)g
tempo em gerações (classe integer
≥ 0)Verificando os parâmetros
N, optimal, pressure, g >= 0
caso contrario (< 0), escreve: “O valor do parametro deve ser positivo”Pseudo-código
nrow = N
e ncol = g
rnorm()
for (i in 2:g)
i
da matrizboxplot
no qual y = mediana do traço (ótimo) da população e x = tempo seq(1,g)
.Saída
A função retorna:
Observações
Parte da ideia desta função se originou como resultado de um curso de simulações empregado pelo Danilo Muniz na UNIFESP.
Bibliografia
Oi Dylan,
A proposta A parece interessante, mas não consigo entender exatamente qual modelo quantitativo estaria sendo implementado aqui. Por favor desenvolva em maior detalhe sua idéia e talvez possa continuar com ela como plano B. Neste ponto, as duas propostas parecem interessantes mas precisam de um pouco de trabalho.
Próximas conversas terão lugar pelo email e uma vez a gente consiga um consenso você deverá fazer as mudanças que tenham lugar no seu wiki.