---
title: "Dot Plot e Gap de Mercado"
date: "2026-04-07"
output: 
 html_document:
  toc: true
  theme: lumen
  highlight: tango
  code_folding: show
  code_download: true
---

```{r setup, include=FALSE}
knitr::opts_chunk$set(echo = FALSE, message = FALSE, warning = FALSE)

library(fredr)
library(dplyr)
library(lubridate)
library(highcharter)

```
---

```{r}
library(highcharter)
library(dplyr)

# ── 1. Configuração dos Dados (Distribuição FOMC Março 2026) ──
# Nota: Ajustado para 19 membros conforme o padrão do FED e seu texto
niveis <- list(
  list(taxa = 3.75, n = 7, cortes = "Sem corte"),
  list(taxa = 3.50, n = 7, cortes = "1 corte"),
  list(taxa = 3.25, n = 3, cortes = "2 cortes"),
  list(taxa = 3.00, n = 2, cortes = "3 cortes")
)

# ── 2. Mapa de Cores com Transparência (RGBA) ────────────────
cores_map <- c(
  "3.75" = "rgba(2, 2, 60, 0.85)",   # Azul Escuro
  "3.5"  = "rgba(26, 58, 107, 0.85)",  # Azul Médio
  "3.25" = "rgba(46, 109, 164, 0.85)", # Azul Claro
  "3"    = "rgba(116, 175, 211, 0.85)"  # Azul Pálido
)

# ── 3. Função para Gerar Pontos (Jitter Horizontal) ──────────
gerar_pontos <- function(nivel) {
  n      <- nivel$n
  taxa   <- nivel$taxa
  cortes <- nivel$cortes
  
  # Distribuição horizontal simétrica
  if (n == 1) {
    xs <- 0
  } else {
    xs <- seq(-(n - 1), (n - 1), by = 2) * 0.5
  }
  
  chave <- as.character(taxa)
  cor   <- ifelse(chave %in% names(cores_map), cores_map[chave], "rgba(2, 2, 60, 0.8)")
  
  data.frame(
    x      = xs,
    y      = rep(taxa, length(xs)),
    cor    = rep(cor,  length(xs)),
    cortes = rep(cortes, length(xs)),
    stringsAsFactors = FALSE
  )
}

pontos <- bind_rows(lapply(niveis, gerar_pontos))

# ── 4. Cálculo da Mediana ────────────────────────────────────
todos_valores <- rep(
  sapply(niveis, function(x) x$taxa),
  sapply(niveis, function(x) x$n)
)
mediana_val <- median(todos_valores)

# ── 5. Construção do Gráfico Highcharter ─────────────────────
hc <- highchart() |>
  hc_chart(
    type = "scatter",
    backgroundColor = "#ffffff",
    margin = list(70, 100, 100, 100)
  ) |>
  hc_title(
    text  = "FOMC Dot Plot — Projeção para Dez/2026",
    style = list(fontSize = "20px", fontWeight = "bold", color = "#02023c")
  ) |>
  hc_subtitle(
    text  = "Distribuição das expectativas dos membros do FOMC (Março 2026)",
    style = list(fontSize = "13px", color = "#666666")
  ) |>
  hc_xAxis(
    visible = FALSE,
    min = -6,
    max = 6
  ) |>
  hc_yAxis(
    title = list(text = "Fed Funds Rate (%)", style = list(color = "#02023c", fontWeight = "bold")),
    labels = list(format = "{value}%", style = list(fontSize = "12px")),
    min = 2.75,
    max = 4.25,
    tickInterval = 0.25,
    gridLineWidth = 1,
    gridLineColor = "#f0f0f0",
    # PlotLines com zIndex alto para ficarem à frente dos pontos
    plotLines = list(
      list(
        value = 3.625, color = "#e74c3c", dashStyle = "ShortDash", width = 2, zIndex = 5,
        label = list(text = "Taxa Atual", align = "right", style = list(color = "#e74c3c", fontWeight = "bold"))
      ),
      list(
        value = mediana_val, color = "#feb712", dashStyle = "Solid", width = 4, zIndex = 6,
        label = list(text = paste0("Mediana: ", mediana_val, "%"), align = "left", style = list(color = "#feb712", fontWeight = "bold"))
      ),
      list(
        value = 3.0, color = "#999999", dashStyle = "Dot", width = 1.5, zIndex = 4,
        label = list(text = "Taxa Neutra", align = "right", style = list(color = "#999999"))
      )
    )
  ) |>
  # Exportação e Assinatura IbMacro BH
  hc_exporting(enabled = TRUE) |>
  hc_credits(
    enabled = TRUE, 
    text = "Gráfico de confecção própria: IbMacro BH"
  ) |>
  hc_legend(
    enabled = TRUE, align = "center", verticalAlign = "bottom",
    itemStyle = list(fontSize = "11px")
  ) |>
  hc_tooltip(shared = FALSE, useHTML = TRUE)

# ── 6. Adicionar Séries por Nível de Taxa ────────────────────
for (nivel in niveis) {
  df_nivel <- pontos |> filter(y == nivel$taxa)
  cor_ponto <- df_nivel$cor[1]
  
  hc <- hc |> hc_add_series(
    name  = paste0(nivel$cortes, " (", nivel$n, " membros)"),
    data  = list_parse2(df_nivel |> select(x, y)),
    color = cor_ponto,
    marker = list(
      symbol = "circle",
      radius = 12, # Ajustado para não poluir demais
      lineWidth = 1,
      lineColor = "#ffffff"
    ),
    tooltip = list(
      pointFormatter = JS(paste0(
        "function() {
          return '<b>", nivel$cortes, "</b><br/>' +
                 'Taxa: <b>", nivel$taxa, "%</b><br/>' +
                 'Membros: <b>", nivel$n, "</b>';
        }"
      ))
    )
  )
}

hc
```

```{r}
library(highcharter)
library(dplyr)

# ── Dados Ajustados — Fed (Hawkish) vs Mercado (Dovish) ──────
periodos <- c("Mar/26", "Q2/26", "Q3/26", "Q4/26", "Q4/27", "Q4/28", "L.Prazo")

# Fed (Mediana Dot Plot): Projeção de queda lenta
fed_dots <- c(3.625, 3.625, 3.625, 3.40, 3.125, 2.875, 3.00)

# Mercado (Futures): Projeção de cortes agressivos (Dovish)
mercado_futures <- c(3.625, 3.25, 2.875, 2.50, 2.25, 2.50, 2.75)

df_gap <- data.frame(
  x = 0:(length(periodos) - 1),
  fed = fed_dots,
  mkt = mercado_futures
) |>
  mutate(
    gap_sup = pmax(fed, mkt),
    gap_inf = pmin(fed, mkt)
  )

banda_gap <- lapply(1:nrow(df_gap), function(i) list(
  x = df_gap$x[i], 
  low = df_gap$gap_inf[i], 
  high = df_gap$gap_sup[i]
))

# ── Construção do Gráfico ──────────────────────────────────
highchart() |>
  hc_chart(backgroundColor = "#ffffff", margin = list(70, 80, 100, 70)) |>
  
  hc_title(
    text = "Fed vs Mercado: O Abismo de Expectativas",
    style = list(fontSize = "18px", fontWeight = "bold", color = "#02023c")
  ) |>
  
  hc_subtitle(
    text = "Fed (Hawkish) vs Mercado (Dovish) — Projeções Março 2026",
    style = list(fontSize = "12px", color = "#666666")
  ) |>
  
  # Área da divergência (Gap)
  hc_add_series(
    type = "arearange", 
    name = "Divergência (Gap)", 
    data = banda_gap,
    color = "#feb712", 
    fillColor = "rgba(254, 183, 18, 0.15)", 
    lineWidth = 0,
    tooltip = list(pointFormatter = JS("function() {
      var gap = Math.abs(this.point.high - this.point.low) * 100;
      if (gap === 0) return '<span style=\"color:#feb712\">●</span> <b>Sem divergência</b><br/>';
      
      // Lógica corrigida: Se Série 1 (Fed) > Série 2 (Mercado) -> Fed mais hawkish
      var direcao = (this.series.chart.series[1].data[this.point.index].y > 
                     this.series.chart.series[2].data[this.point.index].y) ? 
                     'Fed mais hawkish' : 'Mercado mais hawkish';
                     
      return '<span style=\"color:#feb712\">●</span> <b>Divergência: ' + gap.toFixed(0) + ' bps</b> — ' + direcao + '<br/>';
    }"))
  ) |>
  
  # Linha do Fed (Série 1)
  hc_add_series(
    type = "spline", 
    name = "Fed (Dot Plot)", 
    data = fed_dots, 
    color = "#02023c",
    lineWidth = 4, 
    marker = list(symbol = "diamond", radius = 6, fillColor = "#02023c")
  ) |>
  
  # Linha do Mercado (Série 2)
  hc_add_series(
    type = "spline", 
    name = "Mercado (Futures)", 
    data = mercado_futures, 
    color = "#feb712",
    lineWidth = 4, 
    dashStyle = "ShortDash", 
    marker = list(symbol = "circle", radius = 6, fillColor = "#feb712")
  ) |>
  
  hc_xAxis(
    categories = periodos, 
    gridLineWidth = 1,
    labels = list(style = list(fontWeight = "bold"))
  ) |>
  
  hc_yAxis(
    title = list(text = "Fed Funds Rate (%)"),
    labels = list(format = "{value}%"),
    min = 2.00, 
    max = 4.00, 
    tickInterval = 0.25,
    plotLines = list(
      list(value = 3.625, color = "#999", dashStyle = "Dot", width = 2, 
           label = list(text = "Taxa Atual: 3.625%", align = "right", style = list(fontSize = "10px")))
    )
  ) |>
  
  hc_legend(
    enabled = TRUE, 
    align = "center", 
    verticalAlign = "bottom",
    layout = "horizontal"
  ) |>
  
  # Exportação e Créditos IbMacro BH
  hc_exporting(enabled = TRUE) |>
  hc_credits(
    enabled = TRUE, 
    text = "Gráfico de confecção própria: IbMacro BH"
  ) |>
  
  hc_tooltip(shared = TRUE, useHTML = TRUE)
```