Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(364)

Side by Side Diff: webrtc/tools/event_log_visualizer/plot_base.h

Issue 2179223003: Convenience functions to set axis properties in visualization tool. (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: Created 4 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved. 2 * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license 4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source 5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found 6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may 7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree. 8 * be found in the AUTHORS file in the root of the source tree.
9 */ 9 */
10 #ifndef WEBRTC_TOOLS_EVENT_LOG_VISUALIZER_PLOT_BASE_H_ 10 #ifndef WEBRTC_TOOLS_EVENT_LOG_VISUALIZER_PLOT_BASE_H_
11 #define WEBRTC_TOOLS_EVENT_LOG_VISUALIZER_PLOT_BASE_H_ 11 #define WEBRTC_TOOLS_EVENT_LOG_VISUALIZER_PLOT_BASE_H_
12 12
13 #include <algorithm>
13 #include <memory> 14 #include <memory>
14 #include <string> 15 #include <string>
15 #include <utility> 16 #include <utility>
16 #include <vector> 17 #include <vector>
17 18
19 #include "webrtc/base/checks.h"
20
18 namespace webrtc { 21 namespace webrtc {
19 namespace plotting { 22 namespace plotting {
20 23
21 enum PlotStyle { LINE_GRAPH, BAR_GRAPH }; 24 enum PlotStyle { LINE_GRAPH, BAR_GRAPH };
22 25
23 struct TimeSeriesPoint { 26 struct TimeSeriesPoint {
24 TimeSeriesPoint(float x, float y) : x(x), y(y) {} 27 TimeSeriesPoint(float x, float y) : x(x), y(y) {}
25 float x; 28 float x;
26 float y; 29 float y;
27 }; 30 };
28 31
29 struct TimeSeries { 32 struct TimeSeries {
30 TimeSeries() = default; 33 TimeSeries() = default;
31 TimeSeries(TimeSeries&& other) 34 TimeSeries(TimeSeries&& other)
32 : label(std::move(other.label)), 35 : label(std::move(other.label)),
33 style(other.style), 36 style(other.style),
34 points(std::move(other.points)) {} 37 points(std::move(other.points)) {}
35 TimeSeries& operator=(TimeSeries&& other) { 38 TimeSeries& operator=(TimeSeries&& other) {
36 label = std::move(other.label); 39 label = std::move(other.label);
37 style = other.style; 40 style = other.style;
38 points = std::move(other.points); 41 points = std::move(other.points);
39 return *this; 42 return *this;
40 } 43 }
41 44
42 std::string label; 45 std::string label;
43 PlotStyle style; 46 PlotStyle style;
44 std::vector<TimeSeriesPoint> points; 47 std::vector<TimeSeriesPoint> points;
45 }; 48 };
46 49
47 // This is basically a struct that represents of a general graph, with axes, 50 // This is basically a struct that represents a general graph, with axes,
48 // title and one or more data series. We make it a class only to document that 51 // title and one or more data series. We make it a class only to document that
danilchap 2016/07/26 10:52:46 Comment probably need an update too: This struct b
terelius 2016/07/26 17:37:38 Done.
49 // it also specifies an interface for the draw()ing objects. 52 // it also specifies an interface for the draw()ing objects.
50 class Plot { 53 class Plot {
danilchap 2016/07/26 10:52:46 may be add plot_base.cc and move implementation th
terelius 2016/07/26 17:37:38 Done.
51 public: 54 public:
52 virtual ~Plot() {} 55 virtual ~Plot() {}
53 virtual void draw() = 0; 56 virtual void Draw() = 0;
54 57
55 float xaxis_min; 58 void SetXAxis(float min,
56 float xaxis_max; 59 float max,
57 std::string xaxis_label; 60 std::string label,
58 float yaxis_min; 61 float left_margin = 0,
danilchap 2016/07/26 10:52:46 it doesn't look like you use default arguments (i.
terelius 2016/07/26 17:37:38 They are not used right now, but just setting the
59 float yaxis_max; 62 float right_margin = 0) {
danilchap 2016/07/26 10:52:46 margin doesn't use same units as min/max. It might
terelius 2016/07/26 17:37:38 I added comments indicating that the margins are m
60 std::string yaxis_label; 63 xaxis_min_ = min - left_margin * (max - min);
61 std::vector<TimeSeries> series; 64 xaxis_max_ = max + right_margin * (max - min);
62 std::string title; 65 xaxis_label_ = label;
66 }
67
68 void SetSuggestedXAxis(float min,
69 float max,
70 std::string label,
71 float left_margin = 0,
72 float right_margin = 0) {
73 for (auto& series : series_list_) {
danilchap 2016/07/26 10:52:46 const auto& here and next line
terelius 2016/07/26 17:37:38 Done.
74 for (auto& point : series.points) {
75 min = std::min(min, point.x);
danilchap 2016/07/26 10:52:46 std::min as function and min as variable in same l
terelius 2016/07/26 17:37:38 Done.
76 max = std::max(max, point.x);
77 }
78 }
79 RTC_DCHECK(max >= min);
danilchap 2016/07/26 10:52:46 RTC_DCHECK_LE(min, max); and have this check in Se
terelius 2016/07/26 17:37:38 Done.
80 xaxis_min_ = min - left_margin * (max - min);
danilchap 2016/07/26 10:52:46 may be call SetXAxis instead of duplicating the co
terelius 2016/07/26 17:37:38 Done.
81 xaxis_max_ = max + right_margin * (max - min);
82 xaxis_label_ = label;
83 }
84
85 void SetYAxis(float min,
86 float max,
87 std::string label,
88 float bottom_margin = 0,
89 float top_margin = 0) {
90 yaxis_min_ = min - bottom_margin * (max - min);
91 yaxis_max_ = max + top_margin * (max - min);
92 yaxis_label_ = label;
93 }
94
95 void SetSuggestedYAxis(float min,
96 float max,
97 std::string label,
98 float bottom_margin = 0,
99 float top_margin = 0) {
100 for (auto& series : series_list_) {
101 for (auto& point : series.points) {
102 min = std::min(min, point.y);
103 max = std::max(max, point.y);
104 }
105 }
106 RTC_DCHECK(max >= min);
107 yaxis_min_ = min - bottom_margin * (max - min);
108 yaxis_max_ = max + top_margin * (max - min);
109 yaxis_label_ = label;
110 }
111
112 void SetTitle(std::string title) { title_ = title; }
113
114 std::vector<TimeSeries> series_list_;
danilchap 2016/07/26 10:52:46 Why rename this variable to _list when it is not e
terelius 2016/07/26 17:37:38 This variable is a collection of TimeSeries object
115
116 protected:
danilchap 2016/07/26 10:52:46 either make it private, or update CL description t
terelius 2016/07/26 17:37:38 Can't be private. Updated CL description.
117 float xaxis_min_;
118 float xaxis_max_;
119 std::string xaxis_label_;
120 float yaxis_min_;
121 float yaxis_max_;
122 std::string yaxis_label_;
123 std::string title_;
63 }; 124 };
64 125
65 class PlotCollection { 126 class PlotCollection {
66 public: 127 public:
67 virtual ~PlotCollection() {} 128 virtual ~PlotCollection() {}
68 virtual void draw() = 0; 129 virtual void Draw() = 0;
69 virtual Plot* append_new_plot() = 0; 130 virtual Plot* AppendNewPlot() = 0;
70 131
71 protected: 132 protected:
72 std::vector<std::unique_ptr<Plot> > plots; 133 std::vector<std::unique_ptr<Plot> > plots_;
73 }; 134 };
74 135
75 } // namespace plotting 136 } // namespace plotting
76 } // namespace webrtc 137 } // namespace webrtc
77 138
78 #endif // WEBRTC_TOOLS_EVENT_LOG_VISUALIZER_PLOT_BASE_H_ 139 #endif // WEBRTC_TOOLS_EVENT_LOG_VISUALIZER_PLOT_BASE_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698