Cobertura por Grupos Optimizados
Cobertura MINSA

Cobertura privada

Cobertura General

Cobertura por Microred
Cobertura MINSA

Cobertura privada

Cobertura General

Cobertura por Cluster

Cobertura privadas

Cobertura General

Cobertura por Distrito

Cobertura privadas

Cobertura General

Ratio Humano Perro

---
title: "Coberturas - Encustas Vancan"
author: "Equipo de Datos - One Health - Sede ARQ"
date: "2025-02-06"
output:
  html_document:
    toc: true
    toc_float: true
    code_download: true
    theme: united
---



```{r, message=FALSE, echo=FALSE, warning = FALSE}

###########################################################################--
#0. LIBRERIA/IMPORTACIÓN DATA ---- 
###########################################################################--

rm(list = setdiff(ls(), c()))
#install.packages("terra")
#install.packages("sp")
#install.packages("leaflet")
#install.packages("openxlsx")
library(sf)
library(sp)
library(rio)
library(dplyr)
library(terra)
library(readr)
library(haven)
library(Hmisc)
library(tidyr)
library(readxl)
library(leaflet)
library(writexl)
library(stringr)
library(ggplot2)
library(openxlsx)
cat("\014")  

# data_encuestas <- import('Modified data/data_encuestas.RDS')
# Lee los archivos CSV


coberturas <- read_excel("C:/Users/artur_4yucftm/Box/ENCUESTAS POST VANCAN RABIA/Encuestas Post Vancan 2024/Data_ENCUESTAS-2024/Resultados/microred_2_3_4.xlsx")

cluster <- read_excel("C:/Users/artur_4yucftm/Box/ENCUESTAS POST VANCAN RABIA/Encuestas Post Vancan 2024/Data_ENCUESTAS-2024/Resultados/cluster_2_3_4.xlsx")

distrito <- read_excel("C:/Users/artur_4yucftm/Box/ENCUESTAS POST VANCAN RABIA/Encuestas Post Vancan 2024/Data_ENCUESTAS-2024/Resultados/distrito_2_3_4.xlsx")

group_opt <- read_excel("C:/Users/artur_4yucftm/Box/ENCUESTAS POST VANCAN RABIA/Encuestas Post Vancan 2024/Data_ENCUESTAS-2024/Resultados/grupo_opt_2_3_4.xlsx")


cob <- coberturas
clster <- cluster
dstrito <- distrito
group <- group_opt

#########################--
## Cobertura por el MINSA
#########################--

# Extraer cobertura, intervalo inferior y superior
extraer_valores <- function(x) {
  num <- as.numeric(str_extract(x, "^[0-9]+\\.?[0-9]*")) # Extrae el primer número como cobertura
  li <- as.numeric(str_extract(x, "(?<=\\()[0-9]+\\.?[0-9]*")) # Extrae el límite inferior
  ls <- as.numeric(str_extract(x, "[0-9]+\\.?[0-9]*(?=\\))")) # Extrae el límite superior
  return(data.frame(cobertura = num, li = li, ls = ls))
}


```

# **Cobertura por Grupos Optimizados**

## Cobertura MINSA

```{r, message=FALSE, echo=FALSE, warning = FALSE, fig.width=16, fig.height=14}
group <- group %>%
  mutate(across(starts_with("cob_minsa"), as.character))


# Aplicar la función a cada columna de cobertura
datos_long <- group %>%
  pivot_longer(cols = starts_with("cob_minsa"), names_to = "anio", values_to = "valor") %>%
  mutate(anio = str_extract(anio, "[0-9]+")) %>%  # Extraer el año de la variable
  rowwise() %>%
  mutate(extraido = list(extraer_valores(valor))) %>%
  unnest(cols = c(extraido)) %>%
  select(-valor)  # Eliminar la columna original con texto

datos_long <- datos_long %>%
  mutate(anio = case_when(
    anio == "22" ~ "2022",
    anio == "23" ~ "2023",
    anio == "24" ~ "2024",
    TRUE ~ anio  # Mantiene los demás valores sin cambios
  ))


# Graficar con ggplot2
minsa <- ggplot(datos_long, aes(x = grupo_opt, y = cobertura, fill = anio)) +
  geom_bar(stat = "identity", position = "dodge", width = 0.9) +
  geom_errorbar(aes(ymin = li, ymax = ls), width = 0.2, position = position_dodge(0.9)) +
  scale_fill_brewer(palette = "Set2") +
  labs(title = "",
       x = "",
       y = "",
       fill = "Año") +
  theme_minimal() +
  theme(axis.text.x = element_text(angle = 0, hjust = 1, size = 16),
        axis.text.y = element_text(size = 18),  # Aumentar tamaño eje Y)
        legend.position = "bottom",             # Colocar la leyenda abajo
        legend.direction = "horizontal",        # Leyenda horizontal
        legend.box = "horizontal",              # Alinear etiquetas horizontalmente
        legend.title = element_text(size = 16), # Ajustar tamaño del título de la leyenda
        legend.text = element_text(size = 15))   # Ajustar tamaño del texto de la leyenda
minsa

```

## Cobertura privada

```{r, message=FALSE, echo=FALSE, warning = FALSE, fig.width=16, fig.height=14}
group <- group %>%
  mutate(across(starts_with("cob_priv"), as.character))


# Aplicar la función a cada columna de cobertura
datos_priv <- group %>%
  pivot_longer(cols = starts_with("cob_priv"), names_to = "anio", values_to = "valor") %>%
  mutate(anio = str_extract(anio, "[0-9]+")) %>%  # Extraer el año de la variable
  rowwise() %>%
  mutate(extraido = list(extraer_valores(valor))) %>%
  unnest(cols = c(extraido)) %>%
  select(-valor)  # Eliminar la columna original con texto

datos_priv <- datos_priv %>%
  mutate(anio = case_when(
    anio == "22" ~ "2022",
    anio == "23" ~ "2023",
    anio == "24" ~ "2024",
    TRUE ~ anio  # Mantiene los demás valores sin cambios
  ))


# Graficar con ggplot2
privado <- ggplot(datos_priv, aes(x = grupo_opt, y = cobertura, fill = anio)) +
  geom_bar(stat = "identity", position = "dodge", width = 0.9) +
  geom_errorbar(aes(ymin = li, ymax = ls), width = 0.2, position = position_dodge(0.9)) +
  scale_fill_brewer(palette = "Set2") +
  labs(title = "",
       x = "",
       y = "",
       fill = "Año") +
  theme_minimal() +
  theme(axis.text.x = element_text(angle = 0, hjust = 1, size = 16),
        axis.text.y = element_text(size = 18),  # Aumentar tamaño eje Y)
        legend.position = "bottom",             # Colocar la leyenda abajo
        legend.direction = "horizontal",        # Leyenda horizontal
        legend.box = "horizontal",              # Alinear etiquetas horizontalmente
        legend.title = element_text(size = 16), # Ajustar tamaño del título de la leyenda
        legend.text = element_text(size = 15))   # Ajustar tamaño del texto de la leyenda
privado


```


## Cobertura General

```{r, message=FALSE, echo=FALSE, warning = FALSE, fig.width=16, fig.height=14}
group <- group %>%
  mutate(across(starts_with("cob_total"), as.character))


# Aplicar la función a cada columna de cobertura
datos_total <- group %>%
  pivot_longer(cols = starts_with("cob_total"), names_to = "anio", values_to = "valor") %>%
  mutate(anio = str_extract(anio, "[0-9]+")) %>%  # Extraer el año de la variable
  rowwise() %>%
  mutate(extraido = list(extraer_valores(valor))) %>%
  unnest(cols = c(extraido)) %>%
  select(-valor)  # Eliminar la columna original con texto

datos_total <- datos_total %>%
  mutate(anio = case_when(
    anio == "22" ~ "2022",
    anio == "23" ~ "2023",
    anio == "24" ~ "2024",
    TRUE ~ anio  # Mantiene los demás valores sin cambios
  ))

# Graficar con ggplot2
general <- ggplot(datos_total, aes(x = grupo_opt, y = cobertura, fill = anio)) +
  geom_bar(stat = "identity", position = "dodge", width = 0.9) +
  geom_errorbar(aes(ymin = li, ymax = ls), width = 0.2, position = position_dodge(0.9)) +
  scale_fill_brewer(palette = "Set2") +
  labs(title = "",
       x = "",
       y = "",
       fill = "Año") +
  theme_minimal() +
  theme(axis.text.x = element_text(angle = 0, hjust = 1, size = 16),
        axis.text.y = element_text(size = 18),  # Aumentar tamaño eje Y)
        legend.position = "bottom",             # Colocar la leyenda abajo
        legend.direction = "horizontal",        # Leyenda horizontal
        legend.box = "horizontal",              # Alinear etiquetas horizontalmente
        legend.title = element_text(size = 16), # Ajustar tamaño del título de la leyenda
        legend.text = element_text(size = 15))   # Ajustar tamaño del texto de la leyenda

general

```



# **Cobertura por Microred**

## Cobertura MINSA

```{r, message=FALSE, echo=FALSE, warning = FALSE, fig.width=16, fig.height=14}


# Calcular la diferencia porcentual
cob <- cob %>%
  mutate(dif_porcentual = cob_minsa_24 - cob_minsa_23)

cob <- cob %>%
  mutate(across(starts_with("cob_minsa"), as.character))


# Aplicar la función a cada columna de cobertura
datos_long <- cob %>%
  pivot_longer(cols = starts_with("cob_minsa"), names_to = "anio", values_to = "valor") %>%
  mutate(anio = str_extract(anio, "[0-9]+")) %>%  # Extraer el año de la variable
  rowwise() %>%
  mutate(extraido = list(extraer_valores(valor))) %>%
  unnest(cols = c(extraido)) %>%
  select(-valor)  # Eliminar la columna original con texto

datos_long <- datos_long %>%
  mutate(anio = case_when(
    anio == "22" ~ "2022",
    anio == "23" ~ "2023",
    anio == "24" ~ "2024",
    TRUE ~ anio  # Mantiene los demás valores sin cambios
  ))


# Ordenar los datos de mayor a menor según la diferencia porcentual
datos_long <- datos_long %>%
  arrange(desc(dif_porcentual))

# Convertir microred en factor para fijar el orden en el gráfico
datos_long$microred <- factor(datos_long$microred, levels = unique(datos_long$microred))

# Graficar con ggplot2
minsa <- ggplot(datos_long, aes(x = microred, y = cobertura, fill = anio)) +
  geom_bar(stat = "identity", position = "dodge", width = 0.9) +
  geom_errorbar(aes(ymin = li, ymax = ls), width = 0.2, position = position_dodge(0.9)) +
  scale_fill_brewer(palette = "Set2") +
  labs(title = "",
       x = "",
       y = "",
       fill = "Año") +
  theme_minimal() +
  theme(axis.text.x = element_text(angle = 45, hjust = 1, size = 16),
        axis.text.y = element_text(size = 18),  # Aumentar tamaño eje Y)
         legend.position = "bottom",             # Colocar la leyenda abajo
        legend.direction = "horizontal",        # Leyenda horizontal
        legend.box = "horizontal",              # Alinear etiquetas horizontalmente
        legend.title = element_text(size = 16), # Ajustar tamaño del título de la leyenda
        legend.text = element_text(size = 15))   # Ajustar tamaño del texto de la leyenda
minsa

```



## Cobertura privada

```{r, message=FALSE, echo=FALSE, warning = FALSE, fig.width=16, fig.height=14}

# Extraer la primera parte usando regex
cob <- cob %>%
  mutate(
    cob_priv_23 = as.numeric(str_extract(cob_priv_23_ic, "^[0-9]+\\.?[0-9]*")),
    cob_priv_24 = as.numeric(str_extract(cob_priv_24_ic, "^[0-9]+\\.?[0-9]*")))
# Calcular la diferencia porcentual
cob <- cob %>%
  mutate(dif_porcentual = cob_priv_24 - cob_priv_23)

cob <- cob %>%
  mutate(across(starts_with("cob_priv"), as.character))


# Aplicar la función a cada columna de cobertura
datos_priv <- cob %>%
  pivot_longer(cols = starts_with("cob_priv"), names_to = "anio", values_to = "valor") %>%
  mutate(anio = str_extract(anio, "[0-9]+")) %>%  # Extraer el año de la variable
  rowwise() %>%
  mutate(extraido = list(extraer_valores(valor))) %>%
  unnest(cols = c(extraido)) %>%
  select(-valor)  # Eliminar la columna original con texto

datos_priv <- datos_priv %>%
  mutate(anio = case_when(
    anio == "22" ~ "2022",
    anio == "23" ~ "2023",
    anio == "24" ~ "2024",
    TRUE ~ anio  # Mantiene los demás valores sin cambios
  ))


# Ordenar los datos de mayor a menor según la diferencia porcentual
datos_priv <- datos_priv %>%
  arrange(desc(dif_porcentual))

# Convertir microred en factor para fijar el orden en el gráfico
datos_priv$microred <- factor(datos_priv$microred, levels = unique(datos_priv$microred))

# Graficar con ggplot2
privado <- ggplot(datos_priv, aes(x = microred, y = cobertura, fill = anio)) +
  geom_bar(stat = "identity", position = "dodge", width = 0.9) +
  geom_errorbar(aes(ymin = li, ymax = ls), width = 0.2, position = position_dodge(0.9)) +
  scale_fill_brewer(palette = "Set2") +
  labs(title = "",
       x = "",
       y = "",
       fill = "Año") +
  theme_minimal() +
  theme(axis.text.x = element_text(angle = 45, hjust = 1, size = 16),
        axis.text.y = element_text(size = 18),  # Aumentar tamaño eje Y)
         legend.position = "bottom",             # Colocar la leyenda abajo
        legend.direction = "horizontal",        # Leyenda horizontal
        legend.box = "horizontal",              # Alinear etiquetas horizontalmente
        legend.title = element_text(size = 16), # Ajustar tamaño del título de la leyenda
        legend.text = element_text(size = 15))   # Ajustar tamaño del texto de la leyenda
privado


```


## Cobertura General

```{r, message=FALSE, echo=FALSE, warning = FALSE, fig.width=16, fig.height=14}
#########################--
## Cobertura Total
#########################--

# Calcular la diferencia porcentual
ct <- cob %>%
  mutate(dif_porcentual = cob_total_24 - cob_total_23)

cob <- cob %>%
  mutate(across(starts_with("cob_total"), as.character))


# Aplicar la función a cada columna de cobertura
datos_total <- cob %>%
  pivot_longer(cols = starts_with("cob_total"), names_to = "anio", values_to = "valor") %>%
  mutate(anio = str_extract(anio, "[0-9]+")) %>%  # Extraer el año de la variable
  rowwise() %>%
  mutate(extraido = list(extraer_valores(valor))) %>%
  unnest(cols = c(extraido)) %>%
  select(-valor)  # Eliminar la columna original con texto

datos_total <- datos_total %>%
  mutate(anio = case_when(
    anio == "22" ~ "2022",
    anio == "23" ~ "2023",
    anio == "24" ~ "2024",
    TRUE ~ anio  # Mantiene los demás valores sin cambios
  ))


# Ordenar los datos de mayor a menor según la diferencia porcentual
datos_total <- datos_total %>%
  arrange(desc(dif_porcentual))

# Convertir microred en factor para fijar el orden en el gráfico
datos_total$microred <- factor(datos_total$microred, levels = unique(datos_total$microred))

# Graficar con ggplot2
general <- ggplot(datos_total, aes(x = microred, y = cobertura, fill = anio)) +
  geom_bar(stat = "identity", position = "dodge", width = 0.9) +
  geom_errorbar(aes(ymin = li, ymax = ls), width = 0.2, position = position_dodge(0.9)) +
  scale_fill_brewer(palette = "Set2") +
  labs(title = "",
       x = "",
       y = "",
       fill = "Año") +
  theme_minimal() +
  theme(axis.text.x = element_text(angle = 45, hjust = 1, size = 16),
        axis.text.y = element_text(size = 18),  # Aumentar tamaño eje Y)
         legend.position = "bottom",             # Colocar la leyenda abajo
        legend.direction = "horizontal",        # Leyenda horizontal
        legend.box = "horizontal",              # Alinear etiquetas horizontalmente
        legend.title = element_text(size = 16), # Ajustar tamaño del título de la leyenda
        legend.text = element_text(size = 15))   # Ajustar tamaño del texto de la leyenda
general

```




# **Cobertura por Cluster**

```{r, message=FALSE, echo=FALSE, warning = FALSE, fig.width=16, fig.height=14}

# Calcular la diferencia porcentual
clster <- clster %>%
  mutate(dif_porcentual = cob_minsa_24 - cob_minsa_23)

clster <- clster %>%
  mutate(across(starts_with("cob_minsa"), as.character))


# Aplicar la función a cada columna de cobertura
datos_long <- clster %>%
  pivot_longer(cols = starts_with("cob_minsa"), names_to = "anio", values_to = "valor") %>%
  mutate(anio = str_extract(anio, "[0-9]+")) %>%  # Extraer el año de la variable
  rowwise() %>%
  mutate(extraido = list(extraer_valores(valor))) %>%
  unnest(cols = c(extraido)) %>%
  select(-valor)  # Eliminar la columna original con texto

datos_long <- datos_long %>%
  mutate(anio = case_when(
    anio == "22" ~ "2022",
    anio == "23" ~ "2023",
    anio == "24" ~ "2024",
    TRUE ~ anio  # Mantiene los demás valores sin cambios
  ))

# Ordenar los datos de mayor a menor según la diferencia porcentual
datos_long <- datos_long %>%
  arrange(desc(dif_porcentual))

# Convertir microred en factor para fijar el orden en el gráfico
datos_long$cluster <- factor(datos_long$cluster, levels = unique(datos_long$cluster))


# Graficar con ggplot2
minsa <- ggplot(datos_long, aes(x = cluster, y = cobertura, fill = anio)) +
  geom_bar(stat = "identity", position = "dodge", width = 0.9) +
  geom_errorbar(aes(ymin = li, ymax = ls), width = 0.2, position = position_dodge(0.9)) +
  scale_fill_brewer(palette = "Set2") +
  labs(title = "",
       x = "",
       y = "",
       fill = "Año") +
  theme_minimal() +
  theme(axis.text.x = element_text(angle = 0, hjust = 1, size = 16),
        axis.text.y = element_text(size = 18),  # Aumentar tamaño eje Y)
         legend.position = "bottom",             # Colocar la leyenda abajo
        legend.direction = "horizontal",        # Leyenda horizontal
        legend.box = "horizontal",              # Alinear etiquetas horizontalmente
        legend.title = element_text(size = 16), # Ajustar tamaño del título de la leyenda
        legend.text = element_text(size = 15))   # Ajustar tamaño del texto de la leyenda
minsa

```

## Cobertura privadas

```{r, message=FALSE, echo=FALSE, warning = FALSE, fig.width=16, fig.height=14}
#########################--
## Cobertura por Privado
#########################--

# Extraer la primera parte usando regex
clster <- clster %>%
  mutate(
    cob_priv_23 = as.numeric(str_extract(cob_priv_23_ic, "^[0-9]+\\.?[0-9]*")),
    cob_priv_24 = as.numeric(str_extract(cob_priv_24_ic, "^[0-9]+\\.?[0-9]*")))

# Calcular la diferencia porcentual
clster <- clster %>%
  mutate(dif_porcentual = cob_priv_24 - cob_priv_23)

clster <- clster %>%
  mutate(across(starts_with("cob_priv"), as.character))


# Aplicar la función a cada columna de cobertura
datos_priv <- clster %>%
  pivot_longer(cols = starts_with("cob_priv"), names_to = "anio", values_to = "valor") %>%
  mutate(anio = str_extract(anio, "[0-9]+")) %>%  # Extraer el año de la variable
  rowwise() %>%
  mutate(extraido = list(extraer_valores(valor))) %>%
  unnest(cols = c(extraido)) %>%
  select(-valor)  # Eliminar la columna original con texto

datos_priv <- datos_priv %>%
  mutate(anio = case_when(
    anio == "22" ~ "2022",
    anio == "23" ~ "2023",
    anio == "24" ~ "2024",
    TRUE ~ anio  # Mantiene los demás valores sin cambios
  ))

# Ordenar los datos de mayor a menor según la diferencia porcentual
datos_priv <- datos_priv %>%
  arrange(desc(dif_porcentual))

# Convertir microred en factor para fijar el orden en el gráfico
datos_priv$cluster <- factor(datos_priv$cluster, levels = unique(datos_priv$cluster))

# Graficar con ggplot2
privado <- ggplot(datos_priv, aes(x = cluster, y = cobertura, fill = anio)) +
  geom_bar(stat = "identity", position = "dodge", width = 0.9) +
  geom_errorbar(aes(ymin = li, ymax = ls), width = 0.2, position = position_dodge(0.9)) +
  scale_fill_brewer(palette = "Set2") +
  labs(title = "",
       x = "",
       y = "",
       fill = "Año") +
  theme_minimal() +
  theme(axis.text.x = element_text(angle = 0, hjust = 1, size = 16),
        axis.text.y = element_text(size = 18),  # Aumentar tamaño eje Y)
         legend.position = "bottom",             # Colocar la leyenda abajo
        legend.direction = "horizontal",        # Leyenda horizontal
        legend.box = "horizontal",              # Alinear etiquetas horizontalmente
        legend.title = element_text(size = 16), # Ajustar tamaño del título de la leyenda
        legend.text = element_text(size = 15))   # Ajustar tamaño del texto de la leyenda
privado


```


## Cobertura General

```{r, message=FALSE, echo=FALSE, warning = FALSE, fig.width=16, fig.height=14}
#########################--
## Cobertura Total
#########################--

# Calcular la diferencia porcentual
clster <- clster %>%
  mutate(dif_porcentual = cob_total_24 - cob_total_23)


clster <- clster %>%
  mutate(across(starts_with("cob_total"), as.character))


# Aplicar la función a cada columna de cobertura
datos_total <- clster %>%
  pivot_longer(cols = starts_with("cob_total"), names_to = "anio", values_to = "valor") %>%
  mutate(anio = str_extract(anio, "[0-9]+")) %>%  # Extraer el año de la variable
  rowwise() %>%
  mutate(extraido = list(extraer_valores(valor))) %>%
  unnest(cols = c(extraido)) %>%
  select(-valor)  # Eliminar la columna original con texto

datos_total <- datos_total %>%
  mutate(anio = case_when(
    anio == "22" ~ "2022",
    anio == "23" ~ "2023",
    anio == "24" ~ "2024",
    TRUE ~ anio  # Mantiene los demás valores sin cambios
  ))


# Ordenar los datos de mayor a menor según la diferencia porcentual
datos_total <- datos_total %>%
  arrange(desc(dif_porcentual))

# Convertir microred en factor para fijar el orden en el gráfico
datos_total$cluster <- factor(datos_total$cluster, levels = unique(datos_total$cluster))

# Graficar con ggplot2
general <- ggplot(datos_total, aes(x = cluster, y = cobertura, fill = anio)) +
  geom_bar(stat = "identity", position = "dodge", width = 0.9) +
  geom_errorbar(aes(ymin = li, ymax = ls), width = 0.2, position = position_dodge(0.9)) +
  scale_fill_brewer(palette = "Set2") +
  labs(title = "",
       x = "",
       y = "",
       fill = "Año") +
  theme_minimal() +
  theme(axis.text.x = element_text(angle = 0, hjust = 1, size = 16),
        axis.text.y = element_text(size = 18),  # Aumentar tamaño eje Y)
         legend.position = "bottom",             # Colocar la leyenda abajo
        legend.direction = "horizontal",        # Leyenda horizontal
        legend.box = "horizontal",              # Alinear etiquetas horizontalmente
        legend.title = element_text(size = 16), # Ajustar tamaño del título de la leyenda
        legend.text = element_text(size = 15))   # Ajustar tamaño del texto de la leyenda
general

```



# **Cobertura por Distrito**

```{r, message=FALSE, echo=FALSE, warning = FALSE, fig.width=16, fig.height=14}

# Calcular la diferencia porcentual
dstrito <- dstrito %>%
  mutate(dif_porcentual = cob_minsa_24 - cob_minsa_23)

dstrito <- dstrito %>%
  mutate(across(starts_with("cob_minsa"), as.character))


# Aplicar la función a cada columna de cobertura
datos_long <- dstrito %>%
  pivot_longer(cols = starts_with("cob_minsa"), names_to = "anio", values_to = "valor") %>%
  mutate(anio = str_extract(anio, "[0-9]+")) %>%  # Extraer el año de la variable
  rowwise() %>%
  mutate(extraido = list(extraer_valores(valor))) %>%
  unnest(cols = c(extraido)) %>%
  select(-valor)  # Eliminar la columna original con texto

datos_long <- datos_long %>%
  mutate(anio = case_when(
    anio == "22" ~ "2022",
    anio == "23" ~ "2023",
    anio == "24" ~ "2024",
    TRUE ~ anio  # Mantiene los demás valores sin cambios
  ))


# Ordenar los datos de mayor a menor según la diferencia porcentual
datos_long <- datos_long %>%
  arrange(desc(dif_porcentual))

# Convertir microred en factor para fijar el orden en el gráfico
datos_long$distrito <- factor(datos_long$distrito, levels = unique(datos_long$distrito))

# Graficar con ggplot2
minsa <- ggplot(datos_long, aes(x = distrito, y = cobertura, fill = anio)) +
  geom_bar(stat = "identity", position = "dodge", width = 0.9) +
  geom_errorbar(aes(ymin = li, ymax = ls), width = 0.2, position = position_dodge(0.9)) +
  scale_fill_brewer(palette = "Set2") +
  labs(title = "",
       x = "",
       y = "",
       fill = "Año") +
  theme_minimal() +
  theme(axis.text.x = element_text(angle = 45, hjust = 1, size = 16),
        axis.text.y = element_text(size = 18),  # Aumentar tamaño eje Y)
         legend.position = "bottom",             # Colocar la leyenda abajo
        legend.direction = "horizontal",        # Leyenda horizontal
        legend.box = "horizontal",              # Alinear etiquetas horizontalmente
        legend.title = element_text(size = 16), # Ajustar tamaño del título de la leyenda
        legend.text = element_text(size = 15))   # Ajustar tamaño del texto de la leyenda
minsa

```

## Cobertura privadas

```{r, message=FALSE, echo=FALSE, warning = FALSE, fig.width=16, fig.height=14}
#########################--
## Cobertura por Privado
#########################--

# Extraer la primera parte usando regex
dstrito <- dstrito %>%
  mutate(
    cob_priv_23 = as.numeric(str_extract(cob_priv_23_ic, "^[0-9]+\\.?[0-9]*")),
    cob_priv_24 = as.numeric(str_extract(cob_priv_24_ic, "^[0-9]+\\.?[0-9]*")))

# Calcular la diferencia porcentual
dstrito <- dstrito %>%
  mutate(dif_porcentual = cob_priv_24 - cob_priv_23)

dstrito <- dstrito %>%
  mutate(across(starts_with("cob_priv"), as.character))


# Aplicar la función a cada columna de cobertura
datos_priv <- dstrito %>%
  pivot_longer(cols = starts_with("cob_priv"), names_to = "anio", values_to = "valor") %>%
  mutate(anio = str_extract(anio, "[0-9]+")) %>%  # Extraer el año de la variable
  rowwise() %>%
  mutate(extraido = list(extraer_valores(valor))) %>%
  unnest(cols = c(extraido)) %>%
  select(-valor)  # Eliminar la columna original con texto

datos_priv <- datos_priv %>%
  mutate(anio = case_when(
    anio == "22" ~ "2022",
    anio == "23" ~ "2023",
    anio == "24" ~ "2024",
    TRUE ~ anio  # Mantiene los demás valores sin cambios
  ))

# Ordenar los datos de mayor a menor según la diferencia porcentual
datos_priv <- datos_priv %>%
  arrange(desc(dif_porcentual))

# Convertir microred en factor para fijar el orden en el gráfico
datos_priv$distrito <- factor(datos_priv$distrito, levels = unique(datos_priv$distrito))

# Graficar con ggplot2
privado <- ggplot(datos_priv, aes(x = distrito, y = cobertura, fill = anio)) +
  geom_bar(stat = "identity", position = "dodge", width = 0.9) +
  geom_errorbar(aes(ymin = li, ymax = ls), width = 0.2, position = position_dodge(0.9)) +
  scale_fill_brewer(palette = "Set2") +
  labs(title = "",
       x = "",
       y = "",
       fill = "Año") +
  theme_minimal() +
  theme(axis.text.x = element_text(angle = 45, hjust = 1, size = 16),
        axis.text.y = element_text(size = 18),  # Aumentar tamaño eje Y)
         legend.position = "bottom",             # Colocar la leyenda abajo
        legend.direction = "horizontal",        # Leyenda horizontal
        legend.box = "horizontal",              # Alinear etiquetas horizontalmente
        legend.title = element_text(size = 16), # Ajustar tamaño del título de la leyenda
        legend.text = element_text(size = 15))   # Ajustar tamaño del texto de la leyenda
privado


```


## Cobertura General

```{r, message=FALSE, echo=FALSE, warning = FALSE, fig.width=16, fig.height=14}
#########################--
## Cobertura Total
#########################--

# Calcular la diferencia porcentual
dstrito <- dstrito %>%
  mutate(dif_porcentual = cob_total_24 - cob_total_23)

dstrito <- dstrito %>%
  mutate(across(starts_with("cob_total"), as.character))


# Aplicar la función a cada columna de cobertura
datos_total <- dstrito %>%
  pivot_longer(cols = starts_with("cob_total"), names_to = "anio", values_to = "valor") %>%
  mutate(anio = str_extract(anio, "[0-9]+")) %>%  # Extraer el año de la variable
  rowwise() %>%
  mutate(extraido = list(extraer_valores(valor))) %>%
  unnest(cols = c(extraido)) %>%
  select(-valor)  # Eliminar la columna original con texto

datos_total <- datos_total %>%
  mutate(anio = case_when(
    anio == "22" ~ "2022",
    anio == "23" ~ "2023",
    anio == "24" ~ "2024",
    TRUE ~ anio  # Mantiene los demás valores sin cambios
  ))

# Ordenar los datos de mayor a menor según la diferencia porcentual
datos_total <- datos_total %>%
  arrange(desc(dif_porcentual))

# Convertir microred en factor para fijar el orden en el gráfico
datos_total$distrito <- factor(datos_total$distrito, levels = unique(datos_total$distrito))

# Graficar con ggplot2
general <- ggplot(datos_total, aes(x = distrito, y = cobertura, fill = anio)) +
  geom_bar(stat = "identity", position = "dodge", width = 0.9) +
  geom_errorbar(aes(ymin = li, ymax = ls), width = 0.2, position = position_dodge(0.9)) +
  scale_fill_brewer(palette = "Set2") +
  labs(title = "",
       x = "",
       y = "",
       fill = "Año") +
  theme_minimal() +
  theme(axis.text.x = element_text(angle = 45, hjust = 1, size = 16),
        axis.text.y = element_text(size = 18),  # Aumentar tamaño eje Y)
         legend.position = "bottom",             # Colocar la leyenda abajo
        legend.direction = "horizontal",        # Leyenda horizontal
        legend.box = "horizontal",              # Alinear etiquetas horizontalmente
        legend.title = element_text(size = 16), # Ajustar tamaño del título de la leyenda
        legend.text = element_text(size = 15))   # Ajustar tamaño del texto de la leyenda
general

```

# **Ratio Humano Perro**

```{r, message=FALSE, echo=FALSE, warning = FALSE, fig.width=16, fig.height=14}
###############-
#### Ratio ####
###############-

library(readr)
ratio_22 <- read_csv("C:/Users/artur_4yucftm/Box/ENCUESTAS POST VANCAN RABIA/Encuestas Post Vancan 2024/Data_ENCUESTAS-2024/Resultados/2022/cobertura_microred_2022.csv")
ratio_23 <- read_csv("C:/Users/artur_4yucftm/Box/ENCUESTAS POST VANCAN RABIA/Encuestas Post Vancan 2024/Data_ENCUESTAS-2024/Resultados/2023/cobertura_microred_2023.csv")
ratio_24 <- read_csv("C:/Users/artur_4yucftm/Box/ENCUESTAS POST VANCAN RABIA/Encuestas Post Vancan 2024/Data_ENCUESTAS-2024/Resultados/2024/cobertura_microred_2024.csv")

# Cambiar el nombre de la columna "old_name" a "new_name"
names(ratio_22)[names(ratio_22) == "ratio_h_p"] <- "ratio_h_p_22"
names(ratio_23)[names(ratio_23) == "ratio_h_p"] <- "ratio_h_p_23"
names(ratio_24)[names(ratio_24) == "ratio_h_p"] <- "ratio_h_p_24"


datos <- ratio_22 %>%
  left_join(ratio_23, by = "microred") %>%
  left_join(ratio_24, by = "microred") %>%
  select(microred, ratio_h_p_22, ratio_h_p_23, ratio_h_p_24)

# Extraer la primera parte usando regex
datos <- datos %>%
  mutate(
    ratio_hu_p_23 = as.numeric(str_extract(ratio_h_p_23, "^[0-9]+\\.?[0-9]*")),
    ratio_hu_p_24 = as.numeric(str_extract(ratio_h_p_24, "^[0-9]+\\.?[0-9]*")))

# Extraer cobertura, intervalo inferior y superior
extraer_valores <- function(x) {
  num <- as.numeric(str_extract(x, "^[0-9]+\\.?[0-9]*")) # Extrae el primer número como cobertura
  li <- as.numeric(str_extract(x, "(?<=\\()[0-9]+\\.?[0-9]*")) # Extrae el límite inferior
  ls <- as.numeric(str_extract(x, "[0-9]+\\.?[0-9]*(?=\\))")) # Extrae el límite superior
  return(data.frame(cobertura = num, li = li, ls = ls))
}


# Calcular la diferencia porcentual

datos <- datos %>%
  mutate(
    ratio_hu_p_24 = as.numeric(ratio_hu_p_24),
    ratio_hu_p_23 = as.numeric(ratio_hu_p_23),
    dif_porcentual = ratio_hu_p_24 - ratio_hu_p_23)


datos <- datos %>%
  mutate(across(starts_with("ratio_h_p"), as.character))


datos_long <- datos %>%
  pivot_longer(cols = starts_with("ratio_h_p"), names_to = "anio", values_to = "valor") %>%
  mutate(anio = str_extract(anio, "[0-9]+")) %>%  # Extraer el año de la variable
  mutate(extraido = str_extract_all(valor, "[0-9]+\\.?[0-9]*")) %>%  # Extraer números
  rowwise() %>%
  mutate(
    cobertura = as.numeric(extraido[1]),
    li = as.numeric(extraido[2]),
    ls = as.numeric(extraido[3])
  ) %>%
  ungroup() %>%
  select(-valor, -extraido)  # Eliminar columnas temporales


datos_long <- datos_long %>%
  mutate(anio = case_when(
    anio == "22" ~ "2022",
    anio == "23" ~ "2023",
    anio == "24" ~ "2024",
    TRUE ~ anio  # Mantiene los demás valores sin cambios
  ))

# Ordenar los datos de mayor a menor según la diferencia porcentual
datos_long <- datos_long %>%
  arrange(desc(dif_porcentual))

# Convertir microred en factor para fijar el orden en el gráfico
datos_long$microred <- factor(datos_long$microred, levels = unique(datos_long$microred))

# Graficar con ggplot2
ratio_h_p <- ggplot(datos_long, aes(x = microred, y = cobertura, fill = anio)) +
  geom_bar(stat = "identity", position = "dodge", width = 0.9) +
  geom_errorbar(aes(ymin = li, ymax = ls), width = 0.2, position = position_dodge(0.9)) +
  scale_fill_brewer(palette = "Set2") +
  labs(title = "",
       x = "",
       y = "",
       fill = "Año") +
  theme_minimal() +
  theme(axis.text.x = element_text(angle = 45, hjust = 1, size = 16),
        axis.text.y = element_text(size = 18),  # Aumentar tamaño eje Y)
        legend.position = "bottom",             # Colocar la leyenda abajo
        legend.direction = "horizontal",        # Leyenda horizontal
        legend.box = "horizontal",              # Alinear etiquetas horizontalmente
        legend.title = element_text(size = 16), # Ajustar tamaño del título de la leyenda
        legend.text = element_text(size = 15))   # Ajustar tamaño del texto de la leyenda
ratio_h_p


```

