<!doctype html>
<html lang="en">
  <head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>Cradicle Explorer</title>
    <link href="/css/bootstrap/bootstrap.min.css" rel="stylesheet">
    <style>
      .form-control-dark::placeholder {
          color: #aaa;
          opacity: 1;
      }
    </style>
    <link rel="stylesheet" href="/assets/fontawesome/css/all.min.css">
    <link rel="icon" type="image/png" href="/favicon.png">


                <link href="/css/dashboard.css" rel="stylesheet">
                </head>
                <body>
                <header class="navbar navbar-dark sticky-top bg-dark flex-md-nowrap p-0 shadow">
                  <a class="navbar-brand col-md-3 col-lg-2 me-0 px-3 fs-6" href="/">Cradicle Explorer</a>
                  <button class="navbar-toggler position-absolute d-md-none collapsed" type="button" data-bs-toggle="collapse" data-bs-target="#sidebarMenu" aria-controls="sidebarMenu" aria-expanded="false" aria-label="Toggle navigation">
                    <span class="navbar-toggler-icon"></span>
                  </button>
                  <form method="get" action="/cgi-bin/main" style="width:100%;"><input class="form-control form-control-dark w-100 rounded-0 border-0" type="text" name="q" placeholder="Search repos" aria-label="Search"></form>
                  <div class="navbar-nav flex-row">
                    <div class="nav-item text-nowrap">
                      <a class="nav-link px-3 active" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn">ai-llm-frameworks-haystack</a>
                    </div>
                  </div>
                </header>
                <div class="container-fluid">
                  <div class="row">
                    <nav id="sidebarMenu" class="col-md-3 col-lg-2 d-md-block bg-dark sidebar collapse">
                      <div class="position-sticky pt-3 sidebar-sticky">
                        <ul class="nav flex-column">
                          <li class="nav-item">
                            <a class="nav-link" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn">
                              <i class="align-text-bottom fa-solid fa-info"></i>
                              Info
                            </a>
                          </li>
                          <li class="nav-item">
                            <a class="nav-link" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&issue=list">
                              <i class="align-text-bottom fa-solid fa-layer-group"></i>
                              Issues
                            </a>
                          </li>
                          <li class="nav-item">
                            <a class="nav-link" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&patch=list">
                              <i class="align-text-bottom fa-solid fa-vest-patches"></i>
                              Patches
                            </a>
                          </li>
                          <li class="nav-item">
                            <a class="nav-link" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&wallet=list">
                              <i class="align-text-bottom fa-solid fa-wallet"></i>
                              Wallets
                            </a>
                          </li>
                          <li class="nav-item">
                            <a class="nav-link active" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=.">
                              <i class="align-text-bottom fa-solid fa-code"></i>
                              Source
                            </a>
                          </li>
                        <h6 class="sidebar-heading d-flex justify-content-between align-items-center px-3 mt-4 mb-1 text-muted text-uppercase">
                          <span></span>
                        </h6>
                        <ul class="nav flex-column mb-2">
                        
    <h6 class="sidebar-heading d-flex justify-content-between align-items-center px-3 mt-1 mb-1 text-muted text-uppercase">
      <span>Source</span>
    </h6>
    <li><a class="nav-link py-0" style="padding-left:16px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=.github"><i class="fa-solid fa-folder" style="color:#f0c040;"></i> .github</a></li><li><a class="nav-link py-0" style="padding-left:16px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=docker"><i class="fa-solid fa-folder" style="color:#f0c040;"></i> docker</a></li><li><a class="nav-link py-0" style="padding-left:16px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=docs-website"><i class="fa-solid fa-folder-open" style="color:#f0c040;"></i> docs-website</a></li><li><a class="nav-link py-0" style="padding-left:32px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=docs-website%2Fapi"><i class="fa-solid fa-folder" style="color:#f0c040;"></i> api</a></li><li><a class="nav-link py-0" style="padding-left:32px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=docs-website%2Fdocs"><i class="fa-solid fa-folder" style="color:#f0c040;"></i> docs</a></li><li><a class="nav-link py-0" style="padding-left:32px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=docs-website%2Fplugins"><i class="fa-solid fa-folder" style="color:#f0c040;"></i> plugins</a></li><li><a class="nav-link py-0" style="padding-left:32px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=docs-website%2Freference"><i class="fa-solid fa-folder" style="color:#f0c040;"></i> reference</a></li><li><a class="nav-link py-0" style="padding-left:32px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=docs-website%2Freference_versioned_docs"><i class="fa-solid fa-folder-open" style="color:#f0c040;"></i> reference_versioned_docs</a></li><li><a class="nav-link py-0" style="padding-left:48px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=docs-website%2Freference_versioned_docs%2Fversion-2.18"><i class="fa-solid fa-folder" style="color:#f0c040;"></i> version-2.18</a></li><li><a class="nav-link py-0" style="padding-left:48px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=docs-website%2Freference_versioned_docs%2Fversion-2.19"><i class="fa-solid fa-folder" style="color:#f0c040;"></i> version-2.19</a></li><li><a class="nav-link py-0" style="padding-left:48px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=docs-website%2Freference_versioned_docs%2Fversion-2.20"><i class="fa-solid fa-folder" style="color:#f0c040;"></i> version-2.20</a></li><li><a class="nav-link py-0" style="padding-left:48px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=docs-website%2Freference_versioned_docs%2Fversion-2.21"><i class="fa-solid fa-folder" style="color:#f0c040;"></i> version-2.21</a></li><li><a class="nav-link py-0" style="padding-left:48px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=docs-website%2Freference_versioned_docs%2Fversion-2.22"><i class="fa-solid fa-folder" style="color:#f0c040;"></i> version-2.22</a></li><li><a class="nav-link py-0" style="padding-left:48px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=docs-website%2Freference_versioned_docs%2Fversion-2.23"><i class="fa-solid fa-folder" style="color:#f0c040;"></i> version-2.23</a></li><li><a class="nav-link py-0" style="padding-left:48px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=docs-website%2Freference_versioned_docs%2Fversion-2.24"><i class="fa-solid fa-folder" style="color:#f0c040;"></i> version-2.24</a></li><li><a class="nav-link py-0" style="padding-left:48px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=docs-website%2Freference_versioned_docs%2Fversion-2.25"><i class="fa-solid fa-folder" style="color:#f0c040;"></i> version-2.25</a></li><li><a class="nav-link py-0" style="padding-left:48px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=docs-website%2Freference_versioned_docs%2Fversion-2.26"><i class="fa-solid fa-folder" style="color:#f0c040;"></i> version-2.26</a></li><li><a class="nav-link py-0" style="padding-left:48px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=docs-website%2Freference_versioned_docs%2Fversion-2.27"><i class="fa-solid fa-folder" style="color:#f0c040;"></i> version-2.27</a></li><li><a class="nav-link py-0" style="padding-left:48px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=docs-website%2Freference_versioned_docs%2Fversion-2.28"><i class="fa-solid fa-folder-open" style="color:#f0c040;"></i> version-2.28</a></li><li><a class="nav-link py-0" style="padding-left:64px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fexperiments-api"><i class="fa-solid fa-folder" style="color:#f0c040;"></i> experiments-api</a></li><li><a class="nav-link py-0" style="padding-left:64px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api"><i class="fa-solid fa-folder-open" style="color:#f0c040;"></i> haystack-api</a></li><li><a class="nav-link py-0" style="padding-left:80px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api%2Fagents_api.md"><i class="fa-solid fa-file" style="color:#888;"></i> agents_api.md</a></li><li><a class="nav-link py-0" style="padding-left:80px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api%2Faudio_api.md"><i class="fa-solid fa-file" style="color:#888;"></i> audio_api.md</a></li><li><a class="nav-link py-0" style="padding-left:80px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api%2Fbuilders_api.md"><i class="fa-solid fa-file" style="color:#888;"></i> builders_api.md</a></li><li><a class="nav-link py-0" style="padding-left:80px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api%2Fcachings_api.md"><i class="fa-solid fa-file" style="color:#888;"></i> cachings_api.md</a></li><li><a class="nav-link py-0" style="padding-left:80px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api%2Fclassifiers_api.md"><i class="fa-solid fa-file" style="color:#888;"></i> classifiers_api.md</a></li><li><a class="nav-link py-0" style="padding-left:80px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api%2Fconnectors_api.md"><i class="fa-solid fa-file" style="color:#888;"></i> connectors_api.md</a></li><li><a class="nav-link py-0" style="padding-left:80px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api%2Fconverters_api.md"><i class="fa-solid fa-file" style="color:#888;"></i> converters_api.md</a></li><li><a class="nav-link py-0" style="padding-left:80px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api%2Fdata_classes_api.md"><i class="fa-solid fa-file" style="color:#888;"></i> data_classes_api.md</a></li><li><a class="nav-link py-0" style="padding-left:80px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api%2Fdocument_stores_api.md"><i class="fa-solid fa-file" style="color:#888;"></i> document_stores_api.md</a></li><li><a class="nav-link py-0" style="padding-left:80px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api%2Fdocument_writers_api.md"><i class="fa-solid fa-file" style="color:#888;"></i> document_writers_api.md</a></li><li><a class="nav-link py-0" style="padding-left:80px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api%2Fembedders_api.md"><i class="fa-solid fa-file" style="color:#888;"></i> embedders_api.md</a></li><li><a class="nav-link py-0" style="padding-left:80px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api%2Fevaluation_api.md"><i class="fa-solid fa-file" style="color:#888;"></i> evaluation_api.md</a></li><li><a class="nav-link py-0" style="padding-left:80px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api%2Fevaluators_api.md"><i class="fa-solid fa-file" style="color:#888;"></i> evaluators_api.md</a></li><li><a class="nav-link py-0" style="padding-left:80px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api%2Fextractors_api.md"><i class="fa-solid fa-file" style="color:#888;"></i> extractors_api.md</a></li><li><a class="nav-link py-0" style="padding-left:80px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api%2Ffetchers_api.md"><i class="fa-solid fa-file" style="color:#888;"></i> fetchers_api.md</a></li><li><a class="nav-link py-0" style="padding-left:80px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api%2Fgenerators_api.md"><i class="fa-solid fa-file" style="color:#888;"></i> generators_api.md</a></li><li><a class="nav-link py-0" style="padding-left:80px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api%2Fhuman_in_the_loop_api.md"><i class="fa-solid fa-file" style="color:#888;"></i> human_in_the_loop_api.md</a></li><li><a class="nav-link py-0" style="padding-left:80px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api%2Fimage_converters_api.md"><i class="fa-solid fa-file" style="color:#888;"></i> image_converters_api.md</a></li><li><a class="nav-link py-0" style="padding-left:80px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api%2Fjoiners_api.md"><i class="fa-solid fa-file" style="color:#888;"></i> joiners_api.md</a></li><li><a class="nav-link py-0" style="padding-left:80px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api%2Fpipeline_api.md"><i class="fa-solid fa-file" style="color:#888;"></i> pipeline_api.md</a></li><li><a class="nav-link py-0" style="padding-left:80px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api%2Fpreprocessors_api.md"><i class="fa-solid fa-file" style="color:#888;"></i> preprocessors_api.md</a></li><li><a class="nav-link py-0 active" style="padding-left:80px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api%2Fquery_api.md"><i class="fa-solid fa-file" style="color:#888;"></i> query_api.md</a></li><li><a class="nav-link py-0" style="padding-left:80px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api%2Frankers_api.md"><i class="fa-solid fa-file" style="color:#888;"></i> rankers_api.md</a></li><li><a class="nav-link py-0" style="padding-left:80px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api%2Freaders_api.md"><i class="fa-solid fa-file" style="color:#888;"></i> readers_api.md</a></li><li><a class="nav-link py-0" style="padding-left:80px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api%2Fretrievers_api.md"><i class="fa-solid fa-file" style="color:#888;"></i> retrievers_api.md</a></li><li><a class="nav-link py-0" style="padding-left:80px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api%2Frouters_api.md"><i class="fa-solid fa-file" style="color:#888;"></i> routers_api.md</a></li><li><a class="nav-link py-0" style="padding-left:80px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api%2Fsamplers_api.md"><i class="fa-solid fa-file" style="color:#888;"></i> samplers_api.md</a></li><li><a class="nav-link py-0" style="padding-left:80px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api%2Ftool_components_api.md"><i class="fa-solid fa-file" style="color:#888;"></i> tool_components_api.md</a></li><li><a class="nav-link py-0" style="padding-left:80px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api%2Ftools_api.md"><i class="fa-solid fa-file" style="color:#888;"></i> tools_api.md</a></li><li><a class="nav-link py-0" style="padding-left:80px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api%2Futils_api.md"><i class="fa-solid fa-file" style="color:#888;"></i> utils_api.md</a></li><li><a class="nav-link py-0" style="padding-left:80px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api%2Fvalidators_api.md"><i class="fa-solid fa-file" style="color:#888;"></i> validators_api.md</a></li><li><a class="nav-link py-0" style="padding-left:80px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api%2Fwebsearch_api.md"><i class="fa-solid fa-file" style="color:#888;"></i> websearch_api.md</a></li><li><a class="nav-link py-0" style="padding-left:64px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fintegrations-api"><i class="fa-solid fa-folder" style="color:#f0c040;"></i> integrations-api</a></li><li><a class="nav-link py-0" style="padding-left:64px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Findex.mdx"><i class="fa-solid fa-file" style="color:#888;"></i> index.mdx</a></li><li><a class="nav-link py-0" style="padding-left:32px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=docs-website%2Freference_versioned_sidebars"><i class="fa-solid fa-folder" style="color:#f0c040;"></i> reference_versioned_sidebars</a></li><li><a class="nav-link py-0" style="padding-left:32px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=docs-website%2Fscripts"><i class="fa-solid fa-folder" style="color:#f0c040;"></i> scripts</a></li><li><a class="nav-link py-0" style="padding-left:32px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=docs-website%2Fsrc"><i class="fa-solid fa-folder" style="color:#f0c040;"></i> src</a></li><li><a class="nav-link py-0" style="padding-left:32px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=docs-website%2Fstatic"><i class="fa-solid fa-folder" style="color:#f0c040;"></i> static</a></li><li><a class="nav-link py-0" style="padding-left:32px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=docs-website%2Fversioned_docs"><i class="fa-solid fa-folder" style="color:#f0c040;"></i> versioned_docs</a></li><li><a class="nav-link py-0" style="padding-left:32px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=docs-website%2Fversioned_sidebars"><i class="fa-solid fa-folder" style="color:#f0c040;"></i> versioned_sidebars</a></li><li><a class="nav-link py-0" style="padding-left:32px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2F.gitattributes"><i class="fa-solid fa-file" style="color:#888;"></i> .gitattributes</a></li><li><a class="nav-link py-0" style="padding-left:32px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2F.gitignore"><i class="fa-solid fa-file" style="color:#888;"></i> .gitignore</a></li><li><a class="nav-link py-0" style="padding-left:32px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2FCONTRIBUTING.md"><i class="fa-solid fa-file" style="color:#888;"></i> CONTRIBUTING.md</a></li><li><a class="nav-link py-0" style="padding-left:32px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2FREADME.md"><i class="fa-solid fa-file" style="color:#888;"></i> README.md</a></li><li><a class="nav-link py-0" style="padding-left:32px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Fdocusaurus.config.js"><i class="fa-solid fa-file" style="color:#888;"></i> docusaurus.config.js</a></li><li><a class="nav-link py-0" style="padding-left:32px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Fpackage.json"><i class="fa-solid fa-file" style="color:#888;"></i> package.json</a></li><li><a class="nav-link py-0" style="padding-left:32px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference-sidebars.js"><i class="fa-solid fa-file" style="color:#888;"></i> reference-sidebars.js</a></li><li><a class="nav-link py-0" style="padding-left:32px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Freference_versions.json"><i class="fa-solid fa-file" style="color:#888;"></i> reference_versions.json</a></li><li><a class="nav-link py-0" style="padding-left:32px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Fsidebars.js"><i class="fa-solid fa-file" style="color:#888;"></i> sidebars.js</a></li><li><a class="nav-link py-0" style="padding-left:32px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Fvercel.json"><i class="fa-solid fa-file" style="color:#888;"></i> vercel.json</a></li><li><a class="nav-link py-0" style="padding-left:32px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=docs-website%2Fversions.json"><i class="fa-solid fa-file" style="color:#888;"></i> versions.json</a></li><li><a class="nav-link py-0" style="padding-left:16px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=e2e"><i class="fa-solid fa-folder" style="color:#f0c040;"></i> e2e</a></li><li><a class="nav-link py-0" style="padding-left:16px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=examples"><i class="fa-solid fa-folder" style="color:#f0c040;"></i> examples</a></li><li><a class="nav-link py-0" style="padding-left:16px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=haystack"><i class="fa-solid fa-folder" style="color:#f0c040;"></i> haystack</a></li><li><a class="nav-link py-0" style="padding-left:16px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=images"><i class="fa-solid fa-folder" style="color:#f0c040;"></i> images</a></li><li><a class="nav-link py-0" style="padding-left:16px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=pydoc"><i class="fa-solid fa-folder" style="color:#f0c040;"></i> pydoc</a></li><li><a class="nav-link py-0" style="padding-left:16px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=releasenotes"><i class="fa-solid fa-folder" style="color:#f0c040;"></i> releasenotes</a></li><li><a class="nav-link py-0" style="padding-left:16px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=scripts"><i class="fa-solid fa-folder" style="color:#f0c040;"></i> scripts</a></li><li><a class="nav-link py-0" style="padding-left:16px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=test"><i class="fa-solid fa-folder" style="color:#f0c040;"></i> test</a></li><li><a class="nav-link py-0" style="padding-left:16px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=.gitignore"><i class="fa-solid fa-file" style="color:#888;"></i> .gitignore</a></li><li><a class="nav-link py-0" style="padding-left:16px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=.pre-commit-config.yaml"><i class="fa-solid fa-file" style="color:#888;"></i> .pre-commit-config.yaml</a></li><li><a class="nav-link py-0" style="padding-left:16px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=AGENTS.md"><i class="fa-solid fa-file" style="color:#888;"></i> AGENTS.md</a></li><li><a class="nav-link py-0" style="padding-left:16px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=CITATION.cff"><i class="fa-solid fa-file" style="color:#888;"></i> CITATION.cff</a></li><li><a class="nav-link py-0" style="padding-left:16px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=CLAUDE.md"><i class="fa-solid fa-file" style="color:#888;"></i> CLAUDE.md</a></li><li><a class="nav-link py-0" style="padding-left:16px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=CONTRIBUTING.md"><i class="fa-solid fa-file" style="color:#888;"></i> CONTRIBUTING.md</a></li><li><a class="nav-link py-0" style="padding-left:16px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=LICENSE"><i class="fa-solid fa-file" style="color:#888;"></i> LICENSE</a></li><li><a class="nav-link py-0" style="padding-left:16px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=README.md"><i class="fa-solid fa-file" style="color:#888;"></i> README.md</a></li><li><a class="nav-link py-0" style="padding-left:16px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=SECURITY.md"><i class="fa-solid fa-file" style="color:#888;"></i> SECURITY.md</a></li><li><a class="nav-link py-0" style="padding-left:16px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=VERSION.txt"><i class="fa-solid fa-file" style="color:#888;"></i> VERSION.txt</a></li><li><a class="nav-link py-0" style="padding-left:16px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=code_of_conduct.txt"><i class="fa-solid fa-file" style="color:#888;"></i> code_of_conduct.txt</a></li><li><a class="nav-link py-0" style="padding-left:16px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=license-header.txt"><i class="fa-solid fa-file" style="color:#888;"></i> license-header.txt</a></li><li><a class="nav-link py-0" style="padding-left:16px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=licenserc.toml"><i class="fa-solid fa-file" style="color:#888;"></i> licenserc.toml</a></li><li><a class="nav-link py-0" style="padding-left:16px;" href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&file=pyproject.toml"><i class="fa-solid fa-file" style="color:#888;"></i> pyproject.toml</a></li>
    
                        </ul>
                      </div>
                    </nav>
                <main class="col-md-9 ms-sm-auto col-lg-10">
                  <div class="container px-1 py-3">
        
<div class="mb-2" style="font-size:1.1rem;"><a href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=.">/</a> <a href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=docs-website">docs-website</a> / <a href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=docs-website%2Freference_versioned_docs">reference_versioned_docs</a> / <a href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=docs-website%2Freference_versioned_docs%2Fversion-2.28">version-2.28</a> / <a href="/cgi-bin/repo?id=zTi14k6zGh5QJwhnY6uZk3xfNTvn&source=docs-website%2Freference_versioned_docs%2Fversion-2.28%2Fhaystack-api">haystack-api</a> / query_api.md</div>
        <div class="list-group">
        <div class="list-group-item">
        <div class="mb-2" style="font-weight:bold;"><i class="fa-solid fa-file"></i> query_api.md</div>
        <pre style="margin:0; font-size:0.85rem; overflow-x:auto; color:#fafafa;"><span style="color:#666; user-select:none;">  1</span>  ---
<span style="color:#666; user-select:none;">  2</span>  title: &quot;Query&quot;
<span style="color:#666; user-select:none;">  3</span>  id: query-api
<span style="color:#666; user-select:none;">  4</span>  description: &quot;Components for query processing and expansion.&quot;
<span style="color:#666; user-select:none;">  5</span>  slug: &quot;/query-api&quot;
<span style="color:#666; user-select:none;">  6</span>  ---
<span style="color:#666; user-select:none;">  7</span>  
<span style="color:#666; user-select:none;">  8</span>  
<span style="color:#666; user-select:none;">  9</span>  ## query_expander
<span style="color:#666; user-select:none;"> 10</span>  
<span style="color:#666; user-select:none;"> 11</span>  ### QueryExpander
<span style="color:#666; user-select:none;"> 12</span>  
<span style="color:#666; user-select:none;"> 13</span>  A component that returns a list of semantically similar queries to improve retrieval recall in RAG systems.
<span style="color:#666; user-select:none;"> 14</span>  
<span style="color:#666; user-select:none;"> 15</span>  The component uses a chat generator to expand queries. The chat generator is expected to return a JSON response
<span style="color:#666; user-select:none;"> 16</span>  with the following structure:
<span style="color:#666; user-select:none;"> 17</span>  
<span style="color:#666; user-select:none;"> 18</span>  ```json
<span style="color:#666; user-select:none;"> 19</span>  {&quot;queries&quot;: [&quot;expanded query 1&quot;, &quot;expanded query 2&quot;, &quot;expanded query 3&quot;]}
<span style="color:#666; user-select:none;"> 20</span>  ```
<span style="color:#666; user-select:none;"> 21</span>  
<span style="color:#666; user-select:none;"> 22</span>  ### Usage example
<span style="color:#666; user-select:none;"> 23</span>  
<span style="color:#666; user-select:none;"> 24</span>  ```python
<span style="color:#666; user-select:none;"> 25</span>  from haystack.components.generators.chat.openai import OpenAIChatGenerator
<span style="color:#666; user-select:none;"> 26</span>  from haystack.components.query import QueryExpander
<span style="color:#666; user-select:none;"> 27</span>  
<span style="color:#666; user-select:none;"> 28</span>  expander = QueryExpander(
<span style="color:#666; user-select:none;"> 29</span>      chat_generator=OpenAIChatGenerator(model=&quot;gpt-4.1-mini&quot;),
<span style="color:#666; user-select:none;"> 30</span>      n_expansions=3
<span style="color:#666; user-select:none;"> 31</span>  )
<span style="color:#666; user-select:none;"> 32</span>  
<span style="color:#666; user-select:none;"> 33</span>  result = expander.run(query=&quot;green energy sources&quot;)
<span style="color:#666; user-select:none;"> 34</span>  print(result[&quot;queries&quot;])
<span style="color:#666; user-select:none;"> 35</span>  # Output: [&#x27;alternative query 1&#x27;, &#x27;alternative query 2&#x27;, &#x27;alternative query 3&#x27;, &#x27;green energy sources&#x27;]
<span style="color:#666; user-select:none;"> 36</span>  # Note: Up to 3 additional queries + 1 original query (if include_original_query=True)
<span style="color:#666; user-select:none;"> 37</span>  
<span style="color:#666; user-select:none;"> 38</span>  # To control total number of queries:
<span style="color:#666; user-select:none;"> 39</span>  expander = QueryExpander(n_expansions=2, include_original_query=True)  # Up to 3 total
<span style="color:#666; user-select:none;"> 40</span>  # or
<span style="color:#666; user-select:none;"> 41</span>  expander = QueryExpander(n_expansions=3, include_original_query=False)  # Exactly 3 total
<span style="color:#666; user-select:none;"> 42</span>  ```
<span style="color:#666; user-select:none;"> 43</span>  
<span style="color:#666; user-select:none;"> 44</span>  #### __init__
<span style="color:#666; user-select:none;"> 45</span>  
<span style="color:#666; user-select:none;"> 46</span>  ```python
<span style="color:#666; user-select:none;"> 47</span>  __init__(
<span style="color:#666; user-select:none;"> 48</span>      *,
<span style="color:#666; user-select:none;"> 49</span>      chat_generator: ChatGenerator | None = None,
<span style="color:#666; user-select:none;"> 50</span>      prompt_template: str | None = None,
<span style="color:#666; user-select:none;"> 51</span>      n_expansions: int = 4,
<span style="color:#666; user-select:none;"> 52</span>      include_original_query: bool = True
<span style="color:#666; user-select:none;"> 53</span>  ) -&gt; None
<span style="color:#666; user-select:none;"> 54</span>  ```
<span style="color:#666; user-select:none;"> 55</span>  
<span style="color:#666; user-select:none;"> 56</span>  Initialize the QueryExpander component.
<span style="color:#666; user-select:none;"> 57</span>  
<span style="color:#666; user-select:none;"> 58</span>  **Parameters:**
<span style="color:#666; user-select:none;"> 59</span>  
<span style="color:#666; user-select:none;"> 60</span>  - **chat_generator** (&lt;code&gt;ChatGenerator | None&lt;/code&gt;) – The chat generator component to use for query expansion.
<span style="color:#666; user-select:none;"> 61</span>    If None, a default OpenAIChatGenerator with gpt-4.1-mini model is used.
<span style="color:#666; user-select:none;"> 62</span>  - **prompt_template** (&lt;code&gt;str | None&lt;/code&gt;) – Custom [PromptBuilder](https://docs.haystack.deepset.ai/docs/promptbuilder)
<span style="color:#666; user-select:none;"> 63</span>    template for query expansion. The template should instruct the LLM to return a JSON response with the
<span style="color:#666; user-select:none;"> 64</span>    structure: `{&quot;queries&quot;: [&quot;query1&quot;, &quot;query2&quot;, &quot;query3&quot;]}`. The template should include &#x27;query&#x27; and
<span style="color:#666; user-select:none;"> 65</span>    &#x27;n_expansions&#x27; variables.
<span style="color:#666; user-select:none;"> 66</span>  - **n_expansions** (&lt;code&gt;int&lt;/code&gt;) – Number of alternative queries to generate (default: 4).
<span style="color:#666; user-select:none;"> 67</span>  - **include_original_query** (&lt;code&gt;bool&lt;/code&gt;) – Whether to include the original query in the output.
<span style="color:#666; user-select:none;"> 68</span>  
<span style="color:#666; user-select:none;"> 69</span>  #### to_dict
<span style="color:#666; user-select:none;"> 70</span>  
<span style="color:#666; user-select:none;"> 71</span>  ```python
<span style="color:#666; user-select:none;"> 72</span>  to_dict() -&gt; dict[str, Any]
<span style="color:#666; user-select:none;"> 73</span>  ```
<span style="color:#666; user-select:none;"> 74</span>  
<span style="color:#666; user-select:none;"> 75</span>  Serializes the component to a dictionary.
<span style="color:#666; user-select:none;"> 76</span>  
<span style="color:#666; user-select:none;"> 77</span>  **Returns:**
<span style="color:#666; user-select:none;"> 78</span>  
<span style="color:#666; user-select:none;"> 79</span>  - &lt;code&gt;dict\[str, Any\]&lt;/code&gt; – Dictionary with serialized data.
<span style="color:#666; user-select:none;"> 80</span>  
<span style="color:#666; user-select:none;"> 81</span>  #### from_dict
<span style="color:#666; user-select:none;"> 82</span>  
<span style="color:#666; user-select:none;"> 83</span>  ```python
<span style="color:#666; user-select:none;"> 84</span>  from_dict(data: dict[str, Any]) -&gt; QueryExpander
<span style="color:#666; user-select:none;"> 85</span>  ```
<span style="color:#666; user-select:none;"> 86</span>  
<span style="color:#666; user-select:none;"> 87</span>  Deserializes the component from a dictionary.
<span style="color:#666; user-select:none;"> 88</span>  
<span style="color:#666; user-select:none;"> 89</span>  **Parameters:**
<span style="color:#666; user-select:none;"> 90</span>  
<span style="color:#666; user-select:none;"> 91</span>  - **data** (&lt;code&gt;dict\[str, Any\]&lt;/code&gt;) – Dictionary with serialized data.
<span style="color:#666; user-select:none;"> 92</span>  
<span style="color:#666; user-select:none;"> 93</span>  **Returns:**
<span style="color:#666; user-select:none;"> 94</span>  
<span style="color:#666; user-select:none;"> 95</span>  - &lt;code&gt;QueryExpander&lt;/code&gt; – Deserialized component.
<span style="color:#666; user-select:none;"> 96</span>  
<span style="color:#666; user-select:none;"> 97</span>  #### run
<span style="color:#666; user-select:none;"> 98</span>  
<span style="color:#666; user-select:none;"> 99</span>  ```python
<span style="color:#666; user-select:none;">100</span>  run(query: str, n_expansions: int | None = None) -&gt; dict[str, list[str]]
<span style="color:#666; user-select:none;">101</span>  ```
<span style="color:#666; user-select:none;">102</span>  
<span style="color:#666; user-select:none;">103</span>  Expand the input query into multiple semantically similar queries.
<span style="color:#666; user-select:none;">104</span>  
<span style="color:#666; user-select:none;">105</span>  The language of the original query is preserved in the expanded queries.
<span style="color:#666; user-select:none;">106</span>  
<span style="color:#666; user-select:none;">107</span>  **Parameters:**
<span style="color:#666; user-select:none;">108</span>  
<span style="color:#666; user-select:none;">109</span>  - **query** (&lt;code&gt;str&lt;/code&gt;) – The original query to expand.
<span style="color:#666; user-select:none;">110</span>  - **n_expansions** (&lt;code&gt;int | None&lt;/code&gt;) – Number of additional queries to generate (not including the original).
<span style="color:#666; user-select:none;">111</span>    If None, uses the value from initialization. Can be 0 to generate no additional queries.
<span style="color:#666; user-select:none;">112</span>  
<span style="color:#666; user-select:none;">113</span>  **Returns:**
<span style="color:#666; user-select:none;">114</span>  
<span style="color:#666; user-select:none;">115</span>  - &lt;code&gt;dict\[str, list\[str\]\]&lt;/code&gt; – Dictionary with &quot;queries&quot; key containing the list of expanded queries.
<span style="color:#666; user-select:none;">116</span>    If include_original_query=True, the original query will be included in addition
<span style="color:#666; user-select:none;">117</span>    to the n_expansions alternative queries.
<span style="color:#666; user-select:none;">118</span>  
<span style="color:#666; user-select:none;">119</span>  **Raises:**
<span style="color:#666; user-select:none;">120</span>  
<span style="color:#666; user-select:none;">121</span>  - &lt;code&gt;ValueError&lt;/code&gt; – If n_expansions is not positive (less than or equal to 0).
<span style="color:#666; user-select:none;">122</span>  
<span style="color:#666; user-select:none;">123</span>  #### warm_up
<span style="color:#666; user-select:none;">124</span>  
<span style="color:#666; user-select:none;">125</span>  ```python
<span style="color:#666; user-select:none;">126</span>  warm_up() -&gt; None
<span style="color:#666; user-select:none;">127</span>  ```
<span style="color:#666; user-select:none;">128</span>  
<span style="color:#666; user-select:none;">129</span>  Warm up the LLM provider component.
</pre>
        </div>
        </div>

</div>
</main>
</div>
</div>


</body>
</html>

