Skip to content

Instantly share code, notes, and snippets.

@bamford
Last active December 26, 2015 10:39
Show Gist options
  • Save bamford/7138311 to your computer and use it in GitHub Desktop.
Save bamford/7138311 to your computer and use it in GitHub Desktop.
{
"metadata": {
"name": ""
},
"nbformat": 3,
"nbformat_minor": 0,
"worksheets": [
{
"cells": [
{
"cell_type": "code",
"collapsed": false,
"input": [
"\n",
"%matplotlib inline\n",
"import numpy\n",
"from matplotlib import pyplot"
],
"language": "python",
"metadata": {},
"outputs": [],
"prompt_number": 46
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Create an array x = [-3.00, -2.99, -2.98, \u2026, 2.98, 2.99, 3.00], and corresponding values of the standard Gaussian function."
]
},
{
"cell_type": "code",
"collapsed": false,
"input": [
"dx = 0.01\n",
"x = numpy.arange(-3.0, 3.0+dx/2, dx)\n",
"y = 1/sqrt(2*pi) * numpy.exp(-x**2 / 2)"
],
"language": "python",
"metadata": {},
"outputs": [],
"prompt_number": 47
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Check the result is unit normalised."
]
},
{
"cell_type": "code",
"collapsed": false,
"input": [
"print(y.sum()*dx)"
],
"language": "python",
"metadata": {},
"outputs": [
{
"output_type": "stream",
"stream": "stdout",
"text": [
"0.997344300831\n"
]
}
],
"prompt_number": 48
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"_This is not quite one as we have chopped the tails ( $>3 \\sigma$ ) off the distribution._"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"For convenience, put x and y together in a recarray and save to a file."
]
},
{
"cell_type": "code",
"collapsed": false,
"input": [
"xy = numpy.rec.array((x, y), names=('x', 'y'))\n",
"numpy.savetxt('xy.txt', xy)"
],
"language": "python",
"metadata": {},
"outputs": [],
"prompt_number": 49
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Create samples of one hundred Gaussian random numbers."
]
},
{
"cell_type": "code",
"collapsed": false,
"input": [
"z1 = numpy.random.normal(size=100)\n",
"z2 = numpy.random.normal(size=100)"
],
"language": "python",
"metadata": {},
"outputs": [],
"prompt_number": 50
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Plot your Gaussian curve, x versus y, with axis labels"
]
},
{
"cell_type": "code",
"collapsed": false,
"input": [
"pyplot.plot(x, y)\n",
"pyplot.xlabel('x')\n",
"pyplot.ylabel(r'$y = \\frac{1}{\\sqrt{2}}\\ \\exp\\left(\\frac{x^2}{2}\\right)$')\n",
"pyplot.hist(z1, normed=True, histtype='stepfilled', alpha=0.5)\n",
"pyplot.hist(z2, normed=True, histtype='stepfilled', alpha=0.5)"
],
"language": "python",
"metadata": {},
"outputs": [
{
"metadata": {},
"output_type": "pyout",
"prompt_number": 51,
"text": [
"(array([ 0.12326755, 0.14381214, 0.30816887, 0.34925805, 0.36980264,\n",
" 0.41089182, 0.18490132, 0.10272296, 0.04108918, 0.02054459]),\n",
" array([-2.21097456, -1.72422844, -1.23748232, -0.7507362 , -0.26399008,\n",
" 0.22275604, 0.70950216, 1.19624828, 1.6829944 , 2.16974052,\n",
" 2.65648664]),\n",
" <a list of 1 Patch objects>)"
]
},
{
"metadata": {},
"output_type": "display_data",
"png": "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\n",
"text": [
"<matplotlib.figure.Figure at 0x111d9ea90>"
]
}
],
"prompt_number": 51
},
{
"cell_type": "code",
"collapsed": false,
"input": [],
"language": "python",
"metadata": {},
"outputs": []
}
],
"metadata": {}
}
]
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment