EQUIPO 6
Alexa Mariana Marin Villar A00831342
Diego Martínez Ruibal A01740559
Oscar Emiliano Melendez Chavez A01276802
Librerias
#install.packages("maps")
library(maps)
library(readr)
library(dplyr)
library(forecast)
library(tidyverse)
library(janitor)
library(here)
library(plotly)
Ejemplo
El ejemplo con la librería maps no está funcionando, pero con fines
prácticos de la actividad se agregó el código.
#library(maps)
#map(database = "state", fill = TRUE, col = "lightgray") # Añade colores de fondo
#grupo1 <- c("New York", "California", "Texas")
#map(database = "state", regions = grupo1, col = "red", fill = TRUE, add = TRUE)
#grupo2 <- c("Arizona", "Florida", "Illinois")
#map(database = "state", regions = grupo2, col = "green", fill = TRUE, add = TRUE)
Generar base de datos del tipo panel

La base de datos cuenta con la información anual de los estados de
Estados Unidos desde 1900 hasta 2019.
mapa <- read_csv("C:/Users/alexa/OneDrive/Desktop/8VO/MODULO 1/historical_state_population_by_year.csv",
col_names = FALSE)
mapa<- mapa %>%
rename(estate = X1, year = X2, population = X3)
Resumen de los datos
La base de datos consta de 3 variables y 6,020 observaciones. El
mínimo de años recabados es desde 1900 hasta 2019, mientras que el
mínimo de población consta de 43,000 con un máximo de 39,512,223.
glimpse(mapa)
## Rows: 6,020
## Columns: 3
## $ estate <chr> "AK", "AK", "AK", "AK", "AK", "AK", "AK", "AK", "AK", "AK",…
## $ year <dbl> 1950, 1951, 1952, 1953, 1954, 1955, 1956, 1957, 1958, 1959,…
## $ population <dbl> 135000, 158000, 189000, 205000, 215000, 222000, 224000, 231…
summary(mapa)
## estate year population
## Length:6020 Min. :1900 Min. : 43000
## Class :character 1st Qu.:1930 1st Qu.: 901483
## Mode :character Median :1960 Median : 2359000
## Mean :1960 Mean : 3726003
## 3rd Qu.:1990 3rd Qu.: 4541883
## Max. :2019 Max. :39512223
Filtro de solo los estados a analizar
En este caso decidimos analizar los estados de:
California
Nueva York
Florida
Wyoming
Texas
california <- filter(mapa, estate =="CA")
newyork <- filter(mapa, estate =="NY")
florida <- filter(mapa, estate =="FL")
wyoming <- filter(mapa, estate =="WY")
texas <- filter(mapa, estate =="TX")
Crear modelo de series de tiempo
california$population <- as.numeric(california$population)
tscalifornia <- ts(data = california$population, start=c(1900,1),end=c(2019,1),frequency=1)
newyork$population <- as.numeric(newyork$population)
tsnewyork <- ts(data = newyork$population, start=c(1900,1),end=c(2019,1),frequency=1)
florida$population <- as.numeric(florida$population)
tsflorida <- ts(data = florida$population, start=c(1900,1),end=c(2019,1),frequency=1)
wyoming$population <- as.numeric(wyoming$population)
tswyoming <- ts(data = wyoming$population, start=c(1900,1),end=c(2019,1),frequency=1)
texas$population <- as.numeric(texas$population)
tstexas <- ts(data = texas$population, start=c(1900,1),end=c(2019,1),frequency=1)
Modelo ARIMA
Con fines del formato del documento, se decidió ejecutar el código,
pero no mostrar el resultado del modelo ARIMA por estado.
arimacali <- auto.arima(tscalifornia, D=1)
summary(arimacali)
arimany <- auto.arima(tsnewyork, D=1)
summary(arimany)
arimaflo <- auto.arima(tsflorida, D=1)
summary(arimaflo)
arimawy <- auto.arima(tswyoming, D=1)
summary(arimawy)
arimatx <- auto.arima(tstexas, D=1)
summary(arimatx)
Generar el pronóstico
pronosticocali <- forecast(arimacali,level=c(95), h=51)
pronosticony <- forecast(arimany,level=c(95), h=51)
pronosticoflorida <- forecast(arimaflo,level=c(95), h=51)
pronosticowyoming <- forecast(arimawy,level=c(95), h=51)
pronosticotx <- forecast(arimatx,level=c(95), h=51)
Observar el pronóstico por estado
plot(pronosticocali)

plot(pronosticony)

plot(pronosticoflorida)

plot(pronosticowyoming)

plot(pronosticotx)

Se puede observar un crecimiento positivo en cuanto a la poblacion de
los estados de California,Nueva York, Florida, Wyoming y Texas.
Unir los pronósticos en una sola base de datos
library(dplyr)
# Crear un data frame con los pronósticos y estados correspondientes
pronosticos <- data.frame(
estate = rep(c("CA", "NY", "FL", "WY", "TX"), each = 51),
year = rep(seq(2020, 2070), times = 5),
point_forecast = c(
pronosticocali$mean,
pronosticony$mean,
pronosticoflorida$mean,
pronosticowyoming$mean,
pronosticotx$mean
)
)
# Limpiar nombres de columnas
pronosticos <- pronosticos %>% clean_names()
Visualizaciones
California
Visualizar los años en el mapa
library(maps)
library(plotly)
# Filtra los datos para el estado de California
datos_cali <- subset(pronosticos, estate == "CA")
# Define la escala de colores personalizada
color_scale <- colorRampPalette(c("blue", "lightblue", "lightgreen", "darkgreen", "darkred", "red"))
# Crea un mapa interactivo para cada año deseado
for (ano in c(2020,2030, 2040, 2050, 2060, 2070)) {
datos_ano <- subset(datos_cali, year == ano)
mapa <- plot_ly(
data = datos_ano,
type = "choropleth",
locationmode = "USA-states",
locations = ~estate,
z = ~point_forecast,
colorscale = color_scale(100),
marker = list(line = list(color = "rgb(255,255,255)", width = 2)),
text = ~paste("Estado: ", estate, "<br>Año: ", year, "<br>Población Pronosticada: ", point_forecast),
zmin = min(datos_cali$point_forecast), # Establece el valor mínimo de la escala de colores
zmax = max(datos_cali$point_forecast) # Establece el valor máximo de la escala de colores
) %>%
layout(
title = paste("Población Pronosticada California en", ano),
geo = list(scope = "usa", projection = list(type = "albers usa")),
colorbar = list(title = "Población Pronosticada"),
showlegend = FALSE
)
# Muestra el mapa
print(mapa)
}
Al momento de hacer el ‘knit’ del documento, no se visualizan los
mapas debido al bucle creado para mostrar cada década. Por esta razón y
debido al formato del documento, se decidió adjuntar las imágenes de los
pronósticos del estado de California, pero este resultado se obtiene
para cada estado. Se eligió una escala de colores que muestra el
pronóstico del crecimiento de la población década por década.
Imagen en grande sobre como se observa el pronóstico dentro
del mapa creado

Imagenes juntas para observar de mejor manera la escala y el
crecimiento del pronóstico.


New York
Visualizar los años en el mapa
# Instala y carga las librerías necesarias
# install.packages(c("maps", "plotly"))
library(maps)
library(plotly)
# Filtra los datos para el estado de California
datos_ny <- subset(pronosticos, estate == "NY")
# Define la escala de colores personalizada
color_scale <- colorRampPalette(c("blue", "lightblue", "lightgreen", "darkgreen", "darkred", "red"))
# Crea un mapa interactivo para cada año deseado
for (ano in c(2020,2030, 2040, 2050, 2060, 2070)) {
datos_ano <- subset(datos_ny, year == ano)
mapa <- plot_ly(
data = datos_ano,
type = "choropleth",
locationmode = "USA-states",
locations = ~estate,
z = ~point_forecast,
colorscale = color_scale(100),
marker = list(line = list(color = "rgb(255,255,255)", width = 2)),
text = ~paste("Estado: ", estate, "<br>Año: ", year, "<br>Población Pronosticada: ", point_forecast),
zmin = min(datos_ny$point_forecast), # Establece el valor mínimo de la escala de colores
zmax = max(datos_ny$point_forecast) # Establece el valor máximo de la escala de colores
) %>%
layout(
title = paste("Población Pronosticada Nueva York en", ano),
geo = list(scope = "usa", projection = list(type = "albers usa")),
colorbar = list(title = "Población Pronosticada"),
showlegend = FALSE
)
# Muestra el mapa
print(mapa)
}
Florida
Visualizar los años en el mapa
# Instala y carga las librerías necesarias
# install.packages(c("maps", "plotly"))
library(maps)
library(plotly)
# Filtra los datos para el estado de California
datos_flo <- subset(pronosticos, estate == "FL")
# Define la escala de colores personalizada
color_scale <- colorRampPalette(c("blue", "lightblue", "lightgreen", "darkgreen", "darkred", "red"))
# Crea un mapa interactivo para cada año deseado
for (ano in c(2020,2030, 2040, 2050, 2060, 2070)) {
datos_ano <- subset(datos_flo, year == ano)
mapa <- plot_ly(
data = datos_ano,
type = "choropleth",
locationmode = "USA-states",
locations = ~estate,
z = ~point_forecast,
colorscale = color_scale(100),
marker = list(line = list(color = "rgb(255,255,255)", width = 2)),
text = ~paste("Estado: ", estate, "<br>Año: ", year, "<br>Población Pronosticada: ", point_forecast),
zmin = min(datos_flo$point_forecast), # Establece el valor mínimo de la escala de colores
zmax = max(datos_flo$point_forecast) # Establece el valor máximo de la escala de colores
) %>%
layout(
title = paste("Población Pronosticada Florida en", ano),
geo = list(scope = "usa", projection = list(type = "albers usa")),
colorbar = list(title = "Población Pronosticada"),
showlegend = FALSE
)
# Muestra el mapa
print(mapa)
}
Texas
Visualizar los años en el mapa
library(maps)
library(plotly)
# Filtra los datos para el estado de California
datos_tx <- subset(pronosticos, estate == "TX")
# Define la escala de colores personalizada
color_scale <- colorRampPalette(c("blue", "lightblue", "lightgreen", "darkgreen", "darkred", "red"))
# Crea un mapa interactivo para cada año deseado
for (ano in c(2020,2030, 2040, 2050, 2060, 2070)) {
datos_ano <- subset(datos_tx, year == ano)
mapa <- plot_ly(
data = datos_ano,
type = "choropleth",
locationmode = "USA-states",
locations = ~estate,
z = ~point_forecast,
colorscale = color_scale(100),
marker = list(line = list(color = "rgb(255,255,255)", width = 2)),
text = ~paste("Estado: ", estate, "<br>Año: ", year, "<br>Población Pronosticada: ", point_forecast),
zmin = min(datos_tx$point_forecast), # Establece el valor mínimo de la escala de colores
zmax = max(datos_tx$point_forecast) # Establece el valor máximo de la escala de colores
) %>%
layout(
title = paste("Población Pronosticada Texas en", ano),
geo = list(scope = "usa", projection = list(type = "albers usa")),
colorbar = list(title = "Población Pronosticada"),
showlegend = FALSE
)
# Muestra el mapa
print(mapa)
}
Wyoming
Visualizar los años en el mapa
library(maps)
library(plotly)
# Filtra los datos para el estado de California
datos_wo <- subset(pronosticos, estate == "WY")
# Define la escala de colores personalizada
color_scale <- colorRampPalette(c("blue", "lightblue", "lightgreen", "darkgreen", "darkred", "red"))
# Crea un mapa interactivo para cada año deseado
for (ano in c(2020,2030, 2040, 2050, 2060, 2070)) {
datos_ano <- subset(datos_wo, year == ano)
mapa <- plot_ly(
data = datos_ano,
type = "choropleth",
locationmode = "USA-states",
locations = ~estate,
z = ~point_forecast,
colorscale = color_scale(100),
marker = list(line = list(color = "rgb(255,255,255)", width = 2)),
text = ~paste("Estado: ", estate, "<br>Año: ", year, "<br>Población Pronosticada: ", point_forecast),
zmin = min(datos_wo$point_forecast), # Establece el valor mínimo de la escala de colores
zmax = max(datos_wo$point_forecast) # Establece el valor máximo de la escala de colores
) %>%
layout(
title = paste("Población Pronosticada Wyoming en", ano),
geo = list(scope = "usa", projection = list(type = "albers usa")),
colorbar = list(title = "Población Pronosticada"),
showlegend = FALSE
)
# Muestra el mapa
print(mapa)
}
---
title: "Actividad Integradora"
date: "`r Sys.Date()`"
output:
  rmdformats::downcute:
    default_style: "light"
    downcute_theme: "default"
    code_download : true
    lib_dir: libs
    self_contained: false
  html_document:
    df_print: paged
---

```{r setup, include=FALSE}
## Global options
knitr::opts_chunk$set(cache = TRUE,echo = TRUE,warning = FALSE,message = FALSE)
```

## **EQUIPO 6**

-   Alexa Mariana Marin Villar A00831342

-   Diego Martínez Ruibal A01740559

-   Oscar Emiliano Melendez Chavez A01276802

## **Librerias**

```{r}
#install.packages("maps")
library(maps)
library(readr)
library(dplyr)
library(forecast)
library(tidyverse)
library(janitor)
library(here)
library(plotly)
```

## **Ejemplo**

El ejemplo con la librería maps no está funcionando, pero con fines prácticos de la actividad se agregó el código.

```{r}
#library(maps)
#map(database = "state", fill = TRUE, col = "lightgray")  # Añade colores de fondo
#grupo1 <- c("New York", "California", "Texas")
#map(database = "state", regions = grupo1, col = "red", fill = TRUE, add = TRUE)
#grupo2 <- c("Arizona", "Florida", "Illinois")
#map(database = "state", regions = grupo2, col = "green", fill = TRUE, add = TRUE)
```

# **Generar base de datos del tipo panel**

![](giphy%20(5).gif){width="183"}

La base de datos cuenta con la información anual de los estados de Estados Unidos desde 1900 hasta 2019.

```{r}
mapa <-  read_csv("C:/Users/alexa/OneDrive/Desktop/8VO/MODULO 1/historical_state_population_by_year.csv", 
    col_names = FALSE)

mapa<- mapa %>% 
  rename(estate = X1, year = X2, population = X3) 
```

## **Resumen de los datos**

La base de datos consta de 3 variables y 6,020 observaciones. El mínimo de años recabados es desde 1900 hasta 2019, mientras que el mínimo de población consta de 43,000 con un máximo de 39,512,223.

```{r}
glimpse(mapa)
summary(mapa)
```

```{r,include=FALSE}
#Filtrar información por estadofiltrar estado por pequeña poblacion y grande poblacion
mapa2 <- select(mapa ,c(1,3))

promedio_por_estado <- mapa2 %>%
  group_by(estate) %>%
  summarise(promedio_columna = mean(population))

promedio_por_estado <- promedio_por_estado[order(-promedio_por_estado$promedio_columna), ]

promedio_por_estado

#mapa2 %>% group_by(suma_por_estado) %>% filter(population > mean(population, na.rm = TRUE))
#mapa2 %>% group_by(promedio_por_estado) %>% filter(population < mean(population, na.rm = TRUE))
```

## **Filtro de solo los estados a analizar**

En este caso decidimos analizar los estados de:

1.  **California**

2.  **Nueva York**

3.  **Florida**

4.  **Wyoming**

5.  **Texas**

```{r}
california <- filter(mapa, estate =="CA")
newyork <- filter(mapa, estate =="NY")
florida <- filter(mapa, estate =="FL")
wyoming <- filter(mapa, estate =="WY")
texas <- filter(mapa, estate =="TX")
```

# **Crear modelo de series de tiempo**

```{r}
california$population <- as.numeric(california$population)
tscalifornia <- ts(data = california$population, start=c(1900,1),end=c(2019,1),frequency=1)
newyork$population <- as.numeric(newyork$population)
tsnewyork <- ts(data = newyork$population, start=c(1900,1),end=c(2019,1),frequency=1)
florida$population <- as.numeric(florida$population)
tsflorida <- ts(data = florida$population, start=c(1900,1),end=c(2019,1),frequency=1)
wyoming$population <- as.numeric(wyoming$population)
tswyoming <- ts(data = wyoming$population, start=c(1900,1),end=c(2019,1),frequency=1)
texas$population <- as.numeric(texas$population)
tstexas <- ts(data = texas$population, start=c(1900,1),end=c(2019,1),frequency=1)
```

## **Modelo ARIMA**

Con fines del formato del documento, se decidió ejecutar el código, pero no mostrar el resultado del modelo ARIMA por estado.

```{r,eval=FALSE}
arimacali <- auto.arima(tscalifornia, D=1)
summary(arimacali)
arimany <- auto.arima(tsnewyork, D=1)
summary(arimany)
arimaflo <- auto.arima(tsflorida, D=1)
summary(arimaflo)
arimawy <- auto.arima(tswyoming, D=1)
summary(arimawy)
arimatx <- auto.arima(tstexas, D=1)
summary(arimatx)
```

## **Generar el pronóstico**

```{r}
pronosticocali <- forecast(arimacali,level=c(95), h=51)
pronosticony <- forecast(arimany,level=c(95), h=51)
pronosticoflorida <- forecast(arimaflo,level=c(95), h=51)
pronosticowyoming <- forecast(arimawy,level=c(95), h=51)
pronosticotx <- forecast(arimatx,level=c(95), h=51)
```

## **Observar el pronóstico por estado**

```{r}
plot(pronosticocali)
plot(pronosticony)
plot(pronosticoflorida)
plot(pronosticowyoming)
plot(pronosticotx)
```

Se puede observar un crecimiento positivo en cuanto a la poblacion de los estados de California,Nueva York, Florida, Wyoming y Texas.

## **Unir los pronósticos en una sola base de datos**

```{r}
library(dplyr)

# Crear un data frame con los pronósticos y estados correspondientes
pronosticos <- data.frame(
  estate = rep(c("CA", "NY", "FL", "WY", "TX"), each = 51),
  year = rep(seq(2020, 2070), times = 5),
  point_forecast = c(
    pronosticocali$mean,
    pronosticony$mean,
    pronosticoflorida$mean,
    pronosticowyoming$mean,
    pronosticotx$mean
  )
)

# Limpiar nombres de columnas
pronosticos <- pronosticos %>% clean_names()
```

# **Visualizaciones**

## **California**

### **Visualizar los años en el mapa**

```{r}
library(maps)
library(plotly)

# Filtra los datos para el estado de California
datos_cali <- subset(pronosticos, estate == "CA")

# Define la escala de colores personalizada
color_scale <- colorRampPalette(c("blue", "lightblue", "lightgreen", "darkgreen", "darkred", "red"))

# Crea un mapa interactivo para cada año deseado
for (ano in c(2020,2030, 2040, 2050, 2060, 2070)) {
  datos_ano <- subset(datos_cali, year == ano)
  
  mapa <- plot_ly(
    data = datos_ano,
    type = "choropleth",
    locationmode = "USA-states",
    locations = ~estate,
    z = ~point_forecast,
    colorscale = color_scale(100),
    marker = list(line = list(color = "rgb(255,255,255)", width = 2)),
    text = ~paste("Estado: ", estate, "<br>Año: ", year, "<br>Población Pronosticada: ", point_forecast),
    zmin = min(datos_cali$point_forecast),  # Establece el valor mínimo de la escala de colores
    zmax = max(datos_cali$point_forecast)   # Establece el valor máximo de la escala de colores
  ) %>%
    layout(
      title = paste("Población Pronosticada California en", ano),
      geo = list(scope = "usa", projection = list(type = "albers usa")),
      colorbar = list(title = "Población Pronosticada"),
      showlegend = FALSE
    )
  
  # Muestra el mapa
  print(mapa)
}

```

Al momento de hacer el 'knit' del documento, no se visualizan los mapas debido al bucle creado para mostrar cada década. Por esta razón y debido al formato del documento, se decidió adjuntar las imágenes de los pronósticos del estado de California, pero este resultado se obtiene para cada estado. Se eligió una escala de colores que muestra el pronóstico del crecimiento de la población década por década.

### **Imagen en grande sobre como se observa el pronóstico dentro del mapa creado**

![](images/Screenshot%202024-02-23%20070156.png)

### **Imagenes juntas para observar de mejor manera la escala y el crecimiento del pronóstico.**

![](1.png)

![](2.png)

## **New York**

### **Visualizar los años en el mapa**

```{r}
# Instala y carga las librerías necesarias
# install.packages(c("maps", "plotly"))
library(maps)
library(plotly)

# Filtra los datos para el estado de California
datos_ny <- subset(pronosticos, estate == "NY")

# Define la escala de colores personalizada
color_scale <- colorRampPalette(c("blue", "lightblue", "lightgreen", "darkgreen", "darkred", "red"))

# Crea un mapa interactivo para cada año deseado
for (ano in c(2020,2030, 2040, 2050, 2060, 2070)) {
  datos_ano <- subset(datos_ny, year == ano)
  
  mapa <- plot_ly(
    data = datos_ano,
    type = "choropleth",
    locationmode = "USA-states",
    locations = ~estate,
    z = ~point_forecast,
    colorscale = color_scale(100),
    marker = list(line = list(color = "rgb(255,255,255)", width = 2)),
    text = ~paste("Estado: ", estate, "<br>Año: ", year, "<br>Población Pronosticada: ", point_forecast),
    zmin = min(datos_ny$point_forecast),  # Establece el valor mínimo de la escala de colores
    zmax = max(datos_ny$point_forecast)   # Establece el valor máximo de la escala de colores
  ) %>%
    layout(
      title = paste("Población Pronosticada Nueva York en", ano),
      geo = list(scope = "usa", projection = list(type = "albers usa")),
      colorbar = list(title = "Población Pronosticada"),
      showlegend = FALSE
    )
  
  # Muestra el mapa
  print(mapa)
}

```

## **Florida**

### **Visualizar los años en el mapa**

```{r}
# Instala y carga las librerías necesarias
# install.packages(c("maps", "plotly"))
library(maps)
library(plotly)

# Filtra los datos para el estado de California
datos_flo <- subset(pronosticos, estate == "FL")

# Define la escala de colores personalizada
color_scale <- colorRampPalette(c("blue", "lightblue", "lightgreen", "darkgreen", "darkred", "red"))

# Crea un mapa interactivo para cada año deseado
for (ano in c(2020,2030, 2040, 2050, 2060, 2070)) {
  datos_ano <- subset(datos_flo, year == ano)
  
  mapa <- plot_ly(
    data = datos_ano,
    type = "choropleth",
    locationmode = "USA-states",
    locations = ~estate,
    z = ~point_forecast,
    colorscale = color_scale(100),
    marker = list(line = list(color = "rgb(255,255,255)", width = 2)),
    text = ~paste("Estado: ", estate, "<br>Año: ", year, "<br>Población Pronosticada: ", point_forecast),
    zmin = min(datos_flo$point_forecast),  # Establece el valor mínimo de la escala de colores
    zmax = max(datos_flo$point_forecast)   # Establece el valor máximo de la escala de colores
  ) %>%
    layout(
      title = paste("Población Pronosticada Florida en", ano),
      geo = list(scope = "usa", projection = list(type = "albers usa")),
      colorbar = list(title = "Población Pronosticada"),
      showlegend = FALSE
    )
  
  # Muestra el mapa
  print(mapa)
}

```

## **Texas**

### **Visualizar los años en el mapa**

```{r}
library(maps)
library(plotly)

# Filtra los datos para el estado de California
datos_tx <- subset(pronosticos, estate == "TX")

# Define la escala de colores personalizada
color_scale <- colorRampPalette(c("blue", "lightblue", "lightgreen", "darkgreen", "darkred", "red"))

# Crea un mapa interactivo para cada año deseado
for (ano in c(2020,2030, 2040, 2050, 2060, 2070)) {
  datos_ano <- subset(datos_tx, year == ano)
  
  mapa <- plot_ly(
    data = datos_ano,
    type = "choropleth",
    locationmode = "USA-states",
    locations = ~estate,
    z = ~point_forecast,
    colorscale = color_scale(100),
    marker = list(line = list(color = "rgb(255,255,255)", width = 2)),
    text = ~paste("Estado: ", estate, "<br>Año: ", year, "<br>Población Pronosticada: ", point_forecast),
    zmin = min(datos_tx$point_forecast),  # Establece el valor mínimo de la escala de colores
    zmax = max(datos_tx$point_forecast)   # Establece el valor máximo de la escala de colores
  ) %>%
    layout(
      title = paste("Población Pronosticada Texas en", ano),
      geo = list(scope = "usa", projection = list(type = "albers usa")),
      colorbar = list(title = "Población Pronosticada"),
      showlegend = FALSE
    )
  
  # Muestra el mapa
  print(mapa)
}

```

## **Wyoming**

### **Visualizar los años en el mapa**

```{r}
library(maps)
library(plotly)

# Filtra los datos para el estado de California
datos_wo <- subset(pronosticos, estate == "WY")

# Define la escala de colores personalizada
color_scale <- colorRampPalette(c("blue", "lightblue", "lightgreen", "darkgreen", "darkred", "red"))

# Crea un mapa interactivo para cada año deseado
for (ano in c(2020,2030, 2040, 2050, 2060, 2070)) {
  datos_ano <- subset(datos_wo, year == ano)
  
  mapa <- plot_ly(
    data = datos_ano,
    type = "choropleth",
    locationmode = "USA-states",
    locations = ~estate,
    z = ~point_forecast,
    colorscale = color_scale(100),
    marker = list(line = list(color = "rgb(255,255,255)", width = 2)),
    text = ~paste("Estado: ", estate, "<br>Año: ", year, "<br>Población Pronosticada: ", point_forecast),
    zmin = min(datos_wo$point_forecast),  # Establece el valor mínimo de la escala de colores
    zmax = max(datos_wo$point_forecast)   # Establece el valor máximo de la escala de colores
  ) %>%
    layout(
      title = paste("Población Pronosticada Wyoming en", ano),
      geo = list(scope = "usa", projection = list(type = "albers usa")),
      colorbar = list(title = "Población Pronosticada"),
      showlegend = FALSE
    )
  
  # Muestra el mapa
  print(mapa)
}

```
