MtasDataItemAdvanced.java.html 14.3 KB
<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"><html xmlns="http://www.w3.org/1999/xhtml" lang="en"><head><meta http-equiv="Content-Type" content="text/html;charset=UTF-8"/><link rel="stylesheet" href="../.resources/report.css" type="text/css"/><link rel="shortcut icon" href="../.resources/report.gif" type="image/gif"/><title>MtasDataItemAdvanced.java</title><link rel="stylesheet" href="../.resources/prettify.css" type="text/css"/><script type="text/javascript" src="../.resources/prettify.js"></script></head><body onload="window['PR_TAB_WIDTH']=4;prettyPrint()"><div class="breadcrumb" id="breadcrumb"><span class="info"><a href="../.sessions.html" class="el_session">Sessions</a></span><a href="../index.html" class="el_report">MTAS</a> &gt; <a href="index.source.html" class="el_package">mtas.codec.util.collector</a> &gt; <span class="el_source">MtasDataItemAdvanced.java</span></div><h1>MtasDataItemAdvanced.java</h1><pre class="source lang-java linenums">package mtas.codec.util.collector;

import java.io.IOException;
import java.io.Serializable;
import java.util.HashMap;
import java.util.Map;
import java.util.TreeSet;
import java.util.Map.Entry;
import java.util.Set;

import mtas.codec.util.CodecUtil;

/**
 * The Class MtasDataItemAdvanced.
 *
 * @param &lt;T1&gt;
 *          the generic type
 * @param &lt;T2&gt;
 *          the generic type
 */
abstract class MtasDataItemAdvanced&lt;T1 extends Number &amp; Comparable&lt;T1&gt;, T2 extends Number &amp; Comparable&lt;T2&gt;&gt;
    extends MtasDataItem&lt;T1, T2&gt; implements Serializable {

  /** The Constant serialVersionUID. */
  private static final long serialVersionUID = 1L;

  /** The value sum. */
  protected T1 valueSum;

  /** The value sum of logs. */
  protected T2 valueSumOfLogs;

  /** The value sum of squares. */
  protected T1 valueSumOfSquares;

  /** The value min. */
  protected T1 valueMin;

  /** The value max. */
  protected T1 valueMax;

  /** The value n. */
  protected Long valueN;

  /** The operations. */
  protected MtasDataOperations&lt;T1, T2&gt; operations;

  /**
   * Instantiates a new mtas data item advanced.
   *
   * @param valueSum
   *          the value sum
   * @param valueSumOfLogs
   *          the value sum of logs
   * @param valueSumOfSquares
   *          the value sum of squares
   * @param valueMin
   *          the value min
   * @param valueMax
   *          the value max
   * @param valueN
   *          the value n
   * @param sub
   *          the sub
   * @param statsItems
   *          the stats items
   * @param sortType
   *          the sort type
   * @param sortDirection
   *          the sort direction
   * @param errorNumber
   *          the error number
   * @param errorList
   *          the error list
   * @param operations
   *          the operations
   * @param sourceNumber
   *          the source number
   */
  public MtasDataItemAdvanced(T1 valueSum, T2 valueSumOfLogs,
      T1 valueSumOfSquares, T1 valueMin, T1 valueMax, Long valueN,
      MtasDataCollector&lt;?, ?&gt; sub, Set&lt;String&gt; statsItems, String sortType,
      String sortDirection, int errorNumber, Map&lt;String, Integer&gt; errorList,
      MtasDataOperations&lt;T1, T2&gt; operations, int sourceNumber) {
<span class="fc" id="L85">    super(sub, statsItems, sortType, sortDirection, errorNumber, errorList,</span>
        sourceNumber);
<span class="fc" id="L87">    this.valueSum = valueSum;</span>
<span class="fc" id="L88">    this.valueSumOfLogs = valueSumOfLogs;</span>
<span class="fc" id="L89">    this.valueSumOfSquares = valueSumOfSquares;</span>
<span class="fc" id="L90">    this.valueMin = valueMin;</span>
<span class="fc" id="L91">    this.valueMax = valueMax;</span>
<span class="fc" id="L92">    this.valueN = valueN;</span>
<span class="fc" id="L93">    this.operations = operations;</span>
<span class="fc" id="L94">  }</span>

  /*
   * (non-Javadoc)
   * 
   * @see mtas.codec.util.DataCollector.MtasDataItem#add(mtas.codec.util.
   * DataCollector.MtasDataItem)
   */
  @Override
  public void add(MtasDataItem&lt;T1, T2&gt; newItem) throws IOException {
<span class="nc bnc" id="L104" title="All 2 branches missed.">    if (newItem instanceof MtasDataItemAdvanced) {</span>
<span class="nc" id="L105">      MtasDataItemAdvanced&lt;T1, T2&gt; newTypedItem = (MtasDataItemAdvanced&lt;T1, T2&gt;) newItem;</span>
<span class="nc" id="L106">      valueSum = operations.add11(valueSum, newTypedItem.valueSum);</span>
<span class="nc" id="L107">      valueSumOfLogs = operations.add22(valueSumOfLogs,</span>
          newTypedItem.valueSumOfLogs);
<span class="nc" id="L109">      valueSumOfSquares = operations.add11(valueSumOfSquares,</span>
          newTypedItem.valueSumOfSquares);
<span class="nc" id="L111">      valueMin = operations.min11(valueMin, newTypedItem.valueMin);</span>
<span class="nc" id="L112">      valueMax = operations.max11(valueMax, newTypedItem.valueMax);</span>
<span class="nc" id="L113">      valueN += newTypedItem.valueN;</span>
<span class="nc" id="L114">      recomputeComparableSortValue = true;</span>
<span class="nc" id="L115">    } else {</span>
<span class="nc" id="L116">      throw new IOException(&quot;can only add MtasDataItemAdvanced&quot;);</span>
    }
<span class="nc" id="L118">  }</span>

  /*
   * (non-Javadoc)
   * 
   * @see mtas.codec.util.DataCollector.MtasDataItem#rewrite()
   */
  @Override
  public Map&lt;String, Object&gt; rewrite(boolean showDebugInfo) throws IOException {
<span class="fc" id="L127">    Map&lt;String, Object&gt; response = new HashMap&lt;String, Object&gt;();</span>
<span class="fc bfc" id="L128" title="All 2 branches covered.">    for (String statsItem : statsItems) {</span>
<span class="fc bfc" id="L129" title="All 2 branches covered.">      if (statsItem.equals(CodecUtil.STATS_TYPE_SUM)) {</span>
<span class="fc" id="L130">        response.put(statsItem, valueSum);</span>
<span class="fc bfc" id="L131" title="All 2 branches covered.">      } else if (statsItem.equals(CodecUtil.STATS_TYPE_N)) {</span>
<span class="fc" id="L132">        response.put(statsItem, valueN);</span>
<span class="fc bfc" id="L133" title="All 2 branches covered.">      } else if (statsItem.equals(CodecUtil.STATS_TYPE_MAX)) {</span>
<span class="fc" id="L134">        response.put(statsItem, valueMax);</span>
<span class="fc bfc" id="L135" title="All 2 branches covered.">      } else if (statsItem.equals(CodecUtil.STATS_TYPE_MIN)) {</span>
<span class="fc" id="L136">        response.put(statsItem, valueMin);</span>
<span class="pc bpc" id="L137" title="1 of 2 branches missed.">      } else if (statsItem.equals(CodecUtil.STATS_TYPE_SUMSQ)) {</span>
<span class="nc" id="L138">        response.put(statsItem, valueSumOfSquares);</span>
<span class="pc bpc" id="L139" title="1 of 2 branches missed.">      } else if (statsItem.equals(CodecUtil.STATS_TYPE_SUMOFLOGS)) {</span>
<span class="nc" id="L140">        response.put(statsItem, valueSumOfLogs);</span>
<span class="pc bpc" id="L141" title="1 of 2 branches missed.">      } else if (statsItem.equals(CodecUtil.STATS_TYPE_MEAN)) {</span>
<span class="fc" id="L142">        response.put(statsItem, getValue(statsItem));</span>
<span class="nc bnc" id="L143" title="All 2 branches missed.">      } else if (statsItem.equals(CodecUtil.STATS_TYPE_GEOMETRICMEAN)) {</span>
<span class="nc" id="L144">        response.put(statsItem, getValue(statsItem));</span>
<span class="nc bnc" id="L145" title="All 2 branches missed.">      } else if (statsItem.equals(CodecUtil.STATS_TYPE_STANDARDDEVIATION)) {</span>
<span class="nc" id="L146">        response.put(statsItem, getValue(statsItem));</span>
<span class="nc bnc" id="L147" title="All 2 branches missed.">      } else if (statsItem.equals(CodecUtil.STATS_TYPE_VARIANCE)) {</span>
<span class="nc" id="L148">        response.put(statsItem, getValue(statsItem));</span>
<span class="nc bnc" id="L149" title="All 2 branches missed.">      } else if (statsItem.equals(CodecUtil.STATS_TYPE_POPULATIONVARIANCE)) {</span>
<span class="nc" id="L150">        response.put(statsItem, getValue(statsItem));</span>
<span class="nc bnc" id="L151" title="All 2 branches missed.">      } else if (statsItem.equals(CodecUtil.STATS_TYPE_QUADRATICMEAN)) {</span>
<span class="nc" id="L152">        response.put(statsItem, getValue(statsItem));</span>
      } else {
<span class="nc" id="L154">        response.put(statsItem, null);</span>
      }
<span class="fc" id="L156">    }</span>
<span class="pc bpc" id="L157" title="1 of 2 branches missed.">    if (errorNumber &gt; 0) {</span>
<span class="nc" id="L158">      Map&lt;String, Object&gt; errorResponse = new HashMap&lt;String, Object&gt;();</span>
<span class="nc bnc" id="L159" title="All 2 branches missed.">      for (Entry&lt;String, Integer&gt; entry : errorList.entrySet()) {</span>
<span class="nc" id="L160">        errorResponse.put(entry.getKey(), entry.getValue());</span>
<span class="nc" id="L161">      }</span>
<span class="nc" id="L162">      response.put(&quot;errorNumber&quot;, errorNumber);</span>
<span class="nc" id="L163">      response.put(&quot;errorList&quot;, errorResponse);</span>
    }
<span class="pc bpc" id="L165" title="1 of 2 branches missed.">    if (showDebugInfo) {</span>
<span class="nc" id="L166">      response.put(&quot;sourceNumber&quot;, sourceNumber);</span>
<span class="nc" id="L167">      response.put(&quot;stats&quot;, &quot;advanced&quot;);</span>
    }
<span class="fc" id="L169">    return response;</span>
  }

  /**
   * Gets the value.
   *
   * @param statsType
   *          the stats type
   * @return the value
   */
  protected T2 getValue(String statsType) {
<span class="pc bpc" id="L180" title="1 of 2 branches missed.">    if (statsType.equals(CodecUtil.STATS_TYPE_MEAN)) {</span>
<span class="fc" id="L181">      return operations.divide1(valueSum, valueN);</span>
<span class="nc bnc" id="L182" title="All 2 branches missed.">    } else if (statsType.equals(CodecUtil.STATS_TYPE_GEOMETRICMEAN)) {</span>
<span class="nc" id="L183">      return operations.exp2(operations.divide2(valueSumOfLogs, valueN));</span>
<span class="nc bnc" id="L184" title="All 2 branches missed.">    } else if (statsType.equals(CodecUtil.STATS_TYPE_STANDARDDEVIATION)) {</span>
<span class="nc" id="L185">      return operations</span>
<span class="nc" id="L186">          .sqrt2(</span>
<span class="nc" id="L187">              operations.divide2(</span>
<span class="nc" id="L188">                  operations.subtract12(valueSumOfSquares,</span>
<span class="nc" id="L189">                      operations.divide1(</span>
<span class="nc" id="L190">                          operations.product11(valueSum, valueSum), valueN)),</span>
<span class="nc" id="L191">                  (valueN - 1)));</span>
<span class="nc bnc" id="L192" title="All 2 branches missed.">    } else if (statsType.equals(CodecUtil.STATS_TYPE_VARIANCE)) {</span>
<span class="nc" id="L193">      return operations</span>
<span class="nc" id="L194">          .divide2(</span>
              operations
<span class="nc" id="L196">                  .subtract12(valueSumOfSquares,</span>
<span class="nc" id="L197">                      operations.divide1(</span>
<span class="nc" id="L198">                          operations.product11(valueSum, valueSum), valueN)),</span>
<span class="nc" id="L199">              (valueN - 1));</span>
<span class="nc bnc" id="L200" title="All 2 branches missed.">    } else if (statsType.equals(CodecUtil.STATS_TYPE_POPULATIONVARIANCE)) {</span>
<span class="nc" id="L201">      return operations</span>
<span class="nc" id="L202">          .divide2(</span>
              operations
<span class="nc" id="L204">                  .subtract12(valueSumOfSquares,</span>
<span class="nc" id="L205">                      operations.divide1(</span>
<span class="nc" id="L206">                          operations.product11(valueSum, valueSum), valueN)),</span>
<span class="nc" id="L207">              valueN);</span>
<span class="nc bnc" id="L208" title="All 2 branches missed.">    } else if (statsType.equals(CodecUtil.STATS_TYPE_QUADRATICMEAN)) {</span>
<span class="nc" id="L209">      return operations.sqrt2(operations.divide1(valueSumOfSquares, valueN));</span>
    } else {
<span class="nc" id="L211">      return null;</span>
    }
  }

  /*
   * (non-Javadoc)
   * 
   * @see mtas.codec.util.collector.MtasDataItem#getCompareValueType()
   */
  @Override
  public int getCompareValueType() throws IOException {
<span class="nc bnc" id="L222" title="All 50 branches missed.">    switch (sortType) {</span>
    case CodecUtil.STATS_TYPE_N:
<span class="nc" id="L224">      return 0;</span>
    case CodecUtil.STATS_TYPE_SUM:
<span class="nc" id="L226">      return 1;</span>
    case CodecUtil.STATS_TYPE_MAX:
<span class="nc" id="L228">      return 1;</span>
    case CodecUtil.STATS_TYPE_MIN:
<span class="nc" id="L230">      return 1;</span>
    case CodecUtil.STATS_TYPE_SUMSQ:
<span class="nc" id="L232">      return 1;</span>
    case CodecUtil.STATS_TYPE_SUMOFLOGS:
<span class="nc" id="L234">      return 2;</span>
    case CodecUtil.STATS_TYPE_MEAN:
<span class="nc" id="L236">      return 2;</span>
    case CodecUtil.STATS_TYPE_GEOMETRICMEAN:
<span class="nc" id="L238">      return 2;</span>
    case CodecUtil.STATS_TYPE_STANDARDDEVIATION:
<span class="nc" id="L240">      return 2;</span>
    case CodecUtil.STATS_TYPE_VARIANCE:
<span class="nc" id="L242">      return 2;</span>
    case CodecUtil.STATS_TYPE_POPULATIONVARIANCE:
<span class="nc" id="L244">      return 2;</span>
    case CodecUtil.STATS_TYPE_QUADRATICMEAN:
<span class="nc" id="L246">      return 2;</span>
    default:
<span class="nc" id="L248">      throw new IOException(&quot;sortType &quot; + sortType + &quot; not supported&quot;);</span>
    }
  }

  /*
   * (non-Javadoc)
   * 
   * @see mtas.codec.util.collector.MtasDataItem#getCompareValue0()
   */
  @Override
  public final MtasDataItemNumberComparator&lt;Long&gt; getCompareValue0() {
<span class="nc bnc" id="L259" title="All 6 branches missed.">    switch (sortType) {</span>
    case CodecUtil.STATS_TYPE_N:
<span class="nc" id="L261">      return new MtasDataItemNumberComparator&lt;Long&gt;(valueN, sortDirection);</span>
    default:
<span class="nc" id="L263">      return null;</span>
    }
  }

}
</pre><div class="footer"><span class="right">Created with <a href="http://www.eclemma.org/jacoco">JaCoCo</a> 0.7.5.201505241946</span></div></body></html>