Lendo as cartas dos gestores com IA usando Python

O que os gestores de fundos de investimentos pensam sobre os mercados e sobre a economia? Todo mês, dezenas de gestores publicam suas cartas relatando sua visão, desempenho e outras informações relevantes para os cotistas. No entanto, ler estes relatórios pode facilmente tomar 1 dia inteiro ou mais de trabalho. Para economizar este tempo, podemos utilizar inteligência artificial e sumarizar os principais tópicos do documento em poucos segundos!

Neste artigo mostramos como usar um modelo LLM para ler e sumarizar as “Cartas do Gestor”, publicadas em fundos de investimento no Brasil. Em menos de 60 linhas de código, criamos uma aplicação completa em Python que pega um arquivo PDF da carta do gestor, processa os dados e usa inteligência artificial para sumarizar os pontos chave do texto.

Aprenda a coletar, processar e analisar dados na formação de Do Zero à Análise de Dados com Python.

Passo 01: bibliotecas de Python necessárias

Para criar o app, utilizaremos as seguintes bibliotecas no Python:

  • shiny para desenvolver o app/dashboard.
  • langchain para processar os dados e o prompt de LLM.
  • langchain_community para ler o PDF.
  • langchain_openai para usar a API do ChatGPT (OpenAI).
  • os para gerenciar chave de token da API da OpenAI.
  • pypdf para trabalhar com PDFs.

Certifique-se de ter todas as bibliotecas instaladas.

Para obter o código e o tutorial deste exercício faça parte do Clube AM e receba toda semana os códigos em R/Python, vídeos, tutoriais e suporte completo para dúvidas.

Passo 02: chave de autenticação da API da OpenAI

Para utilizar o modelo de inteligência artificial ChatGPT, é necessário obter uma chave de token na plataforma OpenAI (veja mais informações aqui).

Com a chave de token em mãos, defina uma variável de ambiente com nome OPENAI_API_KEY para armazenar a chave.

Atenção: a utilização da API da OpenAI não é gratuita. Verifique o site da empresa para mais informações.

Passo 03: interface visual do app/dashboard

Para simplificar o exemplo, vamos criar o app com um visual simples, contendo apenas:

  • Título do app
  • Descrição breve sobre a funcionalidade
  • Campo de texto para inserir o link do PDF
  • Painel para exibir o sumário do PDF gerado pela inteligência artificial

Tudo isso pode ser feito em cerca de 12 linhas de código utilizando a biblioteca Shiny.

Passo 04: conversão de PDF para texto

Para que a carta do gestor possa ser lida pela inteligência artificial, precisamos converter o conteúdo do arquivo PDF para o formato de texto. Fazemos isso da seguinte forma:

  • Definimos o componente Servidor do Shiny para implementar a lógica de funcionamento do app.
  • Definimos uma função reativa para ler o arquivo PDF informado pelo usuário através do link e converter para o formato de texto.

Passo 05: engenharia de prompt e modelo de inteligência artificial

Ainda no componente Servidor, iniciado no passo anterior, definimos qual será a instrução enviada para a inteligência artificial e qual modelo cumprirá esta tarefa. Estes procedimentos são realizados da seguinte forma:

  • Utilizamos o prompt a seguir para instruir o modelo de inteligência artificial a sumarizar o texto fornecendo uma breve descrição sobre o mesmo.
    Escreva um sumário do texto a seguir delimitado com 3 crases. Retorne sua resposta em 3 ou 5 marcadores com uma breve descrição dos pontos chave do texto.
    ```{TEXTO}```
    SUMÁRIO:
  • Definimos o gpt-3.5-turbo, da OpenAI, como modelo de inteligência artificial a ser utilizado.
  • Utilizamos o langchain para processar automaticamente o prompt e o texto, além de fazer a comunicação com a API da OpenAI para retornar a resposta do modelo.

Passo 06: execução e teste do app

Para rodar o app/dashboard localmente e testar o funcionamento com diferentes cartas do gestor, utilizamos o Shiny. A biblioteca se encarrega de unir as definições da interface e da lógica de servidor para gerar a dashboard que pode ser visualizada pelo navegador, conforme abaixo:

Conclusão

Neste artigo mostramos como usar um modelo LLM para ler e sumarizar as “Cartas do Gestor”, publicadas em fundos de investimento no Brasil. Em menos de 60 linhas de código, criamos uma aplicação completa em Python que pega um arquivo PDF da carta do gestor, processa os dados e usa inteligência artificial para sumarizar os pontos chave do texto.

Quer aprender mais?

Clique aqui para fazer seu cadastro no Boletim AM e baixar o código que produziu este exercício, além de receber novos 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 diretamente em seu e-mail.

Compartilhe esse artigo

Facebook
Twitter
LinkedIn
WhatsApp
Telegram
Email
Print

Comente o que achou desse artigo

Outros artigos relacionados

Onde encontrar dados e ferramentas para text mining?

A aplicação das técnicas de mineração de texto pode trazer análises quantitativas informativas sobre a emoção, tom, categoria e outros padrões de interesse em documentos textuais. O primeiro passo é identificar, coletar e preparar estes dados brutos. Neste artigo, apresentamos bases de dados públicas de Economia e Finanças que podem ser exploradas, assim como ferramentas de programação úteis.

O que é mineração de textos e sua relação com IA?

Com uma matéria prima em comum, a mineração de textos e a inteligência artificial generativa usam grandes volumes de dados não estruturados para fins distintos e com aplicações em Economia, Finanças, Marketing e outras áreas. Mas quando devemos usar uma técnica e não a outra? O que é possível fazer e o que é mineração de textos? Neste artigo introduzimos estes tópicos e fornecemos alguns exemplos de aplicações.

Avaliando a evolução do Funcionalismo Público nos Estados Brasileiros usando Controle Sintético no R

O objetivo deste exercício é introduzir o uso do método de Controle Sintético na linguagem de programação R, aplicando-o a um exemplo prático relevante para a análise de políticas públicas. Vamos focar na utilização dessa técnica para avaliar o impacto do Regime de Recuperação Fiscal (RRF) sobre o número de vínculos do poder executivo nos estados brasileiros, com ênfase no caso do Rio de Janeiro.

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.