aed6b39bb6 | ||
---|---|---|
.. | ||
docs | ||
LICENSE | ||
README.md | ||
neurosky_adaptor.go | ||
neurosky_adaptor_test.go | ||
neurosky_driver.go | ||
neurosky_driver_test.go |
README.md
Neurosky
This package contains the Gobot adaptor and driver for the Neurosky Mindwave Mobile EEG.
Installing
go get github.com/hybridgroup/gobot && go install github.com/hybridgroup/platforms/neurosky
How To Connect
OSX
In order to allow Gobot running on your Mac to access the Mindwave, go to "Bluetooth > Open Bluetooth Preferences > Sharing Setup" and make sure that "Bluetooth Sharing" is checked.
Now you must pair with the Mindwave. Open System Preferences > Bluetooth. Now with the Bluetooth devices windows open, hold the On/Pair button on the Mindwave towards the On/Pair text until you see "Mindwave" pop up as available devices. Pair with that device. Once paired your Mindwave will be accessable through the serial device similarly named as /dev/tty.MindWaveMobile-DevA
Ubuntu
Connecting to the Mindwave from Ubuntu or any other Linux-based OS can be done entirely from the command line using Gort CLI commands. Here are the steps.
Find the address of the Mindwave, by using:
gort scan bluetooth
Pair to Mindwave using this command (substituting the actual address of your Mindwave):
gort bluetooth pair <address>
Connect to the Mindwave using this command (substituting the actual address of your Mindwave):
gort bluetooth connect <address>
Windows
You should be able to pair your Mindwave using your normal system tray applet for Bluetooth, and then connect to the COM port that is bound to the device, such as COM3
.
Examples
package main
import (
"fmt"
"github.com/hybridgroup/gobot"
"github.com/hybridgroup/gobot/platforms/neurosky"
)
func main() {
gbot := gobot.NewGobot()
adaptor := neurosky.NewNeuroskyAdaptor("neurosky", "/dev/rfcomm0")
neuro := neurosky.NewNeuroskyDriver(adaptor, "neuro")
work := func() {
gobot.On(neuro.Events["Extended"], func(data interface{}) {
fmt.Println("Extended", data)
})
gobot.On(neuro.Events["Signal"], func(data interface{}) {
fmt.Println("Signal", data)
})
gobot.On(neuro.Events["Attention"], func(data interface{}) {
fmt.Println("Attention", data)
})
gobot.On(neuro.Events["Meditation"], func(data interface{}) {
fmt.Println("Meditation", data)
})
gobot.On(neuro.Events["Blink"], func(data interface{}) {
fmt.Println("Blink", data)
})
gobot.On(neuro.Events["Wave"], func(data interface{}) {
fmt.Println("Wave", data)
})
gobot.On(neuro.Events["EEG"], func(data interface{}) {
eeg := data.(gobotNeurosky.EEG)kj
fmt.Println("Delta", eeg.Delta)
fmt.Println("Theta", eeg.Theta)
fmt.Println("LoAlpha", eeg.LoAlpha)
fmt.Println("HiAlpha", eeg.HiAlpha)
fmt.Println("LoBeta", eeg.LoBeta)
fmt.Println("HiBeta", eeg.HiBeta)
fmt.Println("LoGamma", eeg.LoGamma)
fmt.Println("MidGamma", eeg.MidGamma)
fmt.Println("\n")
})
}
gbot.Robots = append(gbot.Robots,
gobot.NewRobot("brainBot", []gobot.Connection{adaptor}, []gobot.Device{neuro}, work))
gbot.Start()
}