Skip to content
Chris Esposito edited this page Feb 6, 2018 · 27 revisions

This wiki is a work in progress.

Licence

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 will suffice).

http://creativecommons.org/licenses/by-sa/4.0

Introduction

Welcome to the initial documentation for the EspoTek Labrador!

Please note that it’s currently in a WIP state. If you have any suggestions, please right-click and leave a comment! It’s harder than you’d think to write a guide for something you invented yourself, so any questions or suggestions help!

Note that the "Using the Hardware" section is mainly based on confused emails I got from software people. If you’re familiar with electronics, you can safely skip it.

If you’re familiar with 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 onto the setup stage.

Interface Installation

Binary releases for all 3 platforms are available here:

https://drive.google.com/open?id=0B7U0ulRLHf8cRVBkeFc2SHpUOGs

The Windows .exe installer contains both 32 and 64 bit versions.

There are separate .deb files for 32-bit and 64-bit Linux.

The OSX software is 64-bit only.

It’s recommended that you install the Linux software using the install script (not by double-clicking the .deb). If you do not use the install script, you will need to restart after installing the .deb.

The software on all platforms is in a stable state (as far as I’m aware), but there may be some minor bugs present!

Using The Hardware

Pinout

image_0

Yeah, it’s not very neat. Sorry.

If you don’t know what AC coupling is, please don’t use the AC-coupled pins. Use the DC-coupled pins instead as they don’t alter your signals.

Currently asking some folks on Fiverr to make a nicer diagram for me. Will upload when it comes through.

Connecting Your Labrador to a Breadboard

image_1

(image credit: Gianpaolo Macario)

You can connect your Labrador board as shown above. Power supply pins should go in the side rails to prevent any shorts.

Of course, if you don’t have a breadboard handy, the board can also be used without one. But where’s the fun in that?

Connecting Your Circuits to Labrador (WIP)

There are a few important things to keep in mind when using your Labrador board:

  • Labrador is a *collection of independent tools *that happen to share a single connection and software interface. Apart from small amounts of unintended crosstalk, there are no internal connections between Labrador’s different instruments!

  • All voltages are GND-referenced, with the exception of the multimeter which measures CH1 referenced against CH2. If your oscilloscope measures 5V, it means that the voltage at the node your oscilloscope pin is connected to is 5V higher than the Labrador’s GND pin (NOTE: In Electrical Engineering there is no such thing as an "absolute voltage" at all; only how much higher or lower the voltage at one particular node is compared to another. A 1.5V battery doesn’t “have” 1.5V; it just means that the positive terminal is 1.5V higher than the negative terminal.). Make sure you connect the GND point of your circuit under test to Labrador’s GND pin!

  • If you don’t know what AC coupling is, don’t use the AC-coupled pins. Use the DC-coupled pins instead as they don’t alter your signals.

  • Labrador is idiot-proof. You should be able to short any two pins together without damaging your board, and even if you do something like connecting a 12V external power supply directly to one of your digital output pins, they’ll nobly sacrifice themselves to ensure the rest of the board will still function (and you can fix it by replacing a single resistor). Experiment a bit! You can’t do too much wrong.

  • Labrador is idiot-proof, but not complete-idiot-proof! If you start touching live wires to random components on your board, I cannot guarantee what will happen. Please make sure you only connect your circuits to the external header pins, and don’t dangle live wires near the microcontroller!

A Simple Circuit Example

The simplest circuit I can think of is the voltage divider:

image_2

It transforms the input voltage Vin to the output voltage Vout according to the equation:

For example, if you used a 1k resistor for R1 and a 10k resistor for R2, the voltage at Vout would be equal to 10/11ths of the voltage at Vin.

I tested this theory in real life by building the voltage divider and connecting it to Labrador!

You can do the same. If you’ve not dealt with oscilloscopes or signal generators before, it’s the best place to start.

image_3

Above is a picture of my breadboard. The oscilloscope CH2 pin is connected directly to Vin with a standard solid-core jumper wire. The oscilloscope CH1 pin is connected to Vout. The GND node of the voltage divider is connected to the GND pin of the Labrador (NOTE: If you’re not familiar with how the connections in a breadboard work, I recommend checking out Adafruit’s tutorial. I also recommend tearing the backing off of a breadboard at least once in your life. Just make sure you have duct tape handy to put it back together again.). Vin is connected to the signal generator CH1 DC output. The resistors used were both 6.8k, meaning that the voltage at Vout should be approximately half (NOTE: I say "approximately half" because no component is 100% accurate. The resistors I used have a tolerance of +/- 1%, meaning that the actual resistance could be anywhere between 6.73k and 6.87k.) the voltage at Vin. You can do the maths if you don’t believe me.

image_4

Above is a picture of my Labrador’s software interface. I used the signal generator to output a 3V sin wave. As you can see, the yellow trace (oscilloscope CH1), is half the height of the blue trace (oscilloscope CH2). Thus, the voltage at Vout is half of the voltage at Vin!

Firmware and Bootloader Mode

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.

Using the Interface

Video here:

https://player.vimeo.com/video/180909597

It’s for an old version of the software. I need to make a new one.

Calibration

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.

Shortcuts

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

Buffers

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.

image_5

Oscilloscope

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).

Signal Generator

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.

Logic Analyzer

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.

Power Supply

Unlock, drag the slider, re-lock. Bob’s your Uncle.

Multimeter

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.