main.cpp 55 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367
  1. #include <memory>
  2. #include <tuple>
  3. #include "src/pico_server_dispatcher.hpp"
  4. using namespace std;
  5. extern std::ostream out(cout.rdbuf());
  6. extern SimpleLogger logger(out, "pico", "picologs");
  7. void createDirectoryRecursively(const std::string &directory) {
  8. static const std::string separators("\\/");
  9. // If the specified directory name doesn't exist, do our thing
  10. DWORD fileAttributes = ::GetFileAttributesA(directory.c_str());
  11. if(fileAttributes == INVALID_FILE_ATTRIBUTES) {
  12. // Recursively do it all again for the parent directory, if any
  13. std::size_t slashIndex = directory.find_last_of(separators);
  14. if(slashIndex != std::wstring::npos) {
  15. createDirectoryRecursively(directory.substr(0, slashIndex));
  16. }
  17. // Create the last directory on the path (the recursive calls will have taken
  18. // care of the parent directories by now)
  19. BOOL result = ::CreateDirectoryA(directory.c_str(), nullptr);
  20. if(result == FALSE) {
  21. throw std::runtime_error("Could not create directory");
  22. }
  23. } else { // Specified directory name already exists as a file or directory
  24. bool isDirectoryOrJunction =
  25. ((fileAttributes & FILE_ATTRIBUTE_DIRECTORY) != 0) ||
  26. ((fileAttributes & FILE_ATTRIBUTE_REPARSE_POINT) != 0);
  27. if(!isDirectoryOrJunction) {
  28. throw std::runtime_error(
  29. "Could not create directory because a file with the same name exists"
  30. );
  31. }
  32. }
  33. }
  34. class PicoLocalService
  35. {
  36. private:
  37. CActiveSocket* SocketActive; // *
  38. const static uint8_t magic_number = 0xAA; // *
  39. int16_t handle = 0; // *
  40. uint8_t last_command = 0x00; // *
  41. uint32_t error_code = 0x00000000; // *
  42. int32_t points_value = 0;
  43. uint32_t sample_rate = 0;
  44. std::vector<uint32_t> times;
  45. uint32_t num_triggers = 0;
  46. uint32_t number_channels = 0;
  47. std::vector<PS4000A_CHANNEL> channels;
  48. std::vector<uint32_t> points_vector;
  49. uint32_t premeasurement_percentage = 0;
  50. PS4000A_CONDITION* conditions;
  51. PS4000A_CHANNEL trig_channel = PS4000A_CHANNEL_A;
  52. PS4000A_THRESHOLD_DIRECTION th_direction = PS4000A_ABOVE;
  53. int16_t threshold = 0;
  54. int16_t trig_delay = 0;
  55. int16_t trig_autoTrigger_ms = 0;
  56. uint32_t nbytes_sent = 0; // *
  57. std::vector<std::vector<int16_t*>> data_buffer_vec;
  58. uint8_t rcbuf[MAX_PACKET]{0};
  59. uint8_t sndbuf[MAX_PACKET]{0};
  60. public:
  61. PicoLocalService(CActiveSocket* socket) : SocketActive(socket) {}
  62. ~PicoLocalService() {}
  63. int get_request() {
  64. // Check if buffer has at least 2 bytes for magic number and command
  65. // Receive data from socket
  66. int bytes_recieved = SocketActive->Receive(MAX_PACKET, rcbuf);
  67. if(bytes_recieved == 0)
  68. {
  69. logger << LogPref::Flag(ERROR) << "Client disconnected" << endl;
  70. pico_stop();
  71. pico_close();
  72. return 0;
  73. }
  74. if(bytes_recieved < 2)
  75. {
  76. logger << LogPref::Flag(ERROR) << "Invalid buffer size" << endl;
  77. sndbuf[0] = magic_number;
  78. sndbuf[1] = 0xFF; // Error flag
  79. sndbuf[2] = 0x01; // Error type
  80. this->error_code = 0x00000000; // No pico error
  81. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  82. if(SocketActive->Send(sndbuf, 7) == -1) {
  83. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  84. }
  85. return -1;
  86. }
  87. // Extract magic number from buffer
  88. uint8_t magic;
  89. memcpy(&magic, rcbuf, sizeof(uint8_t));
  90. // Check if magic number is correct
  91. if (magic != this->magic_number) {
  92. logger << LogPref::Flag(ERROR) << "Invalid magic number: " << std::hex << magic << endl;
  93. sndbuf[0] = magic_number;
  94. sndbuf[1] = 0xFF;
  95. sndbuf[2] = 0x03;
  96. this->error_code = 0x00000000;
  97. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  98. if(SocketActive->Send(sndbuf, 7) == -1) {
  99. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  100. }
  101. return -1;
  102. }
  103. // Extract command from buffer
  104. uint8_t cmd;
  105. memcpy(&cmd, rcbuf + 1, sizeof(uint8_t));
  106. // Check if command is correct
  107. switch(cmd)
  108. {
  109. case 0x01:
  110. {
  111. this->last_command = 0x01;
  112. logger << LogPref::Flag(INFO) << "Command 0x01 received" << endl;
  113. pico_open();
  114. logger << LogPref::Flag(INFO) << "Pico device opened" << endl;
  115. break;
  116. }
  117. case 0x02:
  118. {
  119. this->last_command = 0x02;
  120. logger << LogPref::Flag(INFO) << "Command 0x02 received" << endl;
  121. if(bytes_recieved < 7) {
  122. logger << LogPref::Flag(ERROR) << "Invalid buffer size" << endl;
  123. sndbuf[0] = magic_number;
  124. sndbuf[1] = 0xFF;
  125. sndbuf[2] = 0x01;
  126. this->error_code = 0x00000000;
  127. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  128. if(SocketActive->Send(sndbuf, 7) == -1) {
  129. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  130. }
  131. return -1;
  132. }
  133. uint32_t size;
  134. memcpy(&size, rcbuf + 2, sizeof(uint32_t));
  135. if(size < 1) {
  136. logger << LogPref::Flag(ERROR) << "Invalid data size" << endl;
  137. sndbuf[0] = magic_number;
  138. sndbuf[1] = 0xFF;
  139. sndbuf[2] = 0x02;
  140. this->error_code = 0x00000000;
  141. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  142. if(SocketActive->Send(sndbuf, 7) == -1) {
  143. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  144. }
  145. return -1;
  146. }
  147. char* file_name = new char[size + 1];
  148. memcpy(file_name, rcbuf + 6, size * sizeof(char));
  149. file_name[size] = '\0'; // Null-terminate the string
  150. std::string file_name_str(file_name);
  151. logger << LogPref::Flag(INFO) << "File name: " << file_name_str << endl;
  152. pico_xml_config(file_name_str);
  153. logger << LogPref::Flag(INFO) << "Pico device configured" << endl;
  154. delete[] file_name;
  155. break;
  156. }
  157. case 0x0C:
  158. {
  159. this->last_command = 0x0C;
  160. logger << LogPref::Flag(INFO) << "Command 0x0C received" << endl;
  161. if(bytes_recieved < 22) {
  162. logger << LogPref::Flag(ERROR) << "Invalid buffer size" << endl;
  163. return -1;
  164. sndbuf[0] = magic_number;
  165. sndbuf[1] = 0xFF;
  166. sndbuf[2] = 0x01;
  167. this->error_code = 0x00000000;
  168. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  169. if(SocketActive->Send(sndbuf, 7) == -1) {
  170. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  171. }
  172. return -1;
  173. }
  174. uint32_t size;
  175. memcpy(&size, rcbuf + 2, sizeof(uint32_t));
  176. if(size < 1) {
  177. logger << LogPref::Flag(ERROR) << "Invalid data size" << endl;
  178. sndbuf[0] = magic_number;
  179. sndbuf[1] = 0xFF;
  180. sndbuf[2] = 0x02;
  181. this->error_code = 0x00000000;
  182. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  183. if(SocketActive->Send(sndbuf, 7) == -1) {
  184. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  185. }
  186. return -1;
  187. }
  188. uint32_t* apoints = new uint32_t[size];
  189. memcpy(apoints, rcbuf + 6, size * sizeof(uint32_t));
  190. uint32_t* atimes = new uint32_t[size];
  191. memcpy(atimes, rcbuf + 6 + size * sizeof(uint32_t), size * sizeof(uint32_t));
  192. uint32_t sample_rate = 0;
  193. memcpy(&sample_rate, rcbuf + 6 + 2 * size * sizeof(uint32_t), sizeof(uint32_t));
  194. uint32_t number_channels = 0;
  195. memcpy(&number_channels, rcbuf + 10 + 2 * size * sizeof(uint32_t), sizeof(uint32_t));
  196. pico_set_params(apoints, atimes, sample_rate, number_channels, size);
  197. logger << LogPref::Flag(INFO) << "Pico device parameters set" << endl;
  198. delete[] apoints;
  199. delete[] atimes;
  200. break;
  201. }
  202. case 0x03:
  203. {
  204. this->last_command = 0x03;
  205. logger << LogPref::Flag(INFO) << "Command 0x03 received" << endl;
  206. pico_close();
  207. logger << LogPref::Flag(INFO) << "Pico device closed" << endl;
  208. break;
  209. }
  210. case 0x04:
  211. {
  212. // Check if buffer has enough data for version numbers
  213. this->last_command = 0x04;
  214. logger << LogPref::Flag(INFO) << "Command 0x04 received" << endl;
  215. pico_get_current_params();
  216. logger << LogPref::Flag(INFO) << "Pico device parameters retrieved" << endl;
  217. break;
  218. }
  219. case 0x05:
  220. {
  221. this->last_command = 0x05;
  222. logger << LogPref::Flag(INFO) << "Command 0x05 received" << endl;
  223. pico_probe();
  224. logger << LogPref::Flag(INFO) << "Pico device probed" << endl;
  225. break;
  226. }
  227. case 0x06:
  228. {
  229. this->last_command = 0x06;
  230. logger << LogPref::Flag(INFO) << "Command 0x06 received" << endl;
  231. if(bytes_recieved < 10) {
  232. logger << LogPref::Flag(ERROR) << "Invalid buffer size" << endl;
  233. sndbuf[0] = magic_number;
  234. sndbuf[1] = 0xFF;
  235. sndbuf[2] = 0x01;
  236. this->error_code = 0x00000000;
  237. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  238. if(SocketActive->Send(sndbuf, 7) == -1) {
  239. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  240. }
  241. return -1;
  242. }
  243. uint32_t size;
  244. memcpy(&size, rcbuf + 2, sizeof(uint32_t));
  245. if(size < 1) {
  246. logger << LogPref::Flag(ERROR) << "Invalid data size" << endl;
  247. sndbuf[0] = magic_number;
  248. sndbuf[1] = 0xFF;
  249. sndbuf[2] = 0x02;
  250. this->error_code = 0x00000000;
  251. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  252. if(SocketActive->Send(sndbuf, 7) == -1) {
  253. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  254. }
  255. return -1;
  256. }
  257. uint32_t* apoints = new uint32_t[size];
  258. memcpy(apoints, rcbuf + 6, size * sizeof(uint32_t));
  259. pico_set_points(apoints, size);
  260. logger << LogPref::Flag(INFO) << "Pico device points set" << endl;
  261. delete[] apoints;
  262. break;
  263. }
  264. case 0x07:
  265. {
  266. this->last_command = 0x07;
  267. logger << LogPref::Flag(INFO) << "Command 0x07 received" << endl;
  268. if(bytes_recieved < 6) {
  269. logger << LogPref::Flag(ERROR) << "Invalid buffer size" << endl;
  270. sndbuf[0] = magic_number;
  271. sndbuf[1] = 0xFF;
  272. sndbuf[2] = 0x01;
  273. this->error_code = 0x00000000;
  274. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  275. if(SocketActive->Send(sndbuf, 7) == -1) {
  276. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  277. }
  278. return -1;
  279. }
  280. uint32_t sample_rate = 0;
  281. memcpy(&sample_rate, rcbuf + 2, sizeof(uint32_t));
  282. pico_set_sample_rate(sample_rate);
  283. logger << LogPref::Flag(INFO) << "Pico device sample rate set" << endl;
  284. break;
  285. }
  286. case 0x08:
  287. {
  288. this->last_command = 0x08;
  289. logger << LogPref::Flag(INFO) << "Command 0x08 received" << endl;
  290. if(bytes_recieved < 10) {
  291. logger << LogPref::Flag(ERROR) << "Invalid buffer size" << endl;
  292. sndbuf[0] = magic_number;
  293. sndbuf[1] = 0xFF;
  294. sndbuf[2] = 0x01;
  295. this->error_code = 0x00000000;
  296. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  297. if(SocketActive->Send(sndbuf, 7) == -1) {
  298. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  299. }
  300. return -1;
  301. }
  302. uint32_t size;
  303. memcpy(&size, rcbuf + 2, sizeof(uint32_t));
  304. if(size < 1) {
  305. logger << LogPref::Flag(ERROR) << "Invalid data size" << endl;
  306. sndbuf[0] = magic_number;
  307. sndbuf[1] = 0xFF;
  308. sndbuf[2] = 0x02;
  309. this->error_code = 0x00000000;
  310. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  311. if(SocketActive->Send(sndbuf, 7) == -1) {
  312. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  313. }
  314. return -1;
  315. }
  316. uint32_t* atimes = new uint32_t[size];
  317. memcpy(atimes, rcbuf + 6, size * sizeof(uint32_t));
  318. pico_set_times(atimes, size);
  319. logger << LogPref::Flag(INFO) << "Pico device times set" << endl;
  320. delete[] atimes;
  321. break;
  322. }
  323. case 0x09:
  324. {
  325. this->last_command = 0x09;
  326. logger << LogPref::Flag(INFO) << "Command 0x09 received" << endl;
  327. if(bytes_recieved < 16) {
  328. logger << LogPref::Flag(ERROR) << "Invalid buffer size" << endl;
  329. sndbuf[0] = magic_number;
  330. sndbuf[1] = 0xFF;
  331. sndbuf[2] = 0x01;
  332. this->error_code = 0x00000000;
  333. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  334. if(SocketActive->Send(sndbuf, 7) == -1) {
  335. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  336. }
  337. return -1;
  338. }
  339. uint32_t channels = 0;
  340. memcpy(&channels, rcbuf + 2, sizeof(uint32_t));
  341. logger << "CHANNELS: " << channels << endl;
  342. if(channels < 1 || channels > 16) {
  343. logger << LogPref::Flag(ERROR) << "Invalid number of channels" << endl;
  344. sndbuf[0] = magic_number;
  345. sndbuf[1] = 0xFF;
  346. sndbuf[2] = 0x02;
  347. this->error_code = 0x00000000;
  348. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  349. if(SocketActive->Send(sndbuf, 7) == -1) {
  350. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  351. }
  352. return -1;
  353. }
  354. enPicoConnectProbeRange* channels_range = new enPicoConnectProbeRange[channels];
  355. int8_t* raw_ranges = new int8_t[channels];
  356. memset(raw_ranges, PICO_X1_PROBE_5V, sizeof(int8_t) * channels);
  357. memcpy(raw_ranges, rcbuf + 6, sizeof(int8_t) * channels);
  358. logger << "RAW" << (int) raw_ranges[0] << endl;
  359. for(int i = 0; i < channels; ++i)
  360. {
  361. channels_range[i] = static_cast<enPicoConnectProbeRange>(raw_ranges[i]);
  362. }
  363. uint8_t trigger_channel = 0;
  364. memcpy(&trigger_channel, rcbuf + 6 + channels, sizeof(uint8_t));
  365. int32_t direction = 0;
  366. memcpy(&direction, rcbuf + 7 + channels, sizeof(int32_t));
  367. uint16_t threshold = 0;
  368. memcpy(&threshold, rcbuf + 11 + channels, sizeof(uint16_t));
  369. int16_t autoTrigger_ms = 0;
  370. memcpy(&autoTrigger_ms, rcbuf + 13 + channels, sizeof(int16_t));
  371. pico_configure_channels_t(channels, channels_range, trigger_channel, direction, threshold, autoTrigger_ms);
  372. logger << LogPref::Flag(INFO) << "Pico device channels configured" << endl;
  373. break;
  374. }
  375. case 0x29:
  376. {
  377. }
  378. case 0x0D:
  379. {
  380. this->last_command = 0x0D;
  381. logger << LogPref::Flag(INFO) << "Command 0x0B received" << endl;
  382. int ret = pico_exit();
  383. if(ret == 0) {
  384. logger << LogPref::Flag(INFO) << "Pico device exited successfully" << endl;
  385. return 0;
  386. } else {
  387. logger << LogPref::Flag(ERROR) << "Failed to exit Pico device" << endl;
  388. }
  389. break;
  390. }
  391. case 0x0E:
  392. {
  393. this->last_command = 0x0E;
  394. logger << LogPref::Flag(INFO) << "Command 0x0E received" << endl;
  395. pico_stop();
  396. logger << LogPref::Flag(INFO) << "Pico device stopped" << endl;
  397. break;
  398. }
  399. case 0x20:
  400. {
  401. this->last_command = 0x20;
  402. logger << LogPref::Flag(INFO) << "Command 0x0F received" << endl;
  403. if(bytes_recieved < 12) {
  404. logger << LogPref::Flag(ERROR) << "Invalid buffer size" << endl;
  405. sndbuf[0] = magic_number;
  406. sndbuf[1] = 0xFF;
  407. sndbuf[2] = 0x01;
  408. this->error_code = 0x00000000;
  409. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  410. if(SocketActive->Send(sndbuf, 7) == -1) {
  411. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  412. }
  413. return -1;
  414. }
  415. uint32_t trigger_channel = 0;
  416. memcpy(&trigger_channel, rcbuf + 2, sizeof(uint32_t));
  417. int32_t direction = 0;
  418. memcpy(&direction, rcbuf + 6, sizeof(int32_t));
  419. uint16_t threshold = 0;
  420. memcpy(&threshold, rcbuf + 10, sizeof(uint16_t));
  421. int16_t autoTrigger_ms = 0;
  422. memcpy(&autoTrigger_ms, rcbuf + 12, sizeof(int16_t));
  423. pico_configure_trigger(trigger_channel, direction, threshold, autoTrigger_ms);
  424. break;
  425. }
  426. case 0x28:
  427. {
  428. this->last_command = 0x28;
  429. logger << LogPref::Flag(INFO) << "Command 0x28 received" << endl;
  430. if(bytes_recieved < 6) {
  431. logger << LogPref::Flag(ERROR) << "Invalid buffer size" << endl;
  432. sndbuf[0] = magic_number;
  433. sndbuf[1] = 0xFF;
  434. sndbuf[2] = 0x01;
  435. this->error_code = 0x00000000;
  436. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  437. if(SocketActive->Send(sndbuf, 7) == -1) {
  438. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  439. }
  440. return -1;
  441. }
  442. uint32_t percentage = 0;
  443. memcpy(&percentage, rcbuf + 2, sizeof(uint32_t));
  444. if(percentage < 0 || percentage > 100) {
  445. logger << LogPref::Flag(ERROR) << "Invalid premeasurement percentage" << endl;
  446. sndbuf[0] = magic_number;
  447. sndbuf[1] = 0xFF;
  448. sndbuf[2] = 0x02;
  449. this->error_code = 0x00000000;
  450. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  451. if(SocketActive->Send(sndbuf, 7) == -1) {
  452. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  453. }
  454. return -1;
  455. }
  456. pico_set_premeasurement(percentage);
  457. break;
  458. }
  459. case 0x19:
  460. {
  461. this->last_command = 0x19;
  462. logger << LogPref::Flag(INFO) << "Command 0x19 received" << endl;
  463. if(bytes_recieved < 6) {
  464. logger << LogPref::Flag(ERROR) << "Invalid buffer size" << endl;
  465. sndbuf[0] = magic_number;
  466. sndbuf[1] = 0xFF;
  467. sndbuf[2] = 0x01;
  468. this->error_code = 0x00000000;
  469. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  470. if(SocketActive->Send(sndbuf, 7) == -1) {
  471. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  472. }
  473. return -1;
  474. }
  475. uint32_t num_trigger = 0;
  476. memcpy(&num_trigger, rcbuf + 2, sizeof(uint32_t));
  477. pico_set_num_trigger(num_trigger);
  478. break;
  479. }
  480. case 0x3B:
  481. {
  482. this->last_command;
  483. logger << LogPref::Flag(INFO) << "Command 0x3B received" << endl;
  484. pico_tcp_measurement_s();
  485. break;
  486. }
  487. default:
  488. {
  489. this->last_command = 0xFF;
  490. logger << LogPref::Flag(ERROR) << "Invalid command: " << std::hex << cmd << endl;
  491. sndbuf[0] = magic_number;
  492. sndbuf[1] = 0xFF;
  493. sndbuf[2] = 0x00;
  494. this->error_code = 0x00000000;
  495. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  496. if(SocketActive->Send(sndbuf, 7) == -1) {
  497. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  498. }
  499. return -1;
  500. }
  501. }
  502. return 1;
  503. }
  504. int pico_open() {
  505. // Open socket and initialize Pico device
  506. auto retval = ps4000aOpenUnit(&handle, NULL);
  507. logger << LogPref::Flag(INFO) << "Pico device opened with handle: " << handle << endl;
  508. if (retval != 0) {
  509. logger << LogPref::Flag(ERROR) << "Failed to open Pico device. Code: " << retval << endl;
  510. sndbuf[0] = magic_number;
  511. sndbuf[1] = 0xFF;
  512. sndbuf[2] = 0x03;
  513. this->error_code = retval;
  514. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  515. if(SocketActive->Send(sndbuf, 7) == -1) {
  516. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  517. }
  518. return -1;
  519. }
  520. int16_t start{10};
  521. retval = ps4000aFlashLed(handle, start);
  522. logger << LogPref::Flag(INFO) << "Pico device LED flashed." << endl;
  523. if (retval != 0) {
  524. logger << LogPref::Flag(ERROR) << "Failed to flash Pico device LED. Code: " << retval << endl;
  525. sndbuf[0] = magic_number;
  526. sndbuf[1] = 0xFF;
  527. sndbuf[2] = 0x04;
  528. this->error_code = retval;
  529. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  530. if(SocketActive->Send(sndbuf, 7) == -1) {
  531. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  532. }
  533. return -1;
  534. }
  535. logger << LogPref::Flag(INFO) << "Pico device LED flashed." << endl;
  536. sndbuf[0] = magic_number;
  537. sndbuf[1] = 0xC1;
  538. if(SocketActive->Send(sndbuf, 2) == -1) {
  539. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  540. return -1;
  541. }
  542. logger << LogPref::Flag(INFO) << "Data sent to socket" << endl;
  543. return 0;
  544. }
  545. int pico_stop()
  546. {
  547. // Stop measurement and close Pico device
  548. auto retval = ps4000aStop(handle);
  549. if (retval != 0) {
  550. logger << LogPref::Flag(ERROR) << "Failed to stop Pico device. Code: " << retval << endl;
  551. sndbuf[0] = magic_number;
  552. sndbuf[1] = 0xFF;
  553. sndbuf[2] = 0x06;
  554. this->error_code = retval;
  555. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  556. if(SocketActive->Send(sndbuf, 7) == -1) {
  557. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  558. }
  559. return -1;
  560. }
  561. logger << LogPref::Flag(INFO) << "Pico device stopped" << endl;
  562. sndbuf[0] = magic_number;
  563. sndbuf[1] = 0xCE;
  564. if(SocketActive->Send(sndbuf, 2) == -1) {
  565. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  566. return -1;
  567. }
  568. logger << LogPref::Flag(INFO) << "Data sent to socket" << endl;
  569. return 0;
  570. }
  571. // To be deprecated in future versions
  572. int pico_xml_config(const string& file_name) {
  573. // Load configuration from XML file
  574. auto data_set = parse_xml_function(file_name.c_str());
  575. points_vector = string_to_vector(std::get<0>(data_set));
  576. times = string_to_vector(std::get<2>(data_set));
  577. points_value = *(std::max_element(points_vector.begin(), points_vector.end()));
  578. number_channels = std::get<1>(data_set);
  579. sample_rate = std::get<3>(data_set);
  580. sndbuf[0] = magic_number;
  581. sndbuf[1] = 0xC2;
  582. if(SocketActive->Send(sndbuf, 2) == -1) {
  583. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  584. return -1;
  585. }
  586. logger << LogPref::Flag(INFO) << "Data sent to socket" << endl;
  587. return 0;
  588. }
  589. // Deprecated function, use other functions instead
  590. int pico_set_params(const uint32_t* points, const uint32_t* times, const uint32_t sample_rate, const uint32_t number_channels, const uint32_t size) {
  591. // Set parameters for measurement
  592. this->points_vector.assign(points, points + size);
  593. this->times.assign(times, times + size);
  594. this->sample_rate = sample_rate;
  595. this->number_channels = number_channels;
  596. points_value = *(std::max_element(points_vector.begin(), points_vector.end()));
  597. logger << LogPref::Flag(INFO) << "Parameters set" << endl;
  598. sndbuf[0] = magic_number;
  599. sndbuf[1] = 0xCC;
  600. if(SocketActive->Send(sndbuf, 2) == -1) {
  601. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  602. return -1;
  603. }
  604. return 0;
  605. }
  606. int pico_close() {
  607. // Close Pico device and socket
  608. auto retval = ps4000aCloseUnit(handle);
  609. if (retval != 0) {
  610. logger << LogPref::Flag(ERROR) << "Failed to close Pico device. Code: " << retval << endl;
  611. sndbuf[0] = magic_number;
  612. sndbuf[1] = 0xFF;
  613. sndbuf[2] = 0x05;
  614. this->error_code = retval;
  615. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  616. if(SocketActive->Send(sndbuf, 7) == -1) {
  617. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  618. }
  619. return -1;
  620. }
  621. logger << LogPref::Flag(INFO) << "Pico device closed" << endl;
  622. sndbuf[0] = magic_number;
  623. sndbuf[1] = 0xC3;
  624. if(SocketActive->Send(sndbuf, 2) == -1) {
  625. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  626. return -1;
  627. }
  628. logger << LogPref::Flag(INFO) << "Data sent to socket" << endl;
  629. return 0;
  630. }
  631. int pico_get_current_params() {
  632. // Get current parameters from Pico device
  633. logger << LogPref::Flag(INFO) << "Current parameters:" << endl;
  634. logger << "Points: " << points_value << endl;
  635. logger << "Times size: " << times.size() << endl;
  636. logger << "Sample rate: " << sample_rate << endl;
  637. logger << "Number of channels: " << number_channels << endl;
  638. logger << "Trigger channel: " << trig_channel << endl;
  639. logger << "Trigger direction: " << th_direction << endl;
  640. sndbuf[0] = magic_number;
  641. sndbuf[1] = 0xC4;
  642. uint32_t bsize = points_vector.size() * sizeof(uint32_t);
  643. uint32_t test = 0;
  644. memcpy(sndbuf + 2, &bsize, sizeof(uint32_t));
  645. memcpy(sndbuf + 6, points_vector.data(), bsize);
  646. memcpy(&test, points_vector.data(), bsize);
  647. logger << LogPref::Flag(INFO) << test << endl;
  648. memcpy(sndbuf + 6 + bsize, times.data(), bsize);
  649. logger << LogPref::Flag(INFO) << times.data()[0] << endl;
  650. memcpy(sndbuf + 6 + 2 * bsize, &sample_rate, sizeof(sample_rate));
  651. memcpy(sndbuf + 10 + 2 * bsize, &number_channels, sizeof(number_channels));
  652. if(SocketActive->Send(sndbuf, 10 + sizeof(points_vector.data()) + sizeof(times.data())) == -1) {
  653. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  654. return -1;
  655. }
  656. return 0;
  657. }
  658. int pico_probe() {
  659. // Probe signal from Pico device
  660. sndbuf[0] = magic_number;
  661. sndbuf[1] = 0xC5;
  662. if(SocketActive->Send(sndbuf, 2) == -1) {
  663. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  664. return -1;
  665. }
  666. logger << LogPref::Flag(INFO) << "Data sent to socket" << endl;
  667. return 0;
  668. }
  669. int pico_set_points(const uint32_t* points, const uint32_t size) {
  670. // Set points for measurement
  671. this->points_vector.assign(points, points + size);
  672. points_value = *(std::max_element(points_vector.begin(), points_vector.end()));
  673. logger << LogPref::Flag(INFO) << "Points set" << endl;
  674. sndbuf[0] = magic_number;
  675. sndbuf[1] = 0xC6;
  676. if(SocketActive->Send(sndbuf, 2) == -1) {
  677. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  678. return -1;
  679. }
  680. return 0;
  681. }
  682. int pico_set_sample_rate(const uint32_t sample_rate) {
  683. // Set sample rate for measurement
  684. this->sample_rate = sample_rate;
  685. logger << LogPref::Flag(INFO) << "Sample rate set to: " << sample_rate << endl;
  686. sndbuf[0] = magic_number;
  687. sndbuf[1] = 0xC7;
  688. if(SocketActive->Send(sndbuf, 2) == -1) {
  689. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  690. return -1;
  691. }
  692. return 0;
  693. }
  694. int pico_set_times(const uint32_t* times, const uint32_t size) {
  695. // Set times for measurement
  696. this->times.assign(times, times + size);
  697. logger << LogPref::Flag(INFO) << "Times set" << endl;
  698. sndbuf[0] = magic_number;
  699. sndbuf[1] = 0xC8;
  700. if(SocketActive->Send(sndbuf, 2) == -1) {
  701. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  702. return -1;
  703. }
  704. return 0;
  705. }
  706. int pico_set_num_trigger(const uint32_t num_trigger) {
  707. // Set number of channels for trigger
  708. this->num_triggers = num_trigger;
  709. logger << LogPref::Flag(INFO) << "Number of triggers set to: " << num_trigger << endl;
  710. sndbuf[0] = magic_number;
  711. sndbuf[1] = 0xD9;
  712. memcpy(sndbuf + 2, &num_triggers, sizeof(uint32_t));
  713. if(SocketActive->Send(sndbuf, 6) == -1) {
  714. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  715. return -1;
  716. }
  717. logger << LogPref::Flag(INFO) << "Data sent to socket" << endl;
  718. return 0;
  719. }
  720. int pico_configure_channels_s(const uint32_t number_channels, enPicoConnectProbeRange* channel_ranges, uint8_t trigger_channel)
  721. {
  722. this->number_channels = number_channels;
  723. logger << LogPref::Flag(INFO) << "Number of channels set to: " << number_channels << endl;
  724. this->channels = create_channel(number_channels);
  725. conditions = new PS4000A_CONDITION[number_channels];
  726. for (uint32_t i = 0; i < number_channels; ++i) {
  727. conditions[i].source = channels[i];
  728. conditions[i].condition = PS4000A_CONDITION_FALSE;
  729. }
  730. logger << LogPref::Flag(INFO) << "DEBUG RANGE" << trigger_channel << " " << channel_ranges[trigger_channel] << endl;
  731. auto retval = ps4000aSetChannel(handle, channels[trigger_channel], true, PS4000A_DC, channel_ranges[trigger_channel], 0);
  732. if(retval != 0) {
  733. logger << LogPref::Flag(ERROR) << "Failed to set trigger channel. Code: " << retval << endl;
  734. sndbuf[0] = magic_number;
  735. sndbuf[1] = 0xFF;
  736. sndbuf[2] = 0x06;
  737. this->error_code = retval;
  738. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  739. if(SocketActive->Send(sndbuf, 7) == -1) {
  740. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  741. }
  742. return -1;
  743. }
  744. logger << LogPref::Flag(INFO) << "Trigger channel set" << endl;
  745. for(uint8_t i = 0; i < number_channels; ++i) {
  746. if(i == trigger_channel) continue;
  747. else {
  748. logger << LogPref::Flag(INFO) << "DEBUG RANGE" << i << " " << channel_ranges[i] << endl;
  749. auto retval = ps4000aSetChannel(handle, channels[i], true, PS4000A_AC, channel_ranges[i], 0);
  750. if (retval != 0) {
  751. logger << LogPref::Flag(ERROR) << "Failed to set channel " << i << ". Code: " << retval << endl;
  752. sndbuf[0] = magic_number;
  753. sndbuf[1] = 0xFF;
  754. sndbuf[2] = 0x07 + i;
  755. this->error_code = retval;
  756. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  757. if(SocketActive->Send(sndbuf, 7) == -1) {
  758. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  759. }
  760. return -1;
  761. }
  762. logger << LogPref::Flag(INFO) << "Channel " << i << " set" << endl;
  763. }
  764. }
  765. if (retval != 0) {
  766. logger << LogPref::Flag(ERROR) << "Failed to set trigger. Code: " << retval << endl;
  767. sndbuf[0] = magic_number;
  768. sndbuf[1] = 0xFF;
  769. sndbuf[2] = 0x12;
  770. this->error_code = retval;
  771. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  772. if(SocketActive->Send(sndbuf, 7) == -1) {
  773. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  774. }
  775. return -1;
  776. }
  777. sndbuf[0] = magic_number;
  778. sndbuf[1] = 0xE9;
  779. if(SocketActive->Send(sndbuf, 2) == -1) {
  780. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  781. return -1;
  782. }
  783. }
  784. int pico_configure_channels_t(const uint32_t number_channels, enPicoConnectProbeRange* channel_ranges, uint8_t trigger_channel, int32_t direction, uint16_t threshold, int16_t autoTrigger_ms) {
  785. // Set number of channels for measurement
  786. this->number_channels = number_channels;
  787. logger << LogPref::Flag(INFO) << "Number of channels set to: " << number_channels << endl;
  788. logger << LogPref::Flag(INFO) << "trigger_channel set to: " << (int) trigger_channel << endl;
  789. logger << LogPref::Flag(INFO) << "direction set to: " << direction << endl;
  790. logger << LogPref::Flag(INFO) << "threshold set to: " << threshold << endl;
  791. logger << LogPref::Flag(INFO) << "autoTrigger_ms set to: " << autoTrigger_ms << endl;
  792. this->channels = create_channel(number_channels);
  793. conditions = new PS4000A_CONDITION[number_channels];
  794. for (uint32_t i = 0; i < number_channels; ++i) {
  795. conditions[i].source = channels[i];
  796. conditions[i].condition = PS4000A_CONDITION_FALSE;
  797. }
  798. logger << LogPref::Flag(INFO) << "DEBUG RANGE" << trigger_channel << " " << channel_ranges[trigger_channel] << endl;
  799. if(auto retval = ps4000aSetChannel(handle, channels[trigger_channel], true, PS4000A_DC, channel_ranges[trigger_channel], 0) != 0) {
  800. logger << LogPref::Flag(ERROR) << "Failed to set trigger channel. Code: " << retval << endl;
  801. sndbuf[0] = magic_number;
  802. sndbuf[1] = 0xFF;
  803. sndbuf[2] = 0x06;
  804. this->error_code = retval;
  805. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  806. if(SocketActive->Send(sndbuf, 7) == -1) {
  807. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  808. }
  809. return -1;
  810. }
  811. logger << LogPref::Flag(INFO) << "Trigger channel set" << endl;
  812. this->trig_channel = channels[trigger_channel];
  813. this->th_direction = static_cast<PS4000A_THRESHOLD_DIRECTION>(direction);
  814. this->threshold = threshold;
  815. this->trig_delay = 10;
  816. this->trig_autoTrigger_ms = autoTrigger_ms;
  817. for(uint8_t i = 0; i < number_channels; ++i) {
  818. if(i == trigger_channel) continue;
  819. else {
  820. logger << LogPref::Flag(INFO) << "DEBUG RANGE" << i << " " << channel_ranges[i] << endl;
  821. auto retval = ps4000aSetChannel(handle, channels[i], true, PS4000A_AC, channel_ranges[i], 0);
  822. if (retval != 0) {
  823. logger << LogPref::Flag(ERROR) << "Failed to set channel " << i << ". Code: " << retval << endl;
  824. sndbuf[0] = magic_number;
  825. sndbuf[1] = 0xFF;
  826. sndbuf[2] = 0x07 + i;
  827. this->error_code = retval;
  828. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  829. if(SocketActive->Send(sndbuf, 7) == -1) {
  830. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  831. }
  832. return -1;
  833. }
  834. logger << LogPref::Flag(INFO) << "Channel " << i << " set" << endl;
  835. }
  836. }
  837. logger << LogPref::Flag(INFO) << "DEBUG TRIGGER" << endl;
  838. logger << LogPref::Flag(INFO) << this->handle << endl;
  839. logger << LogPref::Flag(INFO) << this->trig_channel << endl;
  840. logger << LogPref::Flag(INFO) << this->threshold << endl;
  841. logger << LogPref::Flag(INFO) << this->th_direction << endl;
  842. logger << LogPref::Flag(INFO) << this->trig_delay << endl;
  843. logger << LogPref::Flag(INFO) << this->trig_autoTrigger_ms << endl;
  844. auto retval = ps4000aSetSimpleTrigger
  845. (
  846. handle,
  847. true,
  848. conditions[trigger_channel].source,
  849. threshold,
  850. th_direction,
  851. trig_delay,
  852. trig_autoTrigger_ms
  853. );
  854. if (retval != 0) {
  855. logger << LogPref::Flag(ERROR) << "Failed to set trigger. Code: " << retval << endl;
  856. sndbuf[0] = magic_number;
  857. sndbuf[1] = 0xFF;
  858. sndbuf[2] = 0x12;
  859. this->error_code = retval;
  860. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  861. if(SocketActive->Send(sndbuf, 7) == -1) {
  862. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  863. }
  864. return -1;
  865. }
  866. sndbuf[0] = magic_number;
  867. sndbuf[1] = 0xC9;
  868. if(SocketActive->Send(sndbuf, 2) == -1) {
  869. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  870. return -1;
  871. }
  872. return 0;
  873. }
  874. // To be deprecated in future versions
  875. int pico_exit() {
  876. // Exit Pico device and free resources
  877. if (handle != NULL) {
  878. auto ret = ps4000aCloseUnit(handle);
  879. if (ret != 0) {
  880. logger << LogPref::Flag(ERROR) << "Failed to close Pico device. Code: " << ret << endl;
  881. sndbuf[0] = magic_number;
  882. sndbuf[1] = 0xFF;
  883. sndbuf[2] = 0x23;
  884. this->error_code = ret;
  885. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  886. if(SocketActive->Send(sndbuf, 7) == -1) {
  887. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  888. }
  889. return -1;
  890. }
  891. sndbuf[0] = magic_number;
  892. sndbuf[1] = 0xCD;
  893. if(SocketActive->Send(sndbuf, 2) == -1) {
  894. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  895. return -1;
  896. }
  897. logger << LogPref::Flag(INFO) << "Pico device closed" << endl;
  898. handle = NULL;
  899. }
  900. return 0;
  901. }
  902. int pico_configure_trigger(int8_t trigger_channel, int32_t direction, uint16_t threshold, int16_t autoTrigger_ms) {
  903. // Configure trigger for Pico device
  904. this->trig_channel = channels[trigger_channel];
  905. this->th_direction = static_cast<PS4000A_THRESHOLD_DIRECTION>(direction);
  906. this->trig_delay = 10;
  907. this->threshold = threshold;
  908. this->trig_autoTrigger_ms = autoTrigger_ms;
  909. logger << LogPref::Flag(INFO) << "Trigger configured" << endl;
  910. sndbuf[0] = magic_number;
  911. sndbuf[1] = 0xC9;
  912. if(SocketActive->Send(sndbuf, 2) == -1) {
  913. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  914. return -1;
  915. }
  916. auto retval = ps4000aSetSimpleTrigger
  917. (
  918. handle,
  919. true,
  920. channels[trigger_channel],
  921. this->threshold,
  922. this->th_direction,
  923. this->trig_delay,
  924. this->trig_autoTrigger_ms
  925. );
  926. if (retval != 0) {
  927. logger << LogPref::Flag(ERROR) << "Failed to set trigger. Code: " << retval << endl;
  928. sndbuf[0] = magic_number;
  929. sndbuf[1] = 0xFF;
  930. sndbuf[2] = 0x16;
  931. this->error_code = retval;
  932. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  933. if(SocketActive->Send(sndbuf, 7) == -1) {
  934. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  935. }
  936. return -1;
  937. }
  938. logger << LogPref::Flag(INFO) << "Trigger set successfully" << endl;\
  939. sndbuf[0] = magic_number;
  940. sndbuf[1] = 0xE0;
  941. if(SocketActive->Send(sndbuf, 2) == -1) {
  942. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  943. return -1;
  944. }
  945. return 0;
  946. }
  947. int pico_set_premeasurement(uint32_t percentage)
  948. {
  949. // Set pre-measurement percentage
  950. this->premeasurement_percentage = percentage;
  951. logger << LogPref::Flag(INFO) << "Pre-measurement percentage set to: " << percentage << "%" << endl;
  952. sndbuf[0] = magic_number;
  953. sndbuf[1] = 0xE8;
  954. if(SocketActive->Send(sndbuf, 2) == -1) {
  955. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  956. return -1;
  957. }
  958. return 0;
  959. }
  960. int pico_tcp_measurement_s()
  961. {
  962. logger << LogPref::Flag(INFO) << "Multi-trigger measurement started" << endl;
  963. data_buffer_vec.assign(num_triggers, std::vector<int16_t*>(number_channels, nullptr));
  964. logger << LogPref::Flag(INFO) << "Get timebase:" << endl;
  965. uint32_t timebase = timebase_choice(sample_rate);
  966. logger << "Timebase = " << timebase << endl;
  967. #define FAST_BLOCK
  968. #ifdef FAST_BLOCK
  969. logger << LogPref::Flag(INFO) << "Set data buffer:" << endl;
  970. for(size_t i = 0; i < num_triggers; ++i) {
  971. for(size_t j = 0; j < number_channels; ++j) {
  972. data_buffer_vec[i][j] = new int16_t[points_vector[i]];
  973. memset(data_buffer_vec[i][j], 0, points_vector[i]);
  974. }
  975. }
  976. int32_t* nSamples = new int32_t[num_triggers];
  977. int32_t retval = ps4000aMemorySegments(handle, num_triggers, nSamples);
  978. if(retval != 0) {
  979. logger << LogPref::Flag(ERROR) << "Failed to get values. Code: " << retval << endl;
  980. sndbuf[0] = magic_number;
  981. sndbuf[1] = 0xFF;
  982. sndbuf[2] = 0x21;
  983. this->error_code = retval;
  984. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  985. if(SocketActive->Send(sndbuf, 7) == -1) {
  986. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  987. }
  988. return -1;
  989. }
  990. retval = ps4000aSetNoOfCaptures(handle, num_triggers);
  991. if(retval != 0) {
  992. logger << LogPref::Flag(ERROR) << "Failed to get values. Code: " << retval << endl;
  993. sndbuf[0] = magic_number;
  994. sndbuf[1] = 0xFF;
  995. sndbuf[2] = 0x21;
  996. this->error_code = retval;
  997. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  998. if(SocketActive->Send(sndbuf, 7) == -1) {
  999. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  1000. }
  1001. return -1;
  1002. }
  1003. int32_t timeIntervalNanoseconds = 0;
  1004. int32_t maxSamples = 0;
  1005. int32_t segmentIndex = 0;
  1006. retval = ps4000aGetTimebase(handle, timebase, points_value, &timeIntervalNanoseconds,
  1007. &maxSamples, segmentIndex);
  1008. logger << "retval: " << retval << endl;
  1009. if(retval != 0) {
  1010. logger << LogPref::Flag(ERROR) << "Failed to get timebase. Code: " << retval << endl;
  1011. sndbuf[0] = magic_number;
  1012. sndbuf[1] = 0xFF;
  1013. sndbuf[2] = 0x13;
  1014. this->error_code = retval;
  1015. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  1016. if(SocketActive->Send(sndbuf, 7) == -1) {
  1017. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  1018. }
  1019. return -1;
  1020. }
  1021. int32_t noOfPreTriggerSamples = 0;
  1022. int32_t noOfPostTriggerSamples = points_value;
  1023. logger << LogPref::Flag(INFO) << "Run block" << endl;
  1024. retval = ps4000aRunBlock(handle, noOfPreTriggerSamples, noOfPostTriggerSamples, timebase,
  1025. nullptr, segmentIndex, nullptr, nullptr);
  1026. if(retval != 0) {
  1027. logger << LogPref::Flag(ERROR) << "Failed to get values. Code: " << retval << endl;
  1028. sndbuf[0] = magic_number;
  1029. sndbuf[1] = 0xFF;
  1030. sndbuf[2] = 0x21;
  1031. this->error_code = retval;
  1032. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  1033. if(SocketActive->Send(sndbuf, 7) == -1) {
  1034. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  1035. }
  1036. return -1;
  1037. }
  1038. logger << LogPref::Flag(INFO) << "Run block done" << endl;
  1039. int16_t ready = 0;
  1040. while (ready == 0) {
  1041. retval = ps4000aIsReady(handle, &ready);
  1042. }
  1043. logger << LogPref::Flag(INFO) << "Data ready" << endl;
  1044. for(size_t i = 0; i < num_triggers; ++i) {
  1045. for(size_t j = 0; j < number_channels; ++j) {
  1046. logger << LogPref::Flag(INFO) << "Set data buffer for channel " << j << endl;
  1047. PS4000A_RATIO_MODE mode = PS4000A_RATIO_MODE_NONE;
  1048. retval = ps4000aSetDataBuffer(handle, channels[j], data_buffer_vec[i][j], points_vector[i],
  1049. i, mode);
  1050. logger << "retval: " << retval << endl;
  1051. if(retval != 0) {
  1052. logger << LogPref::Flag(ERROR) << "Failed to set data buffer for channel " << j << ". Code: " << retval << endl;
  1053. sndbuf[0] = magic_number;
  1054. sndbuf[1] = 0xFF;
  1055. sndbuf[2] = 0x15 + j;
  1056. this->error_code = retval;
  1057. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  1058. if(SocketActive->Send(sndbuf, 7) == -1) {
  1059. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  1060. }
  1061. return -1;
  1062. }
  1063. }
  1064. }
  1065. logger << LogPref::Flag(INFO) << "Set data buffer done" << endl;
  1066. logger << LogPref::Flag(INFO) << "Data collection start" << endl;
  1067. uint32_t StartIndex = 0;
  1068. uint32_t noOfSamples = static_cast<uint32_t>(points_value);
  1069. int16_t overflow = 0;
  1070. uint32_t DownSampleRatio = 1;
  1071. retval = ps4000aGetValuesBulk(handle, &noOfSamples, 0, num_triggers-1, DownSampleRatio, PS4000A_RATIO_MODE_NONE, &overflow);
  1072. logger << "retval: " << retval << endl;
  1073. if(retval != 0) {
  1074. logger << LogPref::Flag(ERROR) << "Failed to get values. Code: " << retval << endl;
  1075. sndbuf[0] = magic_number;
  1076. sndbuf[1] = 0xFF;
  1077. sndbuf[2] = 0x21;
  1078. this->error_code = retval;
  1079. memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
  1080. if(SocketActive->Send(sndbuf, 7) == -1) {
  1081. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  1082. }
  1083. return -1;
  1084. }
  1085. logger << LogPref::Flag(INFO) << "Data collection done" << endl;
  1086. logger << LogPref::Flag(INFO) << "Confirm data to socket" << endl;
  1087. #endif // FAST_BLOCK
  1088. logger << LogPref::Flag(INFO) << "Sending confirmation code" << endl;
  1089. sndbuf[0] = magic_number;
  1090. sndbuf[1] = 0xFB;
  1091. if(SocketActive->Send(sndbuf, 2) == -1) {
  1092. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  1093. return -1;
  1094. }
  1095. logger << LogPref::Flag(INFO) << "Confirmation code sended" << endl;
  1096. int bytes_recieved = SocketActive->Receive(MAX_PACKET, rcbuf);
  1097. if(rcbuf[1] == 0xCB)
  1098. {
  1099. logger << LogPref::Flag(INFO) << "Data confirmed" << endl;
  1100. }
  1101. else{
  1102. return -1;
  1103. }
  1104. logger << LogPref::Flag(INFO) << "Sending data" << endl;
  1105. std::chrono::time_point<std::chrono::system_clock> time_now = std::chrono::system_clock::now();
  1106. std::time_t t_n = std::chrono::system_clock::to_time_t(time_now);
  1107. for(uint32_t i = 0; i < num_triggers; ++i)
  1108. {
  1109. for(uint32_t j = 0; j < number_channels; ++j)
  1110. {
  1111. uint32_t data_seek = 0;
  1112. uint32_t packet = 0;
  1113. uint32_t total_data = sizeof(int16_t) * points_vector[i];
  1114. uint32_t total_packets = 1 + ((uint32_t) ((total_data * 1.0f) / MAX_PACKET));
  1115. do
  1116. {
  1117. uint32_t ndata_sent;
  1118. if(total_data - data_seek < MAX_PACKET - 22)
  1119. {
  1120. ndata_sent = total_data - data_seek;
  1121. }
  1122. else
  1123. {
  1124. ndata_sent = MAX_PACKET - 22;
  1125. }
  1126. sndbuf[0] = magic_number;
  1127. sndbuf[1] = 0xFD;
  1128. memcpy(sndbuf + 2, &i, sizeof(uint32_t));
  1129. memcpy(sndbuf + 6, &j, sizeof(uint32_t));
  1130. memcpy(sndbuf + 10, &total_packets, sizeof(uint32_t));
  1131. memcpy(sndbuf + 14, &packet, sizeof(uint32_t));
  1132. memcpy(sndbuf + 18, &ndata_sent, sizeof(uint32_t));
  1133. int16_t test_data = data_buffer_vec[i][j][0];
  1134. memcpy(sndbuf + 22, data_buffer_vec[i][j] + (data_seek / 2), ndata_sent);
  1135. logger << LogPref::Flag(INFO) << "Total data: " << total_data << ". Data seek: " << data_seek << ". Test data:" << test_data << endl;
  1136. logger << LogPref::Flag(INFO) << "Sending packet " << packet << " of " << total_packets << " (sig" << i << "ch" << j << "). Data to send: " << ndata_sent << endl;
  1137. if(SocketActive->Send(sndbuf, 22 + ndata_sent) == -1) {
  1138. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  1139. return -1;
  1140. }
  1141. data_seek += ndata_sent;
  1142. ++packet;
  1143. int bytes_recieved = SocketActive->Receive(MAX_PACKET, rcbuf);
  1144. if(rcbuf[1] == 0x3D)
  1145. {
  1146. logger << LogPref::Flag(INFO) << "Data confirmed" << endl;
  1147. }
  1148. else{
  1149. return -1;
  1150. }
  1151. } while (packet < total_packets);
  1152. }
  1153. }
  1154. sndbuf[0] = magic_number;
  1155. sndbuf[1] = 0xFC;
  1156. if(SocketActive->Send(sndbuf, 2) == -1) {
  1157. logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
  1158. return -1;
  1159. }
  1160. bytes_recieved = SocketActive->Receive(MAX_PACKET, rcbuf);
  1161. if(rcbuf[1] == 0x3C)
  1162. {
  1163. logger << LogPref::Flag(INFO) << "Data confirmed" << endl;
  1164. }
  1165. else{
  1166. return -1;
  1167. }
  1168. return 0;
  1169. }
  1170. };
  1171. int main()
  1172. {
  1173. logger.enableConsoleOutput(true);
  1174. logger << "Open socket" << endl;
  1175. CPassiveSocket SocketPassive(CSimpleSocket::CSocketType::SocketTypeTcp);
  1176. if (!SocketPassive.Initialize())
  1177. {
  1178. logger << LogPref::Flag(ERROR) << "Socket initialization failed" << endl;
  1179. return -1;
  1180. }
  1181. if(!SocketPassive.Listen("localhost", 5003))
  1182. {
  1183. logger << LogPref::Flag(ERROR) << "Socket listening failed" << endl;
  1184. return -1;
  1185. }
  1186. logger << "Socket initialized!" << endl;
  1187. CActiveSocket* ClientSocket = nullptr;
  1188. pico_server_dispatcher pico_server(ClientSocket);
  1189. while(true)
  1190. {
  1191. logger << LogPref::Flag(INFO) << "Wait for connection..." << endl;
  1192. logger.closeLogger();
  1193. if ((ClientSocket = SocketPassive.Accept()) == nullptr)
  1194. {
  1195. logger.closeLogger();
  1196. logger.initializeLogger("picologs", "pico");
  1197. logger.enableConsoleOutput(true);
  1198. logger << LogPref::Flag(ERROR) << "Socket accept failed" << endl;
  1199. logger.closeLogger();
  1200. return -1;
  1201. }
  1202. logger.initializeLogger("picologs", "pico");
  1203. logger.enableConsoleOutput(true);
  1204. logger << LogPref::Flag(INFO) << "Client connected" << endl;
  1205. while(pico_server.acceptRequest() == true)
  1206. {
  1207. logger << LogPref::Flag(INFO) << "Request received" << endl;
  1208. }
  1209. logger << LogPref::Flag(INFO) << "Request processing finished" << endl;
  1210. delete ClientSocket;
  1211. ClientSocket = nullptr;
  1212. }
  1213. return 0;
  1214. }