Atualmente sou mestranda do Programa De Pós-Graduação em Oceanografia Biológica do Instituto Oceanográfico da Universidade de São Paulo, atuando em projetos ligados a trofodinâmica do zooplâncton marinho, com ênfase em interações entre copépodes planctônicos e microalgas potencialmente nocivas.
exercicio_introducao_ao_r_naira.r exercicio_funcoes_matematicas_naira.r exercicio_leitura_e_manipulacao_de_dados_naira_2.r exercicio_analise_exploratoria_de_dados2_naira.r exercicio_teste_de_hipotese_e_simulacao_naira.r exercicio_criacao_de_graficos_naira2.r exercicio_regressoes_simples_naira2.r exercicio_cronstrucao_de_funcoes_simples_naira.r
Criar uma função que calcule a taxa de ingestão de microorganismos em função da concentração de alimento oferecida (resposta funcional), com base em dietas definidas e diferentes equações para estimativas da taxa de ingestão.
A função terá por finalidade receber:
No meu caso estes dados consistem em contagens de amostras de microalgas marinhas no formato de planilhas de Excel extraídas do software COULTER® AccuComp®. As contagens das amostras foram executadas em contador de partículas (Beckman® Z Series). Para cada experimento, isto é, para a determinação de uma única curva de resposta funcional, o número mínimo de planilhas é 270 (90 referentes às contagens iniciais e 180 referentes as contagens após duas incubações de 24h). Cada planilha é composta por colunas com várias variáveis relativas a cada partícula contada. A coluna de interesse apresenta o tamanho de cada partícula contada em µm. A densidade celular deverá ser obtida mediante a seleção das partículas compreendidas dentro do intervalo de tamanho correspondente à dieta oferecida (determinado pelo usuário).
Para o caso da minha dissertação, na qual os experimentos foram executados com copépodes planctônicos marinhos, as concentrações médias nos frascos de incubação (C), as taxas de filtração (F) e as taxas de ingestão (I) são estimadas de acordo com as equações propostas por Frost (1972) e modificadas por Kiørboe et al. (1982), sendo o desaparecimento de partículas nas garrafas experimentais, ao longo do tempo de incubação, contrastado com as concentrações nas garrafas controle.
E retornar:
Aplicação: Tenho feito todas as etapas de processamento dos arquivos em Excel de forma que para cada planilha é necessário extrair a coluna referente ao tamanho das partículas, selecionar o intervalo de contagem mais adequado, calcular as densidades médias para cada amostra (cada amostra é contada de três a seis vezes no equipamento), calcular a densidade média para cada tratamento (considerando três réplicas) e inserir as médias finais nas equações. A função me ajudaria a reprocessar alguns experimentos e confirmar os padrões obtidos, além de possiblitar a finalização de três experimentos ainda não processados (três conjuntos de 270 planilhas ). O equipamento tem sido usado com rotina no laboratório e acredito que esta função também poderá ser útil para outros alunos. Não sei se é possível, mas minha idéia é que a função seja flexível para outras equações de ingestão e para diferentes tipos de experimentos, de forma que os conjuntos de dados I e II também possam ser ajustados.
FROST, B. W. 1972. Effects of size and concentration of food particles on the feeding behavior of the marine planktonic copepod Calanus pacificus. Limnol. Oceanogr., 17(6): 805- 815.
KIØRBOE, T.; MØHLENBERG, F.; NICOLAJSEN, H. 1982. Ingestion rate and gut clearance in the planktonic copepod Centropages hamatus (Lilljeborg) in relation to food concentration and temperature. Ophelia, 21(2): 182-194.
O Plano B tem como principal objetivo aprimorar a função Curvas de crescimento idealizada por uma colega de laboratório que foi aluna da turma de 2011 da disciplina BIE5782. A função elaborada recebe planilhas de contagens em contador de partículas (.csv), calcula as médias das contagens para cada dia e retorna a curva de crescimento para uma determinada microalga marinha. A idéia para o plano B consiste em aprimorar esta função conforme as seguinte ideias:
Alterações na entrada de dados:
Alteração na saída de dados:
As duas propostas estão bem interessantes. Facilitarão tarefas trabalhosas e podem ser utilizadas em outros estudos e experimentos. Minha única preocupação é que podem dar bastante trabalho e o prazo pode não ser suficiente para que você as termine. Se escolher a proposta A (que eu recomendo pelo fato de ser nova) sugiro começar com a equação mais simples, deixando outras equações e a automatização dos testes estatísticos para depois.
Como previsto pelo Leo eu consegui finalizar apenas uma função que calcula a taxa de ingestão para uma equação padrão (Frost, 1972), mas não deu tempo de modificar a função para aplicação de outras equações. Em relação à automatização dos testes estatísticos, eu consegui escrever um scrip complementar que recebe a saída da função principal (Função INGESTION) e testa a diferença entre as médias calculadas para cada tratamento, mas não deu tempo de tentar unificar as duas funções. Deste modo, estou inserindo esta parte como um script complementar (STAT_IR).
INGESTION <- function(EXP.LIST, REPLICATES1, REPLICATES2, DATA) { install.packages("plotrix") require(plotrix) ALL.FILES <- list(file=NULL) for (i in 1:length(EXP.LIST)){ x <- read.table(EXP.LIST[i], skip=37, nrows=255, header=TRUE, sep="\t") x1 <- data.frame(x) ALL.FILES[i] <- list(x1) } if(DATA$algae[1] == "FLA") ED <- 0.11 #Fator de convercao para algas flageladas; else ED <- 0.13 #Fator de conversao para dinoflagelados; NT <- (DATA$f.start + DATA$f.end)/2 DATE1 <- rep("2012-04-19", times=15) TIME1 <- paste(DATE1, DATA$start) TIME.START<- strptime(TIME1, "%Y-%m-%d %H:%M:%S") DATE2 <- rep("2012-04-20", times=15) TIME2 <- paste(DATE2, DATA$end) TIME.END <- strptime(TIME2, "%Y-%m-%d %H:%M:%S") TIMES <- difftime(TIME.END, TIME.START, units="hours") TIMES <- as.numeric(TIMES) #Intervalo de incubação de cada uma das garrafas experimentais; ALL.CONCENTRATIONS <- rep(0, each= length(ALL.FILES)) for(i in 1:length(ALL.FILES)){ #Corre a lista de que contemn todos os arquivos; x3 <- sum(ALL.FILES[[i]]$X.mL[ALL.FILES[[i]]$um<(DATA$d.upper[1]) & ALL.FILES[[i]]$um>(DATA$d.lower[1])]) #Extrai as densidades dentro do intervalos de tamanho desejado para cada um dos arquivos; ALL.CONCENTRATIONS[i] <- x3 #Armazena as densidades extraidas em um novo vetor; } MEAN.CONCENTRATIONS <- rep(0, each= length(REPLICATES1)) COEFF.VAR.CONCENTRATIONS <- rep(0, each= length(REPLICATES1)) a=1 b=REPLICATES1[1] for(i in 1:length(REPLICATES1)){ #Corre o vetor "REPLICATES1" para preenchimento do vetor "ALL.DENSITIES" de acordo com as posicoes adequadas; x4 <- mean(ALL.CONCENTRATIONS[a:b]) x5 <- (sd(ALL.CONCENTRATIONS[a:b])/x4)*100 MEAN.CONCENTRATIONS[i] <- x4*ED*(DATA$biov[1])*(DATA$fc[1]) #Converte as medias para valores em umg/L e armazena em um novo vetor; COEFF.VAR.CONCENTRATIONS[i] <- x5 a=b+1 i=i+1 b=a+REPLICATES1[i]-1 } CONC.INICIAL.MEAN <- rep(0, each=5) CONC.CONTROL.MEAN <- rep(0, each=5) ia=1 ib=REPLICATES2[1] ca=4 cb= ca + REPLICATES2[2] -1 for(i in 1:5){ x6 <- mean(MEAN.CONCENTRATIONS[ia:ib]) x7 <- mean(MEAN.CONCENTRATIONS[ca:cb]) CONC.INICIAL.MEAN[i] <- x6 CONC.CONTROL.MEAN[i] <- x7 ia <- ib + REPLICATES2[i*3-1] + REPLICATES2[i*3] + 1 #Atualiza os indices ia e ib: posicao anterior mais a soma dos dados compreendidos no vetor ca <- cb + REPLICATES2[i*3] + REPLICATES2[i*3+1] + 1 #MEAN.CONCENTRATIONS que correspondem as posicoes no vetor REPLICATES2 (anda no vetor i = i + 1 #MEAN.CONCENTRATIONS de acordo com um numero ditado pelo vetor REPLICATES2) ib <- ia + REPLICATES2[i*3-2] - 1 cb <- ca + REPLICATES2[i*3-1] - 1 } TEM <- c(MEAN.CONCENTRATIONS[7:9], MEAN.CONCENTRATIONS[16:18], MEAN.CONCENTRATIONS[25:27],MEAN.CONCENTRATIONS[34:36], MEAN.CONCENTRATIONS[42:44]) TREAT <- c(CONC.INICIAL.MEAN[1], CONC.INICIAL.MEAN[1], CONC.INICIAL.MEAN[1], #OBS.: Esta parte eu tentei simplificar com a função "rep", CONC.INICIAL.MEAN[2], CONC.INICIAL.MEAN[2], CONC.INICIAL.MEAN[2], #mas não consegui, nem atravez do "each",nem atravez do "times"; CONC.INICIAL.MEAN[3], CONC.INICIAL.MEAN[3], CONC.INICIAL.MEAN[3], CONC.INICIAL.MEAN[4], CONC.INICIAL.MEAN[4], CONC.INICIAL.MEAN[4], CONC.INICIAL.MEAN[5], CONC.INICIAL.MEAN[5], CONC.INICIAL.MEAN[5]) CONT <- c(CONC.CONTROL.MEAN[1], CONC.CONTROL.MEAN[1], CONC.CONTROL.MEAN[1], CONC.CONTROL.MEAN[2], CONC.CONTROL.MEAN[2], CONC.CONTROL.MEAN[2], CONC.CONTROL.MEAN[3], CONC.CONTROL.MEAN[3], CONC.CONTROL.MEAN[3], CONC.CONTROL.MEAN[4], CONC.CONTROL.MEAN[4], CONC.CONTROL.MEAN[4], CONC.CONTROL.MEAN[5], CONC.CONTROL.MEAN[5], CONC.CONTROL.MEAN[5]) IR=rep(0,each=15) j=1 for(i in 1:15){ x8 <- (((TEM[i] - TREAT[i]) / (log(TEM[i] / TREAT[i]))) * (((DATA$vol[1])/NT[j]) * log((TREAT[i] * CONT[i])/(TREAT[i] * TEM[i]))))/TIMES[j] #Equacao de ingestao (FROST, 1972) adaptadas por KIØRBOE et al. (1982); j = j+1 IR[i] <- x8 } RESUMO.IR <- summary(IR) RESUMO.IR$Sd <- sd(IR) IR.POS <- c() for(i in 1:15){ if(IR[i] >= 0) IR.POS[i] <- IR[i] } IR.POSITIVE <- as.vector(na.exclude(IR.POS)) RESUMO.IR.POSITIVE <- summary(IR.POSITIVE) RESUMO.IR.POSITIVE$Sd <- sd(IR) RESUMO.TOT <- data.frame(RESUMO.IR, RESUMO.IR.POSITIVE) RESULT <- data.frame(TREAT,IR) IR.MEAN <- (tapply(RESULT$IR, RESULT$TREAT, mean)) IR.SD <- (tapply(RESULT$IR, RESULT$TREAT, sd)) IR.STD.ERROR <- tapply(RESULT$IR, RESULT$TREAT, std.error) RESUMO.MEANS <- data.frame(IR.MEAN, IR.SD, IR.STD.ERROR) C <- rep(1:5, each=3) RESULT.STAT <- data.frame(C,IR) X11() par(mfrow = c(1,2)) plot(RESULT, xlab=expression("Concentração de alimento (µg C L"^"-1"*")"), ylab=expression("Resposta funcional (µg C copepode"^"-1 "*"dia"^"-1"*")"), xlim=c(0,450), ylim=c(-0.2,0.6), pch=19, bty="L") text(x=380, y=0.6, "A", font=2) text(x=380, y=0.55, DATA$EXP[1]) CONC.MEAN.INC <- sort(CONC.INICIAL.MEAN) RESULT2 <- data.frame(CONC.MEAN.INC, IR.MEAN) plot(RESULT2, xlab=expression("Concentração de alimento (µg C L"^"-1"*")"), ylab="", xlim=c(0,450), ylim=c(-0.2,0.6), pch=19, bty= "L") text(x=380, y=0.6, "B", font=2) text(x=380, y=0.55, DATA$EXP[1]) for(i in 1:5){ arrows(CONC.MEAN.INC[i],IR.MEAN[i]+IR.STD.ERROR[i], CONC.MEAN.INC[i], IR.MEAN[i]-IR.STD.ERROR[i], angle=90, code=3, length=0) } savePlot("RESPOSTA FUNCIONAL", type="jpeg") write.csv(RESUMO.TOT, file= "RESUMO.TOT.csv") write.csv(RESULT, file= "INGESTION.csv") write.csv(RESULT.STAT, file = "INGESTION.STAT.csv") } ###ENTRADAS DA FUNCAO IR######################################## ###EXEMPLO: EXPERIMENTO COM A MICROALGA RHODOMONAS CF. SALINA### EXP.LIST <- list.files(pattern="\\.XLS$") REPLICATES1 <- rep(1, each=44) REPLICATES2 <- c(rep(3, times=13), 2, 3) DATA <- read.csv("DATA.txt", sep="\t") ################################################################# INGESTION (EXP.LIST, REPLICATES1, REPLICATES2, DATA)
modelo package:unknown R Documentation
Calcula da Taxa de Ingestão de microorganismos (ex.: microcrustáceos marinhos) incubados em microcosmos
Description:
INGESTION calcula um vetor de valores correspondentes à taxa de ingestão de cinco tratamentos (número usual em experimentos de incubação do mesmo gênero na literatura)
Usage:
INGESTION (LISTA, REPLICATES1, REPLICATES2, DATA)
Arguments:
EXP.LIST: Um vetor de caracteres; um vetor contendo os nomes dos arquivos de leitura (.XLS/.CSV/.TXT) provenientes preferencialmente de contadores automáticos de partículas (ex. .Z2 exportados para .XLS/.CSV/.TXT); REPLICATES1: Um vetor de números; um vetor contendo o número de vezes que cada uma das amostras foi analisada/ numero de arquivos correspondentes a uma mesma amostra/ numero de subamostragens de cada amostra; REPLICATES2: Um vetor de números; contendo o número de réplicas adotadas para frascos correspondentes às concentrações iniciais, frascos controles (sem organismos) e frascos experimentais (com organismos); DATA: Um data.frame; data.frame contendo as seguintes colunas: - EXP; designação do experimento sob análise; -algae; algae=FLA para microalgas flageladas e algae=DIN para dinoflagelados; -d.upper; diametro superior do espectro de distribuição de tamanho da microalga empregada; -d.lower; diâmetro inferior do espectro de distribuição de tamanho da microalga empregada; -biov; biovolume medio da microalga empregada; -vol; volume da garrafa de incubação empregada; -fc; fator de correção da unidade de concentração dos itens alimentares (conversão das densidades dos itens alimentares, em cel.mL conforme padrão dos arquivos sob análise, para cel.L, conforme padrão mais empregado na literatura sob o tema; -f.star; número de fêmeas incubadas em cada garrafa; -f.end; número de fêmeas ao final das incubações;
-star; horário no qual foram iniciadas as incubações;
Details:
O experimento de determinação da taxa de ingestão (resposta funcional) de microorganismos corresponde, em resumo, à incubação de um número conhecido de microorganismos em garrafas (garrafas experimentais) por um determinado intervalo de tempo (período de incubação). A taxa será então calculada a partir da densidade dos itens alimentares após o final da incubação subtraída da densidade inicial (frascos iniciais) e corrigida pela determinação do crescimento dos itens alimentares ao final da incubação (obtida através da incubação simultânea de frascos controles). Sob este desenho experimental podem ser incubados diferentes organismos, diferentes itens alimentares e aplicadas distintas concentrações de itens alimentares com números de réplicas desejados. A função INGESTION se adapta a diferentes itens alimentares e diferentes números de réplicas, porém foi ajustada para apenas 5 tratamentos, número frequentemente aplicado na literatura.
Os vetores REPLICATES 1 e 2 permitem que experimentos com diferentes números de réplicas e diferentes números de contagens para cada réplica sejam igualmente processados.
Value:
Retorna uma lista de objetos:
comp1 : .csv1; list (summary1; análise explorária aplicada a todos os dados de ingestão); (summary2; análise explorária aplicada somente aos dados de ingestão positivos); comp2: .csv2; data.frame (Tratamentos/Concentrações, Taxa de Ingestão - (TREAT, IR));
comp3 : .csv3; data.frame (Tratamentos/Concentrações, Taxa de Ingestão - (C, IR)) para utilização na função STAT_IR (valores numeros relativos aos tratamentos impressos como fatores (Tratamentos 1 a 5);
comp4 : plot; plot1 de todos os valores de IR em funcao dos tratamentos (dispersao) e plot2 dos valores medios de IR em funcao dos tratamentos com seus respectivos desvios;
Author(s):
Naira Juliana da Silva
References:
Fatores aplicados para conversão do biovolume para unidades de carbono para microalgas flageladas e dinoflagelados: EDLER, L. 1979. Recommendations on methods for marine biological studies in the Baltic Sea. Phytoplankton and chlorophyll. The Baltic Marine Biologists, Publications No 5.
Equação para cálculo da taxa de ingestão de microorganismos:
FROST, B. W. 1972. Effects of size and concentration of food particles on the feeding behavior of the marine planktonic copepod Calanus pacificus. Limnol. Oceanogr., 17(6): 805- 815.
KIØRBOE, T.; MØHLENBERG, F.; NICOLAJSEN, H. 1982. Ingestion rate and gut clearance in the planktonic copepod Centropages hamatus (Lilljeborg) in relation to food concentration and temperature. Ophelia, 21(2): 182-194.
Examples:
#Rhodomonas cf. salina experiment - flagelate microalgae#
INGESTION(EXP.LIST = list.files(pattern=“\\.XLS$”),
REPLICATES1 ← rep(1, each=44) REPLICATES2 ← c(rep(3, times=13), 2, 3) DATA = read.csv("DATA.txt", sep="\t"))