Conversão de dados de respirometria fechada e intermitente (Berlink-Chauí & Bicudo, 2006) em dados de consumo de oxigênio.
A respirometria intermitente é uma técnica de medida de consumo de oxigênio ideal para artrópodes, pequenos vertebrados (p.e.anfíbios) e outros organismos com baixo consumo de oxigênio. Ela mistura conceitos de respirometria aberta e fechada, através de fluxo de ar e fechamentos intercalados, em intervalos pré-determinados.
O transdutor que detecta o oxigênio apresenta as diferenças de Pressão Parcial de Oxigênio (PPO2) do fluxo de ar que passa por ele e é registrado por um computador através de programa específico de cada equipamento. O resultado apresentado ao usuário é um gráfico que mostra a queda e retorno da [O2] em relação a uma linha de base que representa a pressão encontrada normalmente no ar (~21%). O consumo de oxigênio é obtido pela integral da área sob a curva, corrigida pelo fluxo de ar e tempo de fechamento imediatamente antes da leitura.
A função, além de realizar a conversão de consumo, plota os dados em um gráfico xy do consumo de oxigênio em relação à massa do indivíduo.
Fiz a primeira parte da função: executar as contas e controles de unidades (função “consumo.uni.r”) Estou implementando a mesma função para ser executada em uma tabela com duas colunas: massa e integral. E falta o gráfico também (função “consumo.mult.r”) Não vai dar tempo de fazer a fase III: implementar médias móveis, médias a cada intervalo de tempo, gráficos de consumo para vários dias, em sequencia. Mas continuarei mesmo depois de terminada a disciplina.
Se a proposta for simples para servir como avaliação da disciplina, gostaria de incluir cálculos de escopo (diferença entre o menor e o maior consumo de oxigênio), máximo e mínimo. Talvez incluir ajuste de da curva de registro através de médias móveis.
Engraçado, esta parte me parece mais fácil de implementar, e só isto já daria um belo trabalho final também. Mas minha dúvida é apenas pq não ficou muito claro como vc vai calcular a integral. Se isto for simples, qualquer uma das duas propostas está ótima. Claro, as duas juntas seria melhor ainda
o programa do equipamento “cospe” o valor da integral já , ou seja, não é tão difícil de fazer. A vantagem de usar o R é dar um jeito das pessoas não errarem tanto nas contas e unidades. Pretendo colocar recadinhos do tipo “qual a unidade de tempo vc está usando? segundos ou minutos”, coisas assim. Esse tipo de problema acontece o tempo todo no labs. Sinto também que os cálculos e gráficos ficam mais fáceis de fazer no R. Correções alométricas etc. Na verdade, pretendo fazer tanto o plano A quanto o plano B em algum momento esse ano. Só não acho que tenho habilidade para terminar tudo para a prova :P Ainda não achei um pacote que contenha essas análises (mas pode ser simples imperícia de busca minha he he he). Achei uma chamada “Metabonomic”, mas olhando meio por alto, não parece ser o que preciso. Nem preciso dizer que estou adorando o potencial do R (potencial pq só vou adorar o R quando conseguir fazer as coisas kkkk). Já andei divulgando os tutoriais do curso por aí! Vamos dominar o mundo Obrigada pelos comentários Paulo.
Fiz essa função mais simplezinha como preparativo da função 2, mais complexa.
consumo.uni.r package:nenhum R Documentation Cálculo do consumo de oxigênio obtido através de respirometria fechada Description: Calcula e corrige unidades de valores de consumo obtidos em equipamento respirométrico. Usage: consumo.uni(x,massa,fluxo,tempo,unidd.massa,unidd.tempo) Arguments: x: Vetor numérico. Cálculo da área (integral) sob a curva de queda e retorno às concentrações de oxigênio à linha de base (concentrações do ar atmosférico) obtida com o equipamento respirométrico. Unidade mLO2*minuto. massa: Vetor numérico. Massa do organismo medido com o equipamento respirométrico. O padrão é grama. fluxo: Numérico. Fluxo de ar usado para realizar a medição. Necessário usar o padrão mL por minuto. tempo: Numérico. Tempo em que a câmara respirométrica permaneceu fechada e à qual corresponde a medida de consumo de oxigênio. O padrão é hora. unidd.massa: Caracter. A unidade usada pode ser "miligramas","gramas" e "quilogramas", o resultado é sempre em grama. Se preferir usar outra unidade que não seja grama, use a opção "outra". unidd.tempo: Caracter. A unidade usada pode ser "segundo", "minuto" e "hora", o resultado é sempre em hora. Se preferir usar outra unidade que não seja hora, use a opção "outra". Details: Transforma os dados brutos obtidos através de respirometria fechada ou intermitente em dados de consumo de oxigênio. Os valores geralmente são fornecidos como uma curva de queda e retorno das concentrações de oxigênio tendo como linha de base as concentrações encontradas no ar atmosférico. A partir da integral da área do gráfico resultante do registro obtêm-se o oxigênio consumido no período em que a câmara permaneceu fechada. A função corrige esse valor pelo fluxo e tempo de fechamento fornecendo a medida de consumo de oxigênio. Value: Apresenta na tela uma tabela com a massa do indivíduo, o consumo de oxigênio corrigido e as unidades finais da conversão. Obs : função para cálculos de somente 1 medida por vez. Para cálculos de vetores vide consumo.mult(). massa : a mesma massa fornecida como argumento da função. em : unidade da massa. consumo.O2 : valor do consumo transformado conforme unidades determinadas. por : unidade final do consumo calculado. Warning: Cuidado com as unidades usadas nos cálculos. Ao usar a opção "outra" nos argumentos de unidd.massa e unidd.tempo, preste muita atenção na unidade resultante. Author(s): Tatiana Hideko Kawamoto th.kawamoto@gmail.com References: Chaui-Berlink,J.G. & Bicudo,J.E.P.W. (2006) Respirometria, a técnica, Livraria Santos Editora ISBN 85-7288-576-5 See Also: consumo.mult() Examples: consumo.uni(-0.01288103,0.2,200,1) consumo.uni(-0.01288103,0.2,200,1,unidd.tempo="outra",unidd.massa="quilogramas") consumo.uni(-0.01288103,0.1,150,3,unidd.tempo="outra",unidd.massa="quilogramas")
#1ªsituação: medidas isoladas de consumo. consumo.uni<-function(x,massa,fluxo,tempo,unidd.massa="gramas",unidd.tempo="hora") { { resultado<-matrix(rep(NA,4),nrow=1,ncol=4) rownames(resultado)<- rownames(x) colnames(resultado)<- c("massa","em","consumo.O2","por") { consumo.default=(((abs(x))*fluxo)/(tempo*100))/massa #o valor da integral geralmente é negativo por simples convenção para medidas de consumo. { if(unidd.massa=="gramas"& unidd.tempo=="hora") { consumo=consumo.default resultado[1,1]<-massa resultado[1,2]<-unidd.massa resultado[1,3]<-consumo resultado[1,3]<-paste("hora e gramas") } if(unidd.tempo=="hora") { consumo.tmp=consumo.default } if(unidd.tempo=="minuto") { consumo.tmp=consumo.default*60 } if(unidd.tempo=="segundo") { consumo.tmp=consumo.default*360 } if(unidd.tempo=="outra") { consumo.tmp=consumo.default cat("\t","AVISO: as unidades PADRÂO são tempo em horas e fluxo em mL por minuto. Nessa opção as unidades não são corrigidas. PRESTE ATENÇÃO NAS UNIDADES que usou nos argumentos!\n") } if(unidd.massa=="gramas") { consumo=consumo.tmp } if(unidd.massa=="miligramas") { consumo=consumo.tmp*1000 } if(unidd.massa=="quilogramas") { consumo=consumo.tmp/1000 } if(unidd.massa=="outra") { consumo=consumo.tmp cat("\t","AVISO: a unidade PADRÂO de massa é gramas. Nessa opção as unidades não são corrigidas. PRESTE ATENÇÃO NAS UNIDADES que usou nos argumentos!\n") } resultado[1,1]<-massa resultado[1,2]<-unidd.massa resultado[1,3]<-consumo resultado[1,4]<-paste(unidd.tempo,"e",unidd.massa) }}} return(resultado) }
Fiz essa função mais útil para calcular lista de valores em uma tabela com 2 colunas.
consumo.mult.r package:nenhum R Documentation Cálculo do consumo de oxigênio obtido através de respirometria fechada para vários indivíduos, ou vários tempos do mesmo indivíduo (intermitente). Description: Calcula e corrige unidades de valores de consumo obtidos em equipamento respirométrico. Faz um gráfico xy para os valores obtidos em função da massa, e outro gráfico xlog-ylog, para uma primeira análise visual dos dados. Usage: consumo.mult(x,fluxo,tempo,unidd.massa,unidd.tempo) Arguments: x: data.frame ou matriz numérica. Primeira coluna com a massa dos organismos.O padrão é gramas. Segunda coluna com o cálculo da área (integral) sob a curva de queda e retorno às concentrações de oxigênio à linha de base (concentrações do ar atmosférico) obtida com o equipamento respirométrico. Unidade mLO2*minuto. fluxo: numérico. Fluxo de ar usado para realizar a medição. Necessário usar o padrão mL por minuto. tempo: numérico. Tempo em que a câmara respirométrica permaneceu fechada e à qual corresponde a medida de consumo de oxigênio. O padrão é hora. unidd.massa: Caracter. A unidade usada pode ser "miligramas","gramas" e "quilogramas", o resultado é sempre em grama. Se preferir usar outra unidade que não seja grama, use a opção "outra". unidd.tempo: Caracter. A unidade usada pode ser "segundo", "minuto" e "hora", o resultado é sempre em hora. Se preferir usar outra unidade que não seja hora, use a opção "outra". Details: Transforma os dados brutos obtidos através de respirometria fechada ou intermitente em dados de consumo de oxigênio. Os valores geralmente são fornecidos como uma curva de queda e retorno das concentrações de oxigênio tendo como linha de base as concentrações encontradas no ar atmosférico. A partir da integral da área do gráfico resultante do registro obtêm-se o oxigênio consumido no período em que a câmara permaneceu fechada. A função corrige esse valor pelo fluxo e tempo de fechamento fornecendo a medida de consumo de oxigênio. Quando há mais de um organismo medido, a função plota o resultado em um gráfico de regressão do consumo por massa no animal. Value: Apresenta na tela uma tabela com a massa dos indivíduos, ou do mesmo indivíduo nos diferentes tempos na primeira coluna e o consumo de oxigênio corrigido na segunda coluna. Apresenta também as unidades finais da conversão. Obs : Cálculos de vetores. Para conversões simples e rápidas use também o consumo.uni() título : unidade final do consumo calculado. massa : a mesma massa fornecida como argumento da função. consumo.O2 : valor do consumo transformado conforme unidades determinadas. Warning: Cuidado com as unidades usadas nos cálculos. Ao usar a opção "outra" nos argumentos de unidd.massa e unidd.tempo, preste muita atenção na unidade resultante. Os dados da tabela de entrada precisam estar organizados com os valores de massa na 1ªcoluna e o valor da integral obtido no equipamento na 2ªcoluna. Author(s): Tatiana Hideko Kawamoto th.kawamoto@gmail.com References: Chaui-Berlink,J.G. & Bicudo,J.E.P.W. (2006) Respirometria, a técnica, Livraria Santos Editora ISBN 85-7288-576-5 See Also: consumo.uni() # para cálculos mais rápidos de valores únicos. Examples: massa<-c(0.2000,0.1642,0.2154) integral<-(-0.01288103,-0.009742808,-0.005112421) respiro<-cbind(massa,integral) consumo.mult(respiro,200,1) consumo.mult(respiro,200,1,unidd.tempo="outra",unidd.massa="quilogramas") consumo.mult(respiro,150,3,unidd.tempo="outra",unidd.massa="miligramas")
#2ªsituação: medidas isoladas de consumo de vários indivíduos ou várias medidas do mesmo indivíduo. consumo.mult<-function(x,fluxo,tempo,unidd.massa="gramas",unidd.tempo="hora")# x é uma tabela com 2 colunas (massa e consumo) { resultado<-matrix(rep(NA,dim(x)[1]*2),ncol=2) rownames(resultado)<-rownames(x) colnames(resultado)<-paste(c("consumo","massa")) cat("\t","mL O2 por",unidd.tempo,"e",unidd.massa,"\n") for(i in 1:dim(x)[1]) { consumo.default=(((abs(x[i,2])*fluxo)/(tempo*100))/x[i,1]) if(unidd.massa=="gramas"&unidd.tempo=="hora") { consumo=consumo.default } if(unidd.tempo=="minuto") { consumo.tmp=consumo.default*60 } if(unidd.tempo=="segundo") { consumo.tmp=consumo.default*360 } if(unidd.tempo=="outra") { consumo.tmp=consumo.default cat("\t","AVISO: as unidades PADRÂO são tempo em horas e fluxo em mL por minuto. Nessa opção as unidades não são corrigidas. PRESTE ATENÇÃO NAS UNIDADES que usou nos argumentos!\n") } if(unidd.massa=="miligramas") { consumo=consumo.tmp*1000 } if(unidd.massa=="quilogramas") { consumo=consumo.tmp/1000 } if(unidd.massa=="outra") { consumo=consumo.tmp cat("\t","AVISO: a unidade PADRÂO de massa é gramas. Nessa opção as unidades não são corrigidas. PRESTE ATENÇÃO NAS UNIDADES que usou nos argumentos!\n") } consumo=consumo.default resultado[i,2]<-consumo resultado[i,1]<-x[i,1] } write.table(resultado,file="consumos.mult.csv",sep=",",col.names=NA) par(mfrow=c(1,2)) plot(y=resultado[,1],x=resultado[,2],cex.lab=0.6,cex.main=0.8,tck=0.02,xlab=paste("massa (",unidd.massa,")"),ylab=paste("consumo","(mLO2 por",unidd.tempo,"e",unidd.massa,")"), main="consumo por massa") plot(y=resultado[,1],x=resultado[,2],cex.lab=0.6,cex.main=0.8,tck=0.02,xlab=paste("Log da massa","(",unidd.massa,")"),ylab=paste("Log do consumo","(mLO2 por",unidd.tempo,"e",unidd.massa,")"), main="Log consumo por Log massa", log="xy") return(resultado) }