45 #include <visp3/gui/vpPlot.h>
46 #include <visp3/sensor/vpComedi.h>
50 #ifdef VISP_HAVE_COMEDI
56 #ifdef VISP_HAVE_DISPLAY
57 vpPlot scope(1, 700, 700, 100, 200,
58 std::string(
"ATI physical sensor data (") + comedi.
getPhyDataUnits() + std::string(
")"));
60 #if (VISP_CXX_STANDARD >= VISP_CXX_STANDARD_11)
61 for (
unsigned int i = 0; i < comedi.
getNChannel(); i++) {
62 scope.setLegend(0, i,
"G" + ((std::ostringstream() << i)).str());
67 std::string file(
"recorded-physical-data-sync.txt");
68 std::ofstream f(file.c_str());
71 #ifdef VISP_HAVE_DISPLAY
74 std::cout <<
"Data recording during 20 seconds in progress..." << std::endl;
80 double timestamp = loop_time - start_time;
82 f << timestamp <<
" " << phydata.
t() << std::endl;
84 #ifdef VISP_HAVE_DISPLAY
85 scope.plot(0, timestamp, phydata);
93 std::cout <<
"You should install comedi to enable this test..." << std::endl;
Implementation of column vector and the associated operations.
void setChannelNumbers(const unsigned int &nchannel)
void setDevice(const std::string &device)
Set comedi device name. Default value is /dev/comedi0.
unsigned int getNChannel() const
Get number of channels.
vpColVector getPhyData() const
std::string getPhyDataUnits() const
static bool getClick(const vpImage< unsigned char > &I, bool blocking=true)
This class enables real time drawing of 2D or 3D graphics. An instance of the class open a window whi...
VISP_EXPORT int wait(double t0, double t)
VISP_EXPORT double measureTimeMs()