Diferencial de Juros

---
title: 'Diferencial de Juros '
author: ''
date: "04-11-2025"
output:
  html_document:
    toc: true
    toc_float: true
    theme: lumen
    highlight: tango
    code_folding: show
    code_download: true
  pdf_document:
    toc: true
---

```{r setup, include=FALSE}
knitr::opts_chunk$set(echo = FALSE, message = FALSE, warning = FALSE)

# Carregar pacotes
library(tidyverse)
library(plotly)
library(highcharter)
library(fredr)
library(rbcb)
library(quantmod)
library(lubridate)
library(ggplot2)
library(tibble)
library(scales)
library(httr)
library(jsonlite)
library(stringr)
library(tidyr)
library(pdftools)


```


# **Diferencial de Juros**
```{r}
library(readr)
library(dplyr)
library(lubridate)
library(highcharter)
library(stringr)
library(htmlwidgets)

# --- Ler dados das reservas brasileiras ---
dados_raw <- read_delim(
  "Custofiscal.csv",
  delim = ";",
  locale = locale(encoding = "latin1", decimal_mark = ".")
)

# --- Processar dados brasileiros ---
dados_processed <- dados_raw %>%
  rename(
    Data = 1,
    Reservas = 2,
    Cambio = 3,
    Selic = 4
  ) %>%
  mutate(
    Reservas = gsub("\\.", "", trimws(Reservas)),
    Reservas = gsub(",", ".", Reservas),
    Reservas = as.numeric(Reservas),
    Cambio = gsub(",", ".", trimws(Cambio)),
    Cambio = as.numeric(Cambio),
    Selic = gsub(",", ".", trimws(Selic)),
    Selic = as.numeric(Selic),
    Data = paste0("01/", Data),
    Data = dmy(Data, locale = "pt_BR.utf8"),
    Data = floor_date(Data, "month")
  ) %>%
  filter(!is.na(Reservas) & !is.na(Cambio) & !is.na(Selic))

# --- Criar tabela com dados GS10 (rendimento de Treasury 10Y) a partir de 2020 ---
fedfunds_data <- data.frame(
  Data = as.Date(c(
    "2020-01-01", "2020-02-01", "2020-03-01", "2020-04-01", "2020-05-01", "2020-06-01",
    "2020-07-01", "2020-08-01", "2020-09-01", "2020-10-01", "2020-11-01", "2020-12-01",
    "2021-01-01", "2021-02-01", "2021-03-01", "2021-04-01", "2021-05-01", "2021-06-01",
    "2021-07-01", "2021-08-01", "2021-09-01", "2021-10-01", "2021-11-01", "2021-12-01",
    "2022-01-01", "2022-02-01", "2022-03-01", "2022-04-01", "2022-05-01", "2022-06-01",
    "2022-07-01", "2022-08-01", "2022-09-01", "2022-10-01", "2022-11-01", "2022-12-01",
    "2023-01-01", "2023-02-01", "2023-03-01", "2023-04-01", "2023-05-01", "2023-06-01",
    "2023-07-01", "2023-08-01", "2023-09-01", "2023-10-01", "2023-11-01", "2023-12-01",
    "2024-01-01", "2024-02-01", "2024-03-01", "2024-04-01", "2024-05-01", "2024-06-01",
    "2024-07-01", "2024-08-01", "2024-09-01", "2024-10-01", "2024-11-01", "2024-12-01",
    "2025-01-01", "2025-02-01", "2025-03-01", "2025-04-01", "2025-05-01", "2025-06-01",
    "2025-07-01", "2025-08-01", "2025-09-01"
  )),
  FEDFUNDS = c(
    1.76, 1.50, 0.87, 0.66, 0.67, 0.73,
    0.62, 0.65, 0.68, 0.79, 0.87, 0.93,
    1.08, 1.26, 1.61, 1.64, 1.62, 1.52,
    1.32, 1.28, 1.37, 1.58, 1.56, 1.47,
    1.76, 1.93, 2.13, 2.75, 2.90, 3.14,
    2.90, 2.90, 3.52, 3.98, 3.89, 3.62,
    3.53, 3.75, 3.66, 3.46, 3.57, 3.75,
    3.90, 4.17, 4.38, 4.80, 4.50, 4.02,
    4.06, 4.21, 4.21, 4.54, 4.48, 4.31,
    4.25, 3.87, 3.72, 4.10, 4.36, 4.39,
    4.63, 4.45, 4.28, 4.28, 4.42, 4.38,
    4.39, 4.26, 4.12
  )
)

# --- Juntar dados brasileiros com FEDFUNDS ---
dados_completos <- dados_processed %>%
  left_join(fedfunds_data, by = "Data") %>%
  mutate(Diferencial = Selic - FEDFUNDS) %>%
  filter(!is.na(FEDFUNDS))

# --- Preparar para gráfico ---
selic_hc <- dados_completos %>%
  mutate(Data = datetime_to_timestamp(Data)) %>%
  select(Data, Selic)

fedfunds_hc <- dados_completos %>%
  mutate(Data = datetime_to_timestamp(Data)) %>%
  select(Data, FEDFUNDS)

diferencial_hc <- dados_completos %>%
  mutate(Data = datetime_to_timestamp(Data)) %>%
  select(Data, Diferencial)

# --- Criar gráfico (código limpo) ---
grafico <- highchart() %>%
  hc_add_series(
    data = list_parse2(selic_hc),
    type = "line",
    name = "Taxa Selic",
    color = "#02023C",
    lineWidth = 2,
    marker = list(enabled = FALSE)
  ) %>%
  hc_add_series(
    data = list_parse2(fedfunds_hc),
    type = "line",
    name = "Treasury10Y",
    color = "#46B1E1",
    lineWidth = 2,
    marker = list(enabled = FALSE)
  ) %>%
  hc_add_series(
    data = list_parse2(diferencial_hc),
    type = "area",
    name = "Diferencial de juros",
    color = "#FEB712",
    fillOpacity = 0.3,
    # Garante linha de contorno
    lineWidth = 2, 
    # Impede marcadores no GRÁFICO
    marker = list(enabled = FALSE) 
  ) %>%
  hc_title(
    text = "Diferencial de juros: Taxa Selic x Rendimento Externo (2020–2025)"
  ) %>%
  hc_subtitle(
    text = "Fonte: Banco Central do Brasil e FED"
  ) %>%
  hc_yAxis(
    title = list(text = "Taxa de Juros (% a.a.)"),
    labels = list(format = "{value:.1f}%")
  ) %>%
  hc_xAxis(
    type = "datetime",
    title = list(text = "Período"),
    labels = list(format = "{value:%b/%Y}"),
    tickInterval = 30 * 24 * 3600 * 1000 * 6
  ) %>%
  hc_tooltip(
    enabled = TRUE,
    shared = TRUE,
    valueSuffix = "% a.a.",
    xDateFormat = "%b/%Y"
  ) %>%
  hc_legend(
    enabled = TRUE,
    align = "center",
    verticalAlign = "bottom",
    layout = "horizontal",
    # --- AJUSTE: Aumenta o tamanho do símbolo para que a linha fique nítida ---
    symbolWidth = 25, 
    symbolHeight = 10,
    symbolRadius = 2
    # ------------------------------------------------------------------------
  ) %>%
  hc_exporting(
    enabled = TRUE,
    filename = "diferencial_juros_br_eua",
    buttons = list(
      contextButton = list(
        menuItems = c("downloadPNG", "downloadJPEG", "downloadPDF", "downloadSVG")
      )
    )
  ) %>%
  hc_credits(
    enabled = TRUE,
    text = "Fonte: BCB(4189) e FED(10) | Gráfico: Ibmacro BH"
  ) %>%
  hc_chart(
    backgroundColor = "#FFFFFF"
  )

# Exibir gráfico
grafico

```

