|  Thu Jun  7 16:27:21 2018, Phan Van Chuan,    | 
| Dear Stefan, 
 I am using an DRS4 board to test the signal from an scintillator detector; It has connected well to the computer on DRS Oscilloscope (Figure
 1). Now, I am having a problem of developing from the code of the drs_exam program, because the DRS4 board has not connected to the computer when translation
 | 
|  Fri Jun  8 08:11:05 2018, Stefan Ritt, | 
| Several people reported this problem, but we cannot reproduce it at our lab. Both the oscilloscope and the command line interface use exactly the same code to connect to the board. Have you tried the solution reported here: elog:657 ?
 
 Best,
 | 
|  Tue Feb 27 13:17:00 2018, Steven Block, WIndows Connection problem with drs507 SOLVED | 
| Hello All, 
 I too have been struggling with trying to get the drs4 (507) to work on my windows machine and I found it to be a problem with the libusb library.
 My solution is as follows and has worked on multiple PC's. I ran this solution after I first plugged in the drs4 and installed 507.
 | 
|  Tue Feb 27 13:29:47 2018, Stefan Ritt, WIndows Connection problem with drs507 SOLVED | 
| Dear Steven, many thanks for this information, this is very useful. I know of people having problems on Windows 10, maybe this will also help them. 
 Stefan
 
 
 
 
 Steven
 | 
|  Wed May  9 14:07:10 2018, Alec Shackleford, WIndows Connection problem with drs507 SOLVED | 
| Thank you for this fantastic solution. I had almost reinstalled windows 7 to see if that would solve the issue! 
 
 
 All the best,
 | 
|  Mon May 14 09:21:29 2018, Alessio Berti, WIndows Connection problem with drs507 SOLVED | 
| Hi, 
 I have a machine with Windows 10 and the solution provided by Steven works fine. To give more details, the driver installed in my case is WinUSB
 (i.e. libusb, v6.1.7600.16385).
 | 
|  Tue May  8 23:58:35 2018, Sean Quinn, Manual Rev5.1 Figure 1, optional components | 
| Dear All, 
 
 
 I'm troubleshooting a board which uses the DRS4 and adopts an analog front end very similar to the evaluation board. As a result, we rely
 | 
|  Wed May  9 09:03:52 2018, Stefan Ritt, Manual Rev5.1 Figure 1, optional components | 
| I updated the picture in the manual with a current picture of a Rev5.1 board, and also added a picture of the bottom side. If you need a picture without the blue labels, have a look at https://www.psi.ch/drs/old-evaluation-boards at the bottom.
 
 Here is the explanation of the optional components:
 | 
|  Wed May  2 10:44:17 2018, Alessio Berti, Peak at 0 mV in traces       | 
| Hi, 
 we modified drs_exam.cpp to read all 4 channels from the DRS4 and apply directly the spike removal (taken from Osci.cpp) during the acquisition
 phase. For test purposes, we don't save the data showing spikes and we focus on the data not having spikes (even if at the end we end up having triple
 | 
|  Wed May  2 12:12:42 2018, Stefan Ritt, Peak at 0 mV in traces | 
| I note that your peak at zero is exactly twice as high as the bins left and right, so this looks to me like a binning problem in your histogramming. Maybe your bin #0 goes from -1mV to +1mV, which all other bins are just 1mW wide. Can you check that?
 
 Stefan
 | 
|  Wed May  2 12:23:16 2018, Alessio Berti, Peak at 0 mV in traces   | 
| Hi, 
 thank you for the quick reply. All the bins in the previous histograms have the same width. We also tried to plot the noise histogram for channel
 2 with more bins (i.e. 1000, so that we can see almost discrete values), and the peak is still there.
 | 
|  Fri May  4 11:35:20 2018, Stefan Ritt, Peak at 0 mV in traces   | 
| I tried the following: 
 - trigger on a 10 MHz sine wave on CH0, CH1 was open
 
 - run drs_exam.cpp program and write data.txt with a few events
 | 
|  Tue May  8 12:15:54 2018, Alessio Berti, Peak at 0 mV in traces      | 
| Hi Stefan, 
 following your example, we tried to perform the same measurement, using drs_exam and taking 1000 events. The results we obtained are in the plots
 attached (both in log and linear scale). We tried two different binnings:
 | 
|  Tue May  8 14:43:03 2018, Stefan Ritt, Peak at 0 mV in traces | 
| The DRS chip is read out with a 12 bit ADC, thus the phyical resolution is roughly 1V/4096 = 0.24 mV. I say roughly since the DRS has an analog gain of 0.98, which is corrected for. Now you have integer values which are converted into floating point numbers my multiplying them with ~0.24mV. If you then
 do histogramming with different bin sizes such as 0.1 mV and 0.35 mV , you get aliasing effects. The code truncates the result to 0.1 mV, which can give
 | 
|  Wed Mar 14 09:13:39 2018, chen wenjun, confusion about the description in drs.cpp   | 
| Hi,Stefan: 
 recently,whtn I study the drs.cpp code ,I found that  the buffer[1] is char but the addr and the base_addr are all unsigned int,isn't
 there any problem that the addr may be cut off to 8 bits? Also ,I found that the data fpga recieved from the usb is 16 bits,so how can fpga get the true
 | 
|  Fri Mar 16 14:00:06 2018, Stefan Ritt, confusion about the description in drs.cpp | 
| The FPGA is very small, so it only has an address space of 256 bytes. Look at the definition in DRS.cpp 
 #define USB_CTRL_OFFSET
 0x00    /* all registers 32 bit */
 | 
|  Sun May  6 08:13:37 2018, chen wenjun, confusion about the description in drs.cpp | 
| Hi Stefan: 
 I'm still confused that althought the 8 bits buffer is enough,the FPGA receive the command through the uc_data_i register which is
 16 bits wides.As we can see in the firmware, the locbus_addr is 32 bits wides. Does it means the locbus_addr[31:8] are always '0' because the address
 | 
|  Sun May  6 11:45:09 2018, Stefan Ritt, confusion about the description in drs.cpp | 
| The locbus_addr is indeed 32 bits wide, since the firmware was originally derived from some firmware running in a VME crate, and the VME bus has 32 bits or addressing. So you will still find some "historic" remnants from that era. In the USB firmware, lcobus_addr[32:8] is always zero. Sorry for
 the confusuion.
 | 
|  Fri Apr 13 18:14:07 2018, Alessio Berti, Voltage and Timing Calibration in drs_exam.cpp | 
| Hi, 
 we were trying to implement an automatic way to calibrate our DRS4 both in voltage and in time (we have the V5 Evaluation Board). We started
 from drs_exam.cpp and tried with the following lines:
 | 
|  Fri May  4 11:56:08 2018, Stefan Ritt, Voltage and Timing Calibration in drs_exam.cpp | 
| Have you set the sampling frequency 
 b->SetFrequency(5, true);
 
 before the calibration?
 | 
|  Tue May  1 02:00:40 2018, Hyunseong Kim, DRS4 using drs_exam.cpp to save as binary files | 
| Hi, 
 I would like to save the waveform in a .dat binary file using drs_exam.cpp.
 
 I know the distributed software allows us to save as binary files with the save button, but I currently need to save multiple runs using
 | 
|  Wed May  2 09:24:53 2018, Stefan Ritt, DRS4 using drs_exam.cpp to save as binary files | 
| You have to write the C/C++ code yourself to write data in binary or any other format. All information is present after the waveform readout in drs_exam.cpp, so it's just a matter of proper write() functions. Please consult any C/C++ handbook on how to write to files.
 
 
 
 
 Hyunseong
 | 
|  Mon Apr 16 21:21:29 2018, Sobimpe Eniola, DRS4 read_binary.cpp | 
| Hello everyone, 
 The new read_binary.cpp code
 
 I will be very glad if anyone can help with the old version of read_binary.cpp code. The latest version I saw online was updated on June
 | 
|  Tue Apr 17 13:28:23 2018, Stefan Ritt, DRS4 read_binary.cpp | 
| On the software download page at https://www.psi.ch/drs/software-download you find a link to all versions of the DRS software, which is located at: https://www.dropbox.com/sh/clqo7ekr0ysbrip/AACoWJzrQAbf3WiBJHG89bGGa?dl=0
 
 Earch .tar.gz file has a date, which should help you find the correct version.
 | 
|  Thu Mar 22 14:36:01 2018, Phan Van Chuan, Read the CalibrateWaveform | 
| Helo I'm building an application for reading waveforms from the DRS4 board to PC. However, I am having problems reading calibration data from EEPROM
 on DRS4 board. The calibration data is read through the function reference:
 | 
|  Fri Mar 23 09:39:55 2018, Stefan Ritt, Read the CalibrateWaveform | 
| You don't have to read and calibrate the waveforms in your user code, but can rely on the DRS.cpp library to do that. Just look at the drs_exam.cpp program coming with the distribution. It uses the function b->GetWave() to retrieve the calibrated waveform. If you like, you can look into that function
 to learn how to apply the calibration, but I can tell you that it's a bit complicated. Since each event starts at an arbitrary stop cell in the DRS4,
 | 
|  Fri Mar  2 18:08:55 2018, Steven Block, ROI | 
| Hello, 
 I have a question about how ROI works. From what I have read, it will only save data that ocurs some time
 | 
|  Fri Mar  2 20:17:17 2018, Stefan Ritt, ROI | 
| N'/N is correct. The 2 us "from the response you got from me" come from the fact that after readout, you have to start the DRS4 again. During this time, the power supply usually becomes slightly unstable, and it takes on the evaluation board about 2us to stabilize it again. Tha't why
 I add the 2 us. If you don't care about slight offset effect, or if you make a better power supply, you dead time would be 10*30ns = 300ns for 10 samples.
 | 
|  Fri Mar  2 21:05:48 2018, Steven Block, ROI | 
| Great! That is very helpful. 
 One more question. If no signals were detected in the 1024*200ps time frame in ROI mode, would the DRS4 go dead for 32us (or 30us depending on
 the supply)  for, or would it dump the earliest events in the buffer for the more recent ones until it detects a signal to readout? Or rather, does
 | 
|  Mon Mar 19 16:22:42 2018, Stefan Ritt, ROI | 
| The DRS4 has an internal storage of 1024 capacitors. They work as a ring buffer, so at 5GSPS you can store 200ns wide signals. After 200ns, the first samples are overwritten by new samples, so you always have the last 200ns of samples stored. Once you trigger the DRS4, this buffer is frozen, and the
 readout of this buffer causes the dead time. No trigger, no dead time. Hope this answers your question.
 | 
|  Wed Mar 14 00:38:15 2018, Will Flanagan, sub-ms precision timestamps? | 
| Dear DRS4 community, 
 Is there a way to extract timestamps with sub-ms precision? The milliseconds of an event is clearly given when unpacking the header. I would
 like to determine how far apart events are when they are within the same millisecond.
 | 
|  Thu Mar 15 08:44:26 2018, Stefan Ritt, sub-ms precision timestamps? | 
| Putting sub-ms precision into the header does not make sense, since the USB transfer only happens in time-slots of about 2 ms. To get better timing, you would need a hardware time clock in the FPGA, which does not exist right now.
 
 Best,
 | 
|  Tue Feb 27 16:34:26 2018, Steven Block, DRS4 Dead times 6x   | 
| Hello All, 
 I am currently trying to figure out how to properly characterize the dead time of the DRS4 board. My most recent experiment to try and answer
 this question involved using an external trigger that can range from 1Hz to 2MHz. I fed this trigger into the DRS4 and collected 1000 samples with no input
 | 
|  Tue Feb 27 17:04:12 2018, Stefan Ritt, DRS4 Dead times | 
| XML is very slow to write, and you are probably limited by that. Switch to binary mode, which is much faster. You will see in the end a maximum rate of ~500 Hz, and thus a dead time of 2ms, independent of the sampling speed. Note that you have only an evaluation board, which is optimized for ease of
 use. If you develop your own electronics, and do optimized readout, you can bring the deadtime down to 30ns x number of samples + 2us, or 32us if you read
 | 
|  Tue Feb 27 18:04:18 2018, Steven Block, DRS4 Dead times | 
| That is extremely helpful! Many thanks. One more question; If I were to take inputs from 2 channels at once, would that scale the dead time to 64us using your example?
 
 Steven
 | 
|  Tue Feb 27 18:12:32 2018, Stefan Ritt, DRS4 Dead times | 
| For applications which are critical on the dead time, one typically uses one ADC per DRS4 channel, and thus the dead time stays at 32us. If you multiplex two DRS4 channels into one ADC channel, then it goes to 32us.
 
 Stefan
 | 
|  Thu Jan 25 05:24:05 2018, chen wenjun, problem with the drscl(drs507) | 
| Hi! Stefan: 
 when I change a new computer(win7,64bit),I meet a problem that the drscl app cannot found the board! It shows"USB successfully scanned,but
 no boards found",but the drsosc runs well . when I connect to other win7*64bits computer,only one of them runs property! Is there any driver else
 | 
|  Thu Jan 25 08:00:16 2018, Stefan Ritt, problem with the drscl(drs507) | 
| This problem has been reported by several people, like elog:551 
 So far I could not solve it. On the computers at our lab it works find so I cannot reproduce and fix the problem. One suspicion I have is that
 the underlying libusb library needs to be updated. You can try to install the newest version from their website at http://libusb.info/, but I haven't
 | 
|  Thu Jan 25 08:07:32 2018, chen wenjun, problem with the drscl(drs507) | 
| I have tried about 4 computers,only one worked fine.I truly want to know how others get this fixed,can you get in touch with them? 
 
 
 
 Stefan
 Ritt wrote:
 
 
 
 This problem has been reported by several people, like
 | 
|  Tue Mar 28 21:53:12 2017, Jim Freeman, drscl doesn't find eval board but drsosc does (Windows 7) | 
| I cannot find the EVAL board using drscl version 5.06 while the drsosc works fine. I tried 2 different eval boards and 2 different computers and the same effect. I looked under device manager at the libusb and the drs4 was there, and checked the driver which was found to be up to date.
 | 
|  Wed Apr  5 12:28:28 2017, Stefan Ritt, drscl doesn't find eval board but drsosc does (Windows 7)    | 
| Two people report now this problem, while this works fine at our lab. So I'm puzzled right now. 
 I attach two screenshots from the device manager and the Command Line interface. Can you compare it with what you see? Which is the firmware
 version of your evaluaiton board?
 | 
|  Thu Jan 25 06:10:52 2018, chen wenjun, drscl doesn't find eval board but drsosc does (Windows 7) | 
| Hi! Jim: 
 It seems that I meet the same question with you ,and I am confused ,have you find out the reason about this problem?Or can you tell me
 how you deal with it?
 | 
|  Wed Jan 17 09:51:16 2018, Tran Cong Thien, The input signals recorded are different with the signal showed in oscilloscope | 
| Dear Stefan, 
 I am using an DRS4 board to record the signals from an plastic scintillator detector. It was working really good, yet a few day ago the signals
 became "not right". When I checked the signal using an oscilloscope it show the normal signals previously recorded. The signal amplitude
 | 
|  Wed Jan 17 10:09:09 2018, Stefan Ritt, The input signals recorded are different with the signal showed in oscilloscope | 
| First thing is to do another voltage calibration. Disconnect input, "Config", "Execute Voltage Calibration". If this does not fix the problem, the board is probably broken. This can happen if you send very high input singals to the board (like >10V) and exceed the maximul allowed
 limit from the datasheet. In that case the board needs to be repaired. Please contact me directly (via email) so that we can make you a quote.
 | 
|  Tue Mar 26 01:17:59 2013, Jill Russek, cascading -- DRS4 Osci.cpp & DRS.cpp | 
| All I'm trying to do is cascade one input signal, though all available channels, so that I end up with 8*1024 bins per event.
 Here is the read out on my board/chip:
 | 
|  Thu Apr  4 11:32:21 2013, Stefan Ritt, cascading -- DRS4 Osci.cpp & DRS.cpp | 
| 
 
 
 Jill Russek wrote:
 
 
 
 
 | 
|  Fri Apr  5 02:21:33 2013, Jill Russek, cascading -- DRS4 Osci.cpp & DRS.cpp | 
| 
 
 
 Stefan Ritt wrote:
 
 
 
 
 
 
 | 
|  Fri Apr  5 08:54:37 2013, Stefan Ritt, cascading -- DRS4 Osci.cpp & DRS.cpp   | 
| 
 
 
 Jill Russek wrote:
 
 
 
 Would it be possible to just hardcode a few lines in the SetChannelConfig in DRS.cpp method as such:
 | 
|  Wed Apr 10 22:41:21 2013, Jill Russek, cascading -- DRS4 Osci.cpp & DRS.cpp | 
| 
 
 
 Stefan Ritt wrote:
 
 
 
 
 
 
 | 
|  Thu Apr 11 08:39:12 2013, Stefan Ritt, cascading -- DRS4 Osci.cpp & DRS.cpp | 
| 
 
 
 Jill Russek wrote:
 
 
 
 
 
 
 | 
|  Thu Apr 11 23:32:57 2013, Jill Russek, cascading -- DRS4 Osci.cpp & DRS.cpp | 
| 
 
 
 Stefan Ritt wrote:
 
 
 
 
 
 
 | 
|  Fri Apr 12 08:25:05 2013, Stefan Ritt, cascading -- DRS4 Osci.cpp & DRS.cpp | 
| 
 
 
 Jill Russek wrote:
 
 
 
 
 
 
 | 
|  Wed Dec 20 15:30:38 2017, Yoni Sher, cascading -- DRS4 Osci.cpp & DRS.cpp | 
| Hi, 
 I'm trying to do the same thing (get 1 channel with 8192 bins), but I'm having some trouble with it. When I call SetChannelConfig(0,
 8, 1) as suggeted, I get output that looks like noise on all readouts. Could you please explain what is supposed to happen in this case?
 | 
|  Wed Dec 20 16:21:42 2017, Stefan Ritt, cascading -- DRS4 Osci.cpp & DRS.cpp | 
| First you need a board which is modified in hardware to support channel cascading. Basically there are internal resistors which connect each input connector to two channels. You have to specify this when you order the board. Then you can use the new drs_exam_2048.cpp file contains in the git repository which
 correctly configures and reads out the board in two-channel cascading mode. Putting all 8 channels together is not supported by the evaluation boards.
 | 
|  Wed Dec 20 16:30:45 2017, Yoni Sher, cascading -- DRS4 Osci.cpp & DRS.cpp | 
| Hi, 
 The board is modified (and checks out with the DRSScope program). Could you please point me to the drs_exam_2048.cpp file? I can't seem to
 fine the most up-to-date git repository....
 | 
|  Wed Dec 20 22:14:35 2017, Stefan Ritt, cascading -- DRS4 Osci.cpp & DRS.cpp | 
| https://bitbucket.org/ritt/drs4eb 
 
 | 
|  Tue Dec 12 00:25:50 2017, Diego Yankelevich, External trigger using Raspberry Pi | 
| Dear Steffan: 
 
 We have been able to use the DRS4 using a Raspberry Pi but we have not been able to use the external trigger. What we are doing is basically
 comment out the code shown below (downloaded from PSI) to use the hardware trigger and uncomment the code to use the external trigger. We have not been
 | 
|  Tue Dec 12 13:58:06 2017, Stefan Ritt, External trigger using Raspberry Pi | 
| Indeed the code does not work for the current evaluation board, it has been written for a previous version and never been updated. Please use following code to enable the external trigger
 
 /* use following lines to enable the external trigger */
 | 
|  Thu Nov 16 02:55:44 2017, Diego Yankelevich, Averaging capabilities | 
| The Display window in the Oscilloscope software shows averaging capabilites but I have not been able to activate these. Is it possible to activate averaging with the existing oscilloscope software? Thanks
 | 
|  Wed Nov 22 14:52:31 2017, Stefan Ritt, Averaging capabilities | 
| This feature is not yet implemented. The (disabled) software swtich is more like a kind of a reminder to myself to work on that one day... 
 
 
 
 Diego
 Yankelevich wrote:
 
 
 
 The Display window in the Oscilloscope software shows averaging
 | 
|  Wed Nov 22 08:31:03 2017, chen wenjun , using of the DRS Command Line Interface   | 
| Hello! I'm using DRS4 evaluation board V5 with the drs command line interface,but the mannal only explained the meaning of the command--"info".And I can't get the hang of the use of other commands through "help",so is there anywhere can I learn more about other commands?Or I can only
 learn it through the datasheet of DRS4 chip.
 | 
|  Wed Nov 22 08:48:36 2017, Stefan Ritt, using of the DRS Command Line Interface | 
| The command line interface is more a debugging tool for experts, and you are not supposed to use it except to test the connection to the evaluation board. The programs for the user are the DRS Oscilloscope and the drs_exam.cpp example program to read out the board with your own program.
 
 Stefan
 | 
|  Wed Nov 22 08:58:33 2017, chen wenjun , using of the DRS Command Line Interface   | 
| OK!Thank you! One more question,when I use the Oscillocope ,I found that the actual speed is a constant value of 1.007G,how can change this speed. 
 
 
 
 Stefan
 Ritt wrote:
 
 
 
 The command line interface is more a debugging tool for experts, and
 | 
|  Wed Nov 22 09:14:18 2017, Stefan Ritt, using of the DRS Command Line Interface | 
| Remove the check mark from the "Lock" box and enter a different value in the sampling speed box and hit return. 
 
 
 
 chen
 wenjun wrote:
 
 
 
 OK!Thank you! One more question,when I use the Oscillocope ,I found
 | 
|  Wed Nov 22 09:19:11 2017, chen wenjun , using of the DRS Command Line Interface | 
| Thank you very much !! All my fault for I thought it too comlicated. Thank you sincerely! 
 
 
 
 Stefan
 Ritt wrote:
 
 
 
 Remove the check mark from the "Lock" box and enter a different
 | 
|  Fri Nov  3 12:11:14 2017, Håkan Wennlöf, Triggering using AND | 
| Hi! 
 I'm using the DRSOsc program, and I have a question that I need a bit clarified;
 
 When triggering using AND between two channels, am I then triggering on rising/falling edge of both channels, or on the actual values?
 | 
|  Fri Nov  3 13:28:04 2017, Stefan Ritt, Triggering using AND | 
| Think about: How would you make a coincidence (AND) between two edges? Since an edge is infinitesimally small, there is no way to make a meaningful coincidence between edges. Therefore, the DRS4 EB firmware makes a simple AND of levels. If you trigger on rising signals and do an AND, then you get a trigger if
 both values are above their threshold. For falling edge trigger (arrow goes down in the trigger configuration) the board triggers when both signals are
 |