/*
* Copyright (C) 2021 Daniel Dietsch (dietsch@informatik.uni-freiburg.de)
* Copyright (C) 2021 University of Freiburg
*
* This file is part of the ULTIMATE Util Library.
*
* The ULTIMATE Util Library is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published
* by the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* The ULTIMATE Util Library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with the ULTIMATE Util Library. If not, see .
*
* Additional permission under GNU GPL version 3 section 7:
* If you modify the ULTIMATE Util Library, or any covered work, by linking
* or combining it with Eclipse RCP (or a modified version of Eclipse RCP),
* containing parts covered by the terms of the Eclipse Public License, the
* licensors of the ULTIMATE Util Library grant you additional permission
* to convey the resulting work.
*/
package de.uni_freiburg.informatik.ultimate.util.statistics;
import java.util.concurrent.TimeUnit;
import java.util.function.Supplier;
import de.uni_freiburg.informatik.ultimate.util.CoreUtil;
/**
*
* @author Daniel Dietsch (dietsch@informatik.uni-freiburg.de)
*
*/
public final class TimeTracker {
private long mStartTime = -1L;
private long mElapsedTimeNs;
private long mLastDeltaNs = -1L;
public TimeTracker() {
reset();
}
public T measure(final Supplier fun) {
start();
final T rtr = fun.get();
stop();
return rtr;
}
public void start() {
assert mStartTime == -1L : "TimeTracker already running";
mStartTime = System.nanoTime();
}
public void stop() {
assert mStartTime != -1L : "TimeTracker was not running";
mLastDeltaNs = System.nanoTime() - mStartTime;
mElapsedTimeNs += mLastDeltaNs;
mStartTime = -1L;
}
public void reset() {
mStartTime = -1L;
mElapsedTimeNs = 0L;
mLastDeltaNs = -1L;
}
@Override
public String toString() {
if (mStartTime == -1) {
return "N/A";
}
return CoreUtil.humanReadableTime(mElapsedTimeNs, TimeUnit.NANOSECONDS, 2);
}
public long lastDelta(final TimeUnit unit) {
assert mStartTime == -1L : "TimeTracker currently running";
if (mLastDeltaNs == -1L) {
throw new IllegalStateException("Clock was not started");
}
return unit.convert(mLastDeltaNs, TimeUnit.NANOSECONDS);
}
public long elapsedTime(final TimeUnit unit) {
assert mStartTime == -1L : "TimeTracker currently running";
return unit.convert(mElapsedTimeNs, TimeUnit.NANOSECONDS);
}
}