Olá Douglas,
Sou Gustavo A. Ballen, monitor encargado de dar um retorno sobre suas propostas. Vou comentar em geral aqui sobre as duas propostas.
Da para perceber que você conhece o R como ferramenta SIG e os pacotes para realizar tais análises; consequentemente, as duas se parecem bastante e apresentam saídas promisorias. Entretanto, em nenhuma das duas funções fica clara qual ira ser a sua contribuição como programador, ou por quê o procedimento desenvolvido pela função é original de alguma maneira. Em geral fica a impressão que a função só vai utilizar ferramentas preexistentes nos pacotes GIS indicados e integrá-los para gerar uma saída composta de diversas informações.
Por gentileza reformule as duas propostas dando enfase à sua contribuição em cada caso, e se for o caso deixe bastante claro qual ira ser o papel dos pacotes citados dentro da função. Se os pacotes forem os responsáveis principais pelos procedimentos que você precisa implementar na função, então acho melhor pensar numa terceira proposta ou então rever as que já estão disponíveis. Até então nenhuma das duas pode ser escolhida como função de trabalho final.
Olá Gustavo, muito obrigado pelo feedback.
Como conversamos por e-mail, editei a proposta A e deixei o pseudocódigo mais claro, aguardo seu retorno.
O atropelamento de fauna é um dos grandes problemas na perda de indivíduos da fauna silvestre em todo o mundo, no Brasil estima-se que mais de 14 milhões de vertebrados silvestres morram todos os anos em atropelados em rodovias. Esses números podem variar de acordo com as estimativas, mas de modo geral são baseados em números de estudos que buscam monitorar sistematicamente rodovias em todo o país em busca de carcaças, para entender onde, quais e como esses animais morrem.
Figura: Cerdocyon thous atropelado.
Diversos fatores podem influenciar a mortalidade de animais em rodovias, desde o grupo taxonômico, o hábito alimentar, a hora de atividade no dia, o comportamento gregário ou solitário e até o tipo de habitat. Um dos fatores mais estudados no atropelamento de fauna é a paisagem, pois é nela que os animais se movimentam apresentando preferências ou repulsa por alguns tipos de vegetação ou uso do solo, e deste modo, entender a paisagem pode ajudar a entender o movimento da fauna.
Um dos principais objetivos dos estudos de mortalidade de fauna em rodovias é a proposição de medidas mitigadoras, como redutores de velocidade, cercamento, passagens de fauna, entre outros, que visam diminuir o número de colisões entre veículos e a fauna, diminuindo assim a mortalidade e a perda de espécimes silvestres e aumentando a segurança dos usuários da rodovia. Deste ponto de vista, analisar o tipo de paisagem onde os atropelamentos ocorrem podem nos ajudar a tomar decisões de onde e como implementar essas medidas de prevenção e mitigação. Após o monitoramento e o levantamento da fauna atropelada numa rodovia, podemos utilizar os pontos georreferenciados dos atropelamentos e analisar a paisagem circundante ao evento, permitindo entender quais fatores naquela paisagem podem estar influenciando o atropelamento de fauna.
Para esse tipo de análise, em geral, os pesquisadores e consultores ambientais, usam ferramentas de geoprocessamento, criando um buffer de influência a partir do ponto de atropelamento e utilizando um mapa de uso do solo para determinar qual a paisagem na região. Mas imagine que você tem um branco de dados do monitoramento de uma rodovia, com centenas de ocorrências, e você gostaria de olhar para a paisagem em todos estes pontos, talvez você tenha que criar muitos buffers e extrair muitas vezes as informações do uso do solo. Sendo assim, seria útil uma ferramenta que faça isso automaticamente, carregando o ponto, o tamanho do raio de influência e o mapa de uso do solo, te fornecendo as quantidades relativas de uso envolta de cada um dos atropelamentos.
Figura: Exemplo de buffer de influência e uso do solo ao redor de atropelamentos
Além disso, uma ferramenta assim pode ser útil para outros tipos de estudos ambientais em que se tem um ponto georreferenciado e se quer saber o uso do solo envolta deste ponto, como por exemplo um ponto de ocorrência de algum animal ou planta, onde queremos saber qual o habitat e a matriz onde ele foi observado; o ponto de uma nascente de rio, para saber quanto por cento da APP da nascente está conservada; um ponto de localização de colar de GPS de um animal, para saber por onde ele andou; o ponto de implantação de uma armadilha fotográfica e até mesmo o ponto de uma rodovia em que pretendemos implementar uma passagem de fauna.
“raster”
“sp”
RoLA (y, x, buffer, graph = TRUE, landscape.data)
• y:
'objeto' ou 'vetor' com a latitude do(s) ponto(s) (em graus decimais);
• x:
'objeto' ou 'vetor' com a longitude do(s) ponto(s) (em graus decimais);
• graph:
default = TRUE
, retorna o mapa gráfico do buffer;
• landscape.data:
arquivo raster (.tiff) contendo o uso do solo na região estudada;
landscape.data
é um arquivo .tif – caso não, retorna uma mensagem de erro;data.frame
os valores e as frequências de valores do arquivo raster;data.frame
com uma coluna de ID, uma coluna de latidude, uma coluna de longitude e uma coluna para cada categoria de uso presente no raster;for
, para cada valor de x
e y
; x
e y
- na mesma projeção do raster;buffer
fornecido pelo usuário;landscape.data
;data.frame
; if
: caso o usuário tenha pedido um mapa gráfico, produz um mapa para cada ponto, com a área de influência e os usos presentes nele (garante que todos os mapas atribuam as mesmas cores aos respectivos usos);for
, contador j
preenche as colunas do data.frame
final com as frequências relativas de cada categoria de uso;if
: caso o buffer possua a categoria presente no arquivo raster, preenche o respectivo valor no data.frame
;else
: caso o buffer não possua a categoria presente no arquivo raster, preenche com zero;
- retorna o laço para o for
para realizar o procedimento para as coordenadas x
e y
seguintes;
data.frame
com os valores em porcentagem para cada valor de pixel e cada ponto; (Atenção: os valores do pixel para cada uso, precisam ser conhecidos pelo usuário, como no exemplo à seguir, que são os valores de uso por pixel do MapBiomas: exemplo);graph
seja verdadeiro, retorna um mapa gráfico com o buffere cada uso, todos na mesma paleta de cores pros valore iguais (ou seja, se há um valor “3” em um mapa, o mesmo valor “3” estará com a mesma cor no mapa de outro ponto). O pacote de GIS cria pontos, lê rasters e cria shape.files, a programação consistirá em:
As principais funções utilizadas pelos pacotes GIS serão:
raster
- lê um arquivo raster;SpatialPoint
- cria um ponto a partir de coordenadas (é necessário identificar e indicar o tipo de projeção cartográfica);mask
e crop
, cortam um arquivo espacial à partir de outro;As principais funções de programação em R serão:
for
- para percorrer todos os pontos, independente da quantidade deles e para percorrer toda a tabela a ser gerada ao final do procedimento;if
- para verificar o tamanho e tipo dos arquivos fornecidos pelo usuário; para verificar dentro do for
se a categoria de uso é correspondente antes de preencher a tabela; para verificar se o usuário quer ou não um resultado gráfico;data.frame
- cria e manipula data frames;plot
e par
- cria e manipula gráficos, e nesse caso garantirá que todos os gráficos tenham exatamente o mesmo padrão de cores, de legendas e tamanho, independente do número de categorias que possuir;as.character
; as.numeric
, e outros manipuladores de dados como []
, sum
, freq
, c()
, ==
; &
; etc - para garantir a extração adequada de dados. FUNÇÃO: Função RoLA - Final
##################################################### ####FUNÇÃO RoLA - Roadkill Landscape Analysis######## ##################################################### RoLA <- function (landscape.data, lat, long, buffer.radius, map.graph=T, pie.graph=F) #nome da função e seus argumentos; { x<-long #atribui o vetor de longitudes a um objeto x y<-lat #atribui o vetor de latitudes a um objeto y if(length(x)!=length(y)){ stop('Os vetores de Latitude e Longitude devem ter o mesmo tamanho e ser ordenados') #verifica o tamanho dos vetores e pára caso não sejam do mesmo tamenho } if (require("raster")!=TRUE) {stop('É necessário instalar o pacote "raster" ')} #verifica se o usuário possui o pacote "raster" if (require("sp")!=TRUE) {stop('É necessário instalar o pacote "sp" ')} #verifica se o usuário possui o pacote "sp" land.data <- raster(landscape.data) #atribui o arquivo raster à um objeto land.data[land.data==0]<-NA #substitui os zeros por NA's no arquivo raster projection <- as.character(land.data@crs) #guarda a projeção do arquivo raster em um objeto freq_land.data <- as.data.frame(freq(land.data, useNA="no")) #mede as frequências de cada categoria de uso presentes no mapa raster m <- as.numeric(length(freq_land.data$value)) #guarda o número de categorias do mapa raster num objeto k <- freq_land.data$value #guarda em um vetor com todos os valores de uso do mapa raster col=(terrain.colors(m)) #cria um objeto com as cores padronizadas de acordo com o número de categorias no mapa raster names(col) = c(k) #coloca o nome de cada uso do raster em cada respectiva cor criada buffer.size <- buffer.radius #guarda o tamanho do buffer fornecido em um objeto n.points <- as.numeric(length(x)) #guarda o número de pontos ordenados (lat, long) em um objeto tabmatrix <-matrix(ncol=3+m, nrow=n.points) #cria uma matriz de dados com o número de colunas igual aos usos do raster + 3, e com o numero de linhas igual o de pontos tab.fin <- as.data.frame (tabmatrix) #transforma a matriz em um data.frame colnames(tab.fin) = c("ID", "lat", "long", c(k)) #renomeia as colunas do data.frame - as 3 primeiras com Id, lat e long for (i in 1:n.points){ #inicia um loop que vai de 1 até o número de coordenadas (lat,long) j <- 0 # zera o contador j l <- 4 #atribui 4 ao contador l (que preencherá as colunas) p <- 1 #contador p para a posição das frequencias no buffer tab.fin[i,1]=i #atribui o ID da linha tab.fin[i,2]=y[i] #atribui a latitude da linha tab.fin[i,3]=x[i] #atribui a longitude da linha ponto<-SpatialPoints(cbind(x[i], y[i]), proj4string= CRS(projection)) #cria um ponto com a coordenada lat, long ordenada influencia <- buffer(ponto, width=buffer.size) #cria um buffer circular com um raio determinado à partir do ponto cort <- mask(land.data, influencia) #corta o mapa raster com o buffer a partir do ponto uso<-crop(cort, influencia) #recorta o mapa do buffer ppelo tamanho exato do buffer frequencias <- as.data.frame(freq(uso, useNA="no")) #guarda um data.frame com os valores de uso(categorias) e as frequências dentro do buffer z <- (frequencias[,1]) #guarda um vetor com as categorias de uso f <- (frequencias[,2]) #guarda um vetor com as frequências de uso n <-as.numeric(length(frequencias$value)) #guarda a quantidade de categorias de uso no buffer tot_val=sum(freq(uso, useNA="no")) #guarda o tamanho total do buffer em área, com todas as categorias if (map.graph == T){ #se o argumento gráfico é verdadeiro x11() #abre uma janela gráfica par(xpd=F, mar=c(5,4,4,4.5)) #atribui os parâmetros de margem cl = col[as.character(c(z))] #atribui as cores do mapa gráfico de acordo com o arquivo raster e o buffer plot(uso, col=col, breaks=c(1,c(k)),legend=F, main=c(y[i], x[i])) #plota um mapa da região do buffer par(xpd=T) legend(par()$usr[2],par()$usr[4], legend=c(z),fill=cl) #aficiona a legenda no canto superior direito do mapa par(new=T) plot(ponto, col="red") #plota o ponto (lat, long) if (pie.graph == T){ #se o argumento gráfico é verdadeiro x11() #abre uma janela gráfica par(xpd=F, mar=c(5,4,4,4.5)) #atribui parâmetros de margem cl = col[as.character(c(z))] #atribui cores do gráfico de acordo com o arquivo raster pie(frequencias[,2],labels = round((frequencias[,2]/tot_val*100),2),col = cl, radius = 1, main = c(y[i], x[i])) #gera um gráfico de pizza com as porcentagens par(xpd=T) legend(par()$usr[2],par()$usr[4], legend=c(z),fill=cl) #adiciona uma legenda por cores } } for (j in k){ #para cada j com os valores do raster original if (j == z[p] & j <= z[n]){ #verifica se o tamanho do vetor é menor ou igual ao contador p e se o contador j é igual ao valor de z tab.fin[i, l] = round((f[p]/tot_val*100),4) #atribui a frequência do uso à respectiva coluna do data.frame final p=p+1 #soma 1 no contador l=l+1 #soma 1 no contador } else{ tab.fin [i,l] = 0 #adiciona zero à coluna do uso que não aparece no buffer l=l+1 #soma 1 ao contador } } } return(tab.fin) }
DOCUMENTAÇÃO: R Documentation - RoLA
R documentation RoLA – Roadkill Landscape Analysis Description: Gera um data.frame com as frequências relativas –em porcentagem- de uso do solo dentro de um buffer de tamanho e ponto central determinado pelo usuário; Usage: RoLA(landscape.data"raster.tif", lat=y, long = x, buffer.radius=4000, map.graph = TRUE, pie.graph = FALSE) Arguments: landscape.data: um arquivo/mapa do tipo raster (formato .tif) contendo os valores de uso do solo na região de estudo; lat: um objeto numérico ou vetor contendo a(s) latitude(s) do(s) ponto(s) a ser(em) utilizado(s) - em GRAUS DECIMAIS; long: um objeto numérico ou vetor contedo a(s) longitude(s) do(s) ponto(S) a ser(em) utilizado(s) - em GRAUS DECIMAIS; buffer.radius: tamanho – em metros – do raio do buffer a ser gerado à partir do(s) ponto(s) central(is); map.graph: default=TRUE – argumento lógico TRUE/FALSE, determina se a saída será acompanhada de um mapa da região com os usos do solo; pie.graph: default=FALSE – argumento lógico TRUE/FALSE, determina se a saída será acompanhada de uma gráfico tipo pizza com as porcentagens relativas de cada uso dentro do buffer; Details: O buffer será gerado no tamanho informado à partir do(s) ponto(s) dado(s), nas coordenadas ordenadas de latitude e longitude. O arquivo raster será a base da informação do uso do solo, fornecido pelo usuário. A saída é um data.frame com as frequências relativas de cada valor presente no arquivo raster fornecido, deste modo o usuário deve conhecer o significado de cada valor de seu arquivo raster. O argumento map.graph = TRUE gera um mapa, com um círculo de raio igual ao buffer.size com todos os usos presentes dentro dessa área e uma legenda; O argumento pie.graph = TRUE gera um gráfico de pizza, com as porcentagens relativas de cada uso dentro do buffer; As cores de cada uso no mapa e no gráfico de pizza, são equivalentes entre si. Value: *Um data.frame contendo na primeira coluna um ID numérico; na segunda coluna a latitude do ponto; na terceira coluna a longitude do ponto; à partir da quarta coluna a porcentagem relativa do uso do solo obtida à partir do arquivo raster fornecido; *Caso o argumento map.graph seja verdadeiro, gera um mapa, delimitado pelo buffer, contendo os usos do solo, com legenda e referência geográfica; *Caso o argumento pie.graph seja verdadeiro, gera um gráfico de pizza com as porcentagens relativas de cada uso; Warning: Para o funcionamento adequado da função é necessário ter instalado os pacotes “sp” e “raster”; Todos os pontos de coordenadas geográficas devem ser fornecidos em GRAUS DECIMAIS; Garanta que seus pontos de coordenadas se sobrepõem à mesma região que o raster que você forneceu; Arquivos raster são arquivos pesados, sua função pode demorar para rodar, aguarde o R terminar o processamento! Author(s): Douglas W. Cirno douglaswcirino@hotmail.com See also: SatialPoints, mask, crop, buffer Examples: #para os arquivos de raster disponíveis no link: Ex. 1 – Atropelamento no Rodoanel de SP: # RoLA(landscape.data="SP_2017.tif", lat=-23.805440, long=-46.694391, buffer.radius=2500, map.graph = TRUE, pie.graph = TRUE) Ex. 2 – Atropelamentos no MS: #lat1<- c(-20.28403, -20.19575, -20.13389, -20.45842, -20.5501, -20.6926, -21.1363, -21.42647) #long1<- c(-56.302455, -56.44354, -56.67615, -55.2395, -55.5366, -55.7840, -55.8203, -56.46465) #RoLA(landscape.data="MS_2016.tif", lat=c(lat1), long=c(long2), buffer.radius=2260) #Ex. 3 – APPS de nascentes de Itu-SP (Mapa FBDS – resolution:5m) #nasc_lat = c(-23.273701, -23.254287, -23.272466, -23.355888, -23.353230, -23.317253, -23.258457) #nasc_long = c( -47.269918, -47.252207, -47.359948, -47.414180, -47.358264, -47.415235, -47.366648) #APP_ITU<- RoLA ("Itu_WGS84.tif", lat = c(nasc_lat), long = c(nasc_long), 100, map.graph = T, pie.graph = T) #Ex. 4 – APPS de nascentes de Itu-SP (Mapa MApBiomas - resolution:30m) #nasc_lat = c(-23.273701, -23.254287, -23.272466, -23.355888, -23.353230, -23.317253, -23.258457) #nasc_long = c( -47.269918, -47.252207, -47.359948, -47.414180, -47.358264, -47.415235, -47.366648) #APP_ITU<- RoLA ("ITU_2017.tif", lat = c(nasc_lat), long = c(nasc_long), 500, map.graph = F, pie.graph = T)
Atropelamento no Rodoanel de SP
Arquivo raster (mapa de SP): SAO_PAULO_2017.tif Legenda do arquivo raster: MapBiomas 3.1 - Legenda
atrop_rodoanel <- RoLA(landscape.data="SAO_PAULO_2017.tif", lat=-23.805440, long=-46.694391, buffer.radius=2500, map.graph = TRUE, pie.graph = TRUE)
Atropelamentos no Pantanal
Arquivo raster (mapa de uma região do MS): MS_2016.tif Legenda do arquivo Raster: MAPBiomas 3.0 - Legenda
lat1<- c(-20.28403, -20.19575, -20.13389, -20.45842, -20.5501, -20.6926, -21.1363, -21.42647) long1<- c(-56.302455, -56.44354, -56.67615, -55.2395, -55.5366, -55.7840, -55.8203, -56.46465) atrop_pantanal <- RoLA ("2016_MS.tif", lat = c(lat1), long = c(long1), 2260, map.graph = T)
APP's de nascentes de Itu com Mapa de 5m de resolução
Arquivo Raster (uso do Solo do FBDS para Itu): ITU_WGS84.tif Legenda do arquivo Raster: Legenda FBDS - Itu
nasc_lat = c(-23.273701, -23.254287, -23.272466, -23.355888, -23.353230, -23.317253, -23.258457) nasc_long = c( -47.269918, -47.252207, -47.359948, -47.414180, -47.358264, -47.415235, -47.366648) APP_ITU<- RoLA ("Itu_WGS84.tif", lat = c(nasc_lat), long = c(nasc_long), 300, map.graph = T, pie.graph = T)
APP's de Nascentes de Itu com mapa de 30m de resolução
Arquivo Raster (uso do solo MapBiomas para Itu): ITU_2017.tif Legenda do arquivo raster: MapBiomas 3.1 - Legenda
nasc_lat = c(-23.273701, -23.254287, -23.272466, -23.355888, -23.353230, -23.317253, -23.258457) nasc_long = c( -47.269918, -47.252207, -47.359948, -47.414180, -47.358264, -47.415235, -47.366648) APP_ITU<- RoLA ("ITU_2017.tif", lat = c(nasc_lat), long = c(nasc_long), 500, map.graph = F, pie.graph = T)
O desmatamento é um dos principais problemas ecológicos que vivenciamos e está associado a diversos problemas ambientais de nosso cotidiano, desde a proliferação de doenças, o descontrole de populações de pragas, a má qualidade da água e principalmente as mudanças climáticas.
Figura: Desmatamento na Amazônia de 1984 a 2016
As florestas são responsáveis por diversos serviços ecossistêmicos em nossa dia-a-dia, desde o controle da temperatura e a produção de chuvas, até mesmo efeitos que nem percebemos, como o bem-estar e a saúde, sobretudo mental e cardiovascular. Parte disso se dá pelo que Edward O. Wilson chamou de Biofilia, que seria a atração pela natureza e atributos naturais. Por outro lado, a cada minuto que se passa nos tornamos mais distantes das florestas, seja pela vida agitada seja pela população humana estar em sua maioria em centros urbanos.
Devemos buscar saber qual é a floresta, por menor que ela seja, que está mais perto de nós, da nossa casa, do nosso trabalho. E precisamos ter a consciência de quanto de floresta é perdido no mundo a cada minuto de nossas vidas. Através da entrada de sua data de nascimento e de sua coordenada geográfica de localização, conseguimos calcular o quanto que você está longe de uma floresta nativa e estimar o quanto de desflorestamento aconteceu do dia que você nasceu até o presente. Essa é uma forma de conscientizarmos as pessoas de que precisamos urgentemente nos preocupar com as questões ambientais. Mas nem tudo são pesadelos, muitas florestas no mundo todo, inclusive no Brasil estão se regenerando aos poucos, apesar do número absoluto ser maior de desmatamento do que de regeneração, algumas ações ambientais podem mudar esse cenário em algumas décadas, então podemos saber também quanto de florestas recuperamos desde o dia em que pisamos nesse mundo! O Brasil é o país com maior quantidade de florestas tropicais no mundo e detém a maior biodiversidade do planeta, portanto estimar o quanto o nosso país está perdendo e ganhando de florestas é essencial para entendermos como vai nosso planeta e nossa biodiversidade.
“maptools”
“raster”
“rgdal”
“GISTools”
Arquivo de uso do solo no Brasil (MapBiomas);
HFFF(forests, birth, x, y)
• forests:
nome do arquivo .tif
com florestas salvo no repositório;
• birth:
dia do seu nascimento (na estrutura dd/mm/aaaa)
• y:
latitude do ponto onde você está ou quer medir a distância de uma floresta (em graus decimais);
• x:
longitude do ponto onde você está ou quer medir a distância de uma floresta (em graus decimais);
forests
a partir do diretório do usuário – previamente baixado. x
e y
estão em graus decimais – caso contrário retorna uma mensagem de erro;birth
está no formato correto – caso contrário retorna uma mensagem de erro;