Skip to content

Instantly share code, notes, and snippets.

@genkuroki
Created December 2, 2017 06:15
Show Gist options
  • Save genkuroki/d734ee906886a6c53452349761215d93 to your computer and use it in GitHub Desktop.
Save genkuroki/d734ee906886a6c53452349761215d93 to your computer and use it in GitHub Desktop.
Test of GaussianProcesses.jl
Display the source blob
Display the rendered blob
Raw
{
"cells": [
{
"metadata": {
"trusted": true
},
"cell_type": "code",
"source": "#Pkg.clone(\"https://github.com/STOR-i/GaussianProcesses.jl.git\")\n#Pkg.add(\"Plots\")\n#Pkg.add(\"Distributions\")\n#Pkg.add(\"Klara\")",
"execution_count": 1,
"outputs": []
},
{
"metadata": {
"trusted": true,
"scrolled": false
},
"cell_type": "code",
"source": "#Load functions from packages\n@time using GaussianProcesses\n@time using Plots\n@time using Distributions #: Normal, TDist\n@time using Klara #: MALA\n\n#Simulate the data\nsrand(112233)\nn = 20\nX = collect(linspace(-3,3,n))\nsigma = 1.0\nY = X + sigma*rand(TDist(3),n);\n\n# Plots observations\npyplot()\nscatter(X,Y;fmt=:png, leg=false)",
"execution_count": 2,
"outputs": [
{
"output_type": "stream",
"text": " 30.986445 seconds (6.37 M allocations: 404.580 MiB, 0.65% gc time)\n 90.308537 seconds (7.35 M allocations: 479.037 MiB, 0.19% gc time)\n 0.000027 seconds (4 allocations: 160 bytes)\n 0.000021 seconds (4 allocations: 160 bytes)\n",
"name": "stdout"
},
{
"output_type": "execute_result",
"execution_count": 2,
"data": {
"text/html": "<img src=\"\" />"
},
"metadata": {}
}
]
},
{
"metadata": {
"trusted": true
},
"cell_type": "code",
"source": "#Build the models\n\ngpe = GPE(X,vec(Y),MeanZero(),Matern(3/2,0.0,0.0),0.5) #Exact GP assuming Gaussian noise",
"execution_count": 3,
"outputs": [
{
"output_type": "execute_result",
"execution_count": 3,
"data": {
"text/plain": "GP Exact object:\n Dim = 1\n Number of observations = 20\n Mean function:\n Type: GaussianProcesses.MeanZero, Params: Float64[]\n Kernel:\n Type: GaussianProcesses.Mat32Iso, Params: [0.0, 0.0]\n Input observations = \n[-3.0 -2.68421 … 2.68421 3.0]\n Output observations = [-3.98707, -2.7855, -1.74722, -2.27384, -7.12662, -1.43191, -0.840899, 0.305618, -0.444213, -0.924319, -0.0303161, -0.368707, -0.706642, 2.07517, 5.68693, -1.02634, 3.25863, 5.46091, 4.45861, 4.60741]\n Variance of observation noise = 2.718281828459045\n Marginal Log-Likelihood = -51.895"
},
"metadata": {}
}
]
},
{
"metadata": {
"trusted": true
},
"cell_type": "code",
"source": "l = StuTLik(3,0.1)\ngpmc = GPMC(X, vec(Y), MeanZero(), Matern(3/2,0.0,0.0), l) #Monte Carlo GP with student-t likelihood",
"execution_count": 4,
"outputs": [
{
"output_type": "execute_result",
"execution_count": 4,
"data": {
"text/plain": "GP Monte Carlo object:\n Dim = 1\n Number of observations = 20\n Mean function:\n Type: GaussianProcesses.MeanZero, Params: Float64[]\n Kernel:\n Type: GaussianProcesses.Mat32Iso, Params: [0.0, 0.0]\n Likelihood:\n Type: GaussianProcesses.StuTLik, Params: [0.1]\n Input observations = \n[-3.0 -2.68421 … 2.68421 3.0]\n Output observations = [-3.98707, -2.7855, -1.74722, -2.27384, -7.12662, -1.43191, -0.840899, 0.305618, -0.444213, -0.924319, -0.0303161, -0.368707, -0.706642, 2.07517, 5.68693, -1.02634, 3.25863, 5.46091, 4.45861, 4.60741]\n Log-posterior = -77.863"
},
"metadata": {}
}
]
},
{
"metadata": {
"trusted": true
},
"cell_type": "code",
"source": "@time optimize!(gpe)",
"execution_count": 5,
"outputs": [
{
"output_type": "stream",
"text": " 3.929464 seconds (4.11 M allocations: 209.256 MiB, 2.24% gc time)\n",
"name": "stdout"
},
{
"output_type": "execute_result",
"execution_count": 5,
"data": {
"text/plain": "Results of Optimization Algorithm\n * Algorithm: L-BFGS\n * Starting Point: [0.5,0.0,0.0]\n * Minimizer: [0.6566151884189473,1.7118340256787345, ...]\n * Minimum: 4.578633e+01\n * Iterations: 11\n * Convergence: true\n * |x - x'| < 1.0e-32: false\n * |f(x) - f(x')| / |f(x)| < 1.0e-32: false\n * |g(x)| < 1.0e-08: true\n * f(x) > f(x'): false\n * Reached Maximum Number of Iterations: false\n * Objective Function Calls: 46\n * Gradient Calls: 46"
},
"metadata": {}
}
]
},
{
"metadata": {
"trusted": true
},
"cell_type": "code",
"source": "set_priors!(gpmc.lik,[Normal(-2.0,4.0)])\nset_priors!(gpmc.k,[Normal(-2.0,4.0),Normal(-2.0,4.0)])\n\n@time samples = mcmc(gpmc;sampler=MALA(0.05),nIter=50000, thin=10, burnin=10000)",
"execution_count": 6,
"outputs": [
{
"output_type": "stream",
"text": "BasicMCJob:\n Variable [1]: p (BasicContMuvParameter)\n GenericModel: 1 variables, 0 dependencies (directed graph)\n MALA sampler: drift step = 0.05\n VanillaMCTuner: period = 100, verbose = false\n BasicMCRange: number of steps = 49991, burnin = 10000, thinning = 10 22.668948 seconds (34.37 M allocations: 4.492 GiB, 3.83% gc time)\n",
"name": "stdout"
},
{
"output_type": "execute_result",
"execution_count": 6,
"data": {
"text/plain": "23×4000 Array{Float64,2}:\n -1.44975 -1.44975 -1.02479 … -1.43093 -1.23015 -1.23015 \n 0.588195 0.588195 0.332809 1.08002 1.17153 1.17153 \n 0.718085 0.718085 0.211443 0.493442 0.385335 0.385335\n -1.32609 -1.32609 -1.15774 -0.333319 -0.200674 -0.200674\n -0.721646 -0.721646 -0.855224 -0.55112 -0.794651 -0.794651\n 0.851406 0.851406 0.986268 … 1.32336 1.21235 1.21235 \n -0.250237 -0.250237 -0.296884 -0.298572 -0.166915 -0.166915\n 0.154486 0.154486 0.387819 0.0714513 0.162703 0.162703\n -0.0969148 -0.0969148 -0.324955 -0.446952 -0.267948 -0.267948\n -0.380338 -0.380338 0.133223 0.765023 0.42936 0.42936 \n 0.378311 0.378311 0.555143 … -0.226185 -0.211079 -0.211079\n -0.918741 -0.918741 -0.744673 -0.589133 -0.436455 -0.436455\n -0.136525 -0.136525 0.123217 1.7611 1.83721 1.83721 \n 1.77061 1.77061 1.61585 -0.923194 -0.784206 -0.784206\n 1.73116 1.73116 1.87613 0.82272 0.86416 0.86416 \n -0.678761 -0.678761 -0.545683 … 0.386 0.503511 0.503511\n 0.830114 0.830114 0.782332 2.30027 2.27326 2.27326 \n 1.28389 1.28389 1.61891 2.18992 2.05585 2.05585 \n 0.247051 0.247051 0.492288 -0.479602 -0.876566 -0.876566\n -0.385056 -0.385056 -0.53043 -0.780789 -0.959797 -0.959797\n -0.372006 -0.372006 -0.116689 … -0.138475 -0.17703 -0.17703 \n -0.0997188 -0.0997188 -0.338012 0.869903 1.11409 1.11409 \n 1.1369 1.1369 1.10389 1.05892 1.07458 1.07458 "
},
"metadata": {}
}
]
},
{
"metadata": {
"trusted": true
},
"cell_type": "code",
"source": "#Plot posterior samples\nxtest = linspace(minimum(gpmc.X),maximum(gpmc.X),50);\n\n#Set the parameters to the posterior values the sample random function\nfsamples = [];\nfor i in 1:size(samples,2)\n set_params!(gpmc,samples[:,i])\n update_target!(gpmc)\n push!(fsamples, rand(gpmc,xtest))\nend\n\n#Predict\np1=plot(gpe,leg=false, title=\"Exact GP\") #Exact GP (assuming Gaussian noise)\n\nsd = [std(fsamples[i]) for i in 1:50]\np2=plot(xtest,mean(fsamples),ribbon=2*sd,leg=false, title=\"Monte Carlo GP\") #GP Monte Carlo with student-t noise\nscatter!(X,Y)\n\nplot(p1,p2;fmt=:png)",
"execution_count": 7,
"outputs": [
{
"output_type": "execute_result",
"execution_count": 7,
"data": {
"text/html": "<img src=\"\" />"
},
"metadata": {}
}
]
},
{
"metadata": {
"trusted": true
},
"cell_type": "code",
"source": "?StuTLik",
"execution_count": 8,
"outputs": [
{
"output_type": "stream",
"text": "search: \u001b[1mS\u001b[22m\u001b[1mt\u001b[22m\u001b[1mu\u001b[22m\u001b[1mT\u001b[22m\u001b[1mL\u001b[22m\u001b[1mi\u001b[22m\u001b[1mk\u001b[22m\n\n",
"name": "stdout"
},
{
"output_type": "execute_result",
"execution_count": 8,
"data": {
"text/plain": "# Description\n\nConstructor for the Student-t likelihood (aka non-standardized Student's t-distribution)\n\n```\np(y|f,σ) = Γ((ν+1)/2)/[Γ(ν/2)sqrt{πν}σ](1+1/ν((y-f)/σ)²)^(-(ν+1)/2),\n```\n\nwhere f is the latent Gaussian process and σ a non-fixed hyperparameter.\n\n# Arguments:\n\n```\n* `ν::Int64`: degrees of freedom\n* `lσ::Float64`: log of scale\n```\n\n# Link:\n\n```\n* https://en.wikipedia.org/wiki/Student's_t-distribution\n```\n",
"text/markdown": "# Description\n\nConstructor for the Student-t likelihood (aka non-standardized Student's t-distribution)\n\n```\np(y|f,σ) = Γ((ν+1)/2)/[Γ(ν/2)sqrt{πν}σ](1+1/ν((y-f)/σ)²)^(-(ν+1)/2),\n```\n\nwhere f is the latent Gaussian process and σ a non-fixed hyperparameter.\n\n# Arguments:\n\n```\n* `ν::Int64`: degrees of freedom\n* `lσ::Float64`: log of scale\n```\n\n# Link:\n\n```\n* https://en.wikipedia.org/wiki/Student's_t-distribution\n```\n"
},
"metadata": {}
}
]
},
{
"metadata": {
"trusted": true
},
"cell_type": "code",
"source": "l = StuTLik(1, 0.01)",
"execution_count": 15,
"outputs": [
{
"output_type": "execute_result",
"execution_count": 15,
"data": {
"text/plain": "Type: GaussianProcesses.StuTLik, Params: [0.01]\n"
},
"metadata": {}
}
]
},
{
"metadata": {
"trusted": true
},
"cell_type": "code",
"source": "dump(l)",
"execution_count": 16,
"outputs": [
{
"output_type": "stream",
"text": "GaussianProcesses.StuTLik\n ν: Int64 1\n σ: Float64 1.010050167084168\n priors: Array{Any}((0,))\n",
"name": "stdout"
}
]
},
{
"metadata": {
"trusted": true,
"collapsed": true
},
"cell_type": "code",
"source": "",
"execution_count": null,
"outputs": []
}
],
"metadata": {
"kernelspec": {
"name": "julia-0.6-pauto",
"display_name": "Julia 0.6.1 procs auto",
"language": "julia"
},
"toc": {
"threshold": 4,
"number_sections": true,
"toc_cell": false,
"toc_window_display": false,
"toc_section_display": "block",
"sideBar": true,
"navigate_menu": true,
"moveMenuLeft": true,
"widenNotebook": false,
"colors": {
"hover_highlight": "#DAA520",
"selected_highlight": "#FFD700",
"running_highlight": "#FF0000",
"wrapper_background": "#FFFFFF",
"sidebar_border": "#EEEEEE",
"navigate_text": "#333333",
"navigate_num": "#000000"
},
"nav_menu": {
"width": "252px",
"height": "12px"
}
},
"language_info": {
"file_extension": ".jl",
"name": "julia",
"mimetype": "application/julia",
"version": "0.6.1"
},
"gist": {
"id": "",
"data": {
"description": "Test of GaussianProcesses.jl",
"public": true
}
}
},
"nbformat": 4,
"nbformat_minor": 2
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment