Added average values

This commit is contained in:
nifi 2010-10-13 22:55:14 +00:00
parent 131d0b5853
commit 1ca83eb314
1 changed files with 62 additions and 5 deletions

View File

@ -26,7 +26,7 @@
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE. * SUCH DAMAGE.
* *
* $Id: NodeInfoPanel.java,v 1.8 2010/09/30 22:24:45 nifi Exp $ * $Id: NodeInfoPanel.java,v 1.9 2010/10/13 22:55:14 nifi Exp $
* *
* ----------------------------------------------------------------- * -----------------------------------------------------------------
* *
@ -34,8 +34,8 @@
* *
* Authors : Joakim Eriksson, Niclas Finne * Authors : Joakim Eriksson, Niclas Finne
* Created : 6 sep 2010 * Created : 6 sep 2010
* Updated : $Date: 2010/09/30 22:24:45 $ * Updated : $Date: 2010/10/13 22:55:14 $
* $Revision: 1.8 $ * $Revision: 1.9 $
*/ */
package se.sics.contiki.collect.gui; package se.sics.contiki.collect.gui;
@ -257,7 +257,7 @@ public class NodeInfoPanel extends JPanel implements Visualizer, Configurable {
if (value == null) { if (value == null) {
setText(null); setText(null);
} }
double v = (Double) value + 0.0005; double v = ((Number) value).doubleValue() + 0.0005;
int dec = ((int)(v * 1000)) % 1000; int dec = ((int)(v * 1000)) % 1000;
setText((long)v + "." + (dec > 99 ? "" : "0") + (dec > 9 ? "" : "0") + dec); setText((long)v + "." + (dec > 99 ? "" : "0") + (dec > 9 ? "" : "0") + dec);
} }
@ -402,7 +402,19 @@ public class NodeInfoPanel extends JPanel implements Visualizer, Configurable {
this.columns = columns; this.columns = columns;
} }
public void recalculateAverage() {
for(TableData td : columns) {
td.clearAverageCache();
}
int row = getRowCount() - 1;
fireTableRowsUpdated(row, row);
}
public Object getValueAt(int row, int col) { public Object getValueAt(int row, int col) {
int count = nodes == null ? 0 : nodes.length;
if (row == count) {
return columns[col].getAverageValue(nodes);
}
return columns[col].getValue(nodes[row]); return columns[col].getValue(nodes[row]);
} }
@ -424,7 +436,7 @@ public class NodeInfoPanel extends JPanel implements Visualizer, Configurable {
} }
public int getRowCount() { public int getRowCount() {
return nodes == null ? 0 : nodes.length; return (nodes == null ? 0 : nodes.length) + 1;
} }
public void setNodes(Node[] nodes) { public void setNodes(Node[] nodes) {
@ -435,6 +447,7 @@ public class NodeInfoPanel extends JPanel implements Visualizer, Configurable {
if (this.nodes != null && this.nodes.length > 0) { if (this.nodes != null && this.nodes.length > 0) {
fireTableRowsInserted(0, this.nodes.length - 1); fireTableRowsInserted(0, this.nodes.length - 1);
} }
recalculateAverage();
} }
public void updateNode(Node node) { public void updateNode(Node node) {
@ -442,6 +455,7 @@ public class NodeInfoPanel extends JPanel implements Visualizer, Configurable {
for(int row = 0; row < this.nodes.length; row++) { for(int row = 0; row < this.nodes.length; row++) {
if (this.nodes[row] == node) { if (this.nodes[row] == node) {
fireTableRowsUpdated(row, row); fireTableRowsUpdated(row, row);
recalculateAverage();
break; break;
} }
} }
@ -453,6 +467,8 @@ public class NodeInfoPanel extends JPanel implements Visualizer, Configurable {
public static abstract class TableData extends AbstractAction { public static abstract class TableData extends AbstractAction {
private static final long serialVersionUID = -3045755073722516926L; private static final long serialVersionUID = -3045755073722516926L;
private final static Node AVERAGE_NODE = new Node("Average");
public final String name; public final String name;
public final Class<?> dataClass; public final Class<?> dataClass;
@ -460,6 +476,8 @@ public class NodeInfoPanel extends JPanel implements Visualizer, Configurable {
private TableColumn tableColumn; private TableColumn tableColumn;
private int modelIndex = -1; private int modelIndex = -1;
private Object averageCache;
protected TableData(String name, Class<?> dataClass) { protected TableData(String name, Class<?> dataClass) {
this(name, name, dataClass); this(name, name, dataClass);
} }
@ -525,7 +543,46 @@ public class NodeInfoPanel extends JPanel implements Visualizer, Configurable {
} }
} }
public final Object getAverageValue(Node[] nodes) {
Object tmp = averageCache;
if (tmp != null) {
return tmp;
}
if (dataClass == Integer.class || dataClass == Long.class || dataClass == Double.class) {
double average = 0.0;
if (nodes != null && nodes.length > 0) {
int count = 0;
for(Node node : nodes) {
if (node.getSensorDataAggregator().getDataCount() > 0) {
average += ((Number) getValue(node)).doubleValue();
count++;
}
}
if (count > 0) {
average = average / count;
}
}
if (dataClass == Integer.class) {
tmp = (int) (average + 0.5);
} else if (dataClass == Long.class) {
tmp = (long) (average + 0.5);
} else {
tmp = average;
}
} else if (dataClass == Node.class) {
tmp = AVERAGE_NODE;
}
averageCache = tmp;
return tmp;
}
public final void clearAverageCache() {
averageCache = null;
}
public abstract Object getValue(Node node); public abstract Object getValue(Node node);
} }
} }