/* Copyright (C) 2003 Univ. of Massachusetts Amherst, Computer Science Dept.
This file is part of "MALLET" (MAchine Learning for LanguagE Toolkit).
http://www.cs.umass.edu/~mccallum/mallet
This software is provided under the terms of the Common Public License,
version 1.0, as published by http://www.opensource.org. For further
information, see the file `LICENSE' included with this distribution. */
//package cc.mallet.util;
/**
* A class for timing things.
* Originally inspired by the Timing class in the Stanford NLP cade,
* but completely rewritten.
*
* Created: Dec 30, 2004
*
* @author casutton@cs.umass.edu
* @version $Id: Timing.java,v 1.1 2007/10/22 21:37:40 mccallum Exp $
*/
public class Timing {
private long objCreationTime;
private long startTime;
public Timing ()
{
startTime = System.currentTimeMillis ();
objCreationTime = startTime;
}
/**
* Print to System.out how much time has passed, resetting this Timing's start time to
* the current time. Time is measured from the most recent
* tick
call, or when this object was created.
*
* @param msg Prefix of string printed with time
* @return Number of elapsed milliseconds from tick (or start)
*/
public long tick (String msg)
{
long elapsed = report (msg);
startTime = System.currentTimeMillis ();
return elapsed;
}
/**
* Returns how much time as passed since Object creation, or the most recent call to tick().
* @return Number of elapsed milliseconds
*/
public long elapsedTime ()
{
return System.currentTimeMillis () - startTime;
}
/**
* Returns the number of milliseconds since this object was created.
* Ignores previous calls to tick, unlike
* elapsedTime and tick.
*/
public long totalElapsedTime ()
{
return System.currentTimeMillis () - objCreationTime;
}
/** Like tick(), but doesn't reset the counter. */
public long report (String msg)
{
long currentTime = System.currentTimeMillis ();
long elapsed = currentTime - startTime;
System.out.println (msg + " time (ms) = " + (elapsed));
return elapsed;
}
}