UKHAS Wiki

UK High Altitude Society

User Tools

Site Tools


guides:raspberrypi

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revisionPrevious revision
Next revision
Previous revision
guides:raspberrypi [2012/07/04 10:38] daveakeguides:raspberrypi [2014/11/03 20:56] (current) realflash
Line 3: Line 3:
 The pi is an interesting device though hardly ideal for use as a tracker.  For example: The pi is an interesting device though hardly ideal for use as a tracker.  For example:
  
-It needs about 500mA to run.  That's 5-10 times what a normal complete tracker uses.+Model B needs about 450mA to run.  That's 5-10 times what a normal complete tracker uses.  Model A is better at 115mA
  * It's a bit large and heavy compared to most Arduinos  * It's a bit large and heavy compared to most Arduinos
- * It runs Linux which is not a real-time operating system+ * It has an SD card poking out of the end (delicate) 
 + * It will take some effort and Linux knowledge to run a real-time kernel on it
  * Unlike the Arduino you don't have a large selection of shields to choose from  * Unlike the Arduino you don't have a large selection of shields to choose from
  
Line 35: Line 36:
  
  
-This is a 0.1" pitch connector with 2 rows.  You can find the pinouts on the web.  The important ones are the 5V, 3.3V and GND lines, plus the serial port Tx and Rx pins.  You can buy little prototyping boards quite cheaply on ebay, or just pie some pin headers and cut a small piece of veroboard to fit.+This is a 0.1" pitch connector with 2 rows.  You can find the pinouts on the web.  The important ones are the 5V, 3.3V and GND lines, plus the serial port Tx and Rx pins to connect to the GPS (or you could use i2c with some GPS modules).  You can buy little prototyping boards quite cheaply on ebay, or just buy some pin headers and cut a small piece of Veroboard to fit.
  
-You can put the tracker components on here, but I suggest you put the GPS receiver somewhere else to avoid picking up RFI from the pi.+You can put the tracker components on here, but I suggest you put the GPS receiver somewhere else to avoid picking up RFI from the Pi.
  
  
Line 43: Line 44:
  
  
-The pi runs from 5V at about 450mA (before you start adding anything).  This can be delivered by the Micro-USB power connector, or to the GPIO connector.  In a payload, this could come from a set of AA lithiums and a suitable regulator.  Remember that you'll need to supply an average of 500mA or so, meaning that those cells will only last about 5 hours unless you parallel them or use plenty in series with a switching regulator.+The Pi model B runs from 5V at about 450mA (before you start adding anything).  This can be delivered by the Micro-USB power connector, or to the GPIO connector.  In a payload, this could come from a set of AA lithiums and a suitable regulator.  Remember that you'll need to supply an average of 500mA or so, meaning that those cells will only last about 5 hours unless you parallel them or use plenty in series with a switching regulator.
  
-The pi has various onboard voltages fed from regulators.  The only one we're interested in is the 3.3V line because that's handy for running the GPS etc.  However there's only supposed to be 50mA spare from this line, so you will probably be better off supplying 3.3V from your own regulator.  If you do this, consider using a switching regulator to supply the GPS etc and the pi (remove the onboard regulator and insert your 3.3V on the GPIO connector).  There's an article on the internet about this.+The Pi has various onboard voltages fed from regulators.  The only one we're interested in is the 3.3V line because that's handy for running the GPS etc.  However there's only supposed to be 50mA spare from this line, so you will probably be better off supplying 3.3V from your own regulator.  If you do this, consider using a switching regulator to supply the GPS etc and the pi (remove the onboard regulator and insert your 3.3V on the GPIO connector).  There's an article on the internet about this
 + 
 +Unless you're using USB devices, you DO NOT need to supply 5V to the Pi - thee whole thing will run happily from 3.3V and an external regulator.  To do this, remove the existing 3.3V regulator (or just snip off the 2 legs) and apply 3.3V tot he 3.3V AND 5V lines from your regulator.  Your two options then are to use a real LDO (the PI one is rubbish and has a 1.12V dropout) such as the MCP1825S, then run that from 4 Lithium cells.  Second option is to use a switching regulator and more cells (the switchers tend to have a higher dropout).  Either way, calculate your expected run time and then test it.
  
  
 ===== Serial ===== ===== Serial =====
  
-The pi has a serial port brought out to the GPIO connector.  It has 3.3V logic levels so can be connected directly to a GPS receiver.  However, by default (on Debian at least) this port has getty (login) running on it.  To stop that, edit inittab and comment out the line for this serial port (/dev/ttyAMA0).+The Pi has a serial port brought out to the GPIO connector.  It has 3.3V logic levels so can be connected directly to a GPS receiver.  However, by default (on Raspbian at least) this port has getty (login) running on it.  To stop that, edit inittab and comment out the line for this serial port (/dev/ttyAMA0).
  
 The port is also used for kernel log output.  You need to turn that off too.  Again, check the web for info. The port is also used for kernel log output.  You need to turn that off too.  Again, check the web for info.
Line 57: Line 60:
 ===== Radio ===== ===== Radio =====
  
-Linux isn't a real time operating system, and therefore does not provide accurate timing that you can use in a tracker application to generate rtty.  If you have a beard and sandals you may scoff at this challenge, muttering about "kernel drivers" and "timer interrupts" If so, have fun.  For the rest of us, it's possible to cheat and use the serial port to send rtty directly to an NTX2 radio transmitter.  You'll need a series resistor to set the frequency gap, and bias resistors to set the voltage offset, just as you would when using a single pin on an Arduino.+Linux isn't a real time operating system, and therefore does not provide accurate timing that you can use in a tracker application to generate rtty.  If you have a beard and sandals you may scoff at this challenge, muttering about "kernel drivers" and "timer interrupts" If so, head to the [[guides:raspberrypi_advanced|Advanced]] page and have fun.  For the rest of us, it's possible to cheat and use the serial port to send rtty directly to an NTX2 radio transmitter.  You'll need a series resistor to set the frequency gap, and bias resistors to set the voltage offset, just as you would when using a single pin on an Arduino.
  
 You're now probably wondering how to connect the pi to a GPS now that we've used the serial port for the radio.  The pi does have more than one serial port however (as far as can tell) you can only map one at a time to the GPIO connector.  So without some hardware hackery we only have one port available.  My solution was to share that port between NTX2 and GPS.  i.e. Tx goes to the NTX2 and Rx to the GPS.  This means the GPS cannot be "talked to" so I used a Lassen which needs no initialisation.  You could use a UBlox, but you'd then need to connect Tx to the NTX2 and GPS, meaning that those initialisation strings will go out over the air too.  Not a big problem really. You're now probably wondering how to connect the pi to a GPS now that we've used the serial port for the radio.  The pi does have more than one serial port however (as far as can tell) you can only map one at a time to the GPIO connector.  So without some hardware hackery we only have one port available.  My solution was to share that port between NTX2 and GPS.  i.e. Tx goes to the NTX2 and Rx to the GPS.  This means the GPS cannot be "talked to" so I used a Lassen which needs no initialisation.  You could use a UBlox, but you'd then need to connect Tx to the NTX2 and GPS, meaning that those initialisation strings will go out over the air too.  Not a big problem really.
  
-Typically we run the radio at 50 baud.  This is possible on the pi but when I tried it it worked for a few characters only.  I've had better results with 300, 600 and 1200 baud.  The Lassen runs at 4800 baud normally and cannot be switched that low, so this means that the tracker program needs to switch baud rates to read the GPS, then switch before transmitting.  And then back again.  So this all imposes some down-time between transmissions.+Another option would be to connect to the GPS using a different serial connection - i2c or SPI.  If you use i2c with a UBlox receiver you'll find it doesn't work, because the UBlox does "clock stretching" at arbitrary times, and the Pi ii2c driver doesn't handle that.  You may have to resort, as I did, to using a software "bit-banging" i2c implementation. 
 + 
 +Another option would be to use a PL2303 (USB To Serial) device. It's cheap (1€) and quite light. This is working great to discuss with the radio (NTX2) or with the GPS (Ublox). It has been used successfully for UGGY payload with 150 bauds for the radio. For the Ublox that have 3.3V logic, check if your PL2303 is 3.3V or 5V logic and adjust if needed (in case you still power the Pi with 5V). There is a Pin of the chip to unplug from the 5V, and plug to the 3.3V to change the serial logic. 
 + 
 +Typically we run the radio at 50 baud.  This is possible on the pi but when I tried it it worked for a few characters only.  I've had better results with 300, 600 and 1200 baud.  The Lassen GPS runs at 4800 baud and the UBlox at 9600 and neither can be reprogrammed down to low speeds, so this means that the tracker program needs to switch baud rates to read the GPS, then switch before transmitting.  And then back again.  So this all imposes some down-time between transmissions.
  
  
Line 69: Line 76:
  
 There are issues however.  #1 is that by default, Debian doesn't include the necessary driver, so whilst it will "see" your webcam as a device, it won't install it as a video device.  There's a patch available on the web to sort this.  Or you could try a different distribution (Arch seems favourite for webcam users). There are issues however.  #1 is that by default, Debian doesn't include the necessary driver, so whilst it will "see" your webcam as a device, it won't install it as a video device.  There's a patch available on the web to sort this.  Or you could try a different distribution (Arch seems favourite for webcam users).
 +
 +** Update **
 +
 +Raspbian includes the driver, so the webcam will "just work" if it's a compatible model.
  
 Next, only some webcams work.  Check the rpi hardware compatibility list.  Logitechs should all be OK. Next, only some webcams work.  Check the rpi hardware compatibility list.  Logitechs should all be OK.
  
 Finally, many webcams need a bit more, or a lot more, than the 140mA allegedly available.  This is because each USB port has a thermal fuse that will limit the current supplied to 140mA.  At this point the 5V at the port will be about 3V, and the webcam is likely to give up or restart.  100mA is probably a more realistic limit.  Of course the fuse can be bypassed with a bit of soldering, which is what I did (my C920 webcam peaks at over 200mA when it focusses). Finally, many webcams need a bit more, or a lot more, than the 140mA allegedly available.  This is because each USB port has a thermal fuse that will limit the current supplied to 140mA.  At this point the 5V at the port will be about 3V, and the webcam is likely to give up or restart.  100mA is probably a more realistic limit.  Of course the fuse can be bypassed with a bit of soldering, which is what I did (my C920 webcam peaks at over 200mA when it focusses).
 +
 +** Update ** As of September 2012 the model B rev 2 board is being shipped.  The 2 USB thermal fuses have been removed from the board, meaning that high power USB peripherals can be used without any soldering.
  
 Once the webcam is connected it should appear as /dev/video0.  The next step is to install something that can take photos and/or video which can be stored on the SD card and, in the case of jpg images, sent down through the radio link.  I tried uvcconnect, streamer and fswebcam, and can only recommend the latter, and not only because it was written by fsphil of this parish. Once the webcam is connected it should appear as /dev/video0.  The next step is to install something that can take photos and/or video which can be stored on the SD card and, in the case of jpg images, sent down through the radio link.  I tried uvcconnect, streamer and fswebcam, and can only recommend the latter, and not only because it was written by fsphil of this parish.
  
-If you're storing the images/video, then you'll soon find the SD card fills up.  The default Debian image (and I assume the others) occupy about 2GB, with a partitioning scheme that leaves the rest of you 4/8/16GB card unused.  Check the web for options to either extend the main partition or add an extra one in the free space.  If you do the latter, make sure you save the images to the new partition!+If you're storing the images/video, then you'll soon find the SD card fills up.  The default Debian image (and I assume the others) occupy about 2GB, with a partitioning scheme that leaves the rest of your 4/8/16GB card unused.  Check the web for options to either extend the main partition.  In Raspbian this is really easy.
  
-If you want to send live images down to the ground (and if not, why not?), then there is some documentation in the wiki but the simplest option is to use fsphil's encoder program.  This converts your jpg file to a format which can be sent directly over the rtty link.  Some notes on this:+If you want to send live images down to the ground (and if not, why not?), then there is some documentation in the wiki but the simplest option is to use fsphil'SSDV encoder program.  This converts your jpg file to a format which can be sent directly over the rtty link.  Some notes on this:
  
  * I suggest you send 1 block (256 bytes) at a time, and that after sending you close the port (which in the case of close() in C means waiting for the bytes to get sent), then re-open the port.  Buffering anomalies may happen otherwise.  * I suggest you send 1 block (256 bytes) at a time, and that after sending you close the port (which in the case of close() in C means waiting for the bytes to get sent), then re-open the port.  Buffering anomalies may happen otherwise.
Line 86: Line 99:
  * Make sure the serial port isn't doing NL --> CRNL conversion or similar (otherwise your binary image data is going to get messed up).  * Make sure the serial port isn't doing NL --> CRNL conversion or similar (otherwise your binary image data is going to get messed up).
  
 +** Update **
 +For those using the PiCAM and Python there is a python module giving access to the camera rather than having to use os.system. This provides a cleaner interface and will potentially be much faster.
 +
 +Write up on raspberrypi.org can be found at [[http://www.raspberrypi.org/archives/5672]] with installation details at the bottom of the page.
 +
 +The project details are available on [[https://pypi.python.org/pypi/picamera/|PYPI]] and [[https://github.com/waveform80/picamera/|GitHub]]. The module is also installable via ''apt-get install python-picamera'' or ''apt-get install python3-picamera''
  
 +**Update - NEW RASPBERRY PI ADD-ON BOARD**
 +If this all sounds a bit too much work, you can use Dave & Anthony's [[http://www.pi-in-the-sky.com/|PITS]] add-on board for the Raspberry Pi!
guides/raspberrypi.1341398338.txt.gz · Last modified: 2012/07/04 10:38 by daveake

Donate Powered by PHP Valid HTML5 Valid CSS Driven by DokuWiki