-
Notifications
You must be signed in to change notification settings - Fork 119
Home
This wiki is a work in progress.
I just basically copied a Google Doc and haven't even formatted it properly yet.
Bear with me.
~Chris
This document is licensed under the Creative Commons 4.0 BY-SA licence. You are free to download it, share it, and use it for any purpose (including commercial purposes), as long as any edits you make are shared back to the community, and that proper credit is given (a link back to espotek.com or github.com/espotek/labrador will suffice).
http://creativecommons.org/licenses/by-sa/4.0
Welcome to the initial documentation for the EspoTek Labrador!
You're probably aware of what Labrador is by now, but just in case... It's a neat little board that connects to your computer, Raspberry Pi or Android smartphone and turns it into an all-in-one electronics lab bench, complete with oscilloscope, signal generator and all.
The board can be purchased at the EspoTek website
The PC/Raspberry Pi software can be downloaded from GitHub Releases
The Android software can be downloaded from the Google Play store
If you’re familiar with electronics lab equipment, you can also skip most of the "Using the Interface" section, but I do recommend reading the section on “buffers” and everything in bold!
Apart from that, enjoy! Let’s move on.
Each version of the software interface is compatible with a specific version version of the board firmware. If there is a mismatch, then the software will automatically flash the required firmware and continue.
In case this goes wrong, you can enter bootloader mode and flash manually.
Bootloader mode is accessed by shorting Pin 4 from the digital out to GND. While in bootloader mode, you can update the board’s firmware and recover from potentially bad firmware updates.
On Windows, the simplest way to achieve this is to run flash.bat from your /firmware folder in your Labrador directory (C:/Program Files/EspoTek/EspoTek Labrador).
For Linux and Mac, you’ll need to download dfu-programmer and run the commands from the .bat file manually in terminal. Note that on Mac and Linux, unlike Windows you’ll want to flash the firmware ending in _0002.hex.
Video here:
https://player.vimeo.com/video/180909597
It’s for an old version of the software. I need to make a new one.
I recommend calibrating your device before doing anything else. Select Oscilloscope->Calibration and follow the on-screen instructions. During step 1, you’ll want to ensure nothing is connected. During step 2, both oscilloscope channels should be shorted to the USB connector on the board.
Some shortcuts may be different on Mac OS X.
Try pressing Command instead of Ctrl.
KEY | ACTION |
Ctrl-B | Cycles logic analyzer CH1 baudrate forward |
Ctrl-Shift-B | Cycles logic analyzer CH1 baudrate backward |
Ctrl-Alt-B | Cycles logic analyzer CH2 baudrate forward |
Ctrl-Alt-Shift-B | Cycles logic analyzer CH2 baudrate backward |
Z | Snaps display to vertical/horizontal cursors |
M | Brings up window to directly type in oscilloscope range |
C | Takes snapshot of CH1 (CSV file) |
V | Takes snapshot of CH2 (CSV file) |
Up Arrow | Scroll in (useful for laptop users w/o mouse) |
Down Arrow | Scroll out (useful for laptop users w/o mouse) |
Left Arrow | Shift trace left by 10% (add delay) |
Right Arrow | Shift trace right by 10% (reduce delay) |
Ctrl-Left Arrow | Shift trace left by 50% (add delay) |
Ctrl-Right Arrow | Shift trace right by 50% (reduce delay) |
W | Alias of up arrow key |
A | Alias of left arrow key |
S | Alias of down arrow key |
D | Alias of right arrow key |
Due to RAM and USB bandwidth limitations, each board has only two buffer resources available. Each device requires a certain amount of these buffer resources to function.
Device | Buffers needed |
Oscilloscope (375ksps, per channel) | 1 |
Oscilloscope (750ksps) | 2 |
Logic Analyzer (3Msps, per channel) | 1 |
Multimeter++ | 2 |
All other devices | 0 |
This limits which devices can be turned on at any one point in time. For example, the Multimeter and Oscilloscope cannot be turned on at the same time since this would require 3 buffers. One would need to be switched off.
The number of remaining buffers is displayed graphically in the bottom right hand corner of the screen. To free up buffer resources, devices can be switched off by unticking the box next to their name.
The oscilloscope was designed to be beginner friendly. For this reason, settings such as volts/div and attenuation have been replaced by a whole new interface.
To zoom in and out: point the mouse cursor at the area of interest and scroll. If no key is pressed, it will affect the voltage axis. If the Ctrl key is pressed, it will affect the time axis. If you’re on a laptop, you can use the up/down arrows in place of the mouse wheel.
To add cursors: click and drag. Left-click drops horizontal cursors and right-click drops vertical cursors. Relevant stats are displayed automatically, and you can focus on the area inside the cursors by selecting Oscilloscope>Range>Snap to Cursors or pressing Z.
To measure stats such as the waveform max, min, mean and RMS: enable them from the Oscilloscope>CHn Stats menu at the top. They are disabled by default because they cause display issues at low resolutions.
To AC couple: ensure that the input is connected to the AC pin on the board, and that the "AC Coupled" option is selected in the interface.
To enable 750ksps: on channel 1, select "double sample rate". The default is 375ksps.
All references shown are relative to USB GND (Pin 2 of the power supply).
This is fairly self-explanatory. Select your wave shape, frequency, amplitude, offset and you’re done. One thing that should be noted to engineers is that the offset refers to the difference between the lowest point of the wave and zero, and NOT the DC component from the Fourier series. This is to avoid confusing new users, since the positioning of this component changes depending on wave shape.
A waveform of type sin with frequency, amplitude and offset all set to 1 will produce a 1V sine wave oscillating between 1V and 2V at a frequency of 1Hz.
The logic analyzer uses the oscilloscope display to show a waveform, and can serial decode too. At the moment, only UART (8-N-1) is supported. Baudrate for serial decoding can be set by selecting Logic Analyzer > UART CHn in the top menu. SPI and I2C don’t work yet.
Unlock, drag the slider, re-lock. Bob’s your Uncle.
The multimeter measures the difference between the oscilloscope CH1 and CH2 pins, and uses 12-bit samples at 375ksps. The normal oscilloscope uses 8-bit samples only, so sometimes the multimeter will function as a better oscilloscope than the oscilloscope will!
**To measure voltage: **set the mode to "V" and connect the load in parallel to Pin 1 of Oscilloscope CH1 and Oscilloscope CH2.
To measure current: set the mode to "I" and connect the load in series to Pin 1 of Oscilloscope CH1 and Oscilloscope CH2. Add a reference resistor across Pin 4 of the two oscilloscope channels that:
-
Is at most 10% of the load resistance.
-
Will have a drop of at least 50mV.
Then type in the reference resistance used into the box.
As an example, if you are measuring the current through a circuit that you suspect draws 50mA from a 3.3V source, you can guesstimate its load resistance to be 66Ω (V=IR). 10% of this is 6.6Ω. To drop 50mV, you’ll need to use at least a 1Ω resistor. So the reference resistor you’ll need for this circuit should be in the range of 1Ω-6.6Ω Ohms. A 2.8Ω or 3.3Ω resistor will be ideal in this case.
**To measure resistance/capacitance: **connect your load to Pin 4 of oscilloscope CH1 and CH2. Connect Pin 1 of Oscilloscope CH1 to Pin 3 of the signal generator. Connect your reference resistor between Pin 1 of Oscilloscope CH2 and GND.
For resistance, you’ll want to aim for a reference resistor as close to the load resistance as possible. To be more accurate, you may want to take multiple measurements.
For capacitance, you’ll want to choose a reference resistor that gives you an RC time constant of about 1ms.