{ "cells": [ { "cell_type": "markdown", "metadata": {}, "source": [ "### Basic Introduction to Machine Learning: 04-denoise-1d \n", "Jeff Fessler, University of Michigan \n", "2018-10-23 Julia 1.0.1 version" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "### Illustrate 1D signal denoising using Julia's Flux library\n", "This is a Jupyter notebook based on the Julia language \n", "[https://julialang.org/] \n", "To run it you will need Julia 1.0.1 or later and to install several packages. \n", "For some tutorials on using Julia see: \n", "[http://web.eecs.umich.edu/~fessler/course/551/julia/tutor/]" ] }, { "cell_type": "code", "execution_count": 1, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "Plots.PyPlotBackend()" ] }, "execution_count": 1, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# packages used\n", "using LinearAlgebra\n", "using Random\n", "using Distributions\n", "using LaTeXStrings # pretty plot labels\n", "using Plots\n", "using Flux # Julia package for deep learning\n", "using Flux: throttle, mse\n", "if true\n", " pyplot()\n", " pyplot(markersize=7, markerstrokecolor=:auto)\n", " fnt = font(\"DejaVu Sans\", 15) # larger default font\n", " pyplot(guidefont=fnt, xtickfont=fnt, ytickfont=fnt, legendfont=fnt)\n", "end" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "### Generate training and testing data; 1D piece-wise constant signals" ] }, { "cell_type": "code", "execution_count": 2, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "makestep (generic function with 1 method)" ] }, "execution_count": 2, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# function to generate a random piece-wise constant signal\n", "function makestep(;dim=32, njump=3, valueDist=Normal(0,1), minsep=2)\n", " jump_locations = randperm(dim)[1:njump]\n", " while minimum(diff(jump_locations)) <= minsep\n", " jump_locations = randperm(dim)[1:njump] # random jump locations\n", " end\n", " index = zeros(dim)\n", " index[jump_locations] .= 1\n", " index = cumsum(index)\n", " values = rand(valueDist, njump) # random signal values\n", " x = zeros(dim)\n", " for jj=1:njump\n", " x[index .== jj] .= values[jj]\n", " end\n", " x[index .== 0] .= values[njump] # periodic end conditions\n", " x = circshift(x, rand(1:dim, 1)) # random shift - just to be sure\n", " return x\n", "end" ] }, { "cell_type": "code", "execution_count": 3, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "#4 (generic function with 1 method)" ] }, "execution_count": 3, "metadata": {}, "output_type": "execute_result" } ], "source": [ "#makestep()\n", "jim = (x; title=\"\") -> heatmap(x', aspect_ratio=1, yflip=true, title=title, # jiffy image display\n", " xtick=[1,size(x,1)], ytick=[1, size(x,2)], transpose=false)\n", "#jim(ones(3,4))" ] }, { "cell_type": "code", "execution_count": 4, "metadata": {}, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "maximum(Kx[:]) = 1.043542557604359\n", "maximum(Ky[:]) = 1.1360815233790753\n" ] }, { "data": { "image/png": "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vf766wnLvzdt2gRN0/DVr37VrZs1axbGjRvn/nzXXXfh0UcfRXZ2Nr7+9a8jGo1i9erVsCwLf/vb33DDDTek9TOkUyq/r71792LgwIHIy8vDeeedh+LiYlRXV2Pr1q04evQounbtitdeew2jR49ui4/Sqh599FHcddddAIAJEyYgLy8v6Xm//e1v3ZAOcOb+baX6+zqT/7ac53iPHj0wcuRIFBQUoKqqCh988AEOHTqEYDCIZ599Ft/97ncTrjtT/7Y6lbbu4VHT/u///k/85Cc/ESNGjBA9e/YUGRkZIj8/X1x88cXikUceOSPTMyxZskQAOOkr2V5nS5YsESNHjhTZ2dkiPz9fjB07Vqxbty79HyDNUvl91dbWivvuu09cfvnlol+/fiIQCIjs7GwxdOhQcc8994gDBw607YdpRc4+ec29ku0Jeib+baX6+zqT/7Y+++wz8cADD4jRo0eLPn36iMzMTJGTkyOGDh0q7rjjDvHJJ580ee2Z+LfVmXAEi4iIiKiFcZI7ERERUQtjB4uIiIiohbGDRURERNTC2MEiIiIiamHsYBERERG1MHawiIiIiFoYO1hERERELYwdLCIiIqIWxg4WEXmyd+9eaJqGa665Junx3/zmN9A0DYMGDcLu3bvT3DoiorbFDhYRtbj7778f9913H4YOHYr169ejpKSkrZtERJRWGW3dACLqPCzLwvTp0/HUU0/hoosuwhtvvIHu3bu3dbOIiNKOI1hE1CJisRhuvPFGPPXUU7j66quxZs0at3O1a9cu5Obmori4GMePH0+47sMPP0R2djYGDBiAmpqatmg6EXViW7ZswUMPPYSJEyeiX79+0DQNwWDQ8/2qq6tx11134ayzzkIgEMBZZ52FO++8E9XV1QnncbNnIvJk7969GDhwIMaOHYtXXnkFkyZNwptvvomJEyfi+eefh9/vTzj/6aefxg9/+EPccMMNeOmllwAAkUgEF110EXbs2IHy8nKMHj26LT4KEaVROBxGNBr1fL3f70+pgzR+/HisXLkyoS4QCCAcDqf83kePHkVpaSk++eQTDBo0CBdeeCF27tyJnTt34uyzz8a7776LgoIC+2RBROTBnj17BABx8cUXi9GjRwsAYurUqcIwjCavmTRpkgAg/vjHPwohhLjrrrsEADF79uw0tZqI2lJDQ4MoLMwXADy/CgsLRUND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" }, "execution_count": 4, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# training data\n", "Random.seed!(0)\n", "siz = 32\n", "\n", "ntrain = 2^11\n", "Xtrain = [makestep(dim=siz) for _ in 1:ntrain]\n", "Xtrain = hcat(Xtrain...) # noiseless data\n", "\n", "ntest = 2^10\n", "Xtest = [makestep(dim=siz) for _ in 1:ntest]\n", "Xtest = hcat(Xtest...) # noiseless data\n", "\n", "p0 = plot(Xtrain[:,1:14], label=\"\")\n", "\n", "Kx = Xtrain*Xtrain' / ntrain\n", "p1 = jim(Kx, title=\"Kx\")\n", "\n", "σnoise = 0.3\n", "Ytrain = Xtrain + σnoise * randn(size(Xtrain)) # noisy train data\n", "Ytest = Xtest + σnoise * randn(size(Xtest)) # noisy test data\n", "\n", "Ky = Ytrain*Ytrain' / ntrain\n", "\n", "@show maximum(Kx[:])\n", "@show maximum(Ky[:])\n", "\n", "p2 = jim(Ky, title=\"Ky\")\n", "plot(p0, p1, p2, layout=(3,1))" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "### Implement and evaluate Wiener filter (MMSE estimator)" ] }, { "cell_type": "code", "execution_count": 5, "metadata": {}, "outputs": [ { "data": { "image/png": "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" }, "execution_count": 5, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# wiener filter / MMSE estimator\n", "# cond(Kx + σnoise*I)\n", "Hw = Kx * inv(Kx + σnoise^2 * I)\n", "heatmap(Hw, aspect_ratio=1, yflip=true)" ] }, { "cell_type": "code", "execution_count": 6, "metadata": {}, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "(nrmse(Ytest), nrmse(Xw)) = (29.25, 22.59)\n" ] }, { "data": { "image/png": "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" }, "execution_count": 6, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# denoise via wiener filter (MMSE *linear* method)\n", "Xw = Hw * Ytest\n", "nrmse = (Xh) -> round(norm(Xh - Xtest) / norm(Xtest) * 100, digits=2)\n", "@show nrmse(Ytest), nrmse(Xw)\n", "plot(Xw[:,1:4])\n", "plot!(Xtest[:,1:4])" ] }, { "cell_type": "code", "execution_count": 7, "metadata": {}, "outputs": [ { "data": { "image/png": "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/e53v1N8fLzef/99/f73v3f7M7zxxht6+eWXNXv2bFvb008/rVdffVVLly7Vxo0b3d6WdDVg7dy5U3fddZckqaCgQEOHDlVSUpI+/PBDTZ48ucz++/fvV1JSkkaPHq3NmzfbfZc5OTn69ttvJXn+nRqJS4QAAFSxp59+2vbzo48+qoiIiEpvc8qUKU7DlSQ98MADduFKkpo2baqVK1dKkrZu3erRvvr3728XriRp3rx5kqTExESPtiVd/T6s4Uq6OgbsmWeecXt758+fl3T1cum1QTUoKEi9e/f2uCajcQYLAIAqFhsba/v5008/VUFBgZo0aVKpbd5///1lLj99+rQ+/fRTffvtt8rPz9eVK1ds0xScPn3ao33dc889Dm0tWrRQixYtnD5BoSLb69KliyS5tb3IyEhdd911euWVV9SmTRuNGDFCTZs29biOqkTAAgCgCu3Zs0fr1q1TWFiYevbsqW3btik2NlZLly6t1HZdTSVRUlKiP/7xj1q5cqXLeZ+sD+h2V1hYmNP2wMBAXbhwwaNtudpeYGCgJDkdhH+tLl266JVXXtGzzz6rhx56SA0aNFD37t119913KyYmRjfffLPHNRmNS4QAAFQRi8WiP/zhD5Kk119/XW+//baCgoK0cuVKHT9+vFLb9vf3d9r+0UcfacWKFWrXrp02bdqkn376SUVFRSopKbGFF08n3PTx8alUrVWxvVmzZunMmTP67//+bw0fPlw//PCDli9froiICL3xxhsGVFk5BCwAAKrIwoULdfr0aY0ZM0ajR49W27Zt9dJLL+ny5ct69NFHdeXKFcP3GRcXJ0l66623NG7cOIWGhsrX11eS9N133xm+P29q3769ZsyYob/97W/KyMjQe++9p+uuu06zZs1Sdna2V2uzC1gFBQXasmWLpkyZooiICLu5MxYuXKi8vDyHDVjnp3D1evbZZ13uPCkpScOHD1dwcLACAwPVp08fbdiwocyC09PTNXnyZIWGhsrf319dunTRggULZLFYKvgVAABgvJMnT2rZsmUymUx67bXXbO1/+MMfdOedd+rLL790eqalUaNGkqTLly9XaL9ZWVmSroaPa/3lL3+p0DZrg4YNG2rixIm67bbbVFRUpG+++ca2rLLfaUXYBawPPvhAY8aM0dq1a3XlyhUNGzZMAwYM0Pfff6/nn39et912m23k/rX6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4oknJElPPPGE3VisFStW6MSJE+rfv79uu+02b5UILygsLNTLL7+swsJCb5eCGojjA+XhGEFZKnp81Kq7CKWrD3sePHiwDh8+rLZt22rAgAH64YcfdPjwYbVo0UKHDh1Sp06dnPa13kX41VdfuZysFLVPbm6ugoKClJOTU61j61A7cHygPBwjKEtFj49adQZLkvz9/bVnzx7Nnz9fTZo00ZYtW3T27FlNmjRJx44dcxmuAAAAqkutuovQqnHjxlq4cKEWLlzo7VIAAAAc1MqAVVG//vqrJB5uXNdYZ+7/+uuvy50DDfUPxwfKwzGCsnhyfNx44422p83UujFYlfH+++/zsGMAAFAlSo/xrlcBKzMzU5999pk6dOigxo0be7scAABQh9TbM1gAAADVodbdRQgAAFDTEbAAAAAMRsBCrZeamqqXX35ZUVFRCg8Pl5+fn9q0aaOxY8dq//793i4PXmKxWPT888+rS5cu8vf3V2hoqCZPnuzyYfGoPwoKCrRlyxZNmTJFERERMplMCggIUI8ePbRw4ULbXWOAdPVB4K1atZKPj49uvPFGt/sxBgu1XlhYmH766SeZTCbdfvvtat68uf75z3/q5MmT8vHx0YoVK/TUU095u0xUI4vFoqioKCUlJdme+HD27Fl9+eWXatmypQ4ePKiOHTt6u0x4yZo1a/TII49Ikm6++WbddNNNys3NVVJSki5evKgbb7xR+/btU6tWrbxcKWqC6Ohobdy4USUlJeratatSU1Pd61gC1HJDhw4t+eCDD0oKCwvt2levXl0iqaRBgwYl//jHP7xUHbxh/vz5JZJK+vbtW3Lx4kVb+/Lly0sklQwcONCL1cHbNmzYUDJt2rSSb775xq79X//6V0nPnj1LJJU89NBDXqoONUlCQkKJpJJHH320RFJJ165d3e7LGSzUaffee68+//xzxcbG6vnnn/d2OagGly5dUqtWrZSdna3k5GT17NnTbnmPHj104sQJHT16VL179/ZSlaipDh48qDvvvFN+fn7Kzc1Vo0aNvF0SvOTXX39VRESEGjVqpC1btqhLly4encFiDBbqtB49ekiS/vWvf3m5ElSXL774QtnZ2erYsaNDuJKk8ePHS5K2bdtW3aWhFrD+nVFYWKgLFy54uRp40wsvvKAzZ87orbfekq+vr8f9CVio07777jtJUps2bbxcCarL8ePHJck2m/K1rO3W9YDSrH9n+Pr6Kjg42MvVwFtOnDih5cuXKyYmRgMHDqzQNghYqLPOnDmj+Ph4SdL999/v5WpQXdLS0iRdvfnBGWu7dT2gtFWrVkmShg0bJj8/Py9XA2+4cuWKHnnkETVr1kxLly6t8Hbq1cOeUX9cvnxZ0dHRKiws1G9+8xvG2tQj1lvsrY+ruFZAQIDdeoDVp59+qnfffVe+vr5atGiRt8uBl7z22mv68ssvtW7dOrVo0aLC2+EMFuqkGTNm6IsvvtB//Md/6M033/R2OahG1vt2fHx8ylwOlJaSkqKJEyeqpKREr7zyim0sFuqXH3/8UfPmzdOgQYMUHR1dqW1xBgs1nrOD/IEHHtADDzzgdP2FCxdq9erVat26tT777DPGUdQzTZs2lSTl5+c7XV5QUCBJCgwMrLaaULOlp6dr2LBhysrK0qxZs/Tkky6UTIEAAAJySURBVE96uyR4yfTp01VUVKS33nqr0tsiYKHG27Bhg0Nbhw4dnAasN954Q88//7yCgoK0Y8cOderUqTpKRA0SHh4uSS5nbLe2W9dD/ZaZmamhQ4cqLS1NMTExWrZsmbdLghfFx8erWbNmmjZtml27xWKRdHXs5uDBg23rlvWLGgELNZ67l3Tef/99zZgxQ02aNNEnn3yiyMjIKq4MNZH10k5ycrLT5db2iIiIaqsJNdPFixd13333KTU1VWPHjtU777zj8tIy6o/s7Gzt27fP6bJff/3Vtuzy5ctlbocxWKgTPv30U0VHR8vX11dxcXHq16+ft0uCl/Tr109BQUE6c+aMjh075rB806ZNkqSRI0dWd2moQQoLCzV69GgdPXpU9957rz788EM1aNDA22XBy0pKSpy+vv/+e0lS165dbW3NmjUrc1sELNR6Bw4csE0e+dFHH+mee+7xckXwpkaNGumJJ56QJD3xxBN2Y7FWrFihEydOqH///rrtttu8VSK8rLi4WA899JD27NmjAQMGaPPmzczYDsPxqBzUes2bN1d2drZuuOEGlxPC9e/fX1OnTq3myuAtFotFgwcP1uHDh20Pe/7hhx90+PBhtWjRQocOHWJ8Xj22atUq2wPgx4wZI5PJ5HS9ZcuWKSQkpDpLQw119uxZ3XDDDR49KocxWKj1srOzJUnff/+97TSuMwSs+sPf31979uzRiy++qA8++EBbtmxR8+bNNWnSJC1atEjt27f3donwoqysLNvPcXFxLteLjY0lYKHCOIMFAABgMMZgAQAAGIyABQAAYDACFgAAgMEIWAAAAAYjYAEAABjs/wOveZQxlBO2JgAAAABJRU5ErkJggg==" }, "execution_count": 7, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# verify that marginal distribution is gaussian\n", "histogram(Xtrain[:], label = \"Xtrain hist\")" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "### Examine a \"NN\" that is a single fully connected affine layer \n", "(It should perform same as Wiener filter.)" ] }, { "cell_type": "code", "execution_count": 8, "metadata": {}, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "(loss(Ytest, Xtest)).data = 2.364329038429393\n", "(loss(Ytest, Xtest)).data = 0.1937470324375254\n", "(loss(Ytest, Xtest)).data = 0.10469383685135497\n", "(loss(Ytest, Xtest)).data = 0.07678962858852317\n", "(loss(Ytest, Xtest)).data = 0.06493312126563625\n", "(loss(Ytest, Xtest)).data = 0.05939058681818371\n", "(loss(Ytest, Xtest)).data = 0.056766590963969264\n", "(loss(Ytest, Xtest)).data = 0.055550538819282805\n", "(loss(Ytest, Xtest)).data = 0.05501980285441081\n", "(loss(Ytest, Xtest)).data = 0.05479982474025873\n", "(loss(Ytest, Xtest)).data = 0.054714287261874134\n" ] } ], "source": [ "# first try a basic affine NN model\n", "model1 = Chain(Dense(siz,siz))\n", "loss(x, y) = mse(model1(x), y)\n", "\n", "iters = 2^12\n", "dataset = Base.Iterators.repeated((Ytrain, Xtrain), iters) # trick X,Y swap for denoising!\n", "\n", "evalcb = () -> @show(loss(Ytest,Xtest).data) # todo: how to show epoch?\n", "cb = throttle(evalcb, 4)\n", "\n", "Flux.train!(loss, dataset, ADAM(Flux.params(model1)), cb=cb)" ] }, { "cell_type": "code", "execution_count": 9, "metadata": {}, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "(nrmse(Ytest), nrmse(Xw), nrmse(X1), nrmse(X1nn)) = (29.25, 22.59, 24.31, 22.74)\n", "(minimum(bias), maximum(bias)) = (-0.008806088125023523, 0.007318190573222287)\n" ] }, { "data": { "image/png": "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" }, "execution_count": 9, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# compare training affine NN to wiener filter\n", "H1 = model1(Matrix(I, siz, siz)).data\n", "heatmap(H1, aspect_ratio=1, yflip=true, title=\"Learned filter for affine NN\")\n", "\n", "X1 = H1 * Ytest\n", "X1nn = model1(Ytest).data\n", "@show nrmse(Ytest), nrmse(Xw), nrmse(X1), nrmse(X1nn)\n", "bias = model1(zeros(siz)).data\n", "@show minimum(bias), maximum(bias)\n", "plot!()" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "### Examine a single hidden layer NN" ] }, { "cell_type": "code", "execution_count": 10, "metadata": {}, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "(loss(Ytest, Xtest)).data = 1.6297459564280765\n", "(loss(Ytest, Xtest)).data = 0.13810508088667367\n", "(loss(Ytest, Xtest)).data = 0.0988347042643051\n", "(loss(Ytest, Xtest)).data = 0.08523679598981156\n", "(loss(Ytest, Xtest)).data = 0.07852570095260787\n", "(loss(Ytest, Xtest)).data = 0.07451241745178142\n", "(loss(Ytest, Xtest)).data = 0.0715487967737228\n", "(loss(Ytest, Xtest)).data = 0.06936931898963397\n", "(loss(Ytest, Xtest)).data = 0.06765487239135241\n", "(loss(Ytest, Xtest)).data = 0.06628080658295542\n", "(loss(Ytest, Xtest)).data = 0.06517875230973584\n", "(loss(Ytest, Xtest)).data = 0.06417513692196619\n", "(loss(Ytest, Xtest)).data = 0.0634116191767757\n", "(loss(Ytest, Xtest)).data = 0.06275682770457232\n", "(loss(Ytest, Xtest)).data = 0.062141191910418524\n", "(loss(Ytest, Xtest)).data = 0.06160083181369067\n", "(loss(Ytest, Xtest)).data = 0.06117921680360624\n", "(loss(Ytest, Xtest)).data = 0.060793746684749884\n", "(loss(Ytest, Xtest)).data = 0.0604773951146003\n", "(loss(Ytest, Xtest)).data = 0.06021420788254041\n", "(loss(Ytest, Xtest)).data = 0.05995466430868372\n" ] } ], "source": [ "# create a basic NN model\n", "nhidden = siz*2 # neurons in hidden layer\n", "model2 = Chain(Dense(siz,nhidden,relu), Dense(nhidden,siz))\n", "loss(x, y) = mse(model2(x), y)\n", "\n", "iters = 2^12\n", "dataset = Base.Iterators.repeated((Ytrain, Xtrain), iters) # trick X,Y swap for denoising!\n", "\n", "evalcb = () -> @show(loss(Ytest,Xtest).data)\n", "cb = throttle(evalcb, 4)\n", "\n", "Flux.train!(loss, dataset, ADAM(Flux.params(model2)), cb=cb)" ] }, { "cell_type": "code", "execution_count": 11, "metadata": {}, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "(nrmse(Ytest), nrmse(Xw), nrmse(X1), nrmse(X1nn), nrmse(X2)) = (29.25, 22.59, 24.31, 22.74, 23.78)\n" ] }, { "data": { "text/plain": [ "(29.25, 22.59, 24.31, 22.74, 23.78)" ] }, "execution_count": 11, "metadata": {}, "output_type": "execute_result" } ], "source": [ "X2 = model2(Ytest).data\n", "@show nrmse(Ytest), nrmse(Xw), nrmse(X1), nrmse(X1nn), nrmse(X2)" ] }, { "cell_type": "code", "execution_count": 36, "metadata": {}, "outputs": [ { "data": { "image/png": "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fHx80LdvX5vqWPosJlhERERklauuIvT19cXDDz8MANiyZUuT+8ayuLg4s/KxY8c2W6egoAB6vR6xsbFmZyAa6+Tn58NgMJjV+fvvv7Fv3z4EBQUhOjoaABMsIiIiakFb7uRur+TkZADAwoULcfbsWVP5oUOH8OmnnyIwMBDTpk0zqzN9+nQEBgbi+++/x3fffWcqv3z5Mt5++22zdo2GDx+OkSNH4vLly5g7d66pvKGhAUlJSbhx4wZmzZoFb+/GVcmc5E5EREQuY+vWrcjIyDArq6+vx/3332/6+r333jP1KD3yyCN48803sXLlSgwePBijR49GfX09duzYAVEU8fXXXyM4ONisveDgYKxbtw7PPvssJk6ciFGjRiEkJAQ7d+6ETqfD7NmzERsb2yS2rKwsREVFYeXKldi9ezf69++Po0eP4ty5cxgxYgTeffdd07NMsMhpuMeV+3LlPa7agqd//0QtcXQVoT0qKipw+PBhszJJkszKKioqzO6vWLECgwcPxscff4wdO3bA29sbsbGxSElJMQ3Z3e7pp5/G3r17sXDhQvz888+or6/Hvffei9dffx2JiYkW60REROCXX35BamoqCgsLkZubix49eiAlJQXz5s0zG1IUJFs2hCC3d/z4cdx33304duxYs9v8k3VXr15t8n9BZDu+P8fw/ZESqqurERQUhGG+L6GDjBM5GqR6HK37ElVVVRa3Q2jPOAeLiIiIyMk4REhERERWyV0R2NqrCF0ZEywiIiKySpJ5FqEnz0LiECERERGRk7EHi4iIiKwSBRGCINpfD/bXaS+YYBEREZFVIkQIMpIlT06wOERIRERE5GTswSIiIiKrREgye7A8d5I7EywiIiKyyniyoJx6nopDhEREREROxh4sIiIiskoUJAhC25xF2F4wwSIiIiKruIrQfhwiJCIiInIy9mARERGRVezBsh97sNzcggULIAgCBEHAN998o3Q4RETUDhlXEcq5PBUTLDdWVlaGRYsWQRAEpUMhIiKiWzDBclOSJGHGjBnQaDR46qmnlA6HiIjaMVEQZV+eigmWm/rss8+wd+9eZGZmQqPRtPh8fX292T/JPgaDAUuWLIHBYFA6FLfE9+cYvj/HGAwGpKen8/05QIIo6w+HCMmtXLp0CW+//TZiY2MxefJkm+owwXKMwWDA0qVL+QtaJr4/x/D9OcZg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" }, "execution_count": 36, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# Examine joint distribution\n", "lag = 1\n", "tmp = circshift(Xtrain, (lag,))\n", "histogram2d(Xtrain[:], tmp[:])\n", "plot!(aspect_ratio=1, xlim=[-4,4], ylim=[-4,4])\n", "plot!(xlabel=L\"x[n]\", ylabel=latexstring(\"x[n-$lag \\\\ mod \\\\ N]\"))\n", "plot!(title=\"Joint histogram of neighbors\")" ] }, { "cell_type": "code", "execution_count": null, "metadata": {}, "outputs": [], "source": [] }, { "cell_type": "markdown", "metadata": {}, "source": [ "### Experiments below here - work in progress \n", "[https://github.com/FluxML/model-zoo/blob/master/vision/mnist/conv.jl]" ] }, { "cell_type": "code", "execution_count": 50, "metadata": {}, "outputs": [], "source": [ "model3 = Chain(\n", " Conv((2,2), 1=>16, relu),\n", " x -> maxpool(x, (2,2)),\n", " Conv((2,2), 16=>8, relu),\n", " x -> maxpool(x, (2,2)),\n", " x -> reshape(x, :, size(x, 4)))\n", "# Dense(288, 10), softmax)\n", "\n", "tmp = Xtrain[:,1:40];\n", "#model3(tmp)" ] }, { "cell_type": "code", "execution_count": 51, "metadata": {}, "outputs": [], "source": [ "tmp = Conv((3,1), 1=>1, relu)\n", "model3 = Chain(tmp)\n", "#model3 = Chain(Dense(siz,nhidden,relu))\n", "tmp = reshape(Xtrain[:,1], siz, 1);\n", "#model3(tmp)" ] }, { "cell_type": "code", "execution_count": 52, "metadata": {}, "outputs": [], "source": [ "tmp = Conv((3,3), 1=>1, relu)\n", "model3 = Chain(tmp)\n", "#model3 = Chain(Dense(siz,nhidden,relu))\n", "tmp = reshape(Xtrain[:,1], siz, 1)\n", "tmp = Xtrain[:,1:4];\n", "#model3(tmp)" ] }, { "cell_type": "code", "execution_count": 53, "metadata": {}, "outputs": [], "source": [ "# create a basic NN model\n", "nhidden = siz*2 # neurons in hidden layer\n", "model3 = Chain(Dense(siz,nhidden,relu), Dense(nhidden,siz))\n", "loss(x, y) = mse(model2(x), y)\n", "\n", "iters = 2^12\n", "dataset = Base.Iterators.repeated((Ytrain, Xtrain), iters) # trick X,Y swap for denoising!\n", "\n", "evalcb = () -> @show(loss(Ytest,Xtest).data)\n", "cb = throttle(evalcb, 4);\n", "\n", "#Flux.train!(loss, dataset, ADAM(Flux.params(model2)), cb=cb)" ] } ], "metadata": { "kernelspec": { "display_name": "Julia 1.0.1", "language": "julia", "name": "julia-1.0" }, "language_info": { "file_extension": ".jl", "mimetype": "application/julia", "name": "julia", "version": "1.0.1" } }, "nbformat": 4, "nbformat_minor": 2 }