ctkVTKConnectionTest1.cpp 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. // Qt includes
  2. #include <QApplication>
  3. #include <QDebug>
  4. #include <QWidget>
  5. // CTKVTK includes
  6. #include "ctkVTKConnection.h"
  7. // STD includes
  8. #include <cstdlib>
  9. #include <iostream>
  10. // VTK includes
  11. #include <vtkCallbackCommand.h>
  12. #include <vtkCommand.h>
  13. #include <vtkObject.h>
  14. #include <vtkSmartPointer.h>
  15. #include <vtkTimerLog.h>
  16. void doit(vtkObject* obj, unsigned long event, void* client_data, void* param)
  17. {
  18. QWidget* w = reinterpret_cast<QWidget*>(client_data);
  19. w->setFocus();
  20. }
  21. int ctkVTKConnectionTest1( int argc, char * argv [] )
  22. {
  23. QApplication app(argc, argv);
  24. vtkObject* obj = vtkObject::New();
  25. QWidget topLevelWidget;
  26. int objects = 1000;
  27. int events = 100;
  28. for (int i = 0; i < objects; ++i)
  29. {
  30. ctkVTKConnection* objectTest = new ctkVTKConnection(&topLevelWidget);
  31. objectTest->SetParameters(obj, vtkCommand::ModifiedEvent,
  32. &topLevelWidget, SLOT(setFocus()));
  33. objectTest->setEnabled(true);
  34. }
  35. vtkSmartPointer<vtkTimerLog> timerLog =
  36. vtkSmartPointer<vtkTimerLog>::New();
  37. timerLog->StartTimer();
  38. for (int i = 0; i < events; ++i)
  39. {
  40. obj->Modified();
  41. }
  42. timerLog->StopTimer();
  43. double t1 = timerLog->GetElapsedTime();
  44. qDebug() << events << "events listened by" << objects << "objects (ctkVTKConnection): " << t1 << "seconds";
  45. obj->Delete();
  46. vtkObject* obj2 = vtkObject::New();
  47. for (int i = 0; i < objects; ++i)
  48. {
  49. vtkCallbackCommand* callback = vtkCallbackCommand::New();
  50. callback->SetClientData(&topLevelWidget);
  51. callback->SetCallback(doit);
  52. obj2->AddObserver(vtkCommand::ModifiedEvent, callback);
  53. callback->Delete();
  54. }
  55. vtkSmartPointer<vtkTimerLog> timerLog2 =
  56. vtkSmartPointer<vtkTimerLog>::New();
  57. timerLog2->StartTimer();
  58. for (int i = 0; i < events; ++i)
  59. {
  60. obj2->Modified();
  61. }
  62. timerLog2->StopTimer();
  63. double t2 = timerLog2->GetElapsedTime();
  64. qDebug() << events << "events listened by" << objects <<"objects (vtkCallbacks): " << t2 << "seconds";
  65. double ratio = t1 / t2;
  66. qDebug() << "ctkVTKConnection / vtkCallbacks: " << ratio;
  67. // Ideally a ratio of 2 (a callback and a signal/slot connection is used
  68. // is used in ctkVTKConnection
  69. if (ratio > 2.5)
  70. {
  71. return EXIT_FAILURE;
  72. }
  73. obj2->Delete();
  74. return EXIT_SUCCESS;
  75. }