{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "collapsed": true,
    "pycharm": {
     "name": "#%% md\n"
    }
   },
   "source": [
    "In this notebook, we aim at quantifying the non-linearity of the\n",
    "AC Power Flow datasets."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "outputs": [],
   "source": [
    "import os\n",
    "os.chdir('..')\n",
    "\n",
    "import numpy as np"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "outputs": [],
   "source": [
    "# Select dataset\n",
    "data_dir = 'datasets/acpf_14'\n",
    "#data_dir = 'datasets/linear_systems'\n",
    "\n",
    "# Load the train set\n",
    "mode = 'train'\n",
    "\n",
    "# Import numpy data\n",
    "A_train = np.load(os.path.join(data_dir, 'A_'+mode+'.npy'))\n",
    "B_train = np.load(os.path.join(data_dir, 'B_'+mode+'.npy'))\n",
    "U_train = np.load(os.path.join(data_dir, 'U_'+mode+'.npy'))"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "outputs": [],
   "source": [
    "n_samples = np.shape(A_train)[0]\n",
    "\n",
    "A_train_flat = np.reshape(A_train, [n_samples, -1])\n",
    "B_train_flat = np.reshape(B_train, [n_samples, -1])\n",
    "U_train_flat = np.reshape(U_train, [n_samples, -1])\n",
    "\n",
    "X = np.concatenate((A_train_flat, B_train_flat), axis=1)\n",
    "Y = U_train_flat"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "outputs": [
    {
     "data": {
      "text/plain": "LinearRegression()"
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from sklearn import linear_model\n",
    "regr = linear_model.LinearRegression()\n",
    "regr.fit(X, Y)"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "outputs": [],
   "source": [
    "# Load the train set\n",
    "mode = 'test'\n",
    "\n",
    "# Import numpy data\n",
    "A_test = np.load(os.path.join(data_dir, 'A_'+mode+'.npy'))\n",
    "B_test = np.load(os.path.join(data_dir, 'B_'+mode+'.npy'))\n",
    "U_test = np.load(os.path.join(data_dir, 'U_'+mode+'.npy'))\n",
    "\n",
    "n_samples = np.shape(A_test)[0]\n",
    "\n",
    "A_test_flat = np.reshape(A_test, [n_samples, -1])\n",
    "B_test_flat = np.reshape(B_test, [n_samples, -1])\n",
    "U_test_flat = np.reshape(U_test, [n_samples, -1])\n",
    "\n",
    "X_test = np.concatenate((A_test_flat, B_test_flat), axis=1)\n",
    "Y_test = U_test_flat\n"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[1.         0.99940864]\n",
      " [0.99940864 1.        ]]\n",
      "[[1.         0.99599181]\n",
      " [0.99599181 1.        ]]\n"
     ]
    }
   ],
   "source": [
    "pred_test = regr.predict(X_test)\n",
    "pred_test = np.reshape(pred_test, U_test.shape)\n",
    "pred_Vm_test = np.reshape(pred_test[:,:,0], -1)\n",
    "pred_Va_test = np.reshape(pred_test[:,:,1], -1)\n",
    "\n",
    "gt_Vm_test = np.reshape(U_test[:,:,0], -1)\n",
    "gt_Va_test = np.reshape(U_test[:,:,1], -1)\n",
    "\n",
    "print(np.corrcoef(pred_Vm_test, gt_Vm_test))\n",
    "print(np.corrcoef(pred_Va_test, gt_Va_test))"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 432x288 with 1 Axes>",
      "image/png": "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\n"
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": "<Figure size 432x288 with 1 Axes>",
      "image/png": "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\n"
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "plt.scatter(pred_Vm_test, gt_Vm_test)\n",
    "plt.ylim([0.9, 1.1])\n",
    "plt.xlim([0.9, 1.1])\n",
    "plt.show()\n",
    "\n",
    "plt.scatter(pred_Va_test, gt_Va_test)\n",
    "plt.xlim([-1, 1])\n",
    "plt.show()"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "outputs": [],
   "source": [],
   "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
}