Author: bfoster
Date: Fri Dec 10 18:05:07 2010
New Revision: 1044460
URL: http://svn.apache.org/viewvc?rev=1044460&view=rev
Log:
- Commons TimeEventWeightedHash throws a StackOverthrow Error when epsilon is
large and event duration is small
- Added UnitTest class for TimeEventWeightedHash
------------------
OODT-76
Added:
oodt/trunk/commons/src/test/org/apache/oodt/commons/filter/
oodt/trunk/commons/src/test/org/apache/oodt/commons/filter/TestTimeEventWeightedHash.java
(with props)
Modified:
oodt/trunk/CHANGES.txt
oodt/trunk/commons/src/main/java/org/apache/oodt/commons/filter/TimeEventWeightedHash.java
Modified: oodt/trunk/CHANGES.txt
URL:
http://svn.apache.org/viewvc/oodt/trunk/CHANGES.txt?rev=1044460&r1=1044459&r2=1044460&view=diff
==============================================================================
--- oodt/trunk/CHANGES.txt (original)
+++ oodt/trunk/CHANGES.txt Fri Dec 10 18:05:07 2010
@@ -4,6 +4,8 @@ Apache OODT Change Log
Release 0.2 (Current Development)
--------------------------------------------
+* OODT-76 Commons TimeEventWeightedHash throws a StackOverthrow Error when
epsilon is large and event duration is small (bfoster)
+
* OODT-9 Create a generic OpenDAP profile server (mattmann, Victor Hwang,
smcclees)
* OODT-67 All Loggers should be "static final" (bfoster)
Modified:
oodt/trunk/commons/src/main/java/org/apache/oodt/commons/filter/TimeEventWeightedHash.java
URL:
http://svn.apache.org/viewvc/oodt/trunk/commons/src/main/java/org/apache/oodt/commons/filter/TimeEventWeightedHash.java?rev=1044460&r1=1044459&r2=1044460&view=diff
==============================================================================
---
oodt/trunk/commons/src/main/java/org/apache/oodt/commons/filter/TimeEventWeightedHash.java
(original)
+++
oodt/trunk/commons/src/main/java/org/apache/oodt/commons/filter/TimeEventWeightedHash.java
Fri Dec 10 18:05:07 2010
@@ -132,7 +132,7 @@ public class TimeEventWeightedHash {
for (TimeEventNode parent : parentNodes) {
possibleChildrenNodes.addAll(parent.getChildren());
TimeEventNode curPCN = possibleChildrenNodes.get(0);
- while (curPCN != null) {
+ while (curPCN != null && !parentNodes.contains(curPCN)) {
if (happensBefore(newEvent, curPCN.getTimeEvent())) {
childrenNodes.add(curPCN);
}else {
@@ -147,7 +147,7 @@ public class TimeEventWeightedHash {
private boolean happensBefore(TimeEvent t1, TimeEvent t2) {
long boundaryCheck = t2.getStartTime() - t1.getEndTime();
- return (boundaryCheck + epsilon) > 0;
+ return t1.getStartTime() < t2.getStartTime() && (boundaryCheck +
epsilon) > 0;
}
private WeightedNode getGreatestWeightedPath() {
Added:
oodt/trunk/commons/src/test/org/apache/oodt/commons/filter/TestTimeEventWeightedHash.java
URL:
http://svn.apache.org/viewvc/oodt/trunk/commons/src/test/org/apache/oodt/commons/filter/TestTimeEventWeightedHash.java?rev=1044460&view=auto
==============================================================================
---
oodt/trunk/commons/src/test/org/apache/oodt/commons/filter/TestTimeEventWeightedHash.java
(added)
+++
oodt/trunk/commons/src/test/org/apache/oodt/commons/filter/TestTimeEventWeightedHash.java
Fri Dec 10 18:05:07 2010
@@ -0,0 +1,122 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.apache.oodt.commons.filter;
+
+//JDK imports
+import java.util.LinkedList;
+import java.util.List;
+
+//Junit imports
+import junit.framework.TestCase;
+
+/**
+ * @author bfoster
+ * @version $Revision$
+ *
+ * <p>
+ * Test case for {...@link TimeEventWeightedHash}
+ * </p>.
+ */
+public class TestTimeEventWeightedHash extends TestCase {
+
+ public void testBuildHash() {
+ List<TimeEvent> events = new LinkedList<TimeEvent>();
+ events.add(new ObjectTimeEvent<String>(31, 32, 2, "1"));
+ events.add(new ObjectTimeEvent<String>(20, 30, 1, "2"));
+ events.add(new ObjectTimeEvent<String>(1, 8, 2, "3"));
+ events.add(new ObjectTimeEvent<String>(8, 15, 1, "4"));
+ events.add(new ObjectTimeEvent<String>(18, 20, 3, "5"));
+ events.add(new ObjectTimeEvent<String>(10, 12, 1, "6"));
+ events.add(new ObjectTimeEvent<String>(20, 30, 2, "7"));
+ events.add(new ObjectTimeEvent<String>(1, 20, 1, "8"));
+ events.add(new ObjectTimeEvent<String>(11, 13, 1, "9"));
+ events.add(new ObjectTimeEvent<String>(15, 20, 1, "10"));
+ events.add(new ObjectTimeEvent<String>(18, 20, 2, "11"));
+ events.add(new ObjectTimeEvent<String>(1, 15, 1, "12"));
+ events.add(new ObjectTimeEvent<String>(1, 18, 2, "13"));
+ TimeEventWeightedHash timeEventHash =
TimeEventWeightedHash.buildHash(events);
+
+ List<ObjectTimeEvent> orderedEvents = (List<ObjectTimeEvent>)
timeEventHash.getGreatestWeightedPathAsOrderedList();
+ assertEquals(orderedEvents.size(), 3);
+ assertEquals(orderedEvents.get(0).getTimeObject().toString(),
"13");
+ assertEquals(orderedEvents.get(1).getTimeObject().toString(),
"7");
+ assertEquals(orderedEvents.get(2).getTimeObject().toString(),
"1");
+
+ events = new LinkedList<TimeEvent>();
+ events.add(new ObjectTimeEvent<String>(33, 215, 1, "1"));
+ events.add(new ObjectTimeEvent<String>(215, 359, 1, "2"));
+ events.add(new ObjectTimeEvent<String>(358, 541, 1, "3"));
+ events.add(new ObjectTimeEvent<String>(541, 723, 1, "4"));
+ events.add(new ObjectTimeEvent<String>(723, 904, 1, "5"));
+ events.add(new ObjectTimeEvent<String>(904, 904, 1, "6"));
+ events.add(new ObjectTimeEvent<String>(904, 1045, 1, "7"));
+ events.add(new ObjectTimeEvent<String>(905, 905, 1, "8"));
+ events.add(new ObjectTimeEvent<String>(906, 907, 1, "9"));
+ events.add(new ObjectTimeEvent<String>(907, 908, 1, "10"));
+ events.add(new ObjectTimeEvent<String>(908, 908, 1, "11"));
+ events.add(new ObjectTimeEvent<String>(908, 909, 1, "12"));
+ events.add(new ObjectTimeEvent<String>(923, 924, 1, "13"));
+ events.add(new ObjectTimeEvent<String>(926, 927, 1, "14"));
+ events.add(new ObjectTimeEvent<String>(927, 928, 1, "15"));
+ events.add(new ObjectTimeEvent<String>(942, 943, 1, "16"));
+ events.add(new ObjectTimeEvent<String>(945, 946, 1, "17"));
+ events.add(new ObjectTimeEvent<String>(946, 946, 1, "18"));
+ events.add(new ObjectTimeEvent<String>(947, 947, 1, "19"));
+ events.add(new ObjectTimeEvent<String>(1004, 1005, 1, "20"));
+ events.add(new ObjectTimeEvent<String>(1005, 1005, 1, "21"));
+ events.add(new ObjectTimeEvent<String>(1006, 1006, 1, "22"));
+ events.add(new ObjectTimeEvent<String>(1007, 1007, 1, "23"));
+ events.add(new ObjectTimeEvent<String>(1025, 1026, 1, "24"));
+ events.add(new ObjectTimeEvent<String>(1026, 1026, 1, "25"));
+ events.add(new ObjectTimeEvent<String>(1027, 1028, 1, "26"));
+ events.add(new ObjectTimeEvent<String>(1045, 1046, 1, "27"));
+ events.add(new ObjectTimeEvent<String>(1045, 1225, 1, "28"));
+ events.add(new ObjectTimeEvent<String>(1225, 1406, 1, "29"));
+ events.add(new ObjectTimeEvent<String>(1225, 1226, 1, "30"));
+ events.add(new ObjectTimeEvent<String>(1226, 1227, 1, "31"));
+ events.add(new ObjectTimeEvent<String>(1227, 1227, 1, "32"));
+ events.add(new ObjectTimeEvent<String>(1228, 1228, 1, "33"));
+ events.add(new ObjectTimeEvent<String>(1406, 1546, 1, "34"));
+ events.add(new ObjectTimeEvent<String>(1545, 1725, 1, "35"));
+ events.add(new ObjectTimeEvent<String>(1545, 1554, 1, "36"));
+ events.add(new ObjectTimeEvent<String>(1725, 1906, 1, "37"));
+ events.add(new ObjectTimeEvent<String>(1906, 2047, 1, "38"));
+ events.add(new ObjectTimeEvent<String>(1906, 1922, 1, "39"));
+ events.add(new ObjectTimeEvent<String>(2047, 2228, 1, "40"));
+ events.add(new ObjectTimeEvent<String>(2228, 2412, 1, "41"));
+ timeEventHash = TimeEventWeightedHash.buildHash(events, 2);
+
+ orderedEvents = (List<ObjectTimeEvent>)
timeEventHash.getGreatestWeightedPathAsOrderedList();
+ assertEquals(orderedEvents.size(), 14);
+ assertEquals(orderedEvents.get(0).getTimeObject().toString(),
"1");
+ assertEquals(orderedEvents.get(1).getTimeObject().toString(),
"2");
+ assertEquals(orderedEvents.get(2).getTimeObject().toString(),
"3");
+ assertEquals(orderedEvents.get(3).getTimeObject().toString(),
"4");
+ assertEquals(orderedEvents.get(4).getTimeObject().toString(),
"5");
+ assertEquals(orderedEvents.get(5).getTimeObject().toString(),
"7");
+ assertEquals(orderedEvents.get(6).getTimeObject().toString(),
"28");
+ assertEquals(orderedEvents.get(7).getTimeObject().toString(),
"29");
+ assertEquals(orderedEvents.get(8).getTimeObject().toString(),
"34");
+ assertEquals(orderedEvents.get(9).getTimeObject().toString(),
"35");
+ assertEquals(orderedEvents.get(10).getTimeObject().toString(),
"37");
+ assertEquals(orderedEvents.get(11).getTimeObject().toString(),
"38");
+ assertEquals(orderedEvents.get(12).getTimeObject().toString(),
"40");
+ assertEquals(orderedEvents.get(13).getTimeObject().toString(),
"41");
+ }
+
+}
Propchange:
oodt/trunk/commons/src/test/org/apache/oodt/commons/filter/TestTimeEventWeightedHash.java
------------------------------------------------------------------------------
svn:mime-type = text/plain