External/Aga.Controls/PerformanceAnalyzer.cs
author moel.mich
Sun, 09 Jun 2013 17:44:05 +0000
changeset 400 f4e2e3e69651
permissions -rw-r--r--
Added Fahrenheit support to the plot.
moel@345
     1
using System;
moel@345
     2
using System.Collections.Generic;
moel@345
     3
using System.Text;
moel@345
     4
using System.Diagnostics;
moel@345
     5
moel@345
     6
namespace Aga.Controls
moel@345
     7
{
moel@345
     8
	/// <summary>
moel@345
     9
	/// Is used to analyze code performance
moel@345
    10
	/// </summary>
moel@345
    11
	public static class PerformanceAnalyzer
moel@345
    12
	{
moel@345
    13
		public class PerformanceInfo
moel@345
    14
		{
moel@345
    15
			private string _name;
moel@345
    16
			public string Name
moel@345
    17
			{
moel@345
    18
				get { return _name; }
moel@345
    19
			}
moel@345
    20
moel@345
    21
			private int _count = 0;
moel@345
    22
			public int Count
moel@345
    23
			{
moel@345
    24
				get { return _count; }
moel@345
    25
				set { _count = value; }
moel@345
    26
			}
moel@345
    27
moel@345
    28
			private double _totalTime = 0;
moel@345
    29
			public double TotalTime
moel@345
    30
			{
moel@345
    31
				get { return _totalTime; }
moel@345
    32
				set { _totalTime = value; }
moel@345
    33
			}
moel@345
    34
moel@345
    35
			private Int64 _start;
moel@345
    36
			public Int64 Start
moel@345
    37
			{
moel@345
    38
				get { return _start; }
moel@345
    39
				set { _start = value; }
moel@345
    40
			}
moel@345
    41
moel@345
    42
			public PerformanceInfo(string name)
moel@345
    43
			{
moel@345
    44
				_name = name;
moel@345
    45
			}
moel@345
    46
		}
moel@345
    47
moel@345
    48
		private static Dictionary<string, PerformanceInfo> _performances = new Dictionary<string, PerformanceInfo>();
moel@345
    49
moel@345
    50
		public static IEnumerable<PerformanceInfo> Performances
moel@345
    51
		{
moel@345
    52
			get
moel@345
    53
			{
moel@345
    54
				return _performances.Values;
moel@345
    55
			}
moel@345
    56
		}
moel@345
    57
moel@345
    58
		[Conditional("DEBUG")]
moel@345
    59
		public static void Start(string pieceOfCode)
moel@345
    60
		{
moel@345
    61
			PerformanceInfo info = null;
moel@345
    62
			lock(_performances)
moel@345
    63
			{
moel@345
    64
				if (_performances.ContainsKey(pieceOfCode))
moel@345
    65
					info = _performances[pieceOfCode];
moel@345
    66
				else
moel@345
    67
				{
moel@345
    68
					info = new PerformanceInfo(pieceOfCode);
moel@345
    69
					_performances.Add(pieceOfCode, info);
moel@345
    70
				}
moel@345
    71
moel@345
    72
				info.Count++;
moel@345
    73
				info.Start = TimeCounter.GetStartValue();
moel@345
    74
			}
moel@345
    75
		}
moel@345
    76
moel@345
    77
		[Conditional("DEBUG")]
moel@345
    78
		public static void Finish(string pieceOfCode)
moel@345
    79
		{
moel@345
    80
			lock (_performances)
moel@345
    81
			{
moel@345
    82
				if (_performances.ContainsKey(pieceOfCode))
moel@345
    83
				{
moel@345
    84
					PerformanceInfo info = _performances[pieceOfCode];
moel@345
    85
					info.Count++;
moel@345
    86
					info.TotalTime += TimeCounter.Finish(info.Start);
moel@345
    87
				}
moel@345
    88
			}
moel@345
    89
		}
moel@345
    90
moel@345
    91
		public static void Reset()
moel@345
    92
		{
moel@345
    93
			_performances.Clear();
moel@345
    94
		}
moel@345
    95
moel@345
    96
		public static string GenerateReport()
moel@345
    97
		{
moel@345
    98
			return GenerateReport(0);
moel@345
    99
		}
moel@345
   100
moel@345
   101
		public static string GenerateReport(string mainPieceOfCode)
moel@345
   102
		{
moel@345
   103
			if (_performances.ContainsKey(mainPieceOfCode))
moel@345
   104
				return GenerateReport(_performances[mainPieceOfCode].TotalTime);
moel@345
   105
			else
moel@345
   106
				return GenerateReport(0);
moel@345
   107
		}
moel@345
   108
moel@345
   109
		public static string GenerateReport(double totalTime)
moel@345
   110
		{
moel@345
   111
			StringBuilder sb = new StringBuilder();
moel@345
   112
			int len = 0;
moel@345
   113
			foreach (PerformanceInfo info in Performances)
moel@345
   114
				len = Math.Max(info.Name.Length, len);
moel@345
   115
moel@345
   116
			sb.AppendLine("Name".PadRight(len) + " Count              Total Time, ms    Avg. Time, ms       Percentage, %");
moel@345
   117
			sb.AppendLine("----------------------------------------------------------------------------------------------");
moel@345
   118
			foreach (PerformanceInfo info in Performances)
moel@345
   119
			{
moel@345
   120
				sb.Append(info.Name.PadRight(len));
moel@345
   121
				double p = 0;
moel@345
   122
				double avgt = 0;
moel@345
   123
				if (totalTime != 0)
moel@345
   124
					p = info.TotalTime / totalTime;
moel@345
   125
				if (info.Count > 0)
moel@345
   126
					avgt = info.TotalTime * 1000 / info.Count;
moel@345
   127
				string c = info.Count.ToString("0,0").PadRight(20);
moel@345
   128
				string tt = (info.TotalTime * 1000).ToString("0,0.00").PadRight(20);
moel@345
   129
				string t = avgt.ToString("0.0000").PadRight(20);
moel@345
   130
				string sp = (p * 100).ToString("###").PadRight(20);
moel@345
   131
				sb.AppendFormat(" " + c + tt + t + sp + "\n");
moel@345
   132
			}
moel@345
   133
			return sb.ToString();
moel@345
   134
		}
moel@345
   135
	}
moel@345
   136
}