Información espacial en formato ráster en RPermalink

Existen varios paquetes en R que permiten manejar datos espaciales, ya sea en formato de vector o raster. Algunos de ellos incluyen: sp, rgdal, rgeos, sf, stars, raster, terra. Sin embargo, en este curso nos enfocaremos en utilizar sf para el manejo de información vectorial y stars para el manejo de rasters.

Introducción a stars

stars es un paquete creado para trabajar de manera sencilla con información raster y fue creado por el mismo grupo de trabajo que creo sf, así que muchas funciones y sintaxis son compartidas con dicho paquete.

Rasters

El objeto básico en stars son los spatiotemporal arrays (stars), es decir arreglos espacio temporales. Recordemos que un arreglo corresponde a cualquier objeto organizado en dimensiones. Por ejemplo, una arreglo de dos dimensiones podría corresponder a una matriz que cuenta con una dimensión vertical (filas) y horizontal (columnas). De igual manera, un arreglo de tres dimensiones podría corresponder a una imagen raster con dos dimensiones espaciales (vertical y horizontal) y una dimensión espectral (bandas). Adicionalmente, un arreglo con cuatro dimensiones podría incluir una dimensión temporal.

Al igual que en sf cada raster va a estar asociado a un sistema de coordenadas de referencia (CRS). Por lo cual, dicho CRS indicará la proyección de los datos y el datum.

Estructura de datos stars

Los datos stars van a estar organizados en un formato de array, es decir, de una tabla o cuadro de datos de n dimensiones. Para ver un ejemplos carguemos un archivo raster.

library(stars)
## Loading required package: abind
## Loading required package: sf
## Linking to GEOS 3.9.1, GDAL 3.2.1, PROJ 7.2.1; sf_use_s2() is TRUE
tif = system.file("tif/L7_ETMs.tif", package = "stars")
x = read_stars(tif)
x
## stars object with 3 dimensions and 1 attribute
## attribute(s):
##              Min. 1st Qu. Median     Mean 3rd Qu. Max.
## L7_ETMs.tif     1      54     69 68.91242      86  255
## dimension(s):
##      from  to  offset delta                     refsys point values x/y
## x       1 349  288776  28.5 SIRGAS 2000 / UTM zone 25S FALSE   NULL [x]
## y       1 352 9120761 -28.5 SIRGAS 2000 / UTM zone 25S FALSE   NULL [y]
## band    1   6      NA    NA                         NA    NA   NULL

Analicemos qué dice esta información. Primero nos dice que se trata de un objeto stars de tres dimensiones y un atributo. Además, nos da algunas estadísticas de la información que contiene. A continuación, podemos ver las tres dimensiones: x, y y band, es decir, dos dimensiones espaciales y una espectral. Adicionalmente, se puede consultar el número de celdas en cada dimensión (from y to), la coordenada inicial en cada dimensión (offset), el tamaño de la celda en cada dimensión (delta), el sistema de referencia en el que se encuentra la información (refsys), si corresponde a puntos (point) y los valores de secuencia en caso de que la dimensión no sea regular (e.g., geometrías).

La misma información se puede consultar de manera más sintética.

st_dimensions(x)
##      from  to  offset delta                     refsys point values x/y
## x       1 349  288776  28.5 SIRGAS 2000 / UTM zone 25S FALSE   NULL [x]
## y       1 352 9120761 -28.5 SIRGAS 2000 / UTM zone 25S FALSE   NULL [y]
## band    1   6      NA    NA                         NA    NA   NULL

Lectura y escritura de datos

Para leer y escribir datos desde archivos externos se utilizan las funciones read_stars y write_stars. Por ejemplo, carguemos un archivo que viene en el paquete stars:

filename <- system.file("tif/L7_ETMs.tif", package = "stars")
x <- read_stars(filename)
x
## stars object with 3 dimensions and 1 attribute
## attribute(s):
##              Min. 1st Qu. Median     Mean 3rd Qu. Max.
## L7_ETMs.tif     1      54     69 68.91242      86  255
## dimension(s):
##      from  to  offset delta                     refsys point values x/y
## x       1 349  288776  28.5 SIRGAS 2000 / UTM zone 25S FALSE   NULL [x]
## y       1 352 9120761 -28.5 SIRGAS 2000 / UTM zone 25S FALSE   NULL [y]
## band    1   6      NA    NA                         NA    NA   NULL

Para escribir un vector al disco:

write_stars(x, 
         "x_exp.tif")

Las funciones st_read y st_write contienen más argumentos para definir ## Visualización de datos

Por último, el visualizar los datos nos puede dar una muy buena idea de los productos intermedios en un flujo de trabajo o verificar que la información que importamos o exportamos es la correcta. Para ver el objecto stars con todos sus atributos:

plot(x)

También se puede hacer un RGB en color natural o falso color.

plot(x, 
     rgb = c(3,2,1))

plot(x, 
     rgb = c(4,3,2))

Descargar información de trabajo

Primero vamos a cargar información desde mi github.

## [1] "D:\\Drive\\Jonathan_trabaggio\\Doctorado\\R\\SIG\\Curso\\Data\\Sentinel2-2A_10B_2020-01-01_2020-12-30.tif"
## [2] "D:\\Drive\\Jonathan_trabaggio\\Doctorado\\R\\SIG\\Curso\\Data\\SRTM_area.tif"                             
## [3] "D:\\Drive\\Jonathan_trabaggio\\Doctorado\\R\\SIG\\Curso\\Data\\roi.zip"

Veamos qué descargamos.

im1 <- read_stars(paste0(getwd(), "/Data/", "Sentinel2-2A_10B_2020-01-01_2020-12-30.tif"))

im1
## stars object with 3 dimensions and 1 attribute
## attribute(s):
##                                    Min. 1st Qu. Median     Mean 3rd Qu. Max.
## Sentinel2-2A_10B_2020-01-01_20...     6     913   1552 1501.178 2010.75 5041
## dimension(s):
##      from  to   offset        delta refsys point     values x/y
## x       1 103 -101.235  0.000179663 WGS 84 FALSE       NULL [x]
## y       1  81  19.6582 -0.000179663 WGS 84 FALSE       NULL [y]
## band    1  10       NA           NA     NA    NA B2,...,B12
plot(im1)

Operaciones básicas

Elegir parte basado en los índices de los objetos stars

Para elegir parte de los rasters, se puede hacerlo eligiendo parte del arreglo. Esto se puede hacer utilizando la notación tradicional de objetos stars o usando la forma tidyverse-esque.

En la primera forma se utiliza la notación de arreglos [], en la que la primera dimensión corresponde a la dimensión de atributos, la segunda a la primera dimensión espacial (horizontal, x), la tercera a la segunda dimensión temporal (vertical, y) y la cuarta corresponde a la dimensión espectral (bandas).

im1[,1:10,1:20]
## stars object with 3 dimensions and 1 attribute
## attribute(s):
##                                    Min. 1st Qu. Median     Mean 3rd Qu. Max.
## Sentinel2-2A_10B_2020-01-01_20...    73  691.25   1149 1315.034 1693.25 5041
## dimension(s):
##      from to   offset        delta refsys point     values x/y
## x       1 10 -101.235  0.000179663 WGS 84 FALSE       NULL [x]
## y       1 20  19.6582 -0.000179663 WGS 84 FALSE       NULL [y]
## band    1 10       NA           NA     NA    NA B2,...,B12
im1_sub1 <- im1[,1:10,1:20, 2]
im1_sub1
## stars object with 3 dimensions and 1 attribute
## attribute(s):
##                                    Min. 1st Qu. Median   Mean 3rd Qu. Max.
## Sentinel2-2A_10B_2020-01-01_20...   189  485.75  556.5 555.88     635  889
## dimension(s):
##      from to   offset        delta refsys point values x/y
## x       1 10 -101.235  0.000179663 WGS 84 FALSE   NULL [x]
## y       1 20  19.6582 -0.000179663 WGS 84 FALSE   NULL [y]
## band    2  2       NA           NA     NA    NA     B3
library(tidyverse)
## -- Attaching packages --------------------------------------- tidyverse 1.3.1 --
## v ggplot2 3.3.5     v purrr   0.3.4
## v tibble  3.1.6     v dplyr   1.0.7
## v tidyr   1.1.4     v stringr 1.4.0
## v readr   2.1.1     v forcats 0.5.1
## -- Conflicts ------------------------------------------ tidyverse_conflicts() --
## x dplyr::filter()     masks stats::filter()
## x dplyr::lag()        masks stats::lag()
## x readr::parse_date() masks curl::parse_date()
im1_sub2 <- im1 |>
  slice(x, 1:10) |>
  slice(y, 1:20) |>
  slice(band, 2) 
im1_sub2
## stars object with 2 dimensions and 1 attribute
## attribute(s):
##                                    Min. 1st Qu. Median   Mean 3rd Qu. Max.
## Sentinel2-2A_10B_2020-01-01_20...   189  485.75  556.5 555.88     635  889
## dimension(s):
##   from to   offset        delta refsys point values x/y
## x    1 10 -101.235  0.000179663 WGS 84 FALSE   NULL [x]
## y    1 20  19.6582 -0.000179663 WGS 84 FALSE   NULL [y]

Elegir parte basado en los valores de los objetos stars

Además podríamos estar interesados en filtrar valores de los rasters en función de los valores de cierta banda. Para ello, podemos hacer la función filter.

library(cubelyr)
im1_sub3 <- im1 |>
  filter(x < -101.2332, x > -101.235,
         y > 19.6564, y < 19.6582,
         band > 3 )
plot(im1_sub3)

Elegir parte basado en un vector

Para seleccionar parte de un raster basado en un vector se puede utilizar la notación tradicional de corchetes [] o la función st_crop.

roi <- st_read(paste0(getwd(), "/Data/", "roi.shp"))
## Reading layer `roi' from data source 
##   `D:\Drive\Jonathan_trabaggio\Doctorado\R\SIG\Curso\Data\roi.shp' 
##   using driver `ESRI Shapefile'
## Simple feature collection with 1 feature and 1 field
## Geometry type: POLYGON
## Dimension:     XY
## Bounding box:  xmin: -101.2307 ymin: 19.64597 xmax: -101.2206 ymax: 19.65094
## Geodetic CRS:  WGS 84
plot(roi)

im1_crop <- im1[roi]
plot(im1_crop)

im1_crop2 <- st_crop(im1, 
                     roi)
plot(im1_crop2)

Extraer parte de los objetos stars

Para extraer los valores del objeto stars y convertirlos a arreglos se puede usar la función pull. Usando esta función se extrae el atributo indicado dentro de pull.

im_pull <- im1 |>
  pull(1)
# Mostrar únicamente el encabezado y algunos datos de muestra
head(im_pull)
## , , 1
## 
##      [,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] [,9] [,10] [,11] [,12] [,13] [,14]
## [1,]  434  482  414  401  414  415  386  333  200   205   227   264   259   317
## [2,]  434  482  441  398  401  411  440  513  533   478   372   398   397   411
## [3,]  443  487  400  354  339  337  371  399  479   494   462   490   444   367
## [4,]  488  441  326  309  325  333  359  324  390   511   501   489   463   393
## [5,]  560  409  309  320  314  244  114   84  104   303   466   538   402   367
## [6,]  594  418  321  306  255   73  134  225  296   300   208   453   471   275
##      [,15] [,16] [,17] [,18] [,19] [,20] [,21] [,22] [,23] [,24] [,25] [,26]
## [1,]   155   316   402   424   426   434   422   403   369   367   189   456
## [2,]   244   224   357   419   382   398   420   392   350   346   270   408
## [3,]   192   171   257   422   478   415   394   347   336   268   459   251
## [4,]   149   153   160   343   456   465   397   320   219   193   247   109
## [5,]   130   133   136   292   416   447   435   372   171   211   155   125
## [6,]   115   107   100   207   348   460   444   373   169   559   194   225
##      [,27] [,28] [,29] [,30] [,31] [,32] [,33] [,34] [,35] [,36] [,37] [,38]
## [1,]   350   625   290   457   886   977   748   984   730   728   587   415
## [2,]   268  1015   814  1119   807   531   406   378   347   405   436   324
## [3,]   317   317   561   603   642   625   819   470   448   579   712   886
## [4,]   259   278   664   718   374   946   814   365   285   474   713   661
## [5,]   199   328   831  1035   447   995   588   414   330   734  1551   998
## [6,]   308   485  1242   799   493   636   294   890  1186  1449   902   803
##      [,39] [,40] [,41] [,42] [,43] [,44] [,45] [,46] [,47] [,48] [,49] [,50]
## [1,]   527   548   722   632   975   955  1417   828   645  1251   639   815
## [2,]   631  1060  1049   717  1335   667   679   596   724   508   521   738
## [3,]   431   304   688   513   662   932   549   375   632   611   535   555
## [4,]   506   383   581   582   633  1319   342   611   626   748  1037   477
## [5,]   298   279   393   629   716  1144   907   898   860   786   923   870
## [6,]   590  1003  1012   796  1155  1320   750  1144  1341   450   595  1233
##      [,51] [,52] [,53] [,54] [,55] [,56] [,57] [,58] [,59] [,60] [,61] [,62]
## [1,]   612   304   149   105   198   254   783   756   711   627   495   680
## [2,]   965   639   185   110   174   234   817   699   891   907   597   560
## [3,]   535   444   477   204   130   275   484   974   749   890   679   692
## [4,]   690   424  1140   392   102   174   210   596   733   927   937   770
## [5,]  1019   825   662   505   321    89   100   477   405  1350  1211   770
## [6,]   618   818   827   673   420   160   100   477   405  1350  1211  1016
##      [,63] [,64] [,65] [,66] [,67] [,68] [,69] [,70] [,71] [,72] [,73] [,74]
## [1,]   271   334   467  1429   396   781  1410   847   718   570   775   564
## [2,]   507   636   564   637  1280  1241   937   985  1004   783   690  1146
## [3,]   909   832   610   965  1300  1042   818   985  1004   783   690  1146
## [4,]  1098  1088  1220   965  1300  1042   818   928  1225   809   882  1280
## [5,]  1098  1088  1220  1130   713   881  1396   647   468   549  1516  1060
## [6,]  1078   756   856   620   444   460  1285   798   792   784   771   613
##      [,75] [,76] [,77] [,78] [,79] [,80] [,81]
## [1,]  1169  1099  1250  1012  1258  1114   776
## [2,]  1169  1099  1250  1012  1119  1352  1038
## [3,]   936  1132   821   704   883   937  1143
## [4,]   885   766   896  1327  1115  1047   582
## [5,]   707  1021  1393  1542   964  1324   844
## [6,]   558   809  1572  1467  1384   922   872
## 
## , , 2
## 
##      [,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] [,9] [,10] [,11] [,12] [,13] [,14]
## [1,]  662  695  612  616  600  651  617  623  441   440   454   485   501   591
## [2,]  662  695  640  587  599  611  634  754  866   779   655   636   656   708
## [3,]  685  707  603  507  489  507  552  614  666   721   665   697   668   692
## [4,]  729  661  505  458  463  493  540  488  574   719   689   680   708   722
## [5,]  803  619  470  475  471  369  206  202  250   477   682   742   636   749
## [6,]  889  619  469  473  404  189  291  449  508   509   442   670   774   666
##      [,15] [,16] [,17] [,18] [,19] [,20] [,21] [,22] [,23] [,24] [,25] [,26]
## [1,]   354   616   622   618   598   606   601   575   524   509   388   728
## [2,]   576   532   631   622   542   570   591   545   511   529   520   686
## [3,]   509   497   567   638   657   579   556   519   531   465   695   471
## [4,]   482   475   435   590   675   656   583   505   381   389   441   279
## [5,]   494   489   495   580   625   635   617   539   347   448   299   368
## [6,]   491   478   451   561   631   633   641   540   371   804   439   458
##      [,27] [,28] [,29] [,30] [,31] [,32] [,33] [,34] [,35] [,36] [,37] [,38]
## [1,]   546   765   525   739  1014  1196  1030  1196   997   994   832   638
## [2,]   451  1211  1060  1333   966   722   666   633   580   655   739   563
## [3,]   548   527   811   892   931   873  1113   699   738   845   957  1136
## [4,]   475   556   897  1014   573  1112  1086   651   518   678   919   902
## [5,]   460   586  1025  1267   611  1300   825   651   537  1022  1935  1227
## [6,]   646   769  1521  1064   811   927   591  1132  1436  1634  1180  1050
##      [,39] [,40] [,41] [,42] [,43] [,44] [,45] [,46] [,47] [,48] [,49] [,50]
## [1,]   681   855   957   846  1254  1153  1607  1181  1036  1885   869  1012
## [2,]   872  1281  1247   841  1392   965  1011   895  1094   819   830  1100
## [3,]   608   456   929   759   964  1185   758   657   850   854   856   903
## [4,]   785   649   765   836   752  1514   586   819   825   943  1472   665
## [5,]   545   540   611   863   900  1365  1111  1150  1021  1189  1111  1070
## [6,]   783  1256  1188   923  1295  1526  1052  1385  1653   757   971  1402
##      [,51] [,52] [,53] [,54] [,55] [,56] [,57] [,58] [,59] [,60] [,61] [,62]
## [1,]   959   538   309   253   432   465   975  1008   885   806   816   906
## [2,]  1212  1011   456   320   361   477  1037   898  1030  1163   869   737
## [3,]   914   779   779   418   308   526   662  1172  1008  1130   937   864
## [4,]   830   760  1406   588   325   439   449   874   956  1112  1034  1040
## [5,]  1331  1105   985   770   577   320   275   693   605  1551  1448  1040
## [6,]   937  1052  1121  1041   665   396   275   693   605  1551  1448  1204
##      [,63] [,64] [,65] [,66] [,67] [,68] [,69] [,70] [,71] [,72] [,73] [,74]
## [1,]   451   540   728  1702   667  1057  1646  1067   985   826  1027   897
## [2,]   697   734   791   996  1432  1421  1058  1169  1172   960   949  1411
## [3,]  1119  1122   809  1194  1556  1278  1054  1169  1172   960   949  1411
## [4,]  1283  1263  1537  1194  1556  1278  1054  1108  1492  1007  1002  1552
## [5,]  1283  1263  1537  1283   904  1088  1728   850   613   731  1772  1327
## [6,]  1251  1082  1037   850   673   695  1369   959   967   915   881   744
##      [,75] [,76] [,77] [,78] [,79] [,80] [,81]
## [1,]  1321  1295  1544  1302  1529  1336   996
## [2,]  1321  1295  1544  1302  1327  1576  1240
## [3,]  1129  1317  1073   879  1000  1232  1397
## [4,]  1023  1010  1173  1584  1252  1209   798
## [5,]   914  1130  1583  1844  1136  1448  1140
## [6,]   821   942  1729  1615  1701  1130  1033
## 
## , , 3
## 
##      [,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] [,9] [,10] [,11] [,12] [,13] [,14]
## [1,]  939  986  839  840  824  881  815  791  414   445   507   580   556   644
## [2,]  939  986  886  780  817  857  892 1007 1127   969   784   759   824   799
## [3,]  960  978  815  696  674  693  765  842  941   993   898   944   898   782
## [4,] 1028  929  683  636  652  671  741  685  792   987   970   954   981   801
## [5,] 1091  847  653  671  656  505  295  227  272   559   905  1021   843   737
## [6,] 1203  866  662  671  563  226  277  420  589   595   453   922   976   569
##      [,15] [,16] [,17] [,18] [,19] [,20] [,21] [,22] [,23] [,24] [,25] [,26]
## [1,]   367   625   815   858   834   805   787   778   728   705   443   767
## [2,]   553   524   727   820   764   782   818   764   701   708   554   730
## [3,]   454   397   610   865   898   781   773   732   737   601   738   483
## [4,]   353   330   360   726   895   884   805   676   533   414   423   272
## [5,]   282   263   286   624   833   857   854   758   408   404   311   320
## [6,]   230   232   226   408   778   864   878   744   416   869   422   457
##      [,27] [,28] [,29] [,30] [,31] [,32] [,33] [,34] [,35] [,36] [,37] [,38]
## [1,]   609   830   522   732  1120  1357  1204  1245  1161  1185  1240   841
## [2,]   528  1335  1189  1544  1136   817   773   636   645   895   916   629
## [3,]   586   567   868  1100  1091   990  1242   726   788  1283  1275  1272
## [4,]   490   570  1190  1682   688  1233  1172   681   515   751  1027  1187
## [5,]   408   543  1135  1539   721  1415   914   717   593  1200  2212  1484
## [6,]   643   790  1792  1255   916  1064   593  1194  1500  1775  1272  1082
##      [,39] [,40] [,41] [,42] [,43] [,44] [,45] [,46] [,47] [,48] [,49] [,50]
## [1,]   876  1056  1120   993  1360  1319  1735  1296  1241  2006  1024  1126
## [2,]   993  1421  1470  1018  1670  1098  1176   988  1367  1045  1038  1325
## [3,]   642   500  1034   885  1149  1408   877   790   990  1044  1079  1037
## [4,]  1145   756   896   899   885  1620   611  1069   985  1139  1517   997
## [5,]   573   521   609   912  1087  1671  1265  1341  1180  1239  1373  1230
## [6,]   800  1234  1248  1130  1539  1803  1195  1439  1708   977  1147  1449
##      [,51] [,52] [,53] [,54] [,55] [,56] [,57] [,58] [,59] [,60] [,61] [,62]
## [1,]  1012   564   291   224   385   429  1113  1044  1026  1023   881   981
## [2,]  1635  1317   471   236   334   469  1140  1078  1100  1474  1019   857
## [3,]   952   966   907   357   272   516   719  1287  1128  1213   991  1103
## [4,]   924   835  1564   538   220   345   412   994  1045  1182  1213  1209
## [5,]  1444  1176  1157   883   553   217   235   688   719  1683  1504  1209
## [6,]  1078  1210  1274  1200   773   345   235   688   719  1683  1504  1300
##      [,63] [,64] [,65] [,66] [,67] [,68] [,69] [,70] [,71] [,72] [,73] [,74]
## [1,]   455   525   749  1680   617  1122  1724  1225  1098   935  1173  1113
## [2,]   726   779   853   958  1472  1538  1244  1396  1339  1076  1079  1728
## [3,]  1242  1224   954  1333  1876  1471  1211  1396  1339  1076  1079  1728
## [4,]  1396  1567  1734  1333  1876  1471  1211  1232  1606  1202  1167  1777
## [5,]  1396  1567  1734  1416  1257  1240  1864   883   657   994  1970  1409
## [6,]  1354  1159  1164  1059   894   710  1565  1160  1098   983   945   831
##      [,75] [,76] [,77] [,78] [,79] [,80] [,81]
## [1,]  1560  1543  1869  1469  1919  1555  1183
## [2,]  1560  1543  1869  1469  1555  1816  1433
## [3,]  1374  1456  1202   985  1234  1628  1580
## [4,]  1195  1118  1310  1637  1316  1255   870
## [5,]  1039  1245  1744  1939  1295  1668  1282
## [6,]   874  1022  2013  1786  1940  1452  1289
## 
## , , 4
## 
##      [,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] [,9] [,10] [,11] [,12] [,13] [,14]
## [1,] 1078 1072  972  991 1036 1066 1187 1172  970   906   864   815  1065   984
## [2,] 1078 1072 1017  926  940  982 1002 1219 1378  1251  1072  1032  1153  1201
## [3,] 1096 1111  961  809  768  777  859  959 1105  1220  1109  1049  1115  1211
## [4,] 1168 1063  815  733  744  788  827  816  876  1075  1061  1058  1116  1265
## [5,] 1271 1011  752  759  770  566  360  409  508   913  1153  1147  1177  1222
## [6,] 1345 1149  759  783  610  399  597  850  984   867   856  1062  1404  1213
##      [,15] [,16] [,17] [,18] [,19] [,20] [,21] [,22] [,23] [,24] [,25] [,26]
## [1,]   878  1081  1065   962   936   926   922   856   852   820   823   946
## [2,]  1080  1010  1130   980   883   879   920   882   846   786  1001  1044
## [3,]  1023   986  1057  1068  1006   926   891   847   803   860  1032   809
## [4,]  1036   924   903  1013  1090   986   899   784   658   732   669   551
## [5,]  1012   906   916  1030  1082   970   970   869   650   756   668   685
## [6,]   957   939   897   979  1104  1019   991   862   872   972   841   897
##      [,27] [,28] [,29] [,30] [,31] [,32] [,33] [,34] [,35] [,36] [,37] [,38]
## [1,]   915  1058  1065  1217  1259  1300  1440  1491  1433  1402  1426  1152
## [2,]   828  1222  1472  1894  1248  1188  1202  1008   936  1345  1358   945
## [3,]   906   925  1156  1431  1159  1343  1558  1148  1110  1402  1446  1331
## [4,]   865   876  1507  1816  1132  1399  1410  1025   918  1027  1348  1651
## [5,]   920   877  1381  1591  1047  1581  1120  1009  1036  1536  2175  1631
## [6,]  1049  1166  1968  1552  1234  1511  1127  1468  1685  1813  1604  1104
##      [,39] [,40] [,41] [,42] [,43] [,44] [,45] [,46] [,47] [,48] [,49] [,50]
## [1,]  1152  1271  1342  1303  1393  1476  1599  1530  1598  2419  1517  1444
## [2,]  1137  1479  1437  1310  1760  1493  1534  1576  1671  1412  1397  1776
## [3,]  1102   949  1173  1106  1460  1397  1234  1114  1246  1394  1486  1492
## [4,]  1455  1055  1103  1050  1259  1439  1068  1205  1262  1323  1694  1368
## [5,]   994   932  1059  1036  1474  1834  1361  1465  1416  1593  1789  1551
## [6,]  1114  1353  1431  1287  1635  1705  1379  1710  1736  1419  1362  1583
##      [,51] [,52] [,53] [,54] [,55] [,56] [,57] [,58] [,59] [,60] [,61] [,62]
## [1,]  1382  1005   628   618   711   829  1245  1359  1236  1280  1342  1248
## [2,]  1997  1713   965   636   671   856  1266  1281  1225  1513  1423   994
## [3,]  1379  1365  1353   749   641   846  1048  1339  1430  1199  1243  1381
## [4,]  1167  1271  1540   894   600   775   842  1190  1363  1310  1470  1378
## [5,]  1636  1532  1492  1257   924   643   585   891  1016  1775  1637  1378
## [6,]  1455  1319  1593  1579  1111   733   585   891  1016  1775  1637  1303
##      [,63] [,64] [,65] [,66] [,67] [,68] [,69] [,70] [,71] [,72] [,73] [,74]
## [1,]   826   840  1089  1202  1057  1402  1680  1461  1422  1179  1425  1638
## [2,]   960  1158  1129  1368  1813  1809  1366  1402  1409  1307  1331  1762
## [3,]  1417  1342  1145  1510  1882  1604  1530  1402  1409  1307  1331  1762
## [4,]  1489  1673  1701  1510  1882  1604  1530  1368  1437  1413  1609  1731
## [5,]  1489  1673  1701  1474  1472  1514  1852  1304   805  1354  1913  1534
## [6,]  1446  1457  1437  1396  1131  1169  1565  1226  1181  1248  1116  1077
##      [,75] [,76] [,77] [,78] [,79] [,80] [,81]
## [1,]  1559  1759  1940  1692  1996  1627  1583
## [2,]  1559  1759  1940  1692  1660  1795  1639
## [3,]  1665  1445  1305  1273  1377  1759  1708
## [4,]  1301  1330  1417  1644  1461  1435  1161
## [5,]  1209  1386  1822  2042  1571  1782  1578
## [6,]  1114  1063  2397  2174  1617  1621  1438
## 
## , , 5
## 
##      [,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] [,9] [,10] [,11] [,12] [,13] [,14]
## [1,] 1200 1128 1139 1219 1298 1410 1644 1632 1762  1640  1350  1337  1648  1754
## [2,] 1200 1128 1067 1021 1025 1038 1151 1524 1966  1979  1676  1638  1694  2047
## [3,] 1179 1156 1077  975  886  883  928 1074 1225  1353  1207  1161  1203  1954
## [4,] 1237 1165  910  755  758  906  967  863  937  1141  1160  1182  1397  2180
## [5,] 1313 1106  802  827  814  547  502  704 1175  1507  1528  1286  1575  2381
## [6,] 1624 1225  871  834  617  676 1375 1866 1766  1522  1538  1523  1959  2747
##      [,15] [,16] [,17] [,18] [,19] [,20] [,21] [,22] [,23] [,24] [,25] [,26]
## [1,]  1557  2128  1529  1209  1099  1021   951   968  1004   879  1350  1877
## [2,]  2076  1990  1679  1201   957  1001  1035   964   933  1049  1684  1594
## [3,]  2337  2208  1901  1501  1145  1003   994   902   958  1141  1752  1326
## [4,]  2777  2672  2099  1621  1295  1097  1021   876   759  1455  1315  1380
## [5,]  2996  3032  2832  2120  1414  1156  1116   869  1138  1458  1207  1850
## [6,]  3236  3008  3117  2547  1676  1212  1124  1000  1478  1959  1540  1930
##      [,27] [,28] [,29] [,30] [,31] [,32] [,33] [,34] [,35] [,36] [,37] [,38]
## [1,]  1329  1547  1798  2064  1537  1834  1965  1912  2004  1986  1857  1515
## [2,]  1355  1660  1991  2051  1457  1586  1967  1879  1566  1855  1930  1472
## [3,]  1458  1342  1868  2146  1433  1555  2115  1976  1692  1736  1850  1757
## [4,]  1778  1770  2042  2094  1233  1822  1913  1844  1733  1731  1842  1938
## [5,]  1983  2024  1909  1768  1421  2012  1754  1626  1603  2099  2435  2011
## [6,]  2058  1856  2177  1445  1991  1967  1555  1910  1965  1904  1679  1465
##      [,39] [,40] [,41] [,42] [,43] [,44] [,45] [,46] [,47] [,48] [,49] [,50]
## [1,]  1462  1630  1485  1627  1912  1767  2125  2427  2285  2109  1716  2190
## [2,]  1486  1650  1721  1634  1959  1857  1946  2082  2135  2136  2199  2470
## [3,]  1690  1542  1368  1705  1893  1805  1850  1923  1693  1850  2163  2432
## [4,]  1928  1698  1434  1519  1644  2051  1533  1601  1569  1955  2314  1829
## [5,]  1718  1741  1547  1610  1638  1888  1591  1679  1968  2188  1980  1913
## [6,]  1562  1847  1877  1686  1854  1804  1520  1944  2213  2000  2193  2228
##      [,51] [,52] [,53] [,54] [,55] [,56] [,57] [,58] [,59] [,60] [,61] [,62]
## [1,]  2382  1954  1558  1428  1670  1483  1504  1853  1591  1747  2130  1765
## [2,]  2567  2400  1671  1514  1624  1708  1754  1746  1498  1629  1896  1639
## [3,]  2348  2013  1803  1597  1469  1470  1536  1653  1748  1517  1812  1592
## [4,]  1810  2024  1959  1585  1874  1776  1464  1664  1708  1615  1507  1403
## [5,]  1982  2037  2288  1939  1946  1954  1510  1601  1493  1891  1844  1403
## [6,]  1932  1907  2137  2202  1881  1470  1510  1601  1493  1891  1844  1577
##      [,63] [,64] [,65] [,66] [,67] [,68] [,69] [,70] [,71] [,72] [,73] [,74]
## [1,]  1484  1494  1841  2080  1903  1949  1799  1545  1717  1698  1758  2023
## [2,]  1602  1593  1639  1717  2291  2085  1667  1496  1505  1652  1732  2013
## [3,]  1429  1390  1426  1691  2100  1855  1655  1496  1505  1652  1732  2013
## [4,]  1618  1814  1851  1691  2100  1855  1655  1546  1657  1779  1748  1888
## [5,]  1618  1814  1851  1720  1623  1717  1959  1261  1362  1445  1896  1837
## [6,]  1759  1991  1862  1754  1892  1854  1958  1362  1493  1507  1589  1496
##      [,75] [,76] [,77] [,78] [,79] [,80] [,81]
## [1,]  1791  1780  1967  1714  2059  1715  1565
## [2,]  1791  1780  1967  1714  1740  1913  1757
## [3,]  1672  1807  1620  1514  1510  1841  1891
## [4,]  1419  1402  1459  1802  1704  1527  1646
## [5,]  1411  1494  2038  2236  1472  1757  1779
## [6,]  1466  1433  2122  2400  1977  1723  1572
## 
## , , 6
## 
##      [,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] [,9] [,10] [,11] [,12] [,13] [,14]
## [1,] 1246 1271 1268 1252 1259 1473 1689 2021 2088  1716  1603  1578  1866  1810
## [2,] 1246 1271 1156 1135 1156 1225 1301 1650 2214  2454  1938  1629  1776  2510
## [3,] 1244 1235 1187 1030  944  978 1039 1153 1344  1303  1184  1299  1457  2308
## [4,] 1314 1255  998  859  884  918  873  747 1009  1297  1332  1333  1479  2470
## [5,] 1423 1241  887  901  892  707  712 1070 1440  1638  1641  1412  1781  2882
## [6,] 1863 1350  918  883  700  700 1261 1945 1915  1928  1918  1800  2230  3187
##      [,15] [,16] [,17] [,18] [,19] [,20] [,21] [,22] [,23] [,24] [,25] [,26]
## [1,]  1849  2326  1596  1186  1118  1198  1183  1094   985   886  1602  2139
## [2,]  2513  2332  1912  1361  1074  1070  1115  1085  1076  1230  1906  1696
## [3,]  2616  2477  2191  1648  1259  1132  1090  1010  1003  1350  2138  1628
## [4,]  3260  3198  2465  1807  1460  1258  1149   972   951  1509  1487  1491
## [5,]  3622  3610  3435  2520  1605  1267  1192  1019  1316  1717  1537  2025
## [6,]  3726  3651  3742  3216  2019  1421  1251  1125  1738  1966  1727  2234
##      [,27] [,28] [,29] [,30] [,31] [,32] [,33] [,34] [,35] [,36] [,37] [,38]
## [1,]  1511  1755  2200  2470  1555  1677  2148  2163  2061  2064  1985  1577
## [2,]  1314  1493  2081  2229  1594  1898  2348  2029  1793  2051  2071  1670
## [3,]  1902  1697  2160  2181  1519  1735  2427  2284  1865  1762  1962  1766
## [4,]  1982  1933  2153  2228  1323  1829  2008  2251  1918  1857  1944  2165
## [5,]  2367  2246  2015  1732  1535  2185  1723  1673  1859  2271  2435  2006
## [6,]  2282  2113  2529  1546  2293  2156  1850  2072  2081  2026  1863  1567
##      [,39] [,40] [,41] [,42] [,43] [,44] [,45] [,46] [,47] [,48] [,49] [,50]
## [1,]  1680  1821  1698  1757  1837  1798  2103  2549  2459  2456  2008  2468
## [2,]  1785  1704  1714  1712  2101  1942  2213  2438  2406  2421  2514  2760
## [3,]  1641  1601  1542  1860  2115  1928  2163  2077  1771  2085  2452  2685
## [4,]  2326  2009  1676  1669  1710  1909  1681  1809  1758  2125  2498  2038
## [5,]  1778  1892  1823  1670  1866  2107  1620  1760  2172  2375  2149  2013
## [6,]  1795  1866  1881  1803  1866  1742  1635  2080  2371  2287  2324  2391
##      [,51] [,52] [,53] [,54] [,55] [,56] [,57] [,58] [,59] [,60] [,61] [,62]
## [1,]  2667  2159  1796  1857  1926  1716  1678  2097  1639  1949  2383  1980
## [2,]  2757  2579  1936  1843  1842  1841  1832  1826  1487  1778  2028  1818
## [3,]  2673  2321  2038  1765  1694  1765  1747  1830  1838  1593  1901  1717
## [4,]  2032  2332  2072  1836  2172  1978  1713  1849  1816  1669  1576  1407
## [5,]  2112  2324  2539  2286  2254  2290  1777  1797  1634  2097  1866  1407
## [6,]  2103  1920  2235  2403  2127  1853  1777  1797  1634  2097  1866  1614
##      [,63] [,64] [,65] [,66] [,67] [,68] [,69] [,70] [,71] [,72] [,73] [,74]
## [1,]  1673  1724  2010  2182  2190  2086  1861  1566  1898  1832  1918  2167
## [2,]  1786  1784  1879  1911  2436  2204  1747  1454  1632  1794  1878  2032
## [3,]  1563  1437  1525  1782  2212  1886  1744  1454  1632  1794  1878  2032
## [4,]  1636  1829  1840  1782  2212  1886  1744  1590  1718  1803  1827  1949
## [5,]  1636  1829  1840  1767  1674  1811  1994  1409  1470  1512  1957  1918
## [6,]  1894  2131  1937  1895  2030  2091  1997  1426  1709  1636  1725  1634
##      [,75] [,76] [,77] [,78] [,79] [,80] [,81]
## [1,]  1768  1820  1934  1744  2073  1771  1707
## [2,]  1768  1820  1934  1744  1716  1966  1873
## [3,]  1749  1821  1744  1660  1576  1896  1851
## [4,]  1480  1518  1515  1967  1706  1693  1798
## [5,]  1452  1554  2137  2192  1496  1802  1790
## [6,]  1653  1398  2207  2378  2023  1814  1656
## 
## , , 7
## 
##      [,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] [,9] [,10] [,11] [,12] [,13] [,14]
## [1,] 1318 1372 1324 1338 1383 1619 1868 2271 2197  1884  1620  1586  1925  2182
## [2,] 1318 1372 1248 1233 1357 1336 1343 1686 2531  2585  2089  1937  2015  2760
## [3,] 1327 1354 1267 1120 1005 1046 1134 1208 1398  1474  1348  1417  1455  2533
## [4,] 1386 1399 1104  938  976  989 1095 1012 1218  1463  1427  1424  1619  2743
## [5,] 1504 1322  973 1010  960  807  591  912 1249  1751  1739  1581  1872  3018
## [6,] 2108 1390 1028  986  858  668 1523 2383 2210  1974  2039  1880  2463  3438
##      [,15] [,16] [,17] [,18] [,19] [,20] [,21] [,22] [,23] [,24] [,25] [,26]
## [1,]  1877  2681  1633  1361  1305  1241  1273  1231  1191  1184  1522  2377
## [2,]  2719  2481  2175  1432  1175  1184  1238  1179  1156  1303  2172  1665
## [3,]  2896  2767  2424  1811  1404  1219  1186  1135  1177  1373  2353  1627
## [4,]  3585  3357  2545  2059  1570  1396  1225  1061   950  1710  1621  1626
## [5,]  3939  3867  3723  2707  1707  1370  1350  1208  1208  2090  1312  2346
## [6,]  4087  3874  3986  3524  2174  1500  1415  1348  1567  2469  1816  2279
##      [,27] [,28] [,29] [,30] [,31] [,32] [,33] [,34] [,35] [,36] [,37] [,38]
## [1,]  1722  1797  2202  2239  1625  1780  2396  2099  2344  2174  1848  1830
## [2,]  1394  1892  1849  2119  1670  1984  2374  2222  1653  2178  2127  1737
## [3,]  2032  1381  2425  2169  1562  1873  2507  2394  2218  1848  2035  1874
## [4,]  2115  2123  2305  2324  1226  1993  2017  2457  1888  1952  2005  2350
## [5,]  2491  2420  2121  1790  1553  2287  1843  1886  1883  2311  2574  2068
## [6,]  2684  2239  2320  1481  2620  1956  1845  2195  2018  2092  1816  1630
##      [,39] [,40] [,41] [,42] [,43] [,44] [,45] [,46] [,47] [,48] [,49] [,50]
## [1,]  1533  1824  1693  1848  1899  1742  2413  2753  2602  2981  1949  2619
## [2,]  1928  1861  1846  1736  2265  1940  2269  2425  2705  2716  2677  2977
## [3,]  1727  1735  1588  1955  2163  1986  2291  2329  1895  2345  2800  2914
## [4,]  2383  2173  1646  1861  1613  2012  1922  1935  1800  2097  2588  2047
## [5,]  1881  2161  1770  1796  1900  2081  1680  1802  2199  2640  2311  2141
## [6,]  1799  1941  2070  1960  1962  1975  1612  2234  2312  2300  2366  2544
##      [,51] [,52] [,53] [,54] [,55] [,56] [,57] [,58] [,59] [,60] [,61] [,62]
## [1,]  2912  2447  1906  1811  2109  1852  1725  2124  1716  2052  2439  2086
## [2,]  2773  2819  1905  2007  1927  2062  1967  2083  1575  1883  2370  1908
## [3,]  2931  2385  2157  2057  1724  2038  1586  1912  1906  1542  1821  1644
## [4,]  2016  2653  2424  1837  2543  2179  1829  1932  1859  1625  1687  1584
## [5,]  2144  2337  2860  2168  2335  2223  1657  1984  1669  2251  2015  1584
## [6,]  2292  1955  2405  2697  2191  2222  1657  1984  1669  2251  2015  1617
##      [,63] [,64] [,65] [,66] [,67] [,68] [,69] [,70] [,71] [,72] [,73] [,74]
## [1,]  1795  1895  2036  2427  2226  2203  2009  1459  2107  1832  2068  2095
## [2,]  1908  1801  1875  1840  2575  2264  1720  1454  1803  1848  1940  2218
## [3,]  1629  1686  1621  1881  2240  1870  1685  1454  1803  1848  1940  2218
## [4,]  1655  1770  1962  1881  2240  1870  1685  1472  1792  1778  1754  2105
## [5,]  1655  1770  1962  1792  1788  1796  2444  1106  1696  1553  2261  1937
## [6,]  2043  2077  1919  1936  2194  2040  2060  1429  1828  1675  1594  1778
##      [,75] [,76] [,77] [,78] [,79] [,80] [,81]
## [1,]  1719  1926  2236  1721  2040  1912  1753
## [2,]  1719  1926  2236  1721  1778  1964  1715
## [3,]  1568  1858  1754  1712  1537  1862  1890
## [4,]  1493  1620  1713  2018  1583  1784  1802
## [5,]  1422  1692  1954  2276  1539  1938  1585
## [6,]  1583  1521  2389  2206  2269  1672  1637
## 
## , , 8
## 
##      [,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] [,9] [,10] [,11] [,12] [,13] [,14]
## [1,] 1412 1394 1445 1371 1454 1671 1929 2432 2313  1977  1834  1773  2173  2053
## [2,] 1412 1394 1294 1263 1382 1416 1473 1878 2560  2673  2160  1811  2094  2717
## [3,] 1372 1435 1330 1132 1076 1088 1196 1285 1531  1485  1428  1431  1725  2587
## [4,] 1380 1393 1172 1022 1052 1064  993  957 1185  1500  1455  1454  1691  2865
## [5,] 1588 1406 1041 1029 1031  808  756 1198 1447  1799  1861  1607  2056  3175
## [6,] 2062 1584 1034 1059  839  727 1419 2113 2044  2031  2054  1991  2653  3539
##      [,15] [,16] [,17] [,18] [,19] [,20] [,21] [,22] [,23] [,24] [,25] [,26]
## [1,]  2173  2465  1946  1403  1307  1403  1407  1279  1145  1155  1779  2189
## [2,]  2870  2581  2235  1543  1270  1246  1268  1283  1285  1316  2134  1908
## [3,]  2947  2770  2475  1856  1500  1310  1225  1153  1158  1611  2249  1724
## [4,]  3585  3511  2702  2131  1731  1451  1351  1119  1079  1680  1703  1672
## [5,]  3940  4064  3669  2818  1843  1493  1433  1248  1419  2061  1688  2169
## [6,]  4042  4030  3999  3535  2313  1629  1429  1387  1898  2101  2118  2352
##      [,27] [,28] [,29] [,30] [,31] [,32] [,33] [,34] [,35] [,36] [,37] [,38]
## [1,]  1746  1752  2485  2700  1604  1841  2367  2204  2198  2242  1964  1722
## [2,]  1366  1642  2174  2475  1711  2114  2605  2280  1961  2263  2122  1891
## [3,]  2057  1842  2349  2311  1626  1899  2563  2468  1898  1886  2040  1827
## [4,]  2106  1976  2351  2207  1484  1797  2201  2406  2085  2083  2084  2380
## [5,]  2740  2355  2149  1681  1683  2279  1860  1968  1978  2392  2564  2084
## [6,]  2477  2429  2368  1963  2235  2166  1964  2153  2092  2094  1939  1630
##      [,39] [,40] [,41] [,42] [,43] [,44] [,45] [,46] [,47] [,48] [,49] [,50]
## [1,]  1769  1825  1868  1863  1897  1956  2346  2625  2677  2665  2085  2741
## [2,]  1918  1813  1839  1874  2228  2031  2388  2593  2850  2725  2817  3007
## [3,]  1834  1772  1680  2028  2229  1964  2407  2426  2047  2384  2821  2931
## [4,]  2506  2224  1858  1856  1779  1823  1963  1960  1900  2286  2628  2162
## [5,]  1957  2142  2044  1810  1999  2038  1774  1861  2187  2505  2284  2189
## [6,]  1801  1956  2050  1895  1948  1935  1770  2205  2367  2481  2386  2605
##      [,51] [,52] [,53] [,54] [,55] [,56] [,57] [,58] [,59] [,60] [,61] [,62]
## [1,]  2926  2511  2102  1960  2096  1942  1772  2162  1758  2006  2476  2195
## [2,]  2950  2677  2325  2102  1964  2131  1977  2079  1559  1973  2229  2011
## [3,]  2984  2604  2235  2055  1812  1996  1744  1980  1857  1740  1984  1798
## [4,]  2116  2613  2279  1974  2260  2268  1807  1993  1916  1713  1691  1515
## [5,]  2146  2526  2706  2472  2441  2412  1955  1925  1798  2126  1975  1515
## [6,]  2291  2102  2500  2582  2298  2064  1955  1925  1798  2126  1975  1714
##      [,63] [,64] [,65] [,66] [,67] [,68] [,69] [,70] [,71] [,72] [,73] [,74]
## [1,]  1831  1911  2060  2307  2308  2268  1876  1717  2042  1854  2076  2137
## [2,]  1860  1934  1887  1902  2428  2438  1733  1562  1807  1868  2019  2064
## [3,]  1630  1571  1666  1891  2216  1942  1798  1562  1807  1868  2019  2064
## [4,]  1749  1849  1920  1891  2216  1942  1798  1539  1722  1788  1879  2041
## [5,]  1749  1849  1920  1824  1707  1929  2184  1502  1370  1688  2069  1960
## [6,]  2026  2112  1967  2005  2113  2306  2022  1699  1742  1769  1813  1854
##      [,75] [,76] [,77] [,78] [,79] [,80] [,81]
## [1,]  1694  1868  2024  1818  2018  1864  1946
## [2,]  1694  1868  2024  1818  1790  1931  1953
## [3,]  1837  1783  1862  1739  1682  1746  1894
## [4,]  1620  1607  1680  1926  1647  1846  1854
## [5,]  1548  1698  2210  2162  1637  1869  1679
## [6,]  1787  1533  2376  2222  2003  1912  1755
## 
## , , 9
## 
##      [,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] [,9] [,10] [,11] [,12] [,13] [,14]
## [1,] 1909 1893 1870 1809 1834 1967 1998 2006 1730  1550  1696  1754  1978  1788
## [2,] 1909 1893 1742 1742 1818 1865 1990 2189 2252  2194  1940  1885  2054  2223
## [3,] 1856 1882 1761 1668 1603 1605 1675 1833 2036  2094  2033  2083  2098  2244
## [4,] 1908 1849 1679 1559 1533 1538 1469 1404 1612  2009  2050  2091  2134  2229
## [5,] 2054 1851 1587 1568 1497 1185  928  913 1108  1532  1976  2131  2321  2226
## [6,] 2588 2151 1665 1508 1219  900 1004 1328 1568  1577  1647  2057  2504  2082
##      [,15] [,16] [,17] [,18] [,19] [,20] [,21] [,22] [,23] [,24] [,25] [,26]
## [1,]  1584  2019  2279  2168  2086  2095  2080  2036  1950  1803  1687  1695
## [2,]  2037  2000  2217  2160  1997  1959  1956  1895  1844  1777  1760  1584
## [3,]  1911  1791  2130  2346  2249  2050  1929  1831  1780  1747  1726  1415
## [4,]  1875  1692  1831  2186  2433  2312  2056  1735  1493  1414  1303  1273
## [5,]  1777  1642  1701  2111  2347  2329  2189  1908  1516  1371  1220  1353
## [6,]  1596  1594  1631  1942  2329  2379  2279  2151  1900  1720  1534  1655
##      [,27] [,28] [,29] [,30] [,31] [,32] [,33] [,34] [,35] [,36] [,37] [,38]
## [1,]  1581  1630  1687  2141  2019  1978  2153  2314  2345  2077  1961  1870
## [2,]  1513  2000  2112  2465  1958  1924  2103  2029  1992  2082  1964  1726
## [3,]  1686  1609  2043  2398  1857  1863  2132  1926  1939  2156  2089  1906
## [4,]  1679  1734  2225  2376  1765  1947  2030  1862  1637  1916  2276  2344
## [5,]  1708  1807  2121  2133  1764  2301  1733  1573  1747  2408  2886  2476
## [6,]  1911  1980  2384  1798  1876  1955  1642  1790  2202  2453  2443  2018
##      [,39] [,40] [,41] [,42] [,43] [,44] [,45] [,46] [,47] [,48] [,49] [,50]
## [1,]  1976  2117  2086  2009  2063  1994  2353  2468  2635  2651  2375  2556
## [2,]  1835  2139  2261  2004  2174  1985  2145  2540  3014  2929  2730  2865
## [3,]  1664  1697  2153  2061  2120  2165  2145  2427  2581  2638  2795  2660
## [4,]  2209  1961  2043  1854  1840  2049  1936  2202  2110  2286  2362  2143
## [5,]  1935  1682  1786  1807  1918  2176  2159  2269  2195  2266  2239  2193
## [6,]  1775  1966  2067  2012  2381  2448  2216  2347  2430  2430  2495  2429
##      [,51] [,52] [,53] [,54] [,55] [,56] [,57] [,58] [,59] [,60] [,61] [,62]
## [1,]  2587  2065  1332  1106  1370  1454  1830  2025  1959  2113  2266  2046
## [2,]  2983  2730  1735  1174  1298  1531  2064  2154  1958  2042  2153  1914
## [3,]  2498  2520  2133  1381  1239  1494  1808  2077  2132  2050  2175  2010
## [4,]  2135  2292  2308  1610  1270  1386  1446  1778  1989  1998  1952  1990
## [5,]  2239  2307  2330  2017  1618  1232  1135  1481  1704  2258  2182  1990
## [6,]  2309  2227  2296  2356  1934  1372  1135  1481  1704  2258  2182  2049
##      [,63] [,64] [,65] [,66] [,67] [,68] [,69] [,70] [,71] [,72] [,73] [,74]
## [1,]  1600  1594  1784  1854  1849  2143  2227  2079  2055  2006  2024  2189
## [2,]  1676  1703  1668  1775  2124  2265  2141  2043  2022  2003  2116  2352
## [3,]  1947  1918  1890  2031  2403  2241  2077  2043  2022  2003  2116  2352
## [4,]  2202  2284  2188  2031  2403  2241  2077  1887  1886  1966  2103  2250
## [5,]  2202  2284  2188  2085  2112  2250  2214  1558  1410  1807  2126  2086
## [6,]  2145  2119  2019  2012  2006  2052  2184  1826  1878  1935  1939  1875
##      [,75] [,76] [,77] [,78] [,79] [,80] [,81]
## [1,]  2192  2409  2448  2288  2507  2349  2311
## [2,]  2192  2409  2448  2288  2330  2589  2409
## [3,]  2303  2215  2041  1864  2130  2585  2343
## [4,]  1970  1995  1911  2019  2000  2085  2116
## [5,]  1952  2167  2746  2542  2156  2304  2167
## [6,]  1868  1990  2826  2773  2373  2208  2178
## 
## , , 10
## 
##      [,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] [,9] [,10] [,11] [,12] [,13] [,14]
## [1,] 1480 1488 1448 1391 1399 1439 1500 1418 1118  1129  1194  1196  1329  1207
## [2,] 1480 1488 1411 1362 1404 1457 1524 1705 1699  1508  1438  1516  1524  1417
## [3,] 1469 1495 1384 1305 1276 1294 1363 1502 1696  1853  1784  1709  1639  1443
## [4,] 1483 1444 1331 1270 1258 1278 1250 1186 1353  1675  1802  1771  1624  1419
## [5,] 1602 1485 1308 1293 1249 1011  698  600  720  1149  1613  1787  1682  1344
## [6,] 1925 1700 1348 1263 1025  662  669  857 1100  1082  1161  1473  1732  1237
##      [,15] [,16] [,17] [,18] [,19] [,20] [,21] [,22] [,23] [,24] [,25] [,26]
## [1,]   967  1219  1648  1758  1693  1707  1708  1682  1574  1444  1168  1107
## [2,]  1176  1180  1553  1760  1696  1647  1687  1609  1517  1366  1247  1223
## [3,]  1082  1017  1325  1785  1925  1795  1625  1540  1442  1296  1233   989
## [4,]  1006   831  1022  1517  1973  2025  1771  1460  1152   968   842   737
## [5,]   906   780   888  1302  1806  1975  1869  1597  1061   903   796   796
## [6,]   783   735   765  1068  1622  1921  1914  1711  1286  1166  1038  1002
##      [,27] [,28] [,29] [,30] [,31] [,32] [,33] [,34] [,35] [,36] [,37] [,38]
## [1,]  1197  1371  1348  1813  1784  1554  1666  1832  1869  1615  1513  1524
## [2,]  1164  1694  1944  2578  1904  1628  1507  1426  1576  1604  1460  1288
## [3,]  1116  1266  1580  1960  1555  1542  1636  1344  1440  1709  1716  1720
## [4,]  1070  1179  1772  2129  1641  1746  1638  1317  1138  1466  1891  1954
## [5,]  1035  1191  1759  2042  1479  1958  1379  1139  1276  2058  2795  2263
## [6,]  1151  1411  2318  2014  1456  1641  1171  1317  1878  2246  2229  1803
##      [,39] [,40] [,41] [,42] [,43] [,44] [,45] [,46] [,47] [,48] [,49] [,50]
## [1,]  1676  1897  1839  1746  1938  1834  1997  1900  1911  2084  1844  1859
## [2,]  1403  1894  2222  1769  1952  1768  1752  1898  2240  2094  1965  2159
## [3,]  1473  1427  1895  1624  1782  1838  1541  1656  1951  1920  1826  1863
## [4,]  1631  1315  1726  1651  1612  1829  1597  1779  1719  1817  1846  1722
## [5,]  1514  1261  1442  1531  1644  1984  2042  1953  1814  1855  1826  1836
## [6,]  1552  1746  1849  1825  2226  2318  2029  2183  2255  1993  1913  1926
##      [,51] [,52] [,53] [,54] [,55] [,56] [,57] [,58] [,59] [,60] [,61] [,62]
## [1,]  1801  1435   821   613   811  1012  1657  1674  1638  1808  1789  1556
## [2,]  2256  1933  1138   682   757  1033  1753  1802  1710  1783  1756  1467
## [3,]  1830  1766  1574   936   724   971  1456  1813  1934  1876  1982  1869
## [4,]  1696  1680  1837  1220   727   833   949  1362  1823  1771  1810  1848
## [5,]  2060  1874  1744  1530  1115   746   692  1057  1369  1878  1919  1848
## [6,]  1903  1872  1928  1790  1474   860   692  1057  1369  1878  1919  1892
##      [,63] [,64] [,65] [,66] [,67] [,68] [,69] [,70] [,71] [,72] [,73] [,74]
## [1,]  1109  1173  1383  1471  1400  1760  2154  2059  1864  1707  1748  1814
## [2,]  1322  1417  1332  1466  1815  2213  2112  2035  1936  1818  1871  2119
## [3,]  1822  1868  1696  1806  2438  2347  2042  2035  1936  1818  1871  2119
## [4,]  2092  2214  2123  1806  2438  2347  2042  1855  1795  1812  1876  2060
## [5,]  2092  2214  2123  1972  1865  1921  1924  1386  1206  1498  1880  1915
## [6,]  2027  1868  1807  1722  1528  1570  1869  1689  1625  1704  1720  1563
##      [,75] [,76] [,77] [,78] [,79] [,80] [,81]
## [1,]  2026  2274  2359  2254  2495  2443  2402
## [2,]  2026  2274  2359  2254  2278  2625  2568
## [3,]  2199  2084  1830  1685  1920  2164  2106
## [4,]  1878  1942  1804  1891  1908  2030  1852
## [5,]  1824  2048  2751  2488  2102  2182  2015
## [6,]  1647  1812  2697  2733  2209  2019  2068

Agregar un nuevo atributo

Para agregar un nuevo atributo en función de los que ya existen.

names(im1) <- "Sentinel2"
im2 <- im1 |> 
  mutate(band2 = 2 * Sentinel2)
im2
## stars object with 3 dimensions and 2 attributes
## attribute(s):
##            Min. 1st Qu. Median     Mean 3rd Qu.  Max.
## Sentinel2     6     913   1552 1501.178 2010.75  5041
## band2        12    1826   3104 3002.356 4021.50 10082
## dimension(s):
##      from  to   offset        delta refsys point     values x/y
## x       1 103 -101.235  0.000179663 WGS 84 FALSE       NULL [x]
## y       1  81  19.6582 -0.000179663 WGS 84 FALSE       NULL [y]
## band    1  10       NA           NA     NA    NA B2,...,B12

Ahora ya tenemos dos atributos.

Para seleccionar ciertos atributos

Para seleccionar algunos atributos se usa select.

im2 |> 
  select(band2)
## stars object with 3 dimensions and 1 attribute
## attribute(s):
##        Min. 1st Qu. Median     Mean 3rd Qu.  Max.
## band2    12    1826   3104 3002.356  4021.5 10082
## dimension(s):
##      from  to   offset        delta refsys point     values x/y
## x       1 103 -101.235  0.000179663 WGS 84 FALSE       NULL [x]
## y       1  81  19.6582 -0.000179663 WGS 84 FALSE       NULL [y]
## band    1  10       NA           NA     NA    NA B2,...,B12

Cálculo de índices

En algunos casos estaremos más interesados en calcular índices que resalten algunas características de la superficie terrestre. Por ejemplo, algún índice de vegetación. Esto se puede realizar al seleccionar las bandas de interés y aplicar la fórmula.

NIR <- im1[,,,8]
R <- im1 [,,,4]

# Tidyverse-esque
# Si no se agrega drop = F, se elimina la tercera dimensión y luego ya no permite concatenar esta banda con el resto de la imagen.
NIR <- im1 |>
  slice(band, 8, drop = F)
R <- im1 |>
  slice(band, 4, drop = F)

NDVI <- (NIR - R) / (NIR + R)

plot(NDVI)

Agregar bandas a un raster

Para agregar una banda a un raster se utiliza la función c.

im1_cNDVI <- c(im1, 
               NDVI,
               along = 3)

Transformaciones de formato

Transformación de datos stars a sf

Para transformar un vector a raster se utiliza la función st_rasterize. Para ello, hay que determinar la resolución a la que se quiere rasterizar esta información. Utilizamos los valores de resolución que tiene el objeto im1. Recordemos que estos valores están en las unidades del CRS de la capa. En este caso, el CRS está en coordenadas geográficas, por eso se utilizarán valores en grados.

roi_rast <- st_rasterize(roi["id"], dx = 0.000179663, dy = -0.000179663)
plot(roi_rast)
## Warning in plot.stars(roi_rast): breaks="quantile" leads to a single class;
## maybe try breaks="equal" instead?

Transformación de raster a vector

Para transformar de raster a un vector de puntos se puede utilizar la función st_as_sf, utilizando el argumento de as_points. Además, si se desean obtener los datos en formato largo en lugar de ancho se puede utilizar el argumento long.

st_as_sf(im1, 
         as_points = TRUE, 
         merge = FALSE)
## Simple feature collection with 8343 features and 10 fields
## Geometry type: POINT
## Dimension:     XY
## Bounding box:  xmin: -101.2352 ymin: 19.64373 xmax: -101.2169 ymax: 19.6581
## Geodetic CRS:  WGS 84
## First 10 features:
##     B2  B3   B4   B5   B6   B7   B8  B8A  B11  B12                  geometry
## 1  434 662  939 1078 1200 1246 1318 1412 1909 1480 POINT (-101.2352 19.6581)
## 2  434 662  939 1078 1200 1246 1318 1412 1909 1480  POINT (-101.235 19.6581)
## 3  443 685  960 1096 1179 1244 1327 1372 1856 1469 POINT (-101.2348 19.6581)
## 4  488 729 1028 1168 1237 1314 1386 1380 1908 1483 POINT (-101.2347 19.6581)
## 5  560 803 1091 1271 1313 1423 1504 1588 2054 1602 POINT (-101.2345 19.6581)
## 6  594 889 1203 1345 1624 1863 2108 2062 2588 1925 POINT (-101.2343 19.6581)
## 7  461 693  980 1257 1480 1604 1709 1862 2636 1926 POINT (-101.2341 19.6581)
## 8  420 645  907 1067 1152 1321 1561 1701 2432 1814 POINT (-101.2339 19.6581)
## 9  436 635  920 1047 1187 1349 1544 1679 2429 1796 POINT (-101.2338 19.6581)
## 10 345 528  745  990 1185 1381 1333 1621 2329 1695 POINT (-101.2336 19.6581)

Utilizando la misma función se puede convertir de raster a vector de polígonos. En este caso, se indica como argumentos que no se desea obtener una capa de puntos y en merge se puede indicar si se desea fusionar los polígonos con un mismo valor o no.

im1_poly <- st_as_sf(im1, 
                     as_points = F, 
                     merge = T)
plot(im1_poly)

Operaciones espaciales

Reproyección de rasters

Para reproyectar un raster se utiliza la función st_transform. Al igual que en sf se necesita indicar el CRS objetivo ya sea mediante el código EPSG o obteniendo dicha clave con st_crs. Este tipo de reproyección no presenta pérdida de información debido a las diferencias entre proyecciones. Por lo tanto, los pixeles pueden no ser de dimensiones homogeneas en toda la imagen. Ve la siguiente función para hacer reproyecciones más clásicas.

im1_utm <- st_transform(im1, 
                        32614)
im1_utm
## stars object with 3 dimensions and 1 attribute
## attribute(s):
##            Min. 1st Qu. Median     Mean 3rd Qu. Max.
## Sentinel2     6     913   1552 1501.178 2010.75 5041
## dimension(s):
##      from  to offset delta                refsys point
## x       1 103     NA    NA WGS 84 / UTM zone 14N FALSE
## y       1  81     NA    NA WGS 84 / UTM zone 14N FALSE
## band    1  10     NA    NA                    NA    NA
##                            values x/y
## x      [103x81] 265619,...,267562 [x]
## y    [103x81] 2173570,...,2175186 [y]
## band                   B2,...,B12    
## curvilinear grid

Resampling

Para cambiar la resolución de un raster o reproyectar con pérdida de información se utiliza la función st_warp. Esta función permite definir el tamaño de celda objetivo mediante el argumento cellsize, así como el CRS objetivo. Esta función hace la reproyección donde todos los tamaños de celda son iguales y quizás es con la que cualquier usuario esté más familiarizado.

im1_utm_20m <- st_warp(im1, 
                       crs = st_crs(im1),
                       cellsize = c(20, 20))
im1_utm_20m
## stars object with 3 dimensions and 1 attribute
## attribute(s):
##            Min. 1st Qu. Median Mean 3rd Qu. Max. NA's
## Sentinel2    NA      NA     NA  NaN      NA   NA   10
## dimension(s):
##      from to   offset delta refsys point     values x/y
## x       1  1 -101.235    20 WGS 84    NA       NULL [x]
## y       1  1  19.6582   -20 WGS 84    NA       NULL [y]
## band    1 10       NA    NA     NA    NA B2,...,B12

Crear mosaicos a partir de varios rasters

Para crear un mosaico a partir de dos o más imágenes se utiliza la función st_mosaic.

im_mosaic <- st_mosaic(im1_sub2, im1_sub3)
plot(im_mosaic)

Operaciones basadas en los valores de raster

Reclasificar

Para reclasificar un raster se puede realizar con la función cut, indicando los intervalos para las clases.

reclass_NDVI <- cut(NDVI,
    breaks = c(-1, 0, 0.2, 0.5, 1),
    labels = F)
plot(reclass_NDVI)

Enmascarar

Para enmascarar algún raster utilizando otro. De igual manera se pueden emascarar los valores que no cumplan con algún criterio de interés.

im_mask <- reclass_NDVI
im_mask[im_mask != 2] <- NA

reclass_NDVI2 <- reclass_NDVI
reclass_NDVI2[is.na(im_mask)] <- NA
plot(reclass_NDVI2)
## Warning in plot.stars(reclass_NDVI2): breaks="quantile" leads to a single class;
## maybe try breaks="equal" instead?

Cálculo de métricas por banda

Para calcular métrias por banda se puede utilizar la función pull para obtener el atributo del que se desea obtener la información. En este caso la imagen solo cuenta con un atributo, así que seleccionamos esa entrada. Después, podemos utilizar la función apply para calcular la media sobre la dimensión 3 del arreglo. Otra forma de acceder a los datos en formato de arreglo es con [[]].

# Opción con pull
im1 |>
  pull(1) |>
  apply(3, mean)
##  [1]  527.6186  772.9070  935.5342 1230.8505 1700.1954 1874.5490 2004.2371
##  [8] 2076.1721 2236.3476 1653.3689
# Opción con doble corchete
im1[[1]] |>
  apply(3, mean)
##  [1]  527.6186  772.9070  935.5342 1230.8505 1700.1954 1874.5490 2004.2371
##  [8] 2076.1721 2236.3476 1653.3689

Aplicar una función sobre todos los pixeles

Si se desea aplicar una función sobre todas las bandas de una imagen por pixel, se puede utilizar la función st_apply para facilitar el cálculo de variables. Esto es muy utilizado para análisis con series de tiempo y obtener por ejemplo la media de cada pixel.

mean_allBands <- st_apply(im1, 
         1:2,
         mean)
mean_allBands
## stars object with 2 dimensions and 1 attribute
## attribute(s):
##        Min. 1st Qu. Median     Mean 3rd Qu.   Max.
## mean  225.8    1253 1502.2 1501.178 1716.45 4223.5
## dimension(s):
##   from  to   offset        delta refsys point values x/y
## x    1 103 -101.235  0.000179663 WGS 84 FALSE   NULL [x]
## y    1  81  19.6582 -0.000179663 WGS 84 FALSE   NULL [y]
plot(mean_allBands)

Tabla de frecuencias

Para obtener una tabla de las frecuencias por el valor de pixel se utiliza la función table.

table(reclass_NDVI)
## reclass_NDVI
##    1    2    3    4 
##   64 2364 5527  388

Objetos stars proxy

En algunos casos los archivos raster con los que se desea trabajar son muy pesados y no caben en la memoria disponible RAM. Por ello, al llamar read_stars se crea automáticamente un objeto proxy stars. Estos objetos permite cargar los datos únicamente cuando se vayan a utilizar. Para cargar los datos ya que se vayan a utilizar se usa la función st_as_stars.

Visualizacion avanzada

Para generar visualizaciones más avanzadas podemos utilizar otros paquetes como ggplot2 o tmap. Aquí veremos un ejemplo de cada uno.

ggplot2

En ggplot se puede determinar directamente el color y relleno de cada capa vectorial. En este ejemplo se carga la biblioteca viridis para usar dicha escala de color.

library(viridis)
## Loading required package: viridisLite
## Loading required package: viridisLite
ggplot() + 
  geom_stars(data = im1) +
  coord_equal() +
  facet_wrap(~band) +
  theme_void() +
  scale_fill_viridis() +
  scale_x_discrete(expand = c(0, 0)) +
  scale_y_discrete(expand = c(0, 0))

tmap

La opción de tmap require de utilizar algún atributo de la información para determinar el color de relleno de cada polígono de acuerdo a los valores de ese atributo. Es similar a ggplot utilizando la opción de aes. Podemos ver algunas de las paletas que ya vienen pre hechas tanto para ggplot como para tmap con tmaptools::palette_explorer()

library(tmap)

# Cargar shapr
tm_shape(im1) +
  # Elegir forma de visualización
  tm_raster()

</div>

</div>