Scratch controlling the GPIO on a RaspberryPi

This blog is now old hat – I’ve made a new version and much better instructions over in a new blog.

Click here

———————————————————————————-

This post is intended to make it as Simple as Pi to get up and running and make your RaspberryPi control some lights and to respond to switches and sensors.

Minimum Requirements – a RaspberryPi with Raspbian installed and a working internet connection, a breadboard, some Light Emitting Diodes (LEDs), some resistors and some wire connectors. Total cost £5-£10.

How to get a Rapsberry_Pi to control the GPIO Pins from Scratch
—————————————————————
Your RaspberryPi needs to be connected to the internet to install the software but not needed to run ScratchGPIO.

Copy the text below ( left click just before the s of sudo and drag right until all the text in the line, up to and including gpio.sh, as been selected) then right-click and select copy.  Open up an LX Terminal window and select Edit and the Paste that into an LX Terminal window and run it to download the installer.

sudo wget https://dl.dropbox.com/s/gery97qildl7ozd/install_scratch_gpio.sh -O /boot/install_scratch_gpio.sh

and then if using Raspberry Pi as a normal user, then just type (or copy and paste as before)

sudo /boot/install_scratch_gpio.sh

but if your logging as as a different user then type

sudo /boot/install_scratch_gpio.sh your_username

Either way will install all the necessary extra software and some simple examples.

(If you do not have internet on your Pi then,  put your SD card into a card reader and try using your browser to right-click and save the script direct to your SD card and then put it back into you Pi and run the second instruction)

Connecting Components Up
———————————————————————
EXTREME care should be taken when connecting hardware to the GPIO pins. You can cause your Pi to die by connecting the wrong things together – only do this if your confident of your ability to follow instructions correctly 🙂
AT A MINIMUM – get a breadboard and use some female-male 0.1 leads (available from lots of online suppliers or your local Maplin shop)

Check out GPIO pin guides to make sure you know what pins are what.

Wire up Pin 1 (3.3V) to (at least) a 330ohm resistor – connect that resistor to the long lead of an LED and then connect other end of LED to Pin 6 (0V).

It should light up. If it doesn’t try reversing your LED.

Now move the lead from Pin 6 to Pin 11.

Run the special Scratch icon (Scratch GPIO) on your desktop.
(It is actually a completely normal version of Scratch, it just runs a little Python background program as well that handles communications between Scratch and the GPIO and automatically enables Scratch’s Remote Sensor Connections(RSC))

To test out control from Scratch, click on File then Open and then click on the My Projects button and select blink11 and click on OK.  Once the project opens, just click on the OK to enable Remote Sensor Connections.  To run the script just click on the Green Flag.

Your LED should now blink on for 1 second and off for 2 seconds – see trouble shooting if this doesn’t happen.

What more can I do with Scratch and the GPIO

You can control seven pins as outputs (Pins 11,12,13,15,16,18,21) and treat seven as simple inputs (7,8,10,19,22,24,26)

As you can see in the blink11 script , you can simply use a broadcast message telling Pins to go on or off (Up to 3.3V and down to 0V)

The valid messages are pin11on, pin12on, pin13on, pin15onpin16on, pin18onpin21on along with the corresponding pin11off etc messages.

You can also say allon and allloff.

And you can replace the work on with high and replace off with low if you want to talk in pure logic levels.

You can combine msgs together to make a single broadcast so to turn Pin11 and Pin13 on and all others off you can say

broadcast pin11on pin12off pin13on pin15off pin16off pin18off pin21off

or

broadcast alloff pin12on pin13on

to switch pins 12 and 13 on.  Alternatively you can use the pinpattern broadcast to achieve the same result e.g:

broadcast pinpattern110

This will also set just pins 12 and 13 on.

To check an input, you should go into the Sensing block and click on the word “slider” at the bottom and you’ll notice that you have pins 10,19,22,24,25,7 and pin8.  If you connect a switch to one of these pins (through a resistor don’t forget) to OV, then you can detect when the switch is open or closed.  The inputs will normally read 1 and go to 0 when they are connected (through a resistor) to ground.  Click on the checkbox next to pin7 and try it out.

Using variables instead of broadcasts

For advanced Scratchers, you can use variables instead (or as well as broadcast messages) .

For example:  create a global variable called pin11

To make pin11 go on  use

set pin11 on

To make is go off use

set pin11 off

On can be replaced with high or 1 and off can be replaced with low or 0 so that you can use whatever logic scheme you’d like.
To set all outputs on use

set allpins on

To use a “bit-pattern” to set/unset multiple outputs simultaneously use

set pinpattern 1010001

(this will set Pin 21 , Pin 16 and Pin 11 on and all the rest off)

Note – currently there is an unfortunate “bug” in Scratch in that it remembers variable states and only sends changes out.  Even when you press the Green Flag, it will not send the state of all the variables out, it will only send them when a variable changes.  I recommend setting any gpio variables to a . and then to their initial state in a Green Flag start-up script.

When GreenFlag clicked

set pin11 .
set pin11 off

Motor Control

Connecting a motor directly to a GPIO pin WILL BREAK YOUR RASPBERRY PI!!! So don’t do it!   Google about driving motors from a RaspberryPi!!!

David Ferguson supplied the diagram below which shows a very cheap way of getting 2 motors connected safely to your Raspberry Pi. The chip used is a very cheap (37 pence) one called a ULN2003.  Wire pin11 of RPi to Pin1 on ULN2003 and then RPi pin12 to ULN2003 pin2 and finally RPi Pin6 (Gnd) connects to ULN Pin8.

Then ULN2003 pin16 goes to one motor, ULN2003 pin15 goes to other motor.  The other connections on each motor are both connected to ULN Pin 9.

Finally connect a separate motor power supply (I use a 4xAA battery pack to give 6V) and CAREFULLY connect +ve to the ULN2003 Pin 9 and -ve to ULN2003 pin 8)

motor_pinout

Once you’ve got your motor(s) SAFELY connected up, to control a motor, it is usually required to be able to not just switch it on or off but to vary its speed.

To do this in Scratch you can create 2 special variables called MotorA and MotorB and then assign these values from 0 (off) to 100(fully on)

MotorA controls pin11 and MotorB controls pin12.

e.g To make MotorA go at half speed use

set MotorA 50

To make MotorA switch off use

set MotorA 0

The motor variables can also be be used to simply vary the brightness of an LED.

Ultrasonic Sensor
Support for cheap 4pin ultrasonic sensors has been added.  To use one, connect Pin23 to the trigger or pulse input and connect the echo output (USING A 10K RESISTOR TO AVOID BROKEN PI!) to any of the input pins  (7,8,10,19,22,24 or 26).  This simple script

forever
broadcast sonar7
wait 1

will send a pulse out on pin23 once per second and setup up a new sensor input called sonar7 that will display the distance (in cm) that the sensor detects.   (NB You need to have done at least 1 broadcast before the sonar7 sensor will show up as a valid option)

Troubleshooting
To test if the software necessary to control the GPIO is correctly installed open a LXTerminal session and type

sudo python blink11.py

If this doesn’t give an error but doesn’t make a LED on Pin 11 blink then we have real problems Houston 😦

Try connecting the lead going to Pin 11 back to Pin 1 to make sure the LED lights up then just in case you have a loose connection.

Scratch GPIO future direction

Having played around with getting Scratch talking to the GPIO and thinking about making a Scratch mod (Razz) to have special blocks to switch pins off and on, I’m settling on just using simple broadcast messages (with the option of using variables as well) and making the default setup have 6 outputs and 2 inputs.

With the 6/2 combo people can flash a few leds and have a couple of switches or digital (easily make a full pedestrian crossing red/amber/green main lights red/green/white wait lights and a switch to cross.

I’m going to reserve build Razz for when I get my Aflex 2[url]http://www.web4robot.com/[/url] that I’m going to use as a prototype PriBoard

MarsCuriosity Lander Challenge

This weeks winning entry is at

http://scratch.mit.edu/projects/mbateman/2744326

Congratualations

In the old days, we all wrote Apollo 11 Lunar Lander games/simulators.

(Here is one I made in Scratch  http://scratch.mit.edu/projects/SimpleScratch/82204 )

Well now its time to get your fingers/mouse moving again and write a MarsCuriosity Lander game/simulator.

ONLY PROGRAMS WRITTEN ON A RASPBERRYPI ARE ALLOWED 🙂

Competition closed 26th Aug Sunday 8 pm GMT  but please feel free to submit a late entry just for the fun of it 🙂

At that time, we all upload somewhere and score/admire each others efforts. 🙂

Any level of game/simulator is acceptable – University PhD Teams programming in assembler as well as 6 Year olds programming in Scratch (possibly with some help from Mum/Dad) are all welcome.

ONE EXCEPTION – NO NASA ENGINEERS ARE ALLOWED AN ENTRY 🙂

I warn you now – my own effort will be awesome (in Scratch of course) and will be hard to beat 🙂

Use #mcsim on Twitter, or post comments here

Simon @cymplecy

ONLY PROGRAMS WRITTEN ON A RASPBERRYPI ARE ALLOWED 🙂

(But you will get away with things as long as it RUNS ok on the Raspberry_Pi 🙂 )

Auto install a Simple Samba Setup

Updated 21Aug12 V1.1

Following on from previous blog I’ve tried to emulate MrEngmans brilliant concept of providing a single install script that does as much of the work as possible

His idea is to copy a file onto the SD while its plugged into a PC/Mac etc and then put the card into your RPi and issue one simple command

So  this is the file

https://dl.dropbox.com/s/wjlshn22z80rzpv/simplesamba.sh

simply copy it to the SD card while its in your PC/Mac and then put it in your RPi and issue this command

sudo /boot/simplesamba.sh

Alternatively (thanks to Jason Powell)

wget https://dl.dropbox.com/s/wjlshn22z80rzpv/simplesamba.sh

and then run

sudo bash simplesamba.sh

Note-some parts of the script can take a bit of time as the Pi needs to download stuff – just answer Y if asked questions BTW 🙂

When it sits there with New SMB passord: showing , enter raspberry as the password and then repeat it.
At the end, you should be able connect to your RPi from windows using username=pi  password=raspberry

Good luck

Treating a RaspberryPi as just another Windows machine

This guide has been superceded by the AutoInstall version https://cymplecy.wordpress.com/2012/08/09/auto-install-a-simple-samba-setup/ but it still shows the process needed to go through 🙂

To access the files on your RPi over your network and to stop worrying about finding its IP address, you need to install and configure something called Samba – but don’t worry-  I’ve made this easy peasy

1st off -need to run LXTerminal and then type

sudo apt-get install samba

(Answer any question it asks with OK or Y)

Once its installed – we need another thing installing – so do this

sudo apt-get install samba-common-bin

And then run this command

sudo smbpasswd -a pi

You will be asked to enter the pi password twice – use raspberry as the password.

Finally use

sudo nano /etc/samba/smb.conf

And copy and paste the following to replace the existing file contents


#======================= Global Settings =======================
[global]
workgroup = WORKGROUP
server string = mypi server
netbios name = mypi

dns proxy = no

#### Debugging/Accounting ####
log file = /var/log/samba/log.%m
max log size = 1000
syslog = 0
panic action = /usr/share/samba/panic-action %d

####### Authentication #######
security = user
map to guest = pi

#======================= Share Definitions =======================
[homes]

comment = Home Directories
browseable = yes
guest ok = yes
read only = no
create mask = 0775
directory mask = 0775
writeable = yes
guest account = pi

[public]
path = /
guest ok = yes
guest account = ftp
browseable = yes
read only = no
create mask = 0777
directory mask = 0777
writeable = yes
admin users = everyone

Save the file in nano (Ctrl-O, answer Y and then Ctrl-X) and finally issue the following command

sudo /etc/init.d/samba restart

Your RPi should now be set to be reffered to as \\mypi from any windows machine on the same network.

You will be asked to logon the 1st time you use it after every computer restart – just use username pi password raspberry

If you wish to change the name of your RPi to say darkstar then just replace mypi with darkstar in the server name and netbios name lines

A Tale of Two Pi

…I’m no longer a SimplePi man – I’m now MrT(au)

Image

 

I didn’t intend having two so soon but last Friday (3rdAug) I was googling for something when I noticed a sponsored advert for a RaspberryPi from Farnell.  In curiosity (just shows their advertising engine is spot on BTW) I clicked on the link and a page came up saying 142 in stock and would I like one!!!

So I clicked yes and  2 hours later I got an email saying it had been dispatched at total cost to me of £24.55 + £4.91VAT – free P&P (Although 24.55 works out at $38 but lets not nit pick 🙂 )

Obviously, with free P&P it was sent out by camel and only arrived here this morning (5 real -3 working days later) but considering I waited 3 months for my 1st one to arrive – I’m not complaining 🙂

My only problem I’m going to have is when my wife finds out I’ve bought another one!