<!DOCTYPE html>
<html class="writer-html5" lang="en" data-content_root="../">
<head>
  <meta charset="utf-8" /><meta name="viewport" content="width=device-width, initial-scale=1" />

  <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  <title>Quick start &mdash; EBES  documentation</title>
      <link rel="stylesheet" type="text/css" href="../_static/pygments.css?v=80d5e7a1" />
      <link rel="stylesheet" type="text/css" href="../_static/css/theme.css?v=19f00094" />

  
  <!--[if lt IE 9]>
    <script src="../_static/js/html5shiv.min.js"></script>
  <![endif]-->
  
        <script src="../_static/jquery.js?v=5d32c60e"></script>
        <script src="../_static/_sphinx_javascript_frameworks_compat.js?v=2cd50e6c"></script>
        <script src="../_static/documentation_options.js?v=5929fcd5"></script>
        <script src="../_static/doctools.js?v=9a2dae69"></script>
        <script src="../_static/sphinx_highlight.js?v=dc90522c"></script>
    <script src="../_static/js/theme.js"></script>
    <link rel="index" title="Index" href="../genindex.html" />
    <link rel="search" title="Search" href="../search.html" />
    <link rel="next" title="Library design overview" href="../user_guide/design.html" />
    <link rel="prev" title="Installation" href="install.html" /> 
</head>

<body class="wy-body-for-nav"> 
  <div class="wy-grid-for-nav">
    <nav data-toggle="wy-nav-shift" class="wy-nav-side">
      <div class="wy-side-scroll">
        <div class="wy-side-nav-search" >

          
          
          <a href="../index.html" class="icon icon-home">
            EBES
          </a>
<div role="search">
  <form id="rtd-search-form" class="wy-form" action="../search.html" method="get">
    <input type="text" name="q" placeholder="Search docs" aria-label="Search docs" />
    <input type="hidden" name="check_keywords" value="yes" />
    <input type="hidden" name="area" value="default" />
  </form>
</div>
        </div><div class="wy-menu wy-menu-vertical" data-spy="affix" role="navigation" aria-label="Navigation menu">
              <p class="caption" role="heading"><span class="caption-text">Getting Started</span></p>
<ul class="current">
<li class="toctree-l1"><a class="reference internal" href="install.html"> Installation</a></li>
<li class="toctree-l1 current"><a class="current reference internal" href="#"> Quick start</a></li>
</ul>
<p class="caption" role="heading"><span class="caption-text">User Guide</span></p>
<ul>
<li class="toctree-l1"><a class="reference internal" href="../user_guide/design.html"> Benchmark design</a></li>
<li class="toctree-l1"><a class="reference internal" href="../user_guide/data_format.html"> Data format used</a></li>
<li class="toctree-l1"><a class="reference internal" href="../user_guide/configs.html"> Configuration files format</a></li>
</ul>
<p class="caption" role="heading"><span class="caption-text">API Reference</span></p>
<ul>
<li class="toctree-l1"><a class="reference internal" href="../reference/modules.html"> Modules</a></li>
</ul>

        </div>
      </div>
    </nav>

    <section data-toggle="wy-nav-shift" class="wy-nav-content-wrap"><nav class="wy-nav-top" aria-label="Mobile navigation menu" >
          <i data-toggle="wy-nav-top" class="fa fa-bars"></i>
          <a href="../index.html">EBES</a>
      </nav>

      <div class="wy-nav-content">
        <div class="rst-content">
          <div role="navigation" aria-label="Page navigation">
  <ul class="wy-breadcrumbs">
      <li><a href="../index.html" class="icon icon-home" aria-label="Home"></a></li>
      <li class="breadcrumb-item active">Quick start</li>
      <li class="wy-breadcrumbs-aside">
            <a href="../_sources/get_started/quick_start.rst.txt" rel="nofollow"> View page source</a>
      </li>
  </ul>
  <hr/>
</div>
          <div role="main" class="document" itemscope="itemscope" itemtype="http://schema.org/Article">
           <div itemprop="articleBody">
             
  <section id="quick-start">
<h1>Quick start<a class="headerlink" href="#quick-start" title="Link to this heading"></a></h1>
<ol class="arabic">
<li><p>Clone the repo and proceed to the root:</p>
<div class="highlight-bash notranslate"><div class="highlight"><pre><span></span>git<span class="w"> </span>clone<span class="w"> </span>https://github.com/########/EBES.git
<span class="nb">cd</span><span class="w"> </span>EBES
</pre></div>
</div>
</li>
<li><p>Download the data.
For example, for X5 Retail Hero dataset, first go to the <a class="reference external" href="https://ods.ai/competitions/x5-retailhero-uplift-modeling/data">data page</a> and download teh archive.
Assuming the archive is downloaded <code class="docutils literal notranslate"><span class="pre">to</span> <span class="pre">EBES/data/x5-retail/retailhero-uplift.zip</span></code> then:</p>
<div class="highlight-bash notranslate"><div class="highlight"><pre><span></span><span class="nb">cd</span><span class="w"> </span>data/x5-retail
unzip<span class="w"> </span>retailhero-uplift.zip<span class="w">  </span><span class="c1"># will create data subfolder with CSV-files</span>
mkdir<span class="w"> </span>preprocessed<span class="w">  </span><span class="c1"># data in EBES format will be stored here</span>
mkdir<span class="w"> </span>preprocessed/cat_codes<span class="w">  </span><span class="c1"># categorical features are encoded into numbers, here will be the mapping</span>
</pre></div>
</div>
</li>
<li><p>Build Docker image and run it:</p>
<div class="highlight-bash notranslate"><div class="highlight"><pre><span></span>docker<span class="w"> </span>build<span class="w"> </span>-t<span class="w"> </span>ebes<span class="w"> </span>.
docker<span class="w"> </span>run<span class="w"> </span>--gpu<span class="w"> </span>all<span class="w"> </span>--ipc<span class="w"> </span>host<span class="w"> </span>-v<span class="w"> </span>/path/to/EBES:/workspace<span class="w"> </span>ebes<span class="w"> </span>bash
</pre></div>
</div>
</li>
<li><p>Save the dataset in the EBES format.
Starting from now everything should be run inside a docker container.</p>
<blockquote>
<div><div class="highlight-bash notranslate"><div class="highlight"><pre><span></span><span class="nb">cd</span><span class="w"> </span>/workspace
python<span class="w"> </span>preprocess/x5-retail.py<span class="w"> </span><span class="se">\</span>
<span class="w">    </span>--data-path<span class="w"> </span>data/x5-retail/data<span class="w"> </span><span class="se">\</span>
<span class="w">    </span>--save-path<span class="w"> </span>data/x5-retail/preprocessed<span class="w"> </span><span class="se">\</span>
<span class="w">    </span>--cat-codes-path<span class="w"> </span>data/x5-retail/preprocessed/cat_codes
</pre></div>
</div>
</div></blockquote>
</li>
<li><p>Run experiment.
The majority of experiment configuration is done using YAML config files.
They are located in <code class="docutils literal notranslate"><span class="pre">configs</span></code> folder in the repository.
To run an experiment you shout choose the dataset on which to run the experiment, the method to benchmark (e.g. vanilla GRU, CoLES, mTAND, etc.), the experiment type (e.g. perform single test run, or launch HPO, etc).
You can also deside to patch default config with the best found hyper-parameters for the particular method on the particular dataset.
These patches are located in <code class="docutils literal notranslate"><span class="pre">configs/specify/{dataset}/{method}/best.yaml</span></code>.
For example, to train the best (according to out HPO results) GRU, run from the repository root:</p>
<blockquote>
<div><div class="highlight-bash notranslate"><div class="highlight"><pre><span></span>python<span class="w"> </span>main.py<span class="w"> </span><span class="se">\</span>
<span class="w">    </span>-d<span class="w"> </span>x5-retail<span class="w">  </span><span class="sb">`</span><span class="c1"># dataset config` \</span>
<span class="w">    </span>-m<span class="w"> </span>gru<span class="w">        </span><span class="sb">`</span><span class="c1"># method config` \</span>
<span class="w">    </span>-e<span class="w"> </span><span class="nb">test</span><span class="w">       </span><span class="sb">`</span><span class="c1"># experiment config, test for simple single train and test` \</span>
<span class="w">    </span>-s<span class="w"> </span>best<span class="w">       </span><span class="sb">`</span><span class="c1"># pick the best config found for gru and x5-retail specifically` \</span>
<span class="w">    </span>-g<span class="w"> </span><span class="s1">&#39;cuda:1&#39;</span><span class="w">   </span><span class="sb">`</span><span class="c1"># run on gpu 1` \</span>
<span class="w">    </span>--tqdm<span class="w">        </span><span class="sb">`</span><span class="c1"># enable train loop progress`</span>
</pre></div>
</div>
</div></blockquote>
<p>During train the folder <code class="docutils literal notranslate"><span class="pre">log/{dataset}/{method}/{experiment}</span></code> is created with logs, checkpoints and evaluation results.</p>
<p>Available experiments (<code class="docutils literal notranslate"><span class="pre">-e</span></code> option) are:</p>
<ul class="simple">
<li><p><code class="docutils literal notranslate"><span class="pre">test</span></code> — perform a single run.</p></li>
<li><p><code class="docutils literal notranslate"><span class="pre">correlation</span></code> — perform multiple runs in parallel with different random seeds.</p></li>
<li><p><code class="docutils literal notranslate"><span class="pre">optuna</span></code> — perform HPO.
You can parallelize optuna search by launching parallel scripts.
In this case they will share the same storage (see <a class="reference external" href="https://optuna.readthedocs.io/en/stable/tutorial/10_key_features/004_distributed.html">optuna docs</a>).</p></li>
</ul>
</li>
<li><p>Analyze results. The notebook with logs analysis is located at <code class="docutils literal notranslate"><span class="pre">notebooks/collect_results.ipynb</span></code>.</p></li>
</ol>
</section>


           </div>
          </div>
          <footer><div class="rst-footer-buttons" role="navigation" aria-label="Footer">
        <a href="install.html" class="btn btn-neutral float-left" title="Installation" accesskey="p" rel="prev"><span class="fa fa-arrow-circle-left" aria-hidden="true"></span> Previous</a>
        <a href="../user_guide/design.html" class="btn btn-neutral float-right" title="Library design overview" accesskey="n" rel="next">Next <span class="fa fa-arrow-circle-right" aria-hidden="true"></span></a>
    </div>

  <hr/>

  <div role="contentinfo">
    <p>&#169; Copyright 2024, Anonymized.</p>
  </div>

  Built with <a href="https://www.sphinx-doc.org/">Sphinx</a> using a
    <a href="https://github.com/readthedocs/sphinx_rtd_theme">theme</a>
    provided by <a href="https://readthedocs.org">Read the Docs</a>.
   

</footer>
        </div>
      </div>
    </section>
  </div>
  <script>
      jQuery(function () {
          SphinxRtdTheme.Navigation.enable(true);
      });
  </script> 

</body>
</html>