Traduções desta página:

Ferramentas do usuário

Ferramentas do site


05_curso_antigo:r2019:alunos:trabalho_final:mariana.santos.martins:monitorar

monitoraR

monitoraR <- function(lat,long, dia.inicio, dia.final, destfile, graph=T ){
  
  longitude= round(abs(long) +180, digits=1) #soma o valor de longitude a 180 e arredonda para 1 casa decimal, pois eh requisito do modelo WaveWatch para baixar os dados - modelo usa longitude em graus leste 
  lat= round(lat, 1) #arredonda latitude para 1 casa decimal - requisito do modelo
  if(lat>3 | lat<(-34)){
    stop('Latitude precisa ser um numero em graus decimais entre 3N e 33S.')
  } #verificando  se os valores de latitude estao dentro dos limites norte e sul da costa brasileira
  
  #verificando se os valores de longitude estao na metade oeste do globo
  if (longitude <180 & longitude>270)
    stop("Longitude deve ser um valor para a costa brasileira")
  
  dia.inicio <- as.Date(dia.inicio, format="%Y-%m-%d") #le o argumento dia.inicio colocado pelo usuario como data no formato YYYY-MM-DD - necessario para baixar os dados
  dia.final <- as.Date(dia.final, format="%Y-%m-%d") #le o argumento dia.final colocado pelo usuario como data no formato YYYY-MM-DD - necessario para baixar os dados
  dif.datas <- dia.final - dia.inicio #calcula o intervalo de dias entre dos dias escolhidos pelo usu?rio
  if (dif.datas>6){
    stop("dia.inicio e dia.final devem ter intervalo de no maximo 6 dias")
  } #verifica se os intervalos de dados estao dentro do limite maximo do modelo
  
  message('Escolha os parametros dentre opcoes fornecidas, digitando diretamente no console (atentar letras maiusculas e minusculas), ao final das proximas 2 frases') #mensagem para facilitar o entendimento do usuário
  estado.BR <- readline("Escolha qual estado brasileiro se encontra a praia, dentre as opcoes fornecidas.\n (AM/PA/MA/PI/CE/RN/PB/PE/AL/SE/BA/ES/RJ/SP/PR/SC/RS)") #usuario escolhe dentre as opcoes dadas o estado brasileiro onde se encontra a praia de interesse
  if(estado.BR!="AM" & estado.BR!="PA" & estado.BR!="MA" & estado.BR!="PI" & estado.BR!="CE" & estado.BR!="RN" & estado.BR!="PB" & estado.BR!="PE" & estado.BR!="AL" & estado.BR!="SE" & estado.BR!="BA" & estado.BR!="ES" & estado.BR!="RJ" & estado.BR!="SP" & estado.BR!="PR" & estado.BR!="SC" & estado.BR!="RS"){
    stop('Sua praia DEVE ESTAR localizada em um estado brasileiro costeiro.')
  } #verificando se o usuario escolheu certo a sigla do estado dentre as opcoes oferecidas
  
  grao.carac <- readline("Escolha a caracteristica do grao na praia escolhida, dentre as opcoes fornecidas. \n (AreiaG/AreiaM/AreiaF/AreiaMF) \n" ) #usu?rio escolhe dentre as opcoes a caracteristica do grao da praia escolhida
  if(grao.carac!="AreiaG" & grao.carac!="AreiaM" & grao.carac!="AreiaF" & grao.carac!="AreiaMF"){
    stop('Caracteristicas do grao fora das opcoes possiveis.')
  } #verificando se o usuario escolheu dentre as opcoes possiveis
  
  #codigo efetivo da funcao:
  link <- paste(paste0("https://coastwatch.pfeg.noaa.gov/erddap/griddap/NWW3_Global_Best.csv?Tper[(",dia.inicio,"):1:(",dia.final,")][(0.0):1:(0.0)][(",lat,"):1:(",lat,")][(",longitude,"):1:(",longitude,")]"), paste0("Thgt[(",dia.inicio,"):1:(",dia.final,")][(0.0):1:(0.0)][(",lat,"):1:(",lat,")][(",longitude,"):1:(",longitude,")]"), sep=",")  #gerando link, a partir dos argumentos inseridos pelo usuario, para baixar o dataframe direto da internet
  
  download.file(url= link, destfile=destfile) #baixando os dados e salvando no destfile escolhido pelo usuario
  Ondas<-read.csv(file=destfile, header=T, skip=2, sep=",", col.names = c("data", "prof", "lat", "long", "T", "Hprof")) #reorganizando os dados baixados e renomeando como Ondas
  
  Ondas$Hrasa <- (9.8 * Ondas$Hprof)^0.5 #cria umaa coluna com as informacoes de altura de ondas em aguas rasas a partir da equacao de conversao Hrasa = sqrt(gravidade * Hprof)
  
  Grao <- data.frame(c("AreiaG", "AreiaM", "AreiaF", "AreiaMF"), c(0.1, 0.043, 0.024, 0.009)) #criacao do data frame Grao que armazena as velocidades de decantacao dos diversos tipos de areia
  colnames(Grao) = c("nomes", "Ws") #nomeia as colunas do dataframe Grao
  
  MareBR <- data.frame(c("AM", "PA", "MA", "PI", "CE", "RN", "PB", "PE", "AL", "SE", "BA", "ES", "RJ", "SP", "PR", "SC", "RS"), c(7, 6.5, 6.5, 4.25, 4.25, 4.25, 2.5, 2.5, 2.5, 2.5, 2.5, 2.5, 2, 1.5, 1.5, 1.5, 0.25)) #criacao do data frame MareBR que armazena a relacao da amplitude de mare em cada estado costeiro brasileiro
  colnames(MareBR) = c("nomes.estados", "TR") #nomeia as colunas do dataframe MareBR
  Hrasa.m <- mean(Ondas$Hrasa) #calcula a media de altura de onda em aguas rasas para todo o intervalo de dias escolhido
  RTR <- MareBR[MareBR$nomes.estados== estado.BR, 2] / Hrasa.m #calculo da relacao entre amplitude de mare do estado em que se localiza a praia (a partir de indexacao) e altura de onda media calculada no intervalo
  
  #controle de fluxo da funcao: praias dominadas por mare (RTR >10) nao eh possivel usar a funcao para calcular o estagio de praia e o fator de risco de corrente de retorno, apenas para praias dominadas por ondas e dominadas por ondas e mare
  if (RTR>10){
    stop("Praia dominada por mare, nao eh possivel calcular estagio praial")
  } #caso RTR>10, para a funcao se a praia for dominada por mare
  if (RTR<3){
    message('Praia dominada por onda, "\n')
  }#retorna a mensagem para o usuario das forcantes que regem a praia a depender do RTR
  if (RTR>3 & RTR<10){
    message('Praia dominada por onda e mare', "\n")
  } #retorna a mensagem para o usuario das forcantes que regem a praia, a depender do RTR
  
  Hrasa.m.dia <- rep(NA, dif.datas) #cria vetor de NA do tamanho do intervalo de datas para armazenar a altura media diaria de onda a ser calculada
  T.m.dia <- rep (NA, dif.datas) #cria vetor de NA do tamanho do intervalo de datas para armazenar a media diaria do periodo de onda 
  omega <- rep(NA, dif.datas) #cria vetor de NA do tamanho do intervalo de datas para armazenar o estagio praial em cada dia do intervalo amostrado
  for (i in 1:dif.datas){ #ciclo iterativo que vai de 1 ate o intervalo de dias
    for(j in 1: dif.datas) #ciclo iterativo que vai de 1 ate o intervalo de dias
    {
      Hrasa.m.dia[j]= mean(Ondas$Hrasa[((j*14)-13): (j*14)]) #calcula a media da altura de onda para cada dia no dataframe Ondas, sendo que cada dia corresponde a 24 linhas no dataframe Ondas, e armazena na posicao j do vetor Hrasa.m.dia
      T.m.dia[j] = mean(Ondas$T[((j*14)-13): (j*14)]) #calcula a media do periodo de onda para cada dia no dataframe Ondas, sendo que cada dia corresponde a 24 linhas no dataframe Ondas, e armazena na posicao j do vetor T.m.dia
    }
    omega[i]= (Hrasa.m.dia[i]^2)/ (9.8 * (T.m.dia[i]^2) * (Grao[Grao$nomes=="AreiaF", 2])) #calcula o estagio de praia a depender da media diaria da altura de onda e da media diaria do periodo de onda para aquele dia, de acordo com a equacao de Wright and Short, e armazena na posicao i do vetor omega
  }
  
  nome.estagio <- rep(NA, dif.datas) ##cria vetor de NA do tamanho do intervalo de datas para armazenar o nome do estagio praial que corresponde ao valor de omega calculado em cada dia
  for(k in 1:dif.datas){ #ciclo iterativo que vai de 1 ate o tamanho do intervalo de dias escolhido
    if (RTR<3 & omega[k]>=6) #retorna nome do estagio praial de cada dia a depender do RTR e do valor de omega calculado pra aquele dia
    {
      nome.estagio[k]= "Dissipativo"
    }
    if (RTR<3 & omega[k]<6 & omega[k]>=1) 
      {
      nome.estagio[k]="Intermediario"
    }
    if (RTR<3 & omega[k]<1)
    {
      nome.estagio[k]="Reflexivo"
    }
    if (RTR>=3 & 10>=RTR & omega[k]>=5)
    {
      nome.estagio[k]= "Ultradissipativo"
    }
    if (RTR>=3 & 10>=RTR & omega[k]<5)
    {
      nome.estagio[k]="Relexivo + Intermediario"
    }
  }
  
  #calcular indice de corrente de retorno de acordo com Engle et al. 2002:
  t.ripcurrent <- rep(NA, dif.datas) #cria vetor de NA de tamanho do intervalo de dias para armazenar o fator de risco diario correspondente ao periodo de onda medio por dia 
  for(l in 1:dif.datas){ #ciclo iterativo que vai de 1 ate o intervalo de datas
    #calcula o fator de risco a depender da media do periodo de onda a cada dia (cada dia corresponde a uma posicao do vetor T.m.dia)
    if(T.m.dia[l]<6){
      t.ripcurrent[l] = 1
    }
    if (6<=T.m.dia[l] & T.m.dia[l]<9){
      t.ripcurrent[l] = 1 + 0.5
    }
    if (9<=T.m.dia[l] & T.m.dia[l]<11){
      t.ripcurrent[l] = 1 + 1 
    }
    if (11<=T.m.dia[l] & T.m.dia[l]<12){
      t.ripcurrent[l] = 1 +2
    }
    if (T.m.dia[l]>=12){
      t.ripcurrent[l] = 1 + 3
    }
  }
  ripcurrent <- rep(NA, dif.datas) #cria vetor para armazenar o fator de risco de corrente de retorno levando em consideracao o fator calculado em funcao do periodo (t.ripcurrent) e o fator correspondente a altura de onda media por dia
  for(m in 1:dif.datas){ #ciclo iterativo que vai de 1 ate o intervalo de datas
    #calcula o fator de risco a depender da media da altura de onda a cada dia (cada dia corresponde a uma posicao do vetor Hrasa.m.dia) somado ao fator de risco associado ao periodo de onda (t.ripcurrent)
    if(Hrasa.m.dia[m]<1){
      ripcurrent[m] = t.ripcurrent[m] 
    }
    if (1<=Hrasa.m.dia[m] & Hrasa.m.dia[m]<2){
      ripcurrent[m] = t.ripcurrent[m] + 0.5
    }
    if (2 <= Hrasa.m.dia[m] & Hrasa.m.dia[m]<3){
      ripcurrent[m] = t.ripcurrent[m] + 1
    }
    if (3<= Hrasa.m.dia[m] & Hrasa.m.dia[m]<5){
      ripcurrent[m] = t.ripcurrent[m] +2
    }
    if (5<= Hrasa.m.dia[m] & Hrasa.m.dia[m]<8){
      ripcurrent[m] = t.ripcurrent[m] +3
    }
    if (Hrasa.m.dia[m]>=8){
      ripcurrent[m] = t.ripcurrent[m] + 4
    }
  }
  #gerando o grafico, caso o usuario deseje esta saida (graph==T):
  if(graph==T)
  {
    plot(omega, bty="l", pch= 19, xlab="Dias") #plota o valor de omega em cada dia
    lines(omega, lwd=2) #liga os pontos plotados com linhas
    par(new=T) #adiciona no mesmo plot
    plot(ripcurrent, axes=F, ann=F, pch=17, col="red") #plota valores do fator de risco das correntes de retorno a cada dia
    lines(ripcurrent, lwd=2, col="red") #liga os valores do fator de risco de corrente de retorno com linhas
    axis(4) #adiciona eixo correspondente ao valor do risco da corrente de retrono
  message("Escolha o ponto no grafico (cique no gráfico) para colocar a legenda")
    legend(locator(1), legend= c("Omega", "Ripcurrent"), pch= c(19,17), col=c("Black", "red")) #insere legenda no local escolhido pelo usuario no grafico
  }
  
  #final da funcao: saida eh uma lista que contem as informacoes de altura media de onda por dia, periodo medio de onda por dia, estagio praial e respectivo nome a cada dia e o fator de risco de corrente de retorno na praia a cada dia
  return(list("Altura media de onda por dia"=Hrasa.m.dia, "Periodo medio de onda por dia"= T.m.dia, "Estagio praial por dia"= omega, "Nome do estgio praial por dia"= nome.estagio, "Fator de risco de corrente de retorno por dia"= ripcurrent))  #retorna lista com dados calculados por dia 
}
05_curso_antigo/r2019/alunos/trabalho_final/mariana.santos.martins/monitorar.txt · Última modificação: 2020/08/12 06:04 (edição externa)