Files
bildverarbeitungss18-hausau…/assignments/04_assignment.ipynb
2018-05-15 23:16:22 +02:00

405 lines
51 KiB
Plaintext

{
"cells": [
{
"cell_type": "markdown",
"metadata": {
"collapsed": true
},
"source": [
"# Image Processing SS 18 - Assignment - 04\n",
"\n",
"### Deadline is 16.5.2016 at 8:00 o'clock\n",
"\n",
"Please solve the assignments together with a partner.\n",
"I will run every notebook. Make sure the code runs through. Select `Kernel` -> `Restart & Run All` to test it.\n",
"Please strip the output from the cells, either select `Cell` -> `All Output` -> `Clear` or use the `nb_strip_output.py` script / git hook."
]
},
{
"cell_type": "code",
"execution_count": 90,
"metadata": {},
"outputs": [],
"source": [
"# display the plots inside the notebook\n",
"%matplotlib inline"
]
},
{
"cell_type": "code",
"execution_count": 91,
"metadata": {},
"outputs": [],
"source": [
"import numpy as np\n",
"import matplotlib.pyplot as plt\n",
"import pylab\n",
"try:\n",
" import urllib.request as urllib2\n",
"except ImportError:\n",
" import urllib2\n",
"\n",
"import random\n",
"try:\n",
" from StringIO import StringIO as BytesIO\n",
"except ImportError:\n",
" from io import BytesIO\n",
" \n",
"from PIL import Image\n",
"\n",
"pylab.rcParams['figure.figsize'] = (12, 12) # This makes the plot bigger"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"# Exercise 1 - Qualify sharpness and noise - 5 Points\n",
"\n",
"Qualify the noise and sharpness in the images. Make a plot images, noise\n",
"\n",
"Please download sample picture from [here](http://sipi.usc.edu/database/misc.zip)"
]
},
{
"cell_type": "code",
"execution_count": 92,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"'/media/sebastian/Daten/nextcloud/Documents/Programmierung/Python/BildverarbeitungSS18/Hausaufgaben'"
]
},
"execution_count": 91,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"%pwd"
]
},
{
"cell_type": "code",
"execution_count": 93,
"metadata": {},
"outputs": [],
"source": [
"# Load the pictures here\n",
"\n",
"sample_images = []\n",
"direc = 'misc/' # directory of the sample pictures relatively to your notebook\n",
"for number in [1,3,5,6]:\n",
" sample_images.append(\n",
" np.array(Image.open(direc+'4.2.0'+str(number)+'.tiff'))\n",
" )\n",
"for name in ['house']:\n",
" sample_images.append(\n",
" np.array(Image.open(direc+name+'.tiff'))\n",
" )"
]
},
{
"cell_type": "code",
"execution_count": 94,
"metadata": {
"collapsed": false
},
"outputs": [
{
"data": {
"text/plain": [
"<Container object of 5 artists>"
]
},
"execution_count": 93,
"metadata": {},
"output_type": "execute_result"
},
{
"data": {
"image/png": "iVBORw0KGgoAAAANSUhEUgAAAsMAAAKvCAYAAACPusJjAAAABHNCSVQICAgIfAhkiAAAAAlwSFlz\nAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDIuMS4wLCBo\ndHRwOi8vbWF0cGxvdGxpYi5vcmcvpW3flQAAFT1JREFUeJzt3V/IZHd9x/HPt1nFf9D4Z5E0kW5A\nsQRBLUtqCfQiaSFtxORCxNJKKCm50TZWQdfeSO8iFP9clEIwtoGKf1AhYqQlxJRSKGk3mlaTVQw2\naiSalWq1vahN/fVipzRNI/uYnXnG9fN6wcMzZ+acnS8cln1z9sz8Zq0VAABo9DP7HgAAAPZFDAMA\nUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQ68hhvtkLXvCCdezYscN8SwAAytx7\n773fXmsdPci+hxrDx44dy8mTJw/zLQEAKDMzXz3ovm6TAACglhgGAKCWGAYAoJYYBgCglhgGAKCW\nGAYAoJYYBgCglhgGAKCWGAYAoJYYBgCglhgGAKCWGAYAoJYYBgCglhgGAKCWGAYAoJYYBgCglhgG\nAKCWGAYAoJYYBgCglhgGAKCWGAYAoJYYBgCglhgGAKCWGAYAoJYYBgCglhgGAKCWGAYAoJYYBgCg\nlhgGAKCWGAYAoNaRfQ8AANt07MQd+x6BJ3jo5mv2PQL8SK4MAwBQSwwDAFBLDAMAUEsMAwBQSwwD\nAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQ\nSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsM\nAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMA\nUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBL\nDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwD\nAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQ\nSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsM\nAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQ68i+B4BdOnbijn2PwJN46OZr9j0CACQ5\n4JXhmfmDmbl/Zr4wMx+amWfMzKUzc8/MPDgzH5mZp+96WAAA2KazxvDMXJzk95McX2u9LMkFSV6f\n5F1J3rPWenGS7yS5YZeDAgDAth30nuEjSZ45M0eSPCvJI0muTPKxzeu3Jblu++MBAMDunDWG11rf\nSPLHSb6WMxH8r0nuTfLdtdZjm90eTnLxroYEAIBdOMhtEs9Ncm2SS5P8XJJnJ7n6oG8wMzfOzMmZ\nOXn69OmnPCgAAGzbQW6T+NUk/7zWOr3W+s8kn0hyRZILN7dNJMklSb7xZAevtW5Zax1fax0/evTo\nVoYGAIBtOEgMfy3Jq2bmWTMzSa5K8kCSu5O8drPP9Ulu382IAACwGwe5Z/ienPmg3GeTfH5zzC1J\n3p7kLTPzYJLnJ7l1h3MCAMDWHWjRjbXWO5O88wlPfyXJ5VufCAAADonlmAEAqCWGAQCoJYYBAKgl\nhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYB\nAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCo\nJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWG\nAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEA\nqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKgl\nhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYB\nAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCo\nJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWG\nAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEA\nqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKgl\nhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCodaAYnpkLZ+ZjM/PFmTk1M788M8+bmTtn5sub38/d9bAA\nALBNB70y/L4kf7nW+oUkL09yKsmJJHettV6S5K7NNgAAnDfOGsMz87NJfiXJrUmy1vrBWuu7Sa5N\ncttmt9uSXLerIQEAYBcOcmX40iSnk/zZzHxuZt4/M89O8sK11iObfb6Z5IW7GhIAAHbhIDF8JMkv\nJvnTtdYrk/x7nnBLxFprJVlPdvDM3DgzJ2fm5OnTp891XgAA2JqDxPDDSR5ea92z2f5YzsTxt2bm\noiTZ/H70yQ5ea92y1jq+1jp+9OjRbcwMAABbcdYYXmt9M8nXZ+alm6euSvJAkk8muX7z3PVJbt/J\nhAAAsCNHDrjf7yX54Mw8PclXkvxOzoT0R2fmhiRfTfK63YwIAAC7caAYXmvdl+T4k7x01XbHAQCA\nw2MFOgAAaolhAABqiWEAAGqJYQAAaolhAABqiWEAAGod9HuGAQB+oh07cce+R+AJHrr5mn2PcFau\nDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwD\nAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQ\nSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsM\nAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMA\nUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBL\nDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwD\nAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQ\nSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUOvIvgc4DMdO3LHvEXgSD918\nzb5HAADKuTIMAEAtMQwAQC0xDABALTEMAEAtMQwAQC0xDABALTEMAEAtMQwAQC0xDABALTEMAEAt\nMQwAQC0xDABALTEMAEAtMQwAQC0xDABALTEMAEAtMQwAQC0xDABALTEMAEAtMQwAQC0xDABALTEM\nAEAtMQwAQC0xDABALTEMAEAtMQwAQK0Dx/DMXDAzn5uZT222L52Ze2bmwZn5yMw8fXdjAgDA9v04\nV4ZvSnLqcdvvSvKetdaLk3wnyQ3bHAwAAHbtQDE8M5ckuSbJ+zfbk+TKJB/b7HJbkut2MSAAAOzK\nQa8MvzfJ25L8cLP9/CTfXWs9ttl+OMnFW54NAAB26qwxPDOvTvLoWuvep/IGM3PjzJycmZOnT59+\nKn8EAADsxEGuDF+R5DUz81CSD+fM7RHvS3LhzBzZ7HNJkm882cFrrVvWWsfXWsePHj26hZEBAGA7\nzhrDa613rLUuWWsdS/L6JJ9Za/1WkruTvHaz2/VJbt/ZlAAAsAPn8j3Db0/ylpl5MGfuIb51OyMB\nAMDhOHL2Xf7XWuuvk/z15vFXkly+/ZEAAOBwWIEOAIBaYhgAgFpiGACAWmIYAIBaYhgAgFpiGACA\nWmIYAIBaYhgAgFpiGACAWmIYAIBaYhgAgFpiGACAWmIYAIBaYhgAgFpiGACAWmIYAIBaYhgAgFpi\nGACAWmIYAIBaYhgAgFpiGACAWmIYAIBaYhgAgFpiGACAWmIYAIBaYhgAgFpiGACAWmIYAIBaYhgA\ngFpiGACAWmIYAIBaYhgAgFpiGACAWmIYAIBaYhgAgFpiGACAWmIYAIBaYhgAgFpiGACAWmIYAIBa\nYhgAgFpiGACAWmIYAIBaYhgAgFpiGACAWmIYAIBaYhgAgFpiGACAWmIYAIBaYhgAgFpiGACAWmIY\nAIBaYhgAgFpiGACAWmIYAIBaYhgAgFpiGACAWmIYAIBaYhgAgFpH9j0AwC4cO3HHvkfgCR66+Zp9\njwDw/7gyDABALTEMAEAtMQwAQC0xDABALTEMAEAtMQwAQC0xDABALTEMAEAtMQwAQC0xDABALTEM\nAEAtMQwAQC0xDABALTEMAEAtMQwAQC0xDABALTEMAEAtMQwAQC0xDABALTEMAEAtMQwAQC0xDABA\nLTEMAEAtMQwAQC0xDABALTEMAEAtMQwAQC0xDABALTEMAEAtMQwAQC0xDABALTEMAEAtMQwAQC0x\nDABALTEMAEAtMQwAQC0xDABALTEMAEAtMQwAQC0xDABALTEMAEAtMQwAQC0xDABALTEMAEAtMQwA\nQC0xDABALTEMAEAtMQwAQC0xDABALTEMAEAtMQwAQC0xDABALTEMAEAtMQwAQC0xDABALTEMAEAt\nMQwAQC0xDABALTEMAEAtMQwAQC0xDABALTEMAECts8bwzLxoZu6emQdm5v6ZuWnz/PNm5s6Z+fLm\n93N3Py4AAGzPQa4MP5bkrWuty5K8KskbZ+ayJCeS3LXWekmSuzbbAABw3jhrDK+1HllrfXbz+PtJ\nTiW5OMm1SW7b7HZbkut2NSQAAOzCj3XP8MwcS/LKJPckeeFa65HNS99M8sKtTgYAADt24Biemeck\n+XiSN6+1vvf419ZaK8n6EcfdODMnZ+bk6dOnz2lYAADYpgPF8Mw8LWdC+INrrU9snv7WzFy0ef2i\nJI8+2bFrrVvWWsfXWsePHj26jZkBAGArDvJtEpPk1iSn1lrvftxLn0xy/ebx9Ulu3/54AACwO0cO\nsM8VSd6Q5PMzc9/muT9McnOSj87MDUm+muR1uxkRAAB246wxvNb62yTzI16+arvjAADA4bECHQAA\ntcQwAAC1xDAAALXEMAAAtcQwAAC1xDAAALXEMAAAtcQwAAC1xDAAALXEMAAAtcQwAAC1xDAAALXE\nMAAAtcQwAAC1xDAAALXEMAAAtcQwAAC1xDAAALXEMAAAtcQwAAC1xDAAALXEMAAAtcQwAAC1xDAA\nALXEMAAAtcQwAAC1xDAAALXEMAAAtcQwAAC1xDAAALXEMAAAtcQwAAC1xDAAALXEMAAAtcQwAAC1\nxDAAALXEMAAAtcQwAAC1xDAAALXEMAAAtcQwAAC1xDAAALXEMAAAtcQwAAC1xDAAALXEMAAAtcQw\nAAC1xDAAALXEMAAAtcQwAAC1xDAAALXEMAAAtcQwAAC1xDAAALXEMAAAtcQwAAC1xDAAALXEMAAA\ntcQwAAC1xDAAALXEMAAAtcQwAAC1xDAAALXEMAAAtcQwAAC1xDAAALXEMAAAtcQwAAC1xDAAALXE\nMAAAtcQwAAC1xDAAALXEMAAAtcQwAAC1xDAAALXEMAAAtcQwAAC1xDAAALXEMAAAtcQwAAC1xDAA\nALXEMAAAtcQwAAC1xDAAALXEMAAAtcQwAAC1xDAAALXEMAAAtcQwAAC1xDAAALXEMAAAtcQwAAC1\nxDAAALXEMAAAtcQwAAC1xDAAALXEMAAAtcQwAAC1xDAAALXEMAAAtcQwAAC1xDAAALXEMAAAtcQw\nAAC1xDAAALXEMAAAtcQwAAC1xDAAALXEMAAAtcQwAAC1xDAAALXEMAAAtcQwAAC1xDAAALXEMAAA\ntcQwAAC1xDAAALXEMAAAtcQwAAC1xDAAALXEMAAAtcQwAAC1zimGZ+bqmfnSzDw4Mye2NRQAAByG\npxzDM3NBkj9J8utJLkvymzNz2bYGAwCAXTuXK8OXJ3lwrfWVtdYPknw4ybXbGQsAAHbvXGL44iRf\nf9z2w5vnAADgvDBrrad24Mxrk1y91vrdzfYbkvzSWutNT9jvxiQ3bjZfmuRLT31ckrwgybf3PQR7\n4dz3cu47Oe+9nPtz9/NrraMH2fHIObzJN5K86HHbl2ye+z/WWrckueUc3ofHmZmTa63j+56Dw+fc\n93LuOznvvZz7w3Uut0n8Q5KXzMylM/P0JK9P8sntjAUAALv3lK8Mr7Uem5k3JfmrJBck+cBa6/6t\nTQYAADt2LrdJZK316SSf3tIsHIxbTno5972c+07Oey/n/hA95Q/QAQDA+c5yzAAA1BLD5wlLX/ea\nmQ/MzKMz84V9z8LhmZkXzczdM/PAzNw/MzfteyYOx8w8Y2b+fmb+cXPu/2jfM3G4ZuaCmfnczHxq\n37M0EMPnAUtf1/vzJFfvewgO3WNJ3rrWuizJq5K80d/7Gv+R5Mq11suTvCLJ1TPzqj3PxOG6Kcmp\nfQ/RQgyfHyx9XWyt9TdJ/mXfc3C41lqPrLU+u3n8/Zz5h9EqnwXWGf+22Xza5scHfErMzCVJrkny\n/n3P0kIMnx8sfQ3FZuZYklcmuWe/k3BYNv9Nfl+SR5PcudZy7nu8N8nbkvxw34O0EMMAP8Fm5jlJ\nPp7kzWut7+17Hg7HWuu/1lqvyJnVXS+fmZfteyZ2b2ZeneTRtda9+56liRg+Pxxo6Wvgp8vMPC1n\nQviDa61P7HseDt9a67tJ7o7PDbS4IslrZuahnLkl8sqZ+Yv9jvTTTwyfHyx9DWVmZpLcmuTUWuvd\n+56HwzMzR2fmws3jZyb5tSRf3O9UHIa11jvWWpestY7lzL/1n1lr/faex/qpJ4bPA2utx5L8z9LX\np5J81NLXPWbmQ0n+LslLZ+bhmblh3zNxKK5I8oacuTJ03+bnN/Y9FIfioiR3z8w/5czFkDvXWr5i\nC3bECnQAANRyZRgAgFpiGACAWmIYAIBaYhgAgFpiGACAWmIYAIBaYhgAgFpiGACAWv8NIQVXd62O\nGPAAAAAASUVORK5CYII=\n",
"text/plain": [
"<matplotlib.figure.Figure at 0x7f0b553c1a20>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"def qualify_noise(img):\n",
" def mu2(img):\n",
" result = []\n",
" for i in range(img.shape[2]):\n",
" result.append(np.average(img[:, :, i]))\n",
" return np.array(result) # [mu(r), mu(g), mu(b)]\n",
" \"\"\"Qualify the noise based on the std of a gaussian model.\n",
" You may find a window that is contant in the images.\n",
" \"\"\"\n",
" # your code here\n",
" WINDOW_SIZE = 128\n",
" SHIFT = 128\n",
" w, h, d = img.shape\n",
" std = []\n",
" for ox in range(0, w-WINDOW_SIZE+1, SHIFT):\n",
" for oy in range(0, h-WINDOW_SIZE+1, SHIFT):\n",
" std_sum = np.std(img[ox:ox+WINDOW_SIZE, oy:oy+WINDOW_SIZE, 0]) + \\\n",
" np.std(img[ox:ox+WINDOW_SIZE, oy:oy+WINDOW_SIZE, 1]) + \\\n",
" np.std(img[ox:ox+WINDOW_SIZE, oy:oy+WINDOW_SIZE, 2])\n",
" std.append(std_sum)\n",
" \n",
" return np.min(std)\n",
"\n",
"plt.bar(range(len(sample_images)), [qualify_noise(i) for i in sample_images])"
]
},
{
"cell_type": "code",
"execution_count": 95,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"<Container object of 5 artists>"
]
},
"execution_count": 94,
"metadata": {},
"output_type": "execute_result"
},
{
"data": {
"image/png": "iVBORw0KGgoAAAANSUhEUgAAAsMAAAKvCAYAAACPusJjAAAABHNCSVQICAgIfAhkiAAAAAlwSFlz\nAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDIuMS4wLCBo\ndHRwOi8vbWF0cGxvdGxpYi5vcmcvpW3flQAAFNBJREFUeJzt3U/IZXd9x/HPt5mIgotoHULIaEdQ\nLKFghCFNyabECmkjmoUUpZUsUrJRiFSwY3dCF3GjdtFNMGKg4h9UiBihhBiRgsRONFpjKqYSaSSa\nEQ3qxhL9dTFXmKZJ58nMvc91/Lxe8PCcc+65nC8chufNmXPvmbVWAACg0e/tewAAANgXMQwAQC0x\nDABALTEMAEAtMQwAQC0xDABALTEMAEAtMQwAQC0xDABArSOHebCXvexl6/jx44d5SAAAyjz44IM/\nXmsdPci+hxrDx48fz6lTpw7zkAAAlJmZ7x90X7dJAABQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMA\nUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBL\nDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwDAFBLDAMAUEsMAwBQSwwD\nAFBLDAMAUOvIvgcA2IXjJ+/Z9wg8w2O337jvEQD+D1eGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKgl\nhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYB\nAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCo\nJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWG\nAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEA\nqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKgl\nhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqHXgGJ6ZS2bm\n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\ntcQwAAC1xDAAALXEMAAAtcQwAAC1xDAAALXEMAAAtcQwAAC1xDAAALXEMAAAtcQwAAC1xDAAALXE\nMAAAtcQwAAC1xDAAALXEMAAAtcQwAAC1xDAAALXEMAAAtcQwAAC1xDAAALXEMAAAtcQwAAC1xDAA\nALXEMAAAtcQwAAC1xDAAALXEMAAAtcQwAAC1zhnDM/ORmXlyZr511raXzsy9M/Pdze+X7HZMAADY\nvoNcGf5okhuese1kkvvWWq9Oct9mHQAALirnjOG11peT/OQZm9+c5K7N8l1JbtryXAAAsHPne8/w\n5WutJzbLP0xy+ZbmAQCAQ3PBH6Bba60k67len5lbZ+bUzJw6ffr0hR4OAAC25nxj+Eczc0WSbH4/\n+Vw7rrXuWGudWGudOHr06HkeDgAAtu98Y/hzSW7eLN+c5O7tjAMAAIfnIF+t9vEkX0nympl5fGZu\nSXJ7kjfMzHeT/NlmHQAALipHzrXDWuttz/HS67c8CwAAHCpPoAMAoJYYBgCglhgGAKCWGAYAoJYY\nBgCglhgGAKCWGAYAoJYYBgCglhgGAKCWGAYAoJYYBgCglhgGAKCWGAYAoJYYBgCglhgGAKCWGAYA\noJYYBgCglhgGAKCWGAYAoJYYBgCglhgGAKCWGAYAoJYYBgCglhgGAKCWGAYAoJYYBgCglhgGAKCW\nGAYAoJYYBgCglhgGAKCWGAYAoJYYBgCglhgGAKCWGAYAoJYYBgCglhgGAKCWGAYAoJYYBgCglhgG\nAKCWGAYAoJYYBgCglhgGAKCWGAYAoJYYBgCglhgGAKCWGAYAoJYYBgCglhgGAKCWGAYAoJYYBgCg\nlhgGAKCWGAYAoJYYBgCglhgGAKCWGAYAoJYYBgCglhgGAKCWGAYAoJYYBgCglhgGAKCWGAYAoJYY\nBgCglhgGAKCWGAYAoJYYBgCglhgGAKCWGAYAoJYYBgCglhgGAKCWGAYAoJYYBgCglhgGAKCWGAYA\noJYYBgCglhgGAKCWGAYAoJYYBgCglhgGAKCWGAYAoJYYBgCglhgGAKCWGAYAoJYYBgCglhgGAKCW\nGAYAoJYYBgCglhgGAKCWGAYAoJYYBgCglhgGAKCWGAYAoJYYBgCglhgGAKCWGAYAoJYYBgCglhgG\nAKCWGAYAoJYYBgCglhgGAKCWGAYAoJYYBgCglhgGAKCWGAYAoJYYBgCglhgGAKCWGAYAoJYYBgCg\nlhgGAKCWGAYAoJYYBgCglhgGAKCWGAYAoJYYBgCglhgGAKCWGAYAoJYYBgCglhgGAKCWGAYAoJYY\nBgCglhgGAKCWGAYAoJYYBgCglhgGAKCWGAYAoJYYBgCglhgGAKCWGAYAoNYFxfDM3DAz35mZR2fm\n5LaGAgCAw3DeMTwzlyT5pyR/nuSqJG+bmau2NRgAAOzahVwZvibJo2ut7621/jvJJ5K8eTtjAQDA\n7l1IDF+Z5L/OWn98sw0AAC4Ks9Y6vzfOvCXJDWutv9msvz3JH6+13vmM/W5Ncutm9TVJvnP+45Lk\nZUl+vO8h2Avnvpdz38l57+XcX7g/WGsdPciORy7gID9I8vKz1o9ttv0va607ktxxAcfhLDNzaq11\nYt9zcPic+17OfSfnvZdzf7gu5DaJf0vy6pl55cy8IMlbk3xuO2MBAMDunfeV4bXW0zPzziT/kuSS\nJB9Zaz28tckAAGDHLuQ2iay1vpDkC1uahYNxy0kv576Xc9/Jee/l3B+i8/4AHQAAXOw8jhkAgFpi\n+CLh0de9ZuYjM/PkzHxr37NweGbm5TNz/8x8e2Yenpnb9j0Th2NmXjgzX52Zb2zO/fv2PROHa2Yu\nmZmvz8zn9z1LAzF8EfDo63ofTXLDvofg0D2d5N1rrauSXJvkHf7d1/hlkuvXWq9NcnWSG2bm2j3P\nxOG6Lckj+x6ihRi+OHj0dbG11peT/GTfc3C41lpPrLW+tln+ec78YfSUzwLrjF9sVi/d/PiAT4mZ\nOZbkxiQf3vcsLcTwxcGjr6HYzBxP8rokD+x3Eg7L5r/JH0ryZJJ711rOfY8PJXlPkl/ve5AWYhjg\nt9jMvDjJZ5K8a631s33Pw+FYa/1qrXV1zjzd9ZqZ+aN9z8Tuzcwbkzy51npw37M0EcMXhwM9+hr4\n3TIzl+ZMCH9srfXZfc/D4VtrPZXk/vjcQIvrkrxpZh7LmVsir5+Zf97vSL/7xPDFwaOvoczMTJI7\nkzyy1vrAvufh8MzM0Zm5bLP8oiRvSPIf+52Kw7DWeu9a69ha63jO/K3/4lrrr/c81u88MXwRWGs9\nneQ3j75+JMmnPPq6x8x8PMlXkrxmZh6fmVv2PROH4rokb8+ZK0MPbX7+Yt9DcSiuSHL/zHwzZy6G\n3LvW8hVbsCOeQAcAQC1XhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCoJYYBAKglhgEAqCWGAQCo9T+4\nCz2ha4YL8QAAAABJRU5ErkJggg==\n",
"text/plain": [
"<matplotlib.figure.Figure at 0x7f0b55368b38>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"def qualify_sharpness(img):\n",
" \"\"\"Qualify the sharpness based on the average pixel differences.\"\"\"\n",
" # your code here\n",
" WINDOW_SIZE = 128\n",
" SHIFT = 128\n",
" w, h, d = img.shape\n",
" std = []\n",
" for ox in range(0, w-WINDOW_SIZE+1, SHIFT):\n",
" for oy in range(0, h-WINDOW_SIZE+1, SHIFT):\n",
" std_sum = np.std(img[ox:ox+WINDOW_SIZE, oy:oy+WINDOW_SIZE, 0]) + \\\n",
" np.std(img[ox:ox+WINDOW_SIZE, oy:oy+WINDOW_SIZE, 1]) + \\\n",
" np.std(img[ox:ox+WINDOW_SIZE, oy:oy+WINDOW_SIZE, 2])\n",
" std.append(std_sum)\n",
" \n",
" return np.std(std)\n",
"plt.bar(range(len(sample_images)), [qualify_sharpness(i) for i in sample_images])"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Does the result match the expectations? If not what processing step can be done?/"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"# Exercise 2 - SSIM JPEG Compression - 5 Points"
]
},
{
"cell_type": "code",
"execution_count": 96,
"metadata": {},
"outputs": [],
"source": [
"def jpeg_enocde(img, quality):\n",
" pil_img = Image.fromarray(img)\n",
" buffer = BytesIO()\n",
" pil_img.save(buffer, \"JPEG\", quality=quality)\n",
" return buffer\n",
"\n",
"def jpeg_decode(buffer):\n",
" img = Image.open(buffer)\n",
" return np.array(img)\n",
"\n",
"def jpeg_quality_filter(img, quality):\n",
" as_jpeg = jpeg_enocde(img, quality)\n",
" return jpeg_decode(as_jpeg)"
]
},
{
"cell_type": "code",
"execution_count": 97,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"3"
]
},
"execution_count": 96,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"images_for_jpeg = sample_images[2::]\n",
"len(images_for_jpeg)"
]
},
{
"cell_type": "code",
"execution_count": 98,
"metadata": {},
"outputs": [],
"source": [
"images1 = [jpeg_quality_filter(img, 1) for img in images_for_jpeg]\n",
"images10 = [jpeg_quality_filter(img, 10) for img in images_for_jpeg]\n",
"images50 = [jpeg_quality_filter(img, 50) for img in images_for_jpeg]\n",
"images80 = [jpeg_quality_filter(img, 80) for img in images_for_jpeg]"
]
},
{
"cell_type": "code",
"execution_count": 99,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"0\n"
]
},
{
"data": {
"image/png": "iVBORw0KGgoAAAANSUhEUgAAAsYAAAKvCAYAAABpkwknAAAABHNCSVQICAgIfAhkiAAAAAlwSFlz\nAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDIuMS4wLCBo\ndHRwOi8vbWF0cGxvdGxpYi5vcmcvpW3flQAAGIxJREFUeJzt3X2MZed90PHvr3bcIBKagpcS+SUb\nwJVqQiFhZYIiQaSmkpNINlJLZSNoU6W1eAkUtUIyL3Ih/JMUqaCCIbVo1bQqSU1A7dI4MgFSRUI4\neNMmIbZxWUyKbQJ20zQlCm1wefhjbmAy2fHcZGZ2dtnPR7ra+/Lo3kePzu757plz58xaKwAAuNJ9\n1UlPAAAALgXCGAAAEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQFVXn9QHX3vttev0\n6dMn9fEAAFwhPvzhD//yWuvUQeNOLIxPnz7duXPnTurjAQC4QszML20zzqkUAACQMAYAgEoYAwBA\nJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUAljAACohDEA\nAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUG0RxjPzozPzzMx8fJ/XZ2Z+aGbOz8zHZuZV\nRz9NAAA4XtscMf6x6tbnef311U2b213VPzz8tAAA4OI6MIzXWh+sfuV5htxe/fja8VD1kpl56VFN\nEAAALoajOMf4uurJXY+f2jwHAACXjYv65buZuWtmzs3MuWefffZifjQAADyvowjjp6sbdj2+fvPc\nl1hr3bfWOrPWOnPq1Kkj+GgAADgaRxHGZ6tv3/x2ildXn1lrffII3hcAAC6aqw8aMDPvql5bXTsz\nT1XfX72gaq31juqB6g3V+epz1Xce12QBAOC4HBjGa607D3h9VX/+yGYEAAAn4MAwBgA4Cqfvfu9J\nT4ET9Im3vfGkp3Agl4QGAICEMQAAVE6lALii+FH2le1y+FE2nCRHjAEAIGEMAACVMAYAgEoYAwBA\nJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKCqq096AnClOX33e096\nCpygT7ztjSc9BQD24YgxAAAkjAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAl\njAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAA\nVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgD\nAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAqq4+6QmchNN3v/ekp8AJ+sTb3njS\nUwAALkGOGAMAQMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwA\nAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLG\nAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAq\nYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEA\noBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVFuG\n8czcOjOPz8z5mbn7Aq/fODMfmJlfmJmPzcwbjn6qAABwfA4M45m5qrq3en11c3XnzNy8Z9hfr+5f\na72yuqP6B0c9UQAAOE7bHDG+pTq/1npirfX56t3V7XvGrOq3be5/TfVfj26KAABw/K7eYsx11ZO7\nHj9V/eE9Y/5G9S9m5i9Uv7V63ZHMDgAALpKj+vLdndWPrbWur95Q/cTMfMl7z8xdM3NuZs49++yz\nR/TRAABweNuE8dPVDbseX795brc3V/dXrbX+bfXC6tq9b7TWum+tdWatdebUqVNf2YwBAOAYbBPG\nD1c3zczLZ+aadr5cd3bPmP9SfVPVzHxDO2HskDAAAJeNA8N4rfVc9Zbqweqxdn77xCMz89aZuW0z\n7Puq756Zj1bvqt601lrHNWkAADhq23z5rrXWA9UDe567Z9f9R6vXHO3UAADg4nHlOwAASBgDAEAl\njAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAA\nVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgD\nAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiE\nMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCA\nShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMA\nAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUw\nBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQ\nCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwA\nAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLG\nAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQbRnGM3PrzDw+M+dn5u59\nxnzbzDw6M4/MzD8+2mkCAMDxuvqgATNzVXVv9c3VU9XDM3N2rfXorjE3VX+les1a69Mz8zuPa8IA\nAHActjlifEt1fq31xFrr89W7q9v3jPnu6t611qer1lrPHO00AQDgeG0TxtdVT+56/NTmud2+vvr6\nmfk3M/PQzNx6VBMEAICL4cBTKb6M97mpem11ffXBmfn9a61f3T1oZu6q7qq68cYbj+ijAQDg8LY5\nYvx0dcOux9dvntvtqersWut/rbX+c/WL7YTyF1lr3bfWOrPWOnPq1KmvdM4AAHDktgnjh6ubZubl\nM3NNdUd1ds+Yn27naHEzc207p1Y8cYTzBACAY3VgGK+1nqveUj1YPVbdv9Z6ZGbeOjO3bYY9WH1q\nZh6tPlD95bXWp45r0gAAcNS2Osd4rfVA9cCe5+7ZdX9V37u5AQDAZceV7wAAIGEMAACVMAYAgEoY\nAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUAljAACo\nhDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYA\ngEoYAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUAlj\nAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACV\nMAYAgEoYAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAA\nUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEM\nAACVMAYAgEoYAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKAS\nxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAA\nKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwB\nAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKDaMoxn5taZeXxmzs/M3c8z\n7ltmZs3MmaObIgAAHL8Dw3hmrqrurV5f3VzdOTM3X2Dci6vvqT501JMEAIDjts0R41uq82utJ9Za\nn6/eXd1+gXF/q3p79etHOD8AALgotgnj66ondz1+avPc/zUzr6puWGu99/neaGbumplzM3Pu2Wef\n/bInCwAAx+XQX76bma+qfrD6voPGrrXuW2udWWudOXXq1GE/GgAAjsw2Yfx0dcOux9dvnvuCF1ev\nqH5uZj5Rvbo66wt4AABcTrYJ44erm2bm5TNzTXVHdfYLL661PrPWunatdXqtdbp6qLptrXXuWGYM\nAADH4MAwXms9V72lerB6rLp/rfXIzLx1Zm477gkCAMDFcPU2g9ZaD1QP7Hnunn3Gvvbw0wIAgIvL\nle8AACBhDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMA\nQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQx\nAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBK\nGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAA\nqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAG\nAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJ\nYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAA\nlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYA\nAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACph\nDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQLVlGM/M\nrTPz+Mycn5m7L/D6987MozPzsZn5VzPzsqOfKgAAHJ8Dw3hmrqrurV5f3VzdOTM37xn2C9WZtdY3\nVu+pfuCoJwoAAMdpmyPGt1Tn11pPrLU+X727un33gLXWB9Zan9s8fKi6/minCQAAx2ubML6uenLX\n46c2z+3nzdX7DjMpAAC42K4+yjebmT9Vnan+2D6v31XdVXXjjTce5UcDAMChbHPE+Onqhl2Pr988\n90Vm5nXVX6tuW2v9xoXeaK1131rrzFrrzKlTp76S+QIAwLHYJowfrm6amZfPzDXVHdXZ3QNm5pXV\nD7cTxc8c/TQBAOB4HRjGa63nqrdUD1aPVfevtR6ZmbfOzG2bYX+7elH1T2bmIzNzdp+3AwCAS9JW\n5xivtR6oHtjz3D277r/uiOcFAAAXlSvfAQBAwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJ\nYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAA\nlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYA\nAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACph\nDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCg\nEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgA\nACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQCWM\nAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABU\nwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMA\nQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQx\nAABUwhgAACphDAAAlTAGAIBqyzCemVtn5vGZOT8zd1/g9a+emZ/avP6hmTl91BMFAIDjdGAYz8xV\n1b3V66ubqztn5uY9w95cfXqt9Xurv1O9/agnCgAAx2mbI8a3VOfXWk+stT5fvbu6fc+Y26t3bu6/\np/qmmZmjmyYAAByvbcL4uurJXY+f2jx3wTFrreeqz1S/4ygmCAAAF8PVF/PDZuau6q7Nw8/OzONf\nwdtcW/3y0c3qinRFr+Ec/kSfK3r9jsAVvX62vxN3Ra+f7e/EXdHrd8Lb38u2GbRNGD9d3bDr8fWb\n5y405qmZubr6mupTe99orXVfdd82E9vPzJxba505zHtc6azh4Vi/w7F+h2P9Dsf6HY71OxzrdzgX\nY/22OZXi4eqmmXn5zFxT3VGd3TPmbPUdm/vfWv3rtdY6umkCAMDxOvCI8VrruZl5S/VgdVX1o2ut\nR2bmrdW5tdbZ6keqn5iZ89WvtBPPAABw2djqHOO11gPVA3ueu2fX/V+v/sTRTm1fhzoVg8oaHpb1\nOxzrdzjW73Cs3+FYv8Oxfodz7Os3zngAAACXhAYAgOoyCOOZ+e0z8/6Z+Y+bP792n3G/OTMf2dz2\nfjnwiuMy3oezxfq9aWae3bXNfddJzPNSNTM/OjPPzMzH93l9ZuaHNuv7sZl51cWe46Vsi/V77cx8\nZtf2d8+Fxl2pZuaGmfnAzDw6M4/MzPdcYIxtcB9brp9tcB8z88KZ+Xcz89HN+v3NC4yxD97Hlut3\nfPvgtdYlfat+oLp7c//u6u37jPvsSc/1Urm18yXJ/1T97uqa6qPVzXvG/LnqHZv7d1Q/ddLzvlRu\nW67fm6q/f9JzvVRv1R+tXlV9fJ/X31C9r5rq1dWHTnrOl9Jti/V7bfWzJz3PS/VWvbR61eb+i6tf\nvMDfYdvg4dbPNrj/+k31os39F1Qfql69Z4x98OHW79j2wZf8EeO++HLT76z++AnO5XLhMt6Hs836\n8TzWWh9s5zfU7Of26sfXjoeql8zMSy/O7C59W6wfz2Ot9cm11s9v7v+P6rG+9IqttsF9bLl+7GOz\nTX128/AFm9veL3TZB+9jy/U7NpdDGH/dWuuTm/v/rfq6fca9cGbOzcxDM3Olx7PLeB/ONutX9S2b\nH8G+Z2ZuuMDr7G/bNWZ/f2Tzo8b3zczvO+nJXKo2P6J+ZTtHnXazDW7hedavbIP7mpmrZuYj1TPV\n+9da+25/9sFfaov1q2PaB18SYTwz/3JmPn6B2xcdpVs7x8/3+1/Dy9bO1VD+ZPV3Z+b3HPe8uaL9\n8+r0Wusbq/f3//7nDxfDz7fzb94fqP5e9dMnPJ9L0sy8qPqn1V9aa/3aSc/ncnPA+tkGn8da6zfX\nWn+wnasF3zIzrzjpOV1Otli/Y9sHXxJhvNZ63VrrFRe4/Uz137/w463Nn8/s8x5Pb/58ovq5dv6H\ne6X6ci7j3TzPZbyvUAeu31rrU2ut39g8/EfVH7pIc/v/xTbbKPtYa/3aF37UuHZ+z/wLZubaE57W\nJWVmXtBO1P3kWuufXWCIbfB5HLR+tsHtrLV+tfpAdeuel+yDt7Df+h3nPviSCOMD7L7c9HdUP7N3\nwMx87cx89eb+tdVrqkcv2gwvPS7jfTgHrt+ecxFva+ccPLZ3tvr2zW8GeHX1mV2nTHGAmfldXzgf\ncWZuaeffcjvVjc3a/Ej12FrrB/cZZhvcxzbrZxvc38ycmpmXbO7/luqbq/+wZ5h98D62Wb/j3Adv\ndeW7E/a26v6ZeXP1S9W3Vc3MmerPrLW+q/qG6odn5n+385fzbWutKzaMl8t4H8qW6/cXZ+a26rl2\n1u9NJzbhS9DMvKudb61fOzNPVd/fzhcoWmu9o50rab6hOl99rvrOk5nppWmL9fvW6s/OzHPV/6zu\nsFP9Iq+p/nT17zfnKVb91erGsg1uYZv1sw3u76XVO2fmqnaa5P611s/aB29tm/U7tn2wK98BAECX\nx6kUAABw7IQxAAAkjAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAFX9H2PUCTbxjzTZAAAAAElF\nTkSuQmCC\n",
"text/plain": [
"<matplotlib.figure.Figure at 0x7f0b55220a20>"
]
},
"metadata": {},
"output_type": "display_data"
},
{
"name": "stdout",
"output_type": "stream",
"text": [
"1\n"
]
},
{
"data": {
"image/png": "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\nwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMA\nQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQx\nAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBK\nGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAA\nqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAG\nAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJ\nYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAA\nlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUW4bxzNw2M0/MzNmZueeAMd8+M4/NzKMz8092\nO00AADha115qwMxcU91XfXN1rnpkZk6vtR7bN+bm6q9Wr11rfWZmfs9RTRgAAI7CNkeMb63OrrWe\nXGt9oXpPdccFY763um+t9ZmqtdYzu50mAAAcrW3C+IbqqX2Pz2227ff11dfPzL+ZmYdn5rZdTRAA\nAC6HS55K8dt4nZur11U3Vh+amT+01vq1/YNm5u7q7qqXvexlO3prAAA4vG2OGD9d3bTv8Y2bbfud\nq06vtf7XWus/V7/UXih/ibXW/WutU2utUydOnPhK5wwAADu3TRg/Ut08M6+YmeuqO6vTF4z5mfaO\nFjcz17d3asWTO5wnAAAcqUuG8Vrr2eot1UPV49UDa61HZ+atM3P7ZthD1adn5rHqg9VfWWt9+qgm\nDQAAu7bVOcZrrQerBy/Ydu+++6v6/s0NAACed1z5DgAAEsYAAFAJYwAAqIQxAABUwhgAACphDAAA\nlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYA\nAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACph\nDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCg\nEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgA\nACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQCWM\nAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABU\nwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMA\nQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQx\nAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBK\nGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUW4bxzNw2M0/MzNmZuec5xn3rzKyZObW7KQIAwNG7ZBjP\nzDXVfdUbqluqu2bmlouMe3H1fdWHdz1JAAA4atscMb61OrvWenKt9YXqPdUdFxn3t6u3V7+xw/kB\nAMBlsU0Y31A9te/xuc22/2tmXl3dtNZ63w7nBgAAl82hv3w3M19V/Uj1A1uMvXtmzszMmfPnzx/2\nrQEAYGe2CeOnq5v2Pb5xs+2LXly9svr5mflk9Zrq9MW+gLfWun+tdWqtderEiRNf+awBAGDHtgnj\nR6qbZ+YVM3NddWd1+otPrrU+u9a6fq11cq11snq4un2tdeZIZgwAAEfgkmG81nq2ekv1UPV49cBa\n69GZeevM3H7UEwQAgMvh2m0GrbUerB68YNu9B4x93eGnBQAAl5cr3wEAQMIYAAAqYQwAAJUwBgCA\nShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMA\nAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUw\nBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQ\nCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwA\nAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLG\nAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAq\nYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEA\noBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIY\nAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAl\njAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEC1ZRjPzG0z88TMnJ2Zey7y/PfP\nzGMz8/GZ+Vcz8/LdTxUAAI7OJcN4Zq6p7qveUN1S3TUzt1ww7BerU2utb6zeW/3QricKAABHaZsj\nxrdWZ9daT661vlC9p7pj/4C11gfXWp/fPHy4unG30wQAgKO1TRjfUD217/G5zbaDvLl6/8WemJm7\nZ+bMzJw5f/789rMEAIAjttMv383Md1Snqh++2PNrrfvXWqfWWqdOnDixy7cGAIBDuXaLMU9XN+17\nfONm25eYmddXf736E2ut39zN9AAA4PLY5ojxI9XNM/OKmbmuurM6vX/AzLyq+rHq9rXWM7ufJgAA\nHK1LhvFa69nqLdVD1ePVA2utR2fmrTNz+2bYD1cvqv7pzHx0Zk4f8HIAAHBF2uZUitZaD1YPXrDt\n3n33X7/jeQEAwGXlyncAAJAwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUw\nBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQ\nCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwA\nAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLG\nAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAq\nYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEA\noBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIY\nAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAl\njAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAA\nVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgD\nAEAljAEAoNoyjGfmtpl5YmbOzsw9F3n+q2fmpzfPf3hmTu56ogAAcJQuGcYzc011X/WG6pbqrpm5\n5YJhb64+s9b6A9Xfqd6+64kCAMBR2uaI8a3V2bXWk2utL1Tvqe64YMwd1bs2999bfdPMzO6mCQAA\nR2ubML6hemrf43ObbRcds9Z6tvps9bt3MUEAALgcrr2cbzYzd1d3bx5+bmae+Ape5vrqV3Y3q6vS\nVb2Gc/gTfa7q9duBq3r97H/H7qpeP/vfsbuq1++Y97+XbzNomzB+urpp3+MbN9suNubczFxbfU31\n6QtfaK11f3X/NhM7yMycWWudOsxrXO2s4eFYv8Oxfodj/Q7H+h2O9Tsc63c4l2P9tjmV4pHq5pl5\nxcxcV91Znb5gzOnquzb3v63612uttbtpAgDA0brkEeO11rMz85bqoeqa6p1rrUdn5q3VmbXW6erH\nq5+ambPVr7YXzwAA8Lyx1TnGa60Hqwcv2Hbvvvu/Uf2p3U7tQIc6FYPKGh6W9Tsc63c41u9wrN/h\nWL/DsX6Hc+TrN854AAAAl4QGAIDqeRDGM/O7ZuYDM/MfN39+7QHjfmtmPrq5XfjlwKuOy3gfzhbr\n96aZOb9vn/ue45jnlWpm3jkzz8zMJw54fmbmRzfr+/GZefXlnuOVbIv1e93MfHbf/nfvxcZdrWbm\nppn54Mw8NjOPzsz3XWSMffAAW66fffAAM/PCmfl3M/Oxzfr9rYuM8Rl8gC3X7+g+g9daV/St+qHq\nns39e6q3HzDuc8c91yvl1t6XJP9T9fuq66qPVbdcMObPV+/Y3L+z+unjnveVctty/d5U/f3jnuuV\neqv+ePXq6hMHPP/G6v3VVK+pPnzcc76Sblus3+uqnzvueV6pt+ql1as3919c/dJF/g7bBw+3fvbB\ng9dvqhdt7r+g+nD1mgvG+Aw+3Pod2WfwFX/EuC+93PS7qj95jHN5vnAZ78PZZv14DmutD7X3G2oO\nckf1k2vPw9VLZuall2d2V74t1o/nsNb61FrrFzb3/0f1eF9+xVb74AG2XD8OsNmnPrd5+ILN7cIv\ndPkMPsCW63dkng9h/HVrrU9t7v+36usOGPfCmTkzMw/PzNUezy7jfTjbrF/Vt25+BPvembnpIs9z\nsG3XmIP9sc2PGt8/M3/wuCdzpdr8iPpV7R112s8+uIXnWL+yDx5oZq6ZmY9Wz1QfWGsduP/5DP5y\nW6xfHdFn8BURxjPzL2fmExe5fclRurV3/Pyg/zW8fO1dDeVPV393Zn7/Uc+bq9q/qE6utb6x+kD/\n73/+cDn8Qnv/5v3h6u9VP3PM87kizcyLqn9W/eW11q8f93yeby6xfvbB57DW+q211h9p72rBt87M\nK497Ts8nW6zfkX0GXxFhvNZ6/VrrlRe5/Wz137/4463Nn88c8BpPb/58svr59v6He7X67VzGu3mO\ny3hfpS65fmutT6+1fnPz8B9Vf/Qyze3/F9vsoxxgrfXrX/xR49r7PfMvmJnrj3laV5SZeUF7UfeP\n11r//CJD7IPP4VLrZx/czlrr16oPVrdd8JTP4C0ctH5H+Rl8RYTxJey/3PR3VT974YCZ+dqZ+erN\n/eur11aPXbYZXnlcxvtwLrl+F5yLeHt75+CxvdPVd25+M8Brqs/uO2WKS5iZ3/vF8xFn5tb2/i33\nobqxWZsfrx5fa/3IAcPsgwfYZv3sgwebmRMz85LN/d9RfXP1Hy4Y5jP4ANus31F+Bm915btj9rbq\ngZl5c/XL1bdXzcyp6s+utb6n+obqx2bmf7f3l/Nta62rNoyXy3gfypbr95dm5vbq2fbW703HNuEr\n0My8u71vrV8/M+eqH2zvCxSttd7R3pU031idrT5ffffxzPTKtMX6fVv152bm2ep/Vnf6UP0Sr63+\nTPXvN+cpVv216mVlH9zCNutnHzzYS6t3zcw17TXJA2utn/MZvLVt1u/IPoNd+Q4AAHp+nEoBAABH\nThgDAEDCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUNX/AS7dDeGSTOD3AAAAAElFTkSuQmCC\n",
"text/plain": [
"<matplotlib.figure.Figure at 0x7f0b55239668>"
]
},
"metadata": {},
"output_type": "display_data"
},
{
"name": "stdout",
"output_type": "stream",
"text": [
"2\n"
]
},
{
"data": {
"image/png": "iVBORw0KGgoAAAANSUhEUgAAAsYAAAKvCAYAAABpkwknAAAABHNCSVQICAgIfAhkiAAAAAlwSFlz\nAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDIuMS4wLCBo\ndHRwOi8vbWF0cGxvdGxpYi5vcmcvpW3flQAAGJJJREFUeJzt3X+s73d90PHnay0MIzimvU7SFi5q\nl6ziFLypGBIlGUsKJK3J5tIa3VjYGn+gM1tM6o90iv/AlkwzRVnjyNiisIpmu46SispCYgR72QBp\na+e1MtuK9o4xJsENO9/+cb7o4XBP73ec77nn1vt4JN/c7493vt933vnc+3nez/l8z2fWWgEAwNXu\nq056AgAAcCUQxgAAkDAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAAKq69qQ++Lrrrlun\nT58+qY8HAOAq8ZGPfOSX1lqnLjXuxML49OnTnTt37qQ+HgCAq8TM/OI245xKAQAACWMAAKiEMQAA\nVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgD\nAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAACqLcJ4Zt4xM0/NzCcOeX1m5odn5vzMfHxmXrH7aQIA\nwPHa5ojxj1W3PsPrr61u2tzuqv7B0acFAACX1yXDeK31weqXn2HI7dWPrz0fql44My/a1QQBAOBy\n2MU5xtdXj+97/MTmOQAAeNa4rF++m5m7ZubczJy7cOHC5fxoAAB4RrsI4yerG/c9vmHz3JdZa927\n1jqz1jpz6tSpHXw0AADsxi7C+Gz17ZvfTvHK6rNrrU/t4H0BAOCyufZSA2bmXdWrq+tm5onq+6vn\nVK213l7dX72uOl99vvrO45osAAAcl0uG8Vrrzku8vqo/v7MZAQDACXDlOwAAaIsjxgAAu3D67vee\n9BQ4QZ98y+tPegqX5IgxAAAkjAEAoHIqBcBVxY+yr27Phh9lw0lyxBgAABLGAABQCWMAAKiEMQAA\nVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAACquvakJwBXm9N3v/ek\np8AJ+uRbXn/SUwDgEI4YAwBAwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABU\nwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMA\nQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQx\nAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUde1JT+AknL77vSc9BU7Q\nJ9/y+pOeAgBwBXLEGAAAEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYA\nAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACph\nDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCg\nEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgA\nACphDAAAlTAGAIBKGAMAQCWMAQCgEsYAAFAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBqyzCemVtn\n5tGZOT8zd1/k9RfPzAdm5udn5uMz87rdTxUAAI7PJcN4Zq6p3la9trq5unNmbj4w7K9X9621Xl7d\nUf39XU8UAACO0zZHjG+pzq+1HltrfaF6d3X7gTGr+m2b+19T/dfdTREAAI7ftVuMub56fN/jJ6o/\nfGDM36j+xcz8heq3Vq/ZyewAAOAy2dWX7+6sfmytdUP1uuonZubL3ntm7pqZczNz7sKFCzv6aAAA\nOLptwvjJ6sZ9j2/YPLffG6v7qtZa/7Z6XnXdwTdaa9271jqz1jpz6tSpr2zGAABwDLYJ4werm2bm\npTPz3Pa+XHf2wJj/Un1T1cx8Q3th7JAwAADPGpcM47XW09WbqgeqR9r77RMPzcybZ+a2zbDvq757\nZj5Wvat6w1prHdekAQBg17b58l1rrfur+w88d8+++w9Xr9rt1AAA4PJx5TsAAEgYAwBAJYwBAKAS\nxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAA\nKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwB\nAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUAljAACohDEAAFTC\nGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBA\nJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUAljAACohDEA\nAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoY\nAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUAljAACo\nhDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYA\ngEoYAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUAlj\nAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUAljAACotgzjmbl1Zh6dmfMzc/ch\nY75tZh6emYdm5h/vdpoAAHC8rr3UgJm5pnpb9c3VE9WDM3N2rfXwvjE3VX+letVa6zMz8zuPa8IA\nAHActjlifEt1fq312FrrC9W7q9sPjPnu6m1rrc9UrbWe2u00AQDgeG0TxtdXj+97/MTmuf2+vvr6\nmfk3M/Ohmbl1VxMEAIDL4ZKnUvwm3uem6tXVDdUHZ+b3r7V+Zf+gmbmruqvqxS9+8Y4+GgAAjm6b\nI8ZPVjfue3zD5rn9nqjOrrX+11rrP1e/0F4of4m11r1rrTNrrTOnTp36SucMAAA7t00YP1jdNDMv\nnZnnVndUZw+M+an2jhY3M9e1d2rFYzucJwAAHKtLhvFa6+nqTdUD1SPVfWuth2bmzTNz22bYA9Wn\nZ+bh6gPVX15rffq4Jg0AALu21TnGa637q/sPPHfPvvur+t7NDQAAnnVc+Q4AABLGAABQCWMAAKiE\nMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCA\nShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMA\nAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUw\nBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQ\nCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwA\nAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLG\nAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAq\nYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEA\noBLGAABQCWMAAKiEMQAAVMIYAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVMIY\nAAAqYQwAAJUwBgCAShgDAEAljAEAoBLGAABQCWMAAKiEMQAAVFuG8czcOjOPzsz5mbn7GcZ9y8ys\nmTmzuykCAMDxu2QYz8w11duq11Y3V3fOzM0XGfeC6nuqD+96kgAAcNy2OWJ8S3V+rfXYWusL1bur\n2y8y7m9Vb61+bYfzAwCAy2KbML6+enzf4yc2z/1fM/OK6sa11nt3ODcAALhsjvzlu5n5quqHqu/b\nYuxdM3NuZs5duHDhqB8NAAA7s00YP1nduO/xDZvnvugF1cuqn52ZT1avrM5e7At4a61711pn1lpn\nTp069ZXPGgAAdmybMH6wumlmXjozz63uqM5+8cW11mfXWtettU6vtU5XH6puW2udO5YZAwDAMbhk\nGK+1nq7eVD1QPVLdt9Z6aGbePDO3HfcEAQDgcrh2m0Frrfur+w88d88hY1999GkBAMDl5cp3AACQ\nMAYAgEoYAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAA\nUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEM\nAACVMAYAgEoYAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKAS\nxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAA\nKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwB\nAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUAljAACohDEAAFTC\nGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBA\nJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUAljAACohDEA\nAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoY\nAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUG0ZxjNz\n68w8OjPnZ+bui7z+vTPz8Mx8fGb+1cy8ZPdTBQCA43PJMJ6Za6q3Va+tbq7unJmbDwz7+erMWusb\nq/dUP7DriQIAwHHa5ojxLdX5tdZja60vVO+ubt8/YK31gbXW5zcPP1TdsNtpAgDA8domjK+vHt/3\n+InNc4d5Y/W+i70wM3fNzLmZOXfhwoXtZwkAAMdsp1++m5k/VZ2pfvBir6+17l1rnVlrnTl16tQu\nPxoAAI7k2i3GPFnduO/xDZvnvsTMvKb6a9UfW2v9+m6mBwAAl8c2R4wfrG6amZfOzHOrO6qz+wfM\nzMurH6luW2s9tftpAgDA8bpkGK+1nq7eVD1QPVLdt9Z6aGbePDO3bYb9YPX86p/MzEdn5uwhbwcA\nAFekbU6laK11f3X/gefu2Xf/NTueFwAAXFaufAcAAAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoY\nAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUAljAACo\nhDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYA\ngEoYAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUAlj\nAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACV\nMAYAgEoYAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAA\nUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEM\nAACVMAYAgEoYAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKAS\nxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAA\nKmEMAACVMAYAgEoYAwBAJYwBAKASxgAAUAljAACohDEAAFTCGAAAKmEMAACVMAYAgEoYAwBAJYwB\nAKASxgAAUAljAACohDEAAFTCGAAAqi3DeGZunZlHZ+b8zNx9kde/emZ+cvP6h2fm9K4nCgAAx+mS\nYTwz11Rvq15b3VzdOTM3Hxj2xuoza63fW/3t6q27nigAABynbY4Y31KdX2s9ttb6QvXu6vYDY26v\n3rm5/57qm2ZmdjdNAAA4XtuE8fXV4/seP7F57qJj1lpPV5+tfscuJggAAJfDtZfzw2bmruquzcPP\nzcyjX8HbXFf90u5mdVW6qtdwjn6iz1W9fjtwVa+f7e/EXdXrZ/s7cVf1+p3w9veSbQZtE8ZPVjfu\ne3zD5rmLjXliZq6tvqb69ME3WmvdW927zcQOMzPn1lpnjvIeVztreDTW72is39FYv6Oxfkdj/Y7G\n+h3N5Vi/bU6leLC6aWZeOjPPre6ozh4Yc7b6js39b63+9Vpr7W6aAABwvC55xHit9fTMvKl6oLqm\nesda66GZeXN1bq11tvrR6idm5nz1y+3FMwAAPGtsdY7xWuv+6v4Dz92z7/6vVX9it1M71JFOxaCy\nhkdl/Y7G+h2N9Tsa63c01u9orN/RHPv6jTMeAADAJaEBAKB6FoTxzPz2mXn/zPzHzZ9fe8i435iZ\nj25uB78ceNVxGe+j2WL93jAzF/Ztc991EvO8Us3MO2bmqZn5xCGvz8z88GZ9Pz4zr7jcc7ySbbF+\nr56Zz+7b/u652Lir1czcODMfmJmHZ+ahmfmei4yxDR5iy/WzDR5iZp43M/9uZj62Wb+/eZEx9sGH\n2HL9jm8fvNa6om/VD1R3b+7fXb31kHGfO+m5Xim39r4k+Z+q3109t/pYdfOBMX+uevvm/h3VT570\nvK+U25br94bq7530XK/UW/VHq1dUnzjk9ddV76umemX14ZOe85V022L9Xl39zEnP80q9VS+qXrG5\n/4LqFy7yd9g2eLT1sw0evn5TPX9z/znVh6tXHhhjH3y09Tu2ffAVf8S4L73c9DurP36Cc3m2cBnv\no9lm/XgGa60Ptvcbag5ze/Xja8+HqhfOzIsuz+yufFusH89grfWptdbPbe7/j+qRvvyKrbbBQ2y5\nfhxis019bvPwOZvbwS902QcfYsv1OzbPhjD+urXWpzb3/1v1dYeMe97MnJuZD83M1R7PLuN9NNus\nX9W3bH4E+56ZufEir3O4bdeYw/2RzY8a3zczv++kJ3Ol2vyI+uXtHXXazza4hWdYv7INHmpmrpmZ\nj1ZPVe9fax26/dkHf7kt1q+OaR98RYTxzPzLmfnERW5fcpRu7R0/P+x/DS9Ze1dD+ZPV35mZ33Pc\n8+aq9s+r02utb6ze3//7nz9cDj/X3r95f6D6u9VPnfB8rkgz8/zqn1Z/aa31qyc9n2ebS6yfbfAZ\nrLV+Y631B9u7WvAtM/Oyk57Ts8kW63ds++ArIozXWq9Za73sIrefrv77F3+8tfnzqUPe48nNn49V\nP9ve/3CvVr+Zy3g3z3AZ76vUJddvrfXptdavbx7+w+oPXaa5/f9im22UQ6y1fvWLP2pce79n/jkz\nc90JT+uKMjPPaS/q/tFa659dZIht8Blcav1sg9tZa/1K9YHq1gMv2Qdv4bD1O8598BURxpew/3LT\n31H99MEBM/O1M/PVm/vXVa+qHr5sM7zyuIz30Vxy/Q6ci3hbe+fgsb2z1bdvfjPAK6vP7jtlikuY\nmd/1xfMRZ+aW9v4tt1Pd2KzNj1aPrLV+6JBhtsFDbLN+tsHDzcypmXnh5v5vqb65+g8HhtkHH2Kb\n9TvOffBWV747YW+p7puZN1a/WH1b1cycqf7MWuu7qm+ofmRm/nd7fznfsta6asN4uYz3kWy5fn9x\nZm6rnm5v/d5wYhO+As3Mu9r71vp1M/NE9f3tfYGitdbb27uS5uuq89Xnq+88mZlembZYv2+t/uzM\nPF39z+oOO9Uv8arqT1f/fnOeYtVfrV5ctsEtbLN+tsHDvah658xc016T3LfW+hn74K1ts37Htg92\n5TsAAOjZcSoFAAAcO2EMAAAJYwAAqIQxAABUwhgAACphDAAAlTAGAIBKGAMAQFX/B8wGDRKtiDcQ\nAAAAAElFTkSuQmCC\n",
"text/plain": [
"<matplotlib.figure.Figure at 0x7f0b55308198>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"def mu(img):\n",
" result = []\n",
" for i in range(img.shape[2]):\n",
" result.append(np.average(img[:, :, i]))\n",
" return np.array(result) # [mu(r), mu(g), mu(b)]\n",
"\n",
"def omega(img, img_mu):\n",
" return np.sqrt(np.average(np.square(img-img_mu))*img.shape[2])\n",
"\n",
"def omega2(img_x, img_x_mu, img_y, img_y_mu):\n",
" pixel = img_x.shape[0]*img_x.shape[1]\n",
" x = (img_x-img_x_mu).reshape(pixel, img_x.shape[2])\n",
" y = (img_y-img_y_mu).reshape(pixel, img_x.shape[2])\n",
" sum = 0\n",
" for xi, yi in zip(x, y):\n",
" sum += xi.dot(yi.T)\n",
" return sum/pixel\n",
" \n",
" #return mu((img_x-img_x_mu).T*(img_y-img_y_mu))**0.5\n",
"\n",
"def ssim(x, y):\n",
" \"\"\"The SSIM similarity measure. Use the parameters from the paper \n",
" as on the second to last slide from the lecture\"\"\"\n",
" #print(\"x\", omega(x, mu(x)))\n",
" #print(\"y\", omega(y, mu(y)))\n",
" #print(\"mu\", mu(x))\n",
" #print(\"xy\", omega2(x, mu(x), y, mu(y)))\n",
" mu_x = mu(x)\n",
" mu_y = mu(y)\n",
" o_x = omega(x, mu_x)\n",
" o_y = omega(y, mu_y)\n",
" o_xy = omega2(x, mu_x, y, mu_y)\n",
" c1 = 0.2\n",
" c2 = 0.6\n",
" return (2*mu_x.dot(mu_y.T)+c1) * (2*o_xy+c2) / (mu_x.dot(mu_x.T)+mu_y.dot(mu_y.T)+c1) / (o_x**2+o_y**2+c2)\n",
"\n",
"for i, img in enumerate(images_for_jpeg):\n",
" print(i)\n",
" compressed_images = [images1[i], images10[i], images50[i], images80[i]]\n",
" plt.bar(range(len(compressed_images)),\n",
" [ssim(img, comp) for comp in compressed_images])\n",
" plt.show()"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": [
""
]
}
],
"metadata": {
"kernelspec": {
"display_name": "Python 3",
"language": "python",
"name": "python3"
},
"language_info": {
"codemirror_mode": {
"name": "ipython",
"version": 3.0
},
"file_extension": ".py",
"mimetype": "text/x-python",
"name": "python",
"nbconvert_exporter": "python",
"pygments_lexer": "ipython3",
"version": "3.5.2"
}
},
"nbformat": 4,
"nbformat_minor": 0
}