< BeagleBoard‎ | GSoC
Revision as of 12:00, 11 March 2009 by Erikwelsh (talk | contribs)
Jump to: navigation, search

Summer code of ideas for 2009

This page collects ideas for BeagleBoard specific Google Summer of Code 2009. Some additional ideas can be found on the BeagleBoard contest page and the BeagleBoard project page.

Student proposals should expand on these projects, or students are free to propose their own project. From reading about previous Summer of Code, the key to success are people passionate about their project, so propose something that is extremely interesting to you, even if it not on the list. We will be glad to talk about your ideas on irc or the mailing list.


NEON Support for FFTW

FFTW is a library for calculating the Fast Fourier Transform. The current implementation of FFTW contains SIMD optimizations for several instructions sets. It should be possible to add optimizations for the NEON SIMD co-processor in the Beagle Board. FFTW is widely used in the open source sommunity and this project would make FFTW far more useful on processors with NEON instructions. The mentor is particularly interested in improving GNU Radio on the OMAP3 and improving FFTW performance would be very useful.

Codec Engine (C64x+) implementation of Ogg Theora

There was a Neuros GSoC project to port Ogg Theora to the C64x+ last year, but it was never finished. See the Neuros project page to understand the status.

Voice recognition integrated into Ubiquity

Integrate Mozilla Firefox, Mozilla Ubiquity, and voice recognition on the BeagleBoard with a microphone. Use of a Wiimote could provide additional interactive capabilities.

Audio-based translator

Utilizing voice recognition on the BeagleBoard with a microphone, submit text to Google Translator, then perform text-to-speech.

Spectrum analyzer using the DSP

Write a program that uses the DSP to take an alsa input and to all the math and a GUI on the arm that display the realtime spectrum. The DSP side needs to use xdais so other DSP programs can run at the same time.

USB sniffer

Come up with a USB sniffer solution. Idea is that the device to be sniffed is connected to the USB host port of the beagle and the beagle itself to the original host. The beagle will pass-trhu all usb data while logging that data. This could be a great help diagnosing USB problems or reengineering USB communication to a device (by logging the behaviour of a device when connected to a PC (software solutions for that exist too (usbsnoop), but a hardware solution could also support replay etc.

USB device audio support

The Linux USB gadget infrastructure doesn't have audio device class support (but Linux does have USB host audio support. There is some work on a gadget MIDI audio driver. Some work has been done over at Blackfin, but is reported as not working very well. Getting USB isochronous endpoint, gadget audio driver connected to audio on BeagleBoard would be beneficial to all OMAP3 isochronous USB needs, better isochronous gadget support in Linux (there are no standard gadgets test for isochronous endpoints), and a prove out a real gadget driver that requires isochronous endpoints. Anyone wanting to learn about communication protocols, a well designed layered communication implementation, and a chance to work at the driver level will enjoy this project.

Touchscreen and LCD open hardware design

BeagleBoard rev C has a new connector for attaching an LCD. The Touchscreen and LCD open hardware design project would consist of a schematic, PCB layout, and bill of materials that can be purchased easily over the Internet. On online PCB fab could make the PCBs cheaply. Only a soldering iron should be needed to populate the PCB. Once built, the user could connect the PCB to their BeagleBoard had have an LCD with touchscreen support. This project is targeted toward those interested in hardware and shouldn't require any complex software if a well supported touch screen controller chip is selected.

OpenCV DSP accelleration

Research and implement hardware acceleration for OpenCV using the DSP on beagleboard. The DSP side needs to use xdais so other DSP programs can run at the same time.

Power Aware Computing APIs

Power consumption is a major problem in mobile devices. While there are many HW level power management features in processors such as the OMAP35x, SW lacks the ability to manipulate and control those features. Research those power features and implement kernel APIs to allow applications to manage their power more efficiently.

OpenGL DSP accelleration

Research and implement OpenGL ES using the DSP on beagleboard. The DSP side needs to use xdais so other DSP programs can run at the same time.

Adding Sense to Beagle

Sensory aware applications are becoming more mainstream with the release of the Apple iPhone. This project would combine both HW and SW to add sensory awareness to beagle. First, additional modules such as GPS, 3-axis accelerometers, Gyroscopes, Temperature Sensors, Humidity Sensors, Pressure Sensors, etc, would be added to beagle to compliment the microphone input in order to allow sensing of the real world environment. Then SW APIs would need to be layered on top to allow easy access to the sensory data for use by applications.

ideas not worked out

  • Move Firefox to Cairo on OpenVG and minimize memory footprint
  • Implement OpenVG with the C64x and DMAs
  • more codecs on the dsp (e.g. mp3 encoder/decoder, mpeg2 decoder, codecs for IP telephony (with video), ...)
  • port LXDE (see
  • beagle as upnp renderer
  • beagle variant of "from 0 to 60 in 5 seconds" make a beagle that starts in < 5 seconds
  • good text to speech support
  • Clean MythTV, Boxee, XBMC, or Miro builds
  • facial recognition with depth analysis using pico projector and webcam
  • high-speed 3d scanning with pico projector and webcam
  • implementing a single pixel camera with beagleboard, pico projector and webcam; accelerate processing using DSP
  • USB class converters (MTP to mass-storage, audio to midi, ...) or invasive sniffer