00001 /* 00002 * ################################################################ 00003 * 00004 * ProActive: The Java(TM) library for Parallel, Distributed, 00005 * Concurrent computing with Security and Mobility 00006 * 00007 * Copyright (C) 1997-2007 INRIA/University of Nice-Sophia Antipolis 00008 * Contact: proactive@objectweb.org 00009 * 00010 * This library is free software; you can redistribute it and/or 00011 * modify it under the terms of the GNU Lesser General Public 00012 * License as published by the Free Software Foundation; either 00013 * version 2.1 of the License, or any later version. 00014 * 00015 * This library is distributed in the hope that it will be useful, 00016 * but WITHOUT ANY WARRANTY; without even the implied warranty of 00017 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00018 * Lesser General Public License for more details. 00019 * 00020 * You should have received a copy of the GNU Lesser General Public 00021 * License along with this library; if not, write to the Free Software 00022 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 00023 * USA 00024 * 00025 * Initial developer(s): The ProActive Team 00026 * http://www.inria.fr/oasis/ProActive/contacts.html 00027 * Contributor(s): 00028 * 00029 * ################################################################ 00030 */ 00031 package org.objectweb.proactive.benchmarks.timit.util; 00032 00043 public class MigratableCounter extends TimerCounter { 00044 00048 private static final long serialVersionUID = 2195039327751012564L; 00049 00050 private TimItReductor netclock; 00051 00052 private long elapsed, latency; 00053 00060 public MigratableCounter(String s) { 00061 super(s); 00062 } 00063 00067 public boolean isMigratable() { 00068 return true; 00069 } 00070 00078 public void setClock(TimItReductor tr) { 00079 this.netclock = tr; 00080 } 00081 00085 public void start() { 00086 this.latency = System.currentTimeMillis(); 00087 this.elapsed = this.netclock.getCurrentTimeMillis(); // ask time to 00088 // network clock 00089 this.latency = System.currentTimeMillis() - this.latency; 00090 this.elapsed -= this.latency / 2; // adjust and consider an symetrical 00091 // connection 00092 } 00093 00097 public void stop() { 00098 this.latency = System.currentTimeMillis(); 00099 this.elapsed = this.netclock.getCurrentTimeMillis() - this.elapsed; 00100 this.latency = System.currentTimeMillis() - this.latency; 00101 this.elapsed -= this.latency / 2; // adjust and consider an symetrical 00102 // connection 00103 00104 super.setValue((int) this.elapsed); 00105 } 00106 }