#include "redpitaya_gui.h"
#include <ansi_c.h>
#include <tcpsupp.h>
#include <utility.h>
#include <cvirte.h>
#include <userint.h>
#include "redpitaya_gui.h"
#include "H1D.h"
#define NBEFORE 150
#define MAXSAMPLES 16384
#define MINTRGDELAY -8192
static int panelHandle
;
static int outputHandle
;
static int settingsHandle
;
static int ch0Handle
;
static int ch1Handle
;
static unsigned int chandle
= 0;
//static int tfID;
int pfreq
;
static int plothandle
[2]= {0,0};
static int tdcplothandle
[2]= {0,0};
static int adcplothandle
[2]= {0,0};
static int excludefirst
[2]= {0,0};
int debug
;
int initialized
= 0;
#define MAX_THREADS 10
int nsamples
=0;
int adctype
;
float athreshold
, twin0
,twin1
;
float timebins
[0XFFFF];
float daqtime
;
double starttime
;
FILE
*foutput
;
int outwaveforms
=0;
static CmtThreadPoolHandle poolHandle
= 0;
int ctrl_c
=0;
int CVICALLBACK SocketCB
(unsigned handle
, int xType
, int errCode
, void *callbackData
);
static int export_data
(int hid
) {
char filename
[0xFF],rootcmd
[0xFF];
char fname
[0xFF];
char path
[0xFF];
char datestr
[0xFF];
int type
=0;
GetCtrlVal
(settingsHandle
,SETTINGS_EXPORTNAME
,fname
);
GetCtrlVal
(settingsHandle
,SETTINGS_FILETYPE
,&type
);
sprintf(path
, "%s\\Desktop\\data", getenv("USERPROFILE"));
MakeDir
(path
);
FILE
*fp
;
int hour
, min
, month
, day
,year
;
double sec
;
double mtime
;
GetCurrentDateTime
(&mtime
);
GetDateTimeElements
(mtime
, &hour
, &min
, &sec
, &month
, &day
, &year
);
sprintf(datestr
,"%02d_%02d_%02d", hour
, min
, (int) sec
);
switch (type
) {
case 0:
case 1:
sprintf(filename
,"%s\\%s_%d_%s.dat",path
, fname
, hid
, datestr
);
fp
=fopen(filename
,"wb");
if (fp
) {
H1D_Write2File
(hid
,fp
);
fclose(fp
);
if (type
) {
sprintf(rootcmd
,"thisroot.bat && root.exe C:/home/cvi/apps/RedPitaya/soccli/H1Dload.cxx(\\\"%s_%d_%s.dat\\\")", fname
, hid
, datestr
);
LaunchExecutable
(rootcmd
);
}
printf("Histogram %d exported to %s \n%s\n", hid
, filename
, rootcmd
);
}
break;
case 2:
sprintf(filename
,"%s\\%s_%d_%s.txt",path
, fname
, hid
, datestr
);
fp
=fopen(filename
,"w");
if (fp
) {
for (int i
=0; i
<H1D_GetNbinsX
(hid
); i
++) fprintf(fp
,"%g\t%g\n", H1D_GetXBinCenter
(hid
,i
), H1D_GetBinContent
(hid
,i
) );
fclose(fp
);
printf("Histogram %d exported to %s\n", hid
, filename
);
}
break;
}
return (0);
}
int main
(int argc
, char *argv
[]) {
if (InitCVIRTE
(0, argv
, 0) == 0)
return -1; /* out of memory */
if ((panelHandle
= LoadPanel
(0, "redpitaya_gui.uir", PANEL
)) < 0)
return -1;
GetPanelHandleFromTabPage
(panelHandle
, PANEL_TAB
, 0, &settingsHandle
);
GetPanelHandleFromTabPage
(panelHandle
, PANEL_TAB
, 1, &outputHandle
);
GetPanelHandleFromTabPage
(panelHandle
, PANEL_TAB
, 2, &ch0Handle
);
GetPanelHandleFromTabPage
(panelHandle
, PANEL_TAB
, 3, &ch1Handle
);
SetStdioPort
(CVI_STDIO_WINDOW
);
SetSleepPolicy
(VAL_SLEEP_MORE
);
CmtNewThreadPool
(MAX_THREADS
, &poolHandle
);
//printf("size of double = %d\n",sizeof(double));
DisplayPanel
(panelHandle
);
RunUserInterface
();
DiscardPanel
(panelHandle
);
CmtDiscardThreadPool
(poolHandle
);
if (chandle
!=0) DisconnectFromTCPServer
(chandle
);
return 0;
}
char strbuf
[0xFF];
int gLog
=0;
int printf(const char *format
, ...
) {
va_list aptr
;
int ret
;
FILE
*flog
;
va_start(aptr
, format
);
ret
= vsprintf(strbuf
, format
, aptr
);
va_end(aptr
);
SetCtrlVal
(outputHandle
,OUTPUT_STDIO
,strbuf
);
if (gLog
) {
flog
= fopen ("stdio.log", "a");
fprintf (flog
, "%s", strbuf
);
fclose (flog
);
}
return(ret
);
}
int CVICALLBACK SetGraphLogYCB
(int panel
, int control
, int event
,
void *callbackData
, int eventData1
, int eventData2
) {
int cid
=0;
int logy
=0;
switch (event
) {
case EVENT_COMMIT
:
GetCtrlVal
(panel
,control
, &logy
);
if (panel
== ch0Handle
){
switch (control
) {
case CH0_LOGY_1
:
cid
= CH0_TDC1
;
break;
case CH0_LOGY_2
:
cid
= CH0_ADC1
;
break;
}
}
if (panel
== ch1Handle
){
switch (control
) {
case CH1_LOGY_3
:
cid
= CH1_TDC2
;
break;
case CH1_LOGY_4
:
cid
= CH1_ADC2
;
break;
}
}
if (logy
) SetCtrlAttribute
(panel
, cid
, ATTR_YMAP_MODE
, VAL_LOG
);
else SetCtrlAttribute
(panel
, cid
, ATTR_YMAP_MODE
, VAL_LINEAR
);
break;
}
return 0;
}
int CVICALLBACK SetGraphPropertiesCB
(int panel
, int control
, int event
,
void *callbackData
, int eventData1
, int eventData2
) {
float min
, max
;
int autoscale
;
switch (event
) {
case EVENT_COMMIT
:
GetCtrlVal
(panelHandle
,PANEL_MINX_5
, &min
);
GetCtrlVal
(panelHandle
,PANEL_MAXX_5
, &max
);
GetCtrlVal
(panelHandle
,PANEL_AUTOY
, &autoscale
);
if (autoscale
)
SetAxisScalingMode
(panelHandle
, PANEL_GRAPH
, VAL_LEFT_YAXIS
, VAL_AUTOSCALE
, min
, max
);
else
SetAxisScalingMode
(panelHandle
, PANEL_GRAPH
, VAL_LEFT_YAXIS
, VAL_MANUAL
, min
, max
);
GetCtrlVal
(panelHandle
,PANEL_MINX_6
, &min
);
GetCtrlVal
(panelHandle
,PANEL_MAXX_6
, &max
);
GetCtrlVal
(panelHandle
,PANEL_AUTOX
, &autoscale
);
if (autoscale
)
SetAxisScalingMode
(panelHandle
, PANEL_GRAPH
, VAL_BOTTOM_XAXIS
, VAL_AUTOSCALE
, min
, max
);
else
SetAxisScalingMode
(panelHandle
, PANEL_GRAPH
, VAL_BOTTOM_XAXIS
, VAL_MANUAL
, min
, max
);
GetCtrlVal
(ch0Handle
,CH0_MINX_7
, &min
);
GetCtrlVal
(ch0Handle
,CH0_MAXX_7
, &max
);
GetCtrlVal
(ch0Handle
,CH0_AUTOY_2
, &autoscale
);
if (autoscale
)
SetAxisScalingMode
(ch0Handle
, CH0_TDC1
, VAL_LEFT_YAXIS
, VAL_AUTOSCALE
, min
, max
);
else
SetAxisScalingMode
(ch0Handle
, CH0_TDC1
, VAL_LEFT_YAXIS
, VAL_MANUAL
, min
, max
);
GetCtrlVal
(ch0Handle
,CH0_MINX_8
, &min
);
GetCtrlVal
(ch0Handle
,CH0_MAXX_8
, &max
);
GetCtrlVal
(ch0Handle
,CH0_AUTOY_3
, &autoscale
);
if (autoscale
)
SetAxisScalingMode
(ch0Handle
, CH0_ADC1
, VAL_LEFT_YAXIS
, VAL_AUTOSCALE
, min
, max
);
else
SetAxisScalingMode
(ch0Handle
, CH0_ADC1
, VAL_LEFT_YAXIS
, VAL_MANUAL
, min
, max
);
GetCtrlVal
(ch1Handle
,CH1_MINX_9
, &min
);
GetCtrlVal
(ch1Handle
,CH1_MAXX_9
, &max
);
GetCtrlVal
(ch1Handle
,CH1_AUTOY_4
, &autoscale
);
if (autoscale
)
SetAxisScalingMode
(ch1Handle
, CH1_TDC2
, VAL_LEFT_YAXIS
, VAL_AUTOSCALE
, min
, max
);
else
SetAxisScalingMode
(ch1Handle
, CH1_TDC2
, VAL_LEFT_YAXIS
, VAL_MANUAL
, min
, max
);
GetCtrlVal
(ch1Handle
,CH1_MINX_10
, &min
);
GetCtrlVal
(ch1Handle
,CH1_MAXX_10
, &max
);
GetCtrlVal
(ch1Handle
,CH1_AUTOY_5
, &autoscale
);
if (autoscale
)
SetAxisScalingMode
(ch1Handle
, CH1_ADC2
, VAL_LEFT_YAXIS
, VAL_AUTOSCALE
, min
, max
);
else
SetAxisScalingMode
(ch1Handle
, CH1_ADC2
, VAL_LEFT_YAXIS
, VAL_MANUAL
, min
, max
);
break;
}
return 0;
}
int histoinit
() {
int nch
;
float min
,max
;
GetCtrlVal
(ch0Handle
,CH0_NCH_1
, &nch
);
GetCtrlVal
(ch0Handle
,CH0_MINX_1
, &min
);
GetCtrlVal
(ch0Handle
,CH0_MAXX_1
, &max
);
H1D_Init
(1, "ADC ch 1","Pulse height", nch
, min
, max
);
H1D_SetTitleX
(1,"ADC (V)");
H1D_SetTitleY
(1,"N");
GetCtrlVal
(ch1Handle
,CH1_NCH_2
, &nch
);
GetCtrlVal
(ch1Handle
,CH1_MINX_2
, &min
);
GetCtrlVal
(ch1Handle
,CH1_MAXX_2
, &max
);
H1D_Init
(2, "ADC ch 2","Pulse height", nch
, min
, max
);
H1D_SetTitleX
(2,"ADC (V)");
H1D_SetTitleY
(2,"N");
GetCtrlVal
(ch0Handle
,CH0_NCH_3
, &nch
);
GetCtrlVal
(ch0Handle
,CH0_MINX_3
, &min
);
GetCtrlVal
(ch0Handle
,CH0_MAXX_3
, &max
);
H1D_Init
(3, "TDC ch 1","TDC", nch
, min
, max
);
H1D_SetTitleX
(3,"TDC (us)");
H1D_SetTitleY
(3,"N");
GetCtrlVal
(ch1Handle
,CH1_NCH_4
, &nch
);
GetCtrlVal
(ch1Handle
,CH1_MINX_4
, &min
);
GetCtrlVal
(ch1Handle
,CH1_MAXX_4
, &max
);
H1D_Init
(4, "TDC ch 2","TDC", nch
, min
, max
);
H1D_SetTitleX
(4,"TDC (us)");
H1D_SetTitleY
(4,"N");
SetCtrlAttribute
(ch0Handle
, CH0_ADC1
, ATTR_XNAME
, H1D_GetTitleX
(1) );
SetCtrlAttribute
(ch0Handle
, CH0_ADC1
, ATTR_YNAME
, H1D_GetTitleY
(1) );
SetCtrlAttribute
(ch1Handle
, CH1_ADC2
, ATTR_XNAME
, H1D_GetTitleX
(2) );
SetCtrlAttribute
(ch1Handle
, CH1_ADC2
, ATTR_YNAME
, H1D_GetTitleY
(2) );
SetCtrlAttribute
(ch0Handle
, CH0_TDC1
, ATTR_XNAME
, H1D_GetTitleX
(3) );
SetCtrlAttribute
(ch0Handle
, CH0_TDC1
, ATTR_YNAME
, H1D_GetTitleY
(3) );
SetCtrlAttribute
(ch1Handle
, CH1_TDC2
, ATTR_XNAME
, H1D_GetTitleX
(4) );
SetCtrlAttribute
(ch1Handle
, CH1_TDC2
, ATTR_YNAME
, H1D_GetTitleY
(4) );
SetGraphLogYCB
( ch0Handle
, CH0_LOGY_1
, EVENT_COMMIT
,NULL
,0,0);
SetGraphLogYCB
( ch0Handle
, CH0_LOGY_2
, EVENT_COMMIT
,NULL
,0,0);
SetGraphLogYCB
( ch1Handle
, CH1_LOGY_3
, EVENT_COMMIT
,NULL
,0,0);
SetGraphLogYCB
( ch1Handle
, CH1_LOGY_4
, EVENT_COMMIT
,NULL
,0,0);
SetGraphPropertiesCB
( panelHandle
, PANEL
, EVENT_COMMIT
,NULL
,0,0);
SetCtrlAttribute
(panelHandle
, PANEL_GRAPH
, ATTR_LABEL_TEXT
, "sampling adc data");
SetCtrlAttribute
(panelHandle
, PANEL_GRAPH
, ATTR_XNAME
, "t(us)" );
SetCtrlAttribute
(panelHandle
, PANEL_GRAPH
, ATTR_YNAME
, "U(V)" );
GetCtrlVal
(settingsHandle
,SETTINGS_TWIN0
, &twin0
);
GetCtrlVal
(settingsHandle
,SETTINGS_TWIN1
, &twin1
);
GetCtrlVal
(panelHandle
,PANEL_ADCTYPE
, &adctype
);
GetCtrlVal
(settingsHandle
,SETTINGS_ITRGLEVEL
, &athreshold
);
return 0;
}
int analyse
(int nb
, unsigned char *cdata
, int *info
, int *ninfo
) {
int *ibuf
= (int *)cdata
;
float *fbuf
= (float *)cdata
;
float *finfo
= (float *)info
;
int neve
=0;
int *data
= (ibuf
+3);
int nr
=0;
static float adc
= 10000;
static float qdc
= 0;
*ninfo
= 0;
printf("Run HDR LEN=%d NEVE=%d dt=%f adc=%f qdc=%f\n", ibuf
[0],ibuf
[1],fbuf
[2],adc
,qdc
);
daqtime
+= fbuf
[2];
SetCtrlVal
(panelHandle
, PANEL_CDAQTIME
,daqtime
);
float ctime = Timer
() -starttime
;
SetCtrlVal
(panelHandle
, PANEL_CTIME
, ctime);
if (ctime
>0)SetCtrlVal
(panelHandle
, PANEL_DAQEFF
, daqtime
/ctime);
//daqtime =0;
while (nr
<nb
) {
int recid
= *data
++;
int chmask
= *data
++;
nr
+=8;
if (recid
!=0x2) continue;
for (int id
=0; id
<2; id
++) {
if ( !(chmask
& (1 << id
)) ) {
if (neve
% pfreq
== 0)
if (plothandle
[id
]) {
DeleteGraphPlot
(panelHandle
, PANEL_GRAPH
, plothandle
[id
], VAL_IMMEDIATE_DRAW
);
plothandle
[id
] = 0;
}
continue;
}
if ( id
!= *(data
++) ) printf("Error\n");
int nsamples
= *(data
++);
if (nsamples
<=0 || nsamples
>16*1024) {
printf("Error nsamples %d\n", nsamples
);
return -1;
}
float *fdata
= (float *) data
;
if ( nsamples
>0 && neve
% pfreq
== 0) {
const int col
[4]= {VAL_RED
,VAL_GREEN
,VAL_BLUE
,VAL_WHITE
};
if (plothandle
[id
]) DeleteGraphPlot
(panelHandle
, PANEL_GRAPH
, plothandle
[id
], VAL_IMMEDIATE_DRAW
);
plothandle
[id
] = PlotXY
(panelHandle
, PANEL_GRAPH
, timebins
, fdata
, nsamples
, VAL_FLOAT
, VAL_FLOAT
, VAL_FAT_LINE
, VAL_NO_POINT
, VAL_SOLID
, 1, col
[id
]);
H1D_Draw
(1, ch0Handle
,CH0_ADC1
,&adcplothandle
[0]);
H1D_Draw
(2, ch1Handle
,CH1_ADC2
,&adcplothandle
[1]);
H1D_Draw
(3, ch0Handle
,CH0_TDC1
,&tdcplothandle
[0]);
H1D_Draw
(4, ch1Handle
,CH1_TDC2
,&tdcplothandle
[1]);
if (debug
) for (int k
=0; k
<10; k
++) printf("%d %d (%f , %d)\n", id
,k
, timebins
[k
],data
[k
]);
}
nr
+=8;
adc
=10000;
qdc
=0;
int nqdc
=0;
int ntdc
=0;
for (int k
=1; k
<nsamples
; k
++) {
float t
=timebins
[k
];
float tp
=timebins
[k
-1];
if (fdata
[k
] < adc
) adc
= fdata
[k
];
if (t
>twin0
&& t
<twin1
) {
nqdc
++;
qdc
+=fdata
[k
];
}
if (fdata
[k
]< athreshold
&& fdata
[k
-1]> athreshold
) {
double t0
= tp
+(athreshold
-fdata
[k
-1])/(fdata
[k
]-fdata
[k
-1])* (t
-tp
);
if (ntdc
>0) H1D_Fill
(3+id
, t0
,1);
if (ntdc
==0 && !excludefirst
[id
]) H1D_Fill
(3+id
, t0
,1);
finfo
[*ninfo
+4+ntdc
]=t0
;
ntdc
++;
}
}
if (nqdc
) qdc
/=nqdc
;
//printf("adc %f qdc %f\n", adc,qdc);
info
[*ninfo
]=(ntdc
+4)*sizeof(int); // len
info
[*ninfo
+1]=id
| 0xF0000000; // recid
finfo
[*ninfo
+2]=adc
;
finfo
[*ninfo
+3]=qdc
;
*ninfo
+= ntdc
+4;
if (adctype
)
H1D_Fill
(1+id
, -adc
,1);
else
H1D_Fill
(1+id
, -qdc
,1);
nr
+=4*nsamples
;
data
+=nsamples
;
}
recid
= *data
++;
int event
= *data
++;
nr
+=8;
neve
++;
if (debug
) printf("recid %d event %d\n",recid
, event
);
}
return neve
;
}
const int maxlen
= 100000000;
unsigned char data
[maxlen
];
int *idata
= (int *) &data
[0];
int evinfo
[maxlen
];
int CVICALLBACK SocketCB
(unsigned handle
, int xType
, int errCode
, void *callbackData
) {
int nb
= 0 ;
static int event
= 0;
static int ncalls
= 0;
static time_t t0
, t1
;
time(&t0
);
switch (xType
) {
case TCP_DISCONNECT
:
printf("TCP_DISCONNECT ErrorString %s\n",GetTCPErrorString
(errCode
));
printf("TCP_DISCONNECT SystemErrorString %s\n",GetTCPSystemErrorString
());
chandle
= 0;
break;
case TCP_DATAREADY
: {
int hdr
[2]= {0,0};
nb
= ClientTCPRead
(handle
,&hdr
[0],8,1000);
int size
= hdr
[1] - 8;
if (size
>maxlen
) size
=maxlen
;
nb
= 0;
while (nb
< size
) {
int retval
= ClientTCPRead
(handle
,&data
[nb
],size
-nb
,1000);
if (retval
<1) break;
nb
+= retval
;
}
if (debug
) printf("Received RECID %d HDRLEN %d == read %d\n", hdr
[0], size
, nb
);
int ninfo
=0;
switch (hdr
[0]) {
case 0:
data
[nb
]=0;
printf("%s\n",data
);
break;
case 1:// read
GetCtrlVal
(panelHandle
,PANEL_CEVE
, &event
);
GetCtrlVal
(settingsHandle
,SETTINGS_NTOTAL
, &ncalls
);
event
+= analyse
(nb
,data
, evinfo
, &ninfo
);
if (foutput
) {
if (outwaveforms
) fwrite(data
, 1, nb
, foutput
);
fwrite(evinfo
, 1, ninfo
*sizeof(int), foutput
);
time(&t1
);
if ((t1
-t0
)>10000) {
for (int i
=0; i
<4; i
++) H1D_Write2File
(1+i
,foutput
);
time(&t0
);
}
}
SetCtrlVal
(panelHandle
,PANEL_CEVE
, event
);
if (event
>=ncalls
) StartCB
(panelHandle
, PANEL_START
, EVENT_COMMIT
, NULL
,1,0);
break;
default:
printf("Unknown command = %d\n", hdr
[0]);
break;
}
break;
}
}
return 0;
}
int rpdecimation
(int i
) {
switch (i
) {
case 1:
return 0;
case 8:
return 1;
case 64:
return 2;
case 1024:
return 3;
case 8192:
return 4;
case 65536:
return 5;
}
return 0;
}
int CVICALLBACK StartCB
(int panel
, int control
, int event
,
void *callbackData
, int eventData1
, int eventData2
) {
char ip
[0xFF];
char path
[0xFF];
int hdr
[0xFF];
char filename
[0xFF];
char filepath
[0xFF];
unsigned short *sbuff
= (unsigned short *)&hdr
[5] ;
unsigned char *cbuff
= (unsigned char *)&sbuff
[3] ;
int imask
[2];
unsigned char mask
;
unsigned char trigger
;
unsigned short nsamples
;
int delay
;
int nbefore
;
unsigned int decimation
;
unsigned short neve
;
int output
;
switch (event
) {
case EVENT_COMMIT
: {
GetCtrlVal
(settingsHandle
,SETTINGS_IP
, ip
);
GetCtrlVal
(settingsHandle
,SETTINGS_TRIGGER
, &trigger
);
GetCtrlVal
(settingsHandle
,SETTINGS_SAMPLES
, &nsamples
);
GetCtrlVal
(settingsHandle
,SETTINGS_DECIMATION
,&decimation
);
GetCtrlVal
(settingsHandle
,SETTINGS_NEVE
, &neve
);
GetCtrlVal
(settingsHandle
,SETTINGS_CH0
, &imask
[0] );
GetCtrlVal
(settingsHandle
,SETTINGS_CH1
, &imask
[1] );
GetCtrlVal
(settingsHandle
,SETTINGS_PFREQ
, &pfreq
);
GetCtrlVal
(settingsHandle
,SETTINGS_DEBUG
, &debug
);
GetCtrlVal
(settingsHandle
,SETTINGS_NBEFORE
, &nbefore
);
GetCtrlVal
(settingsHandle
,SETTINGS_ENABLEDOUTPUT
, &output
);
GetCtrlVal
(panel
,PANEL_OUTWAVE
, &outwaveforms
);
GetCtrlVal
(settingsHandle
,SETTINGS_FILENAME
, filename
);
sprintf(path
, "%s\\Desktop\\data", getenv("USERPROFILE"));
MakeDir
(path
);
sprintf(filepath
,"%s\\%s", path
, filename
);
delay
= MINTRGDELAY
+ nsamples
- nbefore
+ 1;
mask
= 0;
for (int i
=0; i
<2; i
++) {
if (imask
[i
]) mask
|= (1<<i
);
}
double level
=0;
GetCtrlVal
(settingsHandle
,SETTINGS_TRGLEVEL
, &level
);
switch (control
) {
case PANEL_CONNECT
: {
int state
;
GetCtrlVal
(panel
,PANEL_CONNECT
, &state
);
if (state
) {
ConnectToTCPServerEx
(&chandle
, 9930, ip
, SocketCB
, NULL
, 0, TCP_ANY_LOCAL_PORT
);
} else {
if (chandle
!=0) DisconnectFromTCPServer
(chandle
);
chandle
= 0;
}
}
break;
case PANEL_START
: {
int state
;
GetCtrlVal
(panel
,PANEL_START
, &state
);
GetCtrlVal
(ch0Handle
,CH0_EXCLUDE_1
, &excludefirst
[0]);
GetCtrlVal
(ch1Handle
,CH1_EXCLUDE_2
, &excludefirst
[1]);
if (state
&& eventData1
==0) {
histoinit
();
starttime
=Timer
();
daqtime
=0;
/* decimation n (=1,8,64...) : frequency = 125/n MHz*/
for (int i
=0; i
<nsamples
; i
++) timebins
[i
]=(i
-nbefore
)* (float)decimation
/125.
;
if (output
) foutput
= fopen(filepath
, "wb");
printf("decimation %d\n", decimation
);
SetCtrlVal
(panel
,PANEL_CEVE
, 0);
ctrl_c
=0;
hdr
[0] = 0;
hdr
[1] = 7*sizeof(int);
hdr
[2] = delay
;
hdr
[3] = rpdecimation
(decimation
);
hdr
[4] = level
* 1000;
sbuff
[0] = neve
;
sbuff
[1] = nsamples
;
sbuff
[2] = 1000; //tout
cbuff
[0] = trigger
;
cbuff
[1] = mask
;
ClientTCPWrite
(chandle
,&hdr
[0],hdr
[1],5000); // acquire
} else {
hdr
[0] = 1;
hdr
[1] = 2*sizeof(int);
ClientTCPWrite
(chandle
,&hdr
[0],hdr
[1],5000); // stop the transfer
printf("INFO Stopping the acquisition\n");
SetCtrlVal
(panel
,PANEL_START
, 0);
if (foutput
) fclose(foutput
);
foutput
=NULL
;
}
break;
}
default:
printf("Unknown command\n");
break;
}
ProcessSystemEvents
();
break;
}
}
return 0;
}
int CVICALLBACK ExitCB
(int panel
, int control
, int event
,
void *callbackData
, int eventData1
, int eventData2
) {
switch (event
) {
case EVENT_COMMIT
:
QuitUserInterface
(0);
break;
}
return 0;
}
int CVICALLBACK ExportCB
(int panel
, int control
, int event
,
void *callbackData
, int eventData1
, int eventData2
) {
int hid
=0;
switch (event
) {
case EVENT_COMMIT
:
if (panel
== ch0Handle
){
switch (control
) {
case CH0_EXPORT_1
:
hid
=1;
break;
case CH0_EXPORT_3
:
hid
=3;
break;
}
}
if (panel
== ch1Handle
){
switch (control
) {
case CH1_EXPORT_2
:
hid
=2;
break;
case CH1_EXPORT_4
:
hid
=4;
break;
}
}
export_data
(hid
);
break;
}
return 0;
}
int CVICALLBACK ResetCB
(int panel
, int control
, int event
,
void *callbackData
, int eventData1
, int eventData2
) {
switch (event
) {
case EVENT_COMMIT
:
for (int i
=1; i
<=4; i
++) H1D_Clear
(i
);
break;
}
return 0;
}