{
 "cells": [
  {
   "cell_type": "markdown",
   "source": [
    "# Learning to Invert Heat Conduction with Scale-invariant Updates\n",
    "\n",
    "This example can be run with PyTorch and TensorFlow.\n",
    "Adjust the import below to select the library."
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "outputs": [],
   "source": [
    "from phi.torch.flow import *\n",
    "# from phi.tf.flow import *"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "Generate batched 2D source `x` (non-observable) from 10 random rectangles"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "outputs": [],
   "source": [
    "def generate_heat_example(*shape, bounds: Box = None):\n",
    "    shape = math.merge_shapes(*shape)\n",
    "    heat_t0 = CenteredGrid(0, extrapolation.PERIODIC, bounds, resolution=shape.spatial)\n",
    "    bounds = heat_t0.bounds\n",
    "    component_counts = math.to_int32(4 + 7 * math.random_uniform(shape.batch))\n",
    "    positions = (math.random_uniform(shape.batch, batch(components=10), channel(vector=shape.spatial.names)) - 0.5) * bounds.size * 0.8 + bounds.size * 0.5\n",
    "    for i in range(10):\n",
    "        position = positions.components[i]\n",
    "        half_size = math.random_uniform(shape.batch, channel(vector=shape.spatial.names)) * 10\n",
    "        strength = math.random_uniform(shape.batch) * math.to_float(i < component_counts)\n",
    "        position = math.clip(position, bounds.lower + half_size, bounds.upper - half_size)\n",
    "        component_box = Cuboid(position, half_size)\n",
    "        component_mask = SoftGeometryMask(component_box)\n",
    "        component_mask = component_mask.at(heat_t0)\n",
    "        heat_t0 += component_mask * strength\n",
    "    return heat_t0"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "Look at two examples, generate data on-the-fly later during training."
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 864x360 with 3 Axes>",
      "image/png": "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\n"
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "text/plain": "<Figure size 432x288 with 0 Axes>"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "vis.plot(generate_heat_example(batch(view_examples=2), spatial(x=64, y=64)))"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "Define scale-invariant updates.\n",
    "Take probabilistic viewpoint to avoid numerical explosions (see `probability_signal` in `apply_damping()`)"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "outputs": [],
   "source": [
    "def apply_damping(kernel, inv_kernel, amp, f_uncertainty, log_kernel):\n",
    "    signal_prior = 0.5\n",
    "    expected_amp = 1. * kernel.shape.get_size('x') * inv_kernel  # This can be measured\n",
    "    signal_likelihood = math.exp(-0.5 * (abs(amp) / expected_amp) ** 2) * signal_prior  # this can be NaN\n",
    "    signal_likelihood = math.where(math.isfinite(signal_likelihood), signal_likelihood, math.zeros_like(signal_likelihood))\n",
    "    noise_likelihood = math.exp(-0.5 * (abs(amp) / f_uncertainty) ** 2) * (1 - signal_prior)\n",
    "    probability_signal = math.divide_no_nan(signal_likelihood, (signal_likelihood + noise_likelihood))\n",
    "    action = math.where((0.5 >= probability_signal) | (probability_signal >= 0.68), 2 * (probability_signal - 0.5), 0.)  # 1 sigma required to take action\n",
    "    prob_kernel = math.exp(log_kernel * action)\n",
    "    return prob_kernel, probability_signal\n",
    "\n",
    "\n",
    "def inv_diffuse(grid: Grid, amount: float, uncertainty: Grid):\n",
    "    f_uncertainty: math.Tensor = math.sqrt(math.sum(uncertainty.values ** 2, dim='x,y'))  # all frequencies have the same uncertainty, 1/N in iFFT\n",
    "    k_squared: math.Tensor = math.sum(math.fftfreq(grid.shape, grid.dx) ** 2, 'vector')\n",
    "    fft_laplace: math.Tensor = -(2 * np.pi) ** 2 * k_squared\n",
    "    # --- Compute sharpening kernel with damping ---\n",
    "    log_kernel = fft_laplace * -amount\n",
    "    log_kernel_clamped = math.minimum(log_kernel, math.to_float(math.floor(math.log(math.wrap(np.finfo(np.float32).max)))))  # avoid overflow\n",
    "    raw_kernel = math.exp(log_kernel_clamped)  # inverse diffusion FFT kernel, all values >= 1\n",
    "    inv_kernel = math.exp(-log_kernel)\n",
    "    amp = math.fft(grid.values)\n",
    "    kernel, sig_prob = apply_damping(raw_kernel, inv_kernel, amp, f_uncertainty, log_kernel)\n",
    "    # --- Apply and compute uncertainty ---\n",
    "    data = math.real(math.ifft(amp * math.to_complex(kernel)))\n",
    "    uncertainty = math.sqrt(math.sum(((f_uncertainty * kernel) ** 2))) / grid.shape.get_size('x')  # 1/N normalization in iFFT\n",
    "    uncertainty = grid * 0 + uncertainty\n",
    "    return grid.with_values(data), uncertainty, abs(amp), raw_kernel, kernel, sig_prob"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "Set up neural network + Adam\n",
    "We will use 64 bit precision for physics but 32 for network.\n",
    "Batch size 128."
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "outputs": [],
   "source": [
    "math.set_global_precision(64)\n",
    "BATCH = batch(batch=128)\n",
    "\n",
    "math.seed(0)\n",
    "net = u_net(1, 1)\n",
    "optimizer = adam(net, 0.001)"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "Define loss function.\n",
    "Gradients will always computed as d(loss_function)/dθ (network weights).\n",
    "For SIP\n",
    "* Invert the physics\n",
    "* Define proxy loss L2(prediction - correction) where correction is taken as constant (based on `x = field.stop_gradient(prediction)`)"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "outputs": [],
   "source": [
    "# @math.jit_compile\n",
    "def loss_function(x_gt: CenteredGrid, sip: bool):\n",
    "    y_target = diffuse.fourier(x_gt, 8., 1)\n",
    "    with math.precision(32):\n",
    "        prediction = field.native_call(net, field.to_float(y_target)).vector[0]\n",
    "        prediction += field.mean(x_gt) - field.mean(prediction)\n",
    "    prediction = field.to_float(prediction)  # is this call necessary?\n",
    "    x = field.stop_gradient(prediction)\n",
    "    if sip:\n",
    "        y = diffuse.fourier(x, 8., 1)\n",
    "        dx, _, amp, raw_kernel, kernel, sig_prob = inv_diffuse(y_target - y, 8., uncertainty=abs(y_target - y) * 1e-6)\n",
    "        correction = x + dx\n",
    "        loss = field.l2_loss(prediction - correction)\n",
    "        y_l2 = field.l2_loss(y - y_target)\n",
    "    else:\n",
    "        y = diffuse.fourier(prediction, 8., 1)\n",
    "        y_l2 = loss = field.l2_loss(y - y_target)\n",
    "    return loss, x, y, field.l2_loss(x_gt - x), y_l2"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "Training loop, generate data on-the-fly.\n",
    "(Switch between SIP and GD with the use_SIP checkbox or make two loops)"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m10.493 ± 6.369\u001B[0m \u001B[37m(2e+00...3e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m10.187 ± 6.252\u001B[0m \u001B[37m(2e+00...3e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m11.047 ± 6.128\u001B[0m \u001B[37m(2e+00...3e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m10.072 ± 6.347\u001B[0m \u001B[37m(1e+00...4e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m8.682 ± 5.031\u001B[0m \u001B[37m(1e+00...2e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m8.241 ± 4.486\u001B[0m \u001B[37m(1e+00...2e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m8.466 ± 4.927\u001B[0m \u001B[37m(1e+00...2e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m9.183 ± 6.186\u001B[0m \u001B[37m(1e+00...5e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m8.269 ± 5.729\u001B[0m \u001B[37m(1e+00...4e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m7.814 ± 4.365\u001B[0m \u001B[37m(8e-01...2e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m8.390 ± 5.162\u001B[0m \u001B[37m(1e+00...2e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m7.937 ± 4.595\u001B[0m \u001B[37m(2e+00...2e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m7.315 ± 4.118\u001B[0m \u001B[37m(1e+00...2e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m7.617 ± 4.776\u001B[0m \u001B[37m(1e+00...3e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m7.730 ± 4.983\u001B[0m \u001B[37m(7e-01...2e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m7.126 ± 3.905\u001B[0m \u001B[37m(5e-01...2e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m7.256 ± 6.348\u001B[0m \u001B[37m(8e-01...6e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m7.313 ± 3.860\u001B[0m \u001B[37m(8e-01...2e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m8.344 ± 5.242\u001B[0m \u001B[37m(5e-01...3e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m6.463 ± 4.300\u001B[0m \u001B[37m(6e-01...2e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m7.400 ± 4.349\u001B[0m \u001B[37m(9e-01...3e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m7.453 ± 4.910\u001B[0m \u001B[37m(5e-01...3e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m7.298 ± 5.256\u001B[0m \u001B[37m(1e+00...4e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m7.223 ± 4.199\u001B[0m \u001B[37m(7e-01...2e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m6.610 ± 4.331\u001B[0m \u001B[37m(3e-01...2e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m6.666 ± 3.827\u001B[0m \u001B[37m(3e-01...2e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m6.979 ± 4.320\u001B[0m \u001B[37m(1e+00...2e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m7.171 ± 4.482\u001B[0m \u001B[37m(3e-01...2e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m6.919 ± 3.900\u001B[0m \u001B[37m(1e+00...2e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m6.410 ± 4.150\u001B[0m \u001B[37m(6e-01...2e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m6.273 ± 3.477\u001B[0m \u001B[37m(5e-01...2e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m7.019 ± 4.924\u001B[0m \u001B[37m(9e-01...3e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m7.876 ± 4.400\u001B[0m \u001B[37m(2e+00...2e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m6.431 ± 4.248\u001B[0m \u001B[37m(5e-01...2e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m6.557 ± 3.771\u001B[0m \u001B[37m(8e-01...2e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m5.735 ± 3.723\u001B[0m \u001B[37m(5e-01...2e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m7.207 ± 4.388\u001B[0m \u001B[37m(6e-01...2e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m6.715 ± 3.744\u001B[0m \u001B[37m(1e+00...2e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m6.823 ± 4.558\u001B[0m \u001B[37m(8e-01...2e+01)\u001B[0m\n",
      "\u001B[92m(batchᵇ=128)\u001B[0m \u001B[94m5.899 ± 3.558\u001B[0m \u001B[37m(5e-01...2e+01)\u001B[0m\n"
     ]
    }
   ],
   "source": [
    "for training_step in range(500):\n",
    "    data = generate_heat_example(spatial(x=64, y=64), BATCH)\n",
    "    loss_value, x, y, x_l2, y_l2 = update_weights(net, optimizer, loss_function, data, sip=True)\n",
    "    if training_step % 10 == 0: print(x_l2)"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 864x360 with 6 Axes>",
      "image/png": "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\n"
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "text/plain": "<Figure size 432x288 with 0 Axes>"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "test_data = generate_heat_example(batch(test_examples=2), spatial(x=64, y=64))\n",
    "_, test_pred, test_y, *_ = loss_function(test_data, True)\n",
    "vis.plot({\"Ground Truth\": test_data, \"Observation\": test_y, \"NN Prediction\": test_pred}, show_color_bar=False, row_dims='test_examples')"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 2
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython2",
   "version": "2.7.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 0
}