Sou aluna de Doutorado em Microbiologia no Laboratório de Ecologia Microbiana, Instituto Oceanográfico da USP. Meu trabalho envolve estudar a diversidade taxonômica e funcional de comunidades de bactérias e arqueias em um vulcão ativo na Antártica.
Currículo Lattes
amandagb@usp.br
Comentários Vitor Rios
vrios81@gmail.com
Resposta Amanda
Comentários Vitor Rios
vrios81@gmail.com
Resposta Amanda
O gene que codifica a subunidade 16S do RNA ribossomal é atualmente o marcador filogenético mais confiável para estudos de ecologia de micro-organismos procariotos (rRNA 16S). O sequenciamento deste gene a partir do DNA total das comunidades microbianas nas amostras ambientais produz milhares ou milhões de sequências que precisam ser processadas através de ferramentas de bioinformática. Durante este processamento, as sequencias são classificadas em Unidades Taxonômicas Operacionais (Operacional Taxonomic Unity - OTU), que se referem basicamente a grupos taxonômicos correspondentes à espécie, quando considerado um valor de similaridade de 97% (é importante destacar que a discussão sobre o que é espécie em microbiologia de procariotos é extensa1)). Em geral, são observadas entre 5.000-30.000 OTUs, dependendo fortemente do ambiente analisado e da cobertura do sequenciamento. Devido ao grande número de OTUs, a maior parte dos trabalhos nesta área representam somente os organismos mais abundantes e que teoricamente teriam uma maior contribuição dentro da comunidade. Contudo, trabalhos recentes2) questionam essa abordagem e discutem que os micro-organismos menos abundantes (biosfera rara) podem exercer um papel fundamental ainda pouco conhecido.
abund.vs.rare(data, rare, abund, richness, a.diversity, stat)
A função “abund.vs.rare()” tem o objetivo de diferenciar as OTUs raras e abundantes dentro de uma comunidade microbiana, de acordo com os passos descritos abaixo.
INPUT: Um data frame com as colunas referentes às amostras e as linhas referentes às OTUs e sua classificação taxonômica. Os valores correspondem ao número de sequências observadas para cada OTU.
1- Transformação da tabela em abundância relativa
2- Manipulação do dataframe de modo que os dados serão salvos em três objetos em relação a abundância de OTUs:
Cada objeto irá conter o número de sequências para cada OTU e sua classificação taxonômica por amostra. Os raros e abundantes serão determinados pelo usuário, através dos argumentos “rare=” e “abund=”, referentes à porcentagem escolhida (Default: >1% para abundantes e <0,1% para raros). Os valores do default foram escolhidos de acordo com trabalhos prévios3) que sugerem que as OTUs que apresentam abundância maior que 1% são consideradas abundantes, enquanto as com valores menores que 0,1%-0,001% de abundância são consideradas raras.
3- Para os dados de cada objeto, serão estimados os índices de riqueza e alfa diversidade por amostra. O usuário terá a opção de usar os índices ACE ou Chao1 para riqueza e Shannon ou Simpson para alfa diversidade. Neste momento, serão criados os objetos:
4- Verificar se há diferença significativa dos índices de riqueza e alfa diversidade comparando cada amostra entre os três objetos. A intenção é observar como a riqueza e diversidade de cada amostra respondem quando consideramos somente membros raros ou somente abundantes, em comparação com os totais. Serão fornecidos os argumentos: “stat”, com as opções de test t ou ANOVA (ou outras ainda a definir).
OUTPUT: retornará dois data frames. O primeiro contendo os índices de riqueza e diversidade para OTUs raras, abundantes e totais, para cada amostra. O segundo com o resultado do teste estatístico escolhido. Além disso, três histogramas referentes às distribuições dos dados para as OTUs raras, abundantes e totais.
Exemplos do OUTPUT:
Dataframe 1: Índices de riqueza e alfa de diversidade para OTUs raras, abundantes e totais, por amostra.
Dataframe 2: Teste estatístico para verificar se há diferença significative entre a diversidade de membros raros, abundantes e totais, para uma determinada amostra.
Histograma: distribuição de membros raros e abundantes. Além destes, a função irá gerar a distribuição dos membros totais.
A hipótese “Everything is everywhere, but the environment selects”, proposta por Baas Becking e Martinus Beijerinck, é extensamente discutida na Ecologia Microbiana desde sua publicação na década de 1930. Basicamente, a hipótese propõe que a maior parte dos micro-organismos possui distribuição ubíqua e que as condições do ambiente explicam melhor a proliferação de determinados grupos do que os fatores geográficos. Contudo, muitos autores contestam a hipótese de Becking e Beijerinck, argumentando que a distribuição de muitos grupos microbianos pode ser explicada por padrões biogeográficos 5). Para testar a hipótese da distribuição ubíqua dos micro-organismos, o primeiro passo seria entender quantos e quais grupos taxonômicos são compartilhados em amostras com diferentes condições ambientais e quantos e quais grupos são únicos para cada condição.
shared.vs.unique.otus(data, plottype)
A função shared.vs.unique.otus() tem o objetivo de contabilizar e verificar quais são as OTUs únicas e compartilhadas comparando amostras par-a-par.
INPUT: Um data frame com as colunas referentes às amostras e as linhas referentes às OTUs e sua classificação taxonômica. Os valores correspondem ao número de sequências observadas para cada OTU (ver explicação de análises baseadas em OTUs na Proposta A).
1- Aplicar um código binário no dataframe de INPUT, onde 1 é equivalente a presença de uma determinada OTU e 0 é equivalente à ausência de uma determinada OTU, para cada amostra.
2- As amostras serão comparadas par-a-par por uma operação lógica. Quando ambas apresentarem valor de 1 para uma determinada OTU, esta OTU será considerada compartilhada. Quando o valor de 0 estiver presente em uma amostra e 1 para outra amostra, esta OTU será considerada única para amostra com valor de 1. Para valores 0 e 0 entre as amostras, esta OTU será desconsiderada.
3- Serão criadas duas matrizes, uma com o número de OTUs compartilhadas entre as amostras, e outra com o número de OTUs únicas.
4- Será criado um dataframe com a informação de quais OTUs são compartilhadas e quais são únicas, na comparação de amostras par-a-par.
OUTPUT: retornará um bubble plot ou heatmap comparando graficamente o número de OTUs compartilhadas (argumento “plottype” com as opções “bubble” ou “heatmap”) e outro com o número de OTUs únicas. Além disso, dois dataframes, um com a informação de quais OTUs são compartilhadas e outro com a informação de quais são únicas.
Exemplos de OUTPUT:
A terceira proposta tem com objetivo realizar uma análise multiparamétrica relacionando a composição de OTUs (opções: totais, abundantes ou raras) para cada amostra com dados físico-químicos ambientais.
otus.vs.env(data, envpar, select, method)
INPUT:
data: Um data frame com as colunas referentes às amostras e as linhas referentes às OTUs e sua classificação taxonômica. Os valores correspondem ao número de sequências observadas para cada OTU (ver explicação de análises baseadas em OTUs na Proposta A) (mesmo input que das propostas anteriores).
envpar: parâmetros ambientais, com amostras por colunas, e parâmetros por linhas.
1- Selecionar no dataframe (argumento “select”) quais OTUs serão representadas nas análises multiparamétricas. Opções: “total”, “abund”, “rare”. Como descrito na proposta A, será realizada a manipulação do datraframe, onde abundância maior que 1% serão consideradas abundantes, e as com valores menores que 0,1% serão consideradas raras.
2- O argumento “method” irá selecionar o tipo de análise multiparamétrica, com as opções “pca”, “rda” ou “cca”.
3- Triplot da análise multiparamétrica (amostras, OTUs e parâmetros ambientais).
OUTPUT: retornará o gráfico triplot com a análise multiparamétrica escolhida, contendo as informações de OTUs totais, abundantes ou raras, determinadas pelo usuário.
Exemplo de OUTPUT:
No quarto item do “Plano A” havia sido proposto uma análise estatística de ANOVA ou teste t. Contudo, durante a elaboração da Função, achei mais interessante analisar a similaridade entre as amostras, comparando-as quanto às suas OTUs totais, raras e abundantes. Escolhi representar essa similaridade através de dendrogramas, construídos ao calcular-se os índices de dissimilaridade por Bray-Curtis ou Distância Euclidiana. —-Amanda
abund.vs.rare package:unknown R Documentation Análise de OTUs raras e abundantes em Ecologia Microbiana Description: Analisa riqueza, diversidade e similaridade de comunidades microbianas, considerando membros totais, raros e abundantes, a partir de uma tabela de OTUs. Usage: abund.vs.rare(x, rare="0.01", diversity="shannon", dist = "bray") Arguments: x: Dataframe contendo os dados. rare: Define o valor máximo de abundância relativa para uma OTU ser considerada rara. O usuário tem as opções de 0.01 (1%) ou 0.001 (0.1%). diversity: Índice de diversidade a ser calculado para OTUs totais, abundantes e raras, por amostra. O usuário tem a opção dos índices Shannon ("shannon") ou Simpson ("simpson"). dist: O método para se calcular o índice de dissimilaridade entre as amostras, quando consideradas OTUs totais, abundantes e raras. O usuário tem a opçao de Bray-curtis ("bray") ou distância Euclidiana ("euclidean"). Details: Essa função fornece análises de riqueza e diversidade em ecologia microbiana ao comparar diferentes amostras quando considerados membros raros, abundantes e totais da comunidade. Os dados introduzidos na função devem ser um dataframe contendo o número de sequencias por OTUs, sendo as OTUs distribuídas por linhas e amostras distribuídas por colunas. Value: Retorna uma matriz contendo os valores de riqueza e diversidade, para OTUs totais, raras e abundantes, por amostra; e um plot contendo seis dendrogramas construídos a partir dos índices de dissimilaridade com os valores de riqueza e diversidade de OTUs totais, raras e abundantes, para cada amostra. Author: Amanda Gonçalves Bendia amandagb@usp.br References: BAGCHI, Samik et al. Diversity and dynamics of dominant and rare bacterial taxa in replicate sequencing batch reactors operated under different solids retention time. Applied microbiology and biotechnology, v. 99, n. 5, p. 2361-2370, 2015. LYNCH, Michael DJ; NEUFELD, Josh D. Ecology and exploration of the rare biosphere. Nature Reviews Microbiology, v. 13, n. 4, p. 217-229, 2015. Examples: ## Dataframe de Input otu.t <- read.table("datateste.txt", header = TRUE, sep = "\t") otu.t Amostra1 Amostra2 Amostra3 Amostra4 Amostra5 Amostra6 Amostra7 Amostra8 Amostra9 Amostra10 OTU1 0.0 3.0 0.0 75.0 50.0 31.0 80.0 23.0 23.0 334.0 OTU2 16.0 26.0 8.0 424.0 122.0 101.0 256.0 147.0 734.0 3.0 OTU3 0.0 2.0 0.0 191.0 181.0 145.0 249.0 108.0 129.0 328.0 OTU4 0.0 0.0 0.0 4.0 0.0 3.0 7.0 0.0 0.0 1076.0 OTU5 0.0 0.0 0.0 1.0 0.0 2.0 0.0 1.0 3.0 515.0 OTU6 0.0 0.0 0.0 3.0 0.0 3.0 6.0 3.0 17.0 493.0 OTU7 718.0 726.0 872.0 687.0 460.0 522.0 1476.0 669.0 1314.0 46.0 OTU8 469.0 816.0 372.0 292.0 90.0 80.0 662.0 175.0 1951.0 27.0 OTU9 0.0 2.0 6.0 0.0 0.0 0.0 8.0 4.0 0.0 4.0 OTU10 0.0 0.0 0.0 5.0 3.0 2.0 6.0 3.0 5.0 835.0 OTU11 0.0 5.0 2.0 1.0 1.0 0.0 6.0 3.0 10.0 84.0 OTU12 0.0 1.0 1.0 6.0 4.0 3.0 0.0 0.0 2.0 508.0 OTU13 165.0 171.0 316.0 400.0 170.0 233.0 22.0 16.0 8.0 7.0 OTU14 0.0 0.0 1.0 10.0 3.0 9.0 20.0 2.0 10.0 1474.0 OTU15 11.0 29.0 17.0 342.0 152.0 138.0 488.0 181.0 353.0 5.0 OTU16 0.0 8.0 0.0 5.0 4.0 0.0 12.0 3.0 4.0 80.0 OTU17 27.0 74.0 38.0 257.0 134.0 111.0 794.0 280.0 579.0 0.0 OTU18 3.0 2.0 4.0 939.0 37.0 231.0 513.0 49.0 1260.0 0.0 OTU19 0.0 4.0 0.0 40.0 5.0 17.0 13.0 1.0 8.0 0.0 OTU20 0.0 0.0 0.0 0.0 0.0 3.0 0.0 0.0 0.0 574.0 ## Matriz com dados de riqueza e diversidade de OTUs totais, raras, abundantes, por amostra abund.vs.rare(otu.t, rare="0.01", diversity="shannon", dist = "bray") riqueza.rare riqueza.abund riqueza.tot div.tot div.rare div.abund Amostra1 2 5 7 1.138470 0.05098383 1.087487 Amostra2 8 6 14 1.288572 0.08866381 1.199908 Amostra3 6 5 11 1.203014 0.07849486 1.124519 Amostra4 8 10 18 2.103346 0.06210771 2.041238 Amostra5 6 9 15 2.029372 0.08430975 1.945063 Amostra6 7 10 17 2.059021 0.09133335 1.967688 Amostra7 9 8 17 1.943201 0.12780042 1.815401 Amostra8 9 8 17 1.819002 0.12147570 1.697526 Amostra9 10 7 17 1.799358 0.08908378 1.710274 Amostra10 6 11 17 2.220433 0.07986509 2.140568
####################################################################################### # Função abund.vs.rare() - Análises de OTUs raras e abundantes em Ecologia Microbiana # ####################################################################################### abund.vs.rare <- function(x, rare="0.01", diversity="shannon", dist = "bray") # O arquivo contendo os dados precisa ser organizado em: amostras por colunas e espécies (OTUs) por linhas # É criado um dataframe com o arquivo de input dos dados # A Função possui três argumentos: (a) rare, (b) diversity e (c) dist # No argumento "rare" o usuário tem as opções de "0.001" ou "0.01" (0,1% e 1%) para definir quais OTUs são raras e quais são abundantes # No argumento "diversity" o usuário tem a opção de escolher "shannon" ou "simpson" para as análises de alfa diversidade # No argumento "dist" o usuário tem a opção de escolher os índices de dissimilaridade "bray-curtis" ou distância euclideana, # para comparar as amostras quando consideradas OTUs raras, abundantes e totais. # Exige Pacote Vegan { if (missing(x)) { # Caso os dados da tabela OTUs não tenham sido inseridos. stop("Tabela de OTUs não fornecida.") } library(vegan) RAROS <- c("0.001", "0.01") # usuario seleciona membros raros da comunidade, com as opções de 0,1% ou 1% rare <- match.arg(rare, RAROS) DIVERSIDADE <- c("shannon", "simpson") # usuario seleciona indice de shannon ou simpson para alfa diversidade diversity <- match.arg(diversity, DIVERSIDADE) DIST <- c("bray", "euclidean") # usuario seleciona indice de dissimilaridade bray-curtis ou distância euclideana dist <- match.arg(dist, DIST) otu.table.abund <- decostand(x, method = "total", MARGIN=2) #cria objeto com os valores de abundância relativa # a partir da tabela OTU contendo o número de espécies otu.rare <- otu.table.abund #cria objeto para selecionar OTUs raras, a partir do dataframe original otu.abund <- otu.table.abund #cria objeto para selecionar OTUs abundantes, a partir do dataframe original otu.tot <- otu.table.abund #cria objeto para selecionar as OTUs totais, a partir do dataframe original if(rare=="0.001") #escolha do usuario para OTUs raras de 0.01% (0.001) { otu.rare[otu.rare > 0.001] <- NA #selecao de OTUs raras, desconsiderando os valores maiores que 0.001 de abundancia relativa otu.abund[otu.abund < 0.001] <- NA #selecao de OTUs abundantes, desconsiderando os valores menores que 0.001 de abundancia relativa otu.rare[is.na(otu.rare)] <- 0 #substitui NAs por 0 otu.abund[is.na(otu.abund)] <- 0 #substitui NAs por 0 } if(rare=="0.01") #escolha do usuario para OTUs raras de 0.1% (0.01) { otu.rare[otu.rare > 0.01] <- NA #selecao de OTUs raras, desconsiderando os valores maiores que 0.01 de abundancia relativa otu.abund[otu.abund < 0.01] <- NA #selecao de OTUs abundantes, desconsiderando os valores menores que 0.01 de abundancia relativa otu.rare[is.na(otu.rare)] <- 0 #substitui NAs por 0 otu.abund[is.na(otu.abund)] <- 0 #substitui NAs por 0 } { # Análise de riqueza para OTUs abundantes, raras e totais riqueza.rare <- apply(otu.rare, 2, function(c)sum(c!=0)) #numero de especies (OTUs) raras riqueza.abund <- apply(otu.abund, 2, function(c)sum(c!=0)) #numero de especies (OTUs) abundantes riqueza.tot <- apply(otu.tot, 2, function(c)sum(c!=0)) #numero de especies (OTUs) totais riqueza <- cbind(riqueza.rare, riqueza.abund, riqueza.tot) #juntando valores referentes # ao numero de (OTUs) totais, raras e abundantes (riqueza) message("Riqueza calculada!") # Criando objetos para os cálculos de diversidade para OTUs abundantes, raras e totais t <- otu.tot #para calcular diversidade a partir de OTUs totais r <- otu.rare #para calcular diversidade a partir de OTUs raras a <- otu.abund #para calcular diversidade a partir de OTUs abundantes } if(diversity=="shannon") { message("Índice de diversidade Shannon calculado!") #calcula diversidade shannon a partir de OTUs totais t <- -t * log(t) div.tot <- apply(t, 2, sum, na.rm = TRUE) #calcula diversidade shannon a partir de OTUs raras r <- -r * log(r) div.rare <- apply(r, 2, sum, na.rm = TRUE) #calcula diversidade shannon a partir de OTUs abundantes a <- -a * log(a) div.abund <- apply(a, 2, sum, na.rm = TRUE) diversidade <- cbind(div.tot, div.rare, div.abund) #juntando valores dos indices de diversidade para OTUs totais, raras e abundantes riqueza.diversidade <- cbind(riqueza, diversidade) #juntando os valores de riqueza e diversidade para OTUs totais, abundantes e raras } if(diversity=="simpson") { message("Índice de diversidade Simpson calculado!") #calcula diversidade simpson a partir de OTUs totais t <- t * t simpson.t <- apply(t, 2, sum, na.rm = TRUE) div.tot <- 1 - simpson.t #calcula diversidade simpson a partir de OTUs raras r <- r * r simpson.r <- apply(r, 2, sum, na.rm = TRUE) div.rare <- 1 - simpson.r #calcula diversidade simpson a partir de OTUs abundantes a <- a * a simpson.a <- apply(a, 2, sum, na.rm = TRUE) div.abund <- 1 - simpson.a diversidade <- cbind(div.tot, div.rare, div.abund) #juntando valores dos indices de diversidade para OTUs totais, raras e abundantes riqueza.diversidade <- cbind(riqueza, diversidade) #juntando os valores de riqueza e diversidade para OTUs totais, abundantes e raras } # Transformando em dataframes para calcular índices de dissimilaride entre as amostras div.tot <- as.data.frame(div.tot) # índice de diversidade para OTUS totais div.abund <- as.data.frame(div.abund) # índice de diversidade para OTUS abundantes div.rare <- as.data.frame(div.rare) # índice de diversidade para OTUS raras riqueza.tot <- as.data.frame(riqueza.tot) # Riqueza para OTUS totais riqueza.abund <- as.data.frame(riqueza.abund) # Riqueza para OTUS abundantes riqueza.rare <- as.data.frame(riqueza.rare) # Riqueza para OTUS raras # Cálculo de índices de dissimilaridade (bray-curtis ou euclideano) entre as amostras, considerando riqueza e diversidade para OTUs totais, raras e abundantes if(dist=="bray") { message("Índice de dissimilaridade calculado: Bray-Curtis!") div.tot.clus <- hclust(vegdist(div.tot, method="bray")) #Calcula dissimilaridade Bray-Curtis para diversidade de OTUs totais div.abund.clus <- hclust(vegdist(div.tot, method="bray")) #Calcula dissimilaridade Bray-Curtis para diversidade de OTUs abundantes div.rare.clus<- hclust(vegdist(div.tot, method="bray")) #Calcula dissimilaridade Bray-Curtis para diversidade de OTUs raras riq.tot.clus <- hclust(vegdist(riqueza.tot, method="bray")) #Calcula dissimilaridade Bray-Curtis para riqueza de OTUs totais riq.abund.clus <- hclust(vegdist(riqueza.tot, method="bray")) #Calcula dissimilaridade Bray-Curtis para riqueza de OTUs abundantes riq.rare.clus <- hclust(vegdist(riqueza.tot, method="bray")) #Calcula dissimilaridade Bray-Curtis para riqueza de OTUs raras } if(dist=="euclidean") { message("Índice de dissimilaridade calculado: Distância Euclideana!") div.tot.clus <- hclust(vegdist(div.tot, method="euclidean")) #Calcula distância euclidiana para diversidade de OTUs totais div.abund.clus <- hclust(vegdist(div.tot, method="euclidean")) #Calcula distância euclidiana para diversidade de OTUs abundantes div.rare.clus<- hclust(vegdist(div.tot, method="euclidean")) #Calcula distância euclidiana para diversidade de OTUs raras riq.tot.clus <- hclust(vegdist(riqueza.tot, method="euclidean")) #Calcula distância euclidiana para riqueza de OTUs totais riq.abund.clus <- hclust(vegdist(riqueza.tot, method="euclidean")) #Calcula distância euclidiana para riqueza de OTUs abundantes riq.rare.clus <- hclust(vegdist(riqueza.tot, method="euclidean")) #Calcula distância euclidiana para riqueza de OTUs raras } # Plotando dendrogramas de dissimilaridade para diversidade e riqueza de OTUs totais, abundantes e raras par(mfrow = c(2,3)) plot(div.tot.clus, main = "Diversidade: OTUs totais", xlab="", sub="") plot(div.abund.clus, main = "Diversidade: OTUs abundantes", xlab="", sub="") plot(div.rare.clus, main = "Diversidade: OTUs raras", xlab="", sub="") plot(riq.tot.clus, main = "Riqueza: OTUs totais", xlab="", sub="") plot(riq.abund.clus, main = "Riqueza: OTUs abundantes", xlab="", sub="") plot(riq.rare.clus, main = "Riqueza: OTUs raras", xlab="", sub="") par(mfrow = c(1,1)) message("Dendrogramas plotados a partir de índice de dissimilaridade!") return(riqueza.diversidade) # retorna riqueza e índice de diversidade para OTUs totais, abundantes e raras, para cada amostra # FIM da função }
Arquivos da Função:
Função: abund.vs.rare()
Help: Help da Função
Input: Data
Output:
1- Plot: Dendrogramas, 2- Matriz de dados