

<!DOCTYPE html>

<html lang="en-US">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=Edge">

  <link rel="stylesheet" href="/puffin/assets/css/just-the-docs-default.css">

  <link rel="stylesheet" href="/puffin/assets/css/just-the-docs-head-nav.css" id="jtd-head-nav-stylesheet">

  <style id="jtd-nav-activation">
  
    .site-nav ul li a {
      background-image: none;
    }

  </style>

  

  
    <script src="/puffin/assets/js/vendor/lunr.min.js"></script>
  

  <script src="/puffin/assets/js/just-the-docs.js"></script>

  <meta name="viewport" content="width=device-width, initial-scale=1">

  



  <!-- Begin Jekyll SEO tag v2.8.0 -->
<title>Puffin - Algorithmic Trading Guide | A comprehensive guide for algorithmic trading - from market fundamentals through ML and AI-assisted trading systems. Learn by building.</title>
<meta name="generator" content="Jekyll v4.4.1" />
<meta property="og:title" content="Puffin - Algorithmic Trading Guide" />
<meta property="og:locale" content="en_US" />
<meta name="description" content="A comprehensive guide for algorithmic trading - from market fundamentals through ML and AI-assisted trading systems. Learn by building." />
<meta property="og:description" content="A comprehensive guide for algorithmic trading - from market fundamentals through ML and AI-assisted trading systems. Learn by building." />
<link rel="canonical" href="/puffin/assets/css/just-the-docs-head-nav.css" />
<meta property="og:url" content="/puffin/assets/css/just-the-docs-head-nav.css" />
<meta property="og:site_name" content="Puffin - Algorithmic Trading Guide" />
<meta property="og:type" content="website" />
<meta name="twitter:card" content="summary" />
<meta property="twitter:title" content="Puffin - Algorithmic Trading Guide" />
<script type="application/ld+json">
{"@context":"https://schema.org","@type":"WebPage","description":"A comprehensive guide for algorithmic trading - from market fundamentals through ML and AI-assisted trading systems. Learn by building.","headline":"Puffin - Algorithmic Trading Guide","publisher":{"@type":"Organization","logo":{"@type":"ImageObject","url":"/puffin/assets/images/puffin_logo.png"}},"url":"/puffin/assets/css/just-the-docs-head-nav.css"}</script>
<!-- End Jekyll SEO tag -->


  <!-- Favicon -->
<link rel="icon" type="image/png" href="/puffin/assets/images/puffin_logo.png">

<!-- Table styling for better visibility in dark mode -->
<style>
  /* Table borders - visible in dark mode */
  table {
    border-collapse: collapse !important;
    border: 1px solid #6b7280 !important;
  }

  table th,
  table td {
    border: 1px solid #6b7280 !important;
    padding: 8px 12px !important;
  }

  /* Table header - slightly different background */
  table th {
    background-color: rgba(107, 114, 128, 0.3) !important;
    font-weight: 600 !important;
  }

  /* Alternating row colors for readability */
  table tbody tr:nth-child(even) {
    background-color: rgba(107, 114, 128, 0.1) !important;
  }

  /* Hover effect */
  table tbody tr:hover {
    background-color: rgba(107, 114, 128, 0.2) !important;
  }
</style>

<!-- Mermaid diagrams with paper-like background -->
<style>
  /* Mermaid container - paper-like background */
  .mermaid,
  pre.mermaid,
  .language-mermaid,
  code.language-mermaid {
    background-color: #d5d0c8 !important;
    border-radius: 8px !important;
    padding: 16px !important;
    margin: 16px 0 !important;
    display: block !important;
  }

  /* All text in Mermaid - dark gray */
  .mermaid text,
  .mermaid tspan,
  .mermaid .nodeLabel,
  .mermaid .label,
  .mermaid .edgeLabel,
  .mermaid .cluster-label,
  .mermaid .messageText,
  .mermaid .loopText,
  .mermaid .noteText,
  .mermaid .labelText,
  .mermaid .actor {
    fill: #2c3e50 !important;
    color: #2c3e50 !important;
  }

  /* All lines and arrows - dark gray */
  .mermaid path,
  .mermaid .edgePath path,
  .mermaid .flowchart-link,
  .mermaid .messageLine0,
  .mermaid .messageLine1,
  .mermaid .relation {
    stroke: #4a5568 !important;
  }

  /* Sequence diagram actor lifelines - force visible */
  line[id^="actor"] {
    stroke: #000000 !important;
    stroke-width: 0.5px !important;
  }

  /* Sequence diagram message lines */
  .mermaid .messageText {
    fill: #2c3e50 !important;
  }

  .mermaid .messageLine0,
  .mermaid .messageLine1 {
    stroke: #4a5568 !important;
    stroke-width: 1.5px !important;
  }

  .mermaid marker path,
  .mermaid .arrowheadPath {
    fill: #4a5568 !important;
    stroke: #4a5568 !important;
  }

  /* Node backgrounds - paper tones */
  .mermaid .node rect,
  .mermaid .node circle,
  .mermaid .node ellipse,
  .mermaid .node polygon,
  .mermaid .node path {
    fill: #c5c0b8 !important;
    stroke: #8a8578 !important;
  }

  /* Cluster backgrounds */
  .mermaid .cluster rect {
    fill: #cac5bd !important;
    stroke: #8a8578 !important;
  }

  /* Actor boxes in sequence diagrams */
  .mermaid .actor-box,
  .mermaid rect.actor {
    fill: #c5c0b8 !important;
    stroke: #8a8578 !important;
  }

  /* Notes - slightly warmer */
  .mermaid .note {
    fill: #ddd8c8 !important;
    stroke: #a89878 !important;
  }

  /* Mindmap nodes */
  .mermaid .mindmap-node rect,
  .mermaid .mindmap-node circle {
    fill: #c5c0b8 !important;
    stroke: #8a8578 !important;
  }

  .mermaid .mindmap-edges path {
    stroke: #4a5568 !important;
    stroke-width: 2px !important;
  }
</style>

<!-- Fix sequence diagram lifelines after mermaid renders -->
<script>
(function() {
  function fixActorLines() {
    var lines = document.querySelectorAll('line[id^="actor"]');
    for (var i = 0; i < lines.length; i++) {
      lines[i].setAttribute('stroke', '#000000');
      lines[i].setAttribute('stroke-width', '0.5px');
    }
  }

  // Run after page fully loads
  if (document.readyState === 'complete') {
    setTimeout(fixActorLines, 500);
    setTimeout(fixActorLines, 1500);
  } else {
    window.addEventListener('load', function() {
      setTimeout(fixActorLines, 500);
      setTimeout(fixActorLines, 1500);
      setTimeout(fixActorLines, 3000);
    });
  }
})();
</script>


</head>

<body>
  <a class="skip-to-main" href="#main-content">Skip to main content</a>
  <svg xmlns="http://www.w3.org/2000/svg" class="d-none">
  <symbol id="svg-link" viewBox="0 0 24 24">
  <title>Link</title>
  <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="feather feather-link">
    <path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71"></path><path d="M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path>
  </svg>
</symbol>

  <symbol id="svg-menu" viewBox="0 0 24 24">
  <title>Menu</title>
  <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="feather feather-menu">
    <line x1="3" y1="12" x2="21" y2="12"></line><line x1="3" y1="6" x2="21" y2="6"></line><line x1="3" y1="18" x2="21" y2="18"></line>
  </svg>
</symbol>

  <symbol id="svg-arrow-right" viewBox="0 0 24 24">
  <title>Expand</title>
  <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="feather feather-chevron-right">
    <polyline points="9 18 15 12 9 6"></polyline>
  </svg>
</symbol>

  <!-- Feather. MIT License: https://github.com/feathericons/feather/blob/master/LICENSE -->
<symbol id="svg-external-link" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="feather feather-external-link">
  <title id="svg-external-link-title">(external link)</title>
  <path d="M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6"></path><polyline points="15 3 21 3 21 9"></polyline><line x1="10" y1="14" x2="21" y2="3"></line>
</symbol>

  
    <symbol id="svg-doc" viewBox="0 0 24 24">
  <title>Document</title>
  <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="feather feather-file">
    <path d="M13 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V9z"></path><polyline points="13 2 13 9 20 9"></polyline>
  </svg>
</symbol>

    <symbol id="svg-search" viewBox="0 0 24 24">
  <title>Search</title>
  <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="feather feather-search">
    <circle cx="11" cy="11" r="8"></circle><line x1="21" y1="21" x2="16.65" y2="16.65"></line>
  </svg>
</symbol>

  
  
    <!-- Bootstrap Icons. MIT License: https://github.com/twbs/icons/blob/main/LICENSE.md -->
<symbol id="svg-copy" viewBox="0 0 16 16">
  <title>Copy</title>
  <svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="currentColor" class="bi bi-clipboard" viewBox="0 0 16 16">
    <path d="M4 1.5H3a2 2 0 0 0-2 2V14a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2V3.5a2 2 0 0 0-2-2h-1v1h1a1 1 0 0 1 1 1V14a1 1 0 0 1-1 1H3a1 1 0 0 1-1-1V3.5a1 1 0 0 1 1-1h1v-1z"/>
    <path d="M9.5 1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-3a.5.5 0 0 1-.5-.5v-1a.5.5 0 0 1 .5-.5h3zm-3-1A1.5 1.5 0 0 0 5 1.5v1A1.5 1.5 0 0 0 6.5 4h3A1.5 1.5 0 0 0 11 2.5v-1A1.5 1.5 0 0 0 9.5 0h-3z"/>
  </svg>
</symbol>
<symbol id="svg-copied" viewBox="0 0 16 16">
  <title>Copied</title>
  <svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="currentColor" class="bi bi-clipboard-check-fill" viewBox="0 0 16 16">
    <path d="M6.5 0A1.5 1.5 0 0 0 5 1.5v1A1.5 1.5 0 0 0 6.5 4h3A1.5 1.5 0 0 0 11 2.5v-1A1.5 1.5 0 0 0 9.5 0h-3Zm3 1a.5.5 0 0 1 .5.5v1a.5.5 0 0 1-.5.5h-3a.5.5 0 0 1-.5-.5v-1a.5.5 0 0 1 .5-.5h3Z"/>
    <path d="M4 1.5H3a2 2 0 0 0-2 2V14a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2V3.5a2 2 0 0 0-2-2h-1v1A2.5 2.5 0 0 1 9.5 5h-3A2.5 2.5 0 0 1 4 2.5v-1Zm6.854 7.354-3 3a.5.5 0 0 1-.708 0l-1.5-1.5a.5.5 0 0 1 .708-.708L7.5 10.793l2.646-2.647a.5.5 0 0 1 .708.708Z"/>
  </svg>
</symbol>

  
</svg>

  
    <header class="side-bar">
  <div class="site-header">
    <a href="/puffin/" class="site-title lh-tight">
  <div class="site-logo" role="img" aria-label="Puffin - Algorithmic Trading Guide"></div>

</a>
    <button id="menu-button" class="site-button btn-reset" aria-label="Menu" aria-expanded="false">
      <svg viewBox="0 0 24 24" class="icon" aria-hidden="true"><use xlink:href="#svg-menu"></use></svg>
    </button>
  </div>

  <nav aria-label="Main" id="site-nav" class="site-nav">
  
  
    <ul class="nav-list"><li class="nav-list-item"><a href="/puffin/" class="nav-list-link">Home</a></li><li class="nav-list-item"><button class="nav-list-expander btn-reset" aria-label="Part 1: Market Foundations submenu" aria-expanded="false">
        <svg viewBox="0 0 24 24" aria-hidden="true"><use xlink:href="#svg-arrow-right"></use></svg>
      </button><a href="/puffin/01-market-foundations/" class="nav-list-link">Part 1: Market Foundations</a><ul class="nav-list"><li class="nav-list-item"><a href="/puffin/01-market-foundations/01-market-structure.html" class="nav-list-link">Market Structure</a></li><li class="nav-list-item"><a href="/puffin/01-market-foundations/02-asset-classes.html" class="nav-list-link">Asset Classes</a></li><li class="nav-list-item"><a href="/puffin/01-market-foundations/03-trading-mechanics.html" class="nav-list-link">Trading Mechanics</a></li><li class="nav-list-item"><a href="/puffin/01-market-foundations/04-financial-metrics.html" class="nav-list-link">Financial Metrics</a></li><li class="nav-list-item"><a href="/puffin/01-market-foundations/05-historical-context.html" class="nav-list-link">Historical Context</a></li><li class="nav-list-item"><a href="/puffin/01-market-foundations/06-market-microstructure.html" class="nav-list-link">Market Microstructure</a></li></ul></li><li class="nav-list-item"><button class="nav-list-expander btn-reset" aria-label="Part 2: Data Pipeline submenu" aria-expanded="false">
        <svg viewBox="0 0 24 24" aria-hidden="true"><use xlink:href="#svg-arrow-right"></use></svg>
      </button><a href="/puffin/02-data-pipeline/" class="nav-list-link">Part 2: Data Pipeline</a><ul class="nav-list"><li class="nav-list-item"><a href="/puffin/02-data-pipeline/01-data-providers.html" class="nav-list-link">Data Providers</a></li><li class="nav-list-item"><a href="/puffin/02-data-pipeline/02-caching-storage.html" class="nav-list-link">Caching & Storage</a></li><li class="nav-list-item"><a href="/puffin/02-data-pipeline/03-preprocessing.html" class="nav-list-link">Preprocessing</a></li></ul></li><li class="nav-list-item"><button class="nav-list-expander btn-reset" aria-label="Part 3: Alternative Data submenu" aria-expanded="false">
        <svg viewBox="0 0 24 24" aria-hidden="true"><use xlink:href="#svg-arrow-right"></use></svg>
      </button><a href="/puffin/03-alternative-data/" class="nav-list-link">Part 3: Alternative Data</a><ul class="nav-list"><li class="nav-list-item"><a href="/puffin/03-alternative-data/01-web-scraping-transcripts.html" class="nav-list-link">Web Scraping & Transcript Parsing</a></li><li class="nav-list-item"><a href="/puffin/03-alternative-data/02-alt-data-evaluation.html" class="nav-list-link">Alternative Data Evaluation</a></li></ul></li><li class="nav-list-item"><button class="nav-list-expander btn-reset" aria-label="Part 4: Alpha Factors submenu" aria-expanded="false">
        <svg viewBox="0 0 24 24" aria-hidden="true"><use xlink:href="#svg-arrow-right"></use></svg>
      </button><a href="/puffin/04-alpha-factors/" class="nav-list-link">Part 4: Alpha Factors</a><ul class="nav-list"><li class="nav-list-item"><a href="/puffin/04-alpha-factors/01-momentum-value-volatility.html" class="nav-list-link">Momentum, Value & Volatility Factors</a></li><li class="nav-list-item"><a href="/puffin/04-alpha-factors/02-kalman-wavelets.html" class="nav-list-link">Kalman Filters & Wavelets</a></li><li class="nav-list-item"><a href="/puffin/04-alpha-factors/03-factor-evaluation.html" class="nav-list-link">Factor Evaluation</a></li></ul></li><li class="nav-list-item"><button class="nav-list-expander btn-reset" aria-label="Part 5: Portfolio Optimization submenu" aria-expanded="false">
        <svg viewBox="0 0 24 24" aria-hidden="true"><use xlink:href="#svg-arrow-right"></use></svg>
      </button><a href="/puffin/05-portfolio-optimization/" class="nav-list-link">Part 5: Portfolio Optimization</a><ul class="nav-list"><li class="nav-list-item"><a href="/puffin/05-portfolio-optimization/01-mean-variance.html" class="nav-list-link">Mean-Variance Optimization</a></li><li class="nav-list-item"><a href="/puffin/05-portfolio-optimization/02-risk-parity.html" class="nav-list-link">Risk Parity</a></li><li class="nav-list-item"><a href="/puffin/05-portfolio-optimization/03-hierarchical-risk-parity.html" class="nav-list-link">Hierarchical Risk Parity</a></li></ul></li><li class="nav-list-item"><button class="nav-list-expander btn-reset" aria-label="Part 6: Trading Strategies submenu" aria-expanded="false">
        <svg viewBox="0 0 24 24" aria-hidden="true"><use xlink:href="#svg-arrow-right"></use></svg>
      </button><a href="/puffin/06-trading-strategies/" class="nav-list-link">Part 6: Trading Strategies</a><ul class="nav-list"><li class="nav-list-item"><a href="/puffin/06-trading-strategies/01-trading-strategies.html" class="nav-list-link">Trading Strategies</a></li><li class="nav-list-item"><a href="/puffin/06-trading-strategies/02-putting-it-together.html" class="nav-list-link">Putting It All Together</a></li></ul></li><li class="nav-list-item"><button class="nav-list-expander btn-reset" aria-label="Part 7: Backtesting submenu" aria-expanded="false">
        <svg viewBox="0 0 24 24" aria-hidden="true"><use xlink:href="#svg-arrow-right"></use></svg>
      </button><a href="/puffin/07-backtesting/" class="nav-list-link">Part 7: Backtesting</a><ul class="nav-list"><li class="nav-list-item"><a href="/puffin/07-backtesting/01-event-driven-engine.html" class="nav-list-link">Event-Driven Engine</a></li><li class="nav-list-item"><a href="/puffin/07-backtesting/02-execution-models.html" class="nav-list-link">Execution Models</a></li><li class="nav-list-item"><a href="/puffin/07-backtesting/03-walk-forward-analysis.html" class="nav-list-link">Walk-Forward Analysis</a></li></ul></li><li class="nav-list-item"><button class="nav-list-expander btn-reset" aria-label="Part 8: Linear Models submenu" aria-expanded="false">
        <svg viewBox="0 0 24 24" aria-hidden="true"><use xlink:href="#svg-arrow-right"></use></svg>
      </button><a href="/puffin/08-linear-models/" class="nav-list-link">Part 8: Linear Models</a><ul class="nav-list"><li class="nav-list-item"><a href="/puffin/08-linear-models/01-ols-ridge-lasso.html" class="nav-list-link">OLS, Ridge & Lasso</a></li><li class="nav-list-item"><a href="/puffin/08-linear-models/02-logistic-regression.html" class="nav-list-link">Logistic Regression</a></li><li class="nav-list-item"><a href="/puffin/08-linear-models/03-fama-french.html" class="nav-list-link">Fama-French Factor Models</a></li></ul></li><li class="nav-list-item"><button class="nav-list-expander btn-reset" aria-label="Part 9: Time Series Models submenu" aria-expanded="false">
        <svg viewBox="0 0 24 24" aria-hidden="true"><use xlink:href="#svg-arrow-right"></use></svg>
      </button><a href="/puffin/09-time-series-models/" class="nav-list-link">Part 9: Time Series Models</a><ul class="nav-list"><li class="nav-list-item"><a href="/puffin/09-time-series-models/diagnostics-stationarity/" class="nav-list-link">Diagnostics & Stationarity</a></li><li class="nav-list-item"><a href="/puffin/09-time-series-models/arima-var-garch/" class="nav-list-link">ARIMA, VAR & GARCH</a></li><li class="nav-list-item"><a href="/puffin/09-time-series-models/cointegration-pairs-trading/" class="nav-list-link">Cointegration & Pairs Trading</a></li></ul></li><li class="nav-list-item"><button class="nav-list-expander btn-reset" aria-label="Part 10: Bayesian ML submenu" aria-expanded="false">
        <svg viewBox="0 0 24 24" aria-hidden="true"><use xlink:href="#svg-arrow-right"></use></svg>
      </button><a href="/puffin/10-bayesian-ml/" class="nav-list-link">Part 10: Bayesian ML</a><ul class="nav-list"><li class="nav-list-item"><a href="/puffin/10-bayesian-ml/01-pymc-fundamentals.html" class="nav-list-link">PyMC Fundamentals</a></li><li class="nav-list-item"><a href="/puffin/10-bayesian-ml/02-bayesian-sharpe.html" class="nav-list-link">Bayesian Sharpe Ratio</a></li><li class="nav-list-item"><a href="/puffin/10-bayesian-ml/03-stochastic-volatility.html" class="nav-list-link">Stochastic Volatility</a></li></ul></li><li class="nav-list-item"><button class="nav-list-expander btn-reset" aria-label="Part 11: Tree Ensembles submenu" aria-expanded="false">
        <svg viewBox="0 0 24 24" aria-hidden="true"><use xlink:href="#svg-arrow-right"></use></svg>
      </button><a href="/puffin/11-tree-ensembles/" class="nav-list-link">Part 11: Tree Ensembles</a><ul class="nav-list"><li class="nav-list-item"><a href="/puffin/11-tree-ensembles/01-random-forests" class="nav-list-link">Random Forests</a></li><li class="nav-list-item"><a href="/puffin/11-tree-ensembles/02-gradient-boosting" class="nav-list-link">Gradient Boosting</a></li><li class="nav-list-item"><a href="/puffin/11-tree-ensembles/03-shap-interpretation" class="nav-list-link">SHAP Interpretation</a></li><li class="nav-list-item"><a href="/puffin/11-tree-ensembles/04-long-short-strategy" class="nav-list-link">Long-Short Strategy</a></li></ul></li><li class="nav-list-item"><button class="nav-list-expander btn-reset" aria-label="Part 12: Unsupervised Learning submenu" aria-expanded="false">
        <svg viewBox="0 0 24 24" aria-hidden="true"><use xlink:href="#svg-arrow-right"></use></svg>
      </button><a href="/puffin/12-unsupervised-learning/" class="nav-list-link">Part 12: Unsupervised Learning</a><ul class="nav-list"><li class="nav-list-item"><a href="/puffin/12-unsupervised-learning/01-pca-eigenportfolios.html" class="nav-list-link">PCA & Eigenportfolios</a></li><li class="nav-list-item"><a href="/puffin/12-unsupervised-learning/02-clustering-methods.html" class="nav-list-link">Clustering Methods</a></li><li class="nav-list-item"><a href="/puffin/12-unsupervised-learning/03-data-driven-risk-factors.html" class="nav-list-link">Data-Driven Risk Factors</a></li></ul></li><li class="nav-list-item"><button class="nav-list-expander btn-reset" aria-label="Part 13: NLP for Trading submenu" aria-expanded="false">
        <svg viewBox="0 0 24 24" aria-hidden="true"><use xlink:href="#svg-arrow-right"></use></svg>
      </button><a href="/puffin/13-nlp-trading/" class="nav-list-link">Part 13: NLP for Trading</a><ul class="nav-list"><li class="nav-list-item"><a href="/puffin/13-nlp-trading/01-nlp-pipeline-tokenization" class="nav-list-link">NLP Pipeline & Tokenization</a></li><li class="nav-list-item"><a href="/puffin/13-nlp-trading/02-bag-of-words-tfidf" class="nav-list-link">Bag-of-Words & TF-IDF</a></li><li class="nav-list-item"><a href="/puffin/13-nlp-trading/03-sentiment-classification" class="nav-list-link">Sentiment Classification</a></li></ul></li><li class="nav-list-item"><button class="nav-list-expander btn-reset" aria-label="Part 14: Topic Modeling submenu" aria-expanded="false">
        <svg viewBox="0 0 24 24" aria-hidden="true"><use xlink:href="#svg-arrow-right"></use></svg>
      </button><a href="/puffin/14-topic-modeling/" class="nav-list-link">Part 14: Topic Modeling</a><ul class="nav-list"><li class="nav-list-item"><a href="/puffin/14-topic-modeling/01-lsi-lda.html" class="nav-list-link">LSI & LDA</a></li><li class="nav-list-item"><a href="/puffin/14-topic-modeling/02-earnings-topic-analysis.html" class="nav-list-link">Earnings Call Topic Analysis</a></li></ul></li><li class="nav-list-item"><button class="nav-list-expander btn-reset" aria-label="Part 15: Word Embeddings submenu" aria-expanded="false">
        <svg viewBox="0 0 24 24" aria-hidden="true"><use xlink:href="#svg-arrow-right"></use></svg>
      </button><a href="/puffin/15-word-embeddings/" class="nav-list-link">Part 15: Word Embeddings</a><ul class="nav-list"><li class="nav-list-item"><a href="/puffin/15-word-embeddings/01-word2vec-glove" class="nav-list-link">Word2Vec & GloVe</a></li><li class="nav-list-item"><a href="/puffin/15-word-embeddings/02-doc2vec-sec-filings" class="nav-list-link">Doc2Vec & SEC Filings</a></li><li class="nav-list-item"><a href="/puffin/15-word-embeddings/03-transformer-embeddings" class="nav-list-link">Transformer Embeddings</a></li></ul></li><li class="nav-list-item"><button class="nav-list-expander btn-reset" aria-label="Part 16: Deep Learning Fundamentals submenu" aria-expanded="false">
        <svg viewBox="0 0 24 24" aria-hidden="true"><use xlink:href="#svg-arrow-right"></use></svg>
      </button><a href="/puffin/16-deep-learning/" class="nav-list-link">Part 16: Deep Learning Fundamentals</a><ul class="nav-list"><li class="nav-list-item"><a href="/puffin/16-deep-learning/01-feedforward-nns" class="nav-list-link">Feedforward Neural Networks</a></li><li class="nav-list-item"><a href="/puffin/16-deep-learning/02-training-utilities" class="nav-list-link">Training Utilities</a></li><li class="nav-list-item"><a href="/puffin/16-deep-learning/03-tensorboard" class="nav-list-link">TensorBoard Integration</a></li></ul></li><li class="nav-list-item"><button class="nav-list-expander btn-reset" aria-label="Part 17: CNNs for Trading submenu" aria-expanded="false">
        <svg viewBox="0 0 24 24" aria-hidden="true"><use xlink:href="#svg-arrow-right"></use></svg>
      </button><a href="/puffin/17-cnns-for-trading/" class="nav-list-link">Part 17: CNNs for Trading</a><ul class="nav-list"><li class="nav-list-item"><a href="/puffin/17-cnns-for-trading/01-1d-cnn-time-series" class="nav-list-link">1D CNNs for Time Series</a></li><li class="nav-list-item"><a href="/puffin/17-cnns-for-trading/02-cnn-ta-transfer-learning" class="nav-list-link">CNN-TA & Transfer Learning</a></li></ul></li><li class="nav-list-item"><button class="nav-list-expander btn-reset" aria-label="Part 18: RNNs for Trading submenu" aria-expanded="false">
        <svg viewBox="0 0 24 24" aria-hidden="true"><use xlink:href="#svg-arrow-right"></use></svg>
      </button><a href="/puffin/18-rnns-for-trading/" class="nav-list-link">Part 18: RNNs for Trading</a><ul class="nav-list"><li class="nav-list-item"><a href="/puffin/18-rnns-for-trading/01-lstm-fundamentals" class="nav-list-link">LSTM Fundamentals</a></li><li class="nav-list-item"><a href="/puffin/18-rnns-for-trading/02-stacked-lstm-gru" class="nav-list-link">Stacked LSTM & GRU</a></li><li class="nav-list-item"><a href="/puffin/18-rnns-for-trading/03-sentiment-rnn" class="nav-list-link">Sentiment RNN</a></li></ul></li><li class="nav-list-item"><button class="nav-list-expander btn-reset" aria-label="Part 19: Autoencoders submenu" aria-expanded="false">
        <svg viewBox="0 0 24 24" aria-hidden="true"><use xlink:href="#svg-arrow-right"></use></svg>
      </button><a href="/puffin/19-autoencoders/" class="nav-list-link">Part 19: Autoencoders</a><ul class="nav-list"><li class="nav-list-item"><a href="/puffin/19-autoencoders/01-standard-denoising.html" class="nav-list-link">Standard & Denoising Autoencoders</a></li><li class="nav-list-item"><a href="/puffin/19-autoencoders/02-variational-ae.html" class="nav-list-link">Variational Autoencoders</a></li><li class="nav-list-item"><a href="/puffin/19-autoencoders/03-conditional-ae.html" class="nav-list-link">Conditional Autoencoders for Asset Pricing</a></li></ul></li><li class="nav-list-item"><button class="nav-list-expander btn-reset" aria-label="Part 20: Synthetic Data with GANs submenu" aria-expanded="false">
        <svg viewBox="0 0 24 24" aria-hidden="true"><use xlink:href="#svg-arrow-right"></use></svg>
      </button><a href="/puffin/20-synthetic-data-gans/" class="nav-list-link">Part 20: Synthetic Data with GANs</a><ul class="nav-list"><li class="nav-list-item"><a href="/puffin/20-synthetic-data-gans/01-gan-architecture.html" class="nav-list-link">GAN Architecture Fundamentals</a></li><li class="nav-list-item"><a href="/puffin/20-synthetic-data-gans/02-timegan.html" class="nav-list-link">TimeGAN for Financial Data</a></li><li class="nav-list-item"><a href="/puffin/20-synthetic-data-gans/03-synthetic-evaluation.html" class="nav-list-link">Synthetic Data Evaluation</a></li></ul></li><li class="nav-list-item"><button class="nav-list-expander btn-reset" aria-label="Part 21: Deep Reinforcement Learning submenu" aria-expanded="false">
        <svg viewBox="0 0 24 24" aria-hidden="true"><use xlink:href="#svg-arrow-right"></use></svg>
      </button><a href="/puffin/21-deep-rl/" class="nav-list-link">Part 21: Deep Reinforcement Learning</a><ul class="nav-list"><li class="nav-list-item"><a href="/puffin/21-deep-rl/01-q-learning.html" class="nav-list-link">Q-Learning Fundamentals</a></li><li class="nav-list-item"><a href="/puffin/21-deep-rl/02-dqn-ddqn.html" class="nav-list-link">DQN & Double DQN</a></li><li class="nav-list-item"><a href="/puffin/21-deep-rl/03-ppo-trading-env.html" class="nav-list-link">PPO & Trading Environment</a></li></ul></li><li class="nav-list-item"><button class="nav-list-expander btn-reset" aria-label="Part 22: AI-Assisted Trading submenu" aria-expanded="false">
        <svg viewBox="0 0 24 24" aria-hidden="true"><use xlink:href="#svg-arrow-right"></use></svg>
      </button><a href="/puffin/22-ai-assisted-trading/" class="nav-list-link">Part 22: AI-Assisted Trading</a><ul class="nav-list"><li class="nav-list-item"><a href="/puffin/22-ai-assisted-trading/01-llm-providers.html" class="nav-list-link">LLM Providers</a></li><li class="nav-list-item"><a href="/puffin/22-ai-assisted-trading/02-sentiment-signals.html" class="nav-list-link">Sentiment & Signals</a></li><li class="nav-list-item"><a href="/puffin/22-ai-assisted-trading/03-ai-agent.html" class="nav-list-link">AI Agent Portfolio Manager</a></li></ul></li><li class="nav-list-item"><button class="nav-list-expander btn-reset" aria-label="Part 23: Live Trading submenu" aria-expanded="false">
        <svg viewBox="0 0 24 24" aria-hidden="true"><use xlink:href="#svg-arrow-right"></use></svg>
      </button><a href="/puffin/23-live-trading/" class="nav-list-link">Part 23: Live Trading</a><ul class="nav-list"><li class="nav-list-item"><a href="/puffin/23-live-trading/01-live-trading.html" class="nav-list-link">Live Trading</a></li><li class="nav-list-item"><a href="/puffin/23-live-trading/02-ibkr-advanced.html" class="nav-list-link">IBKR Advanced Trading</a></li><li class="nav-list-item"><a href="/puffin/23-live-trading/03-broker-comparison.html" class="nav-list-link">Broker Comparison</a></li></ul></li><li class="nav-list-item"><button class="nav-list-expander btn-reset" aria-label="Part 24: Risk Management submenu" aria-expanded="false">
        <svg viewBox="0 0 24 24" aria-hidden="true"><use xlink:href="#svg-arrow-right"></use></svg>
      </button><a href="/puffin/24-risk-management/" class="nav-list-link">Part 24: Risk Management</a><ul class="nav-list"><li class="nav-list-item"><a href="/puffin/24-risk-management/01-position-sizing.html" class="nav-list-link">Position Sizing</a></li><li class="nav-list-item"><a href="/puffin/24-risk-management/02-stop-losses.html" class="nav-list-link">Stop Losses</a></li><li class="nav-list-item"><a href="/puffin/24-risk-management/03-portfolio-risk-controls.html" class="nav-list-link">Portfolio Risk Controls</a></li></ul></li><li class="nav-list-item"><button class="nav-list-expander btn-reset" aria-label="Part 25: Monitoring & Analytics submenu" aria-expanded="false">
        <svg viewBox="0 0 24 24" aria-hidden="true"><use xlink:href="#svg-arrow-right"></use></svg>
      </button><a href="/puffin/25-monitoring-analytics/" class="nav-list-link">Part 25: Monitoring & Analytics</a><ul class="nav-list"><li class="nav-list-item"><a href="/puffin/25-monitoring-analytics/01-trade-logging-pnl.html" class="nav-list-link">Trade Logging & P&L</a></li><li class="nav-list-item"><a href="/puffin/25-monitoring-analytics/02-benchmark-comparison.html" class="nav-list-link">Benchmark Comparison</a></li><li class="nav-list-item"><a href="/puffin/25-monitoring-analytics/03-streamlit-dashboard.html" class="nav-list-link">Streamlit Dashboard</a></li></ul></li><li class="nav-list-item"><button class="nav-list-expander btn-reset" aria-label="Part 26: Real-Time Market Data submenu" aria-expanded="false">
        <svg viewBox="0 0 24 24" aria-hidden="true"><use xlink:href="#svg-arrow-right"></use></svg>
      </button><a href="/puffin/26-realtime-data/" class="nav-list-link">Part 26: Real-Time Market Data</a><ul class="nav-list"><li class="nav-list-item"><a href="/puffin/26-realtime-data/01-websocket-fundamentals.html" class="nav-list-link">WebSocket Fundamentals</a></li><li class="nav-list-item"><a href="/puffin/26-realtime-data/02-realtime-engine.html" class="nav-list-link">Real-Time Engine</a></li><li class="nav-list-item"><a href="/puffin/26-realtime-data/03-orderbook-streaming.html" class="nav-list-link">Order Book Streaming</a></li></ul></li></ul>
  
</nav>


<div class="d-md-block d-none site-footer">
  
  
    This site uses <a href="https://github.com/just-the-docs/just-the-docs">Just the Docs</a>, a documentation theme for Jekyll.
  
  </div>
</header>

  
  <div class="main" id="top">
    <div id="main-header" class="main-header">
  
    

<div class="search" role="search">
  <div class="search-input-wrap">
    <input type="text" id="search-input" class="search-input" tabindex="0" placeholder="Search Puffin - Algorithmic Trading Guide" autocomplete="off">
    <label for="search-input" class="search-label">
      <span class="sr-only">Search Puffin - Algorithmic Trading Guide</span>
      <svg viewBox="0 0 24 24" class="search-icon" aria-hidden="true"><use xlink:href="#svg-search"></use></svg>
    </label>
  </div>
  <div id="search-results" class="search-results"></div>
</div>

  
  
  
    <nav aria-label="Auxiliary" class="aux-nav">
  <ul class="aux-nav-list">
    
      <li class="aux-nav-list-item">
        <a href="https://github.com/MichaelTien8901/puffin" class="site-button"
          
          target="_blank" rel="noopener noreferrer"
          
        >
          Puffin GitHub
        </a>
      </li>
    
  </ul>
</nav>

  
</div>

    <div class="main-content-wrap">
      
      <div id="main-content" class="main-content">
        <main>
          
            <h.site-nav ul li a {
  background-image: linear-gradient(-90deg, rgb(31.6333333333, 30.8222222222, 34.8777777778) 0%, rgba(31.6333333333, 30.8222222222, 34.8777777778, 0.8) 80%, rgba(31.6333333333, 30.8222222222, 34.8777777778, 0) 100%);
}

          

          
            
          
        </main>
        
<hr>
<footer>
  
    <p><a href="#top" id="back-to-top">Back to top</a></p>
  

  




  <div class="d-md-none mt-4 fs-2">
    
    
      This site uses <a href="https://github.com/just-the-docs/just-the-docs">Just the Docs</a>, a documentation theme for Jekyll.
    
  </div>
</footer>

      </div>
    </div>
    
      

<div class="search-overlay"></div>

    
  </div>

  
    





<script type="module">
  
  import mermaid from 'https://cdn.jsdelivr.net/npm/mermaid@10.6.0/dist/mermaid.esm.min.mjs';
  

  var config = // Mermaid configuration with soft light background
mermaid.initialize({
  startOnLoad: true,
  theme: 'base',
  securityLevel: 'loose',
  themeVariables: {
    // Paper-like background (warm, unlit paper tone)
    background: '#d5d0c8',
    mainBkg: '#ccc7bf',

    // Primary colors - muted blue
    primaryColor: '#5a9bd5',
    primaryTextColor: '#2c3e50',
    primaryBorderColor: '#4a89c0',

    // Secondary colors - muted green
    secondaryColor: '#7ec88b',
    secondaryTextColor: '#2c3e50',
    secondaryBorderColor: '#5fb06f',

    // Tertiary colors - muted purple
    tertiaryColor: '#b08ed0',
    tertiaryTextColor: '#2c3e50',
    tertiaryBorderColor: '#9575b5',

    // Lines - dark gray for good contrast
    lineColor: '#4a5568',

    // Node backgrounds - paper tones
    nodeBkg: '#c5c0b8',
    nodeTextColor: '#2c3e50',
    nodeBorder: '#8a8578',

    // Text - dark gray (not pure black)
    textColor: '#2c3e50',

    // Clusters
    clusterBkg: '#cac5bd',
    clusterBorder: '#8a8578',

    // Notes - slightly warmer
    noteBkgColor: '#ddd8c8',
    noteTextColor: '#2c3e50',
    noteBorderColor: '#a89878',

    // Sequence diagram
    actorBkg: '#c5c0b8',
    actorBorder: '#8a8578',
    actorTextColor: '#2c3e50',
    actorLineColor: '#4a5568',
    signalColor: '#4a5568',
    signalTextColor: '#2c3e50',
    labelTextColor: '#2c3e50',

    // Edge labels
    edgeLabelBackground: '#d5d0c8',

    // Gantt
    sectionBkgColor: '#dde4ed',
    altSectionBkgColor: '#e8ebef',
    gridColor: '#b8c4d0',
    todayLineColor: '#e05252',
    critBkgColor: '#f8d7da',
    critBorderColor: '#dc3545',
    doneBkgColor: '#d4edda',
    doneBorderColor: '#28a745',

    // Git graph
    git0: '#5a9bd5',
    git1: '#7ec88b',
    git2: '#e05252',
    git3: '#f0ad4e'
  },
  flowchart: {
    useMaxWidth: true,
    htmlLabels: true,
    curve: 'basis',
    diagramPadding: 8
  },
  sequence: {
    diagramMarginX: 50,
    diagramMarginY: 10,
    actorMargin: 50,
    width: 150,
    height: 65,
    boxMargin: 10,
    boxTextMargin: 5,
    noteMargin: 10,
    messageMargin: 35
  },
  gantt: {
    titleTopMargin: 25,
    barHeight: 20,
    barGap: 4,
    topPadding: 50
  }
});
;
  mermaid.initialize(config);
  mermaid.run({
    querySelector: '.language-mermaid',
  });
</script>



  
</body>
</html>

