Changeset 14174
- Timestamp:
- 06/13/12 15:44:01 (13 years ago)
- Location:
- fact
- Files:
-
- 6 edited
Legend:
- Unmodified
- Added
- Removed
-
fact/Evidence/Evidence.cc
r12910 r14174 360 360 // If invoked twice, call exit() 361 361 if (Count == 2) { 362 This->Message(WARN, "Signal handler called twice, invoking exit() (signal %d)", Signal);362 This->Message(WARN, "Signal handler called twice, invoking exit(). Will abort() on next signal without message. (signal %d)", Signal); 363 363 exit(EXIT_FAILURE); 364 364 } 365 365 366 366 // If invoked more than twice, call abort() 367 This->Message(WARN, "Signal handler called %d times, invoking abort(). Good bye. (signal %d)", Count, Signal);367 // Does not use Message() again, as this might be blocked 368 368 abort(); 369 369 } -
fact/Evidence/readme.txt
r12940 r14174 65 65 Edd much faster now. Made a new version Edd:LP for La Palma. History server publishes a list of 66 66 services subscribed to. 67 13/6/2012 Removed calling Message() before abort() in signal handler, as Message() might get stuck -
fact/FADctrl/FAD.cc
r12891 r14174 617 617 void FAD::cmd_dynrange() { 618 618 619 // Set number of events required for measurement620 if (Parameter.size()==1 || !ConvertToInt(Parameter[1], &NumEventsRequested) || NumEventsRequested<=0) {621 NumEventsRequested = DEFAULT_NUM_CALIB_EVENTS;622 }623 624 // Start calibration by setting mode625 619 Mode = dynrange; 626 Message(INFO, "Starting determination of dynamic range with %d events", NumEventsRequested);620 Message(INFO, "Starting determination of dynamic range"); 627 621 } 628 622 … … 667 661 else if (Mode == acalib) PrintMessage("Current mode is ACALIB (3x%d events, slowest board %d has %d events)\n", NumEventsRequested, SlowestBoard, MinCount); 668 662 else if (Mode == datarun) PrintMessage("Current mode is DATARUN (%d events requested, %d events taken)\n", NumEventsRequested, NumEvents); 669 else if (Mode == dynrange) PrintMessage("Current mode is DYNRANGE (%d events requested)\n", NumEventsRequested);663 else if (Mode == dynrange) PrintMessage("Current mode is DYNRANGE\n"); 670 664 return; 671 665 } … … 957 951 958 952 // If amplitude calibration mode, check if all boards finished procedure 959 if (Mode == acalib ) {953 if (Mode == acalib || Mode == dynrange) { 960 954 bool Done = true; 961 955 for (unsigned int i=0; i<Boards.size(); i++) { … … 965 959 // Amplitude calibration finished? 966 960 if (Done) { 967 SaveAmplitudeCalibration(); 961 if (Mode == acalib) { 962 SaveAmplitudeCalibration(); 963 Message(INFO, "Amplitude calibration done, mode set to IDLE"); 964 } 965 if (Mode == dynrange) { 966 Message(INFO, "Dynamic range measurement done, mode set to IDLE"); 967 } 968 968 Mode = idle; 969 Message(INFO, "Amplitude calibration done, mode set to IDLE");970 969 } 971 970 } -
fact/FADctrl/FADBoard.cc
r12891 r14174 168 168 unsigned short DACCmd[] = {htons(CMD_Write | (BADDR_DAC + 1)), 0, htons(CMD_Write | (BADDR_DAC + 2)), 0, htons(CMD_Write | (BADDR_DAC + 3)), 0, htons(CMD_Execute) }; 169 169 string Message = string("ACALIBDONE")+Name+"\n"; 170 170 171 171 switch (State) { 172 // ******************************************************************* 173 // ****************** AMPLITUDE CALIBRATION ********************* 174 // ******************************************************************* 175 172 176 // ====== Part A: Check if amplitude calibration should start and initialise ===== 173 177 case standbye: 174 if (m->Mode != m->acalib) break; 175 176 // Invalidate current calibration 177 ACalib.Time = -1; 178 Count = 0; 178 if (m->Mode != m->acalib && m->Mode != m->dynrange) break; 179 179 180 180 // Save initial board status, set all ROIs to 1024 and set DAC values (no triggers while setting ROI) … … 188 188 Send(&ROICmd[0], ROICmd.size()*sizeof(unsigned short)); 189 189 190 DACCmd[1] = htons(0); 191 DACCmd[3] = htons(0); 192 DACCmd[5] = htons(0); 193 Send(DACCmd, sizeof(DACCmd)); 194 195 // Clear sum vector and set state to accumulate 196 memset(Sum, 0, sizeof(Sum)); 197 State = baseline; 198 SetStatus("Starting calilbration"); 190 if (m->Mode == m->acalib) { 191 // Set DAC to zero 192 DACCmd[1] = htons(0); 193 DACCmd[3] = htons(0); 194 DACCmd[5] = htons(0); 195 Send(DACCmd, sizeof(DACCmd)); 196 197 // Invalidate current calibration 198 ACalib.Time = -1; 199 Count = 0; 200 201 // Clear sum vector and set state to accumulate 202 memset(Sum, 0, sizeof(Sum)); 203 State = baseline; 204 SetStatus("Starting calilbration"); 205 } 206 207 if (m->Mode == m->dynrange) { 208 // No amplitude calibration allowed! 209 DAC_DR = 0; 210 Delta_DAC = 1000; 211 State = setdac; 212 } 213 199 214 break; 200 215 … … 317 332 for (unsigned int i=0; i<NTemp; i++) ACalib.Temp += Status.Temp[i] / NTemp; 318 333 319 // Inform event thread that calibration is finished for this board320 if (write(m->Pipe[1], Message.data(), Message.size()) == -1) {321 m->Message(m->ERROR, "write() to Pipe[1] failed in class FADBoard::AmplitudeCalibration (%s)", strerror(errno));322 }323 324 SetStatus("Finished calibration");325 State = cleanup;326 break;327 328 // ====== Part E: Write back original ROI and DAC settings =====329 case cleanup:330 // ROI values331 332 ROICmd.clear();333 for (unsigned int i=0; i<NChips*NChannels; i++) {334 ROICmd.push_back(htons(CMD_Write | (BADDR_ROI + i)));335 ROICmd.push_back(htons(InitialStatus.ROI[i/NChannels][i%NChannels]));336 }337 ROICmd.push_back(htons(CMD_Execute));338 Send(&ROICmd[0], ROICmd.size()*sizeof(unsigned short));339 340 // DAC values341 DACCmd[1] = htons(InitialStatus.DAC[1]);342 DACCmd[3] = htons(InitialStatus.DAC[2]);343 DACCmd[5] = htons(InitialStatus.DAC[3]);344 Send(DACCmd, sizeof(DACCmd));345 346 334 // Update DIM service with calibration information 347 335 for (unsigned int i=0; i<NChips; i++) { … … 356 344 DIM_ACalData->updateService(ACalData, 3*NChips*NChannels*NBins*sizeof(float)); 357 345 346 SetStatus("Finished calibration"); 347 State = cleanup; 348 break; 349 350 // ====== Part E: Write back original ROI and DAC settings ===== 351 case cleanup: 352 // ROI values 353 354 ROICmd.clear(); 355 for (unsigned int i=0; i<NChips*NChannels; i++) { 356 ROICmd.push_back(htons(CMD_Write | (BADDR_ROI + i))); 357 ROICmd.push_back(htons(InitialStatus.ROI[i/NChannels][i%NChannels])); 358 } 359 ROICmd.push_back(htons(CMD_Execute)); 360 Send(&ROICmd[0], ROICmd.size()*sizeof(unsigned short)); 361 362 // DAC values 363 DACCmd[1] = htons(InitialStatus.DAC[1]); 364 DACCmd[3] = htons(InitialStatus.DAC[2]); 365 DACCmd[5] = htons(InitialStatus.DAC[3]); 366 Send(DACCmd, sizeof(DACCmd)); 367 368 // Inform event thread that calibration is finished for this board 369 if (write(m->Pipe[1], Message.data(), Message.size()) == -1) { 370 m->Message(m->ERROR, "write() to Pipe[1] failed in class FADBoard::AmplitudeCalibration (%s)", strerror(errno)); 371 } 372 373 SetStatus("Cleaning up"); 358 374 State = wait; 359 375 break; … … 363 379 if (m->Mode == m->idle) State = standbye; 364 380 break; 365 } 366 } 381 382 383 // ************************************************************************ 384 // ****************** DYNAMIC RANGE DETERMINATION ********************* 385 // ************************************************************************ 386 387 // ====== Set calibration DACs 1-3 ===== 388 case setdac: 389 // Check for stopping 390 if (m->Mode != m->dynrange) { 391 State = cleanup; 392 break; 393 } 394 395 // Set new DAC values 396 DACCmd[1] = htons(DAC_DR); 397 DACCmd[3] = htons(DAC_DR); 398 DACCmd[5] = htons(DAC_DR); 399 Send(DACCmd, sizeof(DACCmd)); 400 401 SetStatus("Dynamic range: DACs 1-3 at %u", DAC_DR); 402 State = measure; 403 break; 404 405 // ====== Determine mean and sigma ===== 406 case measure: 407 // Check for stopping 408 if (m->Mode != m->dynrange) { 409 State = cleanup; 410 break; 411 } 412 413 // Check if current event has correct DAC values 414 if (Status.DAC[1] != DAC_DR || Status.DAC[2] != DAC_DR || Status.DAC[3] != DAC_DR) break; 415 416 // Discard first few events with correct DAC setting (can still have wrong voltage) 417 if (Count_DR++ < 2) break; 418 Count_DR = 0; 419 420 bool Clip; 421 422 // Evaluate current event for all channels 423 for (unsigned int Chip=0; Chip<NChips; Chip++) { 424 for (unsigned int Chan=0; Chan<NChannels; Chan++) { 425 Clip = false; 426 Mean[Chip][Chan] = 0; 427 428 // Determine mean value and check if CLIP_LEVEL exceeded 429 for (int i=0; i<Status.ROI[Chip][Chan]; i++) { 430 Mean[Chip][Chan] += Data[Chip][Chan][i] / Status.ROI[Chip][Chan]; 431 if (abs(Data[Chip][Chan][i]) >= CLIP_LEVEL) Clip = true; 432 } 433 } 434 } 435 436 // If clipping occurred, continue to increase/decrease DAC until at 16-bit limit 437 if (Clip) { 438 if (DAC_DR + Delta_DAC < 0 || DAC_DR + Delta_DAC > 65535) State = cleanup; 439 else { 440 DAC_DR += Delta_DAC; 441 State = setdac; 442 } 443 break; 444 } 445 446 // Start again from maximum DAC value downwards 447 if (Delta_DAC > 0) { 448 for (unsigned int Chip=0; Chip<NChips; Chip++) { 449 for (unsigned int Chan=0; Chan<NChannels; Chan++) Mean_low[Chip][Chan] = Mean[Chip][Chan]; 450 } 451 DAC_low = DAC_DR; 452 DAC_DR = 65535; 453 Delta_DAC = -1000; 454 State = setdac; 455 break; 456 } 457 458 // Procedure finished 459 double Sigma; 460 printf("Extrapolated DAC values for range with 1-sigma\nclearance to ADC count level +/-%u\n", CLIP_LEVEL); 461 462 for (unsigned int Chip=0; Chip<NChips; Chip++) { 463 for (unsigned int Chan=0; Chan<NChannels; Chan++) { 464 465 // Calculate baseline sigma for current event 466 Sigma = 0; 467 for (int i=0; i<Status.ROI[Chip][Chan]; i++) Sigma += pow(Data[Chip][Chan][i] - Mean[Chip][Chan], 2); 468 if (Status.ROI[Chip][Chan] > 1) Sigma = sqrt(Sigma / (Status.ROI[Chip][Chan] - 1)); 469 470 // Extrapolate to find DAC values corresponding to 1-sigma clearance to CLIP_LEVEL 471 DR_low[Chip][Chan] = DAC_low - (Mean_low[Chip][Chan] + (CLIP_LEVEL-Sigma))* (DAC_DR-DAC_low) / (Mean[Chip][Chan]-Mean_low[Chip][Chan]); 472 DR_high[Chip][Chan] = DAC_DR + (CLIP_LEVEL - Sigma - Mean[Chip][Chan]) * (DAC_DR-DAC_low) / (Mean[Chip][Chan]-Mean_low[Chip][Chan]); 473 474 printf("Chip %u, chan %u: DAC Min %6d Max %d Range %6d\n", Chip, Chan, DR_low[Chip][Chan], DR_high[Chip][Chan], DR_high[Chip][Chan]-DR_low[Chip][Chan]); 475 } 476 } 477 478 State = cleanup; 479 break; 480 } 481 } 367 482 368 483 // … … 723 838 } 724 839 } 725 726 727 728 //729 // Dynamic range determination730 //731 void FADBoard::DynamicRange() {732 733 #if 0734 vector<unsigned short> ROICmd;735 unsigned short DACCmd[] = {htons(CMD_Write | (BADDR_DAC + 1)), 0, htons(CMD_Write | (BADDR_DAC + 2)), 0, htons(CMD_Write | (BADDR_DAC + 3)), 0, htons(CMD_Execute) };736 string Message = string("ACALIBDONE")+Name+"\n";737 738 switch (StateDR) {739 // ====== Check if dynamic range measurement should start and initialise =====740 case standbye:741 if (m->Mode != m->dynrange) break;742 743 // Save initial board status, and set all ROIs to 1024744 InitialStatus = GetStatus();745 746 for (unsigned int i=0; i<NChips*NChannels; i++) {747 ROICmd.push_back(htons(CMD_Write | (BADDR_ROI + i)));748 ROICmd.push_back(htons(NBins));749 }750 ROICmd.push_back(htons(CMD_Execute));751 Send(&ROICmd[0], ROICmd.size()*sizeof(unsigned short));752 753 // Start measurement754 DAC_DR = 0;755 StateDR = setdac;756 SetStatus("Starting dynamic range measurement");757 break;758 759 // ====== Set calibration DAC =====760 case setdac:761 // Check for stopping762 if (m->Mode != m->dynrange) {763 StateDR = cleanup;764 break;765 }766 767 if (DAC_DR > 66000) {768 StateDR = cleanup;769 break;770 }771 772 // Set new DAC values773 DACCmd[1] = htons(DAC_DR);774 DACCmd[3] = htons(DAC_DR);775 DACCmd[5] = htons(DAC_DR);776 Send(DACCmd, sizeof(DACCmd));777 778 StateDR = measure;779 break;780 781 // ====== Determine mean and sigma =====782 case measure:783 // Check for stopping784 if (m->Mode != m->dynrange) {785 StateDR = cleanup;786 break;787 }788 789 Mean = 0;790 Sigma = 0;791 for (unsigned int Chip=0; Chip<NChips; Chip++) {792 for (unsigned int Chan=0; Chan<NChannels; Chan++) {793 for (int i=0; i<Status.ROI[Chip][Chan]; i++) {794 Mean += Data[Chip][Chan][i];795 Sigma += Data[Chip][Chan][i]*Data[Chip][Chan][i];796 }797 Mean /= Status.ROI[Chip][Chan];798 Sigma = sqrt(Status.ROI[Chip][Chan]/(Status.ROI[Chip][Chan]-1)*(Sigma/Status.ROI[Chip][Chan]-Mean*Mean));799 }800 }801 802 DAC_DR += 1000;803 804 StateDR = setdac;805 break;806 807 // ====== Write back original ROI and DAC settings =====808 case cleanup:809 // ROI values810 ROICmd.clear();811 for (unsigned int i=0; i<NChips*NChannels; i++) {812 ROICmd.push_back(htons(CMD_Write | (BADDR_ROI + i)));813 ROICmd.push_back(htons(InitialStatus.ROI[i/NChannels][i%NChannels]));814 }815 ROICmd.push_back(htons(CMD_Execute));816 Send(&ROICmd[0], ROICmd.size()*sizeof(unsigned short));817 818 // DAC values819 DACCmd[1] = htons(InitialStatus.DAC[1]);820 DACCmd[3] = htons(InitialStatus.DAC[2]);821 DACCmd[5] = htons(InitialStatus.DAC[3]);822 Send(DACCmd, sizeof(DACCmd));823 824 StateDR = wait;825 break;826 827 // ====== Wait for Mode not being idle =====828 case wait:829 if (m->Mode == m->idle) StateDR = standbye;830 break;831 }832 #endif833 } -
fact/FADctrl/FADBoard.h
r12891 r14174 96 96 void Lock(); 97 97 void Unlock(); 98 void DynamicRange();99 98 100 99 unsigned short Port; … … 110 109 111 110 private: 112 enum StateType {standbye, baseline, gain, secondary, cleanup, wait}; 111 enum StateType {standbye, baseline, gain, secondary, cleanup, wait, setdac, measure}; 112 StateType State; 113 113 114 struct BoardStatus InitialStatus; 114 StateType State; 115 uint16_t DAC_DR, DAC_low; 116 int16_t Delta_DAC; 117 unsigned int Count_DR; 118 static const short CLIP_LEVEL = 2000; 119 double Mean[NChips][NChannels], Mean_low[NChips][NChannels]; 120 int DR_low[NChips][NChannels], DR_high[NChips][NChannels]; 115 121 }; 116 122 -
fact/FADctrl/History.txt
r11385 r14174 35 35 24/6/2011 PLL lock status published as DIM service 36 36 7/7/2011 Fixed error in setting the active boards in EventThread() 37 13/7/2911 FAD board time published as DIM service 37 13/7/2011 FAD board time published as DIM service 38 13/6/2012 New command to determine dynamic range using the calibration DACs
Note:
See TracChangeset
for help on using the changeset viewer.