Defining a Custom Waveform - EspoTek/Labrador GitHub Wiki
Introduction
Labrador's waveform generators are fully programmable and drive an 8-bit, 1MSPS DAC with a 512-byte buffer.
This means that it's possible to define any custom wave shape you like!
To do so, you'll need to create a .tlw file.
There are some sample files located under the waveforms
directory beside the Labrador executable (on Windows, this would be C:\Program Files\EspoTek\EspoTek Labrador\waveforms
).
.tlw Files
Opening a sample .tlw file in a text editor, you will find that each file consists of three lines.
The first line defines the number of samples in the waveform. This number can range from 1 to 512.
The second line defines the "binary downsampling" parameter. For most custom waveforms, you'll want to set this to 1. Setting it above 1 allows the Labrador software to reduce the sample count in order to extend the frequency. As this is an advanced topic, it's explained at the bottom.
The third line contains a list of each of the samples, separated by tabs. Each sample should be in the range 0 to 255, where 0 represents minimum voltage, and 255 represents maximum.
For example, here is Triangle.tlw
:
128
4
0 4 8 12 16 20 24 28 32 36 40 45 49 53 57 61 65 69 73 77 81 85 89 93 97 101 105 109 113 117 121 125 130 134 138 142 146 150 154 158 162 166 170 174 178 182 186 190 194 198 202 206 210 215 219 223 227 231 235 239 243 247 251 255 255 251 247 243 239 235 231 227 223 219 215 210 206 202 198 194 190 186 182 178 174 170 166 162 158 154 150 146 142 138 134 130 125 121 117 113 109 105 101 97 93 89 85 81 77 73 69 65 61 57 53 49 45 40 36 32 28 24 20 16 12 8 4 0
_list.wfl
Once you have defined your custom waveform in a .tlw file, the last step is to add your waveform's name to _list.wfl
.
This file is also located in the waveforms
directory, alongside the sample .tlw files.
To add your custom waveform to _list.wfl
, simply add a line to the file consisting of the name of your .tlw file.
Note that the order in which the waveforms are defined in _list.wfl
is the order in which they will appear in the Labrador Software's UI.
A Note on Binary Downsampling
As the DAC is only capable of outputting 1MSPS, the maximum frequency that your waveform can be produced is limited by the sample count. For example, the maximum frequency a waveform with 500 samples can be generated at is 2kHz (2kHz * 500 samples = 1MSPS).
To get around this limitation, the in-built waveforms define use a "binary downsampling" parameter greater than 1. A binary downsampling parameter of 2 means that the software can discard every second sample in order to increase the frequency above the maximum (in our example above, it would allow the software to automatically scale the waveform to 250 samples in order to allow a maximum frequency of 4kHz. However, it would use the full 500 samples if the frequency was set to 2kHz or below).
Increasing this value to 3 would allow the software to discard more samples - in the case of our example, it would allow the software to extend the range to 8kHz by discarding all but 125 samples.
Long story short, increasing this value by 1 allows the software to halve the sample count and double the frequency.