From 6ec471bae5759e3773f5bf71862fd15fc96a5317 Mon Sep 17 00:00:00 2001 From: Mathieu Baudier Date: Sat, 20 Mar 2010 10:57:35 +0000 Subject: [PATCH] Add cosntructor based on count git-svn-id: https://svn.argeo.org/commons/trunk@3435 4cfe0d0a-d680-48aa-b62c-e0a02a3f76cc --- .../src/main/java/org/argeo/util/Throughput.java | 16 +++++++++++++++- 1 file changed, 15 insertions(+), 1 deletion(-) diff --git a/basic/runtime/org.argeo.basic.nodeps/src/main/java/org/argeo/util/Throughput.java b/basic/runtime/org.argeo.basic.nodeps/src/main/java/org/argeo/util/Throughput.java index 12f669505..35a03b18d 100644 --- a/basic/runtime/org.argeo.basic.nodeps/src/main/java/org/argeo/util/Throughput.java +++ b/basic/runtime/org.argeo.basic.nodeps/src/main/java/org/argeo/util/Throughput.java @@ -10,7 +10,7 @@ public class Throughput { private final static NumberFormat usNumberFormat = NumberFormat .getInstance(Locale.US); - enum Unit { + public enum Unit { s, m, h, d } @@ -22,6 +22,20 @@ public class Throughput { this.unit = unit; } + public Throughput(Long periodMs, Long count, Unit unit) { + if (unit.equals(Unit.s)) + value = ((double) count * 1000d) / periodMs; + else if (unit.equals(Unit.m)) + value = ((double) count * 60d * 1000d) / periodMs; + else if (unit.equals(Unit.h)) + value = ((double) count * 60d * 60d * 1000d) / periodMs; + else if (unit.equals(Unit.d)) + value = ((double) count * 24d * 60d * 60d * 1000d) / periodMs; + else + throw new ArgeoException("Unsupported unit " + unit); + this.unit = unit; + } + public Throughput(Double value, String unitStr) { this(value, Unit.valueOf(unitStr)); } -- 2.30.2