Índice
- O Curso R
-
- Tutoriais
-
- Apostila
-
- 6. Testes de Hipótese (em preparação!)
- Exercícios
-
- Material de Apoio
-
- Área dos Alunos
-
- Cursos Anteriores
-
IBUSP
Outras Insitutições
Linques
Visitantes
Outras Insitutições
Mestranda em Ecologia (IB - USP) Orientada pelo Dr. Glauco Machado. Nosso objetivo é tentar dominar o mundo. Enquanto isso não acontece nos divertimos estudando comportamento de opiliões.1)
O método de marcação e recaptura é usado em estudos populacionais para estimar parâmetros como o tamanho da população, a mortalidade e as taxas de migração. Na ecologia comportamental esse método também possibilita a compreensão do sistema de acasalamento em uma população, através de comparações entre os deslocamentos de machos e fêmeas ou os deslocamentos entre indivíduos do mesmo sexo. Por exemplo, se as fêmeas se deslocam menos do ques os machos, podemos pensar em hipóteses sobre a territorilidade das fêmeas e escolha dos sítios de reprodução. Se entre os machos de uma população existe uma diferença significativa dos deslocamentos, podemos pensar em hipóteses sobre diferenças morfológicas ou comportamentais dentro de uma mesma população.
O Objetivo da função
Calcular a distância percorrida por cada indivíduo, a média e a moda.
Dependendo do conteúdo e formato dos dados de entrada, estimar esses parâmetros pode ser uma tarefa banal. Inclua na função algum teste de hipótese entre grupos. Por exemplo: teste de hipótese se o deslocamento entre dois níveis (machos e femeas) de um fator apresentam diferenças na média ou na moda. Acho que poderia faze-lo utilizando técnicas de monte carlo. — Alexandre Adalardo de Oliveira 2010/03/31 09:42
rwalker package:nenhum R Documentation Diferenças de deslocamento e Índice de Residência de machos e fêmeas Description: Usando uma tabela com dados de captura e recaptura calcula a diferença entre os deslocamentos de machos e fêmeas e utiliza o Método de Monte Carlo para testar se essa diferença é significativa.Gera matrizes com as modas dos locais de recaptura e os Índices de Residência para cada indivíduo. Usage: rwalker(x, hipotese="both", RI=T) Arguments: x: um objeto da classe data.frame contendo os locais de captura e recaptura dos indivíduos. hipotese: lógico, indicando se o teste de hipóteses será bicaudal (H1), unicaudal (H2) ou ambos (both). RI: lógico, indicando quando é desejável que os Índices de Residência sejam calculados. Details: Peculiaridades do data.frame (x) O data.frame com os dados a serem analisados precisa ser construído da seguinte forma: Cada linha corresponde a um indivíduo. A primeira coluna deve ser um vetor com dois níveis de um fator: M e F, para machos e fêmeas respectivamente. A segunda coluna deve ser de identificação dos indivíduos e portanto deverá ser indicada como row.names se a tabela for importada. As colunas seguintes devem conter apenas números que representem os locais de captura e recaptura, para que possam ser calculadas as distâncias entre eles. Os deslocamentos serão calculados como o somatório das diferenças entre o local de captura na coluna t e o local de recaptura na coluna t+1. Quando o indivíduo não foi capturado (ou recapturado) este evento deverá representado por NA. Cáluclo da moda Para calcular as modas dos locais de recaptura é usada a função Mode() que pertence ao pacote prettyR. Portanto será necessário baixar e instalar esse pacote. Simulação Monte Carlo Para testar a hipótese de que a diferença das médias do deslocamento de machos e fêmeas não é gerada ao acaso ("H1") e/ou que o deslocamento dos machos é maior do que o das fêmeas ("H2"). Número de simulações=1000 Índices de Residência O ìndice de residência (RI) é calculado pela equação: (N/n)*100, onde N é o número de vezes que um indivíduo foi recapturado no local que representa a moda, ou seja, o local de maior frequência de recaptura, e n representa o número de vezes que cada indivíduo foi recapturado durante o período de estudo. Quando um indivíduo nunca é recapturado duas vezes no mesmo lugar o RI tende a zero e quando o indivíduo é recapturado 100% das vezes no mesmo local o RI tende a 1. Value: Retorna um histograma da frequência das diferenças entre os deslocamentos médios de machos e fêmeas, geradas pela simulação. No caso do teste bicaudal, as linhas vermelhas marcam a diferença observada e a diferença observada*(-1). No teste unicaudal a linha vermelha marca a diferença observada. O argumento hipotese alimentado por "H1" retorna uma lista com os valores da diferença observada (Dif.obs) e a probabilidade (P1) calculada coma simulação para o teste bilateral. Quando alimentado por "H2" retorna uma lista com os valores Dif.obs e a probabilidade (P2) calculada para o teste unilateral. Alimentado por "both" retorna uma lista com Dif.obs, P1 e P2. Quando o argumento RI=T, os índices de residência para machos e fêmeas são calculados e apenas as quatro primeiras linhas das matrizes contendo os índices são mostradas no console. Retorna uma lista com os valores das médias de deslocamentos para machos e fêmeas, e mostra as quatro primeiras linhas das matrizes que contem a moda. Warning: Se o pacote prettyR não estiver instalado a função retornará uma mensagem de erro. Se o pacote prettyR estiver instalado mas não estiver carregado a funçãom retornará a mensagem: "Erro em match.fun(FUN) : objeto 'Mode' não encontrado" Se houver casos em que há mais de uma moda para o mesmo indivíduo a função retornará a mensagem: ">1 mode". Author(s): Rachel Miranda Werneck References: http://ecologia.ib.usp.br/bie5782/doku.php?id=bie5782:02_tutoriais:start Zatz C, Werneck RM, Macías-Ordóñez R, Machado G. Sexual selection on male weaponry in two neotropical harvestmen (Arachnida: Opiliones) Examples: ### Instalar e carregar o pacote prettyR install.package("prettyR") library(nome do pacote) ##criando dados a<-as.numeric(c("S",1,5,8,10,5,"NA","NA","NA","NA","NA","NA","NA","NA","NA","NA","NA")) b<-as.numeric(c("S",2,6,6,6,7,"NA","NA","NA","NA","NA","NA","NA","NA","NA","NA","NA")) c<-as.numeric(c("S",3,105,102,103,110,109,109,"NA","NA","NA","NA","NA","NA","NA","NA","NA")) d<-as.numeric(c("S",4,24,20,24,21,14,12,11,4,5,5,8,6,6,6,6)) e<-as.numeric(c("S",5,"NA","NA","NA","NA",10,11,10,12,12,10,12,"NA","NA","NA","NA")) f<-as.numeric(c("S",6,91,94,84,84,86,85,"NA","NA","NA","NA","NA","NA","NA","NA","NA")) S<-sample(c(rep("M", 3), rep("F",3))) D<-matrix(c(a,b,c,d,e,f), nrow=6, byrow=T) desloc<-as.data.frame(D) row.names(desloc)<-desloc[,2] desloc[,1]<-S #usando a função rwalker(desloc) rwalker(desloc, "H2", RI=F)
rwalker<-function(x, hipotese="both", RI=T) { pacotes_instalados<-rownames(installed.packages()) vetor_logico<-pacotes_instalados=="prettyR" s_logico<-sum(vetor_logico) if (s_logico==0) { print("Erro: Sistema não possui pacote preetyR") } else { macho<-x[x[,1]=="M",] femea<-x[x[,1]=="F",] deslocF<-abs(apply(femea[,2:dim(femea)[2]],1,FUN=diff,lag=1,byrow=T,na.rm=T)) deslocM<-abs(apply(macho[,2:dim(macho)[2]],1,FUN=diff,lag=1,byrow=T,na.rm=T)) D.F<-apply(deslocF,2,sum,na.rm=T) D.M<-apply(deslocM,2,sum,na.rm=T) media.D.F<-mean(apply(deslocF,2,sum,na.rm=T)) media.D.M<-mean(apply(deslocM,2,sum,na.rm=T)) moda.F<<-matrix(apply(femea,1,Mode),ncol=1,nrow=dim(femea)[1],byrow=T) colnames(moda.F)<-("Moda") rownames(moda.F)<-paste(rownames(femea)) moda.M<<-matrix(apply(macho,1,Mode),ncol=1,nrow=dim(macho)[1],byrow=T) colnames(moda.M)<-("Moda") rownames(moda.M)<-paste(rownames(macho)) mf<-c(D.M,D.F) difer.media<-media.D.M-media.D.F ## Índice de Residência ###Fêmeas f.F<-as.matrix(femea[,2:dim(femea)[2]]) FreqF<-as.matrix(NA,ncol=1,nrows= dim(f.F)[1]) for (i in 1:dim(f.F)[1]) { FreqF[i]<-max(table(f.F[i,]))#nro de vezes que cada indivíduo foi recaptura no local da moda RIF<- as.matrix(rep(NA),nrows=length(FreqF)) for (i in 1:length(FreqF)) { RIF[i]<-((FreqF[i]/sum(table(f.F[i,])))*100) } } ###Machos f.M<-as.matrix(macho[,2:dim(macho)[2]]) FreqM<-as.matrix(NA,ncol=1,nrows= dim(f.M)[1]) for (i in 1:dim(f.M)[1]) { FreqM[i]<-max(table(f.M[i,]))#nro de vezes que cada indivíduo foi recaptura no local da moda RIM<- as.matrix(rep(NA),nrows=length(FreqM)) for (i in 1:length(FreqM)) { RIM[i]<-((FreqM[i]/sum(table(f.M[i,])))*100 ) } } mRIF<<-as.matrix(RIF) colnames(mRIF)<-("Indice de Residencia Femeas") rownames(mRIF)<-paste(rownames(femea)) mRIM<<-as.matrix(RIM) colnames(mRIM)<-("Indice de Residencia Machos") rownames(mRIM)<-paste(rownames(macho)) #Monte Carlo sexo=c(rep("M",length(D.M)),rep("F",length(D.F))) dif.mf=diff(tapply(mf,sexo,mean)[]) result<-rep(0,1000) result[1]<-diff(tapply(mf,sexo,mean)[]) for(i in 2:1000) { dif.dados=diff(tapply(sample(mf),sexo,mean)[]) result[i]<-dif.dados } if (hipotese=="H1")#H1: Há diferença entre o deslocamento de machos e fêmeas. Teste bicaudal { H1=sum(result>=result[1]| result<=(result[1]*-1)) p.H1=H1/length(result) LH1<-list(difer.media,p.H1) names(LH1)<-c("Dif.obs", "P1") if (RI==T) { print(list(head(mRIF),head(mRIM))) print(LH1) hist(result,main="", xlab="Diferenças entre as médias dos deslocamentos (Macho-Femea)", ylab="Frequências") abline(v = result[1], col="red") abline(v = result[1]*-1, col="red") } if (RI==F) { print(LH1) hist(result,main="", xlab="Diferenças entre as médias dos deslocamentos (Macho-Femea)", ylab="Frequências") abline(v = result[1], col="red") abline(v = result[1]*-1, col="red") } } if (hipotese=="H2")#H2: Machos se deslocam mais do que fêmeas. Teste unicaudal { H2=sum(result>=result[1]) p.H2=H2/length(result) LH2<-list(difer.media, p.H2) names(LH2)<-c("Dif.obs","P2") if (RI==T) { print(LH2) print(list(head(mRIF),head(mRIM))) hist(result,main="", xlab="Diferenças entre as médias dos deslocamentos (Macho-Femea)", ylab="Frequências") abline(v = result[1], col="red") } if (RI==F) { print(LH2) hist(result,main="", xlab="Diferenças entre as médias dos deslocamentos (Macho-Femea)", ylab="Frequências") abline(v = result[1], col="red") } } if (hipotese=="both") { H1=sum(result>=result[1]| result<=(result[1]*-1)) p.H1=H1/length(result) H2=sum(result>=result[1]) p.H2=H2/length(result) L<-list(difer.media,p.H1, p.H2) names(L)<-c("Dif.obs", "P1", "P2") if (RI==T) { hist(result,main="", xlab="Diferenças entre as médias dos deslocamentos (Macho-Femea)", ylab="Frequências") abline(v = result[1], col="red") abline(v = result[1]*-1, col="red") print(L) print(list(head(mRIF),head(mRIM))) } if (RI==F) { hist(result,main="", xlab="Diferenças entre as médias dos deslocamentos (Macho-Femea)", ylab="Frequências") abline(v = result[1], col="red") abline(v = result[1]*-1, col="red") print(L) } } { cat(' A função gerou matrizes separadas para machos e fêmeas, com a moda do local de recaptura e os índices de residência para cada indivíduo. Para consultar essas matrizes forneça o nome do objeto: moda.F : matriz com os valores da moda para as fêmeas moda.M : matriz com os valores da moda para os machos mRIF: matriz com os índices de residência das fêmeas mRIM: matriz com os índices de residência dos machos\n\n\n ') { resumo<-list(media.D.F, media.D.M, head(moda.F),head(moda.M)) names(resumo)<-c("Deslocamento médio F", "Deslocamento médio M", "Moda F", "Moda M") print(resumo) } { cat('\n "KEEP WALKING"\n RWalker\n') } } } }
Aos professores, “May the force be with you”. Aos monitores (um 'tks' especial pro Fábio que desenhou quando eu precisei ) . Aos coleguinhas. Ao Musgo pelos seus 20 minutos de vida, help's, conselhos e críticas (Monkey work!). Aos amigos que compreenderam a mudança de comportamento e de linguagem. Ao Dr. Glauco Machado pela “Pergunta Fundamental da Vida, do Universo e Tudo Mais”.