QuantStart.
Junte-se ao portal de membros privados da Quantcademy que atende à comunidade de comerciantes de varejo de varejo em rápido crescimento. Você encontrará um grupo bem informado de mentalistas quant pronto para responder suas perguntas comerciais mais importantes.
Confira meu ebook sobre o comércio de quant, onde eu ensino você como criar estratégias de negociação sistemáticas lucrativas com ferramentas Python, desde o início.
Dê uma olhada no meu novo ebook sobre estratégias de negociação avançadas usando análise de séries temporais, aprendizado de máquina e estatísticas bayesianas, com Python e R.
Por Frank Smietana em 18 de julho de 2017.
Neste artigo, Frank Smietana, um dos colaboradores experientes do QuantStart, descreve a paisagem do software de backtesting de código aberto da Python e fornece conselhos sobre quais framework de backtesting são adequados para suas próprias necessidades de projeto.
Backtesting é indiscutivelmente a parte mais crítica do processo de produção da Sistemática de Negociação Sistemática (STS), sentado entre o desenvolvimento da estratégia e a implantação (negociação ao vivo). Se uma estratégia é defeituosa, um teste rigoroso provavelmente expõe isso, evitando que uma estratégia de perda seja implantada.
Uma série de capacidades relacionadas se sobrepõem com backtesting, incluindo simulação comercial e negociação ao vivo. O Backtesting usa dados históricos para quantificar o desempenho STS. Os simuladores de negociação levam backtesting um passo adiante, visualizando o desencadeamento de trades e desempenho de preços em uma base bar-a-bar. A negociação simulada / ao vivo implementa um STS testado em tempo real: negociações de sinalização, gerando ordens, roteando ordens para corretores e mantendo as posições à medida que as ordens são executadas.
A maioria dos quadros vai além do backtesting para incluir algumas capacidades de negociação ao vivo. Isso é conveniente se você deseja implantar a partir de sua estrutura de backtesting, que também funciona com o seu fornecedor preferido e fontes de dados. Quantopian / Zipline vai um passo adiante, fornecendo uma solução totalmente integrada de desenvolvimento, backtesting e implantação.
A comunidade Python é bem servida, com pelo menos seis estruturas de backtesting de código aberto disponíveis. No entanto, estão em vários estágios de desenvolvimento e documentação. Se você gosta de trabalhar em uma equipe construindo uma estrutura de backtesting de código aberto, confira seus reembolsos Github.
Antes de avaliar quadros de teste, vale a pena definir os requisitos do seu STS.
Qual classe de ativos você está negociando? Embora a maioria dos frameworks ofereça suporte aos dados da US Equities via YahooFinance, se uma estratégia incorporar derivados, ETFs ou títulos de EM, os dados precisam ser importados ou fornecidos pela estrutura. As coberturas de classe de ativos vão além dos dados. O framework pode lidar com futuros e opções de tamanho finito e gerar negociações de roll-over automaticamente? E quanto aos mercados ilíquidos, quão realista é uma suposição ao executar grandes encomendas?
Qual a frequência e o detalhe dos dados do seu STS? Um sistema de negociação que exige que cada marca ou lance / peça tenha um conjunto muito diferente de problemas de gerenciamento de dados do que um intervalo de 5 minutos ou horário. Os hedge funds e as lojas HFT investiram significativamente na construção de quadros robustos e escaláveis de backtesting para lidar com esse volume e freqüência de dados. Algumas plataformas fornecem um conjunto rico e profundo de dados para várias classes de ativos, como ações da S & P, com resolução de um minuto.
Qual (s) tipo (s) de ordem o seu STS requer? No mínimo, o limite, as paradas e o OCO devem ser suportados pela estrutura.
Nível de suporte e amp; documentação necessária. Os quadros de estágio inicial têm escassa documentação, poucos têm suporte além de placas comunitárias.
Os Componentes de um Quadro de Teste de Backtesting.
Dados e aquisição de STS: os componentes de aquisição consomem o arquivo de script / definição STS e fornecem os dados necessários para testes. Se a estrutura exige que qualquer STS seja recodificado antes do teste posterior, a estrutura deve suportar funções enlatadas para os indicadores técnicos mais populares para acelerar o teste STS. Os usuários determinam o tempo de um período histórico para fazer backtest com base no que o framework fornece, ou o que eles são capazes de importar.
O teste de desempenho aplica a lógica STS à janela de dados históricos solicitada e calcula uma ampla gama de riscos & amp; métricas de desempenho, incluindo redução máxima, taxas Sharpe e Sortino. A maioria dos frameworks suporta um número decente de capacidades de visualização, incluindo curvas de equidade e estatísticas decimais.
A otimização tende a exigir a maior parte dos recursos de computação no processo STS. Se o seu STS precisar de otimização, concentre-se em uma estrutura que suporte processamento escalável distribuído / paralelo.
No contexto de estratégias desenvolvidas usando indicadores técnicos, os desenvolvedores de sistemas tentam encontrar um conjunto ideal de parâmetros para cada indicador. Mais simplesmente, a otimização pode achar que um fluxo de média móvel de 6 e 10 dias STS acumulou mais lucro sobre os dados de teste históricos do que qualquer outra combinação de períodos de tempo entre 1 e 20. Já com este exemplo trivial, 20 * 20 = 400 combinações de parâmetros devem ser calculado & amp; classificado.
No contexto de um portfólio, a otimização procura encontrar a ponderação ideal de cada ativo na carteira, incluindo os instrumentos em curto e alavancado. Em uma base periódica, o portfólio é reequilibrado, resultando na compra e venda de participações da carteira, conforme necessário, para alinhar com os pesos otimizados.
O dimensionamento de posição é um uso adicional da otimização, ajudando os desenvolvedores de sistemas a simular e analisar o impacto da alavancagem e dimensionamento de posição dinâmico no STS e no desempenho do portfólio.
Seis quadros de teste para o Python.
As capacidades padrão das plataformas open source Python backtesting parecem incluir:
Gerenciamento de eventos, flexível e irrestrito Coleta decente de indicadores técnicos pré-definidos Captação de desempenho padrão / visualização / geração de relatórios.
PyAlgoTrade.
PyAlgoTrade é uma estrutura de backtesting mutuamente documentada, juntamente com capacidades de negociação em papel e ao vivo. O suporte a dados inclui Yahoo! Finanças, Google Finance, NinjaTrader e qualquer tipo de série de tempo baseada em CSV, como Quandl. Os tipos de pedidos suportados incluem Market, Limit, Stop e StopLimit.
O PyAlgoTrade suporta a negociação Bitcoin via Bitstamp e o gerenciamento de eventos do Twitter em tempo real.
bt - Backtesting para Python.
bt "visa promover a criação de blocos de lógica de estratégia facilmente testáveis, reutilizáveis e flexíveis para facilitar o rápido desenvolvimento de estratégias comerciais complexas".
O framework é particularmente adequado para testar STS com base em portfólio, com algos para ponderação de ativos e reequilíbrio de portfólio. A modificação de uma estratégia para executar em diferentes freqüências de tempo ou pesos de ativos alternativos envolve um mínimo de ajuste de código. bt é construído em cima do ffn - uma biblioteca de funções financeiras para Python.
Backtrader.
Esta plataforma está excepcionalmente bem documentada, com um blog acompanhante e uma comunidade on-line ativa para postar perguntas e solicitações de recursos. O Backtrader suporta uma série de formatos de dados, incluindo arquivos CSV, Pandas DataFrames, iteradores de incandescência e feeds de dados em tempo real de três corretores. Esses feeds de dados podem ser acessados simultaneamente e podem até representar diferentes cronogramas. Os corretores suportados incluem Oanda para negociação de Forex e negociação de classes de ativos múltiplos através de Interactive Brokers e Visual Chart.
Pysystemtrade.
O desenvolvedor da Pysystemtrade, Rob Carver, tem uma ótima postagem em discussão sobre o porquê ele se propôs a criar mais uma nova estrutura de teste do Python e os argumentos para e contra o desenvolvimento do framework. A estrutura backtesting para pysystemtrade é discutida no livro Rob, "Systematic Trading".
Pysystemtrade lista uma série de recursos de roteiro, incluindo um testador de back-up completo, que inclui técnicas de otimização e calibração e negociação de futuros totalmente automáticos com Interactive Brokers. Os contribuidores da fonte aberta são bem-vindos.
Zipline é um simulador de negociação algorítmica com recursos de papel e negociação ao vivo. Acessível através da interface do navegador IPython baseado no navegador, a Zipline fornece uma alternativa fácil de usar para ferramentas de linha de comando. Suportado e desenvolvido por Quantopian, Zipline pode ser usado como uma estrutura de backtesting autônomo ou como parte de um ambiente completo de desenvolvimento, teste e implantação de STS, de Aosta / Zipline STS. A Zipline fornece 10 anos de dados de estoque históricos históricos de última hora e uma série de opções de importação de dados.
QSTrader é uma estrutura de backtesting com capacidades de negociação ao vivo. O fundador da QuantStart, Michael Halls-Moore, lançou o QSTrader com a intenção de construir uma plataforma robusta e escalável o suficiente para atender às necessidades dos fundos de hedge quantitativos institucionais, bem como aos comerciantes quantos de varejo. O QSTrader atualmente suporta dados de resolução "barra" da OHLCV em várias escalas de tempo, mas permite que dados de marca sejam usados.
Tanto o backtesting como o comércio ao vivo são completamente orientados para eventos, simplificando a transição das estratégias da pesquisa para o teste e, finalmente, a negociação ao vivo. A estratégia básica / código do portfólio geralmente é idêntico em ambas as implementações.
O principal benefício do QSTrader é em sua modularidade, permitindo uma ampla personalização de código para aqueles que possuem requisitos específicos de gerenciamento de risco ou portfólio.
Abraçando o Backtest.
É a natureza humana se concentrar na recompensa de desenvolver um STS (esperançosamente lucrativo), então apressar-se a implantar uma conta financiada (porque esperamos), sem gastar tempo e recursos suficientes para testar completamente a estratégia. Mas backtesting não é apenas um gatekeeper para nos impedir de implementar estratégias erradas e perder capital comercial, também fornece uma série de diagnósticos que podem informar o processo de desenvolvimento STS. Por exemplo, testando um STS idêntico em dois intervalos de tempo diferentes, compreendendo a redução máxima de uma estratégia no contexto de correlações de ativos e criando portfólios mais inteligentes por backtesting de alocações de ativos em várias regiões geográficas.
Em futuras postagens, iremos abordar frameworks de backtesting para ambientes que não sejam Python e o uso de várias técnicas de amostragem como bootstrapping e jackknife para testar modelos de negociação preditivos.
Apenas iniciando o comércio quantitativo?
3 razões para se inscrever para a lista de e-mails QuantStart:
1. Quant Trading Lessons.
Você terá acesso instantâneo a um curso de e-mail gratuito de 10 partes, repleto de sugestões e dicas para ajudá-lo a começar a negociação quantitativa!
2. Todo o conteúdo mais recente.
Todas as semanas, vou enviar-lhe um envoltório de todas as atividades no QuantStart para que você nunca mais perca uma postagem novamente.
Real, dicas de negociação viáveis, sem tonturas.
LearnDataSci.
Início »Python for Finance, Parte 2: Introdução às Estratégias de Negociação Quantitativas.
Python for Finance, Parte 2: Introdução às Estratégias de Negociação Quantitativas.
Python for Finance, Parte 2: Introdução às Estratégias de Negociação Quantitativas.
Idioma: Python 3.5 Bibliotecas: pandas, numpy e matplotlib iPython notebook: disponível no GitHub.
Em Python for Finance, Parte I, nos concentramos no uso de Python e Pandas para.
Recupere as séries temporais financeiras das fontes on-line gratuitas (Yahoo), formateie os dados preenchendo observações faltantes e alinhando-as, calcule alguns indicadores simples, como médias móveis rolantes e visualize as séries temporais finais.
Como lembrete, o quadro de dados contendo os três & # 8220; cleaned & # 8221; timeseries de preços tem o seguinte formato:
Também calculamos as médias móveis de rolamento destas três vezes, da seguinte forma. Observe que ao calcular a média móvel de $ M $ dias, os primeiros $ M-1 $ não são válidos, pois os preços de $ M $ são necessários para o primeiro ponto de dados de média móvel.
Com base nesses resultados, nosso objetivo final será projetar uma estratégia de negociação simples e realista. No entanto, primeiro precisamos passar por alguns dos conceitos básicos relacionados às estratégias de negociação quantitativas, bem como as ferramentas e técnicas no processo.
Considerações gerais sobre estratégias de negociação.
Existem várias maneiras de se lidar com uma estratégia de negociação. Uma abordagem seria usar as séries temporais de preços diretamente e trabalhar com números que correspondem a algum valor monetário. Por exemplo, um pesquisador poderia estar trabalhando com séries temporais que expressam o preço de uma determinada ação, como as séries temporais usadas no artigo anterior. Da mesma forma, se estiver trabalhando com instrumentos de renda fixa, por exemplo, títulos, pode-se usar uma série de tempo que expressa o preço do vínculo como uma porcentagem de um determinado valor de referência, neste caso, o valor nominal da obrigação. Trabalhar com este tipo de séries de tempo pode ser mais intuitivo, pois as pessoas costumam pensar em termos de preços. Contudo, as séries temporais dos preços apresentam algumas desvantagens. Os preços geralmente são apenas positivos, o que dificulta a utilização de modelos e abordagens que exigem ou produzam números negativos. Além disso, as séries temporais de preços geralmente não são estacionárias, ou seja, suas propriedades estatísticas são menos estáveis ao longo do tempo.
Uma abordagem alternativa é usar séries temporais que correspondem não a valores reais, mas mudanças no valor monetário do recurso. Essas séries de tempo podem assumir valores negativos e também, suas propriedades estatísticas são geralmente mais estáveis do que as séries temporais de preços. Os formulários mais utilizados são os retornos relativos definidos como.
e log-returns definido como.
onde $ p \ left (t \ right) $ é o preço do ativo no tempo $ t $. Por exemplo, se $ p \ left (t \ right) = 101 $ e $ p \ left (t-1 \ right) = 100 $ e $ r_> \ left (t \ right) = \ frac = 1 \% $ .
Há várias razões pelas quais os log-returns estão sendo usados no setor e alguns deles estão relacionados a premissas de longa data sobre o comportamento dos retornos de ativos e estão fora do nosso alcance. No entanto, o que precisamos apontar são duas propriedades bastante interessantes. Log-returns são aditivos e isso facilita o tratamento de nossas séries temporais, os retornos relativos não são. Podemos ver a aditividade de log-returns na seguinte equação.
que é simplesmente o log-return de $ t_0 $ para $ t_2 $. Em segundo lugar, os retornos de log são aproximadamente iguais aos retornos relativos dos valores de $ \ frac $ suficientemente perto de $ 1 $. Ao tomar a expansão Taylor de 1ª ordem de $ \ log \ left (\ frac \ right) $ em torno de US $ 1 $, obtemos.
Ambos são calculados trivialmente usando Pandas como:
Uma vez que os retornos de log são aditivos, podemos criar as séries temporais dos retornos de registro cumulativos definidos como.
c \ left (t \ right) = \ sum_ ^ t r \ left (t \ right)
Os retornos de log cumulativos e os retornos relativos totais de 2000/01/01 para as três séries de tempo podem ser vistos abaixo. Observe que, embora os log-returns sejam fáceis de manipular, os investidores estão acostumados a usar retornos relativos. Por exemplo, um retorno de log de $ 1 $ não significa que um investidor tenha duplicado o valor de seu portfólio. Um retorno relativo de $ 1 = 100 \% $ faz! A conversão entre o retorno de log cumulativo $ c \ left (t \ right) $ eo retorno relativo total $ c_> \ left (t \ right) = \ frac $ é simples.
Para aqueles que estão se perguntando se isso está correto, sim é. Se alguém tivesse comprado $ \ $ 1000 $ de ações da AAPL em janeiro de 2000, seu portfólio agora valeria mais de $ \ $ 30,000 $. Se ao menos tivéssemos uma máquina do tempo & # 8230;
O que é uma estratégia de negociação quantitativa?
Nosso objetivo é desenvolver uma estratégia de negociação de brinquedos, mas o que significa a estratégia de negociação quantitativa & # 8220; # 8221; realmente significa? Nesta seção, daremos uma definição que nos guiará em nosso objetivo de longo prazo.
Suponha que temos à nossa disposição uma certa quantia de dólares, $ N $, que estamos interessados em investir. Temos à nossa disposição um conjunto de ativos de US $ K $ dos quais podemos comprar e vender livremente qualquer valor arbitrário. Nosso objetivo é derivar pesos $ w_i \ left (t \ right), i = 1, \ ldots, K $ desse tipo.
$$ w_i \ left (t \ right) \ in \ mathbb \ \ text \ \ sum_ ^ K w_i \ left (t \ right) \ leq 1 $$
de modo que uma quantia de dólares igual a $ w_i \ left (t \ right) N $ é investida no time $ t $ no asset $ i $.
A condição de desigualdade significa $ \ sum_ ^ K w_i \ left (t \ right) \ leq 1 $ que o valor máximo que podemos investir é igual ao valor de dólares que temos, que é $ N $.
Por exemplo, suponha que possamos investir apenas US $ 2 $ e que $ N = \ $ 1000 $. O objetivo é derivar dois pesos $ w_1 \ left (t \ right) $ e $ w_2 \ left (t \ right) $.
Se em algum ponto $ w_1 \ left (t \ right) = 0.4 $ e $ w_2 \ left (t \ right) = 0.6 $, isso significa que investimos $ w_1 \ left (t \ right) N = \ $ 400 $ no activo $ 1 $ e $ w_2 \ left (t \ right) N = \ $ 600 $ no ativo $ 2 $. Uma vez que só temos $ \ $ 1000 $, só podemos investir tanto quanto isso significa isso.
$$ w_1 \ left (t \ right) N + w_2 \ left (t \ right) N \ leq N \ Rightarrow w_1 \ left (t \ right) + w_2 \ left (t \ right)
Georgios Efstathopoulos.
A Georgios tem mais de 7 anos de experiência como analista quantitativo no setor financeiro e tem trabalhado extensivamente em modelos estatísticos e de aprendizagem por máquina para negociação quantitativa, gerenciamento de risco de mercado e de crédito e modelagem comportamental. Georgios possui doutorado em Matemática Aplicada e Estatística no Imperial College de Londres, e é fundador e CEO da QuAnalytics Limited, uma consultoria focada em soluções quantitativas e de análise de dados para indivíduos e organizações que desejam colher o potencial de seus próprios dados para aumentar seus negócios .
Recomendado.
Python for Finance, Parte I: Yahoo Finance API, pandas e matplotlib.
Em detalhes, no primeiro de nossos tutoriais, vamos mostrar como se pode usar facilmente o Python para baixar dados financeiros de bancos de dados on-line gratuitos, manipular os dados baixados e, em seguida, criar alguns indicadores técnicos básicos que serão usados como base de nossa estratégia quantitativa.
Python for Finance, Parte 3: uma estratégia de negociação média móvel.
Neste artigo, começaremos a conceber uma estratégia de negociação mais complexa, que terá pesos não constantes wi (t) wi (t), e assim se adaptará de algum modo ao comportamento recente do preço de nossos ativos.
Melhores Cursos Online de Ciência de Dados em 2017.
O seguinte é uma extensa lista de cursos e recursos de Ciências da Informação, de plataformas como Coursera, edX e Udacity, que lhe dão as habilidades necessárias para se tornar um cientista de dados.
Mais de 100 livros gratuitos de ciência de dados para 2017.
Tirado da web, aqui está a nossa coleção dos melhores livros gratuitos em Data Science, Big Data, Data Mining, Machine Learning, Python, R, SQL, NoSQL e muito mais.
Obrigado por compartilhar Georgios. Utilizar uma simulação de Monte Carlo para derivar os pesos ótimos divididos para maximizar o retorno seja uma melhoria dessa estratégia em vez de dividir uniformemente 1/3 de cada uma? : weights_vector = pd. DataFrame (1/3, index = r_t. index, columns = r_t. columns)
Você está certo, a MC seria uma das formas possíveis de otimizar os pesos para essa estratégia. Note, no entanto, que existem várias questões abertas sobre esta otimização. Em primeiro lugar, o que estamos otimizando? Retorno total, volatilidade da carteira, retração? Em segundo lugar, a otimização corre o risco de sobrepor os pesos ao intervalo histórico que estamos usando para a otimização. Essas e outras questões serão abordadas nos seguintes artigos nesta série.
Quando podemos esperar a próxima publicação?
Obrigado pelo artigo. Há várias instâncias acima, onde você divide 1/3 e 1/7. Python assume que o resultado seja um número inteiro, então a resposta é 0 em ambos os casos. Você deve usar 1.0 / 3 e 1.0 / 7 para evitar esse problema.
Obrigado pelo aviso. Esta série de artigos pressupõe que o Python 3 é usado. No Python 3, 1/3 produzirá 1.3333, em vez da divisão inteira, que foi o caso no Python 2.
No entanto, para tornar isso compatível com os usuários do Python 2, no que se segue, eu me certificarei de que, nesses casos, seja tomado um cuidado especial para garantir que as divisões sejam tratadas de forma adequada.
Copyright © 2017 LearnDataSci. Todos os direitos reservados.
Estratégias de negociação em python
Se você é um comerciante ou um investidor e gostaria de adquirir um conjunto de habilidades de negociação quantitativas, você está no lugar certo.
O curso Trading With Python irá fornecer-lhe as melhores ferramentas e práticas para pesquisa de negociação quantitativa, incluindo funções e scripts escritos por comerciantes quantitativos especializados. O curso dá o máximo impacto para o seu tempo investido e dinheiro. Ele se concentra na aplicação prática da programação ao comércio e não à informática teórica. O curso irá pagar por si mesmo rapidamente, economizando tempo no processamento manual de dados. Você passará mais tempo pesquisando sua estratégia e implementando negócios lucrativos.
Visão geral do curso.
Parte 1: princípios Você vai aprender por que a Python é uma ferramenta ideal para negociação quantitativa. Começaremos pela criação de um ambiente de desenvolvimento e, em seguida, apresentaremos as bibliotecas científicas.
Parte 2: Manipulação dos dados Saiba como obter dados de várias fontes gratuitas, como Yahoo Finance, CBOE e outros sites. Leia e escreva vários formatos de dados, incluindo arquivos CSV e Excel.
Parte 3: estratégias de pesquisa Aprenda a calcular o P & L e as métricas de desempenho acompanhantes, como Sharpe e Drawdown. Desenvolva uma estratégia de negociação e otimize seu desempenho. Múltiplos exemplos de estratégias são discutidos nesta parte.
Parte 4: Indo ao vivo! Esta parte é centrada em torno da Interactive Brokers API. Você aprenderá como obter dados em estoque em tempo real e colocar ordens ao vivo.
Muitos códigos de exemplo.
O material do curso consiste em "cadernos" que contêm texto junto com um código interativo como este. Você poderá aprender interagindo com o código e modificando-o para seu próprio gosto. Será um excelente ponto de partida para escrever suas próprias estratégias.
Embora alguns tópicos sejam explicados em grande detalhe para ajudá-lo a entender os conceitos subjacentes, na maioria dos casos você nem precisa escrever seu próprio código de baixo nível, devido ao suporte de bibliotecas de código aberto existentes:
A biblioteca TradingWithPython combina uma grande parte da funcionalidade discutida neste curso como uma função pronta para usar e será usada ao longo do curso. Pandas irá fornecer-lhe todo o poder de levantamento pesado necessário no trituração de dados.
Todo o código é fornecido sob a licença BSD, permitindo seu uso em aplicações comerciais.
Classificação do curso.
Um piloto do curso foi realizado na primavera de 2018, é o que os alunos conseguiram dizer:
Matej curso bem projetado e bom treinador. Definitivamente valeu o preço e meu tempo, Lave Jev, obviamente, conhecia suas coisas. A profundidade de cobertura foi perfeita. Se Jev executar algo assim novamente, serei o primeiro a se inscrever. John Phillips Seu curso realmente me fez começar a pensar em python para a análise do sistema de estoque.
Estratégias de negociação em python
Olá e bem-vindo à parte 13 da série tutorial Python for Finance. Neste tutorial, vamos começar a falar sobre o back-testing da estratégia. O campo de teste de volta e os requisitos para fazê-lo direito são bastante maciços. Basicamente, o que é necessário para nós é criar um sistema que levará dados de preços históricos e simulará a negociação nesse ambiente e, em seguida, nos dará os resultados. Isso pode parecer simples, mas, para analisar a estratégia, precisamos rastrear um conjunto de métricas, como o que vendemos, quando, com que freqüência trocamos, o que nossa Beta e Alpha é, além de outras métricas, como a redução, Sharpe Relação, volatilidade, alavancagem e muito mais. Juntamente com isso, geralmente queremos visualizar tudo isso. Então, podemos escrever tudo isso a nós mesmos, ou podemos usar uma plataforma para nos ajudar com isso.
. É por isso que vamos introduzir a Quantopian, que é uma plataforma que nos permite escrever e testar as estratégias de negociação com Python facilmente.
O que o Quantopian faz é adicionar uma camada de GUI em cima da biblioteca de testes de Zipline para Python, além de um conjunto de fontes de dados, muitas das quais são completamente gratuitas para trabalhar. Você também pode obter alocações de capital da Quantopian, ao licenciar sua estratégia para elas se você atender a determinados critérios. Geralmente, um beta entre -0.3 e +0.3 é um bom ponto de partida, mas você também precisa ter outras métricas saudáveis para competir. Mais sobre isso mais tarde, vamos aprender sobre os princípios de Quantopian primeiro. Uma vez que a partpian é alimentada por bibliotecas primariamente abertas, como Zipline, Alphalens e Pyfolio, você também pode executar uma plataforma semelhante a Quantopian localmente, se quiser. Eu acho que a maioria das pessoas interessadas em atuar localmente estão interessadas em manter seus algoritmos privados. A Quantopian não vê os seus algoritmos, a menos que você dê permissão, e a comunidade só vê seus algoritmos se os compartilhar. Eu altamente encorajar você a ver seu relacionamento com a Aspian não como um adversário, mas sim como uma parceria. Se você chegar com algo de alta qualidade, a Quespian está muito interessada em trabalhar com, e tem o financiamento para investir em você. Nessa relação, a Quantopian está trazendo a plataforma, o financiamento e outros especialistas no campo para ajudá-lo, é um bom negócio na minha opinião.
Para começar, dirija-se a Quantopian, crie uma conta se você não tiver uma, e faça login. Sinta-se à vontade para puxar um pouco. Os fóruns da comunidade de Quantopian são um ótimo lugar para absorver algum conhecimento. Quantopian também executa um concurso freqüente para preços em dinheiro. Vamos começar com os algoritmos. Uma vez lá, escolha o botão azul "novo algoritmo". Por enquanto, vamos passar a maior parte do tempo em dois lugares, que podem ser encontrados no botão "Meu Código". Para começar, iremos para algoritmos e criamos um novo algoritmo usando o botão azul "Algoritmo novo".
Quando você cria o algoritmo, você deve ser levado para sua página de algoritmos de edição ativa com o algoritmo clonado, que se parece com isso (menos as caixas coloridas) e algumas mudanças possivelmente para a IU.
Python Editor - É onde você codifica sua lógica Python para o algoritmo. Resultados do algoritmo construído - Quando você cria o algoritmo, os resultados gráficos aparecerão aqui. Saída de registro / erro - Qualquer informação de saída / log do console virá aqui. É comum que o seu programa libere vários bits de texto para depuração ou apenas para obter mais informações. Algoritmo de criação: use isso para testar rapidamente o que você escreveu. Os resultados não serão salvos, mas você pode ver o resultado na seção de resultados do algoritmo incorporado. Full Backtest - Isso executará um teste de retorno completo com base no seu algoritmo atual. Os testes completos completos vêm com um pouco mais de análise, os resultados são salvos e o algoritmo que gerou esses resultados também é salvo, para que você possa rever os testes de volta e visualizar o código exato que gerou um resultado específico.
O código de exemplo inicial é algo como:
O que é ótimo, mas talvez seja um pouco demais para começar. Quantopian também fornece alguns algoritmos de exemplo se sua conta for nova. Sinta-se livre para verificar esses, mas você pode achar que eles são confusos. As únicas duas funções que você precisa em cada algoritmo são: initialize e handle_data. A função de inicialização é executada uma vez, no início do seu script. Você usará isso para configurar globals como regras, funções para usar mais tarde e vários parâmetros. Em seguida, a função handle_data que é executada a cada minuto em relação aos dados do mercado.
Vamos escrever nossa estratégia simples para ficar confortável com o Lespian. Vamos implementar uma estratégia de cruzamento de média móvel simples e ver como isso acontece.
Se você não está familiarizado com as médias móveis, o que faz é ter um certo número de "janelas" de dados. No caso de correr contra preços diários, uma janela seria um dia. Se você tivesse uma média móvel de 20, isso significaria uma média móvel de 20 dias. A partir daqui, a idéia é dizer que você tem uma média móvel de 20 e uma média móvel de 50. Traçar isso em um gráfico pode parecer algo como:
Aqui, a linha azul é o preço das ações, a linha vermelha é a média móvel de 20 e a linha amarela é a média móvel de 50. A idéia é que quando a média móvel de 20, que reage mais rápido, ultrapassa a média móvel de 50, isso significa que o preço pode estar tendendo, e podemos querer investir. Por outro lado, se a média móvel de 20 cai abaixo da média móvel de 50, isso indica talvez que o preço está a diminuir, e que queremos vender ou investir, ou mesmo vender a empresa, onde você apostou.
Para os nossos propósitos aqui, apliquemos uma estratégia de cruzamento em média móvel para a Apple (AAPL), entre as datas de 7 de outubro de 2018 e 7 de outubro de 2018. Para esse período, as ações da AAPL diminuíram, e depois, com muito pouca mudança líquida global . Nossa estratégia de cruzamento deve, espero, ficar longe ou curto (apostar contra) à medida que o preço cai e, em seguida, pular quando o preço está aumentando. O shorting de uma empresa implica o empréstimo de partes de outra pessoa, vendendo-as e, em seguida, reabastecimento das ações em uma data posterior. Sua esperança é que o preço das ações caia, e você os recompõe de volta muito mais barato e dê ao proprietário original suas ações, embolando a diferença. Para começar, vamos construir o método de inicialização:
Por enquanto, vamos definir o nosso estoque de maçã. Se você realmente começar a digitar o sid (o Quantopian possui uma funcionalidade de preenchimento automático agradável, onde você pode começar a digitar o nome da empresa ou o símbolo do ticker para encontrar o sid. O motivo para usar o sid é porque os tickers da empresa podem mudar ao longo de períodos de tempo . Esta é uma maneira de garantir que você esteja recebendo o ticker que você realmente pretende obter. Você também pode usar o símbolo () para usar o ticker e tornar seu código um pouco mais fácil de ler, mas isso não é recomendado , uma vez que o ticker pode mudar.
Toda vez que você cria um algoritmo com Zipline ou Quantopian, você precisará ter os métodos initialize e handle_data.
O método de inicialização é executado uma vez no início do algoritmo (ou uma vez por dia, se você estiver executando o algoritmo ao vivo em tempo real). Handle_data é executado uma vez por minuto.
Dentro do nosso método de inicialização, passamos esse parâmetro de contexto. Contexto é um dicionário de Python, que é o que usaremos para rastrear o que de outra forma poderemos usar variáveis globais. Simplificando, a variável de contexto é usada para rastrear nossa atual situação de investimento, com coisas como nossa carteira e dinheiro.
Em seguida, ainda precisamos da nossa função handle_data. Esta função leva contexto e dados como parâmetros.
O parâmetro de contexto já foi explicado e a variável de dados é usada para rastrear o ambiente fora do nosso portfólio atual. Isso rastreia coisas como preços de ações e outras informações sobre empresas nas quais podemos ser investidos, ou não, mas são empresas que estamos rastreando.
Para iniciar a função handle_data:
Podemos usar o método. history para obter os preços históricos da Apple, nos últimos 50 dias, em intervalos de 1 dia. Agora podemos fazer:
O valor sma_50 é apenas o que é a média / média para os dados do histórico que acabamos de tirar. O sma_20 é os últimos 20 dias de dados. Observe que isso está contido no método handle_data, que é executado para todos os períodos, então é tudo o que temos a fazer para rastrear os valores diários das médias móveis 50 e 20 simples.
No próximo tutorial, vamos falar sobre fazer pedidos.
Estratégias de negociação em python
Pegue os pedidos 7.
Participe do GitHub hoje.
O GitHub é o lar de mais de 20 milhões de desenvolvedores que trabalham juntos para hospedar e rever o código, gerenciar projetos e criar software juntos.
Clone com HTTPS.
Use o Git ou o check-out com o SVN usando o URL da web.
Com a versão 1.9.50.117 amostras de dados e feeds de dados do YahooFinance foram atualizados para a última informação disponível. Mas sendo o formato não documentado, ainda pode haver mudanças e cantos inesperados.
Aqui, um trecho de um CrossOver médio simples simples. Isso pode ser feito de várias maneiras diferentes. Use os documentos (e exemplos) Luke!
Incluindo um gráfico completo. De uma chance! Isso está incluído nas amostras como sigsmacross / sigsmacross2.py. Ao longo é sigsmacross. py, que pode ser parametrizado a partir da linha de comando.
Live Trading e backtesting plataforma escrita em Python.
Feed de dados ao vivo e negociação com corretores interativos (precisa de IbPy e beneficia muito de uma pira instalada) Gráfico visual (precisa de um garfo de comtypes até que uma solicitação de tração seja integrada na versão e benefícios de pira) Oanda (precisa de oatoterapia) (apenas API REST - v20 não suportou a transmissão em sequência quando implementado) Os feeds de dados de csv / arquivos, fontes on-line ou de pandas e chama Filtros para dados (como quebrar uma barra diária em pedaços para simular intradía) Múltiplos fluxos de dados e estratégias múltiplas suportadas Múltiplos cronogramas ao mesmo tempo Integrados Resampling e Repetição Step-Step backtesting ou de uma só vez (exceto na avaliação da Estratégia) Bateria de indicadores integrada Suporte do indicador TA-Lib (precisa de python ta-lib / verificar os documentos) Desenvolvimento fácil de indicadores personalizados Analisadores (por exemplo: TimeReturn , Ratio de Sharpe, SQN) e integração do pacto. Definição flexível dos esquemas de comissão. Simulação de corretores integrada com Mercado, Close, Limit, Stop, StopLimit, StopTrail, StopTrailLimit * e * OCO, ordens, deslizamento e ajuste contínuo de caixa para instrumentos futuros. Plotting (requer matplotlib)
Leia a documentação completa em:
Lista de indicadores embutidos (116)
Python 2.7 Python 3.2 / 3.3 / 3.4 / 3.5 / 3.6 Também funciona com pypy e pypy3 (sem traçado - matplotlib não é suportado em pypy)
A compatibilidade é testada durante o desenvolvimento com 2.7 e 3.5.
As outras versões são testadas automaticamente com Travis.
O backtrader é autônomo sem dependências externas (exceto se desejar traçar)
pip instalar backtrader.
pip instalar backtrader [plotting]
Se matplotlib não estiver instalado e você deseja fazer algum planejamento.
A versão mínima matplotlib é 1.4.1.
Um exemplo para IB Data Feeds / Trading:
IbPy não parece estar no PyPi. Ou:
ou (se git não estiver disponível no seu sistema):
Para outras funcionalidades como: Visual Chart, Oanda, TA-Lib, verifique as dependências na documentação.
Coloque o diretório backtrader encontrado nas fontes dentro do seu projeto.
X: Número de versão principal. Deve ficar estável, a menos que algo grande seja alterado como uma revisão para usar numpy Y: Número de versão menor. Para ser alterado após a adição de um novo recurso completo ou (Deus proibe), uma mudança de API incompatível. Z: número de versão de revisão. Para ser alterado para atualizações de documentação, pequenas mudanças, pequenas correções de bugs I: Número de Indicadores já incorporados na plataforma.
Se depois de ver os documentos e algumas amostras (veja o blog também) você sente que essa não é sua xícara de chá, você sempre pode dar uma olhada em plataformas semelhantes de Python:
bt ligeiramente pré-data backtrader e tem uma abordagem completamente diferente, mas é divertido, bt também foi escolhido como abreviatura para backtrader durante as importações e que alguns dos métodos têm a mesma denominação (nomeação óbvia de qualquer forma): executar, traçar.
&cópia de; 2018 GitHub, Inc. Termos Privacidade Segurança Status Ajuda.
Você não pode executar essa ação neste momento.
Você fez login com outra guia ou janela. Recarregue para atualizar sua sessão. Você se separou em outra guia ou janela. Recarregue para atualizar sua sessão.
Olá e bem-vindo à parte 13 da série tutorial Python for Finance. Neste tutorial, vamos começar a falar sobre o back-testing da estratégia. O campo de teste de volta e os requisitos para fazê-lo direito são bastante maciços. Basicamente, o que é necessário para nós é criar um sistema que levará dados de preços históricos e simulará a negociação nesse ambiente e, em seguida, nos dará os resultados. Isso pode parecer simples, mas, para analisar a estratégia, precisamos rastrear um conjunto de métricas, como o que vendemos, quando, com que freqüência trocamos, o que nossa Beta e Alpha é, além de outras métricas, como a redução, Sharpe Relação, volatilidade, alavancagem e muito mais. Juntamente com isso, geralmente queremos visualizar tudo isso. Então, podemos escrever tudo isso a nós mesmos, ou podemos usar uma plataforma para nos ajudar com isso.
. É por isso que vamos introduzir a Quantopian, que é uma plataforma que nos permite escrever e testar as estratégias de negociação com Python facilmente.
O que o Quantopian faz é adicionar uma camada de GUI em cima da biblioteca de testes de Zipline para Python, além de um conjunto de fontes de dados, muitas das quais são completamente gratuitas para trabalhar. Você também pode obter alocações de capital da Quantopian, ao licenciar sua estratégia para elas se você atender a determinados critérios. Geralmente, um beta entre -0.3 e +0.3 é um bom ponto de partida, mas você também precisa ter outras métricas saudáveis para competir. Mais sobre isso mais tarde, vamos aprender sobre os princípios de Quantopian primeiro. Uma vez que a partpian é alimentada por bibliotecas primariamente abertas, como Zipline, Alphalens e Pyfolio, você também pode executar uma plataforma semelhante a Quantopian localmente, se quiser. Eu acho que a maioria das pessoas interessadas em atuar localmente estão interessadas em manter seus algoritmos privados. A Quantopian não vê os seus algoritmos, a menos que você dê permissão, e a comunidade só vê seus algoritmos se os compartilhar. Eu altamente encorajar você a ver seu relacionamento com a Aspian não como um adversário, mas sim como uma parceria. Se você chegar com algo de alta qualidade, a Quespian está muito interessada em trabalhar com, e tem o financiamento para investir em você. Nessa relação, a Quantopian está trazendo a plataforma, o financiamento e outros especialistas no campo para ajudá-lo, é um bom negócio na minha opinião.
Para começar, dirija-se a Quantopian, crie uma conta se você não tiver uma, e faça login. Sinta-se à vontade para puxar um pouco. Os fóruns da comunidade de Quantopian são um ótimo lugar para absorver algum conhecimento. Quantopian também executa um concurso freqüente para preços em dinheiro. Vamos começar com os algoritmos. Uma vez lá, escolha o botão azul "novo algoritmo". Por enquanto, vamos passar a maior parte do tempo em dois lugares, que podem ser encontrados no botão "Meu Código". Para começar, iremos para algoritmos e criamos um novo algoritmo usando o botão azul "Algoritmo novo".
Quando você cria o algoritmo, você deve ser levado para sua página de algoritmos de edição ativa com o algoritmo clonado, que se parece com isso (menos as caixas coloridas) e algumas mudanças possivelmente para a IU.
Python Editor - É onde você codifica sua lógica Python para o algoritmo. Resultados do algoritmo construído - Quando você cria o algoritmo, os resultados gráficos aparecerão aqui. Saída de registro / erro - Qualquer informação de saída / log do console virá aqui. É comum que o seu programa libere vários bits de texto para depuração ou apenas para obter mais informações. Algoritmo de criação: use isso para testar rapidamente o que você escreveu. Os resultados não serão salvos, mas você pode ver o resultado na seção de resultados do algoritmo incorporado. Full Backtest - Isso executará um teste de retorno completo com base no seu algoritmo atual. Os testes completos completos vêm com um pouco mais de análise, os resultados são salvos e o algoritmo que gerou esses resultados também é salvo, para que você possa rever os testes de volta e visualizar o código exato que gerou um resultado específico.
O código de exemplo inicial é algo como:
O que é ótimo, mas talvez seja um pouco demais para começar. Quantopian também fornece alguns algoritmos de exemplo se sua conta for nova. Sinta-se livre para verificar esses, mas você pode achar que eles são confusos. As únicas duas funções que você precisa em cada algoritmo são: initialize e handle_data. A função de inicialização é executada uma vez, no início do seu script. Você usará isso para configurar globals como regras, funções para usar mais tarde e vários parâmetros. Em seguida, a função handle_data que é executada a cada minuto em relação aos dados do mercado.
Vamos escrever nossa estratégia simples para ficar confortável com o Lespian. Vamos implementar uma estratégia de cruzamento de média móvel simples e ver como isso acontece.
Se você não está familiarizado com as médias móveis, o que faz é ter um certo número de "janelas" de dados. No caso de correr contra preços diários, uma janela seria um dia. Se você tivesse uma média móvel de 20, isso significaria uma média móvel de 20 dias. A partir daqui, a idéia é dizer que você tem uma média móvel de 20 e uma média móvel de 50. Traçar isso em um gráfico pode parecer algo como:
Aqui, a linha azul é o preço das ações, a linha vermelha é a média móvel de 20 e a linha amarela é a média móvel de 50. A idéia é que quando a média móvel de 20, que reage mais rápido, ultrapassa a média móvel de 50, isso significa que o preço pode estar tendendo, e podemos querer investir. Por outro lado, se a média móvel de 20 cai abaixo da média móvel de 50, isso indica talvez que o preço está a diminuir, e que queremos vender ou investir, ou mesmo vender a empresa, onde você apostou.
Para os nossos propósitos aqui, apliquemos uma estratégia de cruzamento em média móvel para a Apple (AAPL), entre as datas de 7 de outubro de 2018 e 7 de outubro de 2018. Para esse período, as ações da AAPL diminuíram, e depois, com muito pouca mudança líquida global . Nossa estratégia de cruzamento deve, espero, ficar longe ou curto (apostar contra) à medida que o preço cai e, em seguida, pular quando o preço está aumentando. O shorting de uma empresa implica o empréstimo de partes de outra pessoa, vendendo-as e, em seguida, reabastecimento das ações em uma data posterior. Sua esperança é que o preço das ações caia, e você os recompõe de volta muito mais barato e dê ao proprietário original suas ações, embolando a diferença. Para começar, vamos construir o método de inicialização:
Por enquanto, vamos definir o nosso estoque de maçã. Se você realmente começar a digitar o sid (o Quantopian possui uma funcionalidade de preenchimento automático agradável, onde você pode começar a digitar o nome da empresa ou o símbolo do ticker para encontrar o sid. O motivo para usar o sid é porque os tickers da empresa podem mudar ao longo de períodos de tempo . Esta é uma maneira de garantir que você esteja recebendo o ticker que você realmente pretende obter. Você também pode usar o símbolo () para usar o ticker e tornar seu código um pouco mais fácil de ler, mas isso não é recomendado , uma vez que o ticker pode mudar.
Toda vez que você cria um algoritmo com Zipline ou Quantopian, você precisará ter os métodos initialize e handle_data.
O método de inicialização é executado uma vez no início do algoritmo (ou uma vez por dia, se você estiver executando o algoritmo ao vivo em tempo real). Handle_data é executado uma vez por minuto.
Dentro do nosso método de inicialização, passamos esse parâmetro de contexto. Contexto é um dicionário de Python, que é o que usaremos para rastrear o que de outra forma poderemos usar variáveis globais. Simplificando, a variável de contexto é usada para rastrear nossa atual situação de investimento, com coisas como nossa carteira e dinheiro.
Em seguida, ainda precisamos da nossa função handle_data. Esta função leva contexto e dados como parâmetros.
O parâmetro de contexto já foi explicado e a variável de dados é usada para rastrear o ambiente fora do nosso portfólio atual. Isso rastreia coisas como preços de ações e outras informações sobre empresas nas quais podemos ser investidos, ou não, mas são empresas que estamos rastreando.
Para iniciar a função handle_data:
Podemos usar o método. history para obter os preços históricos da Apple, nos últimos 50 dias, em intervalos de 1 dia. Agora podemos fazer:
O valor sma_50 é apenas o que é a média / média para os dados do histórico que acabamos de tirar. O sma_20 é os últimos 20 dias de dados. Observe que isso está contido no método handle_data, que é executado para todos os períodos, então é tudo o que temos a fazer para rastrear os valores diários das médias móveis 50 e 20 simples.
No próximo tutorial, vamos falar sobre fazer pedidos.
No comments:
Post a Comment