

<!DOCTYPE html>
<!--[if IE 8]><html class="no-js lt-ie9" lang="en" > <![endif]-->
<!--[if gt IE 8]><!--> <html class="no-js" lang="en" > <!--<![endif]-->
<head>
  <meta charset="utf-8">
  
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  
  <title>Utilities &mdash; BIVW: Deep Heteroscedastic Regression using Privileged Information 2020 documentation</title>
  

  
  
  
  

  
  <script type="text/javascript" src="../_static/js/modernizr.min.js"></script>
  
    
      <script type="text/javascript">
          var DOCUMENTATION_OPTIONS = {
              URL_ROOT:'../',
              VERSION:'2020',
              LANGUAGE:'None',
              COLLAPSE_INDEX:false,
              FILE_SUFFIX:'.html',
              HAS_SOURCE:  true,
              SOURCELINK_SUFFIX: '.txt'
          };
      </script>
        <script type="text/javascript" src="../_static/jquery.js"></script>
        <script type="text/javascript" src="../_static/underscore.js"></script>
        <script type="text/javascript" src="../_static/doctools.js"></script>
        <script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.1/MathJax.js?config=TeX-AMS-MML_HTMLorMML"></script>
    
    <script type="text/javascript" src="../_static/js/theme.js"></script>

    

  
  <link rel="stylesheet" href="../_static/css/theme.css" type="text/css" />
  <link rel="stylesheet" href="../_static/pygments.css" type="text/css" />
    <link rel="index" title="Index" href="../genindex.html" />
    <link rel="search" title="Search" href="../search.html" />
    <link rel="next" title="Settings" href="params.html" />
    <link rel="prev" title="Trainer" href="train.html" />
    <link href="../_static/style.css" rel="stylesheet" type="text/css">

</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"> BIVW: Deep Heteroscedastic Regression using Privileged Information
          

          
          </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" />
    <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="main navigation">
          
            
            
              
            
            
              <p class="caption"><span class="caption-text">Contents:</span></p>
<ul class="current">
<li class="toctree-l1"><a class="reference internal" href="getting_started.html">Introduction</a></li>
<li class="toctree-l1"><a class="reference internal" href="arguments.html">Commandline Options</a></li>
<li class="toctree-l1"><a class="reference internal" href="utkf_dataloader.html">Dataloaders: UTKFace</a></li>
<li class="toctree-l1"><a class="reference internal" href="bike_dataloader.html">Dataloaders: Bike Sharing</a></li>
<li class="toctree-l1"><a class="reference internal" href="wine_dataloader.html">Dataloaders: Wine Quality</a></li>
<li class="toctree-l1"><a class="reference internal" href="model_ann_wine.html">Models: Wine Quality</a></li>
<li class="toctree-l1"><a class="reference internal" href="model_ann_bike.html">Models: Bike Sharing</a></li>
<li class="toctree-l1"><a class="reference internal" href="model_cnn_utkf.html">Models: UTKFace</a></li>
<li class="toctree-l1"><a class="reference internal" href="cutoff_loss.html">Losses: Cutoff MSE</a></li>
<li class="toctree-l1"><a class="reference internal" href="biv_loss.html">Losses: Batch Inverse Variance (BIV)</a></li>
<li class="toctree-l1"><a class="reference internal" href="train.html">Trainer</a></li>
<li class="toctree-l1 current"><a class="current reference internal" href="#">Utilities</a></li>
<li class="toctree-l1"><a class="reference internal" href="params.html">Settings</a></li>
</ul>

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

    <section data-toggle="wy-nav-shift" class="wy-nav-content-wrap">

      
      <nav class="wy-nav-top" aria-label="top navigation">
        
          <i data-toggle="wy-nav-top" class="fa fa-bars"></i>
          <a href="../index.html">BIVW: Deep Heteroscedastic Regression using Privileged Information</a>
        
      </nav>


      <div class="wy-nav-content">
        
        <div class="rst-content">
        
          















<div role="navigation" aria-label="breadcrumbs navigation">

  <ul class="wy-breadcrumbs">
    
      <li><a href="../index.html">Docs</a> &raquo;</li>
        
      <li>Utilities</li>
    
    
      <li class="wy-breadcrumbs-aside">
        
            
            <a href="../_sources/pages/utils.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">
            
  <div class="section" id="utilities">
<h1>Utilities<a class="headerlink" href="#utilities" title="Permalink to this headline">¶</a></h1>
<dl class="function">
<dt id="utils.get_unif_Vmax">
<code class="descclassname">utils.</code><code class="descname">get_unif_Vmax</code><span class="sig-paren">(</span><em>mu</em><span class="sig-paren">)</span><a class="headerlink" href="#utils.get_unif_Vmax" title="Permalink to this definition">¶</a></dt>
<dd><dl class="docutils">
<dt>Description:</dt>
<dd>Estimates the maximum variance needed for the uniform distribution to produce maximum heteroscedasticity.</dd>
<dt>Return:</dt>
<dd><table class="first last docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">vmax:</th><td class="field-body">the maximum uniform variance.</td>
</tr>
</tbody>
</table>
</dd>
<dt>Return type:</dt>
<dd>float</dd>
<dt>Args:</dt>
<dd><table class="first last docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">mu:</th><td class="field-body">mean of the the uniform.</td>
</tr>
<tr class="field-even field"><th class="field-name" colspan="2">scale_value [optional]:</th></tr>
<tr class="field-even field"><td>&#160;</td><td class="field-body">controls scaling the Vmax to different values.</td>
</tr>
</tbody>
</table>
</dd>
</dl>
<p>Here is the formula for estimating <span class="math notranslate nohighlight">\(V_{max}\)</span></p>
<div class="math notranslate nohighlight">
\[V_{max} = \frac{4 \mu^2}{12}\]</div>
</dd></dl>

<dl class="function">
<dt id="utils.normalize_labels">
<code class="descclassname">utils.</code><code class="descname">normalize_labels</code><span class="sig-paren">(</span><em>labels</em>, <em>labels_mean</em>, <em>labels_std</em><span class="sig-paren">)</span><a class="headerlink" href="#utils.normalize_labels" title="Permalink to this definition">¶</a></dt>
<dd><dl class="docutils">
<dt>Description:</dt>
<dd>Normalize the training labels as follow:</dd>
</dl>
<div class="math notranslate nohighlight">
\[\widetilde{y} = \frac{(y - \overline{y})} {\sigma_y}.\]</div>
<p>where</p>
<div class="math notranslate nohighlight">
\[\widetilde{y} = \text{Normalized labels, } 
y = \text{labels, }
\overline{y} = \text{Mean of the labels, }.
\sigma = \text{Standard deviation of the labels}\]</div>
<dl class="docutils">
<dt>Return:</dt>
<dd><table class="first last docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">labels_norm:</th><td class="field-body">Normalized labels.</td>
</tr>
</tbody>
</table>
</dd>
<dt>Return type:</dt>
<dd>1D Tensor.</dd>
<dt>Args:</dt>
<dd><table class="first last docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">labels:</th><td class="field-body">Training labels.</td>
</tr>
<tr class="field-even field"><th class="field-name">labels_mean:</th><td class="field-body">Emprical mean of the training labels .</td>
</tr>
<tr class="field-odd field"><th class="field-name">labels_std:</th><td class="field-body">Emprical standard deviation of the training labels.</td>
</tr>
</tbody>
</table>
</dd>
</dl>
</dd></dl>

<dl class="function">
<dt id="utils.normalize_features">
<code class="descclassname">utils.</code><code class="descname">normalize_features</code><span class="sig-paren">(</span><em>features</em>, <em>features_mean</em>, <em>features_std</em>, <em>dataset='UTKFace'</em><span class="sig-paren">)</span><a class="headerlink" href="#utils.normalize_features" title="Permalink to this definition">¶</a></dt>
<dd><dl class="docutils">
<dt>Description:</dt>
<dd>Normalize the training input features as follows:</dd>
</dl>
<div class="math notranslate nohighlight">
\[\widetilde{X} = \frac{(X - \overline{X})} {\sigma_x}.\]</div>
<p>where</p>
<div class="math notranslate nohighlight">
\[\widetilde{X} = \text{Normalized features, } 
X = \text{Input features, }
\overline{X} = \text{Features mean, }.
\sigma = \text{Features standard deviation}\]</div>
<dl class="docutils">
<dt>Return:</dt>
<dd><table class="first last docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">images_norm:</th><td class="field-body">Normalized Features.</td>
</tr>
</tbody>
</table>
</dd>
<dt>Return type:</dt>
<dd>NxD Tensor</dd>
<dt>Args:</dt>
<dd><table class="first last docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">features:</th><td class="field-body">train data. (images)</td>
</tr>
<tr class="field-even field"><th class="field-name">features_mean:</th><td class="field-body">Mean of the features.</td>
</tr>
<tr class="field-odd field"><th class="field-name">features_std:</th><td class="field-body">Standard deviation of the features.</td>
</tr>
<tr class="field-even field"><th class="field-name">dataset:</th><td class="field-body">Name of the dataset that needs to be normalized.</td>
</tr>
</tbody>
</table>
</dd>
</dl>
</dd></dl>

<dl class="function">
<dt id="utils.str_to_bool">
<code class="descclassname">utils.</code><code class="descname">str_to_bool</code><span class="sig-paren">(</span><em>string</em><span class="sig-paren">)</span><a class="headerlink" href="#utils.str_to_bool" title="Permalink to this definition">¶</a></dt>
<dd><dl class="docutils">
<dt>Description:</dt>
<dd>Convert a string to a boolean.</dd>
<dt>Return:</dt>
<dd>True or False.</dd>
<dt>Return type:</dt>
<dd>boolean</dd>
<dt>Args:</dt>
<dd><table class="first last docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">string:</th><td class="field-body">A string to be converted.</td>
</tr>
</tbody>
</table>
</dd>
</dl>
</dd></dl>

<dl class="function">
<dt id="utils.generate_intervals">
<code class="descclassname">utils.</code><code class="descname">generate_intervals</code><span class="sig-paren">(</span><em>num_dists</em>, <em>p=0.5</em><span class="sig-paren">)</span><a class="headerlink" href="#utils.generate_intervals" title="Permalink to this definition">¶</a></dt>
<dd><dl class="docutils">
<dt>Description:</dt>
<dd>Generates intervals for sampling noise variance distributions. The intervals are low, which assigns low sampling probablity values, and high, that assigns high values.</dd>
<dt>Return:</dt>
<dd>intervals</dd>
<dt>Return type:</dt>
<dd>Dictionary</dd>
<dt>Args:</dt>
<dd><table class="first last docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">num_dists:</th><td class="field-body">Number of distributions that need to have sampling intervals.</td>
</tr>
<tr class="field-even field"><th class="field-name">p:</th><td class="field-body">Interval balance factor.It controls the balance between low and high intervals.</td>
</tr>
</tbody>
</table>
</dd>
</dl>
</dd></dl>

<dl class="function">
<dt id="utils.choose_distribution">
<code class="descclassname">utils.</code><code class="descname">choose_distribution</code><span class="sig-paren">(</span><em>intervals</em><span class="sig-paren">)</span><a class="headerlink" href="#utils.choose_distribution" title="Permalink to this definition">¶</a></dt>
<dd><dl class="docutils">
<dt>Description:</dt>
<dd>Chooses a distribution based on sampling from the intervals.</dd>
<dt>Return:</dt>
<dd>key, (an id for the sampled distribution)</dd>
<dt>Return type:</dt>
<dd>int</dd>
<dt>Args:</dt>
<dd><table class="first last docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">intervals:</th><td class="field-body">A dictionary of tuple values, each tuple represents an interval that is compared against when the sampling happens.</td>
</tr>
<tr class="field-even field"><th class="field-name">p:</th><td class="field-body">Interval balance factor.It controls the balance between low and high intervals.</td>
</tr>
</tbody>
</table>
</dd>
</dl>
</dd></dl>

<dl class="function">
<dt id="utils.get_mean_avg_variance">
<code class="descclassname">utils.</code><code class="descname">get_mean_avg_variance</code><span class="sig-paren">(</span><em>noise_type</em>, <em>avg_variance_m</em>, <em>mu1</em>, <em>p</em><span class="sig-paren">)</span><a class="headerlink" href="#utils.get_mean_avg_variance" title="Permalink to this definition">¶</a></dt>
<dd><dl class="docutils">
<dt>Description:</dt>
<dd>Estimates the value of the mean of the second distribution, in a bi-model distribution, based on the average noise varaince mean.</dd>
<dt>Return:</dt>
<dd>mu2</dd>
<dt>Return type:</dt>
<dd>float</dd>
<dt>Args:</dt>
<dd><table class="first last docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">noise_type:</th><td class="field-body">Noise type.</td>
</tr>
<tr class="field-even field"><th class="field-name">avg_variance_m:</th><td class="field-body">The average of means of the noise variance distributions.</td>
</tr>
<tr class="field-odd field"><th class="field-name">mu1:</th><td class="field-body">First distribution’s mean.</td>
</tr>
<tr class="field-even field"><th class="field-name">p:</th><td class="field-body">Distributions ratio.</td>
</tr>
</tbody>
</table>
</dd>
</dl>
</dd></dl>

<dl class="function">
<dt id="utils.print_experiment_information">
<code class="descclassname">utils.</code><code class="descname">print_experiment_information</code><span class="sig-paren">(</span><em>args</em><span class="sig-paren">)</span><a class="headerlink" href="#utils.print_experiment_information" title="Permalink to this definition">¶</a></dt>
<dd><dl class="docutils">
<dt>Description:</dt>
<dd><p class="first">Print experiment information, which consists of :</p>
<blockquote class="last">
<div><ol class="arabic simple">
<li>Dataset information.</li>
<li>Models informations.</li>
<li>Commandline options information.</li>
</ol>
</div></blockquote>
</dd>
<dt>Return:</dt>
<dd>None</dd>
<dt>Return type:</dt>
<dd>None</dd>
<dt>Args:</dt>
<dd><table class="first last docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">args:</th><td class="field-body">Commandline options.</td>
</tr>
</tbody>
</table>
</dd>
</dl>
</dd></dl>

<dl class="function">
<dt id="utils.filter_batch">
<code class="descclassname">utils.</code><code class="descname">filter_batch</code><span class="sig-paren">(</span><em>predictions</em>, <em>labels</em>, <em>noise_var</em>, <em>threshold = 0.4</em><span class="sig-paren">)</span><a class="headerlink" href="#utils.filter_batch" title="Permalink to this definition">¶</a></dt>
<dd><dl class="docutils">
<dt>Description:</dt>
<dd>Filters a batch of labels based on a noise varaince threshold.</dd>
<dt>Return:</dt>
<dd>filtered predictions, filtered labels , filtered noise_variance</dd>
<dt>Return type:</dt>
<dd>Tuple</dd>
<dt>Args:</dt>
<dd><table class="first last docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">predictions:</th><td class="field-body">model’s predictions.</td>
</tr>
<tr class="field-even field"><th class="field-name">labels:</th><td class="field-body">Noisy labels.</td>
</tr>
<tr class="field-odd field"><th class="field-name">noise_var:</th><td class="field-body">noises variances</td>
</tr>
<tr class="field-even field"><th class="field-name">threshold:</th><td class="field-body">noise variance threshold.</td>
</tr>
</tbody>
</table>
</dd>
</dl>
</dd></dl>

<dl class="function">
<dt id="utils.assert_args_mixture">
<code class="descclassname">utils.</code><code class="descname">assert_args_mixture</code><span class="sig-paren">(</span><em>args</em><span class="sig-paren">)</span><a class="headerlink" href="#utils.assert_args_mixture" title="Permalink to this definition">¶</a></dt>
<dd><dl class="docutils">
<dt>Description:</dt>
<dd>Check the validaty of the combination of two or more arguments.</dd>
<dt>Return:</dt>
<dd>None</dd>
<dt>Return type:</dt>
<dd>None</dd>
<dt>Args:</dt>
<dd><table class="first last docutils field-list" frame="void" rules="none">
<col class="field-name" />
<col class="field-body" />
<tbody valign="top">
<tr class="field-odd field"><th class="field-name">args:</th><td class="field-body">Arguments that need to be checked.</td>
</tr>
</tbody>
</table>
</dd>
</dl>
</dd></dl>

</div>


           </div>
           
          </div>
          <footer>
  
    <div class="rst-footer-buttons" role="navigation" aria-label="footer navigation">
      
        <a href="params.html" class="btn btn-neutral float-right" title="Settings" accesskey="n" rel="next">Next <span class="fa fa-arrow-circle-right"></span></a>
      
      
        <a href="train.html" class="btn btn-neutral float-left" title="Trainer" accesskey="p" rel="prev"><span class="fa fa-arrow-circle-left"></span> Previous</a>
      
    </div>
  

  <hr/>

  <div role="contentinfo">
    <p>
        &copy; Copyright 2020, Vincent Mai, Waleed Khamies, Liam Paull

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

</footer>

        </div>
      </div>

    </section>

  </div>
  


  <script type="text/javascript">
      jQuery(function () {
          SphinxRtdTheme.Navigation.enable(true);
      });
  </script>

  
  
    
   

</body>
</html>