COPOM Watch: Análise Textual Automatizada com o Shiny

Dia de decisão da taxa de juros Selic é dia de muita expectativa. Além do valor numérico dos juros, o comunicado textual da decisão do COPOM pode apresentar conteúdo informacional relevante para estratégias de investimentos. Como diria o provérbio, “o diabo mora nos detalhes” e as entrelinhas dos comunicados da autoridade monetária costumam revelar sinalizações mais importantes do que a decisão de juros em si.

Neste espaço já exploramos a análise de sentimentos, a modelagem de tópicos e a previsão com dados textuais no contexto de comunicação de Bancos Centrais. Apesar de serem aplicações interessantes de text mining, geralmente requerem procedimentos que podem ser onerosos ou complexos em excesso.

Hoje apresentaremos uma solução simples de análise textual dos comunicados do COPOM. A ideia é construir um aplicativo Shiny que permita comparar diferenças entre dois textos, destacando as mudanças. Como os comunicados são padronizados, com essa ferramenta é possível rapidamente avaliar mudanças de posicionamento e condução da política monetária.

Acesse o aplicativo Shiny: https://analisemacro.shinyapps.io/copomwatch_py/

O que é Shiny?

Shiny é uma ferramenta para desenvolvimento de dashboards e aplicativos web interativos, como o exemplo acima, implementada em R e Python. Com ele é possível analisar dados de maneira interativa sem precisar escrever uma linha de HTML, CSS ou JavaScript.

Em termos simples, o Shiny é composto por dois componentes:

  • Interface do usuário: é a parte visual que está aos olhos do usuário, ou seja, layout, botões, campos, gráficos, tabelas, cores e outros.
  • Lógica do servidor: é a parte de código que é executada para a dashboard ser interativa, ou seja, é o código executado quando o usuário clica em um botão e um gráfico se atualiza, por exemplo.

A união destes dois componentes forma uma dashboard ou aplicativo web interativo. Para saber mais sobre Shiny e conferir mais exemplos, dê uma olhada no curso de Produção de Dashboards da Análise Macro.

App Shiny de Análise Textual do COPOM

Agora vamos entender como construir o aplicativo Shiny do exemplo acima para analisar os comunicados do COPOM.

Para organizar o código deste projeto estamos utilizando a seguinte estrutura de arquivos:

.
├── app.py
├── comunicado256.txt
└── comunicado257.txt

Onde o primeiro arquivo armazena os códigos em Shiny e os demais arquivos de texto armazenam os últimos comunicados do COPOM para exemplificar a aplicação.

Interface do Usuário

Começamos definindo o primeiro componente do aplicativo Shiny: a interface visual.

Utilizamos o tipo de página “navbar” para criar um layout de páginas de navegação e definimos na interface dois painéis: o painel da barra lateral com campos de entrada textual e o painel principal com visualização textual (resultado da comparação).

Lógica do Servidor

Prosseguimos definindo o segundo componente do aplicativo Shiny: o código de servidor.

Aqui definimos um retorno textual da aplicação para ser exibido no painel principal. Esse código é executado toda vez que os campos de entrada textual mudarem. A função txt_highlighter() faz todo o trabalho de comparar os dois textos e gerar a visualização com destaques.

Resultado final

Unindo a interface visual com a lógica do servidor chegamos na aplicação Shiny, que pode ser visualizada localmente com o comando abaixo.

Por fim, podemos usar o serviço Shinyapps.io para fazer o deploy da aplicação para a nuvem, gerando um link de compartilhamento que facilita o uso da aplicação por usuários externos: https://analisemacro.shinyapps.io/copomwatch_py/Para entender mais sobre deploy confira o curso de Produção de Dashboards da Análise Macro.

Conclusão

Tomar decisões rápidas com novas informações no mercado, especialmente em dia de COPOM, pode ser decisivo para estratégias bem sucedidas. Nesse artigo mostramos como analisar o texto da decisão de juros básico da economia, a Selic, usando a ferramenta Shiny.

Quer aprender mais?

  •  Cadastre-se gratuitamente aqui no Boletim AM e receba toda terça-feira pela manhã nossa newsletter com um compilado dos nossos exercícios com exemplos reais de análise de dados envolvendo as áreas de Data Science, Econometria, Machine Learning, Macroeconomia Aplicada, Finanças Quantitativas e Políticas Públicas;
  •  Quer ter acesso aos códigos, vídeos e scripts de R/Python desse exercício? Vire membro do Clube AM aqui e tenha acesso à nossa Comunidade de Análise de Dados;
  •  Quer aprender a programar em R ou Python com Cursos Aplicados e diretos ao ponto em Data Science, Econometria, Machine Learning, Macroeconomia Aplicada, Finanças Quantitativas e Políticas Públicas? Veja nossos Cursos aqui.

Compartilhe esse artigo

Facebook
Twitter
LinkedIn
WhatsApp
Telegram
Email
Print

Comente o que achou desse artigo

Outros artigos relacionados

Estimando a volatilidade da taxa de câmbio

O que é Volatilidade? Como podemos calcular essa métrica? Este artigo apresenta uma breve introdução à volatilidade, descreve como podemos calcular a volatilidade utilizando Modelos de Volatilidade Condicional e demonstra a aplicação prática dessa abordagem para estimar a volatilidade da taxa de câmbio BRL/USD por meio da linguagem de programação Python.

Como analisar o Núcleo de Inflação no Brasil usando Python?

O Python se destaca como uma ferramenta robusta para análise de dados, permitindo a aplicação de uma ampla gama de técnicas em dados econômico-financeiros. Neste exercício, destacamos como a linguagem oferece uma facilidade muito grande na coleta de dados dos núcleos do IPCA diretamente do site do Banco Central, na manipulação eficiente desses dados e na construção de gráficos que facilitam a compreensão dos indicadores.

Propensity Score com Múltiplas Variáveis no R

O escore de propensão é provavelmente a maneira mais comum de agregar múltiplas variáveis de correspondência em um único valor que pode ser correspondido, ou seja, muito útil para a realização de pareamento.

O escore de propensão é a probabilidade estimada de que uma determinada observação teria sido tratada. A correspondência de escore de propensão muitas vezes significa selecionar um conjunto de observações de controle correspondidas com valores semelhantes do escore de propensão.

como podemos ajudar?

Preencha os seus dados abaixo e fale conosco no WhatsApp

Boletim AM

Preencha o formulário abaixo para receber nossos boletins semanais diretamente em seu e-mail.