123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067 |
- #include <iostream>
- #include <memory>
- #include <windows.h>
- #include <tuple>
- #include "picofunctions.h"
- #include "pugiconfig.hpp"
- #include "pugixml.hpp"
- #include "simplelogger.hpp"
- #include "parser.hpp"
- #include "src/PassiveSocket.h"
- #define MAX_PACKET 4096
- using namespace std;
- extern ostream out(cout.rdbuf());
- extern SimpleLogger logger(out, "pico", "picologs");
- void createDirectoryRecursively(const std::string &directory) {
- static const std::string separators("\\/");
- // If the specified directory name doesn't exist, do our thing
- DWORD fileAttributes = ::GetFileAttributesA(directory.c_str());
- if(fileAttributes == INVALID_FILE_ATTRIBUTES) {
- // Recursively do it all again for the parent directory, if any
- std::size_t slashIndex = directory.find_last_of(separators);
- if(slashIndex != std::wstring::npos) {
- createDirectoryRecursively(directory.substr(0, slashIndex));
- }
- // Create the last directory on the path (the recursive calls will have taken
- // care of the parent directories by now)
- BOOL result = ::CreateDirectoryA(directory.c_str(), nullptr);
- if(result == FALSE) {
- throw std::runtime_error("Could not create directory");
- }
- } else { // Specified directory name already exists as a file or directory
- bool isDirectoryOrJunction =
- ((fileAttributes & FILE_ATTRIBUTE_DIRECTORY) != 0) ||
- ((fileAttributes & FILE_ATTRIBUTE_REPARSE_POINT) != 0);
- if(!isDirectoryOrJunction) {
- throw std::runtime_error(
- "Could not create directory because a file with the same name exists"
- );
- }
- }
- }
- class PicoLocalService
- {
- private:
- CActiveSocket* SocketActive;
- const static uint8_t magic_number = 0xAA;
- int16_t handle = 0;
- uint8_t last_command = 0x00;
- uint32_t error_code = 0x00000000;
- int32_t points_value = 0;
- uint32_t sample_rate = 0;
- std::vector<uint32_t> times;
- uint32_t num_triggers = 0;
- uint32_t number_channels = 0;
- std::vector<PS4000A_CHANNEL> channels;
- std::vector<uint32_t> points_vector;
- uint32_t points_simple = 0;
- uint32_t premeasurement_percentage = 0;
- PS4000A_CONDITION* conditions;
- PS4000A_CHANNEL trig_channel = PS4000A_CHANNEL_A;
- PS4000A_THRESHOLD_DIRECTION th_direction = PS4000A_ABOVE;
- int16_t threshold = 0;
- int16_t trig_delay = 0;
- int16_t trig_autoTrigger_ms = 0;
- uint32_t nbytes_sent = 0;
- std::vector<std::vector<int16_t*>> data_buffer_vec;
- std::vector<int16_t*> simple_data_buffer;
- uint8_t rcbuf[MAX_PACKET]{0};
- uint8_t sndbuf[MAX_PACKET]{0};
- public:
- PicoLocalService(CActiveSocket* socket) : SocketActive(socket) {}
- ~PicoLocalService() {}
- int get_request() {
- // Check if buffer has at least 2 bytes for magic number and command
- // Receive data from socket
- int bytes_recieved = SocketActive->Receive(MAX_PACKET, rcbuf);
- if(bytes_recieved == 0)
- {
- logger << LogPref::Flag(ERROR) << "Client disconnected" << endl;
- pico_stop();
- pico_close();
- return 0;
- }
- if(bytes_recieved < 2)
- {
- logger << LogPref::Flag(ERROR) << "Invalid buffer size" << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF; // Error flag
- sndbuf[2] = 0x01; // Error type
- this->error_code = 0x00000000; // No pico error
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- // Extract magic number from buffer
- uint8_t magic;
- memcpy(&magic, rcbuf, sizeof(uint8_t));
- // Check if magic number is correct
- if (magic != this->magic_number) {
- logger << LogPref::Flag(ERROR) << "Invalid magic number: " << std::hex << magic << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x03;
- this->error_code = 0x00000000;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- // Extract command from buffer
- uint8_t cmd;
- memcpy(&cmd, rcbuf + 1, sizeof(uint8_t));
- // Check if command is correct
- switch(cmd)
- {
- case 0x01:
- {
- this->last_command = 0x01;
- logger << LogPref::Flag(INFO) << "Command 0x01 received" << endl;
- pico_open();
- logger << LogPref::Flag(INFO) << "Pico device opened" << endl;
- break;
- }
- case 0x02:
- {
- this->last_command = 0x02;
- logger << LogPref::Flag(INFO) << "Command 0x02 received" << endl;
- if(bytes_recieved < 7) {
- logger << LogPref::Flag(ERROR) << "Invalid buffer size" << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x01;
- this->error_code = 0x00000000;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- uint32_t size;
- memcpy(&size, rcbuf + 2, sizeof(uint32_t));
- if(size < 1) {
- logger << LogPref::Flag(ERROR) << "Invalid data size" << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x02;
- this->error_code = 0x00000000;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- char* file_name = new char[size + 1];
- memcpy(file_name, rcbuf + 6, size * sizeof(char));
- file_name[size] = '\0'; // Null-terminate the string
- std::string file_name_str(file_name);
- logger << LogPref::Flag(INFO) << "File name: " << file_name_str << endl;
- pico_xml_config(file_name_str);
- logger << LogPref::Flag(INFO) << "Pico device configured" << endl;
- delete[] file_name;
- break;
- }
- case 0x0C:
- {
- this->last_command = 0x0C;
- logger << LogPref::Flag(INFO) << "Command 0x0C received" << endl;
- if(bytes_recieved < 22) {
- logger << LogPref::Flag(ERROR) << "Invalid buffer size" << endl;
- return -1;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x01;
- this->error_code = 0x00000000;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- uint32_t size;
- memcpy(&size, rcbuf + 2, sizeof(uint32_t));
- if(size < 1) {
- logger << LogPref::Flag(ERROR) << "Invalid data size" << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x02;
- this->error_code = 0x00000000;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- uint32_t* apoints = new uint32_t[size];
- memcpy(apoints, rcbuf + 6, size * sizeof(uint32_t));
- uint32_t* atimes = new uint32_t[size];
- memcpy(atimes, rcbuf + 6 + size * sizeof(uint32_t), size * sizeof(uint32_t));
- uint32_t sample_rate = 0;
- memcpy(&sample_rate, rcbuf + 6 + 2 * size * sizeof(uint32_t), sizeof(uint32_t));
- uint32_t number_channels = 0;
- memcpy(&number_channels, rcbuf + 10 + 2 * size * sizeof(uint32_t), sizeof(uint32_t));
- pico_set_params(apoints, atimes, sample_rate, number_channels, size);
- logger << LogPref::Flag(INFO) << "Pico device parameters set" << endl;
- delete[] apoints;
- delete[] atimes;
- break;
- }
- case 0x03:
- {
- this->last_command = 0x03;
- logger << LogPref::Flag(INFO) << "Command 0x03 received" << endl;
- pico_close();
- logger << LogPref::Flag(INFO) << "Pico device closed" << endl;
- break;
- }
- case 0x04:
- {
- // Check if buffer has enough data for version numbers
- this->last_command = 0x04;
- logger << LogPref::Flag(INFO) << "Command 0x04 received" << endl;
- pico_get_current_params();
- logger << LogPref::Flag(INFO) << "Pico device parameters retrieved" << endl;
- break;
- }
- case 0x05:
- {
- this->last_command = 0x05;
- logger << LogPref::Flag(INFO) << "Command 0x05 received" << endl;
- pico_probe();
- logger << LogPref::Flag(INFO) << "Pico device probed" << endl;
- break;
- }
- case 0x06:
- {
- this->last_command = 0x06;
- logger << LogPref::Flag(INFO) << "Command 0x06 received" << endl;
- if(bytes_recieved < 10) {
- logger << LogPref::Flag(ERROR) << "Invalid buffer size" << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x01;
- this->error_code = 0x00000000;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- uint32_t size;
- memcpy(&size, rcbuf + 2, sizeof(uint32_t));
- if(size < 1) {
- logger << LogPref::Flag(ERROR) << "Invalid data size" << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x02;
- this->error_code = 0x00000000;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- uint32_t* apoints = new uint32_t[size];
- memcpy(apoints, rcbuf + 6, size * sizeof(uint32_t));
- pico_set_points(apoints, size);
- logger << LogPref::Flag(INFO) << "Pico device points set" << endl;
- delete[] apoints;
- break;
- }
- case 0x07:
- {
- this->last_command = 0x07;
- logger << LogPref::Flag(INFO) << "Command 0x07 received" << endl;
- if(bytes_recieved < 6) {
- logger << LogPref::Flag(ERROR) << "Invalid buffer size" << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x01;
- this->error_code = 0x00000000;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- uint32_t sample_rate = 0;
- memcpy(&sample_rate, rcbuf + 2, sizeof(uint32_t));
- pico_set_sample_rate(sample_rate);
- logger << LogPref::Flag(INFO) << "Pico device sample rate set" << endl;
- break;
- }
- case 0x08:
- {
- this->last_command = 0x08;
- logger << LogPref::Flag(INFO) << "Command 0x08 received" << endl;
- if(bytes_recieved < 10) {
- logger << LogPref::Flag(ERROR) << "Invalid buffer size" << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x01;
- this->error_code = 0x00000000;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- uint32_t size;
- memcpy(&size, rcbuf + 2, sizeof(uint32_t));
- if(size < 1) {
- logger << LogPref::Flag(ERROR) << "Invalid data size" << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x02;
- this->error_code = 0x00000000;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- uint32_t* atimes = new uint32_t[size];
- memcpy(atimes, rcbuf + 6, size * sizeof(uint32_t));
- pico_set_times(atimes, size);
- logger << LogPref::Flag(INFO) << "Pico device times set" << endl;
- delete[] atimes;
- break;
- }
- case 0x09:
- {
- this->last_command = 0x09;
- logger << LogPref::Flag(INFO) << "Command 0x09 received" << endl;
- if(bytes_recieved < 16) {
- logger << LogPref::Flag(ERROR) << "Invalid buffer size" << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x01;
- this->error_code = 0x00000000;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- uint32_t channels = 0;
- memcpy(&channels, rcbuf + 2, sizeof(uint32_t));
- logger << "CHANNELS: " << channels << endl;
- if(channels < 1 || channels > 16) {
- logger << LogPref::Flag(ERROR) << "Invalid number of channels" << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x02;
- this->error_code = 0x00000000;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- enPicoConnectProbeRange* channels_range = new enPicoConnectProbeRange[channels];
- int8_t* raw_ranges = new int8_t[channels];
- memset(raw_ranges, PICO_X1_PROBE_5V, sizeof(int8_t) * channels);
- memcpy(raw_ranges, rcbuf + 6, sizeof(int8_t) * channels);
- logger << "RAW" << (int) raw_ranges[0] << endl;
- for(int i = 0; i < channels; ++i)
- {
- channels_range[i] = static_cast<enPicoConnectProbeRange>(raw_ranges[i]);
- }
- uint8_t trigger_channel = 0;
- memcpy(&trigger_channel, rcbuf + 6 + channels, sizeof(uint8_t));
- int32_t direction = 0;
- memcpy(&direction, rcbuf + 7 + channels, sizeof(int32_t));
- uint16_t threshold = 0;
- memcpy(&threshold, rcbuf + 11 + channels, sizeof(uint16_t));
- int16_t autoTrigger_ms = 0;
- memcpy(&autoTrigger_ms, rcbuf + 13 + channels, sizeof(int16_t));
- pico_configure_channels_t(channels, channels_range, trigger_channel, direction, threshold, autoTrigger_ms);
- logger << LogPref::Flag(INFO) << "Pico device channels configured" << endl;
- break;
- }
- case 0x29:
- {
- }
- case 0x0A:
- {
- this->last_command = 0x0A;
- logger << LogPref::Flag(INFO) << "Command 0x0A received" << endl;
- pico_begin_measurement_times();
- logger << LogPref::Flag(INFO) << "Pico device measurement started" << endl;
- break;
- }
- case 0x0D:
- {
- this->last_command = 0x0D;
- logger << LogPref::Flag(INFO) << "Command 0x0B received" << endl;
- int ret = pico_exit();
- if(ret == 0) {
- logger << LogPref::Flag(INFO) << "Pico device exited successfully" << endl;
- return 0;
- } else {
- logger << LogPref::Flag(ERROR) << "Failed to exit Pico device" << endl;
- }
- break;
- }
- case 0x0E:
- {
- this->last_command = 0x0E;
- logger << LogPref::Flag(INFO) << "Command 0x0E received" << endl;
- pico_stop();
- logger << LogPref::Flag(INFO) << "Pico device stopped" << endl;
- break;
- }
- case 0x20:
- {
- this->last_command = 0x20;
- logger << LogPref::Flag(INFO) << "Command 0x0F received" << endl;
- if(bytes_recieved < 12) {
- logger << LogPref::Flag(ERROR) << "Invalid buffer size" << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x01;
- this->error_code = 0x00000000;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- uint32_t trigger_channel = 0;
- memcpy(&trigger_channel, rcbuf + 2, sizeof(uint32_t));
- int32_t direction = 0;
- memcpy(&direction, rcbuf + 6, sizeof(int32_t));
- uint16_t threshold = 0;
- memcpy(&threshold, rcbuf + 10, sizeof(uint16_t));
- int16_t autoTrigger_ms = 0;
- memcpy(&autoTrigger_ms, rcbuf + 12, sizeof(int16_t));
- pico_configure_trigger(trigger_channel, direction, threshold, autoTrigger_ms);
- break;
- }
- case 0x28:
- {
- this->last_command = 0x28;
- logger << LogPref::Flag(INFO) << "Command 0x28 received" << endl;
- if(bytes_recieved < 6) {
- logger << LogPref::Flag(ERROR) << "Invalid buffer size" << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x01;
- this->error_code = 0x00000000;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- uint32_t percentage = 0;
- memcpy(&percentage, rcbuf + 2, sizeof(uint32_t));
- if(percentage < 0 || percentage > 100) {
- logger << LogPref::Flag(ERROR) << "Invalid premeasurement percentage" << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x02;
- this->error_code = 0x00000000;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- pico_set_premeasurement(percentage);
- break;
- }
- case 0x2B:
- {
- this->last_command = 0x2B;
- logger << LogPref::Flag(INFO) << "Command 0x2B received" << endl;
- pico_simple_measure();
- break;
- }
- case 0x17:
- {
- this->last_command = 0x17;
- logger << LogPref::Flag(INFO) << "Command 0x17 received" << endl;
- if(bytes_recieved < 6) {
- logger << LogPref::Flag(ERROR) << "Invalid buffer size" << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x01;
- this->error_code = 0x00000000;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- uint32_t points = 0;
- memcpy(&points, rcbuf + 2, sizeof(uint32_t));
- pico_set_simple_points(points);
- break;
- }
- case 0x19:
- {
- this->last_command = 0x19;
- logger << LogPref::Flag(INFO) << "Command 0x19 received" << endl;
- if(bytes_recieved < 6) {
- logger << LogPref::Flag(ERROR) << "Invalid buffer size" << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x01;
- this->error_code = 0x00000000;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- uint32_t num_trigger = 0;
- memcpy(&num_trigger, rcbuf + 2, sizeof(uint32_t));
- pico_set_num_trigger(num_trigger);
- break;
- }
- case 0x1B:
- {
- this->last_command = 0x1B;
- logger << LogPref::Flag(INFO) << "Command 0x1B received" << endl;
- pico_multitrigger_measure();
- break;
- }
- case 0x3B:
- {
- this->last_command;
- logger << LogPref::Flag(INFO) << "Command 0x3B received" << endl;
- pico_tcp_measurement_s();
- break;
- }
- default:
- {
- this->last_command = 0xFF;
- logger << LogPref::Flag(ERROR) << "Invalid command: " << std::hex << cmd << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x00;
- this->error_code = 0x00000000;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- }
- return 1;
- }
- int pico_open() {
- // Open socket and initialize Pico device
- auto retval = ps4000aOpenUnit(&handle, NULL);
- logger << LogPref::Flag(INFO) << "Pico device opened with handle: " << handle << endl;
- if (retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to open Pico device. Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x03;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- int16_t start{10};
- retval = ps4000aFlashLed(handle, start);
- logger << LogPref::Flag(INFO) << "Pico device LED flashed." << endl;
- if (retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to flash Pico device LED. Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x04;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Pico device LED flashed." << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xC1;
- if(SocketActive->Send(sndbuf, 2) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Data sent to socket" << endl;
- return 0;
- }
- int pico_stop()
- {
- // Stop measurement and close Pico device
- auto retval = ps4000aStop(handle);
- if (retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to stop Pico device. Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x06;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Pico device stopped" << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xCE;
- if(SocketActive->Send(sndbuf, 2) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Data sent to socket" << endl;
- return 0;
- }
- // To be deprecated in future versions
- int pico_xml_config(const string& file_name) {
- // Load configuration from XML file
- auto data_set = parse_xml_function(file_name.c_str());
- points_vector = string_to_vector(std::get<0>(data_set));
- times = string_to_vector(std::get<2>(data_set));
- points_value = *(std::max_element(points_vector.begin(), points_vector.end()));
- number_channels = std::get<1>(data_set);
- sample_rate = std::get<3>(data_set);
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xC2;
- if(SocketActive->Send(sndbuf, 2) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Data sent to socket" << endl;
- return 0;
- }
- // Deprecated function, use other functions instead
- 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) {
- // Set parameters for measurement
- this->points_vector.assign(points, points + size);
- this->times.assign(times, times + size);
- this->sample_rate = sample_rate;
- this->number_channels = number_channels;
- points_value = *(std::max_element(points_vector.begin(), points_vector.end()));
- logger << LogPref::Flag(INFO) << "Parameters set" << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xCC;
- if(SocketActive->Send(sndbuf, 2) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- return -1;
- }
- return 0;
- }
- int pico_close() {
- // Close Pico device and socket
- auto retval = ps4000aCloseUnit(handle);
- if (retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to close Pico device. Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x05;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Pico device closed" << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xC3;
- if(SocketActive->Send(sndbuf, 2) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Data sent to socket" << endl;
- return 0;
- }
- int pico_get_current_params() {
- // Get current parameters from Pico device
- logger << LogPref::Flag(INFO) << "Current parameters:" << endl;
- logger << "Points: " << points_value << endl;
- logger << "Times size: " << times.size() << endl;
- logger << "Sample rate: " << sample_rate << endl;
- logger << "Number of channels: " << number_channels << endl;
- logger << "Trigger channel: " << trig_channel << endl;
- logger << "Trigger direction: " << th_direction << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xC4;
- uint32_t bsize = points_vector.size() * sizeof(uint32_t);
- uint32_t test = 0;
- memcpy(sndbuf + 2, &bsize, sizeof(uint32_t));
- memcpy(sndbuf + 6, points_vector.data(), bsize);
- memcpy(&test, points_vector.data(), bsize);
- logger << LogPref::Flag(INFO) << test << endl;
- memcpy(sndbuf + 6 + bsize, times.data(), bsize);
- logger << LogPref::Flag(INFO) << times.data()[0] << endl;
- memcpy(sndbuf + 6 + 2 * bsize, &sample_rate, sizeof(sample_rate));
- memcpy(sndbuf + 10 + 2 * bsize, &number_channels, sizeof(number_channels));
- if(SocketActive->Send(sndbuf, 10 + sizeof(points_vector.data()) + sizeof(times.data())) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- return -1;
- }
- return 0;
- }
- int pico_probe() {
- // Probe signal from Pico device
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xC5;
- if(SocketActive->Send(sndbuf, 2) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Data sent to socket" << endl;
- return 0;
- }
- int pico_set_points(const uint32_t* points, const uint32_t size) {
- // Set points for measurement
- this->points_vector.assign(points, points + size);
- points_value = *(std::max_element(points_vector.begin(), points_vector.end()));
- logger << LogPref::Flag(INFO) << "Points set" << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xC6;
- if(SocketActive->Send(sndbuf, 2) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- return -1;
- }
- return 0;
- }
- int pico_set_simple_points(const uint32_t points) {
- // Set simple points for measurement
- this->points_simple = points;
- logger << LogPref::Flag(INFO) << "Simple points set to: " << points << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xD7;
- if(SocketActive->Send(sndbuf, 2) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- return -1;
- }
- return 0;
- }
- int pico_set_sample_rate(const uint32_t sample_rate) {
- // Set sample rate for measurement
- this->sample_rate = sample_rate;
- logger << LogPref::Flag(INFO) << "Sample rate set to: " << sample_rate << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xC7;
- if(SocketActive->Send(sndbuf, 2) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- return -1;
- }
- return 0;
- }
- int pico_set_times(const uint32_t* times, const uint32_t size) {
- // Set times for measurement
- this->times.assign(times, times + size);
- logger << LogPref::Flag(INFO) << "Times set" << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xC8;
- if(SocketActive->Send(sndbuf, 2) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- return -1;
- }
- return 0;
- }
- int pico_set_num_trigger(const uint32_t num_trigger) {
- // Set number of channels for trigger
- this->num_triggers = num_trigger;
- logger << LogPref::Flag(INFO) << "Number of triggers set to: " << num_trigger << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xD9;
- memcpy(sndbuf + 2, &num_triggers, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 6) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Data sent to socket" << endl;
- return 0;
- }
- int pico_configure_channels_s(const uint32_t number_channels, enPicoConnectProbeRange* channel_ranges, uint8_t trigger_channel)
- {
- this->number_channels = number_channels;
- logger << LogPref::Flag(INFO) << "Number of channels set to: " << number_channels << endl;
- this->channels = create_channel(number_channels);
- conditions = new PS4000A_CONDITION[number_channels];
- for (uint32_t i = 0; i < number_channels; ++i) {
- conditions[i].source = channels[i];
- conditions[i].condition = PS4000A_CONDITION_FALSE;
- }
- logger << LogPref::Flag(INFO) << "DEBUG RANGE" << trigger_channel << " " << channel_ranges[trigger_channel] << endl;
- auto retval = ps4000aSetChannel(handle, channels[trigger_channel], true, PS4000A_DC, channel_ranges[trigger_channel], 0);
- if(retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to set trigger channel. Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x06;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Trigger channel set" << endl;
- for(uint8_t i = 0; i < number_channels; ++i) {
- if(i == trigger_channel) continue;
- else {
- logger << LogPref::Flag(INFO) << "DEBUG RANGE" << i << " " << channel_ranges[i] << endl;
- auto retval = ps4000aSetChannel(handle, channels[i], true, PS4000A_AC, channel_ranges[i], 0);
- if (retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to set channel " << i << ". Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x07 + i;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Channel " << i << " set" << endl;
- }
- }
- if (retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to set trigger. Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x12;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xE9;
- if(SocketActive->Send(sndbuf, 2) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- return -1;
- }
- }
- 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) {
- // Set number of channels for measurement
- this->number_channels = number_channels;
- logger << LogPref::Flag(INFO) << "Number of channels set to: " << number_channels << endl;
- logger << LogPref::Flag(INFO) << "trigger_channel set to: " << (int) trigger_channel << endl;
- logger << LogPref::Flag(INFO) << "direction set to: " << direction << endl;
- logger << LogPref::Flag(INFO) << "threshold set to: " << threshold << endl;
- logger << LogPref::Flag(INFO) << "autoTrigger_ms set to: " << autoTrigger_ms << endl;
- this->channels = create_channel(number_channels);
- conditions = new PS4000A_CONDITION[number_channels];
- for (uint32_t i = 0; i < number_channels; ++i) {
- conditions[i].source = channels[i];
- conditions[i].condition = PS4000A_CONDITION_FALSE;
- }
- logger << LogPref::Flag(INFO) << "DEBUG RANGE" << trigger_channel << " " << channel_ranges[trigger_channel] << endl;
- if(auto retval = ps4000aSetChannel(handle, channels[trigger_channel], true, PS4000A_DC, channel_ranges[trigger_channel], 0) != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to set trigger channel. Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x06;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Trigger channel set" << endl;
- this->trig_channel = channels[trigger_channel];
- this->th_direction = static_cast<PS4000A_THRESHOLD_DIRECTION>(direction);
- this->threshold = threshold;
- this->trig_delay = 10;
- this->trig_autoTrigger_ms = autoTrigger_ms;
- for(uint8_t i = 0; i < number_channels; ++i) {
- if(i == trigger_channel) continue;
- else {
- logger << LogPref::Flag(INFO) << "DEBUG RANGE" << i << " " << channel_ranges[i] << endl;
- auto retval = ps4000aSetChannel(handle, channels[i], true, PS4000A_AC, channel_ranges[i], 0);
- if (retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to set channel " << i << ". Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x07 + i;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Channel " << i << " set" << endl;
- }
- }
- logger << LogPref::Flag(INFO) << "DEBUG TRIGGER" << endl;
- logger << LogPref::Flag(INFO) << this->handle << endl;
- logger << LogPref::Flag(INFO) << this->trig_channel << endl;
- logger << LogPref::Flag(INFO) << this->threshold << endl;
- logger << LogPref::Flag(INFO) << this->th_direction << endl;
- logger << LogPref::Flag(INFO) << this->trig_delay << endl;
- logger << LogPref::Flag(INFO) << this->trig_autoTrigger_ms << endl;
- auto retval = ps4000aSetSimpleTrigger
- (
- handle,
- true,
- conditions[trigger_channel].source,
- threshold,
- th_direction,
- trig_delay,
- trig_autoTrigger_ms
- );
- if (retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to set trigger. Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x12;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xC9;
- if(SocketActive->Send(sndbuf, 2) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- return -1;
- }
- return 0;
- }
- // To be deprecated in future versions
- int pico_begin_measurement_times() {
- // Begin measurement on Pico device
- data_buffer_vec.assign(times.size(), std::vector<int16_t*>(number_channels, nullptr));
- for(size_t i = 0; i < times.size(); ++i) {
- logger << LogPref::Flag(INFO) << "Set data buffer:" << endl;
- for(size_t j = 0; j < number_channels; ++j) {
- data_buffer_vec[i][j] = new int16_t[points_vector[i]];
- }
- logger << LogPref::Flag(INFO) << "Get timebase:" << endl;
- uint32_t timebase = timebase_choice(sample_rate);
- logger << "Timebase = " << timebase << endl;
- int32_t timeIntervalNanoseconds = 0;
- int32_t maxSamples = 0;
- int32_t segmentIndex = 0;
- int32_t retval = ps4000aGetTimebase(handle, timebase, points_vector[i], &timeIntervalNanoseconds,
- &maxSamples, segmentIndex);
- logger << "retval: " << retval << endl;
- if(retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to get timebase. Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x13;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Run block:" << endl;
- int32_t noOfPreTriggerSamples = 0;
- int32_t noOfPostTriggerSamples = points_value;
- retval = ps4000aRunBlock(handle, noOfPreTriggerSamples, noOfPostTriggerSamples, timebase,
- nullptr, segmentIndex, nullptr, nullptr);
- logger << "retval: " << retval << endl;
- if(retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to run block. Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x14;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Run block done" << endl;
- int16_t ready = 0;
- while (ready == 0) {
- retval = ps4000aIsReady(handle, &ready);
- }
- for(uint8_t j = 0; j < number_channels; ++j) {
- logger << LogPref::Flag(INFO) << "Set data buffer for channel " << j << endl;
- PS4000A_RATIO_MODE mode = PS4000A_RATIO_MODE_NONE;
- retval = ps4000aSetDataBuffer(handle, channels[j], data_buffer_vec[i][j], points_vector[i],
- segmentIndex, mode);
- logger << "retval: " << retval << endl;
- if(retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to set data buffer for channel " << j << ". Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x15 + j;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- }
- logger << LogPref::Flag(INFO) << "Set data buffer done" << endl;
- logger << LogPref::Flag(INFO) << "Data collection start" << endl;
- uint32_t StartIndex = 0;
- uint32_t noOfSamples = static_cast<uint32_t>(points_vector[i]);
- int16_t overflow = 0;
- uint32_t DownSampleRatio = 1;
- retval = ps4000aGetValues(handle, StartIndex, &noOfSamples, DownSampleRatio, PS4000A_RATIO_MODE_NONE,
- segmentIndex, &overflow);
- logger << "retval: " << retval << endl;
- if(retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to get values. Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x21;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Data collection done" << endl;
- logger << LogPref::Flag(INFO) << "Confirm data to socket" << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xCA;
- if(SocketActive->Send(sndbuf, 2) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Data sent to socket" << endl;
- logger << LogPref::Flag(INFO) << "Data confirmed" << endl;
- logger << LogPref::Flag(INFO) << "Sleeping for " << times[i+1] - times[i] << " ms" << endl;
- if(i < times.size() - 1) {
- std::chrono::duration<int64, std::milli> duration(times[i+1] - times[i]);
- std::this_thread::sleep_for(duration);
- }
- }
- for(int i = 0; i < data_buffer_vec.size(); ++i) {
- logger << LogPref::Flag(INFO) << "Writing data " << i << " to file" << endl;
- std::string filename = "data" + std::to_string(i);
- writing_data_fixed_name(filename, data_buffer_vec[i], points_vector[i], number_channels);
- logger << LogPref::Flag(INFO) << "Data collection done" << endl;
- }
- logger << LogPref::Flag(INFO) << "Free buffers" << endl;
- for(uint8_t j = 0; j < times.size(); ++j)
- {
- free_buffers(data_buffer_vec[j]);
- }
- logger << LogPref::Flag(INFO) << "Buffers freed" << endl;
- logger << LogPref::Flag(INFO) << "Measurement done" << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xCB;
- if (SocketActive->Send(sndbuf, 2) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Data sent to socket" << endl;
- return 0;
- }
- int pico_exit() {
- // Exit Pico device and free resources
- if (handle != NULL) {
- auto ret = ps4000aCloseUnit(handle);
- if (ret != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to close Pico device. Code: " << ret << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x23;
- this->error_code = ret;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xCD;
- if(SocketActive->Send(sndbuf, 2) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Pico device closed" << endl;
- handle = NULL;
- }
- return 0;
- }
- int pico_configure_trigger(int8_t trigger_channel, int32_t direction, uint16_t threshold, int16_t autoTrigger_ms) {
- // Configure trigger for Pico device
- this->trig_channel = channels[trigger_channel];
- this->th_direction = static_cast<PS4000A_THRESHOLD_DIRECTION>(direction);
- this->trig_delay = 10;
- this->threshold = threshold;
- this->trig_autoTrigger_ms = autoTrigger_ms;
- logger << LogPref::Flag(INFO) << "Trigger configured" << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xC9;
- if(SocketActive->Send(sndbuf, 2) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- return -1;
- }
- auto retval = ps4000aSetSimpleTrigger
- (
- handle,
- true,
- channels[trigger_channel],
- this->threshold,
- this->th_direction,
- this->trig_delay,
- this->trig_autoTrigger_ms
- );
- if (retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to set trigger. Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x16;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Trigger set successfully" << endl;\
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xE0;
- if(SocketActive->Send(sndbuf, 2) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- return -1;
- }
- return 0;
- }
- int pico_simple_measure()
- {
- simple_data_buffer = std::vector<int16_t*>(number_channels, nullptr);
- logger << LogPref::Flag(INFO) << "Set simple data buffer:" << endl;
- for(size_t j = 0; j < number_channels; ++j) {
- simple_data_buffer[j] = new int16_t[points_simple];
- }
- logger << LogPref::Flag(INFO) << "Get timebase:" << endl;\
- uint32_t timebase = timebase_choice(sample_rate);
- logger << "Timebase = " << timebase << endl;
- int32_t timeIntervalNanoseconds = 0;
- int32_t maxSamples = 0;
- int32_t segmentIndex = 0;
- int32_t retval = ps4000aGetTimebase(handle, timebase, points_simple, &timeIntervalNanoseconds,
- &maxSamples, segmentIndex);
- logger << "retval: " << retval << endl;
- if(retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to get timebase. Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x17;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Run block:" << endl;
- int32_t noOfPreTriggerSamples = (int32_t) (points_simple * premeasurement_percentage / 100.0f);
- int32_t noOfPostTriggerSamples = points_simple;
- retval = ps4000aRunBlock(handle, noOfPreTriggerSamples, noOfPostTriggerSamples, timebase,
- nullptr, segmentIndex, nullptr, nullptr);
- logger << "retval: " << retval << endl;
- if(retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to run block. Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x18;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Run block done" << endl;
- int16_t ready = 0;
- while (ready == 0) {
- retval = ps4000aIsReady(handle, &ready);
- }
- for(uint8_t j = 0; j < number_channels; ++j) {
- logger << LogPref::Flag(INFO) << "Set simple data buffer for channel " << j << endl;
- PS4000A_RATIO_MODE mode = PS4000A_RATIO_MODE_NONE;
- retval = ps4000aSetDataBuffer(handle, channels[j], simple_data_buffer[j], points_simple,
- segmentIndex, mode);
- logger << "retval: " << retval << endl;
- if(retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to set data buffer for channel " << j << ". Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x19 + j;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- }
- logger << LogPref::Flag(INFO) << "Set simple data buffer done" << endl;
- logger << LogPref::Flag(INFO) << "Data collection start" << endl;
- uint32_t StartIndex = 0;
- uint32_t noOfSamples = static_cast<uint32_t>(points_simple);
- int16_t overflow = 0;
- uint32_t DownSampleRatio = 1;
- retval = ps4000aGetValues(handle, StartIndex, &noOfSamples, DownSampleRatio, PS4000A_RATIO_MODE_NONE,
- segmentIndex, &overflow);
- logger << "retval: " << retval << endl;
- if(retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to get values. Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x20;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Data collection done" << endl;
- std::string filename = "simple_data_channel.csv";
- writing_data_fixed_name(filename, simple_data_buffer, points_simple, 1);
- logger << LogPref::Flag(INFO) << "Free simple data buffers" << endl;
- for(uint8_t j = 0; j < number_channels; ++j)
- {
- delete[] simple_data_buffer[j];
- simple_data_buffer[j] = nullptr;
- }
- logger << LogPref::Flag(INFO) << "Simple data buffers freed" << endl;
- logger << LogPref::Flag(INFO) << "Simple measurement done" << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xEB;
- if(SocketActive->Send(sndbuf, 2) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Data sent to socket" << endl;
- return 0;
- }
- int pico_set_premeasurement(uint32_t percentage)
- {
- // Set pre-measurement percentage
- this->premeasurement_percentage = percentage;
- logger << LogPref::Flag(INFO) << "Pre-measurement percentage set to: " << percentage << "%" << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xE8;
- if(SocketActive->Send(sndbuf, 2) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- return -1;
- }
- return 0;
- }
- int pico_multitrigger_measure()
- {
- // Multi-trigger measurement
- logger << LogPref::Flag(INFO) << "Multi-trigger measurement started" << endl;
- data_buffer_vec = std::vector<std::vector<int16_t*>>(num_triggers, std::vector<int16_t*>(number_channels, nullptr));
- for(size_t i = 0; i < num_triggers; ++i) {
- data_buffer_vec[i].assign(number_channels, nullptr);
- for(size_t j = 0; j < number_channels; ++j) {
- data_buffer_vec[i][j] = new int16_t[points_simple];
- }
- }
- for(size_t i = 0; i < num_triggers; ++i) {
- logger << LogPref::Flag(INFO) << "Set data buffer for trigger " << i << ":" << endl;
- for(size_t j = 0; j < number_channels; ++j) {
- data_buffer_vec[i][j] = new int16_t[points_simple];
- }
- logger << LogPref::Flag(INFO) << "Get timebase:" << endl;
- uint32_t timebase = timebase_choice(sample_rate);
- logger << "Timebase = " << timebase << endl;
- int32_t timeIntervalNanoseconds = 0;
- int32_t maxSamples = 0;
- int32_t segmentIndex = 0;
- int32_t retval = ps4000aGetTimebase(handle, timebase, points_simple, &timeIntervalNanoseconds,
- &maxSamples, segmentIndex);
- logger << "retval: " << retval << endl;
- if(retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to get timebase. Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x22;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- logger << LogPref::Flag(INFO) << points_simple << endl;
- logger << LogPref::Flag(INFO) << "Run block:" << endl;
- int32_t noOfPreTriggerSamples = (int32_t) (points_simple * premeasurement_percentage / 100.0f);
- int32_t noOfPostTriggerSamples = points_simple;
- retval = ps4000aRunBlock(handle, noOfPreTriggerSamples, noOfPostTriggerSamples, timebase,
- nullptr, segmentIndex, nullptr, nullptr);
- logger << "retval: " << retval << endl;
- if(retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to run block. Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x23;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Run block done" << endl;
- int16_t ready = 0;
- while (ready == 0) {
- retval = ps4000aIsReady(handle, &ready);
- }
- logger << LogPref::Flag(INFO) << "Set data buffer for channels:" << endl;
- for(uint8_t j = 0; j < number_channels; ++j) {
- PS4000A_RATIO_MODE mode = PS4000A_RATIO_MODE_NONE;
- retval = ps4000aSetDataBuffer(handle, channels[j], data_buffer_vec[i][j], points_simple,
- segmentIndex, mode);
- logger << "retval: " << retval << endl;
- if(retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to set data buffer for channel " << j << ". Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x24 + j;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- }
- logger << LogPref::Flag(INFO) << "Set data buffer done" << endl;
- logger << LogPref::Flag(INFO) << "Data collection start" << endl;
- uint32_t StartIndex = 0;
- uint32_t noOfSamples = static_cast<uint32_t>(points_simple);
- int16_t overflow = 0;
- uint32_t DownSampleRatio = 1;
- retval = ps4000aGetValues(handle, StartIndex, &noOfSamples, DownSampleRatio, PS4000A_RATIO_MODE_NONE,
- segmentIndex, &overflow);
- logger << "retval: " << retval << endl;
- if(retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to get values. Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x25;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Data collection done" << endl;
- logger << LogPref::Flag(INFO) << "Confirm data to socket" << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xDA;
- if(SocketActive->Send(sndbuf, 2) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Data sent to socket" << endl;
- logger << LogPref::Flag(INFO) << "Data confirmed" << endl;
- logger << LogPref::Flag(INFO) << this->handle << endl;
- logger << LogPref::Flag(INFO) << this->trig_channel << endl;
- logger << LogPref::Flag(INFO) << this->threshold << endl;
- logger << LogPref::Flag(INFO) << this->th_direction << endl;
- logger << LogPref::Flag(INFO) << this->trig_delay << endl;
- logger << LogPref::Flag(INFO) << this->trig_autoTrigger_ms << endl;
- auto trig_retval = ps4000aSetSimpleTrigger
- (
- this->handle,
- true,
- this->trig_channel,
- this->threshold,
- this->th_direction,
- this->trig_delay,
- this->trig_autoTrigger_ms
- );
- if (trig_retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to set trigger. Code: " << trig_retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x26;
- this->error_code = trig_retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Trigger set successfully" << endl;
- }
- logger << LogPref::Flag(INFO) << "Writing data to files" << endl;
- std::chrono::time_point<std::chrono::system_clock> time_now = std::chrono::system_clock::now();
- std::time_t t_n = std::chrono::system_clock::to_time_t(time_now);
- char time_dir_nm[100];
- std::strftime(time_dir_nm, sizeof(time_dir_nm), "%Y%m%d-%H%M%S", std::localtime(&t_n));
- #ifdef _WIN32
- std::string dir = std::string("output\\") + std::string(time_dir_nm);
- createDirectoryRecursively(dir);
- #endif // _WIN32
- for(int i = 0; i < data_buffer_vec.size(); ++i) {
- logger << LogPref::Flag(INFO) << "Writing data " << i << " to file" << endl;
- std::string filename = std::string(time_dir_nm) + "\\data_trigger_" + std::to_string(i);
- writing_data_fixed_name(filename, data_buffer_vec[i], points_simple, number_channels);
- logger << LogPref::Flag(INFO) << "Data collection done" << endl;
- }
- logger << LogPref::Flag(INFO) << "Free buffers" << endl;
- for(uint8_t j = 0; j < num_triggers; ++j)
- {
- free_buffers(data_buffer_vec[j]);
- }
- logger << LogPref::Flag(INFO) << "Buffers freed" << endl;
- logger << LogPref::Flag(INFO) << "Multi-trigger measurement done" << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xDB;
- if(SocketActive->Send(sndbuf, 2) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Data sent to socket" << endl;
- return 0;
- }
- int pico_tcp_measurement_s()
- {
- logger << LogPref::Flag(INFO) << "Multi-trigger measurement started" << endl;
- data_buffer_vec.assign(num_triggers, std::vector<int16_t*>(number_channels, nullptr));
- int16_t* data_buffer_arr[num_triggers][number_channels];
- logger << LogPref::Flag(INFO) << "Get timebase:" << endl;
- uint32_t timebase = timebase_choice(sample_rate);
- logger << "Timebase = " << timebase << endl;
- #define FAST_BLOCK
- #ifdef SLOW_BLOCK
- for(size_t i = 0; i < num_triggers; ++i) {
- logger << LogPref::Flag(INFO) << "Set data buffer:" << endl;
- for(size_t j = 0; j < number_channels; ++j) {
- data_buffer_vec[i][j] = new int16_t[points_vector[i]];
- memset(data_buffer_vec[i][j], 0, points_vector[i]);
- }
- int32_t timeIntervalNanoseconds = 0;
- int32_t maxSamples = 0;
- int32_t segmentIndex = 0;
- int32_t retval = ps4000aGetTimebase(handle, timebase, points_vector[i], &timeIntervalNanoseconds,
- &maxSamples, segmentIndex);
- logger << "retval: " << retval << endl;
- if(retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to get timebase. Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x13;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Run block:" << endl;
- int32_t noOfPreTriggerSamples = 0;
- int32_t noOfPostTriggerSamples = points_value;
- retval = ps4000aRunBlock(handle, noOfPreTriggerSamples, noOfPostTriggerSamples, timebase,
- nullptr, segmentIndex, nullptr, nullptr);
- logger << "retval: " << retval << endl;
- if(retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to run block. Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x14;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Run block done" << endl;
- int16_t ready = 0;
- while (ready == 0) {
- retval = ps4000aIsReady(handle, &ready);
- }
- for(size_t j = 0; j < number_channels; ++j) {
- logger << LogPref::Flag(INFO) << "Set data buffer for channel " << j << endl;
- PS4000A_RATIO_MODE mode = PS4000A_RATIO_MODE_NONE;
- retval = ps4000aSetDataBuffer(handle, channels[j], data_buffer_vec[i][j], points_vector[i],
- segmentIndex, mode);
- logger << "retval: " << retval << endl;
- if(retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to set data buffer for channel " << j << ". Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x15 + j;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- }
- logger << LogPref::Flag(INFO) << "Set data buffer done" << endl;
- logger << LogPref::Flag(INFO) << "Data collection start" << endl;
- uint32_t StartIndex = 0;
- uint32_t noOfSamples = static_cast<uint32_t>(points_vector[i]);
- int16_t overflow = 0;
- uint32_t DownSampleRatio = 1;
- retval = ps4000aGetValues(handle, StartIndex, &noOfSamples, DownSampleRatio, PS4000A_RATIO_MODE_NONE,
- segmentIndex, &overflow);
- logger << "retval: " << retval << endl;
- if(retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to get values. Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x21;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Data collection done" << endl;
- logger << LogPref::Flag(INFO) << "Confirm data to socket" << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFA;
- if(SocketActive->Send(sndbuf, 2) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- return -1;
- }
- int bytes_recieved = SocketActive->Receive(MAX_PACKET, rcbuf);
- if(rcbuf[1] == 0x3A)
- {
- logger << LogPref::Flag(INFO) << "Data confirmed" << endl;
- }
- else{
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Data sent to socket" << endl;
- /*
- auto trig_retval = ps4000aSetSimpleTrigger
- (
- this->handle,
- true,
- this->trig_channel,
- this->threshold,
- this->th_direction,
- this->trig_delay,
- this->trig_autoTrigger_ms
- );
- if (trig_retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to set trigger. Code: " << trig_retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x26;
- this->error_code = trig_retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- */
- logger << LogPref::Flag(INFO) << "Trigger set successfully" << endl;
- logger << LogPref::Flag(INFO) << "Wait for trig" << endl;
- }
- #endif
- #ifdef FAST_BLOCK
- logger << LogPref::Flag(INFO) << "Set data buffer:" << endl;
- for(size_t i = 0; i < num_triggers; ++i) {
- for(size_t j = 0; j < number_channels; ++j) {
- data_buffer_vec[i][j] = new int16_t[points_vector[i]];
- memset(data_buffer_vec[i][j], 0, points_vector[i]);
- }
- }
- int32_t* nSamples = new int32_t[num_triggers];
- int32_t retval = ps4000aMemorySegments(handle, num_triggers, nSamples);
- if(retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to get values. Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x21;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- retval = ps4000aSetNoOfCaptures(handle, num_triggers);
- if(retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to get values. Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x21;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- int32_t timeIntervalNanoseconds = 0;
- int32_t maxSamples = 0;
- int32_t segmentIndex = 0;
- retval = ps4000aGetTimebase(handle, timebase, points_value, &timeIntervalNanoseconds,
- &maxSamples, segmentIndex);
- logger << "retval: " << retval << endl;
- if(retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to get timebase. Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x13;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- int32_t noOfPreTriggerSamples = 0;
- int32_t noOfPostTriggerSamples = points_value;
- logger << LogPref::Flag(INFO) << "Run block" << endl;
- retval = ps4000aRunBlock(handle, noOfPreTriggerSamples, noOfPostTriggerSamples, timebase,
- nullptr, segmentIndex, nullptr, nullptr);
- if(retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to get values. Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x21;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Run block done" << endl;
- int16_t ready = 0;
- while (ready == 0) {
- retval = ps4000aIsReady(handle, &ready);
- }
- logger << LogPref::Flag(INFO) << "Data ready" << endl;
- for(size_t i = 0; i < num_triggers; ++i) {
- for(size_t j = 0; j < number_channels; ++j) {
- logger << LogPref::Flag(INFO) << "Set data buffer for channel " << j << endl;
- PS4000A_RATIO_MODE mode = PS4000A_RATIO_MODE_NONE;
- retval = ps4000aSetDataBuffer(handle, channels[j], data_buffer_vec[i][j], points_vector[i],
- i, mode);
- logger << "retval: " << retval << endl;
- if(retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to set data buffer for channel " << j << ". Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x15 + j;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- }
- }
- logger << LogPref::Flag(INFO) << "Set data buffer done" << endl;
- logger << LogPref::Flag(INFO) << "Data collection start" << endl;
- uint32_t StartIndex = 0;
- uint32_t noOfSamples = static_cast<uint32_t>(points_value);
- int16_t overflow = 0;
- uint32_t DownSampleRatio = 1;
- retval = ps4000aGetValuesBulk(handle, &noOfSamples, 0, num_triggers-1, DownSampleRatio, PS4000A_RATIO_MODE_NONE, &overflow);
- logger << "retval: " << retval << endl;
- if(retval != 0) {
- logger << LogPref::Flag(ERROR) << "Failed to get values. Code: " << retval << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFF;
- sndbuf[2] = 0x21;
- this->error_code = retval;
- memcpy(sndbuf + 3, &this->error_code, sizeof(uint32_t));
- if(SocketActive->Send(sndbuf, 7) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- }
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Data collection done" << endl;
- logger << LogPref::Flag(INFO) << "Confirm data to socket" << endl;
- #endif // FAST_BLOCK
- logger << LogPref::Flag(INFO) << "Sending confirmation code" << endl;
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFB;
- if(SocketActive->Send(sndbuf, 2) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Confirmation code sended" << endl;
- int bytes_recieved = SocketActive->Receive(MAX_PACKET, rcbuf);
- if(rcbuf[1] == 0x3B)
- {
- logger << LogPref::Flag(INFO) << "Data confirmed" << endl;
- }
- else{
- return -1;
- }
- logger << LogPref::Flag(INFO) << "Sending data" << endl;
- std::chrono::time_point<std::chrono::system_clock> time_now = std::chrono::system_clock::now();
- std::time_t t_n = std::chrono::system_clock::to_time_t(time_now);
- for(uint32_t i = 0; i < num_triggers; ++i)
- {
- for(uint32_t j = 0; j < number_channels; ++j)
- {
- uint32_t data_seek = 0;
- uint32_t packet = 0;
- uint32_t total_data = sizeof(int16_t) * points_vector[i];
- uint32_t total_packets = 1 + ((uint32_t) ((total_data * 1.0f) / MAX_PACKET));
- do
- {
- uint32_t ndata_sent;
- if(total_data - data_seek < MAX_PACKET - 22)
- {
- ndata_sent = total_data - data_seek;
- }
- else
- {
- ndata_sent = MAX_PACKET - 22;
- }
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFD;
- memcpy(sndbuf + 2, &i, sizeof(uint32_t));
- memcpy(sndbuf + 6, &j, sizeof(uint32_t));
- memcpy(sndbuf + 10, &total_packets, sizeof(uint32_t));
- memcpy(sndbuf + 14, &packet, sizeof(uint32_t));
- memcpy(sndbuf + 18, &ndata_sent, sizeof(uint32_t));
- int16_t test_data = data_buffer_vec[i][j][0];
- memcpy(sndbuf + 22, data_buffer_vec[i][j] + (data_seek / 2), ndata_sent);
- logger << LogPref::Flag(INFO) << "Total data: " << total_data << ". Data seek: " << data_seek << ". Test data:" << test_data << endl;
- logger << LogPref::Flag(INFO) << "Sending packet " << packet << " of " << total_packets << " (sig" << i << "ch" << j << "). Data to send: " << ndata_sent << endl;
- if(SocketActive->Send(sndbuf, 22 + ndata_sent) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- return -1;
- }
- data_seek += ndata_sent;
- ++packet;
- int bytes_recieved = SocketActive->Receive(MAX_PACKET, rcbuf);
- if(rcbuf[1] == 0x3D)
- {
- logger << LogPref::Flag(INFO) << "Data confirmed" << endl;
- }
- else{
- return -1;
- }
- } while (packet < total_packets);
- }
- }
- sndbuf[0] = magic_number;
- sndbuf[1] = 0xFC;
- if(SocketActive->Send(sndbuf, 2) == -1) {
- logger << LogPref::Flag(ERROR) << "Failed to send data to socket" << endl;
- return -1;
- }
- bytes_recieved = SocketActive->Receive(MAX_PACKET, rcbuf);
- if(rcbuf[1] == 0x3C)
- {
- logger << LogPref::Flag(INFO) << "Data confirmed" << endl;
- }
- else{
- return -1;
- }
- return 0;
- }
- };
- int main()
- {
- logger.enableConsoleOutput(true);
- logger << "Open socket" << endl;
- CPassiveSocket SocketPassive(CSimpleSocket::CSocketType::SocketTypeTcp);
- if (!SocketPassive.Initialize())
- {
- logger << LogPref::Flag(ERROR) << "Socket initialization failed" << endl;
- return -1;
- }
- if(!SocketPassive.Listen("127.0.0.1", 5003))
- {
- logger << LogPref::Flag(ERROR) << "Socket listening failed" << endl;
- return -1;
- }
- logger << "Socket initialized!" << endl;
- CActiveSocket* ClientSocket;
- PicoLocalService* pico_service;
- while(true)
- {
- logger << LogPref::Flag(INFO) << "Wait for connection..." << endl;
- logger.closeLogger();
- if ((ClientSocket = SocketPassive.Accept()) == nullptr)
- {
- logger.closeLogger();
- logger.initializeLogger("picologs", "pico");
- logger.enableConsoleOutput(true);
- logger << LogPref::Flag(ERROR) << "Socket accept failed" << endl;
- logger.closeLogger();
- return -1;
- }
- logger.initializeLogger("picologs", "pico");
- logger.enableConsoleOutput(true);
- logger << LogPref::Flag(INFO) << "Client connected" << endl;
- pico_service = new PicoLocalService(ClientSocket);
- while(pico_service->get_request() != 0)
- {
- logger << LogPref::Flag(INFO) << "Request received" << endl;
- }
- logger << LogPref::Flag(INFO) << "Request processing finished" << endl;
- delete pico_service;
- pico_service = nullptr;
- delete ClientSocket;
- ClientSocket = nullptr;
- }
- return 0;
- }
|