{ "metadata": { "name": "", "signature": "sha256:70d71632c4ccd4a68f16f207d72505ad4dfce6183d99336a291cb1f99488b655" }, "nbformat": 3, "nbformat_minor": 0, "worksheets": [ { "cells": [ { "cell_type": "heading", "level": 1, "metadata": {}, "source": [ "Introduction to Neural Networks (Psy 5038): Python" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "So far in this course we've tried to emphasize concepts usually with toy examples. We'll now spend a few classes going over tools that can be applied to state-of-the-art problems in cognitive neuroscience. Mathematica is excellent for learning concepts, and for many high-end applications. However, it is not so good for specialized work in the field. Matlab and increasingly Python have large user communities who are building tools that we can build on. That's the goal. But first an introduction to IPython as an environment for scientific programming." ] }, { "cell_type": "heading", "level": 2, "metadata": {}, "source": [ "Starting IPython in the middle" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "In order to run this notebook on your computer, you will need to have Python and IPython installed. Find the directory where you've downloaded this notebook, and then from a terminal command line go the directory (or parent directory) and type: ipython notebook. This will bring up a browswer window from where you should see this notebook listed in your browser window. You can load it from there." ] }, { "cell_type": "heading", "level": 6, "metadata": {}, "source": [ "Installation" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "The hardest, or at least the most frustrating, aspect of Python can be installation. There are a number of package managers. We recommend [Anaconda](https://store.continuum.io/cshop/anaconda/).\n", "\n", "In addition to Python and [IPython](http://ipython.org/), you will need [numpy](http://www.numpy.org/), [matplotlib](http://matplotlib.org/) and the [scipy library](http://www.scipy.org/scipylib/index.html). All of these are part of the [scipy stack](scipy.org) for general purpose scientific programming. Later, we'll also need [pymc](http://pymc-devs.github.io/pymc/) for Bayesian computations using MCMC sampling, the machine learning module [scikit-learn](http://scikit-learn.org/stable/index.html), and [scikit-image](http://scikit-image.org/), which are built on the scipy stack.\n", "\n", "\n", "These [installation notes](http://iacs-courses.seas.harvard.edu/courses/am207/blog/installing-python.html) from a 2013 course at Harvard may be helpful." ] }, { "cell_type": "heading", "level": 6, "metadata": {}, "source": [ "Rationale for scientific python" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "http://nbviewer.ipython.org/github/jrjohansson/scientific-python-lectures/blob/master/Lecture-0-Scientific-Computing-with-Python.ipynb" ] }, { "cell_type": "heading", "level": 3, "metadata": {}, "source": [ "Style" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Let's first cover some style. We'll get to substance--i.e. python code--soon enough. Right off the bat, you can create a Raw NBConvert, various headings, or a Markdown cell. Try the latter and type in LaTeX commands. E.g. try putting the next line between double dollar signs:\n", "\n", "p(y_i|x)= \\frac{e^{y_i(w.x+b)}}{{1+e^{(w.x+b)}}}\n", "\n", "\n", "\n", "After getting acquainted with the menu items and buttons of the IPython notebook interface, take a look at these notes on: [IPython's Rich Display System]( http://nbviewer.ipython.org/github/ipython/ipython/blob/1.x/examples/notebooks/Part%205%20-%20Rich%20Display%20System.ipynb). Try copying in cell content in this notebook to try out displaying different kinds of content. " ] }, { "cell_type": "heading", "level": 3, "metadata": {}, "source": [ "Making and plotting lists" ] }, { "cell_type": "code", "collapsed": false, "input": [ "import numpy as np" ], "language": "python", "metadata": {}, "outputs": [], "prompt_number": 8 }, { "cell_type": "markdown", "metadata": {}, "source": [ "To get started, let's look at some simple python coding examples. We need to load numpy to handle vectors and matrices. To make lists in Mathematica we typically used Table[], e.g. \n", "\n", " Table[Sin[x], {x, 0, 1, .1}];\n", "\n", "\n", "In python, we'll use \"list comprehensions\". Create a code cell and try these:\n", "\n", " [sin(x) for x in arange(0,1,.1)]\n", "\n", " [sin(x) for x in linspace(0,1,10)]\n", "\n", "But wait! Python needs to know where these functions came from. arange(), linspace(), and sin() are all numpy functions. We imported numpy functions with the shorthand \"np\", so you will need to write:\n", "\n", " np.sin(x), and np. arange(0,1,.1). \n", "\n", "For more on creating and manipulating numerical lists in NumPy see [scipy page](http://scipy-lectures.github.io/intro/numpy/index.html)" ] }, { "cell_type": "code", "collapsed": false, "input": [ "sl=[np.sin(x) for x in np.arange(0,10,.1)]" ], "language": "python", "metadata": {}, "outputs": [], "prompt_number": 96 }, { "cell_type": "markdown", "metadata": {}, "source": [ "Let's plot these values. To do this, we'll need to import matplotlib, and in particular the pyplot module, or plt for short. If you want a more matlab like plotting environment, you can use pylab:\n", "\n", " from pylab import *\n", "\n", "For more information on plotting, see [scipy notes](https://scipy-lectures.github.io/intro/matplotlib/matplotlib.html#ipython-and-the-pylab-mode), and Lecture 4 in the [scientific python notebook series](http://nbviewer.ipython.org/github/jrjohansson/scientific-python-lectures/blob/master/Lecture-4-Matplotlib.ipynb). " ] }, { "cell_type": "code", "collapsed": false, "input": [ "import matplotlib.pyplot as plt" ], "language": "python", "metadata": {}, "outputs": [], "prompt_number": 9 }, { "cell_type": "code", "collapsed": false, "input": [ "plt.plot(sl)\n", "plt.show()" ], "language": "python", "metadata": {}, "outputs": [ { "metadata": {}, "output_type": "display_data", "png": "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\n2qkM83NOR6gAAAAASUVORK5CYII=\n", "text": [ "" ] } ], "prompt_number": 17 }, { "cell_type": "markdown", "metadata": {}, "source": [ "With the magic function the next cell, your plot should appear in a separate window. Close the figure window and now excecute the next cell below, and then run the above plot cell again." ] }, { "cell_type": "code", "collapsed": false, "input": [ "%matplotlib inline" ], "language": "python", "metadata": {}, "outputs": [], "prompt_number": 10 }, { "cell_type": "markdown", "metadata": {}, "source": [ "We made 2D lists in Mathematica using the Table[] function like this:\n", "\n", " Table[Sin[x] Cos[y], {x, 0, 1, .1}, {y, 0, 1, .1}];\n", "\n", "Now try using the list comprehension syntax for python:\n", "\n", " [[sin(x)*cos(y) for x in arange(0,1,.1)] for y in arange(0,1,.1)] or\n", "\n", " [[sin(x)*cos(y) for x in linspace(0,1,10)] for y in linspace(0,1,10)]\n", "\n", "Again remember to specify the numpy class using np. " ] }, { "cell_type": "code", "collapsed": false, "input": [ "#If you remove the semicolon and it is the last line, the next line will print out the values\n", "[[np.sin(x)*np.cos(y) for x in np.arange(0,1,.1)] for y in np.arange(0,1,.1)];" ], "language": "python", "metadata": {}, "outputs": [], "prompt_number": 24 }, { "cell_type": "code", "collapsed": false, "input": [ "#but it won't if you assign a variable name to the array\n", "\n", "sl2=[[np.sin(x)*np.cos(y) for x in np.arange(0,1,.1)] for y in np.arange(0,1,.1)];" ], "language": "python", "metadata": {}, "outputs": [], "prompt_number": 53 }, { "cell_type": "heading", "level": 6, "metadata": {}, "source": [ "Getting parts of vectors and arrays" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "[Accessing array values or slicing](http://scipy-lectures.github.io/intro/numpy/numpy.html#indexing-and-slicing)" ] }, { "cell_type": "code", "collapsed": false, "input": [ "#make a vector with 5 rows and 6 columns\n", "sl3=np.array([[x+y*6 for x in np.arange(0,6,1)] for y in np.arange(0,5,1)])\n", "#what happens if you don't use np.array() in the above line?\n", "\n", "print np.array(sl3),'\\n\\n(#rows, #columns)=',np.shape(sl3),\"# elements:\",np.size(sl3)" ], "language": "python", "metadata": {}, "outputs": [ { "output_type": "stream", "stream": "stdout", "text": [ "[[ 0 1 2 3 4 5]\n", " [ 6 7 8 9 10 11]\n", " [12 13 14 15 16 17]\n", " [18 19 20 21 22 23]\n", " [24 25 26 27 28 29]] \n", "\n", "(#rows, #columns): (5, 6) # elements: 30\n" ] } ], "prompt_number": 81 }, { "cell_type": "code", "collapsed": false, "input": [ "#note that unlike Mathematica and Matlab (but like C), indexing starts with 0\n", "#first row\n", "sl3[0]" ], "language": "python", "metadata": {}, "outputs": [], "prompt_number": 86 }, { "cell_type": "code", "collapsed": false, "input": [ "#first column\n", "sl3[:,0]" ], "language": "python", "metadata": {}, "outputs": [ { "metadata": {}, "output_type": "pyout", "prompt_number": 88, "text": [ "array([ 0, 6, 12, 18, 24])" ] } ], "prompt_number": 88 }, { "cell_type": "code", "collapsed": false, "input": [ "#Try accessing the element in the 3rd row, 4th column. It isn't sl3[3,4]|\n", "\n", "#Get the first 2 elements of sl. It isn't sl[0:1]." ], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "code", "collapsed": false, "input": [ "#Now get the submatrix 3rd and 4th row, 4th through 6th columns\n", "sl3[2:4,3:6]" ], "language": "python", "metadata": {}, "outputs": [ { "metadata": {}, "output_type": "pyout", "prompt_number": 94, "text": [ "array([[15, 16, 17],\n", " [21, 22, 23]])" ] } ], "prompt_number": 94 }, { "cell_type": "heading", "level": 6, "metadata": {}, "source": [ "Defining functions" ] }, { "cell_type": "code", "collapsed": false, "input": [ "def f(x,y):\n", " return([[np.sin(3*x)*np.cos(4*y) for x in np.arange(0,1,.1)] for y in np.arange(0,1,.1)])" ], "language": "python", "metadata": {}, "outputs": [], "prompt_number": 17 }, { "cell_type": "code", "collapsed": false, "input": [ "#Visualize f(x,y) using imshow()\n", "\n", "import matplotlib.cm as cm\n", "\n", "n = 10\n", "x = np.linspace(-3,3,4*n)\n", "y = np.linspace(-3,3,3*n)\n", "X, Y = np.meshgrid(x,y)\n", "plt.imshow(f(X,Y),cmap = cm.Greys_r,origin='lower',interpolation='nearest');" ], "language": "python", "metadata": {}, "outputs": [ { "metadata": {}, "output_type": "display_data", "png": "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\n2+0AAAAASUVORK5CYII=\n", "text": [ "" ] } ], "prompt_number": 20 }, { "cell_type": "heading", "level": 6, "metadata": {}, "source": [ "IPython Examples" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "For a directory of [IPython notebook examples](https://github.com/ipython/ipython/wiki/A-gallery-of-interesting-IPython-Notebooks). E.g. here's a demo of [receptive field models]( http://nbviewer.ipython.org/github/jonasnick/ReceptiveFields/blob/master/receptiveFields.ipynb)" ] }, { "cell_type": "heading", "level": 6, "metadata": {}, "source": [ "Python neural network resources" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "For python code, look at [neurolab](https://pythonhosted.org/neurolab/index.html). This has several topics that should look familiar. However, there is some material that we haven't covered, for example see Elmans network for learning temporal sequences.\n", "\n", "For python code to simulate spiking neurons, see http://briansimulator.org. " ] }, { "cell_type": "code", "collapsed": false, "input": [], "language": "python", "metadata": {}, "outputs": [] }, { "cell_type": "markdown", "metadata": {}, "source": [ "Ok, now let's look at a neural network. We will download a python file that simulates the two neuron Hopfield net [TwoNeuroHopfield.py](http://gandalf.psych.umn.edu/users/kersten/kersten-lab/courses/Psy5038WF2014/Lectures/Lect_18_Python/TwoNeuroHopfield.py). And then convert it to an IPython notebook.\n", "\n", "For the IPython version, look at this [link]( http://nbviewer.ipython.org/url/gandalf.psych.umn.edu/users/kersten/kersten-lab/courses/Psy5038WF2014/Lectures/Lect_12_Hopfield/HopfieldTwoNeuronDemo.ipynb)" ] }, { "cell_type": "code", "collapsed": false, "input": [], "language": "python", "metadata": {}, "outputs": [] } ], "metadata": {} } ] }