<?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="../jacoco-resources/report.css" type="text/css"/><link rel="shortcut icon" href="../jacoco-resources/report.gif" type="image/gif"/><title>MtasDataItemDoubleFull.java</title><link rel="stylesheet" href="../jacoco-resources/prettify.css" type="text/css"/><script type="text/javascript" src="../jacoco-resources/prettify.js"></script></head><body onload="window['PR_TAB_WIDTH']=4;prettyPrint()"><div class="breadcrumb" id="breadcrumb"><span class="info"><a href="../jacoco-sessions.html" class="el_session">Sessions</a></span><a href="../index.html" class="el_report">MTAS</a> > <a href="index.source.html" class="el_package">mtas.codec.util.collector</a> > <span class="el_source">MtasDataItemDoubleFull.java</span></div><h1>MtasDataItemDoubleFull.java</h1><pre class="source lang-java linenums">package mtas.codec.util.collector;
import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.Map;
import java.util.Set;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import org.apache.commons.lang.ArrayUtils;
import mtas.codec.util.CodecUtil;
/**
* The Class MtasDataItemDoubleFull.
*/
public class MtasDataItemDoubleFull extends MtasDataItemFull<Double, Double> {
/** The Constant serialVersionUID. */
private static final long serialVersionUID = 1L;
/** The fp argument. */
<span class="nc" id="L21"> private static Pattern fpArgument = Pattern.compile("([^=,]+)=([^,]*)");</span>
/**
* Instantiates a new mtas data item double full.
*
* @param value the value
* @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 sourceNumber the source number
*/
public MtasDataItemDoubleFull(double[] value, MtasDataCollector<?, ?> sub,
Set<String> statsItems, String sortType, String sortDirection,
int errorNumber, Map<String, Integer> errorList, int sourceNumber) {
<span class="nc" id="L38"> super(ArrayUtils.toObject(value), sub, statsItems, sortType, sortDirection,</span>
errorNumber, errorList, new MtasDataDoubleOperations(), sourceNumber);
<span class="nc" id="L40"> }</span>
/**
* Gets the number of decimals.
*
* @param ds the ds
* @return the number of decimals
*/
private int getNumberOfDecimals(String ds) {
<span class="nc bnc" id="L49" title="All 2 branches missed."> if (!ds.contains(".")) {</span>
<span class="nc" id="L50"> return 0;</span>
} else {
<span class="nc" id="L52"> return (ds.length() - ds.indexOf(".") - 1);</span>
}
}
/*
* (non-Javadoc)
*
* @see
* mtas.codec.util.DataCollector.MtasDataItemFull#getDistribution(java.lang.
* String)
*/
@Override
protected HashMap<String, Object> getDistribution(String argument) {
<span class="nc" id="L65"> HashMap<String, Object> result = new LinkedHashMap<String, Object>();</span>
<span class="nc" id="L66"> Double start = null;</span>
<span class="nc" id="L67"> Double end = null;</span>
<span class="nc" id="L68"> Double step = null;</span>
<span class="nc" id="L69"> Integer d = null;</span>
<span class="nc" id="L70"> Integer number = null;</span>
<span class="nc bnc" id="L71" title="All 2 branches missed."> if (argument != null) {</span>
<span class="nc" id="L72"> Matcher m = fpArgument.matcher(argument);</span>
// get settings
<span class="nc bnc" id="L74" title="All 2 branches missed."> while (m.find()) {</span>
<span class="nc bnc" id="L75" title="All 2 branches missed."> if (m.group(1).trim().equals("start")) {</span>
<span class="nc" id="L76"> start = Double.parseDouble(m.group(2));</span>
<span class="nc bnc" id="L77" title="All 2 branches missed."> d = (d == null) ? getNumberOfDecimals(m.group(2))</span>
<span class="nc" id="L78"> : Math.max(d, getNumberOfDecimals(m.group(2)));</span>
<span class="nc bnc" id="L79" title="All 2 branches missed."> } else if (m.group(1).trim().equals("end")) {</span>
<span class="nc" id="L80"> end = Double.parseDouble(m.group(2));</span>
<span class="nc bnc" id="L81" title="All 2 branches missed."> d = (d == null) ? getNumberOfDecimals(m.group(2))</span>
<span class="nc" id="L82"> : Math.max(d, getNumberOfDecimals(m.group(2)));</span>
<span class="nc bnc" id="L83" title="All 2 branches missed."> } else if (m.group(1).trim().equals("step")) {</span>
<span class="nc" id="L84"> step = Double.parseDouble(m.group(2));</span>
<span class="nc bnc" id="L85" title="All 2 branches missed."> d = (d == null) ? getNumberOfDecimals(m.group(2))</span>
<span class="nc" id="L86"> : Math.max(d, getNumberOfDecimals(m.group(2)));</span>
<span class="nc bnc" id="L87" title="All 2 branches missed."> } else if (m.group(1).trim().equals("number")) {</span>
<span class="nc" id="L88"> number = Integer.parseInt(m.group(2));</span>
}
}
}
// always exactly one of (positive) number and (positive) step, other null
<span class="nc bnc" id="L93" title="All 8 branches missed."> if ((number == null || number < 1) && (step == null || step <= 0)) {</span>
<span class="nc" id="L94"> number = 10;</span>
<span class="nc" id="L95"> step = null;</span>
<span class="nc bnc" id="L96" title="All 4 branches missed."> } else if (step != null && step <= 0) {</span>
<span class="nc" id="L97"> step = null;</span>
<span class="nc bnc" id="L98" title="All 4 branches missed."> } else if (number != null && number < 1) {</span>
<span class="nc" id="L99"> number = null;</span>
<span class="nc bnc" id="L100" title="All 2 branches missed."> } else if (step != null) {</span>
<span class="nc" id="L101"> number = null;</span>
}
// sanity checks start/end
<span class="nc" id="L104"> createStats();</span>
<span class="nc" id="L105"> double tmpStart = stats.getMin();</span>
<span class="nc" id="L106"> double tmpEnd = stats.getMax();</span>
<span class="nc bnc" id="L107" title="All 6 branches missed."> if (start != null && end != null && start > end) {</span>
<span class="nc" id="L108"> return null;</span>
<span class="nc bnc" id="L109" title="All 4 branches missed."> } else if (start != null && start > tmpEnd) {</span>
<span class="nc" id="L110"> return null;</span>
<span class="nc bnc" id="L111" title="All 4 branches missed."> } else if (end != null && end < tmpStart) {</span>
<span class="nc" id="L112"> return null;</span>
}
// check start and end
<span class="nc bnc" id="L115" title="All 4 branches missed."> if (start == null && end == null) {</span>
<span class="nc bnc" id="L116" title="All 2 branches missed."> if (step == null) {</span>
<span class="nc" id="L117"> step = (tmpEnd - tmpStart) / number;</span>
}
<span class="nc" id="L119"> number = Double.valueOf(Math.ceil((tmpEnd - tmpStart) / step)).intValue();</span>
<span class="nc" id="L120"> start = tmpStart;</span>
<span class="nc" id="L121"> end = start + (number * step);</span>
<span class="nc bnc" id="L122" title="All 2 branches missed."> } else if (start == null) {</span>
<span class="nc bnc" id="L123" title="All 2 branches missed."> if (step == null) {</span>
<span class="nc" id="L124"> step = (end - tmpStart) / number;</span>
}
<span class="nc" id="L126"> number = Double.valueOf(Math.ceil((end - tmpStart) / step)).intValue();</span>
<span class="nc" id="L127"> start = end - (number * step);</span>
<span class="nc bnc" id="L128" title="All 2 branches missed."> } else if (end == null) {</span>
<span class="nc bnc" id="L129" title="All 2 branches missed."> if (step == null) {</span>
<span class="nc" id="L130"> step = (tmpEnd - start) / number;</span>
}
<span class="nc" id="L132"> number = Double.valueOf(Math.ceil((tmpEnd - start) / step)).intValue();</span>
<span class="nc" id="L133"> end = start + (number * step);</span>
} else {
<span class="nc bnc" id="L135" title="All 2 branches missed."> if (step == null) {</span>
<span class="nc" id="L136"> step = (end - start) / number;</span>
}
<span class="nc" id="L138"> number = Double.valueOf(Math.ceil((end - start) / step)).intValue();</span>
}
// round step to agreeable format and recompute number
<span class="nc" id="L141"> int tmpD = Double.valueOf(Math.max(0, 1 + Math.ceil(-1 * Math.log10(step))))</span>
<span class="nc" id="L142"> .intValue();</span>
<span class="nc bnc" id="L143" title="All 2 branches missed."> d = (d == null) ? tmpD : Math.max(d, tmpD);</span>
<span class="nc" id="L144"> double tmp = Math.pow(10.0, d);</span>
<span class="nc" id="L145"> step = Math.round(step * tmp) / tmp;</span>
<span class="nc" id="L146"> number = Double.valueOf(Math.ceil((end - start) / step)).intValue();</span>
// compute distribution
<span class="nc" id="L149"> long[] list = new long[number];</span>
<span class="nc bnc" id="L150" title="All 2 branches missed."> for (Double v : fullValues) {</span>
<span class="nc bnc" id="L151" title="All 4 branches missed."> if (v >= start && v <= end) {</span>
<span class="nc" id="L152"> int i = Math.min(</span>
<span class="nc" id="L153"> Double.valueOf(Math.floor((v - start) / step)).intValue(),</span>
<span class="nc" id="L154"> (number - 1));</span>
<span class="nc" id="L155"> list[i]++;</span>
}
}
Double l;
Double r;
String ls;
String lsFormat;
String rs;
String rsFormat;
<span class="nc bnc" id="L164" title="All 2 branches missed."> for (int i = 0; i < number; i++) {</span>
<span class="nc" id="L165"> l = start + i * step;</span>
<span class="nc" id="L166"> r = Math.min(end, l + step);</span>
<span class="nc" id="L167"> lsFormat = "%." + d + "f";</span>
<span class="nc" id="L168"> ls = String.format(lsFormat, l);</span>
<span class="nc" id="L169"> rsFormat = "%." + d + "f";</span>
<span class="nc" id="L170"> rs = String.format(rsFormat, r);</span>
<span class="nc" id="L171"> String key = "[" + ls + "," + rs</span>
<span class="nc bnc" id="L172" title="All 6 branches missed."> + ((i == (number - 1) && r >= tmpEnd && l <= tmpEnd) ? "]" : ")");</span>
<span class="nc" id="L173"> result.put(key, list[i]);</span>
}
<span class="nc" id="L175"> return result;</span>
}
/*
* (non-Javadoc)
*
* @see java.lang.Comparable#compareTo(java.lang.Object)
*/
@SuppressWarnings({ "rawtypes", "unchecked" })
public int compareTo(MtasDataItem<Double, Double> o) {
<span class="nc" id="L185"> int compare = 0;</span>
<span class="nc bnc" id="L186" title="All 2 branches missed."> if (o instanceof MtasDataItemDoubleFull) {</span>
<span class="nc" id="L187"> MtasDataItemDoubleFull to = (MtasDataItemDoubleFull) o;</span>
<span class="nc" id="L188"> MtasDataItemNumberComparator c1 = getComparableValue();</span>
<span class="nc" id="L189"> MtasDataItemNumberComparator c2 = to.getComparableValue();</span>
<span class="nc bnc" id="L190" title="All 4 branches missed."> compare = (c1 != null && c2 != null) ? c1.compareTo(c2.getValue()) : 0;</span>
}
<span class="nc bnc" id="L192" title="All 2 branches missed."> return sortDirection.equals(CodecUtil.SORT_DESC) ? -1 * compare : compare;</span>
}
/*
* (non-Javadoc)
*
* @see mtas.codec.util.collector.MtasDataItem#getCompareValue1()
*/
@Override
public MtasDataItemNumberComparator<Double> getCompareValue1() {
<span class="nc" id="L202"> createStats();</span>
<span class="nc bnc" id="L203" title="All 18 branches missed."> switch (sortType) {</span>
case CodecUtil.STATS_TYPE_SUM:
<span class="nc" id="L205"> return new MtasDataItemNumberComparator<Double>(stats.getSum(), sortDirection);</span>
case CodecUtil.STATS_TYPE_MAX:
<span class="nc" id="L207"> return new MtasDataItemNumberComparator<Double>(stats.getMax(), sortDirection);</span>
case CodecUtil.STATS_TYPE_MIN:
<span class="nc" id="L209"> return new MtasDataItemNumberComparator<Double>(stats.getMin(), sortDirection);</span>
case CodecUtil.STATS_TYPE_SUMSQ:
<span class="nc" id="L211"> return new MtasDataItemNumberComparator<Double>(stats.getSumsq(), sortDirection);</span>
default:
<span class="nc" id="L213"> return null;</span>
}
}
/*
* (non-Javadoc)
*
* @see mtas.codec.util.collector.MtasDataItem#getCompareValue2()
*/
@Override
public MtasDataItemNumberComparator<Double> getCompareValue2() {
<span class="nc" id="L224"> createStats();</span>
<span class="nc bnc" id="L225" title="All 42 branches missed."> switch (sortType) {</span>
case CodecUtil.STATS_TYPE_SUMOFLOGS:
<span class="nc" id="L227"> return new MtasDataItemNumberComparator<Double>(</span>
<span class="nc" id="L228"> stats.getN() * Math.log(stats.getGeometricMean()), sortDirection);</span>
case CodecUtil.STATS_TYPE_MEAN:
<span class="nc" id="L230"> return new MtasDataItemNumberComparator<Double>(stats.getMean(), sortDirection);</span>
case CodecUtil.STATS_TYPE_GEOMETRICMEAN:
<span class="nc" id="L232"> return new MtasDataItemNumberComparator<Double>(stats.getGeometricMean(), sortDirection);</span>
case CodecUtil.STATS_TYPE_STANDARDDEVIATION:
<span class="nc" id="L234"> return new MtasDataItemNumberComparator<Double>(stats.getStandardDeviation(), sortDirection);</span>
case CodecUtil.STATS_TYPE_VARIANCE:
<span class="nc" id="L236"> return new MtasDataItemNumberComparator<Double>(stats.getVariance(), sortDirection);</span>
case CodecUtil.STATS_TYPE_POPULATIONVARIANCE:
<span class="nc" id="L238"> return new MtasDataItemNumberComparator<Double>(stats.getPopulationVariance(), sortDirection);</span>
case CodecUtil.STATS_TYPE_QUADRATICMEAN:
<span class="nc" id="L240"> return new MtasDataItemNumberComparator<Double>(stats.getQuadraticMean(), sortDirection);</span>
case CodecUtil.STATS_TYPE_KURTOSIS:
<span class="nc" id="L242"> return new MtasDataItemNumberComparator<Double>(stats.getKurtosis(), sortDirection);</span>
case CodecUtil.STATS_TYPE_MEDIAN:
<span class="nc" id="L244"> return new MtasDataItemNumberComparator<Double>(stats.getPercentile(50), sortDirection);</span>
case CodecUtil.STATS_TYPE_SKEWNESS:
<span class="nc" id="L246"> return new MtasDataItemNumberComparator<Double>(stats.getSkewness(), sortDirection);</span>
default:
<span class="nc" id="L248"> return null;</span>
}
}
/*
* (non-Javadoc)
*
* @see java.lang.Object#toString()
*/
public String toString() {
<span class="nc" id="L258"> return this.getClass().getSimpleName() + "[" + fullValues.length + "]";</span>
}
/* (non-Javadoc)
* @see java.lang.Object#equals(java.lang.Object)
*/
@Override
public boolean equals(Object obj) {
<span class="nc bnc" id="L266" title="All 2 branches missed."> if (this == obj)</span>
<span class="nc" id="L267"> return true;</span>
<span class="nc bnc" id="L268" title="All 2 branches missed."> if (obj == null)</span>
<span class="nc" id="L269"> return false;</span>
<span class="nc bnc" id="L270" title="All 2 branches missed."> if (getClass() != obj.getClass())</span>
<span class="nc" id="L271"> return false;</span>
<span class="nc" id="L272"> MtasDataItemDoubleFull that = (MtasDataItemDoubleFull) obj;</span>
<span class="nc" id="L273"> MtasDataItemNumberComparator<?> c1 = getComparableValue();</span>
<span class="nc" id="L274"> MtasDataItemNumberComparator<?> c2 = that.getComparableValue();</span>
<span class="nc bnc" id="L275" title="All 6 branches missed."> return (c1!=null&&c2!=null&&c1.equals(c2)); </span>
}
/* (non-Javadoc)
* @see java.lang.Object#hashCode()
*/
@Override
public int hashCode() {
<span class="nc" id="L283"> int h = this.getClass().getSimpleName().hashCode();</span>
<span class="nc" id="L284"> h = (h * 7) ^ getComparableValue().hashCode();</span>
<span class="nc" id="L285"> return h;</span>
}
}
</pre><div class="footer"><span class="right">Created with <a href="http://www.jacoco.org/jacoco">JaCoCo</a> 0.7.9.201702052155</span></div></body></html>