GNU Radio Manual and C++ API Reference  3.7.9.2
The Free & Open Software Radio Ecosystem
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
FrequencyDisplayPlot.h
Go to the documentation of this file.
1 /* -*- c++ -*- */
2 /*
3  * Copyright 2008-2011 Free Software Foundation, Inc.
4  *
5  * This file is part of GNU Radio
6  *
7  * GNU Radio is free software; you can redistribute it and/or modify
8  * it under the terms of the GNU General Public License as published by
9  * the Free Software Foundation; either version 3, or (at your option)
10  * any later version.
11  *
12  * GNU Radio is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15  * GNU General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License
18  * along with GNU Radio; see the file COPYING. If not, write to
19  * the Free Software Foundation, Inc., 51 Franklin Street,
20  * Boston, MA 02110-1301, USA.
21  */
22 
23 #ifndef FREQUENCY_DISPLAY_PLOT_HPP
24 #define FREQUENCY_DISPLAY_PLOT_HPP
25 
26 #include <stdint.h>
27 #include <cstdio>
28 #include <vector>
30 
31 /*!
32  * \brief QWidget for displaying frequency domain (PSD) plots.
33  * \ingroup qtgui_blk
34  */
36 {
37  Q_OBJECT
38 
39  Q_PROPERTY ( QColor min_fft_color READ getMinFFTColor WRITE setMinFFTColor )
40  Q_PROPERTY ( QColor max_fft_color READ getMaxFFTColor WRITE setMaxFFTColor )
41  Q_PROPERTY ( bool min_fft_visible READ getMinFFTVisible WRITE setMinFFTVisible )
42  Q_PROPERTY ( bool max_fft_visible READ getMaxFFTVisible WRITE setMaxFFTVisible )
43  Q_PROPERTY ( QColor marker_lower_intensity_color READ getMarkerLowerIntensityColor WRITE setMarkerLowerIntensityColor )
44  Q_PROPERTY ( bool marker_lower_intensity_visible READ getMarkerLowerIntensityVisible WRITE setMarkerLowerIntensityVisible )
45  Q_PROPERTY ( QColor marker_upper_intensity_color READ getMarkerUpperIntensityColor WRITE setMarkerUpperIntensityColor )
46  Q_PROPERTY ( bool marker_upper_intensity_visible READ getMarkerUpperIntensityVisible WRITE setMarkerUpperIntensityVisible )
47  Q_PROPERTY ( QColor marker_peak_amplitude_color READ getMarkerPeakAmplitudeColor WRITE setMarkerPeakAmplitudeColor )
48  Q_PROPERTY ( QColor marker_noise_floor_amplitude_color READ getMarkerNoiseFloorAmplitudeColor WRITE setMarkerNoiseFloorAmplitudeColor )
49  Q_PROPERTY ( bool marker_noise_floor_amplitude_visible READ getMarkerNoiseFloorAmplitudeVisible WRITE setMarkerNoiseFloorAmplitudeVisible )
50  Q_PROPERTY ( QColor marker_CF_color READ getMarkerCFColor WRITE setMarkerCFColor )
51 
52 public:
53  FrequencyDisplayPlot(int nplots, QWidget*);
54  virtual ~FrequencyDisplayPlot();
55 
56  void setFrequencyRange(const double, const double,
57  const double units=1000.0,
58  const std::string &strunits = "kHz");
59  double getStartFrequency()const;
60  double getStopFrequency()const;
61 
62  void plotNewData(const std::vector<double*> dataPoints,
63  const int64_t numDataPoints,
64  const double noiseFloorAmplitude, const double peakFrequency,
65  const double peakAmplitude, const double timeInterval);
66 
67  // Old method to be removed
68  void plotNewData(const double* dataPoints,
69  const int64_t numDataPoints,
70  const double noiseFloorAmplitude, const double peakFrequency,
71  const double peakAmplitude, const double timeInterval);
72 
73  void replot();
74 
75  void setYaxis(double min, double max);
76  double getYMin() const;
77  double getYMax() const;
78 
79  void setTraceColour (QColor);
80  void setBGColour (QColor c);
81  void showCFMarker (const bool);
82 
83  const bool getMaxFFTVisible() const;
84  const bool getMinFFTVisible() const;
85  const QColor getMinFFTColor() const;
86  const QColor getMaxFFTColor() const;
87  const QColor getMarkerLowerIntensityColor () const;
88  const bool getMarkerLowerIntensityVisible () const;
89  const QColor getMarkerUpperIntensityColor () const;
90  const bool getMarkerUpperIntensityVisible () const;
91  const QColor getMarkerPeakAmplitudeColor () const;
92  const bool getMarkerNoiseFloorAmplitudeVisible () const;
93  const QColor getMarkerNoiseFloorAmplitudeColor () const;
94  const QColor getMarkerCFColor () const;
95 
96 public slots:
97  void setMaxFFTVisible(const bool);
98  void setMinFFTVisible(const bool);
99  void setMinFFTColor (QColor c);
100  void setMaxFFTColor (QColor c);
101  void setMarkerLowerIntensityColor (QColor c);
102  void setMarkerLowerIntensityVisible (bool visible);
103  void setMarkerUpperIntensityColor (QColor c);
104  void setMarkerUpperIntensityVisible (bool visible);
105  void setMarkerPeakAmplitudeColor (QColor c);
106  void setMarkerNoiseFloorAmplitudeVisible (bool visible);
107  void setMarkerNoiseFloorAmplitudeColor (QColor c);
108  void setMarkerCFColor (QColor c);
109 
110  void setLowerIntensityLevel(const double);
111  void setUpperIntensityLevel(const double);
112 
113  void onPickerPointSelected(const QwtDoublePoint & p);
114  void onPickerPointSelected6(const QPointF & p);
115 
116  void setAutoScale(bool state);
117  void setAutoScaleShot();
118 
119  void setPlotPosHalf(bool half);
120 
121  void clearMaxData();
122  void clearMinData();
123 
124  void attachTriggerLine(bool en);
125  void setTriggerLine(double value);
126 
127 private:
128  void _resetXAxisPoints();
129  void _autoScale(double bottom, double top);
130 
131  std::vector<double*> d_ydata;
132 
133  QwtPlotCurve* d_min_fft_plot_curve;
134  QwtPlotCurve* d_max_fft_plot_curve;
135  QColor d_min_fft_color;
136  bool d_min_fft_visible;
137  QColor d_max_fft_color;
138  bool d_max_fft_visible;
139  QColor d_marker_lower_intensity_color;
140  bool d_marker_lower_intensity_visible;
141  QColor d_marker_upper_intensity_color;
142  bool d_marker_upper_intensity_visible;
143  QColor d_marker_peak_amplitude_color;
144  QColor d_marker_noise_floor_amplitude_color;
145  bool d_marker_noise_floor_amplitude_visible;
146  QColor d_marker_cf_color;
147 
148  double d_start_frequency;
149  double d_stop_frequency;
150  double d_center_frequency;
151  double d_ymax;
152  double d_ymin;
153  bool d_half_freq;
154 
155  QwtPlotMarker* d_lower_intensity_marker;
156  QwtPlotMarker* d_upper_intensity_marker;
157 
158  QwtPlotMarker *d_marker_peak_amplitude;
159  QwtPlotMarker *d_marker_noise_floor_amplitude;
160  QwtPlotMarker *d_marker_cf;
161 
162  double* d_xdata;
163  int d_xdata_multiplier;
164 
165  double* d_min_fft_data;
166  double* d_max_fft_data;
167 
168  double d_peak_frequency;
169  double d_peak_amplitude;
170 
171  double d_noise_floor_amplitude;
172 
173  bool d_autoscale_shot;
174 
175  QwtPlotMarker *d_trigger_line;
176 };
177 
178 #endif /* FREQUENCY_DISPLAY_PLOT_HPP */
const bool getMarkerNoiseFloorAmplitudeVisible() const
void setAutoScale(bool state)
void setMarkerLowerIntensityVisible(bool visible)
const bool getMarkerLowerIntensityVisible() const
const bool getMaxFFTVisible() const
const QColor getMaxFFTColor() const
void onPickerPointSelected6(const QPointF &p)
void setFrequencyRange(const double, const double, const double units=1000.0, const std::string &strunits="kHz")
void setMarkerCFColor(QColor c)
QWidget base plot to build QTGUI plotting tools.
Definition: DisplayPlot.h:61
float min(float a, float b)
void setUpperIntensityLevel(const double)
void setTriggerLine(double value)
void plotNewData(const std::vector< double * > dataPoints, const int64_t numDataPoints, const double noiseFloorAmplitude, const double peakFrequency, const double peakAmplitude, const double timeInterval)
double getStartFrequency() const
void setMaxFFTColor(QColor c)
void attachTriggerLine(bool en)
void setMarkerPeakAmplitudeColor(QColor c)
void setPlotPosHalf(bool half)
double getYMin() const
double getYMax() const
const bool getMinFFTVisible() const
const QColor getMarkerNoiseFloorAmplitudeColor() const
void showCFMarker(const bool)
void setLowerIntensityLevel(const double)
void onPickerPointSelected(const QwtDoublePoint &p)
const bool getMarkerUpperIntensityVisible() const
void setYaxis(double min, double max)
QWidget for displaying frequency domain (PSD) plots.
Definition: FrequencyDisplayPlot.h:35
const QColor getMarkerLowerIntensityColor() const
const QColor getMarkerPeakAmplitudeColor() const
void setMarkerNoiseFloorAmplitudeVisible(bool visible)
double getStopFrequency() const
const QColor getMarkerUpperIntensityColor() const
void setMarkerUpperIntensityColor(QColor c)
void setMinFFTVisible(const bool)
FrequencyDisplayPlot(int nplots, QWidget *)
void setTraceColour(QColor)
void setMarkerNoiseFloorAmplitudeColor(QColor c)
const QColor getMinFFTColor() const
void setBGColour(QColor c)
void setMinFFTColor(QColor c)
void setMarkerLowerIntensityColor(QColor c)
const QColor getMarkerCFColor() const
void setMaxFFTVisible(const bool)
void setMarkerUpperIntensityVisible(bool visible)
virtual ~FrequencyDisplayPlot()