chr
2026-04-05 fe750b791d5b517cc4e9bc8e99a9a75139a0cfba
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
//            Copyright Keysight Technologies 2012-2019
// This Source Code Form is subject to the terms of the Mozilla Public
// License, v. 2.0. If a copy of the MPL was not distributed with this
// file, you can obtain one at http://mozilla.org/MPL/2.0/.
using System;
using System.Text;
 
 
namespace OpenTap
{
    /// <summary>
    /// Utility class to help print an "ASCII-art" graph with limits in the log files and windows. 
    /// </summary>
    public class TraceBar
    {
        /// <summary>
        /// Gets or sets the lower limit which is also used to determine the range of the graph.
        /// </summary>
        public double LowerLimit { get; set; }
 
        /// <summary>
        /// Gets or sets the upper limit which is also used to determine the range of the graph.
        /// </summary>
        public double UpperLimit { get; set; }
        /// <summary>
        /// Gets or sets a Boolean value indicating whether the result will be printed as a number
        /// next to the bar.
        /// </summary>
        public bool ShowResult { get; set; }
        /// <summary>
        /// Gets or sets a Boolean value indicating whether the verdict (pass/fail) will be shown 
        /// next to the bar.
        /// </summary>
        public bool ShowVerdict { get; set; }
        /// <summary>
        /// Gets or sets the length of the bar in characters.
        /// </summary>
        public byte BarLength { get; set; }
 
        /// <summary>
        /// Combined verdict for all times GetBar has been called.
        /// </summary>
        public Verdict CombinedVerdict { get; private set; }
 
        /// <summary>
        /// Returns a string containing a "tracebar" ready to be printed in the log.
        /// </summary>
        /// <param name="result">The value to visualize in a TraceBar.</param>
        /// <returns>A string containing a "tracebar" ready to be printed in the log.</returns>
        public string GetBar(double result)
        {
            byte stringLength = BarLength;
            double width = (LowerLimit - UpperLimit);
            double stepSize = Math.Abs(width / stringLength);
            bool passed = result <= UpperLimit && result >= LowerLimit;
            Verdict verdict = passed ? Verdict.Pass : Verdict.Fail;
            if (double.IsNaN(result))
                verdict = Verdict.Inconclusive;
            if (verdict > CombinedVerdict)
                CombinedVerdict = verdict;
            StringBuilder bar;
 
            if (ShowResult)
            {
                bar = new StringBuilder();
                bar.AppendFormat("{0,12:G6} ", result);
            }
            else
                bar = new StringBuilder(stringLength + 20);
 
            bar.AppendFormat("{0,6}  ", LowerLimit);
 
            for (byte count = 0; count <= stringLength; count++)
            {
                if (count == 0 & result < LowerLimit)
                {
                    bar.Append('<');
                }
                else if (count == stringLength & result > UpperLimit)
                {
                    bar.Append('>');
                    break;
                }
                else if ((result >= (count * stepSize + LowerLimit)) && (result < ((count + 1) * stepSize + LowerLimit)))
                {
                    bar.Append('|');
                }
                else
                    bar.Append('-');
            }
            bar.AppendFormat(" {0,6}", UpperLimit);
 
            if (ShowVerdict)
            {
                if (!passed)
                {
                    bar.Append("  " + verdict.ToString());
                }
            }
 
            return bar.ToString();
        }
 
        /// <summary>
        /// Initializes a new instance of the TraceBar class.
        /// </summary>
        public TraceBar()
        {
            BarLength = 30;
            LowerLimit = -100;
            UpperLimit = 100;
            ShowResult = true;
            ShowVerdict = true;
            CombinedVerdict = OpenTap.Verdict.NotSet;
        }
 
    }
}