Featured Engineer
Dave Vandenbout
Dave Vandenbout - President at XESS Corp.
How did you get into electronics/ engineering and when did you start?
I remember drawing a radio-controlled robot in kindergarten and all the teachers thought I would be an engineer.
Much later, I took an electronics class in high school which was really a shop class for all the kids too dumb to get into auto mechanics. One of my friends actually had his hair set on fire in class. But we learned about basic circuits and actually built FM radio transmitters. I learned some transistor circuits from Radio Shack books and I built some light-activated burglar alarms and such.
Most of my university coursework was theoretical. I actually learned more about practical electronics from the technicians I worked with at Bell Labs in the early ’80s. That where I learned to wire ICs together to make Z80 and MC6801 microcomputer systems.
What are your favorite hardware tools that you use?
Probably my most-used tool is a Tektronix 475 oscilloscope that I bought used back in 1994. It’s good for getting a quick look at a signal and making sure everything is reasonable.
On the digital side, having a wide variety of simple, low-cost development boards with PC interfaces is great. My favorite is the XuLA FPGA board I designed. I can drop an FPGA and large memory into a 2 in^2 area of a breadboard along with a bunch of other stuff and then query it through a USB cable from a PC. That’s the kind of thing I used to pay thousands for and now it’s available for less than $50.
What are your favorite software tools that you use?
Certainly the free FPGA development tools are one. Now anyone can get the tools to do sophisticated digital design.
I also like the Eagle schematic/PCB tool because it lets me design pretty sophisticated boards for a relatively low cost. And I can extend it by writing user-language programs to do stuff like BGA fanout.
On the open source side, Octave is great because it gives me something like Matlab without the Matlab price. The same goes for things like LibreOffice and Inkscape. And I’m really getting to like Python as a general-purpose programming language that’s easy to code, runs pretty fast, and has great libraries like SciPy.
What is the hardest/trickiest bug you have ever fixed?
Back in 1984, I was in a group of four grad students who designed and built the HECTOR 16-bit microprocessor chip. The chip design tools were pretty primitive (we were laying out most of the actual transistors by hand – all 20,000 of them) so we settled on a microcode-based CPU because it’s functions could be changed just by altering the ROM (there was an automated tool for building that part). But the ALU and register file were always changing and that prevented the microcode guy from writing his code. So I designed a microcode compiler that took high-level versions of the microcode and CPU architecture and used a recursive expression re-writer to search for a set of low-level register transfer operations that would implement each high level microcode statement. Then we could just update the high-level CPU model as the design changed and recompile the microcode. That was one of the things that let us accomplish the design within a single semester.
What is on your bookshelf?
A lot of my books are free PDF files I’ve gotten off the web, like “Global Optimization Algorithms” by Thomas Weise and “Information Theory, Inference, and Learning Algorithms” by David MacKay. But if you’re talking about physical books, then I have “The VNR Concise Encyclopedia of Mathematics” and a 1927 edition of “Peppi the Duck”.
Do you have any tricks up your sleeve?
Many of my designs have an FPGA, so I like to use that to test portions of the design as they become available. I use a library of VHDL modules to upload and download data through the FPGA’s JTAG port as it’s running and talking to other parts of the system. It’s sort of the hardware equivalent of using “printf” statements in code debugging. It doesn’t have the capabilities of using a logic analyzer, but it’s easier to setup and format the resulting data so you can understand what’s going on.
For design in general, I always like to draw a picture of my system to show what’s interacting with what. I try to use simple models of components so I can mentally simulate how I think the total system should respond. Then if the system isn’t even doing that correctly, I know I have a large error in my understanding or my construction that should be easy to find. Once the major functions are working, then I’ll use more precise instruments and simulators to see if the details are correct.
What has been your favorite project?
I was involved in the second (or third?) neural net revolution back in the late ’80s through the early ’90s. I designed and built three neural network chips and did a bunch of theoretical work on statistical mechanics and solving optimization problems. It was a pretty hot topic at the time and everyone was competing to be the one who was going to change the world. It was fun but, like the first few neural net revolutions, it collapsed when it couldn’t live up to its own hype. That was a valuable lesson to learn as well.
Do you have any note-worthy engineering experiences?
When I was young, I once stuck the wires of a small neon bulb into a wall socket. I believe that may have been the first example of caseless, electrically-fired ammunition, because that bulb shot out and buried itself in the opposite wall. It also blackened the socket so, to keep my mother from finding out, I replaced it while the power was still on because there was no way I was going into the far corner of that dark basement to remove the fuse.
What are you currently working on?
I’m currently writing a book to teach FPGA design to beginners using the XuLA board as a training device. It’s called “FPGAs!? Now What?” and I’m releasing each chapter as it’s written. It’s under a Creative Commons Attribution-ShareAlike license so anyone can download it, modify it, sell it, whatever, as long as they don’t remove my name. If anyone makes any money from it, let me know. That would be a first.
What direction do you see your business heading in the next few years?
When I started XESS, all my board schematics and software utilities were open source, but the actual PCB design files were closed. Now, beginning with the XuLA board, I’m open-sourcing everything. One of my friends asked me what recourse I had if my stuff was just copied and sold by others without any payment to me. I repeated to him what a university colleague told me once: “Don’t worry about other people stealing your ideas. You’re going to have to work like hell just to get other people to notice them!”
What challenges do you foresee in our industry?
There are all the normal, physical challenges like reducing semiconductor gate widths and lowering power requirements, but these are manageable. We’ve been doubling computer power every year or two since Charles Babbage, and there’s no reason to expect that to stop. We may be on the upper, flatter portion of the silicon S-curve, but we’ll eventually jump to another technology when that one plays out. After all, the universe is supposedly made up of 96% dark energy + dark matter, neither of which has ever actually been detected, so there must be a lot more tricks in the goody bag the universe has given us.
Then there are challenges created by our success with semiconductors, such as making effective use of parallel computing and managing code complexity. But the semiconductor S-curve has made computing so much cheaper and more accessible that we have many more people who can tinker with it and come up with new languages and abstractions that help hide the underlying complexity and let us work at a higher level. That’s one of the great benefits of open technologies: you get so many more pairs of eyes looking at this stuff and working on the problems.
But while the challenges our industry faces are manageable, I think we’re actually creating a serious challenge for the rest of society: with advances in communications, AI and robotics, we are rapidly reducing the number of workers necessary to provide everyone with goods and services. It seems we can either increase the demand for stuff that people want and put a lot of strain on our planetary resources, or else condemn a large part of our population to a life where they can’t participate in the global economy. We’re already seeing the instability that results from the second option and it’s going to be this century’s primary problem, much more so than other supposed crises that get so much attention. I’m no sociologist so I have no idea how to address this issue, but I hope somebody’s thinking about it.
What are your favorite websites?
Besides EEWeb…
I’ve like listening to some electronics/tech-related podcasts that have started in the past year like “The Amp Hour” and “ZombieTech”. They delve a lot more into the actual workings of technology than the usual consumer gadget shows, and they’ve got a much fresher tone than the more commercial stuff being put out by the established trade press.
Outside technology, I like noagendashow.com because it picks up a lot of news items that don’t enter the mainstream consciousness for months.
When I need a mental challenge, I like to go to projecteuler.com and try to solve one of their puzzles. Even when I can’t find a solution, it still makes me think in a different way than my normal work does.
What advice would you give to others?
All our good habits form before age 15 so anyone reading this is probably beyond help, but here goes: Exercise regularly, take care of your teeth, and learn a lot about math.
Any final words?
Don’t mistake being humorless for being serious.
Previous Spotlights
- Interview with Frits Lyneborg
- Interview with Forrest Cook
- Interview with Radu Motisan
- Interview with Eria Lopez
- Interview with Kevin Parmenter
- Interview with James Hutchby
- Interview with Nury Ramirez
- Interview with Chris Troutner
- Interview with Jebadiah Moulton
- Interview with Jinbuhm Kim
- Interview with João Azevedo
- Interview with Lim Phang Moh
- Interview with Martin Harizanov
- Interview with Randy Sarafan
- Interview with Frederic Vecoven
- Interview with Dan Julio
- Interview with Carlos Asmat
- Interview with Will Faehse
- Interview with Sergio Garcia de Alba
- Interview with Pepe Ruiz
- Interview with Nirmal Patel
- Interview with Mindaugas Marozas
- Interview with Kate Cummings
- Interview with Shrenik Shikhare
- Interview with Mohammad Hossain Mohammadi
- Interview with Steve Spence
- Interview with Amir Rahemtulla
- Interview with William York
- Interview with Valeria Vercesi
- Interview with Chris Zeh
- Interview with Arinze Ekwosimba
- Interview with Mehmet Er
- Interview with Mohamed Sherief
- Interview with Ana Sanchez
- Interview with Sergiu Baluta
- Interview with Kévin Sartor
- Interview with Amr Hassaan
- Interview with Yahya Ezzeldin
- Interview with Patricio Berbel Cifuentes
- Interview with Jonathan Lockhart
- Interview with Ian Lesnet
- Interview with Ahmed El-Sharkasy
- Interview with Daniel Shipps
- Interview with Stephan Zizala
- Interview with Alfredo Bravo Iniguez
- Interview with Adrian Rothenbuhler
- Interview with Candice Patton
- Interview with Brian Petted
- Interview with Kyle Olive
- Interview with Nicholas Abi-Samra
- Interview with Jason Toms
- Interview with Amal Easow
- Interview with Dhaman Singh
- Interview with Mike Copeland
- Interview with Siamak Ebadi
- Interview with Nita Patel
- Interview with Samta Bansal
- Interview with David Touvell
- Interview with Kenny Dacumos
- Interview with Gianluca Antonelli
- Interview with Tim Jenks
- Interview with Benjamin Walsh
- Interview with Gabriel Alfonso Rincón-Mora
- Interview with Dr. Marc Perron
- Interview with Karen Panetta
- Interview with Matt Rogers
- Interview with Bob Heile
- Interview with Rob Riemen
- Interview with Steve Noall
- Interview with Scott T. Lowe
- Interview with Jess Lee
- Interview with Alex Toombs
- Interview with Robert Peruzzi
- Interview with Ramana Kumar Vinjamuri
- Interview with Andrew Yaung
- Interview with Polina Bayvel
- Interview with Vikas Vinayak
- Interview with Sandeep K. Shukla
- Interview with Stavan H. Dholakia
- Interview with Alan Kraemer
- Interview with Scott Nelson
- Interview with Ranjit Deshpande
- Interview with Ram Bhatia
- Interview with Mike Holt
- Interview with Paul Tindall
- Interview with Mike Kappes
- Interview with Andrew Bluiett
- Interview with Ahmad Bahai
- Interview with Tony Salcedo
- Interview with Jaanus Kalde
- Interview with Billie Johnson
- Interview with Sailesh Chittipeddi
- Interview with Brad Cleveland
- Interview with David M Herbert
- Interview with Bob Burns
- Interview with Frank Donald
- Interview with Marcus Ryle
- Interview with Trent Hanson
- Interview with Bogdan Firtat
- Interview with Roy DCruz
- Interview with Alan Gotcher
- Interview with Meenu Sarin
- Interview with Jim Fitzpatrick
- Interview with Russ Dauer
- Interview with Adam Espeseth
- Interview with Bill Hall
- Interview with Bruce Bateman
- Interview with Kowsik Guruswamy
- Interview with Michael Schuette
- Interview with Chris Vermillion
- Interview with Rod Callison
- Interview with Jean Wlodarski
- Interview with Rupert Hirst
- Interview with Robi Thomas
- Interview with Paul Stevenson
- Interview with Barry Katz
- Interview with Denis Hennessey
- Interview with Ken Gracey
- Interview with Mark Majewski
- Interview with Russell Shyur
- Interview with Rodrigo Feliciano
- Interview with Parviz Ghaffaripour
- Interview with Todd DeBoer
- Interview with Charalampos Doukas
- Interview with Al Williams
- Interview with Mike Paganini
- Interview with Joe Grand
- Interview with Joonas Pihlajamaa
- Interview with Karen Cheung
- Interview with Parker Dillmann
- Interview with Christophe Basso
- Interview with Andrei Muller
- Interview with Frank van Graas, Maarten Uijt de Haag, and Wouter Pelgrum
- Interview with Mike P. O’Keeffe
- Interview with Dr. Kent Lundberg
- Interview with Doug Jacobson
- Interview with Beth Cooper
- Interview with Manimaran Govindarasu
- Interview with Koray Ҫelik
- Interview with Eamon McErlean
- Interview with Bob Riley
- Interview with Tamara Schmitz
- Interview with Guy Eschemann
- Interview with Kevin Loughran
- Interview with Eli Hughes
- Interview with Sophi Kravitz
- Interview with Jim Sealock
- Interview with Michael Krumpus
- Interview with Dr. Roman V. Yampolskiy
- Interview with Zhong Lin (ZL) Wang
- Interview with Dr. Ted Moise
- Interview with Ferenc Marki and Christopher Marki
- Interview with Alan Winstanley
- Interview with Michael Parks
- Interview with Will Lyon
- Interview with Seth Prentice
- Interview with Russ Croman
- Interview with Bryan Bergeron
- Interview with Scott Carey
- Interview with Lee Evans
- Interview with Tim Weaver
- Interview with Michael McNamara
- Interview with Karl F. Böhringer
- Interview with Bill Eisenhamer
- Interview with John P. Kiffmeyer
- Interview with Ayman Kabire
- Interview with Jean-Louis Malinge
- Interview with Paul Peng
- Interview with Alan Parekh
- Interview with David Rea
- Interview with Mike Lugert
- Interview with Anthony Catalano
- Interview with Kerry D. Wong
- Interview with Brad Boegler
- Interview with Terry D. Kozlyk
- Interview with Joe Kryzak
- Interview with Laurent Desclos
- Interview with Julián da Silva Gillig
- Interview with Glenn Ray
- Interview with Dr. Robert S. Balog
- Interview with Todd Westerhoff
- Interview with Dr. Katie Hall
- Interview with Dr. Steve M. Rohde
- Interview with Jac Goudsmit
- Interview with Patrick Ryan
- Interview with Jayson Tautic
- Interview with David Arthur
- Interview with Jeff Shamblin
- Interview with Javier Baliñas Santos
- Interview with Frédéric Leens
- Interview with Jay Whitacre
- Interview with Karen Bartleson
- Interview with Leslie Perjes
- Interview with Dave Rich
- Interview with Rolando Calla Zalles
- Interview with Jim Miller
- Interview with Dave Baarman
- Interview with Alan Wolke
- Interview with Bill Marshall
- Interview with Josip Medved
- Interview with Trish Messiter
- Interview with Fred Dart
- Interview with Tom Harvey
- Interview with Chuck Mullett
- Interview with Victor Aprea
- Interview with Rakesh Dhawan
- Interview with Joe Keating
- Interview with Bob Davis
- Interview with Troy Rank
- Interview with Amber Alexandru
- Interview with Robert Feranec
- Interview with Ian Walter
- Interview with Andrew Back
- Interview with Thomas Wagner Nielsen
- Interview with Chris Young
- Interview with Matthew Beckler and Adam Wolf
- Interview with Dr. José Fernández Villaseñor
- Interview with Andy Collinson
- Interview with Alexander Lang
- Interview with Joel Avrunin
- Interview with Ernest Godsey
- Interview with Jim Hargrove
- Interview with Joe Desposito
- Interview with Andrew Howard
- Interview with Allen B. Downey
- Interview with Mitchell Davis
- Interview with Geir Førre
- Interview with Mark Harrington
- Interview with Jack Ganssle
- Interview with Dr. Tiziana C. Bond
- Interview with Steve Norris
- Interview with Dermot O’Shea
- Interview with Amr Ali Abdel-Naby
- Interview with Nathan Dumont
- Interview with Dave Young
- Interview with Joshua Bishop
- Interview with Jeff Smoot
- Interview with Peter Christensen
- Interview with Rick Faehnrich
- Interview with Yao Zhao
- Interview with Mike Burr
- Interview with Michael Hoff
- Interview with Rodrigo Almeida
- Interview with Jordan McRae
- Interview with Alexander Balandin
- Interview with Jamie Cunningham
- Interview with Jean J. Labrosse
- Interview with Jeff Washington
- Interview with Jeff Crockett
- Interview with Colin Walls
- Interview with Rajendra Bhatt
- Interview with Tom Lee
- Interview with Henrik Sandaker Palm
- Interview with Mikey Sklar
- Interview with Cruz Monrreal II
- Interview with Tim Edwards
- Interview with Nathan Seidle
- Interview with Dave Lacey
- Interview with Scott Driscoll
- Interview with Bert Simonovich
- Interview with Mickey Delp
- Interview with Robin McCarty
- Interview with Robert Green
- Interview with Max Robinson
- Interview with Eduardo Viramontes
- Interview with Jose I Quinones
- Interview with Fergus Dixon
- Interview with Nicholas Skinner
- Interview with Sam Barros
- Interview with Elena Villarreal
- Interview with Liang Downey
- Interview with Bill Porter
- Interview with Aaron Clarke
- Interview with Jigish Shukla
- Interview with Dr. Adrian S. Nastase
- Interview with Duane Benson
- Interview with Jan Axelson
- Interview with Erik Cheever
- Interview with Alex Iannuzzi
- Interview with Dr. Colin Warwick
- Interview with Steve Hoefer
- Interview with Dave Vandenbout
- Interview with Adam Fabio
- Interview with Graham Town
- Interview with Mike Harrison
- Interview with Dan McMenamin
- Interview with Sean Westcott
- Interview with Todd Harrison
- Interview with Alan Mantooth
- Interview with Nihal Kularatna
- Interview with Martin Thompson
- Interview with Erica Slusser
- Interview with Massimo Merenda
- Interview with Michael Jones
- Interview with Jin Wang
- Interview with Chris Lovett
- Interview with Charles J Gervasi
- Interview with Carl Zweben
- Interview with George Kourtidis
- Interview with Brett Fox
- Interview with Michael Kleinigger
- Interview with Rob Gray
- Interview with Sanjeev Gupta
- Interview with Dave Divins
- Interview with Jim Marinos
- Interview with Mike Jouppi
- Interview with Peter J Francis
- Interview with Kenneth Finnegan
- Interview with Trishan Esram
- Interview with Dr. Ali Bazzi
- Interview with Carmen Parisi
- Interview with Michael Isaacson
- Interview with Peter Hayles
- Interview with Ray Salemi
- Interview with Chris Styles
- Interview with Allan Evans
- Interview with Michael Schmid
- Interview with Vincent Greb
- Interview with Dr. Ahmed Sayed-Ahmed
- Interview with Bruce Carter
- Interview with Laura Marlino
- Interview with Abhijit D. Pathak
- Interview with Jeff Crystal and Phillip Stearns
- Interview with Bogdan T. Bucheru
- Interview with Paul Hopwood
- Interview with Chris Atkins
- Interview with Dr. Miaosen Shen
- Interview with Heino R. Pull
- Interview with Todd Michael Bailey
- Interview with Anthony Esposito
- Interview with Dan Kurin
- Interview with Dr. Satish K Sharma
- Interview with Michael Hord
- Interview with Bill Peterson
- Interview with Joel Owens
- Interview with Scott Wohler
- Interview with Daniel de Souza Carvalho
- Interview with Cherish Bauer-Reich
- Interview with Deniz Erdogmus
- Interview with Neil Gruending
- Interview with Dr. Albert Helfrick
- Interview with Jessica Barber
- Interview with Jeritt Kent
- Interview with John Woodgate
- Interview with Dr. Kenny Ricks
- Interview with Bob Davidson
- Interview with Geoffrey Orsak
- Interview with Sam Nicaise
- Interview with Mathew Lee
- Interview with Idan Beck
- Interview with John Ladd
- Interview with Dino Segovis
- Interview with Sam Wurzel
- Interview with John Hottenroth
- Interview with Dr. Mahasweta Sarkar
- Interview with Peter Ateshian
- Interview with Daniel Lee
- Interview with Charles Fulks
- Interview with Mark Yim
- Interview with Dr. Steve Parker
- Interview with Dr. David S. Touretzky
- Interview with Eric Holland
- Interview with Dr. Sherif Abdelwahed
- Interview with Andrew Y.J. Szeto
- Interview with Greg Atkinson
- Interview with Dr. Michael Wakin
- Interview with Ketan Rasal
- Interview with Ben Coughlan
- Interview with Selim Ünlü
- Interview with Chuck Alpert
- Interview with Dr. Joel Kubby
- Interview with Sasha Zbrozek
- Interview with Fatemeh Afghah
- Interview with John Boxall
- Interview with Abolfazl Razi
- Interview with Chris Savage
- Interview with Paul J. Clarke
- Interview with Jeff Keyzer
- Interview with Ray Andraka
- Interview with Peter B. Green
- Interview with Dr. Holger Schmidt
- Interview with Jeremy Blum
- Interview with Thomas Adamek
- Interview with Stephen Lau
- Interview with Gerhard Klimeck
- Interview with Dr. Howard Johnson
- Interview with Dr. Taufik
- Interview with Daryl Gerke
- Interview with Bob Pease
- Interview with Rob Gosnell
- Interview with Laura Bica
- Interview with Zach Hoeken Smith
- Interview with Dr. Jason Vaughn Clark
- Interview with Robert Bleidt
- Interview with Ehsan Afshari
- Interview with Kassy Lum
- Interview with Roshan Baliga
- Interview with Bill Messner
- Interview with Richard Mellitz
- Interview with Shiv Biddanda
- Interview with Zach Jacobs
- Interview with Olin Lathrop
- Interview with Christof Teuscher
- Interview with Dr Stavros Iezekiel
- Interview with Dr. Rainee N. Simons
- Interview with Chris Gammell
- Interview with Randy Paul
- Interview with Alex Wyglinski
- Interview with Dr. Deepak Kumar
- Interview with Philip Kornreich
- Interview with Dr. Carlos E. Saavedra
- Interview with Bill Kimmel
- Interview with Rick Sturdivant
- Interview with Seth Hollar
- Interview with Nick Such
- Interview with Arpita Sinha
- Interview with Limor Fried
- Interview with Dean Klein
- Interview with Caleb Fulton
- Interview with Jochen Kronjaeger
- Interview with Charles Qing Cao
- Interview with Botao Lee
- Interview with David L. Jones
- Interview with Charan Langton
- Interview with Henry W. Ott
- Interview with John Webster
- Interview with Parul Gupta
- Interview with Mike Steinberger
- Interview with Ken Tait
- Interview with Jeri Ellsworth
- Interview with Dr. Harold Liu
- Interview with Hariharan Subramanian
- Interview with Dr. Yang Song
- Interview with Steve Weir
- Interview with Vikram Jandhyala
- Interview with William Arthur
- Interview with Chai Wah Wu
- Interview with Dr. Samir Chaudhry
- Interview with Dr. Aaron Franklin
- Interview with Per Viklund
- Interview with Dr. Yu-Ming Lin
- Interview with Doug Smith
- Interview with Tom Hausherr
- Interview with Alok Sanghavi
- Interview with Dr. Marina Koledintseva
- Interview with Doug Brooks
- Interview with Jen-Yi Wuu
- Interview with Dr. Eric Bogatin
- Interview with Dr. Martin Schauer
- Interview with Fedor G Pikus
- Interview with John D. Cressler
- Interview with Kirt Blattenberger from RF Cafe
- Interview with Gary Crowell
