12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152 |
- using System;
- using System.Collections.Generic;
- using System.Diagnostics;
- using System.Linq;
- using System.Text;
- using System.Threading.Tasks;
- namespace bbiwarg.Utility
- {
- class Timer
- {
- private static Dictionary<String, Stopwatch> stopwatches = new Dictionary<string, Stopwatch>();
- private static Dictionary<String, long> minTimes = new Dictionary<string, long>();
- private static Dictionary<String, long> maxTimes = new Dictionary<string, long>();
- private static Dictionary<String, long> sumTimes = new Dictionary<string, long>();
- private static Dictionary<String, int> numTimes = new Dictionary<string, int>();
- public static void start(String name) {
- if (!stopwatches.ContainsKey(name))
- {
- stopwatches.Add(name, new Stopwatch());
- minTimes.Add(name, int.MaxValue);
- maxTimes.Add(name, 0);
- sumTimes.Add(name, 0);
- numTimes.Add(name, 0);
- }
- stopwatches[name].Restart();
- }
- public static void stop(String name) {
- stopwatches[name].Stop();
- long time = stopwatches[name].ElapsedMilliseconds;
- if (time < minTimes[name]) minTimes[name] = time;
- if (time > maxTimes[name]) maxTimes[name] = time;
- sumTimes[name] += time;
- numTimes[name]++;
- }
- public static void output(String name) {
- Console.WriteLine("name:" + name + "\t" + "mean:" + (sumTimes[name] / Math.Max(numTimes[name],1)) + "\t" + "min:" + minTimes[name] + "\t" + "max:" + maxTimes[name]);
- }
- public static void outputAll() {
- Console.WriteLine("---TIMERS-START---");
- foreach (String name in stopwatches.Keys) {
- output(name);
- }
- Console.WriteLine("---TIMERS-END---");
- }
- }
- }
|