{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from __future__ import print_function\n",
    "\n",
    "import os\n",
    "os.environ['CUDA_VISIBLE_DEVICES'] = '2'\n",
    "\n",
    "import keras\n",
    "from keras.layers import Dense, Conv2D, BatchNormalization, Activation\n",
    "from keras.layers import AveragePooling2D, Input, Flatten, Lambda\n",
    "from keras.optimizers import Adam, SGD\n",
    "from keras.callbacks import ModelCheckpoint, LearningRateScheduler, ReduceLROnPlateau\n",
    "from keras.callbacks import ReduceLROnPlateau\n",
    "from keras.preprocessing.image import ImageDataGenerator\n",
    "from keras.regularizers import l2\n",
    "from keras import backend as K\n",
    "from keras.models import Model\n",
    "from keras.datasets import mnist, cifar10, cifar100\n",
    "import tensorflow as tf\n",
    "import numpy as np\n",
    "import os\n",
    "from scipy.io import loadmat\n",
    "import math\n",
    "from utils.model import resnet_v1, resnet_v2\n",
    "import cleverhans.attacks as attacks\n",
    "from cleverhans.utils_tf import model_eval\n",
    "from utils.keras_wraper_ensemble import KerasModelWrapper\n",
    "from utils.utils_model_eval import model_eval_targetacc, model_eval_for_SPSA, model_eval_for_SPSA_targetacc\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "if True:\n",
    "    (x_train, y_train), (x_test, y_test) = cifar10.load_data()\n",
    "    epochs = 200\n",
    "    num_class = 10\n",
    "    epochs_inter = [100,150]\n",
    "    x_place = tf.placeholder(tf.float32, shape=(None, 32, 32, 3))\n",
    "\n",
    "\n",
    "# These parameters are usually fixed                                                                                                                                                                                   \n",
    "subtract_pixel_mean = True\n",
    "version = 2 # Model version                                                                                                                                                                                \n",
    "n = 5 # n=5 for resnet-32 v1                                                                                                                                                                                           \n",
    "\n",
    "# Computed depth from supplied model parameter n                                                                                                                                                                       \n",
    "if version == 1:\n",
    "    depth = n * 6 + 2\n",
    "    feature_dim = 64\n",
    "elif version == 2:\n",
    "    depth = n * 9 + 2\n",
    "    feature_dim = 256"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "                                                                                             \n",
    "kernel_dict = loadmat('kernel_paras/meanvar1_featuredim'+str(feature_dim)+'_class'+str(num_class)+'.mat')\n",
    "mean_logits = kernel_dict['mean_logits'] #num_class X num_dense                                                                                                                                                        \n",
    "mean_logits = 10 * tf.constant(mean_logits,dtype=tf.float32)\n",
    "\n",
    "\n",
    "#MMLDA prediction function                                                                                                                                                                                             \n",
    "def MMLDA_layer(x, means=mean_logits, num_class=num_class, use_ball=True):\n",
    "    #x_shape = batch_size X num_dense                                                                                                                                                                                  \n",
    "    x_expand = tf.tile(tf.expand_dims(x,axis=1),[1,num_class,1]) #batch_size X num_class X num_dense                                                                                                                   \n",
    "    mean_expand = tf.expand_dims(means,axis=0) #1 X num_class X num_dense                                                                                                                                              \n",
    "    logits = -tf.reduce_sum(tf.square(x_expand - mean_expand), axis=-1) #batch_size X num_class                                                                                                                        \n",
    "    if use_ball==True:\n",
    "        if True:\n",
    "            return logits\n",
    "        else:\n",
    "            return tf.nn.softmax(logits, axis=-1)\n",
    "    else:\n",
    "        return tf.nn.softmax(logits, axis=-1)\n",
    "\n",
    "\n",
    "# Load the data.                                                                                                                                                                                                       \n",
    "y_test_target = np.zeros_like(y_test)\n",
    "for i in range(y_test.shape[0]):\n",
    "    l = np.random.randint(num_class)\n",
    "    while l == y_test[i][0]:\n",
    "        l = np.random.randint(num_class)\n",
    "    y_test_target[i][0] = l\n",
    "print('Finish crafting y_test_target!!!!!!!!!!!')\n",
    "\n",
    "# Input image dimensions.                                                                                                                                                                                              \n",
    "input_shape = x_train.shape[1:]\n",
    "\n",
    "# Normalize data.                                                                                                                                                                                                      \n",
    "x_train = x_train.astype('float32') / 255\n",
    "x_test = x_test.astype('float32') / 255\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "clip_min = 0.0\n",
    "clip_max = 1.0\n",
    "# If subtract pixel mean is enabled                                                                                                                                                                                    \n",
    "if subtract_pixel_mean:\n",
    "    x_train_mean = np.mean(x_train, axis=0)\n",
    "    x_train -= x_train_mean\n",
    "    x_test -= x_train_mean\n",
    "    clip_min -= x_train_mean\n",
    "    clip_max -= x_train_mean\n",
    "print (np.min(x_train_mean))\n",
    "print (np.max(x_train_mean))\n",
    "\n",
    "# Convert class vectors to binary class matrices.                                                                                                                                                                      \n",
    "y_train = keras.utils.to_categorical(y_train, num_class)\n",
    "y_test_index = np.squeeze(np.copy(y_test).astype('int32'))\n",
    "y_test = keras.utils.to_categorical(y_test, num_class)\n",
    "y_test_target_index = np.squeeze(np.copy(y_test_target).astype('int32'))\n",
    "y_test_target = keras.utils.to_categorical(y_test_target, num_class)\n",
    "\n",
    "\n",
    "# Define input TF placeholder                                                                                                                                                                                          \n",
    "y_place = tf.placeholder(tf.float32, shape=(None, num_class))\n",
    "y_target = tf.placeholder(tf.float32, shape=(None, num_class))\n",
    "sess = tf.Session()\n",
    "keras.backend.set_session(sess)\n",
    "\n",
    "\n",
    "model_input = Input(shape=input_shape)\n",
    "\n",
    "#dim of logtis is batchsize x dim_means                                                                                                                                                                                \n",
    "if version == 2:\n",
    "    original_model,_,_,_,final_features = resnet_v2(input=model_input, depth=depth, num_classes=num_class, \\\n",
    "                                                    use_BN=True, use_dense=True, use_leaky=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "if True:\n",
    "    \n",
    "    print('Using MMLDA')\n",
    "    new_layer = Lambda(MMLDA_layer)\n",
    "    predictions = new_layer(final_features)\n",
    "    model = Model(input=model_input, output=predictions)\n",
    "    filepath_dir = \"them/model.195.h5\"\n",
    "\n",
    "    \n",
    "model.load_weights(filepath_dir)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "if True:\n",
    "    \n",
    "    xs = tf.placeholder(tf.float32, [None, None, None, None])\n",
    "    ys = tf.placeholder(tf.float32, [None, None])\n",
    "    outs = model(xs)\n",
    "    loss = tf.nn.softmax_cross_entropy_with_logits_v2(logits=outs/100,\n",
    "                                                      labels=ys)\n",
    "    #real = tf.reduce_sum((ys)*outs,1)                                                                                                                                                                                 \n",
    "    #other = tf.reduce_max((1-ys)*outs - (ys*10000),1)                                                                                                                                                                 \n",
    "    #loss = real-other                                                                                                                                                                                                 \n",
    "\n",
    "    grads = tf.gradients(loss, [xs])[0]\n",
    "\n",
    "    keep_adv = np.copy(x_test[:1000])\n",
    "    orig_xs = np.copy(x_test)\n",
    "    \n",
    "    \n",
    "    keep_adv = np.load(\"qq3.npy\")\n",
    "\n",
    "    correct = model.predict(x_test[0:1000]).argmax(1)==y_test[0:1000].argmax(1)\n",
    "    print(np.mean(correct))\n",
    "\n",
    "    correct = model.predict(keep_adv[0:1000]).argmax(1)==y_test[0:1000].argmax(1)\n",
    "    print(np.mean(correct))\n",
    "\n",
    "\n",
    "\n",
    "    print(np.max(np.abs(keep_adv-orig_xs[:1000])))\n",
    "    print(np.max(np.abs(x_test[:1000]-orig_xs[:1000])))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "#x_expand = tf.tile(tf.expand_dims(outs_nop,axis=1),[1,num_class,1]) #batch_size X num_class X num_dense                                                                                                                   \n",
    "#mean_expand = tf.expand_dims(means,axis=0) #1 X num_class X num_dense                                                                                                                                              \n",
    "#\n",
    "#logits = -tf.reduce_sum(tf.square(x_expand - mean_expand), axis=-1) #batch_size X num_class                                                                                                                        \n",
    "#loss2 = outs_np(xs) - \n",
    "\n",
    "\n",
    "orig = np.copy(x_test[:1000][correct])\n",
    "labs = y_test[:1000][correct]\n",
    "\n",
    "\n",
    "axis = tf.placeholder(tf.int32, [])\n",
    "\n",
    "grads2 = tf.gradients(tf.reduce_sum(outs[:,axis]), [xs])[0]\n",
    "print(\"grads2\", grads2)\n",
    "\n",
    "low = np.min(orig)  \n",
    "high = np.max(orig)  \n",
    "\n",
    "\n",
    "N = len(orig)\n",
    "\n",
    "adv = np.copy(orig[:N])\n",
    "\n",
    "\n",
    "ema = np.copy(orig[:N])\n",
    "\n",
    "print(\"True\", np.argmax(labs[:N],axis=1))\n",
    "lab = np.argmax(sess.run(outs, {xs: ema}),axis=1)\n",
    "print(\"Acc:\", np.mean(lab == np.argmax(labs[:N],axis=1)))\n",
    "\n",
    "final_out = np.copy(orig[:N])\n",
    "\n",
    "\n",
    "for ax in list(range(10))[::-1]:\n",
    "    print(\"NEW AXIS\", ax)\n",
    "    adv += np.random.normal(size=adv.shape)\n",
    "    for _ in range(100):\n",
    "        y, g = sess.run((outs, grads2), {xs: adv, axis: ax})\n",
    "        adv += 0.01 * np.sign(g)\n",
    "        adv = np.clip(adv, low, high)                                                                                                                                          \n",
    "        adv = np.clip(adv, orig[:N]-.031, orig[:N]+.031)   \n",
    "        print(np.argmax(y,axis=1))\n",
    "        ema = 0.95 * ema + 0.05 * adv\n",
    "    \n",
    "        if _%1 == 0:\n",
    "            lab = np.argmax(sess.run(outs, {xs: adv}),axis=1)\n",
    "            print(\"Acc:\", np.mean(lab == np.argmax(labs[:N],axis=1)))\n",
    "            print(lab)\n",
    "            for i in range(N):\n",
    "                if lab[i] != np.argmax(labs[i]):\n",
    "                    final_out[i] = np.copy(adv[i])\n",
    "        \n",
    "        if _%10 == 0:\n",
    "            lab = np.argmax(sess.run(outs, {xs: ema}),axis=1)\n",
    "            print(\"Acc:\", np.mean(lab == np.argmax(labs[:N],axis=1)))\n",
    "            print(lab)\n",
    "            for i in range(N):\n",
    "                if lab[i] != np.argmax(labs[i]):\n",
    "                    final_out[i] = np.copy(ema[i])\n",
    "            lab = np.argmax(sess.run(outs, {xs: final_out}),axis=1)\n",
    "            print(\"FAcc:\", np.mean(lab == np.argmax(labs[:N],axis=1)))\n",
    "            print(lab)\n",
    "            print()\n",
    "            "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "import importlib\n",
    "import matplotlib\n",
    "importlib.reload(matplotlib)\n",
    "\n",
    "%matplotlib inline\n",
    "from mpl_toolkits.mplot3d import Axes3D\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "not_yet_adv = correct\n",
    "orig = np.copy(x_test[:1000])\n",
    "xin = np.copy(orig)\n",
    "labs = y_test[:1000]\n",
    "\n",
    "alpha = np.sign(np.random.normal(size=(1,32,32,3)))*0.031\n",
    "beta = np.sign(np.random.normal(size=(1,32,32,3)))*0.31\n",
    "#beta = np.sign(sess.run(grads, {xs: orig[:1], ys: labs[:1]}))*0.31\n",
    "\n",
    "\n",
    "#loss = tf.nn.softmax_cross_entropy_with_logits_v2(logits=outs,\n",
    "#                                                      labels=ys)\n",
    "loss = tf.reduce_max(outs,axis=1)\n",
    "\n",
    "#best_adv_so_far = np.load(\"tmp/adv50_2.npy\")\n",
    "best_adv_so_far = final_out\n",
    "\n",
    "print(\"sum\", np.sum(correct))\n",
    "\n",
    "what = np.arange(-1,1,.02)\n",
    "\n",
    "#for i in what:\n",
    "for I in range(1,2):\n",
    "    #beta = best_adv_so_far[~correct][I]-orig[~correct][I]\n",
    "    beta = best_adv_so_far[I]-orig[I]\n",
    "    X = []\n",
    "    Y = []\n",
    "    Z = []\n",
    "    i = 0\n",
    "    print(I, correct[I])\n",
    "    js = what.reshape((-1,1,1,1))\n",
    "    Z.extend(sess.run(outs, {xs: orig[I:I+1] + alpha * i + beta * js,\n",
    "                             ys: labs[I:I+1]}))\n",
    "    \n",
    "\n",
    "    X.append(i)\n",
    "    Y.append(i)\n",
    "    \n",
    "    print(np.array(Z)[50])\n",
    "    \n",
    "    plt.plot(what,Z)\n",
    "    plt.show()\n",
    "#fig = plt.figure()\n",
    "#ax = fig.add_subplot(111, projection='3d')\n",
    "#ax.plot_surface(np.array(X), np.array(Y), np.array(Z))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "print(np.max(np.abs((keep_adv-x_test[:1000]))))\n",
    "\n",
    "if True:\n",
    "    #keep_adv = np.load(\"tmp/adv50_1.npy\")\n",
    "    keep_adv = np.load(\"qq3.npy\")\n",
    "\n",
    "    correct = model.predict(x_test[0:1000]).argmax(1)==y_test[0:1000].argmax(1)\n",
    "    print(np.mean(correct))\n",
    "\n",
    "    correct = model.predict(keep_adv[0:1000]).argmax(1)==y_test[0:1000].argmax(1)\n",
    "    print(np.mean(correct))\n",
    "    \n",
    "    keep_adv[correct] = final_out\n",
    "    np.save(\"qq4.npy\", keep_adv)\n",
    "    \n",
    "    correct = model.predict(keep_adv[0:1000]).argmax(1)==y_test[0:1000].argmax(1)\n",
    "    print(np.mean(correct))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.5.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
