Skip to main content

USB Random Number Generator

This project is about USB port base true hardware random number generator and it is design around the avalanche noise which occurred in reversed biased P-N junction.

This random number generator is design using commonly available electronic components. The core component of this system is Microchip’s PIC18F2550 microcontroller. The noise source is 2N3904 (Q1) transistor and LM386 low voltage power amplifier is used to amplify the incoming noise signals. This peripheral is design to work as a self-powered USB HID device.

Cumulative distribution graph of random number sample

In this design we use 2N3904 as a noise source because it give more noise amplitude than any another transistors which we tested. Theoretically this transistor (Q1) can be replaced with any other suitable NPN transistor like BC548, BC107, 2SC945, etc.

The control software of this system is available for Linux and it’s compiled as x86 - 32bit binary file. This controller application required libusb driver and it can be obtain from www.libusb.org. This application is working with command line parameters (e.g: sudo ./randgen 500) or through interactive user inputs (e.g: sudo ./randgen).

The valid output range of this random number generator is around 10000 to 41000. This output range is fixed and its linear distribution graph is available with the project package.

This USB random number generator is design as an open hardware project and its schematics, software source codes and detail documentation are available at google drive.

Comments

Ben Alabaster said…
Commendable effort. No doubt you will have received a ton of mixed responses to this. I'm not sure how secure this iteration is, but I think that an open source/open hardware project is much needed. This is a good start.
Robin Leffmann said…
As part of my interest in electronic music and building analog synthesizers, I came up with this exact same solution in 1999 when designing a circuit for producing frequency-tunable noise (in contrast to the usual solution of having just white and pink noise) - a simple reverse-fed transistor feeding a sample-and-hold circuit whose sample rate was controlled by a timer in order to get stepless control of the noise frequency, from white noise all the way down to a rumbling "black" noise.
Anonymous said…
Hi, any chance you could add an image of the schematic to your blog post? Thanks
Sorry, right now schematic is not available in image format. You can find PDF version of schematic at http://elect.wikispaces.com/file/view/N0044D29092013.7z/455035964/N0044D29092013.7z
Anonymous said…
(schematic). Fair enough, but I don't have 7z (or windows for 7-zip), so I guess I won't be looking at it (hence asking).
Anonymous said…
7zip is available for windows/Mac/linux, see http://www.7-zip.org/download.html.

Nice work Dilshan, I wonder how/if I could use this as an additional source of entropy for /dev/random.

Popular posts from this blog

Building the TD4 4-Bit CPU

The TD4 is a famous 4-bit CPU featured in the book How to Build a CPU by Kaoru Tonami . The book focuses on constructing a functional processor entirely from basic 74-series TTL logic ICs. While the book is unfortunately only available in Japanese, a friend from Japan sent me a copy along with a TD4 PCB. I believe the PCB is based on the open-source design files available on BG5DIW's GitHub repository . "How to Build CPU" book and the PCB. Recently, I finally found the time to build and experiment with it. The project took a few months, as I had to translate the book myself to grasp the core concepts. The overall design is simple and elegant, offering a set of 12 instructions and a 16-byte ROM (implemented via DIP switches) for programming. The board operates on 5V and can be powered via USB. Most components were sourced from local shops, though I had to order a few 74HC-series ICs online. Later, I tested the circuit by replacing some 74HC components with 74LS series...

CD2003 - yet another simple FM radio receiver

In the last few days, we are looking for some simple FM radio receiver to integrate into one of our ongoing projects. For that, we try several FM radio receiver ICs including TDA7000, CD2003/TA2003/TA8164, CXA1019, and KA22429. Out of all those chips we select CD2003 (or TA2003/TA8164) based receiver for our project because of its simplicity and outstanding performance. Except to CD2003, Sony CXA1019 also perform well but we drop it because of its higher component count. We design our receiver based on Toshiba TA2003 datasheet and later we try TA8164 and CD2003 with the same circuit. Either CD2003 or TA8164 can directly replace TA2003 IC, and as per our observations, TA8164 gives excellent results out of those 3 chips. A prototype version of CD2003 FM radio receiver The PCB design and schematic which we used in our prototype project are available to download at google drive (including pin-outs of crystal filters and inductors ). Except for CD2003 IC, this receiver consist...

Arduino superheterodyne receiver

In this project, we extend the shortwave superheterodyne receiver we developed a few years ago . Like the previous design, this receiver operates on the traditional superheterodyne principle.  In this upgrade, we enhanced the local oscillator with Si5351 clock generator module and Arduino control circuit. Compared to the old design, this new receiver uses an improved version of an intermediate frequency amplifier with 3 I.F transformers. In this new design, we divide this receiver into several blocks, which include, mixer with a detector, a local oscillator, and an I.F amplifier. The I.F amplifier builds into one PCB. The filter stage, mixer, and detector stages place in another PCB. Prototype version of 455kHz I.F amplifier. In this prototype build, the Si5351 clock generator drives using an Arduino Uno board. With the given sketch, the user can tune and switch the shortwave meter bands using a rotary encoder. The supplied sketch support clock generation from 5205kHz (tuner f...