2022-08-09 16:02:45 -04:00
# include "ClassDigitizer.h"
2022-08-04 17:27:33 -04:00
Digitizer : : Digitizer ( ) {
2022-09-26 16:47:20 -04:00
Initalization ( ) ;
}
Digitizer : : Digitizer ( int boardID , int portID , bool program , bool verbose ) {
Initalization ( ) ;
OpenDigitizer ( boardID , portID , program , verbose ) ;
}
2022-08-04 17:27:33 -04:00
2022-09-26 16:47:20 -04:00
Digitizer : : ~ Digitizer ( ) {
CloseDigitizer ( ) ;
2022-11-01 18:38:01 -04:00
delete data ;
2022-09-26 16:47:20 -04:00
}
void Digitizer : : Initalization ( ) {
2022-10-26 13:23:21 -04:00
data = new Data ( ) ;
2022-09-26 16:47:20 -04:00
2022-08-04 17:27:33 -04:00
portID = - 1 ;
boardID = - 1 ;
handle = - 1 ;
2022-10-14 18:27:31 -04:00
NChannel = 16 ;
2022-08-04 17:27:33 -04:00
ADCbits = 1 ;
DPPType = 0 ;
ADCFullSize = 0 ;
ch2ns = 0 ;
BoardInfo = { } ;
2022-10-26 13:23:21 -04:00
channelMask = 0xFFFF ;
2022-08-04 17:27:33 -04:00
VMEBaseAddress = 0 ;
LinkType = CAEN_DGTZ_USB ; /// default USB
IOlev = CAEN_DGTZ_IOLevel_NIM ; ///default NIM
2022-10-05 17:54:10 -04:00
isSettingFilledinMemeory = false ;
2022-08-09 16:02:45 -04:00
settingFileName = " " ;
settingFileExist = false ;
settingFile = NULL ;
2022-08-04 17:27:33 -04:00
ret = - 1 ;
isConnected = false ;
2022-08-10 18:35:13 -04:00
AcqRun = false ;
2022-10-26 13:23:21 -04:00
isDummy = true ;
2022-08-04 17:27:33 -04:00
}
void Digitizer : : Reset ( ) {
ret = CAEN_DGTZ_Reset ( handle ) ;
2022-09-28 15:09:27 -04:00
if ( ret ! = 0 ) ErrorMsg ( __func__ ) ;
2022-10-04 16:54:01 -04:00
ret | = CAEN_DGTZ_WriteRegister ( handle , Register : : DPP : : SoftwareClear_W , 1 ) ;
if ( ret ! = 0 ) ErrorMsg ( " Reset-SoftwareClear_W " ) ;
2022-09-28 15:09:27 -04:00
2022-08-04 17:27:33 -04:00
}
2022-10-14 18:27:31 -04:00
void Digitizer : : PrintBoard ( ) {
2022-09-16 17:53:57 -04:00
printf ( " Connected to Model %s with handle %d using %s \n " , BoardInfo . ModelName , handle , LinkType = = CAEN_DGTZ_USB ? " USB " : " Optical Link " ) ;
printf ( " Sampling rate : %.0f MHz = %.1f ns \n " , 1000 / ch2ns , ch2ns ) ;
printf ( " Number of Channels : %d = 0x%X \n " , NChannel , channelMask ) ;
printf ( " SerialNumber : \ e[1m \ e[33m %d \ e[0m \n " , BoardInfo . SerialNumber ) ;
2022-10-17 14:42:00 -04:00
printf ( " DPPType : %d (%s) \n " , DPPType , GetDPPString ( ) . c_str ( ) ) ;
2022-10-05 17:54:10 -04:00
printf ( " ADC bit is \ e[33m%d \ e[0m, %d = 0x%X \n " , ADCbits , ADCFullSize , ADCFullSize ) ;
2022-09-16 17:53:57 -04:00
printf ( " ROC FPGA Release is %s \n " , BoardInfo . ROC_FirmwareRel ) ;
printf ( " AMC FPGA Release is %s \n " , BoardInfo . AMC_FirmwareRel ) ;
}
int Digitizer : : OpenDigitizer ( int boardID , int portID , bool program , bool verbose ) {
2022-08-04 17:27:33 -04:00
this - > boardID = boardID ;
this - > portID = portID ;
2022-10-07 16:15:58 -04:00
if ( boardID < 0 | | portID < 0 ) return 0 ; /// for using the Digitizer Class without open digitizer
2022-08-04 17:27:33 -04:00
/***************************************************/
/** Open the digitizer and read board information */
/***************************************************/
2022-08-04 18:02:03 -04:00
if ( verbose ) printf ( " ============= Opening Digitizer at Board %d, Port %d \n " , boardID , portID ) ;
2022-08-04 17:27:33 -04:00
///-------- try USB first
LinkType = CAEN_DGTZ_USB ; /// Link Type
ret = ( int ) CAEN_DGTZ_OpenDigitizer ( LinkType , boardID , 0 , VMEBaseAddress , & handle ) ;
if ( ret ! = 0 ) { ///---------- try Optical link
LinkType = CAEN_DGTZ_OpticalLink ;
ret = ( int ) CAEN_DGTZ_OpenDigitizer ( LinkType , portID , boardID , VMEBaseAddress , & handle ) ;
}
2022-10-24 14:40:16 -04:00
ErrorMsg ( " === Open Digitizer port " + std : : to_string ( portID ) + " board " + std : : to_string ( boardID ) ) ;
2022-08-04 17:27:33 -04:00
if ( ret ! = 0 ) {
2022-08-04 18:02:03 -04:00
if ( verbose ) printf ( " Can't open digitizer \n " ) ;
2022-08-05 16:32:46 -04:00
return - 1 ;
2022-08-04 17:27:33 -04:00
} else {
///----- Getting Board Info
ret = ( int ) CAEN_DGTZ_GetInfo ( handle , & BoardInfo ) ;
if ( ret ! = 0 ) {
2022-08-04 18:02:03 -04:00
if ( verbose ) printf ( " Can't read board info \n " ) ;
2022-08-04 17:27:33 -04:00
} else {
isConnected = true ;
NChannel = BoardInfo . Channels ;
channelMask = pow ( 2 , NChannel ) - 1 ;
switch ( BoardInfo . Model ) {
case CAEN_DGTZ_V1730 : ch2ns = 2.0 ; break ; ///ns -> 500 MSamples/s
case CAEN_DGTZ_V1725 : ch2ns = 4.0 ; break ; ///ns -> 250 MSamples/s
2022-10-20 18:56:11 -04:00
default : ch2ns = 4.0 ; break ;
2022-08-04 18:02:03 -04:00
}
2022-09-29 15:26:40 -04:00
data - > ch2ns = ch2ns ;
2022-10-20 13:51:06 -04:00
data - > boardSN = BoardInfo . SerialNumber ;
2022-08-04 17:27:33 -04:00
ADCbits = BoardInfo . ADC_NBits ;
ADCFullSize = ( unsigned int ) ( pow ( 2 , ADCbits ) - 1 ) ;
}
}
2022-08-10 18:35:13 -04:00
///====================== Check DPP firmware revision
2022-08-04 17:27:33 -04:00
sscanf ( BoardInfo . AMC_FirmwareRel , " %d " , & DPPType ) ;
2022-09-29 15:26:40 -04:00
data - > DPPType = DPPType ;
2022-10-20 18:56:11 -04:00
/// change address 0xEF08 (5 bits), this will reflected in the 2nd word of the Board Agg. header.
ret = CAEN_DGTZ_WriteRegister ( handle , Register : : DPP : : BoardID , ( DPPType & 0xF ) ) ;
2022-10-05 17:54:10 -04:00
if ( verbose ) {
PrintBoard ( ) ;
if ( DPPType < 0x80 ) {
printf ( " This digitizer does not have DPP-PHA firmware \n " ) ;
} else {
printf ( " \t ==== This digitizer has a DPP firmware! \n " ) ;
2022-10-17 14:42:00 -04:00
printf ( " \ e[32m \t %s \ e[0m " , GetDPPString ( ) . c_str ( ) ) ;
2022-10-05 17:54:10 -04:00
}
2022-08-04 17:27:33 -04:00
}
2022-10-20 18:56:11 -04:00
ErrorMsg ( " ========== Set BoardID " ) ;
2022-08-10 18:35:13 -04:00
///======================= Check virtual probe
2022-08-04 17:27:33 -04:00
int probes [ MAX_SUPPORTED_PROBES ] ;
int numProbes ;
ret = CAEN_DGTZ_GetDPP_SupportedVirtualProbes ( handle , 1 , probes , & numProbes ) ;
2022-10-20 18:56:11 -04:00
ErrorMsg ( " === Get Supported Virtual Probes " ) ;
2022-08-04 18:02:03 -04:00
if ( verbose ) {
printf ( " \t ==== supported virtual probe (number of Probe : %d) \n " , numProbes ) ;
for ( int i = 0 ; i < numProbes ; i + + ) {
switch ( probes [ i ] ) {
case 0 : printf ( " \t \t CAEN_DGTZ_DPP_VIRTUALPROBE_Input \n " ) ; break ;
case 1 : printf ( " \t \t CAEN_DGTZ_DPP_VIRTUALPROBE_Delta \n " ) ; break ;
case 2 : printf ( " \t \t CAEN_DGTZ_DPP_VIRTUALPROBE_Delta2 \n " ) ; break ;
case 3 : printf ( " \t \t CAEN_DGTZ_DPP_VIRTUALPROBE_Trapezoid \n " ) ; break ;
case 4 : printf ( " \t \t CAEN_DGTZ_DPP_VIRTUALPROBE_TrapezoidReduced \n " ) ; break ;
case 5 : printf ( " \t \t CAEN_DGTZ_DPP_VIRTUALPROBE_Baseline \n " ) ; break ;
case 6 : printf ( " \t \t CAEN_DGTZ_DPP_VIRTUALPROBE_Threshold \n " ) ; break ;
case 7 : printf ( " \t \t CAEN_DGTZ_DPP_VIRTUALPROBE_CFD \n " ) ; break ;
case 8 : printf ( " \t \t CAEN_DGTZ_DPP_VIRTUALPROBE_SmoothedInput \n " ) ; break ;
case 9 : printf ( " \t \t CAEN_DGTZ_DPP_VIRTUALPROBE_None \n " ) ; break ;
case 10 : printf ( " \t \t CAEN_DGTZ_DPP_DIGITALPROBE_TRGWin \n " ) ; break ;
case 11 : printf ( " \t \t CAEN_DGTZ_DPP_DIGITALPROBE_Armed \n " ) ; break ;
case 12 : printf ( " \t \t CAEN_DGTZ_DPP_DIGITALPROBE_PkRun \n " ) ; break ;
case 13 : printf ( " \t \t CAEN_DGTZ_DPP_DIGITALPROBE_Peaking \n " ) ; break ;
case 14 : printf ( " \t \t CAEN_DGTZ_DPP_DIGITALPROBE_CoincWin \n " ) ; break ;
case 15 : printf ( " \t \t CAEN_DGTZ_DPP_DIGITALPROBE_BLHoldoff \n " ) ; break ;
case 16 : printf ( " \t \t CAEN_DGTZ_DPP_DIGITALPROBE_TRGHoldoff \n " ) ; break ;
case 17 : printf ( " \t \t CAEN_DGTZ_DPP_DIGITALPROBE_TRGVal \n " ) ; break ;
case 18 : printf ( " \t \t CAEN_DGTZ_DPP_DIGITALPROBE_ACQVeto \n " ) ; break ;
case 19 : printf ( " \t \t CAEN_DGTZ_DPP_DIGITALPROBE_BFMVeto \n " ) ; break ;
case 20 : printf ( " \t \t CAEN_DGTZ_DPP_DIGITALPROBE_ExtTRG \n " ) ; break ;
case 21 : printf ( " \t \t CAEN_DGTZ_DPP_DIGITALPROBE_OverThr \n " ) ; break ;
case 22 : printf ( " \t \t CAEN_DGTZ_DPP_DIGITALPROBE_TRGOut \n " ) ; break ;
case 23 : printf ( " \t \t CAEN_DGTZ_DPP_DIGITALPROBE_Coincidence \n " ) ; break ;
case 24 : printf ( " \t \t CAEN_DGTZ_DPP_DIGITALPROBE_PileUp \n " ) ; break ;
case 25 : printf ( " \t \t CAEN_DGTZ_DPP_DIGITALPROBE_Gate \n " ) ; break ;
case 26 : printf ( " \t \t CAEN_DGTZ_DPP_DIGITALPROBE_GateShort \n " ) ; break ;
case 27 : printf ( " \t \t CAEN_DGTZ_DPP_DIGITALPROBE_Trigger \n " ) ; break ;
case 28 : printf ( " \t \t CAEN_DGTZ_DPP_DIGITALPROBE_None \n " ) ; break ;
case 29 : printf ( " \t \t CAEN_DGTZ_DPP_DIGITALPROBE_BLFreeze \n " ) ; break ;
case 30 : printf ( " \t \t CAEN_DGTZ_DPP_DIGITALPROBE_Busy \n " ) ; break ;
case 31 : printf ( " \t \t CAEN_DGTZ_DPP_DIGITALPROBE_PrgVeto \n " ) ; break ;
}
}
2022-08-04 17:27:33 -04:00
}
ErrorMsg ( " end of OpenDigitizer " ) ;
2022-10-24 14:40:16 -04:00
if ( isConnected ) isDummy = false ;
2022-09-16 17:53:57 -04:00
if ( isConnected & & program ) {
2022-08-04 17:27:33 -04:00
ProgramBoard ( ) ;
}
2022-10-13 18:06:07 -04:00
if ( isConnected ) ReadAllSettingsFromBoard ( ) ;
2022-10-06 13:06:11 -04:00
2022-08-04 17:27:33 -04:00
return ret ;
}
int Digitizer : : CloseDigitizer ( ) {
2022-08-06 01:38:01 -04:00
if ( ! isConnected ) return 0 ;
2022-08-04 18:02:03 -04:00
isConnected = false ;
2022-08-04 17:27:33 -04:00
printf ( " -------- Closing Digtizer Board : %d Port : %d \n " , boardID , portID ) ;
printf ( " Model %s with handle %d using %s \n " , BoardInfo . ModelName , handle , LinkType = = CAEN_DGTZ_USB ? " USB " : " Optical Link " ) ;
ret = CAEN_DGTZ_SWStopAcquisition ( handle ) ;
ret | = CAEN_DGTZ_CloseDigitizer ( handle ) ;
return ret ;
}
2022-10-13 18:37:13 -04:00
void Digitizer : : SetChannelMask ( uint32_t mask ) {
if ( ! isConnected ) return ;
channelMask = mask ;
ret | = CAEN_DGTZ_SetChannelEnableMask ( handle , channelMask ) ;
SaveSettingToFile ( Register : : DPP : : ChannelEnableMask , mask ) ;
2022-11-01 18:38:01 -04:00
SetSettingToMemory ( Register : : DPP : : ChannelEnableMask , mask ) ;
2022-10-13 18:37:13 -04:00
ErrorMsg ( __func__ ) ;
2022-08-04 17:27:33 -04:00
}
2022-11-01 18:38:01 -04:00
void Digitizer : : SetChannelOnOff ( unsigned short ch , bool onOff ) {
if ( ! isConnected ) return ;
channelMask = ( ( channelMask & ~ ( 1 < < ch ) ) | ( onOff < < ch ) ) ;
SetChannelMask ( channelMask ) ;
}
2022-10-13 18:37:13 -04:00
2022-08-04 17:27:33 -04:00
int Digitizer : : ProgramBoard ( ) {
2022-08-23 13:43:05 -04:00
2022-08-12 18:13:54 -04:00
printf ( " ----- program Board \n " ) ;
2022-08-04 17:27:33 -04:00
ret = CAEN_DGTZ_Reset ( handle ) ;
if ( ret ) {
printf ( " ERROR: can't reset the digitizer. \n " ) ;
return - 1 ;
}
/// Board Configuration without PHA or PSD fireware
///bx0000 0000 0000 0000 0000 0000 0001 0000 =
/// | | +- (1) trigger overlap not allowed
/// | +- (3) test pattern disable
/// + (6) Self-trigger polarity, 1 = negative, 0 = Positive
ret = CAEN_DGTZ_WriteRegister ( handle , ( uint32_t ) Register : : BoardConfiguration , 0x000E0114 ) ; /// Channel Control Reg (indiv trg, seq readout) ??
/// Set the I/O level (CAEN_DGTZ_IOLevel_NIM or CAEN_DGTZ_IOLevel_TTL)
ret | = CAEN_DGTZ_SetIOLevel ( handle , IOlev ) ;
/// Set the enabled channels
ret | = CAEN_DGTZ_SetChannelEnableMask ( handle , channelMask ) ;
/// Set the number of samples for each waveform
2022-10-13 18:37:13 -04:00
ret | = CAEN_DGTZ_SetRecordLength ( handle , 2000 ) ;
2022-08-04 17:27:33 -04:00
/// Set Extras 2 to enable, this override Accusition mode, focring list mode
2022-08-05 16:32:46 -04:00
ret | = CAEN_DGTZ_WriteRegister ( handle , Register : : BoardConfiguration , 0x00E8114 ) ;
2022-09-27 17:58:14 -04:00
2022-08-04 17:27:33 -04:00
/// Set the digitizer acquisition mode (CAEN_DGTZ_SW_CONTROLLED or CAEN_DGTZ_S_IN_CONTROLLED)
ret | = CAEN_DGTZ_SetAcquisitionMode ( handle , CAEN_DGTZ_SW_CONTROLLED ) ; /// software command
2022-10-26 13:23:21 -04:00
CAEN_DGTZ_DPP_AcqMode_t AcqMode = CAEN_DGTZ_DPP_ACQ_MODE_List ;
2022-08-04 17:27:33 -04:00
ret | = CAEN_DGTZ_SetDPPAcquisitionMode ( handle , AcqMode , CAEN_DGTZ_DPP_SAVE_PARAM_EnergyAndTime ) ;
/** Set the digitizer's behaviour when an external trigger arrives:
CAEN_DGTZ_TRGMODE_DISABLED : do nothing
CAEN_DGTZ_TRGMODE_EXTOUT_ONLY : generate the Trigger Output signal
CAEN_DGTZ_TRGMODE_ACQ_ONLY = generate acquisition trigger
CAEN_DGTZ_TRGMODE_ACQ_AND_EXTOUT = generate both Trigger Output and acquisition trigger
see CAENDigitizer user manual , chapter " Trigger configuration " for details */
2022-08-23 13:43:05 -04:00
//TODO set bit
2022-08-04 17:27:33 -04:00
ret | = CAEN_DGTZ_SetExtTriggerInputMode ( handle , CAEN_DGTZ_TRGMODE_ACQ_ONLY ) ;
2022-08-17 16:08:49 -04:00
ret | = CAEN_DGTZ_SetRunSynchronizationMode ( handle , CAEN_DGTZ_RUN_SYNC_Disabled ) ;
2022-08-04 17:27:33 -04:00
2022-09-27 17:58:14 -04:00
/// Set how many events to accumulate in the board memory before being available for readout
ret | = CAEN_DGTZ_WriteRegister ( handle , Register : : DPP : : NumberEventsPerAggregate_G + 0x7000 , 100 ) ;
ret | = CAEN_DGTZ_WriteRegister ( handle , Register : : DPP : : AggregateOrganization , 0 ) ;
ret | = CAEN_DGTZ_WriteRegister ( handle , Register : : DPP : : MaxAggregatePerBlockTransfer , 50 ) ;
2022-09-23 16:40:59 -04:00
ErrorMsg ( __func__ ) ;
2022-08-04 17:27:33 -04:00
return ret ;
}
2022-10-13 18:37:13 -04:00
int Digitizer : : ProgramPHABoard ( ) {
ret = CAEN_DGTZ_Reset ( handle ) ;
printf ( " ======== program board PHA \n " ) ;
2022-11-01 18:38:01 -04:00
ret = CAEN_DGTZ_WriteRegister ( handle , Register : : DPP : : RecordLength_G + 0x7000 , 62 ) ;
ret = CAEN_DGTZ_WriteRegister ( handle , Register : : DPP : : BoardConfiguration , 0x0F8915 ) ; /// has Extra2
2022-10-20 13:51:06 -04:00
///ret = CAEN_DGTZ_WriteRegister(handle, Register::DPP::BoardConfiguration, 0x0D8115); /// diable Extra2
2022-10-13 18:37:13 -04:00
//TODO change to write register
ret = CAEN_DGTZ_SetAcquisitionMode ( handle , CAEN_DGTZ_SW_CONTROLLED ) ; /// software command
ret | = CAEN_DGTZ_SetIOLevel ( handle , CAEN_DGTZ_IOLevel_NIM ) ;
ret | = CAEN_DGTZ_SetExtTriggerInputMode ( handle , CAEN_DGTZ_TRGMODE_ACQ_ONLY ) ;
ret = CAEN_DGTZ_SetChannelEnableMask ( handle , 0xFFFF ) ;
//ret = CAEN_DGTZ_SetNumEventsPerAggregate(handle, 0);
ret = CAEN_DGTZ_SetRunSynchronizationMode ( handle , CAEN_DGTZ_RUN_SYNC_Disabled ) ;
if ( ret ! = 0 ) { printf ( " ==== set board error. \n " ) ; return 0 ; }
printf ( " ======== program Channels PHA \n " ) ;
uint32_t address ;
address = Register : : DPP : : PHA : : DecayTime ; ret | = CAEN_DGTZ_WriteRegister ( handle , address + 0x7000 , 5000 ) ;
2022-11-01 18:38:01 -04:00
address = Register : : DPP : : PHA : : TrapezoidFlatTop ; ret | = CAEN_DGTZ_WriteRegister ( handle , address + 0x7000 , 0x1A ) ;
2022-10-13 18:37:13 -04:00
address = Register : : DPP : : PHA : : TrapezoidRiseTime ; ret | = CAEN_DGTZ_WriteRegister ( handle , address + 0x7000 , 6 ) ;
address = Register : : DPP : : PHA : : PeakingTime ; ret | = CAEN_DGTZ_WriteRegister ( handle , address + 0x7000 , 6 ) ;
address = Register : : DPP : : PHA : : RCCR2SmoothingFactor ; ret | = CAEN_DGTZ_WriteRegister ( handle , address + 0x7000 , 4 ) ;
address = Register : : DPP : : PHA : : InputRiseTime ; ret | = CAEN_DGTZ_WriteRegister ( handle , address + 0x7000 , 6 ) ;
address = Register : : DPP : : PHA : : TriggerThreshold ; ret | = CAEN_DGTZ_WriteRegister ( handle , address + 0x7000 , 1000 ) ;
address = Register : : DPP : : PHA : : PeakHoldOff ; ret | = CAEN_DGTZ_WriteRegister ( handle , address + 0x7000 , 0x3E ) ;
address = Register : : DPP : : PHA : : TriggerHoldOffWidth ; ret | = CAEN_DGTZ_WriteRegister ( handle , address + 0x7000 , 0x3E ) ;
address = Register : : DPP : : PHA : : RiseTimeValidationWindow ; ret | = CAEN_DGTZ_WriteRegister ( handle , address + 0x7000 , 0x0 ) ;
ret | = CAEN_DGTZ_WriteRegister ( handle , ( uint32_t ) ( Register : : DPP : : ChannelDCOffset ) + 0x7000 , 0xEEEE ) ;
2022-11-01 18:38:01 -04:00
ret | = CAEN_DGTZ_WriteRegister ( handle , ( uint32_t ) ( Register : : DPP : : PreTrigger ) + 0x7000 , 32 ) ;
2022-10-13 18:37:13 -04:00
ret | = CAEN_DGTZ_WriteRegister ( handle , ( uint32_t ) ( Register : : DPP : : InputDynamicRange ) + 0x7000 , 0x0 ) ;
2022-10-25 14:52:57 -04:00
ret | = CAEN_DGTZ_WriteRegister ( handle , ( int32_t ) ( Register : : DPP : : NumberEventsPerAggregate_G ) + 0x7000 , 511 ) ;
2022-11-02 15:43:23 -04:00
ret | = CAEN_DGTZ_WriteRegister ( handle , ( int32_t ) ( Register : : DPP : : AggregateOrganization ) , 2 ) ;
2022-10-25 14:52:57 -04:00
ret | = CAEN_DGTZ_WriteRegister ( handle , ( int32_t ) ( Register : : DPP : : MaxAggregatePerBlockTransfer ) , 4 ) ;
2022-11-01 18:38:01 -04:00
ret | = CAEN_DGTZ_WriteRegister ( handle , ( int32_t ) ( Register : : DPP : : DPPAlgorithmControl ) + 0x7000 , 0xC30200f ) ;
2022-10-13 18:37:13 -04:00
if ( ret ! = 0 ) { printf ( " ==== set channels error. \n " ) ; return 0 ; }
printf ( " End of program board and channels \n " ) ;
isSettingFilledinMemeory = false ; /// unlock the ReadAllSettingsFromBoard();
ReadAllSettingsFromBoard ( ) ;
return ret ;
}
2022-08-10 18:35:13 -04:00
//========================================================= ACQ control
void Digitizer : : StartACQ ( ) {
if ( AcqRun ) return ;
2022-10-20 13:51:06 -04:00
2022-10-25 14:52:57 -04:00
unsigned int bufferSize = CalByteForBuffer ( ) ;
if ( bufferSize > 80 * 1024 * 1024 ) {
printf ( " ============= buffer size bigger than 80 MB " ) ;
return ;
}
data - > AllocateMemory ( bufferSize ) ;
2022-08-10 18:35:13 -04:00
ret = CAEN_DGTZ_SWStartAcquisition ( handle ) ;
2022-10-20 13:51:06 -04:00
2022-08-10 18:35:13 -04:00
if ( ret ! = 0 ) {
ErrorMsg ( " Start ACQ " ) ;
return ;
}
2022-10-20 13:51:06 -04:00
2022-08-12 18:13:54 -04:00
printf ( " \ e[1m \ e[33m======= Acquisition Started for Board %d \ e[0m \n " , boardID ) ;
2022-08-10 18:35:13 -04:00
AcqRun = true ;
2022-11-02 19:01:06 -04:00
data - > ClearTriggerRate ( ) ;
2022-08-10 18:35:13 -04:00
}
void Digitizer : : StopACQ ( ) {
if ( ! AcqRun ) return ;
int ret = CAEN_DGTZ_SWStopAcquisition ( handle ) ;
ret | = CAEN_DGTZ_ClearData ( handle ) ;
if ( ret ! = 0 ) ErrorMsg ( " something wrong when try to stop ACQ and clear buffer " ) ;
printf ( " \n \ e[1m \ e[33m====== Acquisition STOPPED for Board %d \ e[0m \n " , boardID ) ;
AcqRun = false ;
2022-11-02 19:01:06 -04:00
data - > ClearTriggerRate ( ) ;
2022-08-10 18:35:13 -04:00
}
2022-08-15 18:54:55 -04:00
unsigned int Digitizer : : CalByteForBuffer ( ) {
2022-10-14 18:27:31 -04:00
unsigned int numAggBLT ;
unsigned int chMask ;
unsigned int boardCfg ;
unsigned int eventAgg [ NChannel / 2 ] ;
unsigned int recordLength [ NChannel / 2 ] ;
2022-10-25 14:52:57 -04:00
unsigned int aggOrgan ;
2022-10-14 18:27:31 -04:00
if ( isConnected ) {
numAggBLT = ReadRegister ( Register : : DPP : : MaxAggregatePerBlockTransfer , 0 , false ) ;
chMask = ReadRegister ( Register : : DPP : : ChannelEnableMask , 0 , false ) ;
boardCfg = ReadRegister ( Register : : DPP : : BoardConfiguration , 0 , false ) ;
2022-10-25 14:52:57 -04:00
aggOrgan = ReadRegister ( Register : : DPP : : AggregateOrganization , 0 , false ) ;
2022-10-14 18:27:31 -04:00
for ( int pCh = 0 ; pCh < NChannel / 2 ; pCh + + ) {
eventAgg [ pCh ] = ReadRegister ( Register : : DPP : : NumberEventsPerAggregate_G , pCh * 2 , false ) ;
recordLength [ pCh ] = ReadRegister ( Register : : DPP : : RecordLength_G , pCh * 2 , false ) ;
}
} else {
numAggBLT = GetSettingFromMemory ( Register : : DPP : : MaxAggregatePerBlockTransfer ) ;
chMask = GetSettingFromMemory ( Register : : DPP : : ChannelEnableMask ) ;
boardCfg = GetSettingFromMemory ( Register : : DPP : : BoardConfiguration ) ;
2022-10-25 14:52:57 -04:00
aggOrgan = GetSettingFromMemory ( Register : : DPP : : AggregateOrganization ) ;
2022-10-14 18:27:31 -04:00
for ( int pCh = 0 ; pCh < NChannel / 2 ; pCh + + ) {
eventAgg [ pCh ] = GetSettingFromMemory ( Register : : DPP : : NumberEventsPerAggregate_G , pCh * 2 ) ;
recordLength [ pCh ] = GetSettingFromMemory ( Register : : DPP : : RecordLength_G , pCh * 2 ) ;
}
}
2022-08-15 18:54:55 -04:00
2022-10-31 15:00:04 -04:00
///printf(" agg. orgainzation (bit) : 0x%X \n", aggOrgan);
///printf(" Channel Mask : %04X \n", chMask);
///printf("Max number of Agg per Readout : %u \n", numAggBLT);
///printf(" is Extra2 enabed : %u \n", ((boardCfg >> 17) & 0x1) );
///printf(" is Record wave : %u \n", ((boardCfg >> 16) & 0x1) );
///for( int pCh = 0; pCh < NChannel/2; pCh++){
/// printf("Paired Ch : %d, RecordLength (bit value): %u, Event per Agg. : %u \n", pCh, recordLength[pCh], eventAgg[pCh]);
///}
2022-10-24 14:40:16 -04:00
unsigned int bufferSize = 0 ;
2022-10-14 18:27:31 -04:00
for ( int pCh = 0 ; pCh < NChannel / 2 ; pCh + + ) {
if ( ( chMask & ( 3 < < ( 2 * pCh ) ) ) = = 0 ) continue ;
2022-10-25 14:52:57 -04:00
bufferSize + = 2 + ( 2 + ( ( boardCfg > > 17 ) & 0x1 ) + ( ( boardCfg > > 16 ) & 0x1 ) * recordLength [ pCh ] * 4 ) * eventAgg [ pCh ] ;
2022-10-14 18:27:31 -04:00
}
2022-10-24 14:40:16 -04:00
bufferSize + = 4 ; /// Bd. Agg Header
bufferSize = bufferSize * numAggBLT * 4 ; /// 1 words = 4 byte
2022-10-20 13:51:06 -04:00
2022-10-31 15:00:04 -04:00
///printf("=============== Buffer Size : %8d Byte \n", bufferSize );
2022-10-24 14:40:16 -04:00
return bufferSize ;
2022-08-15 18:54:55 -04:00
}
2022-08-10 18:35:13 -04:00
void Digitizer : : ReadData ( ) {
2022-08-23 13:43:05 -04:00
if ( ! isConnected ) return ;
2022-10-25 14:52:57 -04:00
if ( ! AcqRun ) return ;
2022-08-17 16:08:49 -04:00
if ( data - > buffer = = NULL ) {
printf ( " need allocate memory for readout buffer \n " ) ;
2022-08-10 18:35:13 -04:00
return ;
}
2022-08-18 17:34:28 -04:00
ret = CAEN_DGTZ_ReadData ( handle , CAEN_DGTZ_SLAVE_TERMINATED_READOUT_MBLT , data - > buffer , & ( data - > nByte ) ) ;
2022-09-29 15:26:40 -04:00
//uint32_t EventSize = ReadRegister(Register::DPP::EventSize); // Is it as same as data->nByte?
//printf("Read Buffer size %d byte, Event Size : %d byte \n", data->nByte, EventSize);
2022-09-16 17:53:57 -04:00
2022-08-18 17:34:28 -04:00
if ( ret | | data - > nByte = = 0 ) {
2022-09-23 16:40:59 -04:00
ErrorMsg ( __func__ ) ;
2022-08-18 17:34:28 -04:00
return ;
}
2022-10-20 13:51:06 -04:00
}
void Digitizer : : PrintACQStatue ( ) {
if ( ! isConnected ) return ;
unsigned int status = ReadRegister ( Register : : DPP : : AcquisitionStatus_R ) ;
2022-08-17 16:08:49 -04:00
2022-10-20 13:51:06 -04:00
printf ( " =================== Print ACQ status \n " ) ;
printf ( " 32 28 24 20 16 12 8 4 0 \n " ) ;
printf ( " | | | | | | | | | \n " ) ;
std : : cout < < " 0b " < < std : : bitset < 32 > ( status ) < < std : : endl ;
printf ( " Acq state (0x%1X): %s \n " , ( status > > 2 ) & 0x1 , ( ( status > > 2 ) & 0x1 ) = = 0 ? " stopped " : " running " ) ;
printf ( " Event Ready (0x%1X): %s \n " , ( status > > 3 ) & 0x1 , ( ( status > > 3 ) & 0x1 ) = = 0 ? " no event in buffer " : " event in buffer " ) ;
printf ( " Event Full (0x%1X): %s \n " , ( status > > 4 ) & 0x1 , ( ( status > > 4 ) & 0x1 ) = = 0 ? " not full " : " full " ) ;
printf ( " Clock source (0x%1X): %s \n " , ( status > > 5 ) & 0x1 , ( ( status > > 5 ) & 0x1 ) = = 0 ? " internal " : " external " ) ;
printf ( " Board ready (0x%1X): %s \n " , ( status > > 8 ) & 0x1 , ( ( status > > 8 ) & 0x1 ) = = 0 ? " not ready " : " ready " ) ;
printf ( " Ch shutDown (0x%1X): %s \n " , ( status > > 19 ) & 0x1 , ( ( status > > 19 ) & 0x1 ) = = 0 ? " Channels are on " : " channels are shutdown " ) ;
printf ( " TRG-IN 0x%1X \n " , ( status > > 16 ) & 0x1 ) ;
printf ( " Ch temp state 0x%04X \n " , ( status > > 20 ) & 0xF ) ;
2022-08-10 18:35:13 -04:00
}
2022-10-14 12:23:16 -04:00
//===========================================================
//===========================================================
2022-08-04 17:27:33 -04:00
//===========================================================
2022-10-14 18:27:31 -04:00
void Digitizer : : WriteRegister ( Reg registerAddress , uint32_t value , int ch , bool isSave2MemAndFile ) {
2022-10-17 14:42:00 -04:00
2022-11-02 15:43:23 -04:00
printf ( " %30s[0x%04X](ch-%02d) [0x%04X]: 0x%08X \n " , registerAddress . GetNameChar ( ) , registerAddress . GetAddress ( ) , ch , registerAddress . ActualAddress ( ch ) , value ) ;
2022-10-17 14:42:00 -04:00
if ( ! isConnected ) {
SetSettingToMemory ( registerAddress , value , ch ) ;
SaveSettingToFile ( registerAddress , value , ch ) ;
return ;
}
if ( registerAddress . GetType ( ) = = RW : : ReadONLY ) return ;
2022-10-05 17:54:10 -04:00
2022-10-13 18:06:07 -04:00
ret = CAEN_DGTZ_WriteRegister ( handle , registerAddress . ActualAddress ( ch ) , value ) ;
2022-10-17 14:42:00 -04:00
if ( ret = = 0 & & isSave2MemAndFile & & registerAddress . GetType ( ) = = RW : : ReadWrite ) {
2022-10-13 18:06:07 -04:00
SetSettingToMemory ( registerAddress , value , ch ) ;
SaveSettingToFile ( registerAddress , value , ch ) ;
2022-10-06 15:49:08 -04:00
}
2022-10-05 17:54:10 -04:00
ErrorMsg ( " WriteRegister: " + std : : to_string ( registerAddress ) ) ;
2022-08-04 17:27:33 -04:00
}
2022-10-14 18:27:31 -04:00
uint32_t Digitizer : : ReadRegister ( Reg registerAddress , unsigned short ch , bool isSave2MemAndFile , std : : string str ) {
2022-10-05 17:54:10 -04:00
if ( ! isConnected ) return 0 ;
2022-10-17 14:42:00 -04:00
if ( registerAddress . GetType ( ) = = RW : : WriteONLY ) return 0 ;
2022-10-05 17:54:10 -04:00
uint32_t data [ 1 ] ;
2022-10-13 18:06:07 -04:00
ret = CAEN_DGTZ_ReadRegister ( handle , registerAddress . ActualAddress ( ch ) , data ) ;
2022-10-05 17:54:10 -04:00
2022-10-13 18:06:07 -04:00
if ( ret = = 0 & & isSave2MemAndFile ) {
SetSettingToMemory ( registerAddress , data [ 0 ] , ch ) ;
SaveSettingToFile ( registerAddress , data [ 0 ] , ch ) ;
}
2022-10-05 17:54:10 -04:00
ErrorMsg ( " ReadRegister: " + std : : to_string ( registerAddress ) ) ;
2022-10-13 18:06:07 -04:00
if ( str ! = " " ) printf ( " %s : 0x%04X(0x%04X) is 0x%08X \n " , str . c_str ( ) ,
registerAddress . ActualAddress ( ch ) , registerAddress . GetAddress ( ) , data [ 0 ] ) ;
2022-10-05 17:54:10 -04:00
return data [ 0 ] ;
2022-08-04 17:27:33 -04:00
}
2022-10-20 13:51:06 -04:00
uint32_t Digitizer : : PrintRegister ( uint32_t address , std : : string msg ) {
if ( ! isConnected ) return 0 ;
printf ( " \ e[33m---------------------------------------------------- \n " ) ;
printf ( " ------------ %s = 0x%X \n " , msg . c_str ( ) , address ) ;
printf ( " ---------------------------------------------------- \ e[0m \n " ) ;
uint32_t * value = new uint32_t [ 1 ] ;
CAEN_DGTZ_ReadRegister ( handle , address , value ) ;
printf ( " %*s 32 28 24 20 16 12 8 4 0 \n " , ( int ) msg . length ( ) , " " ) ;
printf ( " %*s | | | | | | | | | \n " , ( int ) msg . length ( ) , " " ) ;
printf ( " %*s " , ( int ) msg . length ( ) , " " ) ;
std : : cout < < " : 0b " < < std : : bitset < 32 > ( value [ 0 ] ) < < std : : endl ;
printf ( " %*s : 0x%X \n " , ( int ) msg . length ( ) , msg . c_str ( ) , value [ 0 ] ) ;
2022-08-09 17:31:36 -04:00
2022-10-20 13:51:06 -04:00
return value [ 0 ] ;
2022-08-09 17:31:36 -04:00
}
//========================================== setting file IO
2022-10-14 13:22:55 -04:00
Reg Digitizer : : FindRegister ( uint32_t address ) {
Reg tempReg ;
///========= Find Match Register
for ( int p = 0 ; p < ( int ) RegisterDPPList [ p ] ; p + + ) {
if ( address = = RegisterDPPList [ p ] . GetAddress ( ) ) {
tempReg = RegisterDPPList [ p ] ;
break ;
}
}
if ( tempReg . GetName ( ) = = " " ) {
if ( DPPType = = V1730_DPP_PHA_CODE ) {
for ( int p = 0 ; p < ( int ) RegisterPHAList [ p ] ; p + + ) {
2022-10-17 14:42:00 -04:00
if ( address = = RegisterPHAList [ p ] . GetAddress ( ) ) {
tempReg = RegisterPHAList [ p ] ;
break ;
}
2022-10-14 13:22:55 -04:00
}
}
if ( DPPType = = V1730_DPP_PSD_CODE ) {
for ( int p = 0 ; p < ( int ) RegisterPSDList [ p ] ; p + + ) {
2022-10-17 14:42:00 -04:00
if ( address = = RegisterPSDList [ p ] . GetAddress ( ) ) {
tempReg = RegisterPSDList [ p ] ;
break ;
}
2022-10-14 13:22:55 -04:00
}
}
}
return tempReg ;
}
2022-11-02 15:43:23 -04:00
void Digitizer : : ReadAllSettingsFromBoard ( bool force ) {
2022-10-13 18:06:07 -04:00
if ( ! isConnected ) return ;
2022-11-02 19:01:06 -04:00
if ( AcqRun ) return ;
2022-11-02 15:43:23 -04:00
if ( isSettingFilledinMemeory & & ! force ) return ;
printf ( " ===== %s \n " , __func__ ) ;
2022-10-13 18:06:07 -04:00
/// board setting
for ( int p = 0 ; p < ( int ) RegisterDPPList [ p ] ; p + + ) {
if ( RegisterDPPList [ p ] . GetType ( ) = = RW : : WriteONLY ) continue ;
ReadRegister ( RegisterDPPList [ p ] ) ;
}
2022-11-01 18:38:01 -04:00
channelMask = GetSettingFromMemory ( Register : : DPP : : ChannelEnableMask ) ;
2022-10-13 18:06:07 -04:00
/// Channels Setting
for ( int ch = 0 ; ch < NChannel ; ch + + ) {
if ( DPPType = = V1730_DPP_PHA_CODE ) {
for ( int p = 0 ; p < ( int ) RegisterPHAList [ p ] ; p + + ) {
if ( RegisterPHAList [ p ] . GetType ( ) = = RW : : WriteONLY ) continue ;
ReadRegister ( RegisterPHAList [ p ] , ch ) ;
}
}
if ( DPPType = = V1730_DPP_PSD_CODE ) {
for ( int p = 0 ; p < ( int ) RegisterPSDList [ p ] ; p + + ) {
if ( RegisterPSDList [ p ] . GetType ( ) = = RW : : WriteONLY ) continue ;
ReadRegister ( RegisterPSDList [ p ] , ch ) ;
}
2022-10-07 16:15:58 -04:00
}
2022-08-09 16:02:45 -04:00
}
2022-10-13 18:06:07 -04:00
isSettingFilledinMemeory = true ;
2022-08-09 16:02:45 -04:00
}
2022-10-05 17:54:10 -04:00
2022-10-13 18:06:07 -04:00
void Digitizer : : ProgramSettingsToBoard ( ) {
if ( ! isConnected ) return ;
2022-11-02 15:43:23 -04:00
if ( isDummy ) return ;
Reg haha ;
2022-10-13 18:06:07 -04:00
/// board setting
for ( int p = 0 ; p < ( int ) RegisterDPPList [ p ] ; p + + ) {
if ( RegisterDPPList [ p ] . GetType ( ) = = RW : : ReadONLY ) continue ;
2022-11-02 15:43:23 -04:00
haha = RegisterDPPList [ p ] ;
WriteRegister ( haha , GetSettingFromMemory ( haha ) , - 1 , false ) ;
usleep ( 100 * 1000 ) ;
2022-10-13 18:06:07 -04:00
}
/// Channels Setting
for ( int ch = 0 ; ch < NChannel ; ch + + ) {
if ( DPPType = = V1730_DPP_PHA_CODE ) {
for ( int p = 0 ; p < ( int ) RegisterPHAList [ p ] ; p + + ) {
if ( RegisterPHAList [ p ] . GetType ( ) = = RW : : ReadONLY ) continue ;
2022-11-02 15:43:23 -04:00
haha = RegisterPHAList [ p ] ;
WriteRegister ( haha , GetSettingFromMemory ( haha , ch ) , ch , false ) ;
usleep ( 100 * 1000 ) ;
2022-10-13 18:06:07 -04:00
}
}
if ( DPPType = = V1730_DPP_PSD_CODE ) {
for ( int p = 0 ; p < ( int ) RegisterPSDList [ p ] ; p + + ) {
if ( RegisterPSDList [ p ] . GetType ( ) = = RW : : ReadONLY ) continue ;
2022-11-02 15:43:23 -04:00
haha = RegisterPHAList [ p ] ;
WriteRegister ( haha , GetSettingFromMemory ( haha , ch ) , ch , false ) ;
usleep ( 100 * 1000 ) ;
2022-10-13 18:06:07 -04:00
}
}
}
2022-10-05 17:54:10 -04:00
}
2022-10-14 18:27:31 -04:00
void Digitizer : : SetSettingToMemory ( Reg registerAddress , unsigned int value , unsigned short ch ) {
2022-10-13 18:06:07 -04:00
unsigned short index = registerAddress . Index ( ch ) ;
2022-10-05 17:54:10 -04:00
if ( index > SETTINGSIZE ) return ;
setting [ index ] = value ;
}
2022-10-14 18:27:31 -04:00
unsigned int Digitizer : : GetSettingFromMemory ( Reg registerAddress , unsigned short ch ) {
2022-10-13 18:06:07 -04:00
unsigned short index = registerAddress . Index ( ch ) ;
2022-10-05 17:54:10 -04:00
if ( index > SETTINGSIZE ) return 0xFFFF ;
return setting [ index ] ;
}
void Digitizer : : PrintSettingFromMemory ( ) {
for ( int i = 0 ; i < SETTINGSIZE ; i + + ) printf ( " %4d | 0x%04X |0x%08X = %u \n " , i , i * 4 , setting [ i ] , setting [ i ] ) ;
}
2022-11-02 15:43:23 -04:00
void Digitizer : : SetSettingBinaryPath ( std : : string fileName ) {
2022-10-05 17:54:10 -04:00
settingFile = fopen ( fileName . c_str ( ) , " r+ " ) ;
if ( settingFile = = NULL ) {
2022-10-13 18:06:07 -04:00
printf ( " cannot open file %s. Create one. \n " , fileName . c_str ( ) ) ;
2022-11-02 15:43:23 -04:00
ReadAllSettingsFromBoard ( ) ;
SaveAllSettingsAsBin ( fileName ) ;
2022-10-13 18:06:07 -04:00
2022-11-02 15:43:23 -04:00
this - > settingFileName = fileName ;
2022-10-13 18:06:07 -04:00
settingFileExist = true ;
2022-11-02 15:43:23 -04:00
2022-10-05 17:54:10 -04:00
} else {
2022-10-06 18:25:35 -04:00
this - > settingFileName = fileName ;
2022-10-05 17:54:10 -04:00
settingFileExist = true ;
2022-11-02 15:43:23 -04:00
fclose ( settingFile ) ;
2022-10-13 18:06:07 -04:00
printf ( " setting file already exist. do nothing. Should program the digitizer \n " ) ;
2022-10-05 17:54:10 -04:00
}
2022-11-02 15:43:23 -04:00
2022-10-05 17:54:10 -04:00
}
2022-11-02 15:43:23 -04:00
int Digitizer : : LoadSettingBinaryToMemory ( std : : string fileName ) {
2022-10-05 17:54:10 -04:00
2022-11-02 15:43:23 -04:00
settingFile = fopen ( fileName . c_str ( ) , " r " ) ;
2022-10-05 17:54:10 -04:00
if ( settingFile = = NULL ) {
2022-10-17 14:42:00 -04:00
printf ( " %s does not exist or cannot load. \n " , fileName . c_str ( ) ) ;
2022-10-05 17:54:10 -04:00
settingFileExist = false ;
2022-10-17 14:42:00 -04:00
return - 1 ;
2022-09-26 16:47:20 -04:00
2022-10-05 17:54:10 -04:00
} else {
settingFileExist = true ;
2022-10-06 18:25:35 -04:00
settingFileName = fileName ;
2022-10-17 14:42:00 -04:00
fclose ( settingFile ) ;
2022-10-13 18:06:07 -04:00
2022-10-17 14:42:00 -04:00
uint32_t fileDPP = ( ( ReadSettingFromFile ( Register : : DPP : : AMCFirmwareRevision_R , 0 ) > > 8 ) & 0xFF ) ;
2022-10-06 17:10:54 -04:00
2022-10-17 14:42:00 -04:00
/// compare seeting DPP version;
if ( isConnected & & DPPType ! = fileDPP ) {
printf ( " DPPType in the file is %s(0x%X), but the dgitizer DPPType is %s(0x%X). \n " , GetDPPString ( fileDPP ) . c_str ( ) , fileDPP , GetDPPString ( ) . c_str ( ) , DPPType ) ;
return - 1 ;
} else {
/// load binary to memoery
DPPType = fileDPP ;
printf ( " DPPType in the file is %s(0x%X). \n " , GetDPPString ( fileDPP ) . c_str ( ) , fileDPP ) ;
2022-11-02 15:43:23 -04:00
settingFile = fopen ( fileName . c_str ( ) , " r " ) ;
2022-10-17 14:42:00 -04:00
size_t dummy = fread ( setting , SETTINGSIZE * sizeof ( unsigned int ) , 1 , settingFile ) ;
fclose ( settingFile ) ;
uint32_t boardInfo = GetSettingFromMemory ( Register : : DPP : : BoardInfo_R ) ;
if ( ( boardInfo & 0xFF ) = = 0x0E ) ch2ns = 4.0 ;
if ( ( boardInfo & 0xFF ) = = 0x0B ) ch2ns = 2.0 ;
2022-11-02 15:43:23 -04:00
///Should seperate file<->memory, memory<->board
///ProgramSettingsToBoard(); /// do nothing if not connected.
2022-10-17 14:42:00 -04:00
return 0 ;
}
2022-08-09 16:02:45 -04:00
}
}
2022-10-14 18:27:31 -04:00
unsigned int Digitizer : : ReadSettingFromFile ( Reg registerAddress , unsigned short ch ) {
2022-08-09 16:02:45 -04:00
if ( ! settingFileExist ) return - 1 ;
2022-10-13 18:06:07 -04:00
unsigned short index = registerAddress . Index ( ch ) ;
2022-08-09 16:02:45 -04:00
settingFile = fopen ( settingFileName . c_str ( ) , " r " ) ;
2022-10-05 17:54:10 -04:00
///fseek( settingFile, address, SEEK_SET);
fseek ( settingFile , index * 4 , SEEK_SET ) ;
///printf(" at pos %lu Byte = index(%lu)\n", ftell(settingFile), ftell(settingFile)/4);
2022-08-09 16:02:45 -04:00
unsigned int lala [ 1 ] ;
2022-08-09 17:01:08 -04:00
size_t dummy = fread ( lala , sizeof ( unsigned int ) , 1 , settingFile ) ;
2022-10-05 17:54:10 -04:00
///printf(" data at pos %lu(%lu) : %X = %d\n", ftell(settingFile) - sizeof(unsigned int), (ftell(settingFile) - sizeof(unsigned int))/4, lala[0], lala[0]);
2022-08-09 16:02:45 -04:00
fclose ( settingFile ) ;
return lala [ 0 ] ;
2022-10-05 17:54:10 -04:00
2022-08-09 16:02:45 -04:00
}
2022-10-14 18:27:31 -04:00
void Digitizer : : SaveSettingToFile ( Reg registerAddress , unsigned int value , unsigned short ch ) {
2022-08-09 16:02:45 -04:00
if ( ! settingFileExist ) return ;
2022-08-09 17:01:08 -04:00
2022-10-14 18:27:31 -04:00
unsigned short index = registerAddress . Index ( ch ) ;
2022-10-05 17:54:10 -04:00
setting [ index ] = value ;
2022-08-09 16:02:45 -04:00
settingFile = fopen ( settingFileName . c_str ( ) , " r+ " ) ;
2022-10-05 17:54:10 -04:00
///fseek( settingFile, address, SEEK_SET);
fseek ( settingFile , index * 4 , SEEK_SET ) ;
2022-08-09 16:02:45 -04:00
unsigned int jaja [ 1 ] = { value } ;
2022-08-09 17:01:08 -04:00
size_t dummy = fwrite ( jaja , sizeof ( unsigned int ) , 1 , settingFile ) ;
2022-10-05 17:54:10 -04:00
///printf("fwrite ret : %d, 0x%0X, 0x%0X, %d, 0x%X = %d\n", (int)dummy, registerAddress, index*4, index, jaja[0], jaja[0]);
2022-08-09 16:02:45 -04:00
fclose ( settingFile ) ;
}
2022-11-02 15:43:23 -04:00
void Digitizer : : SaveAllSettingsAsBin ( std : : string fileName ) {
if ( ! isSettingFilledinMemeory ) return ;
2022-10-07 16:15:58 -04:00
2022-11-02 15:43:23 -04:00
FILE * binFile = fopen ( fileName . c_str ( ) , " w+ " ) ;
if ( binFile = = NULL ) {
printf ( " Cannot open %s. \n " , fileName . c_str ( ) ) ;
return ;
}
fwrite ( setting , SETTINGSIZE * sizeof ( unsigned int ) , 1 , binFile ) ;
fseek ( binFile , 0L , SEEK_END ) ;
unsigned int inFileSize = ftell ( binFile ) ;
printf ( " Created file : %s. file size : %d Byte \n " , fileName . c_str ( ) , inFileSize ) ;
fclose ( binFile ) ;
}
void Digitizer : : SaveAllSettingsAsText ( std : : string fileName ) {
if ( ! isSettingFilledinMemeory ) return ;
2022-10-07 16:15:58 -04:00
2022-11-02 15:43:23 -04:00
FILE * txtFile = fopen ( fileName . c_str ( ) , " w+ " ) ;
2022-10-07 16:15:58 -04:00
if ( txtFile = = NULL ) {
printf ( " Cannot open %s. \n " , fileName . c_str ( ) ) ;
return ;
}
2022-09-27 17:58:14 -04:00
2022-10-14 12:23:16 -04:00
Reg haha ;
2022-10-13 18:06:07 -04:00
for ( unsigned int i = 0 ; i < SETTINGSIZE ; i + + ) {
2022-10-14 12:23:16 -04:00
haha . SetName ( " " ) ;
uint32_t actualAddress = haha . CalAddress ( i ) ;
2022-10-10 18:35:35 -04:00
2022-10-13 18:06:07 -04:00
///printf("%7d--- 0x%04X, 0x%04X\n", i, haha->GetAddress(), haha->ActualAddress());
for ( int p = 0 ; p < ( int ) RegisterDPPList . size ( ) ; p + + ) {
2022-10-14 12:23:16 -04:00
if ( haha . GetAddress ( ) = = ( uint32_t ) RegisterDPPList [ p ] ) haha = RegisterDPPList [ p ] ;
2022-10-10 18:35:35 -04:00
}
if ( DPPType = = V1730_DPP_PHA_CODE ) {
for ( int p = 0 ; p < ( int ) RegisterPHAList . size ( ) ; p + + ) {
2022-10-14 12:23:16 -04:00
if ( haha . GetAddress ( ) = = ( uint32_t ) RegisterPHAList [ p ] ) haha = RegisterPHAList [ p ] ;
2022-10-10 18:35:35 -04:00
}
}
if ( DPPType = = V1730_DPP_PSD_CODE ) {
for ( int p = 0 ; p < ( int ) RegisterPSDList . size ( ) ; p + + ) {
2022-10-14 12:23:16 -04:00
if ( haha . GetAddress ( ) = = ( uint32_t ) RegisterPSDList [ p ] ) haha = RegisterPSDList [ p ] ;
2022-10-10 18:35:35 -04:00
}
}
2022-10-14 12:23:16 -04:00
if ( haha . GetName ( ) ! = " " ) {
std : : string typeStr ;
if ( haha . GetType ( ) = = RW : : ReadWrite ) typeStr = " R/W " ;
if ( haha . GetType ( ) = = RW : : ReadONLY ) typeStr = " R " ;
if ( haha . GetType ( ) = = RW : : WriteONLY ) typeStr = " W " ;
2022-10-25 16:56:52 -04:00
fprintf ( txtFile , " 0x%04X %30s 0x%08X %s %u \n " , actualAddress ,
2022-10-14 12:23:16 -04:00
haha . GetNameChar ( ) ,
setting [ i ] ,
typeStr . c_str ( ) ,
setting [ i ] ) ;
}
2022-10-07 16:15:58 -04:00
}
}
2022-09-27 17:58:14 -04:00
2022-10-17 14:42:00 -04:00
std : : string Digitizer : : GetDPPString ( int DPPType ) {
std : : string DPPTypeStr = " " ;
if ( DPPType = = 0 ) DPPType = this - > DPPType ;
switch ( DPPType ) {
case V1724_DPP_PHA_CODE : DPPTypeStr = " DPP-PHA x724 " ; break ; /// 0x80
case V1720_DPP_CI_CODE : DPPTypeStr = " DPP-CI x720 " ; break ; /// 0x82
case V1720_DPP_PSD_CODE : DPPTypeStr = " DPP-PSD x720 " ; break ; /// 0x83
case V1751_DPP_PSD_CODE : DPPTypeStr = " DPP-PSD x751 " ; break ; /// 0x84
case V1751_DPP_ZLE_CODE : DPPTypeStr = " DPP-ZLE x751 " ; break ; /// 0x85
case V1743_DPP_CI_CODE : DPPTypeStr = " DPP-PSD x743 " ; break ; /// 0x86
case V1740_DPP_QDC_CODE : DPPTypeStr = " DPP-QDC x740 " ; break ; /// 0x87
case V1730_DPP_PSD_CODE : DPPTypeStr = " DPP-PSD x730 " ; break ; /// 0x88
case V1730_DPP_PHA_CODE : DPPTypeStr = " DPP-PHA x730 " ; break ; /// 0x8B
case V1730_DPP_ZLE_CODE : DPPTypeStr = " DPP-ZLE x730 " ; break ; /// 0x8C
case V1730_DPP_DAW_CODE : DPPTypeStr = " DPP-DAW x730 " ; break ; /// 0x8D
}
return DPPTypeStr ;
}
2022-10-14 18:27:31 -04:00
void Digitizer : : ErrorMsg ( std : : string header ) {
2022-10-13 18:37:13 -04:00
switch ( ret ) {
///case CAEN_DGTZ_Success : /** 0 */ printf("%s | Operation completed successfully.\n", header.c_str()); break;
case CAEN_DGTZ_CommError : /** -1 */ printf ( " %s | Communication Error. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_GenericError : /** -2 */ printf ( " %s | Unspecified error. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_InvalidParam : /** -3 */ printf ( " %s | Invalid parameter. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_InvalidLinkType : /** -4 */ printf ( " %s | Invalid Link Type. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_InvalidHandle : /** -5 */ printf ( " %s | Invalid device handler. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_MaxDevicesError : /** -6 */ printf ( " %s | Maximum number of devices exceeded. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_BadBoardType : /** -7 */ printf ( " %s | Operation not allowed on this type of board. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_BadInterruptLev : /** -8 */ printf ( " %s | The interrupt level is not allowed. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_BadEventNumber : /** -9 */ printf ( " %s | The event number is bad. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_ReadDeviceRegisterFail : /** -10 */ printf ( " %s | Unable to read the registry. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_WriteDeviceRegisterFail : /** -11 */ printf ( " %s | Unable to write the registry. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_InvalidChannelNumber : /** -13 */ printf ( " %s | The channel number is invalid. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_ChannelBusy : /** -14 */ printf ( " %s | The channel is busy. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_FPIOModeInvalid : /** -15 */ printf ( " %s | Invalid FPIO mode. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_WrongAcqMode : /** -16 */ printf ( " %s | Wrong Acquistion mode. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_FunctionNotAllowed : /** -17 */ printf ( " %s | This function is not allowed on this module. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_Timeout : /** -18 */ printf ( " %s | Communication Timeout. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_InvalidBuffer : /** -19 */ printf ( " %s | The buffer is invalid. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_EventNotFound : /** -20 */ printf ( " %s | The event is not found. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_InvalidEvent : /** -21 */ printf ( " %s | The event is invalid. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_OutOfMemory : /** -22 */ printf ( " %s | Out of memory. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_CalibrationError : /** -23 */ printf ( " %s | Unable to calibrate the board. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_DigitizerNotFound : /** -24 */ printf ( " %s | Unbale to open the digitizer. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_DigitizerAlreadyOpen : /** -25 */ printf ( " %s | The digitizer is already open. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_DigitizerNotReady : /** -26 */ printf ( " %s | The digitizer is not ready. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_InterruptNotConfigured : /** -27 */ printf ( " %s | The digitizer has no IRQ configured. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_DigitizerMemoryCorrupted : /** -28 */ printf ( " %s | The digitizer flash memory is corrupted. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_DPPFirmwareNotSupported : /** -29 */ printf ( " %s | The digitier DPP firmware is not supported in this lib version. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_InvalidLicense : /** -30 */ printf ( " %s | Invalid firmware licence. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_InvalidDigitizerStatus : /** -31 */ printf ( " %s | The digitizer is found in a corrupted status. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_UnsupportedTrace : /** -32 */ printf ( " %s | The given trace is not supported. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_InvalidProbe : /** -33 */ printf ( " %s | The given probe is not supported. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_UnsupportedBaseAddress : /** -34 */ printf ( " %s | The base address is not supported. \n " , header . c_str ( ) ) ; break ;
case CAEN_DGTZ_NotYetImplemented : /** -99 */ printf ( " %s | The function is not yet implemented. \n " , header . c_str ( ) ) ; break ;
}
}
/**
void Digitizer : : SetRecordLength ( unsigned int ns , int ch ) {
WriteRegister ( Register : : DPP : : RecordLength_G , ns / ch2ns / 8 , ch ) ;
if ( ch > = 0 ) WriteRegister ( Register : : DPP : : RecordLength_G , ns / ch2ns / 8 , ch + int ( pow ( - 1 , ch ) ) ) ;
ErrorMsg ( __func__ ) ;
}
void Digitizer : : SetAggregateOrganization ( unsigned int bit ) {
WriteRegister ( Register : : DPP : : AggregateOrganization , bit & 0x7 ) ;
ErrorMsg ( __func__ ) ;
}
void Digitizer : : SetEventAggregation ( unsigned int numEvent , int ch ) {
WriteRegister ( Register : : DPP : : NumberEventsPerAggregate_G , numEvent , ch ) ;
if ( ch > = 0 ) WriteRegister ( Register : : DPP : : NumberEventsPerAggregate_G , numEvent , ch + int ( pow ( - 1 , ch ) ) ) ;
ErrorMsg ( __func__ ) ;
}
void Digitizer : : SetMaxAggregatePerBlockTransfer ( unsigned int numEvent ) {
WriteRegister ( Register : : DPP : : MaxAggregatePerBlockTransfer , numEvent ) ;
ErrorMsg ( __func__ ) ;
}
void Digitizer : : SetACQControl ( uint32_t bit ) {
WriteRegister ( Register : : DPP : : AcquisitionControl , bit ) ;
ErrorMsg ( __func__ ) ;
}
void Digitizer : : SetGlobalTriggerMask ( uint32_t bit ) {
WriteRegister ( Register : : DPP : : GlobalTriggerMask , bit ) ;
ErrorMsg ( __func__ ) ;
}
void Digitizer : : SetFrontPanelTRGOUTMask ( uint32_t bit ) {
WriteRegister ( Register : : DPP : : FrontPanelTRGOUTEnableMask , bit ) ;
ErrorMsg ( __func__ ) ;
}
void Digitizer : : SetFrontPanelIOControl ( uint32_t bit ) {
WriteRegister ( Register : : DPP : : FrontPanelIOControl , bit ) ;
ErrorMsg ( __func__ ) ;
}
void Digitizer : : SetTriggerValidationMask ( uint32_t bit ) {
WriteRegister ( Register : : DPP : : TriggerValidationMask_G , bit ) ;
ErrorMsg ( __func__ ) ;
}
void Digitizer : : SetInputDynamicRange ( unsigned int TwoVol_0_or_halfVol_1 , int ch ) { WriteRegister ( Register : : DPP : : InputDynamicRange , TwoVol_0_or_halfVol_1 , ch ) ; ErrorMsg ( __func__ ) ; }
void Digitizer : : SetPreTriggerSample ( unsigned int nSample , int ch ) { WriteRegister ( Register : : DPP : : PreTrigger , nSample / 4 , ch ) ; ErrorMsg ( __func__ ) ; }
void Digitizer : : SetPreTriggerDuration ( unsigned int ns , int ch ) { WriteRegister ( Register : : DPP : : PreTrigger , ns / ch2ns / 4 , ch ) ; ErrorMsg ( __func__ ) ; }
void Digitizer : : SetDCOffset ( float offsetPrecentage , int ch ) { WriteRegister ( Register : : DPP : : ChannelDCOffset , uint ( 0xFFFF * ( 1.0 - offsetPrecentage ) ) , ch ) ; ErrorMsg ( __func__ ) ; }
void Digitizer : : SetVetoWidth ( uint32_t bit , int ch ) { WriteRegister ( Register : : DPP : : VetoWidth , bit , ch ) ; ErrorMsg ( __func__ ) ; }
void Digitizer : : SetTriggerPolarity ( bool RiseingIsZero , int ch ) {
if ( ! isConnected ) return ;
if ( DPPType > = 128 ) return ; /// do thing for DPP firmware
if ( ch < 0 ) {
ret = 0 ;
for ( int i = 0 ; i < NChannel ; i + + ) {
ret | = CAEN_DGTZ_SetTriggerPolarity ( handle , i , CAEN_DGTZ_TriggerPolarity_t ( RiseingIsZero ) ) ;
}
} else {
ret = CAEN_DGTZ_SetTriggerPolarity ( handle , ch , CAEN_DGTZ_TriggerPolarity_t ( RiseingIsZero ) ) ;
}
if ( ret ! = 0 ) ErrorMsg ( __func__ ) ;
}
//============================== DPP-Alpgorthm Control
void Digitizer : : SetDPPAlgorithmControl ( uint32_t bit , int ch ) {
WriteRegister ( Register : : DPP : : DPPAlgorithmControl , bit , ch ) ;
if ( ret ! = 0 ) ErrorMsg ( __func__ ) ;
}
unsigned int Digitizer : : ReadBits ( Reg address , unsigned int bitLength , unsigned int bitSmallestPos , int ch ) {
int tempCh = ch ;
if ( ch < 0 & & address < 0x8000 ) tempCh = 0 ; /// take ch-0
uint32_t bit = ReadRegister ( address , tempCh ) ;
bit = ( bit > > bitSmallestPos ) & uint ( pow ( 2 , bitLength ) - 1 ) ;
return bit ;
}
void Digitizer : : SetBits ( Reg address , unsigned int bitValue , unsigned int bitLength , unsigned int bitSmallestPos , int ch ) {
///printf("address : 0x%X, value : 0x%X, len : %d, pos : %d, ch : %d \n", address, bitValue, bitLength, bitSmallestPos, ch);
uint32_t bit ;
uint32_t bitmask = ( uint ( pow ( 2 , bitLength ) - 1 ) < < bitSmallestPos ) ;
int tempCh = ch ;
if ( ch < 0 & & address < 0x8000 ) tempCh = 0 ; /// take ch-0
bit = ReadRegister ( address , tempCh ) ;
///printf("bit : 0x%X, bitmask : 0x%X \n", bit, bitmask);
bit = ( bit & ~ bitmask ) | ( bitValue < < bitSmallestPos ) ;
///printf("bit : 0x%X, ch : %d \n", bit, ch);
WriteRegister ( address , bit , ch ) ;
if ( ret ! = 0 ) ErrorMsg ( __func__ ) ;
}
int Digitizer : : GetChTemperature ( int ch ) {
if ( ! isConnected ) return - 404 ;
if ( BoardInfo . Model ! = CAEN_DGTZ_V1730 & &
BoardInfo . Model ! = CAEN_DGTZ_V1725 & &
BoardInfo . Model ! = CAEN_DGTZ_V1751 ) return - 404 ;
uint32_t * temp ;
ret | = CAEN_DGTZ_ReadTemperature ( handle , ch , temp ) ;
if ( ret ! = 0 ) ErrorMsg ( __func__ ) ;
return temp [ 0 ] ;
}
*/