<!DOCTYPE html>

<html xmlns="http://www.w3.org/1999/xhtml">
  <head>
    <meta charset="utf-8" />
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
    <meta http-equiv="x-ua-compatible" content="ie=edge">
    <style>
        .dropdown {
        position: relative;
        display: inline-block;
    }

    .dropdown-content {
        display: none;
        position: absolute;
        background-color: #f9f9f9;
        min-width: 160px;
        box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2);
        padding: 12px 16px;
        z-index: 1;
        text-align: left;
    }

    .dropdown:hover .dropdown-content {
        display: block;
    }

    .dropdown-option:hover {
        color: #FF4500 !important;
    }

    .dropdown-option-active {
        color: #FF4500;
        font-weight: lighter;
    }

    .dropdown-option {
        color: #000000;
        font-weight: lighter;
    }

    .dropdown-header {
        color: #FFFFFF;
        display: inline-flex;
    }

    .dropdown-caret {
        width: 18px;
    }

    .dropdown-caret-path {
        fill: #FFFFFF;
    }
    </style>
    
    <title>mxnet.test_utils &#8212; Apache MXNet  documentation</title>

    <link rel="stylesheet" href="../../../_static/basic.css" type="text/css" />
    <link rel="stylesheet" href="../../../_static/pygments.css" type="text/css" />
    <link rel="stylesheet" type="text/css" href="../../../_static/mxnet.css" />
    <link rel="stylesheet" href="../../../_static/material-design-lite-1.3.0/material.blue-deep_orange.min.css" type="text/css" />
    <link rel="stylesheet" href="../../../_static/sphinx_materialdesign_theme.css" type="text/css" />
    <link rel="stylesheet" href="../../../_static/fontawesome/all.css" type="text/css" />
    <link rel="stylesheet" href="../../../_static/fonts.css" type="text/css" />
    <script id="documentation_options" data-url_root="../../../" src="../../../_static/documentation_options.js"></script>
    <script src="../../../_static/jquery.js"></script>
    <script src="../../../_static/underscore.js"></script>
    <script src="../../../_static/doctools.js"></script>
    <script src="../../../_static/language_data.js"></script>
    <script src="../../../_static/google_analytics.js"></script>
    <script src="../../../_static/autodoc.js"></script>
    <script crossorigin="anonymous" integrity="sha256-Ae2Vz/4ePdIu6ZyI/5ZGsYnb+m0JlOmKPjt6XZ9JJkA=" src="https://cdnjs.cloudflare.com/ajax/libs/require.js/2.3.4/require.min.js"></script>
    <script async="async" src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/latest.js?config=TeX-AMS-MML_HTMLorMML"></script>
    <script type="text/x-mathjax-config">MathJax.Hub.Config({"tex2jax": {"inlineMath": [["$", "$"], ["\\(", "\\)"]], "processEscapes": true, "ignoreClass": "document", "processClass": "math|output_area"}})</script>
    <link rel="shortcut icon" href="../../../_static/mxnet-icon.png"/>
    <link rel="index" title="Index" href="../../../genindex.html" />
    <link rel="search" title="Search" href="../../../search.html" />
    <link rel="next" title="mxnet.torch" href="../torch/index.html" />
    <link rel="prev" title="mxnet.rtc" href="../rtc/index.html" /> 
  </head>
<body><header class="site-header" role="banner">
  <div class="wrapper">
      <a class="site-title" rel="author" href="/versions/1.6/"><img
            src="../../../_static/mxnet_logo.png" class="site-header-logo"></a>
    <nav class="site-nav">
      <input type="checkbox" id="nav-trigger" class="nav-trigger"/>
      <label for="nav-trigger">
          <span class="menu-icon">
            <svg viewBox="0 0 18 15" width="18px" height="15px">
              <path d="M18,1.484c0,0.82-0.665,1.484-1.484,1.484H1.484C0.665,2.969,0,2.304,0,1.484l0,0C0,0.665,0.665,0,1.484,0 h15.032C17.335,0,18,0.665,18,1.484L18,1.484z M18,7.516C18,8.335,17.335,9,16.516,9H1.484C0.665,9,0,8.335,0,7.516l0,0 c0-0.82,0.665-1.484,1.484-1.484h15.032C17.335,6.031,18,6.696,18,7.516L18,7.516z M18,13.516C18,14.335,17.335,15,16.516,15H1.484 C0.665,15,0,14.335,0,13.516l0,0c0-0.82,0.665-1.483,1.484-1.483h15.032C17.335,12.031,18,12.695,18,13.516L18,13.516z"/>
            </svg>
          </span>
      </label>

      <div class="trigger">
        <a class="page-link" href="/versions/1.6/get_started">Get Started</a>
        <a class="page-link" href="/versions/1.6/blog">Blog</a>
        <a class="page-link" href="/versions/1.6/features">Features</a>
        <a class="page-link" href="/versions/1.6/ecosystem">Ecosystem</a>
        <a class="page-link page-current" href="/versions/1.6/api">Docs & Tutorials</a>
        <a class="page-link" href="https://github.com/apache/incubator-mxnet">GitHub</a>
        <div class="dropdown">
          <span class="dropdown-header">1.6
            <svg class="dropdown-caret" viewBox="0 0 32 32" class="icon icon-caret-bottom" aria-hidden="true"><path class="dropdown-caret-path" d="M24 11.305l-7.997 11.39L8 11.305z"></path></svg>
          </span>
          <div class="dropdown-content">
            <a class="dropdown-option" href="/">master</a><br>
            <a class="dropdown-option" href="/versions/1.7/">1.7</a><br>
            <a class="dropdown-option-active" href="/versions/1.6/">1.6</a><br>
            <a class="dropdown-option" href="/versions/1.5.0/">1.5.0</a><br>
            <a class="dropdown-option" href="/versions/1.4.1/">1.4.1</a><br>
            <a class="dropdown-option" href="/versions/1.3.1/">1.3.1</a><br>
            <a class="dropdown-option" href="/versions/1.2.1/">1.2.1</a><br>
            <a class="dropdown-option" href="/versions/1.1.0/">1.1.0</a><br>
            <a class="dropdown-option" href="/versions/1.0.0/">1.0.0</a><br>
            <a class="dropdown-option" href="/versions/0.12.1/">0.12.1</a><br>
            <a class="dropdown-option" href="/versions/0.11.0/">0.11.0</a>
          </div>
        </div>
      </div>
    </nav>
  </div>
</header>
    <div class="mdl-layout mdl-js-layout mdl-layout--fixed-header mdl-layout--fixed-drawer"><header class="mdl-layout__header mdl-layout__header--waterfall ">
    <div class="mdl-layout__header-row">
        
        <nav class="mdl-navigation breadcrumb">
            <a class="mdl-navigation__link" href="../../index.html">Python API</a><i class="material-icons">navigate_next</i>
            <a class="mdl-navigation__link" href="../index.html">mxnet</a><i class="material-icons">navigate_next</i>
            <a class="mdl-navigation__link is-active">mxnet.test_utils</a>
        </nav>
        <div class="mdl-layout-spacer"></div>
        <nav class="mdl-navigation">
        
<form class="form-inline pull-sm-right" action="../../../search.html" method="get">
      <div class="mdl-textfield mdl-js-textfield mdl-textfield--expandable mdl-textfield--floating-label mdl-textfield--align-right">
        <label id="quick-search-icon" class="mdl-button mdl-js-button mdl-button--icon"  for="waterfall-exp">
          <i class="material-icons">search</i>
        </label>
        <div class="mdl-textfield__expandable-holder">
          <input class="mdl-textfield__input" type="text" name="q"  id="waterfall-exp" placeholder="Search" />
          <input type="hidden" name="check_keywords" value="yes" />
          <input type="hidden" name="area" value="default" />
        </div>
      </div>
      <div class="mdl-tooltip" data-mdl-for="quick-search-icon">
      Quick search
      </div>
</form>
        
<a id="button-show-source"
    class="mdl-button mdl-js-button mdl-button--icon"
    href="../../../_sources/api/mxnet/test_utils/index.rst" rel="nofollow">
  <i class="material-icons">code</i>
</a>
<div class="mdl-tooltip" data-mdl-for="button-show-source">
Show Source
</div>
        </nav>
    </div>
    <div class="mdl-layout__header-row header-links">
      <div class="mdl-layout-spacer"></div>
      <nav class="mdl-navigation">
      </nav>
    </div>
</header><header class="mdl-layout__drawer">      
    
      <div class="globaltoc">
        <span class="mdl-layout-title toc">Table Of Contents</span>
        
        
            
            <nav class="mdl-navigation">
                <ul class="current">
<li class="toctree-l1"><a class="reference internal" href="../../../tutorials/index.html">Python Tutorials</a><ul>
<li class="toctree-l2"><a class="reference internal" href="../../../tutorials/getting-started/index.html">Getting Started</a><ul>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/getting-started/crash-course/index.html">Crash Course</a><ul>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/getting-started/crash-course/1-ndarray.html">Manipulate data with <code class="docutils literal notranslate"><span class="pre">ndarray</span></code></a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/getting-started/crash-course/2-nn.html">Create a neural network</a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/getting-started/crash-course/3-autograd.html">Automatic differentiation with <code class="docutils literal notranslate"><span class="pre">autograd</span></code></a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/getting-started/crash-course/4-train.html">Train the neural network</a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/getting-started/crash-course/5-predict.html">Predict with a pre-trained model</a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/getting-started/crash-course/6-use_gpus.html">Use GPUs</a></li>
</ul>
</li>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/getting-started/to-mxnet/index.html">Moving to MXNet from Other Frameworks</a><ul>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/getting-started/to-mxnet/pytorch.html">PyTorch vs Apache MXNet</a></li>
</ul>
</li>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/getting-started/gluon_from_experiment_to_deployment.html">Gluon: from experiment to deployment</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/getting-started/logistic_regression_explained.html">Logistic regression explained</a></li>
<li class="toctree-l3"><a class="reference external" href="https://mxnet.apache.org/api/python/docs/tutorials/packages/gluon/image/mnist.html">MNIST</a></li>
</ul>
</li>
<li class="toctree-l2"><a class="reference internal" href="../../../tutorials/packages/index.html">Packages</a><ul>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/packages/autograd/index.html">Automatic Differentiation</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/packages/gluon/index.html">Gluon</a><ul>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/packages/gluon/blocks/index.html">Blocks</a><ul>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/blocks/custom-layer.html">Custom Layers</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/blocks/custom_layer_beginners.html">Customer Layers (Beginners)</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/blocks/hybridize.html">Hybridize</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/blocks/init.html">Initialization</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/blocks/naming.html">Parameter and Block Naming</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/blocks/nn.html">Layers and Blocks</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/blocks/parameters.html">Parameter Management</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/blocks/save_load_params.html">Saving and Loading Gluon Models</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/blocks/activations/activations.html">Activation Blocks</a></li>
</ul>
</li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/packages/gluon/image/index.html">Image Tutorials</a><ul>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/image/image-augmentation.html">Image Augmentation</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/image/mnist.html">Handwritten Digit Recognition</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/image/pretrained_models.html">Using pre-trained models in MXNet</a></li>
</ul>
</li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/packages/gluon/loss/index.html">Losses</a><ul>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/loss/custom-loss.html">Custom Loss Blocks</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/loss/kl_divergence.html">Kullback-Leibler (KL) Divergence</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/loss/loss.html">Loss functions</a></li>
</ul>
</li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/packages/gluon/text/index.html">Text Tutorials</a><ul>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/text/gnmt.html">Google Neural Machine Translation</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/text/transformer.html">Machine Translation with Transformer</a></li>
</ul>
</li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/packages/gluon/training/index.html">Training</a><ul>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/training/fit_api_tutorial.html">MXNet Gluon Fit API</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/training/trainer.html">Trainer</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/training/learning_rates/index.html">Learning Rates</a><ul>
<li class="toctree-l6"><a class="reference internal" href="../../../tutorials/packages/gluon/training/learning_rates/learning_rate_finder.html">Learning Rate Finder</a></li>
<li class="toctree-l6"><a class="reference internal" href="../../../tutorials/packages/gluon/training/learning_rates/learning_rate_schedules.html">Learning Rate Schedules</a></li>
<li class="toctree-l6"><a class="reference internal" href="../../../tutorials/packages/gluon/training/learning_rates/learning_rate_schedules_advanced.html">Advanced Learning Rate Schedules</a></li>
</ul>
</li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/training/normalization/index.html">Normalization Blocks</a></li>
</ul>
</li>
</ul>
</li>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/packages/kvstore/index.html">KVStore</a><ul>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/packages/kvstore/kvstore.html">Distributed Key-Value Store</a></li>
</ul>
</li>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/packages/ndarray/index.html">NDArray</a><ul>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/packages/ndarray/01-ndarray-intro.html">An Intro: Manipulate Data the MXNet Way with NDArray</a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/packages/ndarray/02-ndarray-operations.html">NDArray Operations</a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/packages/ndarray/03-ndarray-contexts.html">NDArray Contexts</a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/packages/ndarray/gotchas_numpy_in_mxnet.html">Gotchas using NumPy in Apache MXNet</a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/packages/ndarray/sparse/index.html">Tutorials</a><ul>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/ndarray/sparse/csr.html">CSRNDArray - NDArray in Compressed Sparse Row Storage Format</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/ndarray/sparse/row_sparse.html">RowSparseNDArray - NDArray for Sparse Gradient Updates</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/ndarray/sparse/train.html">Train a Linear Regression Model with Sparse Symbols</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/ndarray/sparse/train_gluon.html">Sparse NDArrays with Gluon</a></li>
</ul>
</li>
</ul>
</li>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/packages/onnx/index.html">ONNX</a><ul>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/packages/onnx/fine_tuning_gluon.html">Fine-tuning an ONNX model</a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/packages/onnx/inference_on_onnx_model.html">Running inference on MXNet/Gluon from an ONNX model</a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/packages/onnx/super_resolution.html">Importing an ONNX model into MXNet</a></li>
<li class="toctree-l4"><a class="reference external" href="https://mxnet.apache.org/api/python/docs/tutorials/deploy/export/onnx.html">Export ONNX Models</a></li>
</ul>
</li>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/packages/optimizer/index.html">Optimizers</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/packages/viz/index.html">Visualization</a><ul>
<li class="toctree-l4"><a class="reference external" href="https://mxnet.apache.org/api/faq/visualize_graph">Visualize networks</a></li>
</ul>
</li>
</ul>
</li>
<li class="toctree-l2"><a class="reference internal" href="../../../tutorials/performance/index.html">Performance</a><ul>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/performance/compression/index.html">Compression</a><ul>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/performance/compression/int8.html">Deploy with int-8</a></li>
<li class="toctree-l4"><a class="reference external" href="https://mxnet.apache.org/api/faq/float16">Float16</a></li>
<li class="toctree-l4"><a class="reference external" href="https://mxnet.apache.org/api/faq/gradient_compression">Gradient Compression</a></li>
<li class="toctree-l4"><a class="reference external" href="https://gluon-cv.mxnet.io/build/examples_deployment/int8_inference.html">GluonCV with Quantized Models</a></li>
</ul>
</li>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/performance/backend/index.html">Accelerated Backend Tools</a><ul>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/performance/backend/mkldnn/index.html">Intel MKL-DNN</a><ul>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/performance/backend/mkldnn/mkldnn_quantization.html">Quantize with MKL-DNN backend</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/performance/backend/mkldnn/mkldnn_readme.html">Install MXNet with MKL-DNN</a></li>
</ul>
</li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/performance/backend/tensorrt/index.html">TensorRT</a><ul>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/performance/backend/tensorrt/tensorrt.html">Optimized GPU Inference</a></li>
</ul>
</li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/performance/backend/tvm.html">Use TVM</a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/performance/backend/profiler.html">Profiling MXNet Models</a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/performance/backend/amp.html">Using AMP: Automatic Mixed Precision</a></li>
</ul>
</li>
</ul>
</li>
<li class="toctree-l2"><a class="reference internal" href="../../../tutorials/deploy/index.html">Deployment</a><ul>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/deploy/export/index.html">Export</a><ul>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/deploy/export/onnx.html">Exporting to ONNX format</a></li>
<li class="toctree-l4"><a class="reference external" href="https://gluon-cv.mxnet.io/build/examples_deployment/export_network.html">Export Gluon CV Models</a></li>
<li class="toctree-l4"><a class="reference external" href="https://mxnet.apache.org/api/python/docs/tutorials/packages/gluon/blocks/save_load_params.html">Save / Load Parameters</a></li>
</ul>
</li>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/deploy/inference/index.html">Inference</a><ul>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/deploy/inference/cpp.html">Deploy into C++</a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/deploy/inference/scala.html">Deploy into a Java or Scala Environment</a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/deploy/inference/wine_detector.html">Real-time Object Detection with MXNet On The Raspberry Pi</a></li>
</ul>
</li>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/deploy/run-on-aws/index.html">Run on AWS</a><ul>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/deploy/run-on-aws/use_ec2.html">Run on an EC2 Instance</a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/deploy/run-on-aws/use_sagemaker.html">Run on Amazon SageMaker</a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/deploy/run-on-aws/cloud.html">MXNet on the Cloud</a></li>
</ul>
</li>
</ul>
</li>
<li class="toctree-l2"><a class="reference internal" href="../../../tutorials/extend/index.html">Extend</a><ul>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/extend/custom_layer.html">Custom Layers</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/extend/customop.html">Custom Numpy Operators</a></li>
<li class="toctree-l3"><a class="reference external" href="https://mxnet.apache.org/api/faq/new_op">New Operator Creation</a></li>
<li class="toctree-l3"><a class="reference external" href="https://mxnet.apache.org/api/faq/add_op_in_backend">New Operator in MXNet Backend</a></li>
</ul>
</li>
</ul>
</li>
<li class="toctree-l1 current"><a class="reference internal" href="../../index.html">Python API</a><ul class="current">
<li class="toctree-l2"><a class="reference internal" href="../../ndarray/index.html">mxnet.ndarray</a><ul>
<li class="toctree-l3"><a class="reference internal" href="../../ndarray/ndarray.html">ndarray</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../ndarray/contrib/index.html">ndarray.contrib</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../ndarray/image/index.html">ndarray.image</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../ndarray/linalg/index.html">ndarray.linalg</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../ndarray/op/index.html">ndarray.op</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../ndarray/random/index.html">ndarray.random</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../ndarray/register/index.html">ndarray.register</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../ndarray/sparse/index.html">ndarray.sparse</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../ndarray/utils/index.html">ndarray.utils</a></li>
</ul>
</li>
<li class="toctree-l2"><a class="reference internal" href="../../gluon/index.html">mxnet.gluon</a><ul>
<li class="toctree-l3"><a class="reference internal" href="../../gluon/block.html">gluon.Block</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../gluon/hybrid_block.html">gluon.HybridBlock</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../gluon/symbol_block.html">gluon.SymbolBlock</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../gluon/constant.html">gluon.Constant</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../gluon/parameter.html">gluon.Parameter</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../gluon/parameter_dict.html">gluon.ParameterDict</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../gluon/trainer.html">gluon.Trainer</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../gluon/contrib/index.html">gluon.contrib</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../gluon/data/index.html">gluon.data</a><ul>
<li class="toctree-l4"><a class="reference internal" href="../../gluon/data/vision/index.html">data.vision</a><ul>
<li class="toctree-l5"><a class="reference internal" href="../../gluon/data/vision/datasets/index.html">vision.datasets</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../gluon/data/vision/transforms/index.html">vision.transforms</a></li>
</ul>
</li>
</ul>
</li>
<li class="toctree-l3"><a class="reference internal" href="../../gluon/loss/index.html">gluon.loss</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../gluon/model_zoo/index.html">gluon.model_zoo.vision</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../gluon/nn/index.html">gluon.nn</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../gluon/rnn/index.html">gluon.rnn</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../gluon/utils/index.html">gluon.utils</a></li>
</ul>
</li>
<li class="toctree-l2"><a class="reference internal" href="../../autograd/index.html">mxnet.autograd</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../initializer/index.html">mxnet.initializer</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../optimizer/index.html">mxnet.optimizer</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../lr_scheduler/index.html">mxnet.lr_scheduler</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../metric/index.html">mxnet.metric</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../kvstore/index.html">mxnet.kvstore</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../symbol/index.html">mxnet.symbol</a><ul>
<li class="toctree-l3"><a class="reference internal" href="../../symbol/symbol.html">symbol</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../symbol/contrib/index.html">symbol.contrib</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../symbol/image/index.html">symbol.image</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../symbol/linalg/index.html">symbol.linalg</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../symbol/op/index.html">symbol.op</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../symbol/random/index.html">symbol.random</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../symbol/register/index.html">symbol.register</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../symbol/sparse/index.html">symbol.sparse</a></li>
</ul>
</li>
<li class="toctree-l2"><a class="reference internal" href="../../module/index.html">mxnet.module</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../contrib/index.html">mxnet.contrib</a><ul>
<li class="toctree-l3"><a class="reference internal" href="../../contrib/autograd/index.html">contrib.autograd</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../contrib/io/index.html">contrib.io</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../contrib/ndarray/index.html">contrib.ndarray</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../contrib/onnx/index.html">contrib.onnx</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../contrib/quantization/index.html">contrib.quantization</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../contrib/symbol/index.html">contrib.symbol</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../contrib/tensorboard/index.html">contrib.tensorboard</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../contrib/tensorrt/index.html">contrib.tensorrt</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../contrib/text/index.html">contrib.text</a></li>
</ul>
</li>
<li class="toctree-l2 current"><a class="reference internal" href="../index.html">mxnet</a><ul class="current">
<li class="toctree-l3"><a class="reference internal" href="../attribute/index.html">mxnet.attribute</a></li>
<li class="toctree-l3"><a class="reference internal" href="../base/index.html">mxnet.base</a></li>
<li class="toctree-l3"><a class="reference internal" href="../callback/index.html">mxnet.callback</a></li>
<li class="toctree-l3"><a class="reference internal" href="../context/index.html">mxnet.context</a></li>
<li class="toctree-l3"><a class="reference internal" href="../engine/index.html">mxnet.engine</a></li>
<li class="toctree-l3"><a class="reference internal" href="../executor/index.html">mxnet.executor</a></li>
<li class="toctree-l3"><a class="reference internal" href="../executor_manager/index.html">mxnet.executor_manager</a></li>
<li class="toctree-l3"><a class="reference internal" href="../image/index.html">mxnet.image</a></li>
<li class="toctree-l3"><a class="reference internal" href="../io/index.html">mxnet.io</a></li>
<li class="toctree-l3"><a class="reference internal" href="../kvstore_server/index.html">mxnet.kvstore_server</a></li>
<li class="toctree-l3"><a class="reference internal" href="../libinfo/index.html">mxnet.libinfo</a></li>
<li class="toctree-l3"><a class="reference internal" href="../log/index.html">mxnet.log</a></li>
<li class="toctree-l3"><a class="reference internal" href="../model/index.html">mxnet.model</a></li>
<li class="toctree-l3"><a class="reference internal" href="../monitor/index.html">mxnet.monitor</a></li>
<li class="toctree-l3"><a class="reference internal" href="../name/index.html">mxnet.name</a></li>
<li class="toctree-l3"><a class="reference internal" href="../notebook/index.html">mxnet.notebook</a></li>
<li class="toctree-l3"><a class="reference internal" href="../operator/index.html">mxnet.operator</a></li>
<li class="toctree-l3"><a class="reference internal" href="../profiler/index.html">mxnet.profiler</a></li>
<li class="toctree-l3"><a class="reference internal" href="../random/index.html">mxnet.random</a></li>
<li class="toctree-l3"><a class="reference internal" href="../recordio/index.html">mxnet.recordio</a></li>
<li class="toctree-l3"><a class="reference internal" href="../registry/index.html">mxnet.registry</a></li>
<li class="toctree-l3"><a class="reference internal" href="../rtc/index.html">mxnet.rtc</a></li>
<li class="toctree-l3 current"><a class="current reference internal" href="#">mxnet.test_utils</a></li>
<li class="toctree-l3"><a class="reference internal" href="../torch/index.html">mxnet.torch</a></li>
<li class="toctree-l3"><a class="reference internal" href="../util/index.html">mxnet.util</a></li>
<li class="toctree-l3"><a class="reference internal" href="../visualization/index.html">mxnet.visualization</a></li>
</ul>
</li>
</ul>
</li>
</ul>

            </nav>
        
        </div>
    
</header>
        <main class="mdl-layout__content" tabIndex="0">

	<script type="text/javascript" src="../../../_static/sphinx_materialdesign_theme.js "></script>
    <header class="mdl-layout__drawer">      
    
      <div class="globaltoc">
        <span class="mdl-layout-title toc">Table Of Contents</span>
        
        
            
            <nav class="mdl-navigation">
                <ul class="current">
<li class="toctree-l1"><a class="reference internal" href="../../../tutorials/index.html">Python Tutorials</a><ul>
<li class="toctree-l2"><a class="reference internal" href="../../../tutorials/getting-started/index.html">Getting Started</a><ul>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/getting-started/crash-course/index.html">Crash Course</a><ul>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/getting-started/crash-course/1-ndarray.html">Manipulate data with <code class="docutils literal notranslate"><span class="pre">ndarray</span></code></a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/getting-started/crash-course/2-nn.html">Create a neural network</a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/getting-started/crash-course/3-autograd.html">Automatic differentiation with <code class="docutils literal notranslate"><span class="pre">autograd</span></code></a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/getting-started/crash-course/4-train.html">Train the neural network</a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/getting-started/crash-course/5-predict.html">Predict with a pre-trained model</a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/getting-started/crash-course/6-use_gpus.html">Use GPUs</a></li>
</ul>
</li>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/getting-started/to-mxnet/index.html">Moving to MXNet from Other Frameworks</a><ul>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/getting-started/to-mxnet/pytorch.html">PyTorch vs Apache MXNet</a></li>
</ul>
</li>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/getting-started/gluon_from_experiment_to_deployment.html">Gluon: from experiment to deployment</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/getting-started/logistic_regression_explained.html">Logistic regression explained</a></li>
<li class="toctree-l3"><a class="reference external" href="https://mxnet.apache.org/api/python/docs/tutorials/packages/gluon/image/mnist.html">MNIST</a></li>
</ul>
</li>
<li class="toctree-l2"><a class="reference internal" href="../../../tutorials/packages/index.html">Packages</a><ul>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/packages/autograd/index.html">Automatic Differentiation</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/packages/gluon/index.html">Gluon</a><ul>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/packages/gluon/blocks/index.html">Blocks</a><ul>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/blocks/custom-layer.html">Custom Layers</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/blocks/custom_layer_beginners.html">Customer Layers (Beginners)</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/blocks/hybridize.html">Hybridize</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/blocks/init.html">Initialization</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/blocks/naming.html">Parameter and Block Naming</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/blocks/nn.html">Layers and Blocks</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/blocks/parameters.html">Parameter Management</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/blocks/save_load_params.html">Saving and Loading Gluon Models</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/blocks/activations/activations.html">Activation Blocks</a></li>
</ul>
</li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/packages/gluon/image/index.html">Image Tutorials</a><ul>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/image/image-augmentation.html">Image Augmentation</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/image/mnist.html">Handwritten Digit Recognition</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/image/pretrained_models.html">Using pre-trained models in MXNet</a></li>
</ul>
</li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/packages/gluon/loss/index.html">Losses</a><ul>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/loss/custom-loss.html">Custom Loss Blocks</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/loss/kl_divergence.html">Kullback-Leibler (KL) Divergence</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/loss/loss.html">Loss functions</a></li>
</ul>
</li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/packages/gluon/text/index.html">Text Tutorials</a><ul>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/text/gnmt.html">Google Neural Machine Translation</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/text/transformer.html">Machine Translation with Transformer</a></li>
</ul>
</li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/packages/gluon/training/index.html">Training</a><ul>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/training/fit_api_tutorial.html">MXNet Gluon Fit API</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/training/trainer.html">Trainer</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/training/learning_rates/index.html">Learning Rates</a><ul>
<li class="toctree-l6"><a class="reference internal" href="../../../tutorials/packages/gluon/training/learning_rates/learning_rate_finder.html">Learning Rate Finder</a></li>
<li class="toctree-l6"><a class="reference internal" href="../../../tutorials/packages/gluon/training/learning_rates/learning_rate_schedules.html">Learning Rate Schedules</a></li>
<li class="toctree-l6"><a class="reference internal" href="../../../tutorials/packages/gluon/training/learning_rates/learning_rate_schedules_advanced.html">Advanced Learning Rate Schedules</a></li>
</ul>
</li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/gluon/training/normalization/index.html">Normalization Blocks</a></li>
</ul>
</li>
</ul>
</li>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/packages/kvstore/index.html">KVStore</a><ul>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/packages/kvstore/kvstore.html">Distributed Key-Value Store</a></li>
</ul>
</li>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/packages/ndarray/index.html">NDArray</a><ul>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/packages/ndarray/01-ndarray-intro.html">An Intro: Manipulate Data the MXNet Way with NDArray</a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/packages/ndarray/02-ndarray-operations.html">NDArray Operations</a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/packages/ndarray/03-ndarray-contexts.html">NDArray Contexts</a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/packages/ndarray/gotchas_numpy_in_mxnet.html">Gotchas using NumPy in Apache MXNet</a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/packages/ndarray/sparse/index.html">Tutorials</a><ul>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/ndarray/sparse/csr.html">CSRNDArray - NDArray in Compressed Sparse Row Storage Format</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/ndarray/sparse/row_sparse.html">RowSparseNDArray - NDArray for Sparse Gradient Updates</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/ndarray/sparse/train.html">Train a Linear Regression Model with Sparse Symbols</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/packages/ndarray/sparse/train_gluon.html">Sparse NDArrays with Gluon</a></li>
</ul>
</li>
</ul>
</li>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/packages/onnx/index.html">ONNX</a><ul>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/packages/onnx/fine_tuning_gluon.html">Fine-tuning an ONNX model</a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/packages/onnx/inference_on_onnx_model.html">Running inference on MXNet/Gluon from an ONNX model</a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/packages/onnx/super_resolution.html">Importing an ONNX model into MXNet</a></li>
<li class="toctree-l4"><a class="reference external" href="https://mxnet.apache.org/api/python/docs/tutorials/deploy/export/onnx.html">Export ONNX Models</a></li>
</ul>
</li>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/packages/optimizer/index.html">Optimizers</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/packages/viz/index.html">Visualization</a><ul>
<li class="toctree-l4"><a class="reference external" href="https://mxnet.apache.org/api/faq/visualize_graph">Visualize networks</a></li>
</ul>
</li>
</ul>
</li>
<li class="toctree-l2"><a class="reference internal" href="../../../tutorials/performance/index.html">Performance</a><ul>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/performance/compression/index.html">Compression</a><ul>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/performance/compression/int8.html">Deploy with int-8</a></li>
<li class="toctree-l4"><a class="reference external" href="https://mxnet.apache.org/api/faq/float16">Float16</a></li>
<li class="toctree-l4"><a class="reference external" href="https://mxnet.apache.org/api/faq/gradient_compression">Gradient Compression</a></li>
<li class="toctree-l4"><a class="reference external" href="https://gluon-cv.mxnet.io/build/examples_deployment/int8_inference.html">GluonCV with Quantized Models</a></li>
</ul>
</li>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/performance/backend/index.html">Accelerated Backend Tools</a><ul>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/performance/backend/mkldnn/index.html">Intel MKL-DNN</a><ul>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/performance/backend/mkldnn/mkldnn_quantization.html">Quantize with MKL-DNN backend</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/performance/backend/mkldnn/mkldnn_readme.html">Install MXNet with MKL-DNN</a></li>
</ul>
</li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/performance/backend/tensorrt/index.html">TensorRT</a><ul>
<li class="toctree-l5"><a class="reference internal" href="../../../tutorials/performance/backend/tensorrt/tensorrt.html">Optimized GPU Inference</a></li>
</ul>
</li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/performance/backend/tvm.html">Use TVM</a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/performance/backend/profiler.html">Profiling MXNet Models</a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/performance/backend/amp.html">Using AMP: Automatic Mixed Precision</a></li>
</ul>
</li>
</ul>
</li>
<li class="toctree-l2"><a class="reference internal" href="../../../tutorials/deploy/index.html">Deployment</a><ul>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/deploy/export/index.html">Export</a><ul>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/deploy/export/onnx.html">Exporting to ONNX format</a></li>
<li class="toctree-l4"><a class="reference external" href="https://gluon-cv.mxnet.io/build/examples_deployment/export_network.html">Export Gluon CV Models</a></li>
<li class="toctree-l4"><a class="reference external" href="https://mxnet.apache.org/api/python/docs/tutorials/packages/gluon/blocks/save_load_params.html">Save / Load Parameters</a></li>
</ul>
</li>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/deploy/inference/index.html">Inference</a><ul>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/deploy/inference/cpp.html">Deploy into C++</a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/deploy/inference/scala.html">Deploy into a Java or Scala Environment</a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/deploy/inference/wine_detector.html">Real-time Object Detection with MXNet On The Raspberry Pi</a></li>
</ul>
</li>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/deploy/run-on-aws/index.html">Run on AWS</a><ul>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/deploy/run-on-aws/use_ec2.html">Run on an EC2 Instance</a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/deploy/run-on-aws/use_sagemaker.html">Run on Amazon SageMaker</a></li>
<li class="toctree-l4"><a class="reference internal" href="../../../tutorials/deploy/run-on-aws/cloud.html">MXNet on the Cloud</a></li>
</ul>
</li>
</ul>
</li>
<li class="toctree-l2"><a class="reference internal" href="../../../tutorials/extend/index.html">Extend</a><ul>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/extend/custom_layer.html">Custom Layers</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../../tutorials/extend/customop.html">Custom Numpy Operators</a></li>
<li class="toctree-l3"><a class="reference external" href="https://mxnet.apache.org/api/faq/new_op">New Operator Creation</a></li>
<li class="toctree-l3"><a class="reference external" href="https://mxnet.apache.org/api/faq/add_op_in_backend">New Operator in MXNet Backend</a></li>
</ul>
</li>
</ul>
</li>
<li class="toctree-l1 current"><a class="reference internal" href="../../index.html">Python API</a><ul class="current">
<li class="toctree-l2"><a class="reference internal" href="../../ndarray/index.html">mxnet.ndarray</a><ul>
<li class="toctree-l3"><a class="reference internal" href="../../ndarray/ndarray.html">ndarray</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../ndarray/contrib/index.html">ndarray.contrib</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../ndarray/image/index.html">ndarray.image</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../ndarray/linalg/index.html">ndarray.linalg</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../ndarray/op/index.html">ndarray.op</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../ndarray/random/index.html">ndarray.random</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../ndarray/register/index.html">ndarray.register</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../ndarray/sparse/index.html">ndarray.sparse</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../ndarray/utils/index.html">ndarray.utils</a></li>
</ul>
</li>
<li class="toctree-l2"><a class="reference internal" href="../../gluon/index.html">mxnet.gluon</a><ul>
<li class="toctree-l3"><a class="reference internal" href="../../gluon/block.html">gluon.Block</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../gluon/hybrid_block.html">gluon.HybridBlock</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../gluon/symbol_block.html">gluon.SymbolBlock</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../gluon/constant.html">gluon.Constant</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../gluon/parameter.html">gluon.Parameter</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../gluon/parameter_dict.html">gluon.ParameterDict</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../gluon/trainer.html">gluon.Trainer</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../gluon/contrib/index.html">gluon.contrib</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../gluon/data/index.html">gluon.data</a><ul>
<li class="toctree-l4"><a class="reference internal" href="../../gluon/data/vision/index.html">data.vision</a><ul>
<li class="toctree-l5"><a class="reference internal" href="../../gluon/data/vision/datasets/index.html">vision.datasets</a></li>
<li class="toctree-l5"><a class="reference internal" href="../../gluon/data/vision/transforms/index.html">vision.transforms</a></li>
</ul>
</li>
</ul>
</li>
<li class="toctree-l3"><a class="reference internal" href="../../gluon/loss/index.html">gluon.loss</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../gluon/model_zoo/index.html">gluon.model_zoo.vision</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../gluon/nn/index.html">gluon.nn</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../gluon/rnn/index.html">gluon.rnn</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../gluon/utils/index.html">gluon.utils</a></li>
</ul>
</li>
<li class="toctree-l2"><a class="reference internal" href="../../autograd/index.html">mxnet.autograd</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../initializer/index.html">mxnet.initializer</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../optimizer/index.html">mxnet.optimizer</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../lr_scheduler/index.html">mxnet.lr_scheduler</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../metric/index.html">mxnet.metric</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../kvstore/index.html">mxnet.kvstore</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../symbol/index.html">mxnet.symbol</a><ul>
<li class="toctree-l3"><a class="reference internal" href="../../symbol/symbol.html">symbol</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../symbol/contrib/index.html">symbol.contrib</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../symbol/image/index.html">symbol.image</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../symbol/linalg/index.html">symbol.linalg</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../symbol/op/index.html">symbol.op</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../symbol/random/index.html">symbol.random</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../symbol/register/index.html">symbol.register</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../symbol/sparse/index.html">symbol.sparse</a></li>
</ul>
</li>
<li class="toctree-l2"><a class="reference internal" href="../../module/index.html">mxnet.module</a></li>
<li class="toctree-l2"><a class="reference internal" href="../../contrib/index.html">mxnet.contrib</a><ul>
<li class="toctree-l3"><a class="reference internal" href="../../contrib/autograd/index.html">contrib.autograd</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../contrib/io/index.html">contrib.io</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../contrib/ndarray/index.html">contrib.ndarray</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../contrib/onnx/index.html">contrib.onnx</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../contrib/quantization/index.html">contrib.quantization</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../contrib/symbol/index.html">contrib.symbol</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../contrib/tensorboard/index.html">contrib.tensorboard</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../contrib/tensorrt/index.html">contrib.tensorrt</a></li>
<li class="toctree-l3"><a class="reference internal" href="../../contrib/text/index.html">contrib.text</a></li>
</ul>
</li>
<li class="toctree-l2 current"><a class="reference internal" href="../index.html">mxnet</a><ul class="current">
<li class="toctree-l3"><a class="reference internal" href="../attribute/index.html">mxnet.attribute</a></li>
<li class="toctree-l3"><a class="reference internal" href="../base/index.html">mxnet.base</a></li>
<li class="toctree-l3"><a class="reference internal" href="../callback/index.html">mxnet.callback</a></li>
<li class="toctree-l3"><a class="reference internal" href="../context/index.html">mxnet.context</a></li>
<li class="toctree-l3"><a class="reference internal" href="../engine/index.html">mxnet.engine</a></li>
<li class="toctree-l3"><a class="reference internal" href="../executor/index.html">mxnet.executor</a></li>
<li class="toctree-l3"><a class="reference internal" href="../executor_manager/index.html">mxnet.executor_manager</a></li>
<li class="toctree-l3"><a class="reference internal" href="../image/index.html">mxnet.image</a></li>
<li class="toctree-l3"><a class="reference internal" href="../io/index.html">mxnet.io</a></li>
<li class="toctree-l3"><a class="reference internal" href="../kvstore_server/index.html">mxnet.kvstore_server</a></li>
<li class="toctree-l3"><a class="reference internal" href="../libinfo/index.html">mxnet.libinfo</a></li>
<li class="toctree-l3"><a class="reference internal" href="../log/index.html">mxnet.log</a></li>
<li class="toctree-l3"><a class="reference internal" href="../model/index.html">mxnet.model</a></li>
<li class="toctree-l3"><a class="reference internal" href="../monitor/index.html">mxnet.monitor</a></li>
<li class="toctree-l3"><a class="reference internal" href="../name/index.html">mxnet.name</a></li>
<li class="toctree-l3"><a class="reference internal" href="../notebook/index.html">mxnet.notebook</a></li>
<li class="toctree-l3"><a class="reference internal" href="../operator/index.html">mxnet.operator</a></li>
<li class="toctree-l3"><a class="reference internal" href="../profiler/index.html">mxnet.profiler</a></li>
<li class="toctree-l3"><a class="reference internal" href="../random/index.html">mxnet.random</a></li>
<li class="toctree-l3"><a class="reference internal" href="../recordio/index.html">mxnet.recordio</a></li>
<li class="toctree-l3"><a class="reference internal" href="../registry/index.html">mxnet.registry</a></li>
<li class="toctree-l3"><a class="reference internal" href="../rtc/index.html">mxnet.rtc</a></li>
<li class="toctree-l3 current"><a class="current reference internal" href="#">mxnet.test_utils</a></li>
<li class="toctree-l3"><a class="reference internal" href="../torch/index.html">mxnet.torch</a></li>
<li class="toctree-l3"><a class="reference internal" href="../util/index.html">mxnet.util</a></li>
<li class="toctree-l3"><a class="reference internal" href="../visualization/index.html">mxnet.visualization</a></li>
</ul>
</li>
</ul>
</li>
</ul>

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

    <div class="document">
        <div class="page-content" role="main">
        
  <div class="section" id="module-mxnet.test_utils">
<span id="mxnet-test-utils"></span><h1>mxnet.test_utils<a class="headerlink" href="#module-mxnet.test_utils" title="Permalink to this headline">¶</a></h1>
<p>Tools for testing.</p>
<p><strong>Classes</strong></p>
<table class="longtable docutils align-default">
<colgroup>
<col style="width: 10%" />
<col style="width: 90%" />
</colgroup>
<tbody>
<tr class="row-odd"><td><p><a class="reference internal" href="#mxnet.test_utils.DummyIter" title="mxnet.test_utils.DummyIter"><code class="xref py py-obj docutils literal notranslate"><span class="pre">DummyIter</span></code></a>(real_iter)</p></td>
<td><p>A dummy iterator that always returns the same batch of data (the first data batch of the real data iter).</p></td>
</tr>
<tr class="row-even"><td><p><a class="reference internal" href="#mxnet.test_utils.EnvManager" title="mxnet.test_utils.EnvManager"><code class="xref py py-obj docutils literal notranslate"><span class="pre">EnvManager</span></code></a>(key, val)</p></td>
<td><p>Environment variable setter and unsetter via with idiom</p></td>
</tr>
</tbody>
</table>
<p><strong>Functions</strong></p>
<table class="longtable docutils align-default">
<colgroup>
<col style="width: 10%" />
<col style="width: 90%" />
</colgroup>
<tbody>
<tr class="row-odd"><td><p><a class="reference internal" href="#mxnet.test_utils.almost_equal" title="mxnet.test_utils.almost_equal"><code class="xref py py-obj docutils literal notranslate"><span class="pre">almost_equal</span></code></a>(a, b[, rtol, atol, equal_nan, …])</p></td>
<td><p>Test if two numpy arrays are almost equal.</p></td>
</tr>
<tr class="row-even"><td><p><a class="reference internal" href="#mxnet.test_utils.almost_equal_ignore_nan" title="mxnet.test_utils.almost_equal_ignore_nan"><code class="xref py py-obj docutils literal notranslate"><span class="pre">almost_equal_ignore_nan</span></code></a>(a, b[, rtol, atol])</p></td>
<td><p>Test that two NumPy arrays are almost equal (ignoring NaN in either array).</p></td>
</tr>
<tr class="row-odd"><td><p><a class="reference internal" href="#mxnet.test_utils.assert_almost_equal" title="mxnet.test_utils.assert_almost_equal"><code class="xref py py-obj docutils literal notranslate"><span class="pre">assert_almost_equal</span></code></a>(a, b[, rtol, atol, …])</p></td>
<td><p>Test that two numpy arrays are almost equal.</p></td>
</tr>
<tr class="row-even"><td><p><a class="reference internal" href="#mxnet.test_utils.assert_almost_equal_ignore_nan" title="mxnet.test_utils.assert_almost_equal_ignore_nan"><code class="xref py py-obj docutils literal notranslate"><span class="pre">assert_almost_equal_ignore_nan</span></code></a>(a, b[, rtol, …])</p></td>
<td><p>Test that two NumPy arrays are almost equal (ignoring NaN in either array).</p></td>
</tr>
<tr class="row-odd"><td><p><a class="reference internal" href="#mxnet.test_utils.assert_almost_equal_with_err" title="mxnet.test_utils.assert_almost_equal_with_err"><code class="xref py py-obj docutils literal notranslate"><span class="pre">assert_almost_equal_with_err</span></code></a>(a, b[, rtol, …])</p></td>
<td><p>Test that two numpy arrays are almost equal within given error rate.</p></td>
</tr>
<tr class="row-even"><td><p><a class="reference internal" href="#mxnet.test_utils.assert_exception" title="mxnet.test_utils.assert_exception"><code class="xref py py-obj docutils literal notranslate"><span class="pre">assert_exception</span></code></a>(f, exception_type, *args, …)</p></td>
<td><p>Test that function f will throw an exception of type given by <cite>exception_type</cite></p></td>
</tr>
<tr class="row-odd"><td><p><a class="reference internal" href="#mxnet.test_utils.assign_each" title="mxnet.test_utils.assign_each"><code class="xref py py-obj docutils literal notranslate"><span class="pre">assign_each</span></code></a>(the_input, function)</p></td>
<td><p>Return ndarray composed of passing each array value through some function</p></td>
</tr>
<tr class="row-even"><td><p><a class="reference internal" href="#mxnet.test_utils.assign_each2" title="mxnet.test_utils.assign_each2"><code class="xref py py-obj docutils literal notranslate"><span class="pre">assign_each2</span></code></a>(input1, input2, function)</p></td>
<td><p>Return ndarray composed of passing two array values through some function</p></td>
</tr>
<tr class="row-odd"><td><p><a class="reference internal" href="#mxnet.test_utils.check_consistency" title="mxnet.test_utils.check_consistency"><code class="xref py py-obj docutils literal notranslate"><span class="pre">check_consistency</span></code></a>(sym, ctx_list[, scale, …])</p></td>
<td><p>Check symbol gives the same output for different running context</p></td>
</tr>
<tr class="row-even"><td><p><a class="reference internal" href="#mxnet.test_utils.check_numeric_gradient" title="mxnet.test_utils.check_numeric_gradient"><code class="xref py py-obj docutils literal notranslate"><span class="pre">check_numeric_gradient</span></code></a>(sym, location[, …])</p></td>
<td><p>Verify an operation by checking backward pass via finite difference method.</p></td>
</tr>
<tr class="row-odd"><td><p><a class="reference internal" href="#mxnet.test_utils.check_speed" title="mxnet.test_utils.check_speed"><code class="xref py py-obj docutils literal notranslate"><span class="pre">check_speed</span></code></a>(sym[, location, ctx, N, …])</p></td>
<td><p>Check the running speed of a symbol.</p></td>
</tr>
<tr class="row-even"><td><p><a class="reference internal" href="#mxnet.test_utils.check_symbolic_backward" title="mxnet.test_utils.check_symbolic_backward"><code class="xref py py-obj docutils literal notranslate"><span class="pre">check_symbolic_backward</span></code></a>(sym, location, …)</p></td>
<td><p>Compares a symbol’s backward results with the expected ones.</p></td>
</tr>
<tr class="row-odd"><td><p><a class="reference internal" href="#mxnet.test_utils.check_symbolic_forward" title="mxnet.test_utils.check_symbolic_forward"><code class="xref py py-obj docutils literal notranslate"><span class="pre">check_symbolic_forward</span></code></a>(sym, location, expected)</p></td>
<td><p>Compares a symbol’s forward results with the expected ones.</p></td>
</tr>
<tr class="row-even"><td><p><a class="reference internal" href="#mxnet.test_utils.chi_square_check" title="mxnet.test_utils.chi_square_check"><code class="xref py py-obj docutils literal notranslate"><span class="pre">chi_square_check</span></code></a>(generator, buckets, probs)</p></td>
<td><p>Run the chi-square test for the generator.</p></td>
</tr>
<tr class="row-odd"><td><p><a class="reference internal" href="#mxnet.test_utils.collapse_sum_like" title="mxnet.test_utils.collapse_sum_like"><code class="xref py py-obj docutils literal notranslate"><span class="pre">collapse_sum_like</span></code></a>(a, shape)</p></td>
<td><p>Given <cite>a</cite> as a numpy ndarray, perform reduce_sum on <cite>a</cite> over the axes that do not exist in <cite>shape</cite>.</p></td>
</tr>
<tr class="row-even"><td><p><a class="reference internal" href="#mxnet.test_utils.compare_ndarray_tuple" title="mxnet.test_utils.compare_ndarray_tuple"><code class="xref py py-obj docutils literal notranslate"><span class="pre">compare_ndarray_tuple</span></code></a>(t1, t2[, rtol, atol])</p></td>
<td><p>Compare ndarray tuple.</p></td>
</tr>
<tr class="row-odd"><td><p><a class="reference internal" href="#mxnet.test_utils.compare_optimizer" title="mxnet.test_utils.compare_optimizer"><code class="xref py py-obj docutils literal notranslate"><span class="pre">compare_optimizer</span></code></a>(opt1, opt2, shape, dtype)</p></td>
<td><p>Compare opt1 and opt2.</p></td>
</tr>
<tr class="row-even"><td><p><a class="reference internal" href="#mxnet.test_utils.create_sparse_array" title="mxnet.test_utils.create_sparse_array"><code class="xref py py-obj docutils literal notranslate"><span class="pre">create_sparse_array</span></code></a>(shape, stype[, …])</p></td>
<td><p>Create a sparse array, For Rsp, assure indices are in a canonical format</p></td>
</tr>
<tr class="row-odd"><td><p><a class="reference internal" href="#mxnet.test_utils.create_sparse_array_zd" title="mxnet.test_utils.create_sparse_array_zd"><code class="xref py py-obj docutils literal notranslate"><span class="pre">create_sparse_array_zd</span></code></a>(shape, stype, density)</p></td>
<td><p>Create sparse array, using only rsp_indices to determine density</p></td>
</tr>
<tr class="row-even"><td><p><a class="reference internal" href="#mxnet.test_utils.default_context" title="mxnet.test_utils.default_context"><code class="xref py py-obj docutils literal notranslate"><span class="pre">default_context</span></code></a>()</p></td>
<td><p>Get default context for regression test.</p></td>
</tr>
<tr class="row-odd"><td><p><a class="reference internal" href="#mxnet.test_utils.default_dtype" title="mxnet.test_utils.default_dtype"><code class="xref py py-obj docutils literal notranslate"><span class="pre">default_dtype</span></code></a>()</p></td>
<td><p>Get default data type for regression test.</p></td>
</tr>
<tr class="row-even"><td><p><a class="reference internal" href="#mxnet.test_utils.discard_stderr" title="mxnet.test_utils.discard_stderr"><code class="xref py py-obj docutils literal notranslate"><span class="pre">discard_stderr</span></code></a>()</p></td>
<td><p>Discards error output of a routine if invoked as:</p></td>
</tr>
<tr class="row-odd"><td><p><a class="reference internal" href="#mxnet.test_utils.download" title="mxnet.test_utils.download"><code class="xref py py-obj docutils literal notranslate"><span class="pre">download</span></code></a>(url[, fname, dirname, overwrite, …])</p></td>
<td><p>Download an given URL</p></td>
</tr>
<tr class="row-even"><td><p><a class="reference internal" href="#mxnet.test_utils.download_model" title="mxnet.test_utils.download_model"><code class="xref py py-obj docutils literal notranslate"><span class="pre">download_model</span></code></a>(model_name[, dst_dir, meta_info])</p></td>
<td><p>Download a model from data.mxnet.io</p></td>
</tr>
<tr class="row-odd"><td><p><a class="reference internal" href="#mxnet.test_utils.find_max_violation" title="mxnet.test_utils.find_max_violation"><code class="xref py py-obj docutils literal notranslate"><span class="pre">find_max_violation</span></code></a>(a, b[, rtol, atol])</p></td>
<td><p>Finds and returns the location of maximum violation.</p></td>
</tr>
<tr class="row-even"><td><p><a class="reference internal" href="#mxnet.test_utils.gen_buckets_probs_with_ppf" title="mxnet.test_utils.gen_buckets_probs_with_ppf"><code class="xref py py-obj docutils literal notranslate"><span class="pre">gen_buckets_probs_with_ppf</span></code></a>(ppf, nbuckets)</p></td>
<td><p>Generate the buckets and probabilities for chi_square test when the ppf (Quantile function)  is specified.</p></td>
</tr>
<tr class="row-odd"><td><p><a class="reference internal" href="#mxnet.test_utils.get_atol" title="mxnet.test_utils.get_atol"><code class="xref py py-obj docutils literal notranslate"><span class="pre">get_atol</span></code></a>([atol])</p></td>
<td><p>Get default numerical threshold for regression test.</p></td>
</tr>
<tr class="row-even"><td><p><a class="reference internal" href="#mxnet.test_utils.get_bz2_data" title="mxnet.test_utils.get_bz2_data"><code class="xref py py-obj docutils literal notranslate"><span class="pre">get_bz2_data</span></code></a>(data_dir, data_name, url, …)</p></td>
<td><p>Download and extract bz2 data.</p></td>
</tr>
<tr class="row-odd"><td><p><a class="reference internal" href="#mxnet.test_utils.get_cifar10" title="mxnet.test_utils.get_cifar10"><code class="xref py py-obj docutils literal notranslate"><span class="pre">get_cifar10</span></code></a>()</p></td>
<td><p>Downloads CIFAR10 dataset into a directory in the current directory with the name <cite>data</cite>, and then extracts all files into the directory <cite>data/cifar</cite>.</p></td>
</tr>
<tr class="row-even"><td><p><a class="reference internal" href="#mxnet.test_utils.get_etol" title="mxnet.test_utils.get_etol"><code class="xref py py-obj docutils literal notranslate"><span class="pre">get_etol</span></code></a>([etol])</p></td>
<td><p>Get default numerical threshold for regression test.</p></td>
</tr>
<tr class="row-odd"><td><p><a class="reference internal" href="#mxnet.test_utils.get_im2rec_path" title="mxnet.test_utils.get_im2rec_path"><code class="xref py py-obj docutils literal notranslate"><span class="pre">get_im2rec_path</span></code></a>([home_env])</p></td>
<td><p>Get path to the im2rec.py tool</p></td>
</tr>
<tr class="row-even"><td><p><a class="reference internal" href="#mxnet.test_utils.get_mnist" title="mxnet.test_utils.get_mnist"><code class="xref py py-obj docutils literal notranslate"><span class="pre">get_mnist</span></code></a>()</p></td>
<td><p>Download and load the MNIST dataset</p></td>
</tr>
<tr class="row-odd"><td><p><a class="reference internal" href="#mxnet.test_utils.get_mnist_iterator" title="mxnet.test_utils.get_mnist_iterator"><code class="xref py py-obj docutils literal notranslate"><span class="pre">get_mnist_iterator</span></code></a>(batch_size, input_shape)</p></td>
<td><p>Returns training and validation iterators for MNIST dataset</p></td>
</tr>
<tr class="row-even"><td><p><a class="reference internal" href="#mxnet.test_utils.get_mnist_pkl" title="mxnet.test_utils.get_mnist_pkl"><code class="xref py py-obj docutils literal notranslate"><span class="pre">get_mnist_pkl</span></code></a>()</p></td>
<td><p>Downloads MNIST dataset as a pkl.gz into a directory in the current directory</p></td>
</tr>
<tr class="row-odd"><td><p><a class="reference internal" href="#mxnet.test_utils.get_mnist_ubyte" title="mxnet.test_utils.get_mnist_ubyte"><code class="xref py py-obj docutils literal notranslate"><span class="pre">get_mnist_ubyte</span></code></a>()</p></td>
<td><p>Downloads ubyte version of the MNIST dataset into a directory in the current directory with the name <cite>data</cite> and extracts all files in the zip archive to this directory.</p></td>
</tr>
<tr class="row-even"><td><p><a class="reference internal" href="#mxnet.test_utils.get_rtol" title="mxnet.test_utils.get_rtol"><code class="xref py py-obj docutils literal notranslate"><span class="pre">get_rtol</span></code></a>([rtol])</p></td>
<td><p>Get default numerical threshold for regression test.</p></td>
</tr>
<tr class="row-odd"><td><p><a class="reference internal" href="#mxnet.test_utils.get_zip_data" title="mxnet.test_utils.get_zip_data"><code class="xref py py-obj docutils literal notranslate"><span class="pre">get_zip_data</span></code></a>(data_dir, url, data_origin_name)</p></td>
<td><p>Download and extract zip data.</p></td>
</tr>
<tr class="row-even"><td><p><a class="reference internal" href="#mxnet.test_utils.has_tvm_ops" title="mxnet.test_utils.has_tvm_ops"><code class="xref py py-obj docutils literal notranslate"><span class="pre">has_tvm_ops</span></code></a>()</p></td>
<td><p>Returns True if MXNet is compiled with TVM generated operators.</p></td>
</tr>
<tr class="row-odd"><td><p><a class="reference internal" href="#mxnet.test_utils.is_cd_run" title="mxnet.test_utils.is_cd_run"><code class="xref py py-obj docutils literal notranslate"><span class="pre">is_cd_run</span></code></a>()</p></td>
<td><p>Checks if the test is running as part of a Continuous Delivery run</p></td>
</tr>
<tr class="row-even"><td><p><a class="reference internal" href="#mxnet.test_utils.is_op_runnable" title="mxnet.test_utils.is_op_runnable"><code class="xref py py-obj docutils literal notranslate"><span class="pre">is_op_runnable</span></code></a>()</p></td>
<td><p>Returns True for all CPU tests.</p></td>
</tr>
<tr class="row-odd"><td><p><a class="reference internal" href="#mxnet.test_utils.list_gpus" title="mxnet.test_utils.list_gpus"><code class="xref py py-obj docutils literal notranslate"><span class="pre">list_gpus</span></code></a>()</p></td>
<td><p>Return a list of GPUs</p></td>
</tr>
<tr class="row-even"><td><p><a class="reference internal" href="#mxnet.test_utils.mean_check" title="mxnet.test_utils.mean_check"><code class="xref py py-obj docutils literal notranslate"><span class="pre">mean_check</span></code></a>(generator, mu, sigma[, nsamples])</p></td>
<td><p>Test the generator by matching the mean.</p></td>
</tr>
<tr class="row-odd"><td><p><a class="reference internal" href="#mxnet.test_utils.np_reduce" title="mxnet.test_utils.np_reduce"><code class="xref py py-obj docutils literal notranslate"><span class="pre">np_reduce</span></code></a>(dat, axis, keepdims, numpy_reduce_func)</p></td>
<td><p>Compatible reduce for old version of NumPy.</p></td>
</tr>
<tr class="row-even"><td><p><a class="reference internal" href="#mxnet.test_utils.numeric_grad" title="mxnet.test_utils.numeric_grad"><code class="xref py py-obj docutils literal notranslate"><span class="pre">numeric_grad</span></code></a>(executor, location[, …])</p></td>
<td><p>Calculates a numeric gradient via finite difference method.</p></td>
</tr>
<tr class="row-odd"><td><p><a class="reference internal" href="#mxnet.test_utils.rand_ndarray" title="mxnet.test_utils.rand_ndarray"><code class="xref py py-obj docutils literal notranslate"><span class="pre">rand_ndarray</span></code></a>(shape[, stype, density, dtype, …])</p></td>
<td><p>Generate a random sparse ndarray.</p></td>
</tr>
<tr class="row-even"><td><p><a class="reference internal" href="#mxnet.test_utils.rand_sparse_ndarray" title="mxnet.test_utils.rand_sparse_ndarray"><code class="xref py py-obj docutils literal notranslate"><span class="pre">rand_sparse_ndarray</span></code></a>(shape, stype[, density, …])</p></td>
<td><p>Generate a random sparse ndarray.</p></td>
</tr>
<tr class="row-odd"><td><p><a class="reference internal" href="#mxnet.test_utils.random_arrays" title="mxnet.test_utils.random_arrays"><code class="xref py py-obj docutils literal notranslate"><span class="pre">random_arrays</span></code></a>(*shapes)</p></td>
<td><p>Generate some random numpy arrays.</p></td>
</tr>
<tr class="row-even"><td><p><a class="reference internal" href="#mxnet.test_utils.random_sample" title="mxnet.test_utils.random_sample"><code class="xref py py-obj docutils literal notranslate"><span class="pre">random_sample</span></code></a>(population, k)</p></td>
<td><p>Return a k length list of the elements chosen from the population sequence.</p></td>
</tr>
<tr class="row-odd"><td><p><a class="reference internal" href="#mxnet.test_utils.retry" title="mxnet.test_utils.retry"><code class="xref py py-obj docutils literal notranslate"><span class="pre">retry</span></code></a>(n)</p></td>
<td><p>Retry n times before failing for stochastic test cases.</p></td>
</tr>
<tr class="row-even"><td><p><a class="reference internal" href="#mxnet.test_utils.same" title="mxnet.test_utils.same"><code class="xref py py-obj docutils literal notranslate"><span class="pre">same</span></code></a>(a, b)</p></td>
<td><p>Test if two NumPy arrays are the same.</p></td>
</tr>
<tr class="row-odd"><td><p><a class="reference internal" href="#mxnet.test_utils.same_array" title="mxnet.test_utils.same_array"><code class="xref py py-obj docutils literal notranslate"><span class="pre">same_array</span></code></a>(array1, array2)</p></td>
<td><p>Check whether two NDArrays sharing the same memory block</p></td>
</tr>
<tr class="row-even"><td><p><a class="reference internal" href="#mxnet.test_utils.same_symbol_structure" title="mxnet.test_utils.same_symbol_structure"><code class="xref py py-obj docutils literal notranslate"><span class="pre">same_symbol_structure</span></code></a>(sym1, sym2)</p></td>
<td><p>Compare two symbols to check if they have the same computation graph structure.</p></td>
</tr>
<tr class="row-odd"><td><p><a class="reference internal" href="#mxnet.test_utils.set_default_context" title="mxnet.test_utils.set_default_context"><code class="xref py py-obj docutils literal notranslate"><span class="pre">set_default_context</span></code></a>(ctx)</p></td>
<td><p>Set default context.</p></td>
</tr>
<tr class="row-even"><td><p><a class="reference internal" href="#mxnet.test_utils.set_env_var" title="mxnet.test_utils.set_env_var"><code class="xref py py-obj docutils literal notranslate"><span class="pre">set_env_var</span></code></a>(key, val[, default_val])</p></td>
<td><p>Set environment variable</p></td>
</tr>
<tr class="row-odd"><td><p><a class="reference internal" href="#mxnet.test_utils.shuffle_csr_column_indices" title="mxnet.test_utils.shuffle_csr_column_indices"><code class="xref py py-obj docutils literal notranslate"><span class="pre">shuffle_csr_column_indices</span></code></a>(csr)</p></td>
<td><p>Shuffle CSR column indices per row</p></td>
</tr>
<tr class="row-even"><td><p><a class="reference internal" href="#mxnet.test_utils.simple_forward" title="mxnet.test_utils.simple_forward"><code class="xref py py-obj docutils literal notranslate"><span class="pre">simple_forward</span></code></a>(sym[, ctx, is_train])</p></td>
<td><p>A simple forward function for a symbol.</p></td>
</tr>
<tr class="row-odd"><td><p><a class="reference internal" href="#mxnet.test_utils.var_check" title="mxnet.test_utils.var_check"><code class="xref py py-obj docutils literal notranslate"><span class="pre">var_check</span></code></a>(generator, sigma[, nsamples])</p></td>
<td><p>Test the generator by matching the variance.</p></td>
</tr>
<tr class="row-even"><td><p><a class="reference internal" href="#mxnet.test_utils.verify_generator" title="mxnet.test_utils.verify_generator"><code class="xref py py-obj docutils literal notranslate"><span class="pre">verify_generator</span></code></a>(generator, buckets, probs)</p></td>
<td><p>Verify whether the generator is correct using chi-square testing.</p></td>
</tr>
</tbody>
</table>
<dl class="class">
<dt id="mxnet.test_utils.DummyIter">
<em class="property">class </em><code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">DummyIter</code><span class="sig-paren">(</span><em class="sig-param">real_iter</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#DummyIter"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.DummyIter" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">mxnet.io.io.DataIter</span></code></p>
<p>A dummy iterator that always returns the same batch of data
(the first data batch of the real data iter). This is usually used for speed testing.</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><p><strong>real_iter</strong> (<em>mx.io.DataIter</em>) – The real data iterator where the first batch of data comes from</p>
</dd>
</dl>
<p><strong>Methods</strong></p>
<table class="longtable docutils align-default">
<colgroup>
<col style="width: 10%" />
<col style="width: 90%" />
</colgroup>
<tbody>
<tr class="row-odd"><td><p><a class="reference internal" href="#mxnet.test_utils.DummyIter.next" title="mxnet.test_utils.DummyIter.next"><code class="xref py py-obj docutils literal notranslate"><span class="pre">next</span></code></a>()</p></td>
<td><p>Get a data batch from iterator.</p></td>
</tr>
</tbody>
</table>
<dl class="method">
<dt id="mxnet.test_utils.DummyIter.next">
<code class="sig-name descname">next</code><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#DummyIter.next"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.DummyIter.next" title="Permalink to this definition">¶</a></dt>
<dd><p>Get a data batch from iterator. The first data batch of real iter is always returned.
StopIteration will never be raised.</p>
<dl class="field-list simple">
<dt class="field-odd">Returns</dt>
<dd class="field-odd"><p>The data of next batch.</p>
</dd>
<dt class="field-even">Return type</dt>
<dd class="field-even"><p><a class="reference internal" href="../io/index.html#mxnet.io.DataBatch" title="mxnet.io.DataBatch">DataBatch</a></p>
</dd>
</dl>
</dd></dl>

</dd></dl>

<dl class="class">
<dt id="mxnet.test_utils.EnvManager">
<em class="property">class </em><code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">EnvManager</code><span class="sig-paren">(</span><em class="sig-param">key</em>, <em class="sig-param">val</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#EnvManager"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.EnvManager" title="Permalink to this definition">¶</a></dt>
<dd><p>Bases: <code class="xref py py-class docutils literal notranslate"><span class="pre">object</span></code></p>
<p>Environment variable setter and unsetter via with idiom</p>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.almost_equal">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">almost_equal</code><span class="sig-paren">(</span><em class="sig-param">a</em>, <em class="sig-param">b</em>, <em class="sig-param">rtol=None</em>, <em class="sig-param">atol=None</em>, <em class="sig-param">equal_nan=False</em>, <em class="sig-param">use_broadcast=True</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#almost_equal"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.almost_equal" title="Permalink to this definition">¶</a></dt>
<dd><p>Test if two numpy arrays are almost equal.</p>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.almost_equal_ignore_nan">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">almost_equal_ignore_nan</code><span class="sig-paren">(</span><em class="sig-param">a</em>, <em class="sig-param">b</em>, <em class="sig-param">rtol=None</em>, <em class="sig-param">atol=None</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#almost_equal_ignore_nan"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.almost_equal_ignore_nan" title="Permalink to this definition">¶</a></dt>
<dd><p>Test that two NumPy arrays are almost equal (ignoring NaN in either array).
Combines a relative and absolute measure of approximate eqality.
If either the relative or absolute check passes, the arrays are considered equal.
Including an absolute check resolves issues with the relative check where all
array values are close to zero.</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>a</strong> (<em>np.ndarray</em>) – </p></li>
<li><p><strong>b</strong> (<em>np.ndarray</em>) – </p></li>
<li><p><strong>rtol</strong> (<em>None</em><em> or </em><em>float</em>) – The relative threshold. Default threshold will be used if set to <code class="docutils literal notranslate"><span class="pre">None</span></code>.</p></li>
<li><p><strong>atol</strong> (<em>None</em><em> or </em><em>float</em>) – The absolute threshold. Default threshold will be used if set to <code class="docutils literal notranslate"><span class="pre">None</span></code>.</p></li>
</ul>
</dd>
</dl>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.assert_almost_equal">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">assert_almost_equal</code><span class="sig-paren">(</span><em class="sig-param">a</em>, <em class="sig-param">b</em>, <em class="sig-param">rtol=None</em>, <em class="sig-param">atol=None</em>, <em class="sig-param">names=('a'</em>, <em class="sig-param">'b')</em>, <em class="sig-param">equal_nan=False</em>, <em class="sig-param">use_broadcast=True</em>, <em class="sig-param">mismatches=(10</em>, <em class="sig-param">10)</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#assert_almost_equal"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.assert_almost_equal" title="Permalink to this definition">¶</a></dt>
<dd><p>Test that two numpy arrays are almost equal. Raise exception message if not.</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>a</strong> (<em>np.ndarray</em><em> or </em><em>mx.nd.array</em>) – </p></li>
<li><p><strong>b</strong> (<em>np.ndarray</em><em> or </em><em>mx.nd.array</em>) – </p></li>
<li><p><strong>rtol</strong> (<em>None</em><em> or </em><em>float</em>) – The relative threshold. Default threshold will be used if set to <code class="docutils literal notranslate"><span class="pre">None</span></code>.</p></li>
<li><p><strong>atol</strong> (<em>None</em><em> or </em><em>float</em>) – The absolute threshold. Default threshold will be used if set to <code class="docutils literal notranslate"><span class="pre">None</span></code>.</p></li>
<li><p><strong>names</strong> (<em>tuple of names</em><em>, </em><em>optional</em>) – The names used in error message when an exception occurs</p></li>
<li><p><strong>equal_nan</strong> (<em>boolean</em><em>, </em><em>optional</em>) – The flag determining how to treat NAN values in comparison</p></li>
<li><p><strong>mismatches</strong> (<em>tuple of mismatches</em>) – Maximum number of mismatches to be printed (mismatches[0]) and determine (mismatches[1])</p></li>
</ul>
</dd>
</dl>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.assert_almost_equal_ignore_nan">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">assert_almost_equal_ignore_nan</code><span class="sig-paren">(</span><em class="sig-param">a</em>, <em class="sig-param">b</em>, <em class="sig-param">rtol=None</em>, <em class="sig-param">atol=None</em>, <em class="sig-param">names=('a'</em>, <em class="sig-param">'b')</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#assert_almost_equal_ignore_nan"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.assert_almost_equal_ignore_nan" title="Permalink to this definition">¶</a></dt>
<dd><p>Test that two NumPy arrays are almost equal (ignoring NaN in either array).
Combines a relative and absolute measure of approximate eqality.
If either the relative or absolute check passes, the arrays are considered equal.
Including an absolute check resolves issues with the relative check where all
array values are close to zero.</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>a</strong> (<em>np.ndarray</em>) – </p></li>
<li><p><strong>b</strong> (<em>np.ndarray</em>) – </p></li>
<li><p><strong>rtol</strong> (<em>None</em><em> or </em><em>float</em>) – The relative threshold. Default threshold will be used if set to <code class="docutils literal notranslate"><span class="pre">None</span></code>.</p></li>
<li><p><strong>atol</strong> (<em>None</em><em> or </em><em>float</em>) – The absolute threshold. Default threshold will be used if set to <code class="docutils literal notranslate"><span class="pre">None</span></code>.</p></li>
</ul>
</dd>
</dl>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.assert_almost_equal_with_err">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">assert_almost_equal_with_err</code><span class="sig-paren">(</span><em class="sig-param">a</em>, <em class="sig-param">b</em>, <em class="sig-param">rtol=None</em>, <em class="sig-param">atol=None</em>, <em class="sig-param">etol=None</em>, <em class="sig-param">names=('a'</em>, <em class="sig-param">'b')</em>, <em class="sig-param">equal_nan=False</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#assert_almost_equal_with_err"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.assert_almost_equal_with_err" title="Permalink to this definition">¶</a></dt>
<dd><p>Test that two numpy arrays are almost equal within given error rate. Raise exception message if not.</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>a</strong> (<em>np.ndarray</em>) – </p></li>
<li><p><strong>b</strong> (<em>np.ndarray</em>) – </p></li>
<li><p><strong>threshold</strong> (<em>None</em><em> or </em><em>float</em>) – The checking threshold. Default threshold will be used if set to <code class="docutils literal notranslate"><span class="pre">None</span></code>.</p></li>
<li><p><strong>etol</strong> (<em>None</em><em> or </em><em>float</em>) – The error rate threshold. If etol is float, return true if error_rate &lt; etol even if
any error is found.</p></li>
</ul>
</dd>
</dl>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.assert_exception">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">assert_exception</code><span class="sig-paren">(</span><em class="sig-param">f</em>, <em class="sig-param">exception_type</em>, <em class="sig-param">*args</em>, <em class="sig-param">**kwargs</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#assert_exception"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.assert_exception" title="Permalink to this definition">¶</a></dt>
<dd><p>Test that function f will throw an exception of type given by <cite>exception_type</cite></p>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.assign_each">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">assign_each</code><span class="sig-paren">(</span><em class="sig-param">the_input</em>, <em class="sig-param">function</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#assign_each"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.assign_each" title="Permalink to this definition">¶</a></dt>
<dd><p>Return ndarray composed of passing each array value through some function</p>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.assign_each2">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">assign_each2</code><span class="sig-paren">(</span><em class="sig-param">input1</em>, <em class="sig-param">input2</em>, <em class="sig-param">function</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#assign_each2"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.assign_each2" title="Permalink to this definition">¶</a></dt>
<dd><p>Return ndarray composed of passing two array values through some function</p>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.check_consistency">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">check_consistency</code><span class="sig-paren">(</span><em class="sig-param">sym</em>, <em class="sig-param">ctx_list</em>, <em class="sig-param">scale=1.0</em>, <em class="sig-param">grad_req='write'</em>, <em class="sig-param">arg_params=None</em>, <em class="sig-param">aux_params=None</em>, <em class="sig-param">tol=None</em>, <em class="sig-param">raise_on_err=True</em>, <em class="sig-param">ground_truth=None</em>, <em class="sig-param">equal_nan=False</em>, <em class="sig-param">use_uniform=False</em>, <em class="sig-param">rand_type=&lt;class 'numpy.float64'&gt;</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#check_consistency"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.check_consistency" title="Permalink to this definition">¶</a></dt>
<dd><p>Check symbol gives the same output for different running context</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>sym</strong> (<a class="reference internal" href="../../symbol/symbol.html#mxnet.symbol.Symbol" title="mxnet.symbol.Symbol"><em>Symbol</em></a><em> or </em><em>list of Symbols</em>) – Symbol(s) to run the consistency test.</p></li>
<li><p><strong>ctx_list</strong> (<em>list</em>) – Running context. See example for more detail.</p></li>
<li><p><strong>scale</strong> (<em>float</em><em>, </em><em>optional</em>) – Standard deviation of the inner normal distribution. Used in initialization.</p></li>
<li><p><strong>grad_req</strong> (<em>str</em><em> or </em><em>list of str</em><em> or </em><em>dict of str to str</em>) – Gradient requirement.</p></li>
<li><p><strong>use_unifrom</strong> (<em>bool</em>) – Optional, When flag set to true,
random input data generated follows uniform distribution,
not normal distribution</p></li>
<li><p><strong>rand_type</strong> (<em>np.dtype</em>) – casts the randomly generated data to this type
Optional, when input data is passed via arg_params,
defaults to np.float64 (numpy float default)</p></li>
</ul>
</dd>
</dl>
<p class="rubric">Examples</p>
<div class="doctest highlight-default notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="c1"># create the symbol</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">sym</span> <span class="o">=</span> <span class="n">mx</span><span class="o">.</span><span class="n">sym</span><span class="o">.</span><span class="n">Convolution</span><span class="p">(</span><span class="n">num_filter</span><span class="o">=</span><span class="mi">3</span><span class="p">,</span> <span class="n">kernel</span><span class="o">=</span><span class="p">(</span><span class="mi">3</span><span class="p">,</span><span class="mi">3</span><span class="p">),</span> <span class="n">name</span><span class="o">=</span><span class="s1">&#39;conv&#39;</span><span class="p">)</span>
<span class="gp">&gt;&gt;&gt; </span><span class="c1"># initialize the running context</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">ctx_list</span> <span class="o">=</span><span class="p">[{</span><span class="s1">&#39;ctx&#39;</span><span class="p">:</span> <span class="n">mx</span><span class="o">.</span><span class="n">gpu</span><span class="p">(</span><span class="mi">0</span><span class="p">),</span> <span class="s1">&#39;conv_data&#39;</span><span class="p">:</span> <span class="p">(</span><span class="mi">2</span><span class="p">,</span> <span class="mi">2</span><span class="p">,</span> <span class="mi">10</span><span class="p">,</span> <span class="mi">10</span><span class="p">),</span> <span class="s1">&#39;type_dict&#39;</span><span class="p">:</span> <span class="p">{</span><span class="s1">&#39;conv_data&#39;</span><span class="p">:</span> <span class="n">np</span><span class="o">.</span><span class="n">float64</span><span class="p">}},</span> <span class="p">{</span><span class="s1">&#39;ctx&#39;</span><span class="p">:</span> <span class="n">mx</span><span class="o">.</span><span class="n">gpu</span><span class="p">(</span><span class="mi">0</span><span class="p">),</span> <span class="s1">&#39;conv_data&#39;</span><span class="p">:</span> <span class="p">(</span><span class="mi">2</span><span class="p">,</span> <span class="mi">2</span><span class="p">,</span> <span class="mi">10</span><span class="p">,</span> <span class="mi">10</span><span class="p">),</span> <span class="s1">&#39;type_dict&#39;</span><span class="p">:</span> <span class="p">{</span><span class="s1">&#39;conv_data&#39;</span><span class="p">:</span> <span class="n">np</span><span class="o">.</span><span class="n">float32</span><span class="p">}},</span> <span class="p">{</span><span class="s1">&#39;ctx&#39;</span><span class="p">:</span> <span class="n">mx</span><span class="o">.</span><span class="n">gpu</span><span class="p">(</span><span class="mi">0</span><span class="p">),</span> <span class="s1">&#39;conv_data&#39;</span><span class="p">:</span> <span class="p">(</span><span class="mi">2</span><span class="p">,</span> <span class="mi">2</span><span class="p">,</span> <span class="mi">10</span><span class="p">,</span> <span class="mi">10</span><span class="p">),</span> <span class="s1">&#39;type_dict&#39;</span><span class="p">:</span> <span class="p">{</span><span class="s1">&#39;conv_data&#39;</span><span class="p">:</span> <span class="n">np</span><span class="o">.</span><span class="n">float16</span><span class="p">}},</span> <span class="p">{</span><span class="s1">&#39;ctx&#39;</span><span class="p">:</span> <span class="n">mx</span><span class="o">.</span><span class="n">cpu</span><span class="p">(</span><span class="mi">0</span><span class="p">),</span> <span class="s1">&#39;conv_data&#39;</span><span class="p">:</span> <span class="p">(</span><span class="mi">2</span><span class="p">,</span> <span class="mi">2</span><span class="p">,</span> <span class="mi">10</span><span class="p">,</span> <span class="mi">10</span><span class="p">),</span> <span class="s1">&#39;type_dict&#39;</span><span class="p">:</span> <span class="p">{</span><span class="s1">&#39;conv_data&#39;</span><span class="p">:</span> <span class="n">np</span><span class="o">.</span><span class="n">float64</span><span class="p">}},</span> <span class="p">{</span><span class="s1">&#39;ctx&#39;</span><span class="p">:</span> <span class="n">mx</span><span class="o">.</span><span class="n">cpu</span><span class="p">(</span><span class="mi">0</span><span class="p">),</span> <span class="s1">&#39;conv_data&#39;</span><span class="p">:</span> <span class="p">(</span><span class="mi">2</span><span class="p">,</span> <span class="mi">2</span><span class="p">,</span> <span class="mi">10</span><span class="p">,</span> <span class="mi">10</span><span class="p">),</span> <span class="s1">&#39;type_dict&#39;</span><span class="p">:</span> <span class="p">{</span><span class="s1">&#39;conv_data&#39;</span><span class="p">:</span> <span class="n">np</span><span class="o">.</span><span class="n">float32</span><span class="p">}}]</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">check_consistency</span><span class="p">(</span><span class="n">sym</span><span class="p">,</span> <span class="n">ctx_list</span><span class="p">)</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">sym</span> <span class="o">=</span> <span class="n">mx</span><span class="o">.</span><span class="n">sym</span><span class="o">.</span><span class="n">Concat</span><span class="p">(</span><span class="n">name</span><span class="o">=</span><span class="s1">&#39;concat&#39;</span><span class="p">,</span> <span class="n">num_args</span><span class="o">=</span><span class="mi">2</span><span class="p">)</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">ctx_list</span> <span class="o">=</span> <span class="p">[{</span><span class="s1">&#39;ctx&#39;</span><span class="p">:</span> <span class="n">mx</span><span class="o">.</span><span class="n">gpu</span><span class="p">(</span><span class="mi">0</span><span class="p">),</span> <span class="s1">&#39;concat_arg1&#39;</span><span class="p">:</span> <span class="p">(</span><span class="mi">2</span><span class="p">,</span> <span class="mi">10</span><span class="p">),</span> <span class="s1">&#39;concat_arg0&#39;</span><span class="p">:</span> <span class="p">(</span><span class="mi">2</span><span class="p">,</span> <span class="mi">10</span><span class="p">),</span>  <span class="s1">&#39;type_dict&#39;</span><span class="p">:</span> <span class="p">{</span><span class="s1">&#39;concat_arg0&#39;</span><span class="p">:</span> <span class="n">np</span><span class="o">.</span><span class="n">float64</span><span class="p">,</span> <span class="s1">&#39;concat_arg1&#39;</span><span class="p">:</span> <span class="n">np</span><span class="o">.</span><span class="n">float64</span><span class="p">}},</span> <span class="p">{</span><span class="s1">&#39;ctx&#39;</span><span class="p">:</span> <span class="n">mx</span><span class="o">.</span><span class="n">gpu</span><span class="p">(</span><span class="mi">0</span><span class="p">),</span> <span class="s1">&#39;concat_arg1&#39;</span><span class="p">:</span> <span class="p">(</span><span class="mi">2</span><span class="p">,</span> <span class="mi">10</span><span class="p">),</span> <span class="s1">&#39;concat_arg0&#39;</span><span class="p">:</span> <span class="p">(</span><span class="mi">2</span><span class="p">,</span> <span class="mi">10</span><span class="p">),</span>  <span class="s1">&#39;type_dict&#39;</span><span class="p">:</span> <span class="p">{</span><span class="s1">&#39;concat_arg0&#39;</span><span class="p">:</span> <span class="n">np</span><span class="o">.</span><span class="n">float32</span><span class="p">,</span> <span class="s1">&#39;concat_arg1&#39;</span><span class="p">:</span> <span class="n">np</span><span class="o">.</span><span class="n">float32</span><span class="p">}},</span> <span class="p">{</span><span class="s1">&#39;ctx&#39;</span><span class="p">:</span> <span class="n">mx</span><span class="o">.</span><span class="n">gpu</span><span class="p">(</span><span class="mi">0</span><span class="p">),</span> <span class="s1">&#39;concat_arg1&#39;</span><span class="p">:</span> <span class="p">(</span><span class="mi">2</span><span class="p">,</span> <span class="mi">10</span><span class="p">),</span> <span class="s1">&#39;concat_arg0&#39;</span><span class="p">:</span> <span class="p">(</span><span class="mi">2</span><span class="p">,</span> <span class="mi">10</span><span class="p">),</span>  <span class="s1">&#39;type_dict&#39;</span><span class="p">:</span> <span class="p">{</span><span class="s1">&#39;concat_arg0&#39;</span><span class="p">:</span> <span class="n">np</span><span class="o">.</span><span class="n">float16</span><span class="p">,</span> <span class="s1">&#39;concat_arg1&#39;</span><span class="p">:</span> <span class="n">np</span><span class="o">.</span><span class="n">float16</span><span class="p">}},</span> <span class="p">{</span><span class="s1">&#39;ctx&#39;</span><span class="p">:</span> <span class="n">mx</span><span class="o">.</span><span class="n">cpu</span><span class="p">(</span><span class="mi">0</span><span class="p">),</span> <span class="s1">&#39;concat_arg1&#39;</span><span class="p">:</span> <span class="p">(</span><span class="mi">2</span><span class="p">,</span> <span class="mi">10</span><span class="p">),</span> <span class="s1">&#39;concat_arg0&#39;</span><span class="p">:</span> <span class="p">(</span><span class="mi">2</span><span class="p">,</span> <span class="mi">10</span><span class="p">),</span>  <span class="s1">&#39;type_dict&#39;</span><span class="p">:</span> <span class="p">{</span><span class="s1">&#39;concat_arg0&#39;</span><span class="p">:</span> <span class="n">np</span><span class="o">.</span><span class="n">float64</span><span class="p">,</span> <span class="s1">&#39;concat_arg1&#39;</span><span class="p">:</span> <span class="n">np</span><span class="o">.</span><span class="n">float64</span><span class="p">}},</span> <span class="p">{</span><span class="s1">&#39;ctx&#39;</span><span class="p">:</span> <span class="n">mx</span><span class="o">.</span><span class="n">cpu</span><span class="p">(</span><span class="mi">0</span><span class="p">),</span> <span class="s1">&#39;concat_arg1&#39;</span><span class="p">:</span> <span class="p">(</span><span class="mi">2</span><span class="p">,</span> <span class="mi">10</span><span class="p">),</span> <span class="s1">&#39;concat_arg0&#39;</span><span class="p">:</span> <span class="p">(</span><span class="mi">2</span><span class="p">,</span> <span class="mi">10</span><span class="p">),</span>  <span class="s1">&#39;type_dict&#39;</span><span class="p">:</span> <span class="p">{</span><span class="s1">&#39;concat_arg0&#39;</span><span class="p">:</span> <span class="n">np</span><span class="o">.</span><span class="n">float32</span><span class="p">,</span> <span class="s1">&#39;concat_arg1&#39;</span><span class="p">:</span> <span class="n">np</span><span class="o">.</span><span class="n">float32</span><span class="p">}}]</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">check_consistency</span><span class="p">(</span><span class="n">sym</span><span class="p">,</span> <span class="n">ctx_list</span><span class="p">)</span>
</pre></div>
</div>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.check_numeric_gradient">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">check_numeric_gradient</code><span class="sig-paren">(</span><em class="sig-param">sym</em>, <em class="sig-param">location</em>, <em class="sig-param">aux_states=None</em>, <em class="sig-param">numeric_eps=0.001</em>, <em class="sig-param">rtol=0.01</em>, <em class="sig-param">atol=None</em>, <em class="sig-param">grad_nodes=None</em>, <em class="sig-param">use_forward_train=True</em>, <em class="sig-param">ctx=None</em>, <em class="sig-param">grad_stype_dict=None</em>, <em class="sig-param">dtype=&lt;class 'numpy.float32'&gt;</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#check_numeric_gradient"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.check_numeric_gradient" title="Permalink to this definition">¶</a></dt>
<dd><p>Verify an operation by checking backward pass via finite difference method.</p>
<p>Based on Theano’s <cite>theano.gradient.verify_grad</cite> [1]</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>sym</strong> (<a class="reference internal" href="../../symbol/symbol.html#mxnet.symbol.Symbol" title="mxnet.symbol.Symbol"><em>Symbol</em></a>) – Symbol containing op to test</p></li>
<li><p><strong>location</strong> (<em>list</em><em> or </em><em>tuple</em><em> or </em><em>dict</em>) – <p>Argument values used as location to compute gradient</p>
<ul>
<li><p>if type is list of numpy.ndarray,             inner elements should have the same order as mxnet.sym.list_arguments().</p></li>
<li><p>if type is dict of str -&gt; numpy.ndarray,             maps the name of arguments to the corresponding numpy.ndarray.</p></li>
</ul>
<p><em>In either case, value of all the arguments must be provided.</em></p>
</p></li>
<li><p><strong>aux_states</strong> (<em>list</em><em> or </em><em>tuple</em><em> or </em><em>dict</em><em>, </em><em>optional</em>) – The auxiliary states required when generating the executor for the symbol.</p></li>
<li><p><strong>numeric_eps</strong> (<em>float</em><em>, </em><em>optional</em>) – Delta for the finite difference method that approximates the gradient.</p></li>
<li><p><strong>check_eps</strong> (<em>float</em><em>, </em><em>optional</em>) – relative error eps used when comparing numeric grad to symbolic grad.</p></li>
<li><p><strong>grad_nodes</strong> (<em>None</em><em> or </em><em>list</em><em> or </em><em>tuple</em><em> or </em><em>dict</em><em>, </em><em>optional</em>) – Names of the nodes to check gradient on</p></li>
<li><p><strong>use_forward_train</strong> (<em>bool</em>) – Whether to use is_train=True when computing the finite-difference.</p></li>
<li><p><strong>ctx</strong> (<a class="reference internal" href="../context/index.html#mxnet.context.Context" title="mxnet.context.Context"><em>Context</em></a><em>, </em><em>optional</em>) – Check the gradient computation on the specified device.</p></li>
<li><p><strong>grad_stype_dict</strong> (<em>dict of str-&gt;str</em><em>, </em><em>optional</em>) – Storage type dictionary for gradient ndarrays.</p></li>
<li><p><strong>dtype</strong> (<em>np.float16</em><em> or </em><em>np.float32</em><em> or </em><em>np.float64</em>) – Datatype for mx.nd.array.</p></li>
</ul>
</dd>
</dl>
<p class="rubric">References</p>
<p>[1] <a class="reference external" href="https://github.com/Theano/Theano/blob/master/theano/gradient.py">https://github.com/Theano/Theano/blob/master/theano/gradient.py</a></p>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.check_speed">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">check_speed</code><span class="sig-paren">(</span><em class="sig-param">sym</em>, <em class="sig-param">location=None</em>, <em class="sig-param">ctx=None</em>, <em class="sig-param">N=20</em>, <em class="sig-param">grad_req=None</em>, <em class="sig-param">typ='whole'</em>, <em class="sig-param">**kwargs</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#check_speed"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.check_speed" title="Permalink to this definition">¶</a></dt>
<dd><p>Check the running speed of a symbol.</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>sym</strong> (<a class="reference internal" href="../../symbol/symbol.html#mxnet.symbol.Symbol" title="mxnet.symbol.Symbol"><em>Symbol</em></a>) – Symbol to run the speed test.</p></li>
<li><p><strong>location</strong> (<em>none</em><em> or </em><em>dict of str to np.ndarray</em>) – Location to evaluate the inner executor.</p></li>
<li><p><strong>ctx</strong> (<a class="reference internal" href="../context/index.html#mxnet.context.Context" title="mxnet.context.Context"><em>Context</em></a>) – Running context.</p></li>
<li><p><strong>N</strong> (<em>int</em><em>, </em><em>optional</em>) – Repeat times.</p></li>
<li><p><strong>grad_req</strong> (<em>None</em><em> or </em><em>str</em><em> or </em><em>list of str</em><em> or </em><em>dict of str to str</em><em>, </em><em>optional</em>) – Gradient requirements.</p></li>
<li><p><strong>typ</strong> (<em>str</em><em>, </em><em>optional</em>) – <p>“whole” or “forward”</p>
<ul>
<li><dl class="simple">
<dt>”whole”</dt><dd><p>Test the forward_backward speed.</p>
</dd>
</dl>
</li>
<li><dl class="simple">
<dt>”forward”</dt><dd><p>Only test the forward speed.</p>
</dd>
</dl>
</li>
</ul>
</p></li>
</ul>
</dd>
</dl>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.check_symbolic_backward">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">check_symbolic_backward</code><span class="sig-paren">(</span><em class="sig-param">sym</em>, <em class="sig-param">location</em>, <em class="sig-param">out_grads</em>, <em class="sig-param">expected</em>, <em class="sig-param">rtol=1e-05</em>, <em class="sig-param">atol=None</em>, <em class="sig-param">aux_states=None</em>, <em class="sig-param">grad_req='write'</em>, <em class="sig-param">ctx=None</em>, <em class="sig-param">grad_stypes=None</em>, <em class="sig-param">equal_nan=False</em>, <em class="sig-param">dtype=&lt;class 'numpy.float32'&gt;</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#check_symbolic_backward"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.check_symbolic_backward" title="Permalink to this definition">¶</a></dt>
<dd><p>Compares a symbol’s backward results with the expected ones.
Prints error messages if the backward results are not the same as the expected results.</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>sym</strong> (<a class="reference internal" href="../../symbol/symbol.html#mxnet.symbol.Symbol" title="mxnet.symbol.Symbol"><em>Symbol</em></a>) – output symbol</p></li>
<li><p><strong>location</strong> (<em>list of np.ndarray</em><em> or </em><em>dict of str to np.ndarray</em>) – <p>The evaluation point</p>
<ul>
<li><dl class="simple">
<dt>if type is list of np.ndarray</dt><dd><p>Contains all the NumPy arrays corresponding to <code class="docutils literal notranslate"><span class="pre">mx.sym.list_arguments</span></code>.</p>
</dd>
</dl>
</li>
<li><dl class="simple">
<dt>if type is dict of str to np.ndarray</dt><dd><p>Contains the mapping between argument names and their values.</p>
</dd>
</dl>
</li>
</ul>
</p></li>
<li><p><strong>out_grads</strong> (<em>None</em><em> or </em><em>list of np.ndarray</em><em> or </em><em>dict of str to np.ndarray</em>) – <p>NumPys arrays corresponding to sym.outputs for incomming gradient.</p>
<ul>
<li><dl class="simple">
<dt>if type is list of np.ndarray</dt><dd><p>Contains arrays corresponding to <code class="docutils literal notranslate"><span class="pre">exe.outputs</span></code>.</p>
</dd>
</dl>
</li>
<li><dl class="simple">
<dt>if type is dict of str to np.ndarray</dt><dd><p>contains mapping between mxnet.sym.list_output() and Executor.outputs</p>
</dd>
</dl>
</li>
</ul>
</p></li>
<li><p><strong>expected</strong> (<em>list of np.ndarray</em><em> or </em><em>dict of str to np.ndarray</em>) – <p>expected gradient values</p>
<ul>
<li><dl class="simple">
<dt>if type is list of np.ndarray</dt><dd><p>Contains arrays corresponding to exe.grad_arrays</p>
</dd>
</dl>
</li>
<li><dl class="simple">
<dt>if type is dict of str to np.ndarray</dt><dd><p>Contains mapping between <code class="docutils literal notranslate"><span class="pre">sym.list_arguments()</span></code> and exe.outputs.</p>
</dd>
</dl>
</li>
</ul>
</p></li>
<li><p><strong>check_eps</strong> (<em>float</em><em>, </em><em>optional</em>) – Relative error to check to.</p></li>
<li><p><strong>aux_states</strong> (<em>list of np.ndarray</em><em> or </em><em>dict of str to np.ndarray</em>) – </p></li>
<li><p><strong>grad_req</strong> (<em>str</em><em> or </em><em>list of str</em><em> or </em><em>dict of str to str</em><em>, </em><em>optional</em>) – Gradient requirements. ‘write’, ‘add’ or ‘null’.</p></li>
<li><p><strong>ctx</strong> (<a class="reference internal" href="../context/index.html#mxnet.context.Context" title="mxnet.context.Context"><em>Context</em></a><em>, </em><em>optional</em>) – Running context.</p></li>
<li><p><strong>grad_stypes</strong> (<em>dict of str-&gt;str</em>) – dictionary of mapping argument name to stype for the gradient</p></li>
<li><p><strong>equal_nan</strong> (<em>Boolean</em>) – if True, <cite>nan</cite> is a valid value for checking equivalency (ie <cite>nan</cite> == <cite>nan</cite>)</p></li>
<li><p><strong>dtype</strong> (<em>np.float16</em><em> or </em><em>np.float32</em><em> or </em><em>np.float64</em>) – Datatype for mx.nd.array.</p></li>
</ul>
</dd>
</dl>
<p class="rubric">Example</p>
<div class="doctest highlight-default notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="n">lhs</span> <span class="o">=</span> <span class="n">mx</span><span class="o">.</span><span class="n">symbol</span><span class="o">.</span><span class="n">Variable</span><span class="p">(</span><span class="s1">&#39;lhs&#39;</span><span class="p">)</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">rhs</span> <span class="o">=</span> <span class="n">mx</span><span class="o">.</span><span class="n">symbol</span><span class="o">.</span><span class="n">Variable</span><span class="p">(</span><span class="s1">&#39;rhs&#39;</span><span class="p">)</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">sym_add</span> <span class="o">=</span> <span class="n">mx</span><span class="o">.</span><span class="n">symbol</span><span class="o">.</span><span class="n">elemwise_add</span><span class="p">(</span><span class="n">lhs</span><span class="p">,</span> <span class="n">rhs</span><span class="p">)</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">mat1</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">array</span><span class="p">([[</span><span class="mi">1</span><span class="p">,</span> <span class="mi">2</span><span class="p">],</span> <span class="p">[</span><span class="mi">3</span><span class="p">,</span> <span class="mi">4</span><span class="p">]])</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">mat2</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">array</span><span class="p">([[</span><span class="mi">5</span><span class="p">,</span> <span class="mi">6</span><span class="p">],</span> <span class="p">[</span><span class="mi">7</span><span class="p">,</span> <span class="mi">8</span><span class="p">]])</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">grad1</span> <span class="o">=</span> <span class="n">mx</span><span class="o">.</span><span class="n">nd</span><span class="o">.</span><span class="n">zeros</span><span class="p">(</span><span class="n">shape</span><span class="p">)</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">grad2</span> <span class="o">=</span> <span class="n">mx</span><span class="o">.</span><span class="n">nd</span><span class="o">.</span><span class="n">zeros</span><span class="p">(</span><span class="n">shape</span><span class="p">)</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">exec_add</span> <span class="o">=</span> <span class="n">sym_add</span><span class="o">.</span><span class="n">bind</span><span class="p">(</span><span class="n">default_context</span><span class="p">(),</span> <span class="n">args</span><span class="o">=</span><span class="p">{</span><span class="s1">&#39;lhs&#39;</span><span class="p">:</span> <span class="n">mat1</span><span class="p">,</span> <span class="s1">&#39;rhs&#39;</span><span class="p">:</span> <span class="n">mat2</span><span class="p">},</span>
<span class="gp">... </span><span class="n">args_grad</span><span class="o">=</span><span class="p">{</span><span class="s1">&#39;lhs&#39;</span><span class="p">:</span> <span class="n">grad1</span><span class="p">,</span> <span class="s1">&#39;rhs&#39;</span><span class="p">:</span> <span class="n">grad2</span><span class="p">},</span> <span class="n">grad_req</span><span class="o">=</span><span class="p">{</span><span class="s1">&#39;lhs&#39;</span><span class="p">:</span> <span class="s1">&#39;write&#39;</span><span class="p">,</span> <span class="s1">&#39;rhs&#39;</span><span class="p">:</span> <span class="s1">&#39;write&#39;</span><span class="p">})</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">exec_add</span><span class="o">.</span><span class="n">forward</span><span class="p">(</span><span class="n">is_train</span><span class="o">=</span><span class="kc">True</span><span class="p">)</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">ograd</span> <span class="o">=</span> <span class="n">mx</span><span class="o">.</span><span class="n">nd</span><span class="o">.</span><span class="n">ones</span><span class="p">(</span><span class="n">shape</span><span class="p">)</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">grad_expected</span> <span class="o">=</span> <span class="n">ograd</span><span class="o">.</span><span class="n">copy</span><span class="p">()</span><span class="o">.</span><span class="n">asnumpy</span><span class="p">()</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">check_symbolic_backward</span><span class="p">(</span><span class="n">sym_add</span><span class="p">,</span> <span class="p">[</span><span class="n">mat1</span><span class="p">,</span> <span class="n">mat2</span><span class="p">],</span> <span class="p">[</span><span class="n">ograd</span><span class="p">],</span> <span class="p">[</span><span class="n">grad_expected</span><span class="p">,</span> <span class="n">grad_expected</span><span class="p">])</span>
</pre></div>
</div>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.check_symbolic_forward">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">check_symbolic_forward</code><span class="sig-paren">(</span><em class="sig-param">sym</em>, <em class="sig-param">location</em>, <em class="sig-param">expected</em>, <em class="sig-param">rtol=0.0001</em>, <em class="sig-param">atol=None</em>, <em class="sig-param">aux_states=None</em>, <em class="sig-param">ctx=None</em>, <em class="sig-param">equal_nan=False</em>, <em class="sig-param">dtype=&lt;class 'numpy.float32'&gt;</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#check_symbolic_forward"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.check_symbolic_forward" title="Permalink to this definition">¶</a></dt>
<dd><p>Compares a symbol’s forward results with the expected ones.
Prints error messages if the forward results are not the same as the expected ones.</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>sym</strong> (<a class="reference internal" href="../../symbol/symbol.html#mxnet.symbol.Symbol" title="mxnet.symbol.Symbol"><em>Symbol</em></a>) – output symbol</p></li>
<li><p><strong>location</strong> (<em>list of np.ndarray</em><em> or </em><em>dict of str to np.ndarray</em>) – <p>The evaluation point</p>
<ul>
<li><dl class="simple">
<dt>if type is list of np.ndarray</dt><dd><p>Contains all the numpy arrays corresponding to <cite>sym.list_arguments()</cite>.</p>
</dd>
</dl>
</li>
<li><dl class="simple">
<dt>if type is dict of str to np.ndarray</dt><dd><p>Contains the mapping between argument names and their values.</p>
</dd>
</dl>
</li>
</ul>
</p></li>
<li><p><strong>expected</strong> (<em>list of np.ndarray</em><em> or </em><em>dict of str to np.ndarray</em>) – <p>The expected output value</p>
<ul>
<li><dl class="simple">
<dt>if type is list of np.ndarray</dt><dd><p>Contains arrays corresponding to exe.outputs.</p>
</dd>
</dl>
</li>
<li><dl class="simple">
<dt>if type is dict of str to np.ndarray</dt><dd><p>Contains mapping between sym.list_output() and exe.outputs.</p>
</dd>
</dl>
</li>
</ul>
</p></li>
<li><p><strong>check_eps</strong> (<em>float</em><em>, </em><em>optional</em>) – Relative error to check to.</p></li>
<li><p><strong>aux_states</strong> (<em>list of np.ndarray of dict</em><em>, </em><em>optional</em>) – <ul>
<li><dl class="simple">
<dt>if type is list of np.ndarray</dt><dd><p>Contains all the NumPy arrays corresponding to sym.list_auxiliary_states</p>
</dd>
</dl>
</li>
<li><dl class="simple">
<dt>if type is dict of str to np.ndarray</dt><dd><p>Contains the mapping between names of auxiliary states and their values.</p>
</dd>
</dl>
</li>
</ul>
</p></li>
<li><p><strong>ctx</strong> (<a class="reference internal" href="../context/index.html#mxnet.context.Context" title="mxnet.context.Context"><em>Context</em></a><em>, </em><em>optional</em>) – running context</p></li>
<li><p><strong>dtype</strong> (<em>&quot;asnumpy&quot;</em><em> or </em><em>np.float16</em><em> or </em><em>np.float32</em><em> or </em><em>np.float64</em>) – If dtype is “asnumpy” then the mx.nd.array created will have the same
type as th numpy array from which it is copied.
Otherwise, dtype is the explicit datatype for all mx.nd.array objects
created in this function.</p></li>
<li><p><strong>equal_nan</strong> (<em>Boolean</em>) – if True, <cite>nan</cite> is a valid value for checking equivalency (ie <cite>nan</cite> == <cite>nan</cite>)</p></li>
</ul>
</dd>
</dl>
<p class="rubric">Example</p>
<div class="doctest highlight-default notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="n">shape</span> <span class="o">=</span> <span class="p">(</span><span class="mi">2</span><span class="p">,</span> <span class="mi">2</span><span class="p">)</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">lhs</span> <span class="o">=</span> <span class="n">mx</span><span class="o">.</span><span class="n">symbol</span><span class="o">.</span><span class="n">Variable</span><span class="p">(</span><span class="s1">&#39;lhs&#39;</span><span class="p">)</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">rhs</span> <span class="o">=</span> <span class="n">mx</span><span class="o">.</span><span class="n">symbol</span><span class="o">.</span><span class="n">Variable</span><span class="p">(</span><span class="s1">&#39;rhs&#39;</span><span class="p">)</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">sym_dot</span> <span class="o">=</span> <span class="n">mx</span><span class="o">.</span><span class="n">symbol</span><span class="o">.</span><span class="n">dot</span><span class="p">(</span><span class="n">lhs</span><span class="p">,</span> <span class="n">rhs</span><span class="p">)</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">mat1</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">array</span><span class="p">([[</span><span class="mi">1</span><span class="p">,</span> <span class="mi">2</span><span class="p">],</span> <span class="p">[</span><span class="mi">3</span><span class="p">,</span> <span class="mi">4</span><span class="p">]])</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">mat2</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">array</span><span class="p">([[</span><span class="mi">5</span><span class="p">,</span> <span class="mi">6</span><span class="p">],</span> <span class="p">[</span><span class="mi">7</span><span class="p">,</span> <span class="mi">8</span><span class="p">]])</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">ret_expected</span> <span class="o">=</span> <span class="n">np</span><span class="o">.</span><span class="n">array</span><span class="p">([[</span><span class="mi">19</span><span class="p">,</span> <span class="mi">22</span><span class="p">],</span> <span class="p">[</span><span class="mi">43</span><span class="p">,</span> <span class="mi">50</span><span class="p">]])</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">check_symbolic_forward</span><span class="p">(</span><span class="n">sym_dot</span><span class="p">,</span> <span class="p">[</span><span class="n">mat1</span><span class="p">,</span> <span class="n">mat2</span><span class="p">],</span> <span class="p">[</span><span class="n">ret_expected</span><span class="p">])</span>
</pre></div>
</div>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.chi_square_check">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">chi_square_check</code><span class="sig-paren">(</span><em class="sig-param">generator</em>, <em class="sig-param">buckets</em>, <em class="sig-param">probs</em>, <em class="sig-param">nsamples=1000000</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#chi_square_check"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.chi_square_check" title="Permalink to this definition">¶</a></dt>
<dd><p>Run the chi-square test for the generator. The generator can be both continuous and discrete.</p>
<p>If the generator is continuous, the buckets should contain tuples of (range_min, range_max)     and the probs should be the corresponding ideal probability within the specific ranges.     Otherwise, the buckets should contain all the possible values generated over the discrete distribution and the     probs should be groud-truth probability.</p>
<p>Usually the user is required to specify the probs parameter.</p>
<p>After obtaining the p value, we could further use the standard p &gt; 0.05 (alpha) threshold to get     the final result.</p>
<p>Examples:</p>
<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">buckets</span><span class="p">,</span> <span class="n">probs</span> <span class="o">=</span> <span class="n">gen_buckets_probs_with_ppf</span><span class="p">(</span><span class="k">lambda</span> <span class="n">x</span><span class="p">:</span> <span class="n">ss</span><span class="o">.</span><span class="n">norm</span><span class="o">.</span><span class="n">ppf</span><span class="p">(</span><span class="n">x</span><span class="p">,</span> <span class="mi">0</span><span class="p">,</span> <span class="mi">1</span><span class="p">),</span> <span class="mi">5</span><span class="p">)</span>
<span class="n">generator</span> <span class="o">=</span> <span class="k">lambda</span> <span class="n">x</span><span class="p">:</span> <span class="n">np</span><span class="o">.</span><span class="n">random</span><span class="o">.</span><span class="n">normal</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span> <span class="mf">1.0</span><span class="p">,</span> <span class="n">size</span><span class="o">=</span><span class="n">x</span><span class="p">)</span>
<span class="n">p</span> <span class="o">=</span> <span class="n">chi_square_check</span><span class="p">(</span><span class="n">generator</span><span class="o">=</span><span class="n">generator</span><span class="p">,</span> <span class="n">buckets</span><span class="o">=</span><span class="n">buckets</span><span class="p">,</span> <span class="n">probs</span><span class="o">=</span><span class="n">probs</span><span class="p">)</span>
<span class="k">assert</span><span class="p">(</span><span class="n">p</span> <span class="o">&gt;</span> <span class="mf">0.05</span><span class="p">)</span>
</pre></div>
</div>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>generator</strong> (<em>function</em>) – A function that is assumed to generate i.i.d samples from a specific distribution.
generator(N) should generate N random samples.</p></li>
<li><p><strong>buckets</strong> (<em>list of tuple</em><em> or </em><em>list of number</em>) – The buckets to run the chi-square the test. Make sure that the buckets cover
the whole range of the distribution. Also, the buckets must be in ascending order and have
no intersection</p></li>
<li><p><strong>probs</strong> (<em>list</em><em> or </em><em>tuple</em>) – The ground-truth probability of the random value fall in a specific bucket.</p></li>
<li><p><strong>nsamples</strong> (<em>int</em>) – The number of samples to generate for the testing</p></li>
</ul>
</dd>
<dt class="field-even">Returns</dt>
<dd class="field-even"><p><ul class="simple">
<li><p><strong>p</strong> (<em>float</em>) – p value that the generator has the expected distribution.
A higher value indicates a larger confidence</p></li>
<li><p><strong>obs_freq</strong> (<em>list</em>) – Observed frequency of buckets</p></li>
<li><p><strong>expected_freq</strong> (<em>list</em>) – The expected (ground-truth) frequency of the buckets</p></li>
</ul>
</p>
</dd>
</dl>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.collapse_sum_like">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">collapse_sum_like</code><span class="sig-paren">(</span><em class="sig-param">a</em>, <em class="sig-param">shape</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#collapse_sum_like"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.collapse_sum_like" title="Permalink to this definition">¶</a></dt>
<dd><p>Given <cite>a</cite> as a numpy ndarray, perform reduce_sum on <cite>a</cite> over the axes that do not
exist in <cite>shape</cite>. Note that an ndarray with <cite>shape</cite> must be broadcastable to <cite>a</cite>.</p>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.compare_ndarray_tuple">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">compare_ndarray_tuple</code><span class="sig-paren">(</span><em class="sig-param">t1</em>, <em class="sig-param">t2</em>, <em class="sig-param">rtol=None</em>, <em class="sig-param">atol=None</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#compare_ndarray_tuple"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.compare_ndarray_tuple" title="Permalink to this definition">¶</a></dt>
<dd><p>Compare ndarray tuple.</p>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.compare_optimizer">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">compare_optimizer</code><span class="sig-paren">(</span><em class="sig-param">opt1</em>, <em class="sig-param">opt2</em>, <em class="sig-param">shape</em>, <em class="sig-param">dtype</em>, <em class="sig-param">w_stype='default'</em>, <em class="sig-param">g_stype='default'</em>, <em class="sig-param">rtol=0.0001</em>, <em class="sig-param">atol=1e-05</em>, <em class="sig-param">compare_states=True</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#compare_optimizer"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.compare_optimizer" title="Permalink to this definition">¶</a></dt>
<dd><p>Compare opt1 and opt2.</p>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.create_sparse_array">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">create_sparse_array</code><span class="sig-paren">(</span><em class="sig-param">shape</em>, <em class="sig-param">stype</em>, <em class="sig-param">data_init=None</em>, <em class="sig-param">rsp_indices=None</em>, <em class="sig-param">dtype=None</em>, <em class="sig-param">modifier_func=None</em>, <em class="sig-param">density=0.5</em>, <em class="sig-param">shuffle_csr_indices=False</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#create_sparse_array"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.create_sparse_array" title="Permalink to this definition">¶</a></dt>
<dd><p>Create a sparse array, For Rsp, assure indices are in a canonical format</p>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.create_sparse_array_zd">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">create_sparse_array_zd</code><span class="sig-paren">(</span><em class="sig-param">shape</em>, <em class="sig-param">stype</em>, <em class="sig-param">density</em>, <em class="sig-param">data_init=None</em>, <em class="sig-param">rsp_indices=None</em>, <em class="sig-param">dtype=None</em>, <em class="sig-param">modifier_func=None</em>, <em class="sig-param">shuffle_csr_indices=False</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#create_sparse_array_zd"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.create_sparse_array_zd" title="Permalink to this definition">¶</a></dt>
<dd><p>Create sparse array, using only rsp_indices to determine density</p>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.default_context">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">default_context</code><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#default_context"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.default_context" title="Permalink to this definition">¶</a></dt>
<dd><p>Get default context for regression test.</p>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.default_dtype">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">default_dtype</code><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#default_dtype"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.default_dtype" title="Permalink to this definition">¶</a></dt>
<dd><p>Get default data type for regression test.</p>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.discard_stderr">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">discard_stderr</code><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#discard_stderr"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.discard_stderr" title="Permalink to this definition">¶</a></dt>
<dd><p>Discards error output of a routine if invoked as:</p>
<dl class="simple">
<dt>with discard_stderr():</dt><dd><p>…</p>
</dd>
</dl>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.download">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">download</code><span class="sig-paren">(</span><em class="sig-param">url</em>, <em class="sig-param">fname=None</em>, <em class="sig-param">dirname=None</em>, <em class="sig-param">overwrite=False</em>, <em class="sig-param">retries=5</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#download"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.download" title="Permalink to this definition">¶</a></dt>
<dd><p>Download an given URL</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>url</strong> (<em>str</em>) – URL to download</p></li>
<li><p><strong>fname</strong> (<em>str</em><em>, </em><em>optional</em>) – filename of the downloaded file. If None, then will guess a filename
from url.</p></li>
<li><p><strong>dirname</strong> (<em>str</em><em>, </em><em>optional</em>) – output directory name. If None, then guess from fname or use the current
directory</p></li>
<li><p><strong>overwrite</strong> (<em>bool</em><em>, </em><em>optional</em>) – Default is false, which means skipping download if the local file
exists. If true, then download the url to overwrite the local file if
exists.</p></li>
<li><p><strong>retries</strong> (<em>integer</em><em>, </em><em>default 5</em>) – The number of times to attempt the download in case of failure or non 200 return codes</p></li>
</ul>
</dd>
<dt class="field-even">Returns</dt>
<dd class="field-even"><p>The filename of the downloaded file</p>
</dd>
<dt class="field-odd">Return type</dt>
<dd class="field-odd"><p>str</p>
</dd>
</dl>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.download_model">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">download_model</code><span class="sig-paren">(</span><em class="sig-param">model_name</em>, <em class="sig-param">dst_dir='./'</em>, <em class="sig-param">meta_info=None</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#download_model"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.download_model" title="Permalink to this definition">¶</a></dt>
<dd><p>Download a model from data.mxnet.io</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>model_name</strong> (<em>str</em>) – Model name to download</p></li>
<li><p><strong>dst_dir</strong> (<em>str</em>) – Destination Directory to download the model</p></li>
<li><p><strong>meta_info</strong> (<em>dict of dict</em>) – Mapping from model_name to dict of the following structure:
{‘symbol’: url, ‘params’: url}</p></li>
</ul>
</dd>
<dt class="field-even">Returns</dt>
<dd class="field-even"><p></p>
</dd>
<dt class="field-odd">Return type</dt>
<dd class="field-odd"><p>Two element tuple containing model_name and epoch for the params saved</p>
</dd>
</dl>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.find_max_violation">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">find_max_violation</code><span class="sig-paren">(</span><em class="sig-param">a</em>, <em class="sig-param">b</em>, <em class="sig-param">rtol=None</em>, <em class="sig-param">atol=None</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#find_max_violation"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.find_max_violation" title="Permalink to this definition">¶</a></dt>
<dd><p>Finds and returns the location of maximum violation.</p>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.gen_buckets_probs_with_ppf">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">gen_buckets_probs_with_ppf</code><span class="sig-paren">(</span><em class="sig-param">ppf</em>, <em class="sig-param">nbuckets</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#gen_buckets_probs_with_ppf"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.gen_buckets_probs_with_ppf" title="Permalink to this definition">¶</a></dt>
<dd><dl class="simple">
<dt>Generate the buckets and probabilities for chi_square test when the ppf (Quantile function)</dt><dd><p>is specified.</p>
</dd>
</dl>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>ppf</strong> (<em>function</em>) – The Quantile function that takes a probability and maps it back to a value.
It’s the inverse of the cdf function</p></li>
<li><p><strong>nbuckets</strong> (<em>int</em>) – size of the buckets</p></li>
</ul>
</dd>
<dt class="field-even">Returns</dt>
<dd class="field-even"><p><ul class="simple">
<li><p><strong>buckets</strong> (<em>list of tuple</em>) – The generated buckets</p></li>
<li><p><strong>probs</strong> (<em>list</em>) – The generate probabilities</p></li>
</ul>
</p>
</dd>
</dl>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.get_atol">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">get_atol</code><span class="sig-paren">(</span><em class="sig-param">atol=None</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#get_atol"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.get_atol" title="Permalink to this definition">¶</a></dt>
<dd><p>Get default numerical threshold for regression test.</p>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.get_bz2_data">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">get_bz2_data</code><span class="sig-paren">(</span><em class="sig-param">data_dir</em>, <em class="sig-param">data_name</em>, <em class="sig-param">url</em>, <em class="sig-param">data_origin_name</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#get_bz2_data"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.get_bz2_data" title="Permalink to this definition">¶</a></dt>
<dd><p>Download and extract bz2 data.</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>data_dir</strong> (<em>str</em>) – Absolute or relative path of the directory name to store bz2 files</p></li>
<li><p><strong>data_name</strong> (<em>str</em>) – Name of the output file in which bz2 contents will be extracted</p></li>
<li><p><strong>url</strong> (<em>str</em>) – URL to download data from</p></li>
<li><p><strong>data_origin_name</strong> (<em>str</em>) – Name of the downloaded b2 file</p></li>
</ul>
</dd>
</dl>
<p class="rubric">Examples</p>
<div class="doctest highlight-default notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="n">get_bz2_data</span><span class="p">(</span><span class="s2">&quot;data_dir&quot;</span><span class="p">,</span> <span class="s2">&quot;kdda.t&quot;</span><span class="p">,</span>
<span class="go">                 &quot;https://www.csie.ntu.edu.tw/~cjlin/libsvmtools/datasets/binary/kdda.t.bz2&quot;,</span>
<span class="go">                 &quot;kdda.t.bz2&quot;)</span>
</pre></div>
</div>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.get_cifar10">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">get_cifar10</code><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#get_cifar10"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.get_cifar10" title="Permalink to this definition">¶</a></dt>
<dd><p>Downloads CIFAR10 dataset into a directory in the current directory with the name <cite>data</cite>,
and then extracts all files into the directory <cite>data/cifar</cite>.</p>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.get_etol">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">get_etol</code><span class="sig-paren">(</span><em class="sig-param">etol=None</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#get_etol"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.get_etol" title="Permalink to this definition">¶</a></dt>
<dd><p>Get default numerical threshold for regression test.</p>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.get_im2rec_path">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">get_im2rec_path</code><span class="sig-paren">(</span><em class="sig-param">home_env='MXNET_HOME'</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#get_im2rec_path"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.get_im2rec_path" title="Permalink to this definition">¶</a></dt>
<dd><p>Get path to the im2rec.py tool</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><p><strong>home_env</strong> (<em>str</em>) – Env variable that holds the path to the MXNET folder</p>
</dd>
<dt class="field-even">Returns</dt>
<dd class="field-even"><p>The path to im2rec.py</p>
</dd>
<dt class="field-odd">Return type</dt>
<dd class="field-odd"><p>str</p>
</dd>
</dl>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.get_mnist">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">get_mnist</code><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#get_mnist"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.get_mnist" title="Permalink to this definition">¶</a></dt>
<dd><p>Download and load the MNIST dataset</p>
<dl class="field-list simple">
<dt class="field-odd">Returns</dt>
<dd class="field-odd"><p>A dict containing the data</p>
</dd>
<dt class="field-even">Return type</dt>
<dd class="field-even"><p>dict</p>
</dd>
</dl>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.get_mnist_iterator">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">get_mnist_iterator</code><span class="sig-paren">(</span><em class="sig-param">batch_size</em>, <em class="sig-param">input_shape</em>, <em class="sig-param">num_parts=1</em>, <em class="sig-param">part_index=0</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#get_mnist_iterator"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.get_mnist_iterator" title="Permalink to this definition">¶</a></dt>
<dd><p>Returns training and validation iterators for MNIST dataset</p>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.get_mnist_pkl">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">get_mnist_pkl</code><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#get_mnist_pkl"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.get_mnist_pkl" title="Permalink to this definition">¶</a></dt>
<dd><p>Downloads MNIST dataset as a pkl.gz into a directory in the current directory
with the name <cite>data</cite></p>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.get_mnist_ubyte">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">get_mnist_ubyte</code><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#get_mnist_ubyte"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.get_mnist_ubyte" title="Permalink to this definition">¶</a></dt>
<dd><p>Downloads ubyte version of the MNIST dataset into a directory in the current directory
with the name <cite>data</cite> and extracts all files in the zip archive to this directory.</p>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.get_rtol">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">get_rtol</code><span class="sig-paren">(</span><em class="sig-param">rtol=None</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#get_rtol"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.get_rtol" title="Permalink to this definition">¶</a></dt>
<dd><p>Get default numerical threshold for regression test.</p>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.get_zip_data">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">get_zip_data</code><span class="sig-paren">(</span><em class="sig-param">data_dir</em>, <em class="sig-param">url</em>, <em class="sig-param">data_origin_name</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#get_zip_data"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.get_zip_data" title="Permalink to this definition">¶</a></dt>
<dd><p>Download and extract zip data.</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>data_dir</strong> (<em>str</em>) – Absolute or relative path of the directory name to store zip files</p></li>
<li><p><strong>url</strong> (<em>str</em>) – URL to download data from</p></li>
<li><p><strong>data_origin_name</strong> (<em>str</em>) – Name of the downloaded zip file</p></li>
</ul>
</dd>
</dl>
<p class="rubric">Examples</p>
<div class="doctest highlight-default notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="n">get_zip_data</span><span class="p">(</span><span class="s2">&quot;data_dir&quot;</span><span class="p">,</span>
<span class="go">                 &quot;http://files.grouplens.org/datasets/movielens/ml-10m.zip&quot;,</span>
<span class="go">                 &quot;ml-10m.zip&quot;)</span>
</pre></div>
</div>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.has_tvm_ops">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">has_tvm_ops</code><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#has_tvm_ops"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.has_tvm_ops" title="Permalink to this definition">¶</a></dt>
<dd><p>Returns True if MXNet is compiled with TVM generated operators. If current ctx
is GPU, it only returns True for CUDA compute capability &gt; 52 where FP16 is supported.</p>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.is_cd_run">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">is_cd_run</code><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#is_cd_run"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.is_cd_run" title="Permalink to this definition">¶</a></dt>
<dd><p>Checks if the test is running as part of a Continuous Delivery run</p>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.is_op_runnable">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">is_op_runnable</code><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#is_op_runnable"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.is_op_runnable" title="Permalink to this definition">¶</a></dt>
<dd><p>Returns True for all CPU tests. Returns True for GPU tests that are either of the following.
1. Built with USE_TVM_OP=0.
2. Built with USE_TVM_OP=1, but with compute capability &gt;= 53.</p>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.list_gpus">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">list_gpus</code><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#list_gpus"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.list_gpus" title="Permalink to this definition">¶</a></dt>
<dd><p>Return a list of GPUs</p>
<dl class="field-list simple">
<dt class="field-odd">Returns</dt>
<dd class="field-odd"><p>If there are n GPUs, then return a list [0,1,…,n-1]. Otherwise returns
[].</p>
</dd>
<dt class="field-even">Return type</dt>
<dd class="field-even"><p>list of int</p>
</dd>
</dl>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.mean_check">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">mean_check</code><span class="sig-paren">(</span><em class="sig-param">generator</em>, <em class="sig-param">mu</em>, <em class="sig-param">sigma</em>, <em class="sig-param">nsamples=1000000</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#mean_check"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.mean_check" title="Permalink to this definition">¶</a></dt>
<dd><p>Test the generator by matching the mean.</p>
<dl class="simple">
<dt>We test the sample mean by checking if it falls inside the range</dt><dd><p>(mu - 3 * sigma / sqrt(n), mu + 3 * sigma / sqrt(n))</p>
</dd>
</dl>
<p>References:</p>
<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="nd">@incollection</span><span class="p">{</span><span class="n">goucher2009beautiful</span><span class="p">,</span>
      <span class="n">title</span><span class="o">=</span><span class="p">{</span><span class="n">Beautiful</span> <span class="n">Testing</span><span class="p">:</span> <span class="n">Leading</span> <span class="n">Professionals</span> <span class="n">Reveal</span> <span class="n">How</span> <span class="n">They</span> <span class="n">Improve</span> <span class="n">Software</span><span class="p">},</span>
      <span class="n">author</span><span class="o">=</span><span class="p">{</span><span class="n">Goucher</span><span class="p">,</span> <span class="n">Adam</span> <span class="ow">and</span> <span class="n">Riley</span><span class="p">,</span> <span class="n">Tim</span><span class="p">},</span>
      <span class="n">year</span><span class="o">=</span><span class="p">{</span><span class="mi">2009</span><span class="p">},</span>
      <span class="n">chapter</span><span class="o">=</span><span class="mi">10</span>
<span class="p">}</span>
</pre></div>
</div>
<p>Examples:</p>
<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">generator</span> <span class="o">=</span> <span class="k">lambda</span> <span class="n">x</span><span class="p">:</span> <span class="n">np</span><span class="o">.</span><span class="n">random</span><span class="o">.</span><span class="n">normal</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span> <span class="mf">1.0</span><span class="p">,</span> <span class="n">size</span><span class="o">=</span><span class="n">x</span><span class="p">)</span>
<span class="n">mean_check_ret</span> <span class="o">=</span> <span class="n">mean_check</span><span class="p">(</span><span class="n">generator</span><span class="p">,</span> <span class="mi">0</span><span class="p">,</span> <span class="mf">1.0</span><span class="p">)</span>
</pre></div>
</div>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>generator</strong> (<em>function</em>) – The generator function. It’s expected to generate N i.i.d samples by calling generator(N).</p></li>
<li><p><strong>mu</strong> (<em>float</em>) – </p></li>
<li><p><strong>sigma</strong> (<em>float</em>) – </p></li>
<li><p><strong>nsamples</strong> (<em>int</em>) – </p></li>
</ul>
</dd>
<dt class="field-even">Returns</dt>
<dd class="field-even"><p><strong>ret</strong> – Whether the mean test succeeds</p>
</dd>
<dt class="field-odd">Return type</dt>
<dd class="field-odd"><p>bool</p>
</dd>
</dl>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.np_reduce">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">np_reduce</code><span class="sig-paren">(</span><em class="sig-param">dat</em>, <em class="sig-param">axis</em>, <em class="sig-param">keepdims</em>, <em class="sig-param">numpy_reduce_func</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#np_reduce"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.np_reduce" title="Permalink to this definition">¶</a></dt>
<dd><p>Compatible reduce for old version of NumPy.</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>dat</strong> (<em>np.ndarray</em>) – Same as NumPy.</p></li>
<li><p><strong>axis</strong> (<em>None</em><em> or </em><em>int</em><em> or </em><em>list-like</em>) – Same as NumPy.</p></li>
<li><p><strong>keepdims</strong> (<em>bool</em>) – Same as NumPy.</p></li>
<li><p><strong>numpy_reduce_func</strong> (<em>function</em>) – A NumPy reducing function like <code class="docutils literal notranslate"><span class="pre">np.sum</span></code> or <code class="docutils literal notranslate"><span class="pre">np.max</span></code>.</p></li>
</ul>
</dd>
</dl>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.numeric_grad">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">numeric_grad</code><span class="sig-paren">(</span><em class="sig-param">executor</em>, <em class="sig-param">location</em>, <em class="sig-param">aux_states=None</em>, <em class="sig-param">eps=0.0001</em>, <em class="sig-param">use_forward_train=True</em>, <em class="sig-param">dtype=&lt;class 'numpy.float32'&gt;</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#numeric_grad"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.numeric_grad" title="Permalink to this definition">¶</a></dt>
<dd><p>Calculates a numeric gradient via finite difference method.</p>
<p>Class based on Theano’s <cite>theano.gradient.numeric_grad</cite> [1]</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>executor</strong> (<a class="reference internal" href="../executor/index.html#mxnet.executor.Executor" title="mxnet.executor.Executor"><em>Executor</em></a>) – Executor that computes the forward pass.</p></li>
<li><p><strong>location</strong> (<em>list of numpy.ndarray</em><em> or </em><em>dict of str to numpy.ndarray</em>) – Argument values used as location to compute gradient
Maps the name of arguments to the corresponding numpy.ndarray.
Value of all the arguments must be provided.</p></li>
<li><p><strong>aux_states</strong> (<em>None</em><em> or </em><em>list of numpy.ndarray</em><em> or </em><em>dict of str to numpy.ndarray</em><em>, </em><em>optional</em>) – Auxiliary states values used as location to compute gradient
Maps the name of aux_states to the corresponding numpy.ndarray.
Value of all the auxiliary arguments must be provided.</p></li>
<li><p><strong>eps</strong> (<em>float</em><em>, </em><em>optional</em>) – Epsilon for the finite-difference method.</p></li>
<li><p><strong>use_forward_train</strong> (<em>bool</em><em>, </em><em>optional</em>) – Whether to use <cite>is_train=True</cite> in testing.</p></li>
<li><p><strong>dtype</strong> (<em>np.float16</em><em> or </em><em>np.float32</em><em> or </em><em>np.float64</em>) – Datatype for mx.nd.array.</p></li>
</ul>
</dd>
</dl>
<p class="rubric">References</p>
<p>..[1] <a class="reference external" href="https://github.com/Theano/Theano/blob/master/theano/gradient.py">https://github.com/Theano/Theano/blob/master/theano/gradient.py</a></p>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.rand_ndarray">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">rand_ndarray</code><span class="sig-paren">(</span><em class="sig-param">shape</em>, <em class="sig-param">stype='default'</em>, <em class="sig-param">density=None</em>, <em class="sig-param">dtype=None</em>, <em class="sig-param">modifier_func=None</em>, <em class="sig-param">shuffle_csr_indices=False</em>, <em class="sig-param">distribution=None</em>, <em class="sig-param">ctx=None</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#rand_ndarray"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.rand_ndarray" title="Permalink to this definition">¶</a></dt>
<dd><p>Generate a random sparse ndarray. Returns the generated ndarray.</p>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.rand_sparse_ndarray">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">rand_sparse_ndarray</code><span class="sig-paren">(</span><em class="sig-param">shape</em>, <em class="sig-param">stype</em>, <em class="sig-param">density=None</em>, <em class="sig-param">dtype=None</em>, <em class="sig-param">distribution=None</em>, <em class="sig-param">data_init=None</em>, <em class="sig-param">rsp_indices=None</em>, <em class="sig-param">modifier_func=None</em>, <em class="sig-param">shuffle_csr_indices=False</em>, <em class="sig-param">ctx=None</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#rand_sparse_ndarray"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.rand_sparse_ndarray" title="Permalink to this definition">¶</a></dt>
<dd><p>Generate a random sparse ndarray. Returns the ndarray, value(np) and indices(np)</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>shape</strong> (<em>list</em><em> or </em><em>tuple</em>) – </p></li>
<li><p><strong>stype</strong> (<em>str</em>) – valid values: “csr” or “row_sparse”</p></li>
<li><p><strong>density</strong> (<em>float</em><em>, </em><em>optional</em>) – should be between 0 and 1</p></li>
<li><p><strong>distribution</strong> (<em>str</em><em>, </em><em>optional</em>) – valid values: “uniform” or “powerlaw”</p></li>
<li><p><strong>dtype</strong> (<em>numpy.dtype</em><em>, </em><em>optional</em>) – default value is None</p></li>
</ul>
</dd>
<dt class="field-even">Returns</dt>
<dd class="field-even"><p></p>
</dd>
<dt class="field-odd">Return type</dt>
<dd class="field-odd"><p>Result of type CSRNDArray or <a class="reference internal" href="../../ndarray/sparse/index.html#mxnet.ndarray.sparse.RowSparseNDArray" title="mxnet.ndarray.sparse.RowSparseNDArray">RowSparseNDArray</a></p>
</dd>
</dl>
<p class="rubric">Examples</p>
<p>Below is an example of the powerlaw distribution with csr as the stype.
It calculates the nnz using the shape and density.
It fills up the ndarray with exponentially increasing number of elements.
If there are enough unused_nnzs, n+1th row will have twice more nnzs compared to nth row.
else, remaining unused_nnzs will be used in n+1th row
If number of cols is too small and we have already reached column size it will fill up
all following columns in all followings rows until we reach the required density.</p>
<div class="doctest highlight-default notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="n">csr_arr</span><span class="p">,</span> <span class="n">_</span> <span class="o">=</span> <span class="n">rand_sparse_ndarray</span><span class="p">(</span><span class="n">shape</span><span class="o">=</span><span class="p">(</span><span class="mi">5</span><span class="p">,</span> <span class="mi">16</span><span class="p">),</span> <span class="n">stype</span><span class="o">=</span><span class="s2">&quot;csr&quot;</span><span class="p">,</span>
<span class="go">                                     density=0.50, distribution=&quot;powerlaw&quot;)</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">indptr</span> <span class="o">=</span> <span class="n">csr_arr</span><span class="o">.</span><span class="n">indptr</span><span class="o">.</span><span class="n">asnumpy</span><span class="p">()</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">indices</span> <span class="o">=</span> <span class="n">csr_arr</span><span class="o">.</span><span class="n">indices</span><span class="o">.</span><span class="n">asnumpy</span><span class="p">()</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">data</span> <span class="o">=</span> <span class="n">csr_arr</span><span class="o">.</span><span class="n">data</span><span class="o">.</span><span class="n">asnumpy</span><span class="p">()</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">row2nnz</span> <span class="o">=</span> <span class="nb">len</span><span class="p">(</span><span class="n">data</span><span class="p">[</span><span class="n">indptr</span><span class="p">[</span><span class="mi">1</span><span class="p">]:</span><span class="n">indptr</span><span class="p">[</span><span class="mi">2</span><span class="p">]])</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">row3nnz</span> <span class="o">=</span> <span class="nb">len</span><span class="p">(</span><span class="n">data</span><span class="p">[</span><span class="n">indptr</span><span class="p">[</span><span class="mi">2</span><span class="p">]:</span><span class="n">indptr</span><span class="p">[</span><span class="mi">3</span><span class="p">]])</span>
<span class="gp">&gt;&gt;&gt; </span><span class="k">assert</span><span class="p">(</span><span class="n">row3nnz</span> <span class="o">==</span> <span class="mi">2</span><span class="o">*</span><span class="n">row2nnz</span><span class="p">)</span>
<span class="gp">&gt;&gt;&gt; </span><span class="n">row4nnz</span> <span class="o">=</span> <span class="nb">len</span><span class="p">(</span><span class="n">data</span><span class="p">[</span><span class="n">indptr</span><span class="p">[</span><span class="mi">3</span><span class="p">]:</span><span class="n">indptr</span><span class="p">[</span><span class="mi">4</span><span class="p">]])</span>
<span class="gp">&gt;&gt;&gt; </span><span class="k">assert</span><span class="p">(</span><span class="n">row4nnz</span> <span class="o">==</span> <span class="mi">2</span><span class="o">*</span><span class="n">row3nnz</span><span class="p">)</span>
</pre></div>
</div>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.random_arrays">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">random_arrays</code><span class="sig-paren">(</span><em class="sig-param">*shapes</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#random_arrays"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.random_arrays" title="Permalink to this definition">¶</a></dt>
<dd><p>Generate some random numpy arrays.</p>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.random_sample">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">random_sample</code><span class="sig-paren">(</span><em class="sig-param">population</em>, <em class="sig-param">k</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#random_sample"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.random_sample" title="Permalink to this definition">¶</a></dt>
<dd><p>Return a k length list of the elements chosen from the population sequence.</p>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.retry">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">retry</code><span class="sig-paren">(</span><em class="sig-param">n</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#retry"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.retry" title="Permalink to this definition">¶</a></dt>
<dd><p>Retry n times before failing for stochastic test cases.</p>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.same">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">same</code><span class="sig-paren">(</span><em class="sig-param">a</em>, <em class="sig-param">b</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#same"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.same" title="Permalink to this definition">¶</a></dt>
<dd><p>Test if two NumPy arrays are the same.</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>a</strong> (<em>np.ndarray</em>) – </p></li>
<li><p><strong>b</strong> (<em>np.ndarray</em>) – </p></li>
</ul>
</dd>
</dl>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.same_array">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">same_array</code><span class="sig-paren">(</span><em class="sig-param">array1</em>, <em class="sig-param">array2</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#same_array"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.same_array" title="Permalink to this definition">¶</a></dt>
<dd><p>Check whether two NDArrays sharing the same memory block</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>array1</strong> (<a class="reference internal" href="../../ndarray/ndarray.html#mxnet.ndarray.NDArray" title="mxnet.ndarray.NDArray"><em>NDArray</em></a>) – First NDArray to be checked</p></li>
<li><p><strong>array2</strong> (<a class="reference internal" href="../../ndarray/ndarray.html#mxnet.ndarray.NDArray" title="mxnet.ndarray.NDArray"><em>NDArray</em></a>) – Second NDArray to be checked</p></li>
</ul>
</dd>
<dt class="field-even">Returns</dt>
<dd class="field-even"><p>Whether two NDArrays share the same memory</p>
</dd>
<dt class="field-odd">Return type</dt>
<dd class="field-odd"><p>bool</p>
</dd>
</dl>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.same_symbol_structure">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">same_symbol_structure</code><span class="sig-paren">(</span><em class="sig-param">sym1</em>, <em class="sig-param">sym2</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#same_symbol_structure"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.same_symbol_structure" title="Permalink to this definition">¶</a></dt>
<dd><p>Compare two symbols to check if they have the same computation graph structure.
Returns true if operator corresponding to a particular node id is same in both
symbols for all nodes</p>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.set_default_context">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">set_default_context</code><span class="sig-paren">(</span><em class="sig-param">ctx</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#set_default_context"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.set_default_context" title="Permalink to this definition">¶</a></dt>
<dd><p>Set default context.</p>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.set_env_var">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">set_env_var</code><span class="sig-paren">(</span><em class="sig-param">key</em>, <em class="sig-param">val</em>, <em class="sig-param">default_val=''</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#set_env_var"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.set_env_var" title="Permalink to this definition">¶</a></dt>
<dd><p>Set environment variable</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>key</strong> (<em>str</em>) – Env var to set</p></li>
<li><p><strong>val</strong> (<em>str</em>) – New value assigned to the env var</p></li>
<li><p><strong>default_val</strong> (<em>str</em><em>, </em><em>optional</em>) – Default value returned if the env var doesn’t exist</p></li>
</ul>
</dd>
<dt class="field-even">Returns</dt>
<dd class="field-even"><p>The value of env var before it is set to the new value</p>
</dd>
<dt class="field-odd">Return type</dt>
<dd class="field-odd"><p>str</p>
</dd>
</dl>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.shuffle_csr_column_indices">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">shuffle_csr_column_indices</code><span class="sig-paren">(</span><em class="sig-param">csr</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#shuffle_csr_column_indices"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.shuffle_csr_column_indices" title="Permalink to this definition">¶</a></dt>
<dd><p>Shuffle CSR column indices per row
This allows validation of unordered column indices, which is not a requirement
for a valid CSR matrix</p>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.simple_forward">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">simple_forward</code><span class="sig-paren">(</span><em class="sig-param">sym</em>, <em class="sig-param">ctx=None</em>, <em class="sig-param">is_train=False</em>, <em class="sig-param">**inputs</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#simple_forward"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.simple_forward" title="Permalink to this definition">¶</a></dt>
<dd><p>A simple forward function for a symbol.</p>
<p>Primarily used in doctest to test the functionality of a symbol.
Takes NumPy arrays as inputs and outputs are also converted to NumPy arrays.</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>ctx</strong> (<a class="reference internal" href="../context/index.html#mxnet.context.Context" title="mxnet.context.Context"><em>Context</em></a>) – If <code class="docutils literal notranslate"><span class="pre">None</span></code>, will take the default context.</p></li>
<li><p><strong>inputs</strong> (<em>keyword arguments</em>) – Mapping each input name to a NumPy array.</p></li>
</ul>
</dd>
<dt class="field-even">Returns</dt>
<dd class="field-even"><p><ul class="simple">
<li><p><em>The result as a numpy array. Multiple results will</em></p></li>
<li><p><em>be returned as a list of NumPy arrays.</em></p></li>
</ul>
</p>
</dd>
</dl>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.var_check">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">var_check</code><span class="sig-paren">(</span><em class="sig-param">generator</em>, <em class="sig-param">sigma</em>, <em class="sig-param">nsamples=1000000</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#var_check"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.var_check" title="Permalink to this definition">¶</a></dt>
<dd><p>Test the generator by matching the variance.
It will need a large number of samples and is not recommended to use</p>
<dl class="simple">
<dt>We test the sample variance by checking if it falls inside the range</dt><dd><p>(sigma^2 - 3 * sqrt(2 * sigma^4 / (n-1)), sigma^2 + 3 * sqrt(2 * sigma^4 / (n-1)))</p>
</dd>
</dl>
<p>References:</p>
<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="nd">@incollection</span><span class="p">{</span><span class="n">goucher2009beautiful</span><span class="p">,</span>
      <span class="n">title</span><span class="o">=</span><span class="p">{</span><span class="n">Beautiful</span> <span class="n">Testing</span><span class="p">:</span> <span class="n">Leading</span> <span class="n">Professionals</span> <span class="n">Reveal</span> <span class="n">How</span> <span class="n">They</span> <span class="n">Improve</span> <span class="n">Software</span><span class="p">},</span>
      <span class="n">author</span><span class="o">=</span><span class="p">{</span><span class="n">Goucher</span><span class="p">,</span> <span class="n">Adam</span> <span class="ow">and</span> <span class="n">Riley</span><span class="p">,</span> <span class="n">Tim</span><span class="p">},</span>
      <span class="n">year</span><span class="o">=</span><span class="p">{</span><span class="mi">2009</span><span class="p">},</span>
      <span class="n">chapter</span><span class="o">=</span><span class="mi">10</span>
<span class="p">}</span>
</pre></div>
</div>
<p>Examples:</p>
<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">generator</span> <span class="o">=</span> <span class="k">lambda</span> <span class="n">x</span><span class="p">:</span> <span class="n">np</span><span class="o">.</span><span class="n">random</span><span class="o">.</span><span class="n">normal</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span> <span class="mf">1.0</span><span class="p">,</span> <span class="n">size</span><span class="o">=</span><span class="n">x</span><span class="p">)</span>
<span class="n">var_check_ret</span> <span class="o">=</span> <span class="n">var_check</span><span class="p">(</span><span class="n">generator</span><span class="p">,</span> <span class="mi">0</span><span class="p">,</span> <span class="mf">1.0</span><span class="p">)</span>
</pre></div>
</div>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>generator</strong> (<em>function</em>) – The generator function. It’s expected to generate N i.i.d samples by calling generator(N).</p></li>
<li><p><strong>sigma</strong> (<em>float</em>) – </p></li>
<li><p><strong>nsamples</strong> (<em>int</em>) – </p></li>
</ul>
</dd>
<dt class="field-even">Returns</dt>
<dd class="field-even"><p><strong>ret</strong> – Whether the variance test succeeds</p>
</dd>
<dt class="field-odd">Return type</dt>
<dd class="field-odd"><p>bool</p>
</dd>
</dl>
</dd></dl>

<dl class="function">
<dt id="mxnet.test_utils.verify_generator">
<code class="sig-prename descclassname">mxnet.test_utils.</code><code class="sig-name descname">verify_generator</code><span class="sig-paren">(</span><em class="sig-param">generator</em>, <em class="sig-param">buckets</em>, <em class="sig-param">probs</em>, <em class="sig-param">nsamples=1000000</em>, <em class="sig-param">nrepeat=5</em>, <em class="sig-param">success_rate=0.2</em>, <em class="sig-param">alpha=0.05</em><span class="sig-paren">)</span><a class="reference internal" href="../../../_modules/mxnet/test_utils.html#verify_generator"><span class="viewcode-link">[source]</span></a><a class="headerlink" href="#mxnet.test_utils.verify_generator" title="Permalink to this definition">¶</a></dt>
<dd><p>Verify whether the generator is correct using chi-square testing.</p>
<dl class="simple">
<dt>The test is repeated for “nrepeat” times and we check if the success rate is</dt><dd><p>above the threshold (25% by default).</p>
</dd>
</dl>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>generator</strong> (<em>function</em>) – <dl class="simple">
<dt>A function that is assumed to generate i.i.d samples from a specific distribution.</dt><dd><p>generator(N) should generate N random samples.</p>
</dd>
</dl>
</p></li>
<li><p><strong>buckets</strong> (<em>list of tuple</em><em> or </em><em>list of number</em>) – <dl class="simple">
<dt>The buckets to run the chi-square the test. Make sure that the buckets cover</dt><dd><p>the whole range of the distribution. Also, the buckets must be in ascending order and
have no intersection</p>
</dd>
</dl>
</p></li>
<li><p><strong>probs</strong> (<em>list</em><em> or </em><em>tuple</em>) – The ground-truth probability of the random value fall in a specific bucket.</p></li>
<li><p><strong>nsamples</strong> (<em>int</em>) – The number of samples to generate for the testing</p></li>
<li><p><strong>nrepeat</strong> (<em>int</em>) – The times to repeat the test</p></li>
<li><p><strong>success_rate</strong> (<em>float</em>) – The desired success rate</p></li>
<li><p><strong>alpha</strong> (<em>float</em>) – The desired threshold for type-I error i.e. when a true null hypothesis is rejected</p></li>
</ul>
</dd>
<dt class="field-even">Returns</dt>
<dd class="field-even"><p><strong>cs_ret_l</strong> – The p values of the chi-square test.</p>
</dd>
<dt class="field-odd">Return type</dt>
<dd class="field-odd"><p>list</p>
</dd>
</dl>
</dd></dl>

</div>


        </div>
        <div class="side-doc-outline">
            <div class="side-doc-outline--content"> 
            </div>
        </div>                    

      <div class="clearer"></div>
    </div><div class="pagenation">
     <a id="button-prev" href="../rtc/index.html" class="mdl-button mdl-js-button mdl-js-ripple-effect mdl-button--colored" role="botton" accesskey="P">
         <i class="pagenation-arrow-L fas fa-arrow-left fa-lg"></i>
         <div class="pagenation-text">
            <span class="pagenation-direction">Previous</span>
            <div>mxnet.rtc</div>
         </div>
     </a>
     <a id="button-next" href="../torch/index.html" class="mdl-button mdl-js-button mdl-js-ripple-effect mdl-button--colored" role="botton" accesskey="N">
         <i class="pagenation-arrow-R fas fa-arrow-right fa-lg"></i>
        <div class="pagenation-text">
            <span class="pagenation-direction">Next</span>
            <div>mxnet.torch</div>
        </div>
     </a>
  </div>
            <footer class="site-footer h-card">
    <div class="wrapper">
        <div class="row">
            <div class="col-4">
                <h4 class="footer-category-title">Resources</h4>
                <ul class="contact-list">
                    <li><a class="u-email" href="mailto:dev@mxnet.apache.org">Dev list</a></li>
                    <li><a class="u-email" href="mailto:user@mxnet.apache.org">User mailing list</a></li>
                    <li><a href="https://cwiki.apache.org/confluence/display/MXNET/Apache+MXNet+Home">Developer Wiki</a></li>
                    <li><a href="https://issues.apache.org/jira/projects/MXNET/issues">Jira Tracker</a></li>
                    <li><a href="https://github.com/apache/incubator-mxnet/labels/Roadmap">Github Roadmap</a></li>
                    <li><a href="https://discuss.mxnet.io">MXNet Discuss forum</a></li>
                    <li><a href="/versions/1.6/community/contribute">Contribute To MXNet</a></li>

                </ul>
            </div>

            <div class="col-4"><ul class="social-media-list"><li><a href="https://github.com/apache/incubator-mxnet"><svg class="svg-icon"><use xlink:href="../../../_static/minima-social-icons.svg#github"></use></svg> <span class="username">apache/incubator-mxnet</span></a></li><li><a href="https://www.twitter.com/apachemxnet"><svg class="svg-icon"><use xlink:href="../../../_static/minima-social-icons.svg#twitter"></use></svg> <span class="username">apachemxnet</span></a></li><li><a href="https://youtube.com/apachemxnet"><svg class="svg-icon"><use xlink:href="../../../_static/minima-social-icons.svg#youtube"></use></svg> <span class="username">apachemxnet</span></a></li></ul>
</div>

            <div class="col-4 footer-text">
                <p>A flexible and efficient library for deep learning.</p>
            </div>
        </div>
    </div>
</footer>

<footer class="site-footer2">
    <div class="wrapper">
        <div class="row">
            <div class="col-3">
                <img src="../../../_static/apache_incubator_logo.png" class="footer-logo col-2">
            </div>
            <div class="footer-bottom-warning col-9">
                <p>Apache MXNet is an effort undergoing incubation at The Apache Software Foundation (ASF), <span style="font-weight:bold">sponsored by the <i>Apache Incubator</i></span>. Incubation is required
                    of all newly accepted projects until a further review indicates that the infrastructure,
                    communications, and decision making process have stabilized in a manner consistent with other
                    successful ASF projects. While incubation status is not necessarily a reflection of the completeness
                    or stability of the code, it does indicate that the project has yet to be fully endorsed by the ASF.
                </p><p>"Copyright © 2017-2018, The Apache Software Foundation Apache MXNet, MXNet, Apache, the Apache
                    feather, and the Apache MXNet project logo are either registered trademarks or trademarks of the
                    Apache Software Foundation."</p>
            </div>
        </div>
    </div>
</footer>
        
  </body>
</html>