Paquete spapstat

Caja de herramientas integral de código abierto para analizar patrones de puntos espaciales. Centrado principalmente en patrones de puntos bidimensionales, incluidos puntos marcados/multitipo, en cualquier región espacial. También admite patrones de puntos tridimensionales, patrones de puntos de espacio-tiempo en cualquier número de dimensiones, patrones de puntos en una red lineal y patrones de otros objetos geométricos. Admite datos covariables espaciales, como imágenes de píxeles. Documentación

library(spatstat)
library(maptools)

Datos

Datos de pinos suecos de Strand-Ripley

swedishpines
Planar point pattern: 71 points
window: rectangle = [0, 96] x [0, 100] units (one unit = 0.1 
metres)
class(swedishpines)
[1] "ppp"
summary(swedishpines)
Planar point pattern:  71 points
Average intensity 0.007395833 points per square unit (one unit 
= 0.1 metres)

Coordinates are integers
i.e. rounded to the nearest unit (one unit = 0.1 metres)

Window: rectangle = [0, 96] x [0, 100] units
Window area = 9600 square units
Unit of length: 0.1 metres
plot(swedishpines)

Más documentación

Para una introducción rápida a Spatstat, lea la viñeta del paquete Getting started with spatstat instalado con Spatstat. Para leer ese documento, puede:

vignette("datasets")

Generando coordenadas aleatorias

La función runiff obtiene números decimales aleatorios de 0 a 1. Esta función está incluida dentro del paquete de R llamado stats.

x <- runif(20)
y <- runif(20)

Creando patrón de puntos

ppp: Crea un patrón de puntos a partir de \((x, y)\) y la información de la ventana:

X <- ppp(x, y, c(0,1), c(0,1))
X <- ppp(x, y)
X <- ppp(x, y, window=owin(c(0,1),c(0,1)))
class(X)
[1] "ppp"
summary(X)
Planar point pattern:  20 points
Average intensity 20 points per square unit

Coordinates are given to 8 decimal places

Window: rectangle = [0, 1] x [0, 1] units
Window area = 1 square unit
plot(X)

Datos-vesicles

Convirtiendo DataFrame a PPP

Patrón de puntos de vesículas sinápticas observado en tejido cerebral de rata.

# Estableciendo nueva ubicacion
setwd("C:/Users/EQUIPO/Documents/EstadisticaEspacial/data/vesicles/") 
Error in setwd("C:/Users/EQUIPO/Documents/EstadisticaEspacial/data/vesicles/") : 
  cannot change working directory
class(df)
[1] "data.frame"
head(df)
         x        y
1 467.0168 776.0189
2 445.3418 827.4970
3 364.0606 911.4876
4 323.4200 914.1969
5 339.6762 957.5469
6 345.0950 873.5563
Y1 <- ppp(df$x, df$y,  c(22,587), c(11,1031))
class(Y1)
[1] "ppp"
plot(Y1)

summary(df)
       x               y         
 Min.   :277.4   Min.   : 55.33  
 1st Qu.:347.8   1st Qu.:440.06  
 Median :399.3   Median :637.84  
 Mean   :403.9   Mean   :597.57  
 3rd Qu.:461.6   3rd Qu.:762.47  
 Max.   :548.3   Max.   :957.55  

Datos-finpines

Editando un PPP

Datos de pinos filandenses.

class(df1)
[1] "data.frame"
head(df1)
          x         y diameter height
1 -1.993875 0.9297642        1    1.7
2 -1.019901 0.4120694        1    1.7
3 -4.914071 1.9854250        1    1.6
4 -4.469962 1.4523900        5    4.1
5 -4.303847 0.9148214        3    3.1
6 -3.814774 0.8108644        4    4.3
Y2 = as.ppp(df1, owin(c(-5,5), c(-8,2)))
plot(Y2)

edit(Y2)
Marked planar point pattern: 126 points
Mark variables: diameter, height 
window: rectangle = [-5, 5] x [-8, 2] units

** Removiendo punto fuera de la cuadrícula o ventana**

S = ppp(x=c(-0.2, runif(10)),y=c(0.3, runif(10)),
        window=square(1))
1 point was rejected as lying outside the specified window
plot(S)

# Agregando punto
as.ppp(S)
Planar point pattern: 10 points
window: rectangle = [0, 1] x [0, 1] units
plot(as.ppp(S))

Graficando y editando punto fuera de la cuadrícula o ventana

# Grafica los puntos rechazados por estar fuera de la ventana
# de observacion
plot(attr(S, "rejects"))

edit(attr(S, "rejects"))
Planar point pattern: 1 point
window: polygonal boundary
enclosing rectangle: [-0.3665029, 1] x [0, 1.1536944] units

Verificando existencia de puntos duplicados

Simulación de Procesos Poisson no-homogéneos

Un Proceso puntual Poisson homogéneo son caracterizados por las siguientes propiedades: Homogeneidad e Independencia. Además, se le llama “Proceso Poisson” porque el número de puntos que caen en cualquier región sigue una distribución de Poisson. En muchas pruebas estadísticas, el CSR sirve como hipótesis nula.

  • La intensidad puede ser una constante
pp <- rpoispp(5)
pp
Planar point pattern: 9 points
window: rectangle = [0, 1] x [0, 1] units
plot(pp)

summary(pp)
Planar point pattern:  9 points
Average intensity 9 points per square unit

Coordinates are given to 8 decimal places

Window: rectangle = [0, 1] x [0, 1] units
Window area = 1 square unit
  • La intensidad puede ser una función (x,y) o una imagen pixelada
lambda = function(x,y) { 100 *(x^2+y)}
X = rpoispp(lambda, win = square(1))
X
Planar point pattern: 78 points
window: rectangle = [0, 1] x [0, 1] units
plot(X)

summary(X)
Planar point pattern:  78 points
Average intensity 78 points per square unit

Coordinates are given to 8 decimal places

Window: rectangle = [0, 1] x [0, 1] units
Window area = 1 square unit

Tarea 1

Consultar las clases de objetos que se pueden obtener en el paquete spatstat.

Los principales tipos de datos espaciales admitidos por Spatstat son:

Tarea 2

Leer sección 3.1, 3.2 posiblemente 3.3
Libro PDF

Tarea 3

¿Cuáles serían los argumentos a considerar en la función PPP cuando la ventana de observación es un polígono?

# Librerias
library(GWmodel)
library(ggplot2)

# Leyendo coordenadas de los bordes
borde = readShapeSpatial(file.choose()) # Borde.shp 

# Encontrando coordenadas
Borde = fortify(borde)

# Longitud y latitud
Borde$long = (Borde$long)/1000
Borde$lat = (Borde$lat)/1000
head(Borde)

# Leyendo coordenadas desde los datos
datos = read.csv(file.choose(), header=T) # Indicador.csv
datos$x = (datos$x)/1000
datos$y = (datos$y)/1000

La función rev() coloca las componentes de un vector en orden inverso a como han sido introducidas

# Matriz de coordenadas
Bor = cbind(Borde$long,Borde$lat)
colnames(Bor) = c("Long","Lat") # Matriz de coordenadas

# Reversa
lon = rev(Bor[,1])
lat = rev(Bor[,2])

# Poligono
p=list(x=lon, y=lat)
Z = owin(poly=p)
# Formamos objeto PPP
S = ppp(datos$x, datos$y, window=Z)
S
plot(S)

Tarea 4

Usando la función clickpoly crear una ventana de observación (ver sesión 3.9).

#-------------------------------------------------------------
# Dibuja manualmente ventana de graficacion
# clickpoly()
plot(S) # mapa de Medellín (ventana de observación)
prueba = clickpoly(add=TRUE) # crear otra ventana de observación 
class(prueba)

# Convierte a objeto poligono espacial
library(rgdal)
plot(prueba)
pruebaSp = as(prueba, "SpatialPolygons")
pruebaSp1 = as(pruebaSp, "SpatialPolygonsDataFrame")
class(pruebaSp)
writePolyShape(pruebaSp1,'pruebaSp.shp') # guardar 
---
title: "**Procesos de patrones puntuales**"
author: "Eilin Luna M."
date: "02/Mayo/2021"
output: html_notebook
---

## **Paquete spapstat**

Caja de herramientas integral de código abierto para analizar patrones de puntos espaciales. Centrado principalmente en patrones de puntos bidimensionales, incluidos puntos marcados/multitipo, en cualquier región espacial. También admite patrones de puntos tridimensionales, patrones de puntos de espacio-tiempo en cualquier número de dimensiones, patrones de puntos en una red lineal y patrones de otros objetos geométricos. Admite datos covariables espaciales, como imágenes de píxeles. [Documentación](https://cran.r-project.org/web/packages/spatstat/spatstat.pdf)

```{r}
library(spatstat)
library(maptools)
```


## **Datos**

Datos de pinos suecos de Strand-Ripley
```{r}
swedishpines
class(swedishpines)
summary(swedishpines)
plot(swedishpines)
```

## **Más documentación**  
Para una introducción rápida a Spatstat, lea la viñeta del paquete *Getting started with spatstat* instalado con Spatstat. Para leer ese documento, puede:

```{r}
vignette("datasets")
```

## **Generando coordenadas aleatorias**

La función `runiff` obtiene números decimales aleatorios de 0 a 1. Esta función está incluida dentro del paquete de R llamado stats.

```{r}
x <- runif(20)
y <- runif(20)
```

## **Creando patrón de puntos**

`ppp`: Crea un patrón de puntos a partir de $(x, y)$ y la información de la ventana:  

* `ppp (x, y, xlim, ylim)` para ventana rectangular
* `ppp (x, y, poly)` para ventana poligonal
* `ppp (x, y, máscara)` para la ventana de imagen binaria

```{r}
X <- ppp(x, y, c(0,1), c(0,1))
X <- ppp(x, y)
X <- ppp(x, y, window=owin(c(0,1),c(0,1)))
```

```{r}
class(X)
summary(X)
plot(X)
```

## **Datos-vesicles**
### **Convirtiendo DataFrame a PPP**

Patrón de puntos de vesículas sinápticas observado en tejido cerebral de rata.

```{r}
# Estableciendo nueva ubicacion
setwd("C:/Users/EQUIPO/Documents/EstadisticaEspacial/data/vesicles/") 
copyExampleFiles("vesicles")
df = read.table("vesicles.txt", header=TRUE)
```

```{r paged.print=FALSE}
class(df)
head(df)
```


```{r}
# Convirtiendo a patrones de puntos espaciales
Y1 <- ppp(df$x, df$y,  c(22,587), c(11,1031))
class(Y1)
plot(Y1)
summary(df)
```
## **Datos-finpines**
### **Editando un PPP**

Datos de pinos filandenses.

```{r}
copyExampleFiles('finpines')
df1 = read.table("finpines.txt", header=TRUE)
```

```{r paged.print=FALSE}
class(df1)
head(df1)
Y2 = as.ppp(df1, owin(c(-5,5), c(-8,2)))
plot(Y2)
edit(Y2)
```

## ** Removiendo punto fuera de la cuadrícula o ventana**

```{r}
S = ppp(x=c(-0.2, runif(10)),y=c(0.3, runif(10)),
        window=square(1))
plot(S)

# Removiendo punto
as.ppp(S)
plot(as.ppp(S))
```

### **Graficando y editando punto fuera de la cuadrícula o ventana**

```{r}
# Grafica los puntos rechazados por estar fuera de la ventana
# de observacion
plot(attr(S, "rejects"))
edit(attr(S, "rejects"))
```

### **Verificando existencia de puntos duplicados**

```{r}
# Verifica si hay existencia de puntos duplicados
duplicated(S)
table(duplicated(S))

multiplicity(S)
table(multiplicity(S))
```

### **Simulación de Procesos Poisson no-homogéneos**

Un Proceso puntual Poisson homogéneo son caracterizados por las siguientes propiedades: Homogeneidad e Independencia. Además, se le llama “Proceso Poisson” porque el número de puntos que caen en cualquier región sigue una distribución de Poisson. En muchas pruebas estadísticas, el CSR sirve como hipótesis nula.

* La intensidad puede ser una constante

```{r}
pp <- rpoispp(5)
pp
plot(pp)
summary(pp)
```

* La intensidad puede ser una función (x,y) o una imagen pixelada
```{r}
lambda = function(x,y) {100 *(x^2+y)}
X = rpoispp(lambda, win = square(1))
X
plot(X)
summary(X)
```







# **Tarea 1**
**Consultar las clases de objetos que se pueden obtener en el paquete spatstat.**

Los principales tipos de datos espaciales admitidos por Spatstat son:

+ `ppp`: patrón de puntos ppp  
  **Para crear un patrón de puntos:** Crea un patrón de puntos a partir de (x, y) y la información de la ventana.
  
+ `owin`: ventana propia (región espacial)  
  **Para crear una ventana:** Un objeto de clase "owin" describe una región espacial (una ventana de observación).
  
+ `im`: imagen de píxeles  
  **Imágenes de píxeles:** un objeto de la clase "im" representa una imagen de píxeles. 
  
+ `psp`:patrón de segmento de línea  
  **Patrones de segmento de línea** Un objeto de la clase "psp" representa un patrón de segmentos de línea recta.

+ `tess`: teselación  
  **Teselaciones:** Un objeto de la clase "tess" representa una teselación.
  
+ `pp3`: patrón de puntos tridimensional  
  **Patrones de puntos tridimensionales** Un objeto de clase "pp3" representa un patrón de puntos tridimensional en una caja rectangular. La caja está representada por un objeto de clase "caja3".
  
+ `ppx`: patrón de puntos en cualquier número de dimensiones.  
  **Patrones de puntos de espacio-tiempo multidimensionales**
Un objeto de clase "ppx" representa un patrón de puntos en un espacio y / o tiempo multidimensional.  

+ `lpp`: patrón de puntos en una red lineal  
  **Patrones de puntos en una red lineal:** un objeto de clase "lpp" representa un patrón de puntos en una red lineal (por ejemplo, accidentes de tráfico en una red de carreteras).
  
# **Tarea 2**
**Leer sección 3.1, 3.2 posiblemente 3.3**  
[Libro PDF](https://azaieznotesblog.files.wordpress.com/2017/08/spatial-point-patterns_chapman-hall-crc-2016.pdf)

* **3.1 ENCUESTAS Y EXPERIMENTOS**  
**3.1.1 Diseño de un experimento o encuesta**  
  * El consejo más importante sobre el diseño de un experimento es planificar todo el experimento, incluido el análisis de datos  

  **3.1.2 Qué se necesita registrar**  
    * Además de las coordenadas de los puntos en sí, es necesario registrar otros elementos, como la ventana de observación, covariables espacilaes.  
    * Es una buena práctica registrar la hora a la que se realizó cada observación y buscar cualquier tendencia aparente a lo largo del tiempo  
    
  **3.1.3 Riesgos y buenas prácticas**    
    * El mayor riesgo al registrar observaciones es que se omita o se pierda información importante.  
    * ¿Qué información resultará retrospectivamente relevante para nuestro análisis?   
    * No confunda estas dos ideas: "faltante" o "inobservable" (NA) es un concepto completamente diferente concepto de "ausente" (0).   
    * Registre la secuencia de operaciones aplicadas a los datos, explique los nombres de las variables, indique las unidades en el que se expresan, etc.  
  
* **3.2 MANEJO DE DATOS** 

  **3.2.1 Formatos de archivo de datos**  
  * formato de tabla: los datos se organizan en filas y columna  
  * Valores separados por comas (csv): el software de hoja de cálculo.  
  * shapefiles: Un shapefile es un formato de archivo popular para compartir datos vectoriales entre paquetes de software del sistema de información geográfica (GIS).   
  
  **3.2.2 Lectura de datos en R**  
  * Los datos en un archivo de texto en formato de tabla se pueden leer en R usando el comando read.table.  
  * Los archivos de datos originales para el conjunto de datos de vesículas se instalan en Spatstat como ejemplo práctico.  
  
* **3.3. INGRESAS DATOS DE PATRONES DE PUNTOS EN Spatstat**  
  * 3.3.1 Crear un objeto "ppp"  
  * 3.3.2 Marcas  
    Marcas categóricas, marcas multivariadas  
  * 3.3.3 Unidades  
  
# **Tarea 3**
**¿Cuáles serían los argumentos a considerar en la función PPP cuando la ventana de observación es un polígono?**


```{r}
# Librerias
library(GWmodel)
library(ggplot2)

# Leyendo coordenadas de los bordes
borde = readShapeSpatial(file.choose()) # Borde.shp 

# Encontrando coordenadas
Borde = fortify(borde)

# Longitud y latitud
Borde$long = (Borde$long)/1000
Borde$lat = (Borde$lat)/1000
head(Borde)

# Leyendo coordenadas desde los datos
datos = read.csv(file.choose(), header=T) # Indicador.csv
datos$x = (datos$x)/1000
datos$y = (datos$y)/1000
```

La función rev() coloca las componentes de un vector en orden inverso a como han sido introducidas 

```{r paged.print=FALSE}
# Matriz de coordenadas
Bor = cbind(Borde$long,Borde$lat)
colnames(Bor) = c("Long","Lat") # Matriz de coordenadas

# Reversa
lon = rev(Bor[,1])
lat = rev(Bor[,2])

# Poligono
p=list(x=lon, y=lat)
Z = owin(poly=p)
```

```{r}
# Formamos objeto PPP
S = ppp(datos$x, datos$y, window=Z)
S
```

```{r}
plot(S)
```

# **Tarea 4**

**Usando la función clickpoly crear una ventana de observación (ver sesión 3.9).**

```{r warning=FALSE, paged.print=FALSE}
#-------------------------------------------------------------
# Dibuja manualmente ventana de graficacion
# clickpoly()
plot(S) # mapa de Medellín (ventana de observación)
prueba = clickpoly(add=TRUE) # crear otra ventana de observación 
class(prueba)
```

![](C:\Users\EQUIPO\Documents\GitHub\EstadisticaEspacial\images\medellin.png)

```{r}
# Convierte a objeto poligono espacial
library(rgdal)
plot(prueba)
pruebaSp = as(prueba, "SpatialPolygons")
pruebaSp1 = as(pruebaSp, "SpatialPolygonsDataFrame")
class(pruebaSp)
writePolyShape(pruebaSp1,'pruebaSp.shp') # guardar 
```








