{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "incredible-situation",
   "metadata": {},
   "source": [
    "Joint Shapley value calculations on the Rotten Tomatoes dataset (Pang and Lee, 2005, PACL)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "1c0cd7b3-3356-478e-9834-d849b5057db2",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Using TensorFlow backend.\n",
      "C:\\ProgramData\\Anaconda3\\envs\\Shapley-values\\lib\\site-packages\\tensorflow\\python\\framework\\dtypes.py:516: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  _np_qint8 = np.dtype([(\"qint8\", np.int8, 1)])\n",
      "C:\\ProgramData\\Anaconda3\\envs\\Shapley-values\\lib\\site-packages\\tensorflow\\python\\framework\\dtypes.py:517: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  _np_quint8 = np.dtype([(\"quint8\", np.uint8, 1)])\n",
      "C:\\ProgramData\\Anaconda3\\envs\\Shapley-values\\lib\\site-packages\\tensorflow\\python\\framework\\dtypes.py:518: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  _np_qint16 = np.dtype([(\"qint16\", np.int16, 1)])\n",
      "C:\\ProgramData\\Anaconda3\\envs\\Shapley-values\\lib\\site-packages\\tensorflow\\python\\framework\\dtypes.py:519: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  _np_quint16 = np.dtype([(\"quint16\", np.uint16, 1)])\n",
      "C:\\ProgramData\\Anaconda3\\envs\\Shapley-values\\lib\\site-packages\\tensorflow\\python\\framework\\dtypes.py:520: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  _np_qint32 = np.dtype([(\"qint32\", np.int32, 1)])\n",
      "C:\\ProgramData\\Anaconda3\\envs\\Shapley-values\\lib\\site-packages\\tensorflow\\python\\framework\\dtypes.py:525: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  np_resource = np.dtype([(\"resource\", np.ubyte, 1)])\n",
      "C:\\ProgramData\\Anaconda3\\envs\\Shapley-values\\lib\\site-packages\\tensorboard\\compat\\tensorflow_stub\\dtypes.py:541: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  _np_qint8 = np.dtype([(\"qint8\", np.int8, 1)])\n",
      "C:\\ProgramData\\Anaconda3\\envs\\Shapley-values\\lib\\site-packages\\tensorboard\\compat\\tensorflow_stub\\dtypes.py:542: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  _np_quint8 = np.dtype([(\"quint8\", np.uint8, 1)])\n",
      "C:\\ProgramData\\Anaconda3\\envs\\Shapley-values\\lib\\site-packages\\tensorboard\\compat\\tensorflow_stub\\dtypes.py:543: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  _np_qint16 = np.dtype([(\"qint16\", np.int16, 1)])\n",
      "C:\\ProgramData\\Anaconda3\\envs\\Shapley-values\\lib\\site-packages\\tensorboard\\compat\\tensorflow_stub\\dtypes.py:544: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  _np_quint16 = np.dtype([(\"quint16\", np.uint16, 1)])\n",
      "C:\\ProgramData\\Anaconda3\\envs\\Shapley-values\\lib\\site-packages\\tensorboard\\compat\\tensorflow_stub\\dtypes.py:545: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  _np_qint32 = np.dtype([(\"qint32\", np.int32, 1)])\n",
      "C:\\ProgramData\\Anaconda3\\envs\\Shapley-values\\lib\\site-packages\\tensorboard\\compat\\tensorflow_stub\\dtypes.py:550: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  np_resource = np.dtype([(\"resource\", np.ubyte, 1)])\n"
     ]
    }
   ],
   "source": [
    "import copy\n",
    "import random\n",
    "import scipy\n",
    "\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "\n",
    "from sklearn.feature_extraction.text import CountVectorizer\n",
    "\n",
    "from keras.models import Sequential\n",
    "from keras.layers import Dense"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "fc18b08a-7db5-447d-aaa7-bb63fdc8e93d",
   "metadata": {},
   "source": [
    "## Set parameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "33c43bb9-5d98-4b55-bb22-587386de2118",
   "metadata": {},
   "outputs": [],
   "source": [
    "k = 2\n",
    "take_x_most_common_words = 1000\n",
    "num_sampling_iterations = 5\n",
    "np.random.seed(10) # Set random seed for consistency"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "e5d5fac0-5103-4fa4-89b2-d0aba704c545",
   "metadata": {},
   "outputs": [],
   "source": [
    "# 5331 pos, 5331 neg reviews; the lines here refer to lines in the pos and neg review files separately\n",
    "train_lines = list(range(0,199))\n",
    "train_lines.extend(range(200,1551))\n",
    "train_lines.extend(range(1600,5331))\n",
    "\n",
    "test_lines = list(range(1551, 1600))\n",
    "test_lines.insert(0,199)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "73813295-2d7e-4629-8199-68e19376adc1",
   "metadata": {},
   "source": [
    "## Load data\n",
    "Review variable names suffixed with `_ss` are a list of strings, with one string representing an entire review. \n",
    "\n",
    "Review variable names suffixed with `_ls` are a list of list of strings, with one string representing an entire review. \n",
    "\n",
    "Review variable names suffixed with `_vc` are lists of lists of integers, with a list of integers representing an entire review, and an integer representing a word.\n",
    "\n",
    "Review variable names suffixed with `_oh` are one-hot encoded pandas Dataframes of reviews, with the column names representing the numeric representation of a word."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f075c205-5def-449e-a3f5-bdfdc4c5cee0",
   "metadata": {},
   "source": [
    "### Obtain Rotten tomatoes data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "69c6ecfd-38cb-4f06-8ff9-6a027cc4f100",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_rt_data(fname, line_range):\n",
    "    with open(fname, encoding='utf-8', errors='ignore') as file:\n",
    "        all_lines = list(file)\n",
    "        as_single_string = [all_lines[line_num] for line_num in line_range]\n",
    "        as_list_of_strings = [line.strip().split() for line in as_single_string]\n",
    "    return as_single_string, as_list_of_strings"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "soviet-rental",
   "metadata": {},
   "source": [
    "#### Manual pre-processing converts \"a\" -> \"aaaa\" and \"won't\" -> \"wont\" to ease tokenizing"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "7adcf401-515b-4462-b428-cb9c35a91756",
   "metadata": {},
   "outputs": [],
   "source": [
    "any_y = np.concatenate((np.ones(len(train_lines),dtype=bool), np.zeros(len(train_lines), dtype=bool)))\n",
    "\n",
    "train_pos_reviews_ss, train_pos_reviews_ls = get_rt_data(\"../datasets/rt-polaritydata/rt-polarity-preprocessed.pos\", train_lines) \n",
    "train_neg_reviews_ss, train_neg_reviews_ls = get_rt_data(\"../datasets/rt-polaritydata/rt-polarity-preprocessed.neg\", train_lines)\n",
    "train_reviews_ss = train_pos_reviews_ss + train_neg_reviews_ss \n",
    "train_reviews_ls = train_pos_reviews_ls + train_neg_reviews_ls\n",
    "train_y = np.concatenate(\n",
    "    (np.ones(len(train_lines),dtype=bool), \n",
    "     np.zeros(len(train_lines), dtype=bool))\n",
    ")\n",
    "\n",
    "test_pos_reviews_ss, test_pos_reviews_ls = get_rt_data(\"../datasets/rt-polaritydata/rt-polarity-preprocessed.pos\", test_lines) \n",
    "test_neg_reviews_ss, test_neg_reviews_ls = get_rt_data(\"../datasets/rt-polaritydata/rt-polarity-preprocessed.neg\", test_lines) \n",
    "test_reviews_ss = test_pos_reviews_ss + test_neg_reviews_ss \n",
    "test_reviews_ls = test_pos_reviews_ls + test_neg_reviews_ls\n",
    "test_y = np.concatenate(\n",
    "    (np.ones(len(test_lines),dtype=bool), \n",
    "     np.zeros(len(test_lines), dtype=bool))\n",
    ")\n",
    "\n",
    "all_reviews_ss = train_reviews_ss + test_reviews_ss\n",
    "all_reviews_ls = train_reviews_ls + test_reviews_ls"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "e03efea6-4272-4985-81ab-69c579255850",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train set has 10562 reviews; example review:\n",
      "['the', 'rock', 'is', 'destined', 'to', 'be', 'the', '21st', \"century's\", 'new', '\"', 'conan', '\"', 'and', 'that', \"he's\", 'going', 'to', 'make', 'aaaa', 'splash', 'even', 'greater', 'than', 'arnold', 'schwarzenegger', ',', 'jean-claud', 'van', 'damme', 'or', 'steven', 'segal', '.']\n"
     ]
    }
   ],
   "source": [
    "print(f\"Train set has {len(train_reviews_ss)} reviews; example review:\\n{train_reviews_ls[0]}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "cd057c43-c0f1-492f-945e-17ea8657fbd6",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test set has 100 reviews; example review:\n",
      "['australian', 'actor/director', 'john', 'polson', 'and', 'award-winning', 'english', 'cinematographer', 'giles', 'nuttgens', 'make', 'aaaa', 'terrific', 'effort', 'at', 'disguising', 'the', 'obvious', 'with', 'energy', 'and', 'innovation', '.']\n"
     ]
    }
   ],
   "source": [
    "print(f\"Test set has {len(test_reviews_ss)} reviews; example review:\\n{test_reviews_ls[0]}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "156db910-3a99-47e3-8aa1-7a03e045c3ce",
   "metadata": {},
   "source": [
    "## Add hand-picked example n-grams terms from existing literature\n",
    "#### Socher et al. (EMNLP, 2013), Dhamdhere et al. (ICML, 2020)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "0cbced5f-f227-4b72-a9b0-33e3994a22bd",
   "metadata": {},
   "outputs": [],
   "source": [
    "target_vocab_DSA = dict(\n",
    "    t2dsa = [\"wont disappointed\", \"both inspiring\", \"aaaa crisp\", \"excellent youthful\", \"john terrific\"],\n",
    ")\n",
    "\n",
    "target_vocab = dict(\n",
    "    t1 = ['engaging', 'best', 'powerful', 'love', 'beautiful', 'bad', 'dull', \n",
    "          'boring', 'fails', 'worst', 'stupid', 'painfully'],\n",
    "    t2 = ['excellent performances', 'aaaa masterpiece', 'masterful film', 'wonderful movie',\n",
    "          'marvelous performances', 'worst movie', 'very bad', 'shapeless mess',\n",
    "          'worst thing', 'instantly forgettable', 'complete failure'],\n",
    "    t3 = ['an amazing performance', 'wonderful all ages triumph', 'aaaa wonderful movie',\n",
    "          'most visually stunning', 'for worst movie', 'aaaa lousy movie', 'aaaa complete failure',\n",
    "          'most painfully marginal', 'very bad sign'],\n",
    "    t4 = ['gorgeous imagery effective performances', 'just another bad movie',\n",
    "          'aaaa humorless disjointed mess'],\n",
    "    t5 = ['nicely acted and beautifully shot', 'the best of the year',\n",
    "           'aaaa terrific american sports movie', 'refreshingly honest and ultimately touching',\n",
    "           'silliest and most incoherent movie', 'completely crass and forgettable movie',\n",
    "           'aaaa cumbersome and cliche ridden movie'],\n",
    "    t6 = ['aaaa trashy exploitative thoroughly unpleasant experience'],\n",
    "    t7 = ['aaaa masterful film from aaaa master filmmaker', 'this sloppy drama is an empty vessel',\n",
    "          'quickly drags on becoming boring and predictable'],\n",
    "    t8 = ['one of the best films of the year', 'aaaa love for films shines through each frame',\n",
    "          'created aaaa masterful piece of artistry right here',\n",
    "          'be the worst special effects creation of the year'],\n",
    "    t2dsa = [\"wont disappointed\", \"both inspiring\", \"aaaa crisp\", \"excellent youthful\", \"john terrific\"],\n",
    ")\n",
    "\n",
    "def target_vocab_to_reviews_ss(tv):\n",
    "    return [' '.join(v) for v in tv.values()]\n",
    "\n",
    "def target_vocab_DSA_to_reviews_ss(tv):\n",
    "    return [' '.join(v) for v in tv.values()]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "63a01ae3-c243-4f46-859f-1edfc77f22de",
   "metadata": {},
   "source": [
    "## Manage the formats of the reviews"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "55abf80f-dba1-4573-b3cb-5b4afebf3908",
   "metadata": {},
   "source": [
    "#### We add some helper functions to convert between our chosen review formats"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "029d1b1a-36ba-4c86-bed2-cc2b076e9125",
   "metadata": {},
   "outputs": [],
   "source": [
    "def ss_to_oh(reviews_ss, vectorizer):\n",
    "    oh_reviews = vectorizer.transform(reviews_ss).toarray().astype(bool)\n",
    "    return pd.DataFrame(\n",
    "        columns = vectorizer.get_feature_names(), data=oh_reviews\n",
    "    )    \n",
    "\n",
    "def ss_to_vc_old(reviews_ss, vectorizer):\n",
    "    return [\n",
    "        [vectorizer.get_feature_names().index(w) for w in rev_ss.split()]\n",
    "        for rev_ss in reviews_ss\n",
    "    ]\n",
    "\n",
    "def ss_to_vc(reviews_ss, vectorizer):\n",
    "    as_oh = ss_to_oh(reviews_ss, vectorizer)\n",
    "    return [\n",
    "        [i for i, bl in enumerate(as_oh_row) if bl]\n",
    "        for as_oh_row in as_oh.values\n",
    "    ]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3bdb1856-cad4-4396-938f-0d0942dc760a",
   "metadata": {},
   "source": [
    "#### A 'vectorizer' is used to encode reviews numerically"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "48bc5502-24c1-4674-8ca3-4977374ac084",
   "metadata": {
    "scrolled": true,
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total vocabulary 18326\n"
     ]
    }
   ],
   "source": [
    "def get_vectorizer(reviews_ss):\n",
    "    vectorizer = CountVectorizer()\n",
    "    return vectorizer.fit(reviews_ss)\n",
    "\n",
    "all_vectorizer = get_vectorizer(\n",
    "    all_reviews_ss + target_vocab_to_reviews_ss(target_vocab)\n",
    ")\n",
    "\n",
    "num_features = len(all_vectorizer.get_feature_names())\n",
    "print(f\"Total vocabulary {num_features}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f21bf029-6be7-45cf-a97a-5110581c24e2",
   "metadata": {},
   "source": [
    "#### A function to take the top n most common words from our chosen body of work"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "hazardous-camera",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_top_n_words(corpus, n):\n",
    "    vec = CountVectorizer().fit(corpus)\n",
    "    bag_of_words = vec.transform(corpus)\n",
    "    sum_words = bag_of_words.sum(axis=0) \n",
    "    words_freq = [(word, sum_words[0, idx]) for word, idx in vec.vocabulary_.items()]\n",
    "    words_freq =sorted(words_freq, key = lambda x: x[1], reverse=True)\n",
    "    return words_freq[:n]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "11bad068-7199-4af6-8b96-593472af53ab",
   "metadata": {},
   "source": [
    "#### Get the top x words and create a vectorizer of these plus the DSA words"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "sporting-pathology",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total vocabulary 1004\n"
     ]
    }
   ],
   "source": [
    "top_n_words_ss = [\n",
    "    word for word, _ in get_top_n_words(all_reviews_ss, take_x_most_common_words)\n",
    "]\n",
    "    \n",
    "DSA_vectorizer = get_vectorizer(\n",
    "    top_n_words_ss + target_vocab_DSA_to_reviews_ss(target_vocab_DSA)\n",
    ")\n",
    "\n",
    "num_DSA_features = len(DSA_vectorizer.get_feature_names())\n",
    "\n",
    "print(f\"Total vocabulary {num_DSA_features}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "65554dca-ce47-4553-9946-d3ff6dabea5d",
   "metadata": {},
   "source": [
    "## Shuffle the training set"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "6983939d-e6e3-4a44-be42-3de79ca393ce",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_shuffle_index(x_len):\n",
    "    return np.random.permutation(np.arange(x_len))   "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "208ee307-c7d8-419a-9684-3fabbcee63e4",
   "metadata": {},
   "outputs": [],
   "source": [
    "si = get_shuffle_index(len(train_reviews_ss))\n",
    "ss_train = [train_reviews_ss[i] for i in si]\n",
    "train_y = train_y[si]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5f5b0b17-0068-433d-b7fa-fdb16847eca7",
   "metadata": {},
   "source": [
    "#### One-hot encode the (now shuffled) training set"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "260986f1-76f9-4eee-9df9-bcc72ddfa3df",
   "metadata": {},
   "outputs": [],
   "source": [
    "oh_train = ss_to_oh(ss_train, DSA_vectorizer)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2a2b00df-ec15-4265-9c6f-7d4147e5ec6d",
   "metadata": {},
   "source": [
    "#### One-hot encode the test set (no shuffling is needed)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "23bd23cc-eed6-45c2-b391-ec62f855375c",
   "metadata": {},
   "outputs": [],
   "source": [
    "oh_test = ss_to_oh(test_reviews_ss, DSA_vectorizer)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4abe0c82-8708-4e91-8743-e4daa50e2b9c",
   "metadata": {},
   "source": [
    "## Define the ML model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "ce80d7d3-47bf-4e7a-8cc6-81254d3851d7",
   "metadata": {},
   "outputs": [],
   "source": [
    "model = Sequential()\n",
    "model.add(Dense(16, input_dim=oh_train.shape[1], activation='relu'))\n",
    "model.add(Dense(16, activation='relu'))\n",
    "model.add(Dense(1, activation='sigmoid'))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6642066e-0319-446b-b5e6-fd4da1fef43e",
   "metadata": {},
   "source": [
    "#### Train on one-hot encoded data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "54e0c583-c31f-424b-a9e4-698e86c1580b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "WARNING:tensorflow:From C:\\ProgramData\\Anaconda3\\envs\\Shapley-values\\lib\\site-packages\\tensorflow\\python\\ops\\nn_impl.py:180: add_dispatch_support.<locals>.wrapper (from tensorflow.python.ops.array_ops) is deprecated and will be removed in a future version.\n",
      "Instructions for updating:\n",
      "Use tf.where in 2.0, which has the same broadcast rule as np.where\n",
      "WARNING:tensorflow:From C:\\ProgramData\\Anaconda3\\envs\\Shapley-values\\lib\\site-packages\\keras\\backend\\tensorflow_backend.py:422: The name tf.global_variables is deprecated. Please use tf.compat.v1.global_variables instead.\n",
      "\n",
      "Epoch 1/4\n",
      "10562/10562 [==============================] - 3s 272us/step - loss: 0.6252 - accuracy: 0.6415\n",
      "Epoch 2/4\n",
      "10562/10562 [==============================] - 3s 238us/step - loss: 0.5349 - accuracy: 0.7343\n",
      "Epoch 3/4\n",
      "10562/10562 [==============================] - 2s 227us/step - loss: 0.5112 - accuracy: 0.7551\n",
      "Epoch 4/4\n",
      "10562/10562 [==============================] - 2s 229us/step - loss: 0.4997 - accuracy: 0.7627\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<keras.callbacks.callbacks.History at 0x2b1c474b3c8>"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.compile(optimizer=\"rmsprop\", loss=\"binary_crossentropy\", metrics=[\"accuracy\"])\n",
    "model.fit(oh_train.values, train_y, epochs=4, batch_size=5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "c3ad37ce-dd6b-487a-96f7-6225ccab3be0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "100/100 [==============================] - 0s 279us/step\n",
      "Model accuracy on test set is 80.00%\n"
     ]
    }
   ],
   "source": [
    "_, accuracy = model.evaluate(oh_test.values, test_y)\n",
    "print(f\"Model accuracy on test set is {accuracy:.2%}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e42d7ac2-ad5d-42d3-892a-24401586f7de",
   "metadata": {},
   "source": [
    "#### Some examples of incorrect predictions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "44e43daf-beb5-4314-ac08-30649454cce9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "this is wild surreal stuff , but brilliant and the camera just kind of sits there and lets you look at this and its like you're going from one room to the next and none of them have any relation to the other . \n",
      "\n",
      "Predicted 0, actual 1\n",
      "\n",
      "\n",
      "it's aaaa demented kitsch mess ( although the smeary digital video does match the muddled narrative ) , but it's savvy about celebrity and has more guts and energy than much of what will open this year . \n",
      "\n",
      "Predicted 0, actual 1\n",
      "\n",
      "\n",
      "aaaa welcome relief from baseball movies that try too hard to be mythic , this one is aaaa sweet and modest and ultimately winning story . \n",
      "\n",
      "Predicted 0, actual 1\n",
      "\n",
      "\n"
     ]
    }
   ],
   "source": [
    "predictions = (model.predict(oh_test.values) > 0.5).astype(np.int32)\n",
    "incorrect_predictions = [\n",
    "    (rev, predicted[0], actual) \n",
    "    for (rev, predicted, actual) in zip(test_reviews_ss, predictions, test_y)\n",
    "    if predicted[0] != int(actual)\n",
    "]\n",
    "for rev, predicted, actual in incorrect_predictions[:3]:\n",
    "    print(f\"{rev}\")\n",
    "    print(f\"Predicted {predicted}, actual {int(actual)}\\n\\n\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "08a1e7db-9635-4c08-a155-b78725d23e53",
   "metadata": {},
   "source": [
    "#### Helper functions to generate powerset of features, up to maximum set size of k"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "premier-parliament",
   "metadata": {},
   "outputs": [],
   "source": [
    "# includes the emptyset; don't call this directly as yields index out of bounds\n",
    "def get_powerset_to_k(seq, k, init=True):\n",
    "    if init:\n",
    "        seq = [s if type(s) == frozenset else frozenset([s]) for s in seq]\n",
    "    if len(seq) <= 1:\n",
    "        yield seq[0]\n",
    "        yield frozenset()\n",
    "    else: \n",
    "        for item in get_powerset_to_k(seq[1:], k, False):\n",
    "            if len(item) <= k - 1:\n",
    "                yield seq[0].union(item)\n",
    "            yield item"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "sunrise-adobe",
   "metadata": {},
   "outputs": [],
   "source": [
    "# removes the empty set: can call this directly\n",
    "def get_powerset_to_k_ex_emptyset(seq, k):\n",
    "    gen = get_powerset_to_k(seq, k)\n",
    "    for item in gen:\n",
    "        if item != frozenset():\n",
    "            yield item"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "amateur-reply",
   "metadata": {},
   "outputs": [],
   "source": [
    "def choose(n, k):\n",
    "    return scipy.special.comb(n, k)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a92d2d81-b838-405a-9044-947ebbcf605e",
   "metadata": {},
   "source": [
    "#### The q values allow us to probability-weight our sampled results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "436c8350-7e84-4707-a341-a927b58af3e8",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "def get_q_values_for_k(k, num_local_features):\n",
    "    q = np.zeros(num_local_features, dtype=np.longdouble) \n",
    "    q0den = sum([\n",
    "        choose(num_local_features, s) for s in range(1, k+1)\n",
    "    ])\n",
    "    q[0] = 1/q0den \n",
    "    for r in range(1, num_local_features):\n",
    "        limd = min(k, (num_local_features - r))\n",
    "        limn = max((r - k), 0)\n",
    "        qden = sum([\n",
    "            choose(num_local_features - r, s) for s in range(1, limd+1)\n",
    "        ])\n",
    "        qnum = sum([\n",
    "            choose(r, s) * q[s] for s in range(limn, r)\n",
    "        ])\n",
    "        q[r] = qnum / qden\n",
    "    # Check that the checksum is satisfied\n",
    "    checksum = sum([\n",
    "        choose(num_local_features, i) * q[i] \n",
    "        for i in range((num_local_features - k), num_local_features)\n",
    "    ])\n",
    "    assert(np.isclose(checksum, 1.0))\n",
    "    return q\n",
    "\n",
    "_all_q_values = [get_q_values_for_k(_k, num_DSA_features) for _k in range(1, k+1)]\n",
    "q_values = np.vstack(_all_q_values)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a32e75c3-173f-463c-ab94-efe31f34e349",
   "metadata": {},
   "source": [
    "### Take a single sample review"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "947e4732-46d5-4a6c-93f8-991e3d9312e0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "sample review: australian actor/director john polson and award-winning english cinematographer giles nuttgens make aaaa terrific effort at disguising the obvious with energy and innovation . \n",
      "\n"
     ]
    }
   ],
   "source": [
    "sample_review_oh = oh_test.iloc[0]\n",
    "print(f'sample review: {test_reviews_ss[0]}')\n",
    "all_features_set = set(range(1, num_DSA_features + 1))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d3ec7936-6d69-4108-96dc-ead7a06b550d",
   "metadata": {},
   "source": [
    "## The Joint Shapley calculation function"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "c25bb5a2-26ec-4d62-b677-5e0a382c2131",
   "metadata": {},
   "outputs": [],
   "source": [
    "def calculate_phi_t(\n",
    "    review_oh,\n",
    "    value_function,\n",
    "    coalition_vc,\n",
    "    num_features,\n",
    "    q_values,\n",
    "    num_sampling_iterations,\n",
    "):\n",
    "    coalition_size = len(coalition_vc)\n",
    "    p_values = np.zeros((num_features - coalition_size + 1), dtype=np.longdouble)\n",
    "    for i in range(1, num_features - coalition_size + 2):\n",
    "        q_value = q_values[k-1, i-1]\n",
    "        num_ft_choose_len = choose((num_features - coalition_size), (i - 1))\n",
    "        p_values[i - 1] = num_ft_choose_len * q_value\n",
    "    hat_p_values = p_values / np.sum(p_values)\n",
    "    estimates = np.zeros(num_sampling_iterations)\n",
    "\n",
    "    for itr in range(0, num_sampling_iterations):\n",
    "        U = np.random.uniform(0, 1, 1)\n",
    "        X = sum(U > hat_p_values.cumsum())\n",
    "        S = set()\n",
    "        for w in range(1, X + 1):\n",
    "            possible_next = set(range(1, num_features + 1)).difference(\n",
    "                set(coalition_vc).union(S))\n",
    "            r = random.sample(possible_next, 1)\n",
    "            S = S.union(set(r))\n",
    "\n",
    "        z = np.random.randint(0, 2, num_features)\n",
    "        xminusT = np.copy(review_oh)\n",
    "        xplusT = np.copy(review_oh)\n",
    "        for h in set(range(0, num_features)).difference(S):\n",
    "            xminusT[h] = z[h]\n",
    "        for h in set(range(0, num_features)).difference(S.union(set(coalition_vc))):\n",
    "            xplusT[h] = z[h]\n",
    "\n",
    "        estimates[itr] = value_function(xplusT) - value_function(xminusT)\n",
    "    return np.mean(estimates) * np.sum(p_values)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b3cf547e-226a-4ecf-9ec2-bec40869a344",
   "metadata": {},
   "source": [
    "#### We use a 'value function' to give us the value of a given coalition; in this case the 'value' is the prediction it receives from our ML model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "d779e600-fb15-49a2-ac4b-5c81adf4d4a3",
   "metadata": {},
   "outputs": [],
   "source": [
    "value_f = lambda oh: model.predict(oh[None, :])[0][0]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "adf8e027-11c6-4d1d-9492-60a1312b3184",
   "metadata": {},
   "source": [
    "#### We look at our target vocabulary from Dhamdhere et al. (2020)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "4eabb574-fd32-404c-b314-05f747e69b5e",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Obtain bigrams used in Dhamdhere et al as strings\n",
    "t2dsa = target_vocab[\"t2dsa\"]\n",
    "# Vectorize bigrams\n",
    "t2dsa_vc = ss_to_vc(t2dsa, DSA_vectorizer)\n",
    "# Add both bigrams and single words from bigrams to list of coalitions\n",
    "DSA_coalitions = [cln for cln in t2dsa_vc] + [[word] for cln in t2dsa_vc for word in cln]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "65538268-c2bb-4c1d-b3de-29a1f7f80058",
   "metadata": {},
   "source": [
    "#### We can now calculate Joint Shapley values for the Dhamdhere et al. coalitions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "leading-principle",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "test_reviews_vc[num_review] = [44, 101, 434, 447, 677, 860, 946]\n"
     ]
    }
   ],
   "source": [
    "test_reviews_vc = ss_to_vc(test_reviews_ss, DSA_vectorizer)\n",
    "num_review = 38 # sets the review to be analysed\n",
    "sample_review_oh = oh_test.iloc[num_review]\n",
    "print(f'test_reviews_vc[num_review] = {test_reviews_vc[num_review]}')\n",
    "\n",
    "num_times_to_loop = 60\n",
    "\n",
    "with open(\"results/250528-review-38-convergence.txt\", \"a\") as a_writer:\n",
    "    a_writer.write(f'test_reviews_vc[num_review] = {test_reviews_vc[num_review]}\\n')\n",
    "\n",
    "    for loop_num in range(num_times_to_loop+1):\n",
    "        a_writer.write(f'loop number = {loop_num}\\n')\n",
    "        for coalition in DSA_coalitions:\n",
    "            js = calculate_phi_t(\n",
    "                sample_review_oh,\n",
    "                value_f,\n",
    "                coalition,\n",
    "                num_DSA_features,\n",
    "                q_values,\n",
    "                num_sampling_iterations\n",
    "            )\n",
    "            a_writer.write(f'k = {k}, coalition {coalition}: local jShapley = {js}\\n')\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "premier-startup",
   "metadata": {},
   "source": [
    "#### Iterate through all the reviews in the test set, calculating local joint Shapleys for the DSA features\n",
    "\n",
    "#### (to reproduce Table 4: set k=3 and iterate through reviews 0, 11, 33, 38, 46)\n",
    "\n",
    "#### (global joint Shapleys are calculated externally according to the instructions in the paper)\n",
    "\n",
    "#### (to reproduce Table 5: set k=1 and iterate over all reviews)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "focused-shade",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "k = 2, review 0, coalition [209, 978]: local jShapley = -2.099510518642003e-06\n",
      "k = 2, review 0, coalition [101, 434]: local jShapley = -1.4886589393610838e-05\n",
      "k = 2, review 0, coalition [3, 174]: local jShapley = 2.3190096850864185e-07\n",
      "k = 2, review 0, coalition [269, 1003]: local jShapley = -3.188376419995403e-05\n",
      "k = 2, review 0, coalition [455, 848]: local jShapley = -7.489815944933572e-05\n",
      "k = 2, review 0, coalition [209]: local jShapley = 4.38324461538257e-05\n",
      "k = 2, review 0, coalition [978]: local jShapley = -0.0003035084371104904\n",
      "k = 2, review 0, coalition [101]: local jShapley = 0.0\n",
      "k = 2, review 0, coalition [434]: local jShapley = -3.947177570884824e-05\n",
      "k = 2, review 0, coalition [3]: local jShapley = 7.122016502769221e-07\n",
      "k = 2, review 0, coalition [174]: local jShapley = 3.6732320785569093e-06\n",
      "k = 2, review 0, coalition [269]: local jShapley = -0.000374570609843023\n",
      "k = 2, review 0, coalition [1003]: local jShapley = -7.199457261767925e-05\n",
      "k = 2, review 0, coalition [455]: local jShapley = -0.0008546215082577499\n",
      "k = 2, review 0, coalition [848]: local jShapley = 0.0006298010919805211\n",
      "k = 2, review 1, coalition [209, 978]: local jShapley = 7.032580887445973e-07\n",
      "k = 2, review 1, coalition [101, 434]: local jShapley = -1.8972839039465635e-06\n",
      "k = 2, review 1, coalition [3, 174]: local jShapley = -7.3536473595228325e-06\n",
      "k = 2, review 1, coalition [269, 1003]: local jShapley = -3.545877747808144e-06\n",
      "k = 2, review 1, coalition [455, 848]: local jShapley = 3.6947543384775236e-05\n",
      "k = 2, review 1, coalition [209]: local jShapley = 6.441659381581943e-05\n",
      "k = 2, review 1, coalition [978]: local jShapley = -0.00022315470167065445\n",
      "k = 2, review 1, coalition [101]: local jShapley = -0.00025541058935836465\n",
      "k = 2, review 1, coalition [434]: local jShapley = -2.8922034758982156e-05\n",
      "k = 2, review 1, coalition [3]: local jShapley = -2.70640577063996e-05\n",
      "k = 2, review 1, coalition [174]: local jShapley = 1.7820934662373812e-05\n",
      "k = 2, review 1, coalition [269]: local jShapley = -0.00010888079584437715\n",
      "k = 2, review 1, coalition [1003]: local jShapley = -0.0001432838123519364\n",
      "k = 2, review 1, coalition [455]: local jShapley = 2.9499460425398233e-06\n",
      "k = 2, review 1, coalition [848]: local jShapley = -0.0006391295244824239\n",
      "k = 2, review 2, coalition [209, 978]: local jShapley = 1.0516444777608406e-05\n",
      "k = 2, review 2, coalition [101, 434]: local jShapley = -1.470023760504474e-06\n",
      "k = 2, review 2, coalition [3, 174]: local jShapley = -6.608134455401676e-10\n",
      "k = 2, review 2, coalition [269, 1003]: local jShapley = -3.644551100266076e-05\n",
      "k = 2, review 2, coalition [455, 848]: local jShapley = -6.30008328749902e-05\n",
      "k = 2, review 2, coalition [209]: local jShapley = 6.437249984958857e-05\n",
      "k = 2, review 2, coalition [978]: local jShapley = 0.0\n",
      "k = 2, review 2, coalition [101]: local jShapley = -9.245088935556971e-05\n",
      "k = 2, review 2, coalition [434]: local jShapley = -5.573050890901865e-05\n",
      "k = 2, review 2, coalition [3]: local jShapley = 0.0\n",
      "k = 2, review 2, coalition [174]: local jShapley = 1.5244401400588875e-06\n",
      "k = 2, review 2, coalition [269]: local jShapley = -6.176566797754539e-05\n",
      "k = 2, review 2, coalition [1003]: local jShapley = -3.463482966078067e-05\n",
      "k = 2, review 2, coalition [455]: local jShapley = 2.6057292563619894e-05\n",
      "k = 2, review 2, coalition [848]: local jShapley = -0.00020567140141604937\n",
      "k = 2, review 3, coalition [209, 978]: local jShapley = -1.4393561165113608e-05\n",
      "k = 2, review 3, coalition [101, 434]: local jShapley = -3.123630788869085e-05\n",
      "k = 2, review 3, coalition [3, 174]: local jShapley = -9.123945644493887e-07\n",
      "k = 2, review 3, coalition [269, 1003]: local jShapley = -5.961481297980227e-08\n",
      "k = 2, review 3, coalition [455, 848]: local jShapley = 8.308150743409762e-05\n",
      "k = 2, review 3, coalition [209]: local jShapley = 8.064479386335802e-05\n",
      "k = 2, review 3, coalition [978]: local jShapley = -0.00011341775420088797\n",
      "k = 2, review 3, coalition [101]: local jShapley = -0.0002765627293525307\n",
      "k = 2, review 3, coalition [434]: local jShapley = -3.4847197119029894e-05\n",
      "k = 2, review 3, coalition [3]: local jShapley = 3.819731509494536e-05\n",
      "k = 2, review 3, coalition [174]: local jShapley = 1.0279156009984452e-06\n",
      "k = 2, review 3, coalition [269]: local jShapley = -2.729975280242902e-06\n",
      "k = 2, review 3, coalition [1003]: local jShapley = -9.535051539796213e-05\n",
      "k = 2, review 3, coalition [455]: local jShapley = 0.0008013935423859095\n",
      "k = 2, review 3, coalition [848]: local jShapley = -2.8237196014920916e-05\n",
      "k = 2, review 4, coalition [209, 978]: local jShapley = -2.8680365558052184e-06\n",
      "k = 2, review 4, coalition [101, 434]: local jShapley = -2.6706303391901916e-07\n",
      "k = 2, review 4, coalition [3, 174]: local jShapley = -1.1704643576685176e-05\n",
      "k = 2, review 4, coalition [269, 1003]: local jShapley = -2.2752668353237035e-06\n",
      "k = 2, review 4, coalition [455, 848]: local jShapley = -1.0686353357162246e-06\n",
      "k = 2, review 4, coalition [209]: local jShapley = 0.0\n",
      "k = 2, review 4, coalition [978]: local jShapley = -0.0002765556291152218\n",
      "k = 2, review 4, coalition [101]: local jShapley = -0.00046506454959540245\n",
      "k = 2, review 4, coalition [434]: local jShapley = -1.6531442014528598e-05\n",
      "k = 2, review 4, coalition [3]: local jShapley = -0.0001697676122261277\n",
      "k = 2, review 4, coalition [174]: local jShapley = 1.685378852394745e-06\n",
      "k = 2, review 4, coalition [269]: local jShapley = -0.0002296860724440246\n",
      "k = 2, review 4, coalition [1003]: local jShapley = -3.8885952825776204e-05\n",
      "k = 2, review 4, coalition [455]: local jShapley = 0.0002795685604460817\n",
      "k = 2, review 4, coalition [848]: local jShapley = -0.0003804140404455857\n",
      "k = 2, review 5, coalition [209, 978]: local jShapley = -3.1257090613402284e-08\n",
      "k = 2, review 5, coalition [101, 434]: local jShapley = -3.2489011052383335e-06\n",
      "k = 2, review 5, coalition [3, 174]: local jShapley = 1.3543332313838085e-06\n",
      "k = 2, review 5, coalition [269, 1003]: local jShapley = -3.337405856040345e-05\n",
      "k = 2, review 5, coalition [455, 848]: local jShapley = -5.185025499470531e-07\n",
      "k = 2, review 5, coalition [209]: local jShapley = 0.00012753056011113864\n",
      "k = 2, review 5, coalition [978]: local jShapley = -0.0004172420552561596\n",
      "k = 2, review 5, coalition [101]: local jShapley = -0.0007978078453540329\n",
      "k = 2, review 5, coalition [434]: local jShapley = -3.0981693266075e-05\n",
      "k = 2, review 5, coalition [3]: local jShapley = 0.00011453130542025168\n",
      "k = 2, review 5, coalition [174]: local jShapley = 6.423731815427732e-06\n",
      "k = 2, review 5, coalition [269]: local jShapley = -0.00014499102496710694\n",
      "k = 2, review 5, coalition [1003]: local jShapley = -1.959921361673561e-05\n",
      "k = 2, review 5, coalition [455]: local jShapley = 0.0004623471763035439\n",
      "k = 2, review 5, coalition [848]: local jShapley = -0.0008443681952192395\n",
      "k = 2, review 6, coalition [209, 978]: local jShapley = -7.640443993153839e-06\n",
      "k = 2, review 6, coalition [101, 434]: local jShapley = -4.3155035765675174e-05\n",
      "k = 2, review 6, coalition [3, 174]: local jShapley = 1.8058130521684345e-06\n",
      "k = 2, review 6, coalition [269, 1003]: local jShapley = -3.331306145992331e-05\n",
      "k = 2, review 6, coalition [455, 848]: local jShapley = -1.477649578880754e-07\n",
      "k = 2, review 6, coalition [209]: local jShapley = 7.469864672812302e-05\n",
      "k = 2, review 6, coalition [978]: local jShapley = -0.00037234160441276457\n",
      "k = 2, review 6, coalition [101]: local jShapley = -0.0003404025195056435\n",
      "k = 2, review 6, coalition [434]: local jShapley = -7.440373361818204e-05\n",
      "k = 2, review 6, coalition [3]: local jShapley = 3.644727082880637e-05\n",
      "k = 2, review 6, coalition [174]: local jShapley = 3.392932620108686e-06\n",
      "k = 2, review 6, coalition [269]: local jShapley = -0.00019886057673614024\n",
      "k = 2, review 6, coalition [1003]: local jShapley = -7.975026457773208e-05\n",
      "k = 2, review 6, coalition [455]: local jShapley = 0.0008493439477083917\n",
      "k = 2, review 6, coalition [848]: local jShapley = -0.0007279975232173284\n",
      "k = 2, review 7, coalition [209, 978]: local jShapley = 9.10535463513371e-06\n",
      "k = 2, review 7, coalition [101, 434]: local jShapley = -5.4765661954978916e-06\n",
      "k = 2, review 7, coalition [3, 174]: local jShapley = 5.052980812763486e-07\n",
      "k = 2, review 7, coalition [269, 1003]: local jShapley = -2.3476471474663462e-05\n",
      "k = 2, review 7, coalition [455, 848]: local jShapley = -2.876179901497491e-05\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "k = 2, review 7, coalition [209]: local jShapley = 1.6017964792685445e-06\n",
      "k = 2, review 7, coalition [978]: local jShapley = -3.1545522804273285e-06\n",
      "k = 2, review 7, coalition [101]: local jShapley = -0.0005801260193943258\n",
      "k = 2, review 7, coalition [434]: local jShapley = -6.445224425660184e-06\n",
      "k = 2, review 7, coalition [3]: local jShapley = 7.410733031878358e-05\n",
      "k = 2, review 7, coalition [174]: local jShapley = 3.1315244837497016e-06\n",
      "k = 2, review 7, coalition [269]: local jShapley = -5.897845169819412e-06\n",
      "k = 2, review 7, coalition [1003]: local jShapley = -1.2178889933981704e-05\n",
      "k = 2, review 7, coalition [455]: local jShapley = 1.3376761801897506e-05\n",
      "k = 2, review 7, coalition [848]: local jShapley = -4.166129273221132e-05\n",
      "k = 2, review 8, coalition [209, 978]: local jShapley = -3.196710196095557e-06\n",
      "k = 2, review 8, coalition [101, 434]: local jShapley = -4.837524617011381e-05\n",
      "k = 2, review 8, coalition [3, 174]: local jShapley = 7.713796671008894e-06\n",
      "k = 2, review 8, coalition [269, 1003]: local jShapley = -1.4338987082822315e-06\n",
      "k = 2, review 8, coalition [455, 848]: local jShapley = -1.7239560772534072e-06\n",
      "k = 2, review 8, coalition [209]: local jShapley = 0.00028463102964735226\n",
      "k = 2, review 8, coalition [978]: local jShapley = 0.0\n",
      "k = 2, review 8, coalition [101]: local jShapley = -2.9527605510226442e-05\n",
      "k = 2, review 8, coalition [434]: local jShapley = -7.964982247061288e-05\n",
      "k = 2, review 8, coalition [3]: local jShapley = 9.048977395999434e-05\n",
      "k = 2, review 8, coalition [174]: local jShapley = 1.0220930199432531e-05\n",
      "k = 2, review 8, coalition [269]: local jShapley = -0.00032352849637146727\n",
      "k = 2, review 8, coalition [1003]: local jShapley = -4.835845831115191e-05\n",
      "k = 2, review 8, coalition [455]: local jShapley = 0.0004719099086408788\n",
      "k = 2, review 8, coalition [848]: local jShapley = -0.0003061918277444104\n",
      "k = 2, review 9, coalition [209, 978]: local jShapley = -2.570259266944695e-05\n",
      "k = 2, review 9, coalition [101, 434]: local jShapley = -5.31018386106184e-05\n",
      "k = 2, review 9, coalition [3, 174]: local jShapley = 1.961993839346583e-06\n",
      "k = 2, review 9, coalition [269, 1003]: local jShapley = -4.576901984884427e-06\n",
      "k = 2, review 9, coalition [455, 848]: local jShapley = -7.05617069157395e-05\n",
      "k = 2, review 9, coalition [209]: local jShapley = 9.779589682885439e-05\n",
      "k = 2, review 9, coalition [978]: local jShapley = -0.00014511179296746072\n",
      "k = 2, review 9, coalition [101]: local jShapley = -0.0006242436957269532\n",
      "k = 2, review 9, coalition [434]: local jShapley = -2.1181573729421796e-05\n",
      "k = 2, review 9, coalition [3]: local jShapley = 2.8738498355372474e-05\n",
      "k = 2, review 9, coalition [174]: local jShapley = 7.091154122467613e-06\n",
      "k = 2, review 9, coalition [269]: local jShapley = -0.0006627954376640385\n",
      "k = 2, review 9, coalition [1003]: local jShapley = -1.2101874747315417e-05\n",
      "k = 2, review 9, coalition [455]: local jShapley = 0.0006748580838667474\n",
      "k = 2, review 9, coalition [848]: local jShapley = -0.0012233814867129887\n",
      "k = 2, review 10, coalition [209, 978]: local jShapley = -3.5114568622917518e-06\n",
      "k = 2, review 10, coalition [101, 434]: local jShapley = -2.983016620299195e-05\n",
      "k = 2, review 10, coalition [3, 174]: local jShapley = 3.689154676378772e-06\n",
      "k = 2, review 10, coalition [269, 1003]: local jShapley = -2.4015116319991727e-10\n",
      "k = 2, review 10, coalition [455, 848]: local jShapley = -4.2462939691421485e-05\n",
      "k = 2, review 10, coalition [209]: local jShapley = 0.00020909930217185373\n",
      "k = 2, review 10, coalition [978]: local jShapley = -0.00038864673435883365\n",
      "k = 2, review 10, coalition [101]: local jShapley = -0.001190846470946071\n",
      "k = 2, review 10, coalition [434]: local jShapley = -3.747071281633382e-06\n",
      "k = 2, review 10, coalition [3]: local jShapley = 6.26362679461974e-05\n",
      "k = 2, review 10, coalition [174]: local jShapley = 2.7163928947423094e-06\n",
      "k = 2, review 10, coalition [269]: local jShapley = -0.00020200307340530343\n",
      "k = 2, review 10, coalition [1003]: local jShapley = -3.943166896296804e-05\n",
      "k = 2, review 10, coalition [455]: local jShapley = 0.0003076508305622437\n",
      "k = 2, review 10, coalition [848]: local jShapley = -0.0001957749925734997\n",
      "k = 2, review 11, coalition [209, 978]: local jShapley = -1.7083679600827185e-06\n",
      "k = 2, review 11, coalition [101, 434]: local jShapley = -3.072764231389626e-05\n",
      "k = 2, review 11, coalition [3, 174]: local jShapley = 5.799845895911036e-07\n",
      "k = 2, review 11, coalition [269, 1003]: local jShapley = -3.562484741959875e-06\n",
      "k = 2, review 11, coalition [455, 848]: local jShapley = 5.191512091452913e-05\n",
      "k = 2, review 11, coalition [209]: local jShapley = 9.20153228458192e-05\n",
      "k = 2, review 11, coalition [978]: local jShapley = -0.00010113236870303497\n",
      "k = 2, review 11, coalition [101]: local jShapley = -0.0004680925902525778\n",
      "k = 2, review 11, coalition [434]: local jShapley = -2.193815545409574e-05\n",
      "k = 2, review 11, coalition [3]: local jShapley = 2.2788989897266126e-05\n",
      "k = 2, review 11, coalition [174]: local jShapley = -1.3114362633433195e-05\n",
      "k = 2, review 11, coalition [269]: local jShapley = -0.0001680890137805325\n",
      "k = 2, review 11, coalition [1003]: local jShapley = -5.9780833151815794e-06\n",
      "k = 2, review 11, coalition [455]: local jShapley = 0.0008884524705856673\n",
      "k = 2, review 11, coalition [848]: local jShapley = -0.0011313182732462666\n",
      "k = 2, review 12, coalition [209, 978]: local jShapley = -1.3429853256594015e-05\n",
      "k = 2, review 12, coalition [101, 434]: local jShapley = -4.4373030827851045e-05\n",
      "k = 2, review 12, coalition [3, 174]: local jShapley = 1.8072610522558245e-05\n",
      "k = 2, review 12, coalition [269, 1003]: local jShapley = -4.8646273888443536e-05\n",
      "k = 2, review 12, coalition [455, 848]: local jShapley = -4.677385070534544e-06\n",
      "k = 2, review 12, coalition [209]: local jShapley = 9.335455979889488e-05\n",
      "k = 2, review 12, coalition [978]: local jShapley = -0.0001296891073799089\n",
      "k = 2, review 12, coalition [101]: local jShapley = -0.0004416494941412176\n",
      "k = 2, review 12, coalition [434]: local jShapley = -5.944935881292105e-05\n",
      "k = 2, review 12, coalition [3]: local jShapley = 4.518458826795613e-05\n",
      "k = 2, review 12, coalition [174]: local jShapley = 1.2918124851401442e-05\n",
      "k = 2, review 12, coalition [269]: local jShapley = -0.00016136063274387334\n",
      "k = 2, review 12, coalition [1003]: local jShapley = -7.245184495800183e-05\n",
      "k = 2, review 12, coalition [455]: local jShapley = 0.0006365694518308566\n",
      "k = 2, review 12, coalition [848]: local jShapley = -0.00029700774541242196\n",
      "k = 2, review 13, coalition [209, 978]: local jShapley = -4.228565335295452e-06\n",
      "k = 2, review 13, coalition [101, 434]: local jShapley = -1.376505382690429e-07\n",
      "k = 2, review 13, coalition [3, 174]: local jShapley = -4.0697770580511066e-06\n",
      "k = 2, review 13, coalition [269, 1003]: local jShapley = -1.5561178954165761e-06\n",
      "k = 2, review 13, coalition [455, 848]: local jShapley = 3.9302713065458463e-05\n",
      "k = 2, review 13, coalition [209]: local jShapley = 5.024748191096524e-06\n",
      "k = 2, review 13, coalition [978]: local jShapley = -7.141968527277484e-06\n",
      "k = 2, review 13, coalition [101]: local jShapley = -0.0001390468536806264\n",
      "k = 2, review 13, coalition [434]: local jShapley = -4.776867219501742e-06\n",
      "k = 2, review 13, coalition [3]: local jShapley = 3.2164829609583234e-07\n",
      "k = 2, review 13, coalition [174]: local jShapley = 3.2608987566392817e-06\n",
      "k = 2, review 13, coalition [269]: local jShapley = -4.12907144493461e-05\n",
      "k = 2, review 13, coalition [1003]: local jShapley = -1.79816801437769e-05\n",
      "k = 2, review 13, coalition [455]: local jShapley = 0.00036773744700097213\n",
      "k = 2, review 13, coalition [848]: local jShapley = -1.5164534391880338e-05\n",
      "k = 2, review 14, coalition [209, 978]: local jShapley = -1.664125024873792e-05\n",
      "k = 2, review 14, coalition [101, 434]: local jShapley = -4.337302150883336e-06\n",
      "k = 2, review 14, coalition [3, 174]: local jShapley = -7.117065351219733e-06\n",
      "k = 2, review 14, coalition [269, 1003]: local jShapley = -1.8701970393543694e-05\n",
      "k = 2, review 14, coalition [455, 848]: local jShapley = -7.404035869570404e-05\n",
      "k = 2, review 14, coalition [209]: local jShapley = 3.3302602326369595e-05\n",
      "k = 2, review 14, coalition [978]: local jShapley = -2.687068818040942e-05\n",
      "k = 2, review 14, coalition [101]: local jShapley = -0.00021809395955413468\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "k = 2, review 14, coalition [434]: local jShapley = -6.250967903057234e-05\n",
      "k = 2, review 14, coalition [3]: local jShapley = -5.9626641530601396e-05\n",
      "k = 2, review 14, coalition [174]: local jShapley = 2.7803932284838163e-07\n",
      "k = 2, review 14, coalition [269]: local jShapley = -0.0004351753357154726\n",
      "k = 2, review 14, coalition [1003]: local jShapley = -8.895789351284269e-05\n",
      "k = 2, review 14, coalition [455]: local jShapley = 0.0001481303000102014\n",
      "k = 2, review 14, coalition [848]: local jShapley = -6.442924844297515e-05\n",
      "k = 2, review 15, coalition [209, 978]: local jShapley = 8.416032959450946e-06\n",
      "k = 2, review 15, coalition [101, 434]: local jShapley = -1.9035274109829083e-05\n",
      "k = 2, review 15, coalition [3, 174]: local jShapley = 1.676962079341442e-05\n",
      "k = 2, review 15, coalition [269, 1003]: local jShapley = -2.089443968896513e-06\n",
      "k = 2, review 15, coalition [455, 848]: local jShapley = -8.289850743516578e-08\n",
      "k = 2, review 15, coalition [209]: local jShapley = 3.507585461122515e-05\n",
      "k = 2, review 15, coalition [978]: local jShapley = -0.00013596451246608858\n",
      "k = 2, review 15, coalition [101]: local jShapley = -0.00046316702849874216\n",
      "k = 2, review 15, coalition [434]: local jShapley = -2.0121303607671793e-07\n",
      "k = 2, review 15, coalition [3]: local jShapley = 0.0001240722333126075\n",
      "k = 2, review 15, coalition [174]: local jShapley = 5.7105950675759706e-06\n",
      "k = 2, review 15, coalition [269]: local jShapley = -0.00018857138604392302\n",
      "k = 2, review 15, coalition [1003]: local jShapley = -1.7429483440888117e-06\n",
      "k = 2, review 15, coalition [455]: local jShapley = 0.0012080984697762696\n",
      "k = 2, review 15, coalition [848]: local jShapley = -0.0009544765005587378\n",
      "k = 2, review 16, coalition [209, 978]: local jShapley = -1.8898711406194157e-07\n",
      "k = 2, review 16, coalition [101, 434]: local jShapley = -1.4416802689051505e-07\n",
      "k = 2, review 16, coalition [3, 174]: local jShapley = 5.688069734887983e-07\n",
      "k = 2, review 16, coalition [269, 1003]: local jShapley = -2.7554009040128964e-05\n",
      "k = 2, review 16, coalition [455, 848]: local jShapley = 7.646555584107655e-09\n",
      "k = 2, review 16, coalition [209]: local jShapley = 0.00013335422642454374\n",
      "k = 2, review 16, coalition [978]: local jShapley = -0.00011722069620779094\n",
      "k = 2, review 16, coalition [101]: local jShapley = -5.339694022421663e-05\n",
      "k = 2, review 16, coalition [434]: local jShapley = -6.804853844086556e-07\n",
      "k = 2, review 16, coalition [3]: local jShapley = 0.00013331000452610912\n",
      "k = 2, review 16, coalition [174]: local jShapley = 2.163845294474322e-06\n",
      "k = 2, review 16, coalition [269]: local jShapley = -8.771014832473312e-05\n",
      "k = 2, review 16, coalition [1003]: local jShapley = -2.5172793294079703e-05\n",
      "k = 2, review 16, coalition [455]: local jShapley = 0.0002897011108147469\n",
      "k = 2, review 16, coalition [848]: local jShapley = -0.00010256674457164359\n",
      "k = 2, review 17, coalition [209, 978]: local jShapley = 1.2862261707835407e-08\n",
      "k = 2, review 17, coalition [101, 434]: local jShapley = -2.233184375997706e-07\n",
      "k = 2, review 17, coalition [3, 174]: local jShapley = -4.854818136225555e-06\n",
      "k = 2, review 17, coalition [269, 1003]: local jShapley = -5.058491321784968e-06\n",
      "k = 2, review 17, coalition [455, 848]: local jShapley = 1.3812063033398407e-06\n",
      "k = 2, review 17, coalition [209]: local jShapley = 2.177458347056573e-05\n",
      "k = 2, review 17, coalition [978]: local jShapley = -2.0980881417393216e-08\n",
      "k = 2, review 17, coalition [101]: local jShapley = -0.0003667040159894703\n",
      "k = 2, review 17, coalition [434]: local jShapley = -7.94180732834933e-06\n",
      "k = 2, review 17, coalition [3]: local jShapley = -5.464643806685994e-05\n",
      "k = 2, review 17, coalition [174]: local jShapley = 2.523899820952788e-06\n",
      "k = 2, review 17, coalition [269]: local jShapley = -0.00023891272232198654\n",
      "k = 2, review 17, coalition [1003]: local jShapley = -1.2051234916658599e-05\n",
      "k = 2, review 17, coalition [455]: local jShapley = 1.4446786754184559e-05\n",
      "k = 2, review 17, coalition [848]: local jShapley = -2.7566986185097445e-06\n",
      "k = 2, review 18, coalition [209, 978]: local jShapley = 1.5252341338673502e-05\n",
      "k = 2, review 18, coalition [101, 434]: local jShapley = -2.007370261368512e-05\n",
      "k = 2, review 18, coalition [3, 174]: local jShapley = 9.631674575230615e-06\n",
      "k = 2, review 18, coalition [269, 1003]: local jShapley = -2.2318974123119165e-07\n",
      "k = 2, review 18, coalition [455, 848]: local jShapley = 1.0713123656875943e-05\n",
      "k = 2, review 18, coalition [209]: local jShapley = 7.1098284928613e-05\n",
      "k = 2, review 18, coalition [978]: local jShapley = -0.00011366294426516555\n",
      "k = 2, review 18, coalition [101]: local jShapley = -0.00017599070370198462\n",
      "k = 2, review 18, coalition [434]: local jShapley = -3.43614598633697e-05\n",
      "k = 2, review 18, coalition [3]: local jShapley = 0.0001324353320489706\n",
      "k = 2, review 18, coalition [174]: local jShapley = 4.076772893298356e-07\n",
      "k = 2, review 18, coalition [269]: local jShapley = -0.00028002201614232527\n",
      "k = 2, review 18, coalition [1003]: local jShapley = -6.203517848680947e-06\n",
      "k = 2, review 18, coalition [455]: local jShapley = 0.0003240277091525907\n",
      "k = 2, review 18, coalition [848]: local jShapley = 1.4415400720194313e-06\n",
      "k = 2, review 19, coalition [209, 978]: local jShapley = -1.8536083390318935e-05\n",
      "k = 2, review 19, coalition [101, 434]: local jShapley = -7.803752630088572e-05\n",
      "k = 2, review 19, coalition [3, 174]: local jShapley = -1.1803042919288973e-07\n",
      "k = 2, review 19, coalition [269, 1003]: local jShapley = -1.4452803590633648e-05\n",
      "k = 2, review 19, coalition [455, 848]: local jShapley = -5.0063423227966936e-08\n",
      "k = 2, review 19, coalition [209]: local jShapley = 0.00021822120945281254\n",
      "k = 2, review 19, coalition [978]: local jShapley = -0.00024340145479776154\n",
      "k = 2, review 19, coalition [101]: local jShapley = -0.00036909397612359\n",
      "k = 2, review 19, coalition [434]: local jShapley = 0.0\n",
      "k = 2, review 19, coalition [3]: local jShapley = -0.0001088602029240308\n",
      "k = 2, review 19, coalition [174]: local jShapley = -1.14785464065064e-05\n",
      "k = 2, review 19, coalition [269]: local jShapley = -0.0006804995369086972\n",
      "k = 2, review 19, coalition [1003]: local jShapley = -1.0301590006756342e-07\n",
      "k = 2, review 19, coalition [455]: local jShapley = 0.00045000284870806066\n",
      "k = 2, review 19, coalition [848]: local jShapley = -0.00041567185803122083\n",
      "k = 2, review 20, coalition [209, 978]: local jShapley = -7.983771572622816e-08\n",
      "k = 2, review 20, coalition [101, 434]: local jShapley = -2.7495873415766656e-05\n",
      "k = 2, review 20, coalition [3, 174]: local jShapley = 8.132900007259759e-07\n",
      "k = 2, review 20, coalition [269, 1003]: local jShapley = -6.097932268091713e-05\n",
      "k = 2, review 20, coalition [455, 848]: local jShapley = -8.612352319503509e-06\n",
      "k = 2, review 20, coalition [209]: local jShapley = 8.468783987983618e-05\n",
      "k = 2, review 20, coalition [978]: local jShapley = -1.1624772915409331e-07\n",
      "k = 2, review 20, coalition [101]: local jShapley = -0.000494912297449787\n",
      "k = 2, review 20, coalition [434]: local jShapley = -2.32430172905453e-05\n",
      "k = 2, review 20, coalition [3]: local jShapley = -5.8812225121436004e-05\n",
      "k = 2, review 20, coalition [174]: local jShapley = -3.1394698994679085e-12\n",
      "k = 2, review 20, coalition [269]: local jShapley = -0.00031602823638339446\n",
      "k = 2, review 20, coalition [1003]: local jShapley = -5.153319226371612e-05\n",
      "k = 2, review 20, coalition [455]: local jShapley = 0.0004100187684892371\n",
      "k = 2, review 20, coalition [848]: local jShapley = -1.33731797001921e-07\n",
      "k = 2, review 21, coalition [209, 978]: local jShapley = -3.4801740109372933e-06\n",
      "k = 2, review 21, coalition [101, 434]: local jShapley = -1.7065762411266972e-05\n",
      "k = 2, review 21, coalition [3, 174]: local jShapley = -7.8398966180086e-06\n",
      "k = 2, review 21, coalition [269, 1003]: local jShapley = -6.343483833067883e-06\n",
      "k = 2, review 21, coalition [455, 848]: local jShapley = 6.316433995186101e-06\n",
      "k = 2, review 21, coalition [209]: local jShapley = 0.00010058771866754119\n",
      "k = 2, review 21, coalition [978]: local jShapley = -0.00020827123966095343\n",
      "k = 2, review 21, coalition [101]: local jShapley = -4.7373134019575435e-05\n",
      "k = 2, review 21, coalition [434]: local jShapley = -1.7311753830373755e-05\n",
      "k = 2, review 21, coalition [3]: local jShapley = -6.540150120853512e-06\n",
      "k = 2, review 21, coalition [174]: local jShapley = 1.9161856056132392e-05\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "k = 2, review 21, coalition [269]: local jShapley = -8.047532633743787e-05\n",
      "k = 2, review 21, coalition [1003]: local jShapley = -2.53074632605759e-05\n",
      "k = 2, review 21, coalition [455]: local jShapley = 0.0003042784737049071\n",
      "k = 2, review 21, coalition [848]: local jShapley = -0.00027750123999934775\n",
      "k = 2, review 22, coalition [209, 978]: local jShapley = -6.482261294266374e-06\n",
      "k = 2, review 22, coalition [101, 434]: local jShapley = -2.894704504959697e-05\n",
      "k = 2, review 22, coalition [3, 174]: local jShapley = -7.14916366369759e-06\n",
      "k = 2, review 22, coalition [269, 1003]: local jShapley = -5.472473485036204e-05\n",
      "k = 2, review 22, coalition [455, 848]: local jShapley = -4.4551273325984446e-05\n",
      "k = 2, review 22, coalition [209]: local jShapley = 0.00022777525039605423\n",
      "k = 2, review 22, coalition [978]: local jShapley = -0.00010285771570808917\n",
      "k = 2, review 22, coalition [101]: local jShapley = -0.0002982370672804299\n",
      "k = 2, review 22, coalition [434]: local jShapley = -2.3414132193456515e-05\n",
      "k = 2, review 22, coalition [3]: local jShapley = -9.198163403216119e-05\n",
      "k = 2, review 22, coalition [174]: local jShapley = -1.4500049195018552e-07\n",
      "k = 2, review 22, coalition [269]: local jShapley = -0.00017572477529442598\n",
      "k = 2, review 22, coalition [1003]: local jShapley = -1.183868622112071e-05\n",
      "k = 2, review 22, coalition [455]: local jShapley = 0.00047857303625785527\n",
      "k = 2, review 22, coalition [848]: local jShapley = -0.0011586205407160758\n",
      "k = 2, review 23, coalition [209, 978]: local jShapley = -5.230220419049438e-07\n",
      "k = 2, review 23, coalition [101, 434]: local jShapley = -4.5825306105352975e-05\n",
      "k = 2, review 23, coalition [3, 174]: local jShapley = 9.577428871495826e-07\n",
      "k = 2, review 23, coalition [269, 1003]: local jShapley = -2.2066884118855677e-05\n",
      "k = 2, review 23, coalition [455, 848]: local jShapley = 1.6772097211074922e-05\n",
      "k = 2, review 23, coalition [209]: local jShapley = 7.752316280336613e-05\n",
      "k = 2, review 23, coalition [978]: local jShapley = -0.0001691643372582588\n",
      "k = 2, review 23, coalition [101]: local jShapley = -0.0003703688951612231\n",
      "k = 2, review 23, coalition [434]: local jShapley = -2.4436394207176746e-05\n",
      "k = 2, review 23, coalition [3]: local jShapley = 5.8199771017946973e-05\n",
      "k = 2, review 23, coalition [174]: local jShapley = 8.84709241601185e-07\n",
      "k = 2, review 23, coalition [269]: local jShapley = -0.00035200039467521134\n",
      "k = 2, review 23, coalition [1003]: local jShapley = -6.148651457842256e-05\n",
      "k = 2, review 23, coalition [455]: local jShapley = 0.00025934254299700145\n",
      "k = 2, review 23, coalition [848]: local jShapley = -0.00037904303439849737\n",
      "k = 2, review 24, coalition [209, 978]: local jShapley = -1.3607925476989095e-06\n",
      "k = 2, review 24, coalition [101, 434]: local jShapley = -7.801586437845399e-08\n",
      "k = 2, review 24, coalition [3, 174]: local jShapley = -1.1563645561516117e-05\n",
      "k = 2, review 24, coalition [269, 1003]: local jShapley = -4.3838481979535716e-06\n",
      "k = 2, review 24, coalition [455, 848]: local jShapley = -3.354077382755117e-06\n",
      "k = 2, review 24, coalition [209]: local jShapley = 5.408687859911908e-05\n",
      "k = 2, review 24, coalition [978]: local jShapley = -5.641127880931797e-06\n",
      "k = 2, review 24, coalition [101]: local jShapley = -0.00025545232723984284\n",
      "k = 2, review 24, coalition [434]: local jShapley = -6.328209103283503e-06\n",
      "k = 2, review 24, coalition [3]: local jShapley = -0.00011383228385888193\n",
      "k = 2, review 24, coalition [174]: local jShapley = -5.3084615070759334e-06\n",
      "k = 2, review 24, coalition [269]: local jShapley = -0.0004497865982574421\n",
      "k = 2, review 24, coalition [1003]: local jShapley = -1.3854204786346966e-05\n",
      "k = 2, review 24, coalition [455]: local jShapley = 0.00020620373797693083\n",
      "k = 2, review 24, coalition [848]: local jShapley = -0.0008679508765086612\n",
      "k = 2, review 25, coalition [209, 978]: local jShapley = -2.10086754625338e-06\n",
      "k = 2, review 25, coalition [101, 434]: local jShapley = -8.064533363681923e-06\n",
      "k = 2, review 25, coalition [3, 174]: local jShapley = -1.9369143995642106e-06\n",
      "k = 2, review 25, coalition [269, 1003]: local jShapley = -2.3174409923788119e-07\n",
      "k = 2, review 25, coalition [455, 848]: local jShapley = 6.248675541508023e-05\n",
      "k = 2, review 25, coalition [209]: local jShapley = 0.00016817276672993038\n",
      "k = 2, review 25, coalition [978]: local jShapley = -0.00016065035314857232\n",
      "k = 2, review 25, coalition [101]: local jShapley = -0.00011324149294189707\n",
      "k = 2, review 25, coalition [434]: local jShapley = -4.325814249960097e-07\n",
      "k = 2, review 25, coalition [3]: local jShapley = -6.588882695572539e-05\n",
      "k = 2, review 25, coalition [174]: local jShapley = 5.170763811757311e-06\n",
      "k = 2, review 25, coalition [269]: local jShapley = -0.00021574358910657161\n",
      "k = 2, review 25, coalition [1003]: local jShapley = -9.030885650183724e-05\n",
      "k = 2, review 25, coalition [455]: local jShapley = 0.0009088044246293961\n",
      "k = 2, review 25, coalition [848]: local jShapley = -9.21872637276788e-05\n",
      "k = 2, review 26, coalition [209, 978]: local jShapley = -3.980371438430879e-06\n",
      "k = 2, review 26, coalition [101, 434]: local jShapley = -2.195552672807207e-07\n",
      "k = 2, review 26, coalition [3, 174]: local jShapley = 7.127783103668339e-06\n",
      "k = 2, review 26, coalition [269, 1003]: local jShapley = -2.7198609408829345e-05\n",
      "k = 2, review 26, coalition [455, 848]: local jShapley = -6.891866222722139e-05\n",
      "k = 2, review 26, coalition [209]: local jShapley = 0.00019468569250251212\n",
      "k = 2, review 26, coalition [978]: local jShapley = -4.150377887158041e-05\n",
      "k = 2, review 26, coalition [101]: local jShapley = -4.4597592673016255e-05\n",
      "k = 2, review 26, coalition [434]: local jShapley = -2.8274637506556023e-05\n",
      "k = 2, review 26, coalition [3]: local jShapley = 2.9868674859567943e-06\n",
      "k = 2, review 26, coalition [174]: local jShapley = 4.85238320065516e-06\n",
      "k = 2, review 26, coalition [269]: local jShapley = -0.0002385461398174368\n",
      "k = 2, review 26, coalition [1003]: local jShapley = -2.99258158164777e-05\n",
      "k = 2, review 26, coalition [455]: local jShapley = 0.00120481470597004\n",
      "k = 2, review 26, coalition [848]: local jShapley = -0.00022603135322145414\n",
      "k = 2, review 27, coalition [209, 978]: local jShapley = -4.110347395545579e-06\n",
      "k = 2, review 27, coalition [101, 434]: local jShapley = -6.644632598027672e-06\n",
      "k = 2, review 27, coalition [3, 174]: local jShapley = -5.5293376211399095e-09\n",
      "k = 2, review 27, coalition [269, 1003]: local jShapley = -6.77886770430308e-05\n",
      "k = 2, review 27, coalition [455, 848]: local jShapley = 2.918648430915166e-05\n",
      "k = 2, review 27, coalition [209]: local jShapley = 3.1658529584265344e-05\n",
      "k = 2, review 27, coalition [978]: local jShapley = -3.924328879292468e-05\n",
      "k = 2, review 27, coalition [101]: local jShapley = -0.0007468142608317718\n",
      "k = 2, review 27, coalition [434]: local jShapley = -3.660600905638552e-05\n",
      "k = 2, review 27, coalition [3]: local jShapley = 0.0\n",
      "k = 2, review 27, coalition [174]: local jShapley = 2.0558355226238895e-06\n",
      "k = 2, review 27, coalition [269]: local jShapley = -0.00012390276578668732\n",
      "k = 2, review 27, coalition [1003]: local jShapley = -3.842106851932964e-05\n",
      "k = 2, review 27, coalition [455]: local jShapley = 0.00045929375443019247\n",
      "k = 2, review 27, coalition [848]: local jShapley = -0.0004009722772423975\n",
      "k = 2, review 28, coalition [209, 978]: local jShapley = 1.5684433680436104e-05\n",
      "k = 2, review 28, coalition [101, 434]: local jShapley = -1.4303259827756534e-05\n",
      "k = 2, review 28, coalition [3, 174]: local jShapley = -9.881953980153922e-06\n",
      "k = 2, review 28, coalition [269, 1003]: local jShapley = -1.9172807046144735e-05\n",
      "k = 2, review 28, coalition [455, 848]: local jShapley = 6.602839097657281e-06\n",
      "k = 2, review 28, coalition [209]: local jShapley = 1.722820344029849e-08\n",
      "k = 2, review 28, coalition [978]: local jShapley = -4.607582113576816e-05\n",
      "k = 2, review 28, coalition [101]: local jShapley = -0.0005663466549471811\n",
      "k = 2, review 28, coalition [434]: local jShapley = -9.89272013067447e-05\n",
      "k = 2, review 28, coalition [3]: local jShapley = -1.3793620558944917e-05\n",
      "k = 2, review 28, coalition [174]: local jShapley = 3.032176465450199e-07\n",
      "k = 2, review 28, coalition [269]: local jShapley = -0.0005112698582773656\n",
      "k = 2, review 28, coalition [1003]: local jShapley = 0.0\n",
      "k = 2, review 28, coalition [455]: local jShapley = 0.0006043983618722084\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "k = 2, review 28, coalition [848]: local jShapley = -0.0005122099680767297\n",
      "k = 2, review 29, coalition [209, 978]: local jShapley = 1.1419326880710337e-05\n",
      "k = 2, review 29, coalition [101, 434]: local jShapley = -2.8252698121947926e-06\n",
      "k = 2, review 29, coalition [3, 174]: local jShapley = 1.4867712512648826e-06\n",
      "k = 2, review 29, coalition [269, 1003]: local jShapley = -4.466326390881589e-09\n",
      "k = 2, review 29, coalition [455, 848]: local jShapley = 4.6356729918208356e-05\n",
      "k = 2, review 29, coalition [209]: local jShapley = 7.73831303453288e-05\n",
      "k = 2, review 29, coalition [978]: local jShapley = -0.00023263612243147998\n",
      "k = 2, review 29, coalition [101]: local jShapley = -7.59511199315073e-06\n",
      "k = 2, review 29, coalition [434]: local jShapley = -2.3919123745518456e-05\n",
      "k = 2, review 29, coalition [3]: local jShapley = 6.830820616620252e-05\n",
      "k = 2, review 29, coalition [174]: local jShapley = 1.163426122052187e-06\n",
      "k = 2, review 29, coalition [269]: local jShapley = -0.00034584906250464937\n",
      "k = 2, review 29, coalition [1003]: local jShapley = -7.847378436547289e-05\n",
      "k = 2, review 29, coalition [455]: local jShapley = 4.382588829575563e-06\n",
      "k = 2, review 29, coalition [848]: local jShapley = -0.0006814797108098736\n",
      "k = 2, review 30, coalition [209, 978]: local jShapley = 1.6680841157661427e-05\n",
      "k = 2, review 30, coalition [101, 434]: local jShapley = -7.092321317129031e-05\n",
      "k = 2, review 30, coalition [3, 174]: local jShapley = -7.831323049275488e-06\n",
      "k = 2, review 30, coalition [269, 1003]: local jShapley = -1.0073864972457878e-07\n",
      "k = 2, review 30, coalition [455, 848]: local jShapley = 1.0976365473483848e-05\n",
      "k = 2, review 30, coalition [209]: local jShapley = 0.0002151551862573903\n",
      "k = 2, review 30, coalition [978]: local jShapley = -0.0002743825940241103\n",
      "k = 2, review 30, coalition [101]: local jShapley = -0.00036489140856043163\n",
      "k = 2, review 30, coalition [434]: local jShapley = -4.833698302507205e-05\n",
      "k = 2, review 30, coalition [3]: local jShapley = -8.042108308304168e-05\n",
      "k = 2, review 30, coalition [174]: local jShapley = -4.874696709195102e-06\n",
      "k = 2, review 30, coalition [269]: local jShapley = -0.00032573040149656157\n",
      "k = 2, review 30, coalition [1003]: local jShapley = -3.906516452121644e-05\n",
      "k = 2, review 30, coalition [455]: local jShapley = 0.00030014052789617535\n",
      "k = 2, review 30, coalition [848]: local jShapley = -0.0011020685578046507\n",
      "k = 2, review 31, coalition [209, 978]: local jShapley = -4.170135524551834e-06\n",
      "k = 2, review 31, coalition [101, 434]: local jShapley = -4.064008966151879e-05\n",
      "k = 2, review 31, coalition [3, 174]: local jShapley = -2.8462179118622935e-08\n",
      "k = 2, review 31, coalition [269, 1003]: local jShapley = -9.887678571631916e-06\n",
      "k = 2, review 31, coalition [455, 848]: local jShapley = 5.127961801601272e-05\n",
      "k = 2, review 31, coalition [209]: local jShapley = 8.194049122308583e-05\n",
      "k = 2, review 31, coalition [978]: local jShapley = -0.000136979995655504\n",
      "k = 2, review 31, coalition [101]: local jShapley = -0.0005227171679041196\n",
      "k = 2, review 31, coalition [434]: local jShapley = -9.104991911735557e-06\n",
      "k = 2, review 31, coalition [3]: local jShapley = -4.449722985916293e-05\n",
      "k = 2, review 31, coalition [174]: local jShapley = 5.01391892994192e-06\n",
      "k = 2, review 31, coalition [269]: local jShapley = -0.0002596727786589858\n",
      "k = 2, review 31, coalition [1003]: local jShapley = -9.292249010271392e-05\n",
      "k = 2, review 31, coalition [455]: local jShapley = 0.0007704594156806986\n",
      "k = 2, review 31, coalition [848]: local jShapley = -0.0006141719821809966\n",
      "k = 2, review 32, coalition [209, 978]: local jShapley = -1.3763319536599676e-05\n",
      "k = 2, review 32, coalition [101, 434]: local jShapley = -3.571495992430506e-05\n",
      "k = 2, review 32, coalition [3, 174]: local jShapley = 3.0331314446873405e-06\n",
      "k = 2, review 32, coalition [269, 1003]: local jShapley = -5.54068270788606e-06\n",
      "k = 2, review 32, coalition [455, 848]: local jShapley = -1.112436741226493e-05\n",
      "k = 2, review 32, coalition [209]: local jShapley = 0.0\n",
      "k = 2, review 32, coalition [978]: local jShapley = -0.00015746535300364901\n",
      "k = 2, review 32, coalition [101]: local jShapley = -0.0004606302888154637\n",
      "k = 2, review 32, coalition [434]: local jShapley = -6.416724195703814e-05\n",
      "k = 2, review 32, coalition [3]: local jShapley = 2.7656257043674632e-05\n",
      "k = 2, review 32, coalition [174]: local jShapley = -1.0268691555504646e-06\n",
      "k = 2, review 32, coalition [269]: local jShapley = -0.00021414298932645912\n",
      "k = 2, review 32, coalition [1003]: local jShapley = -6.0317560719066046e-05\n",
      "k = 2, review 32, coalition [455]: local jShapley = 0.0005089046690161998\n",
      "k = 2, review 32, coalition [848]: local jShapley = -0.001002675619310101\n",
      "k = 2, review 33, coalition [209, 978]: local jShapley = -3.085350819121561e-06\n",
      "k = 2, review 33, coalition [101, 434]: local jShapley = -3.113246135073021e-05\n",
      "k = 2, review 33, coalition [3, 174]: local jShapley = 6.000283136429609e-07\n",
      "k = 2, review 33, coalition [269, 1003]: local jShapley = 3.334276432366108e-05\n",
      "k = 2, review 33, coalition [455, 848]: local jShapley = 2.146634482471084e-05\n",
      "k = 2, review 33, coalition [209]: local jShapley = 8.303281902289584e-05\n",
      "k = 2, review 33, coalition [978]: local jShapley = -0.0002853753818529226\n",
      "k = 2, review 33, coalition [101]: local jShapley = -0.0004518151363065898\n",
      "k = 2, review 33, coalition [434]: local jShapley = -1.869942378359131e-05\n",
      "k = 2, review 33, coalition [3]: local jShapley = 6.869938020124671e-05\n",
      "k = 2, review 33, coalition [174]: local jShapley = 3.3256082978775692e-06\n",
      "k = 2, review 33, coalition [269]: local jShapley = 0.00015761339188543862\n",
      "k = 2, review 33, coalition [1003]: local jShapley = 2.7583127339607124e-05\n",
      "k = 2, review 33, coalition [455]: local jShapley = 0.0005775674179631019\n",
      "k = 2, review 33, coalition [848]: local jShapley = -0.0006764664741850183\n",
      "k = 2, review 34, coalition [209, 978]: local jShapley = -8.519997095043592e-06\n",
      "k = 2, review 34, coalition [101, 434]: local jShapley = -1.832459284963083e-07\n",
      "k = 2, review 34, coalition [3, 174]: local jShapley = -1.6352671320786013e-06\n",
      "k = 2, review 34, coalition [269, 1003]: local jShapley = -5.5634692296473494e-05\n",
      "k = 2, review 34, coalition [455, 848]: local jShapley = -2.01779238092689e-06\n",
      "k = 2, review 34, coalition [209]: local jShapley = 9.267481335622567e-05\n",
      "k = 2, review 34, coalition [978]: local jShapley = -8.187661040933937e-09\n",
      "k = 2, review 34, coalition [101]: local jShapley = -0.0009824570042715297\n",
      "k = 2, review 34, coalition [434]: local jShapley = -0.00010466555766253757\n",
      "k = 2, review 34, coalition [3]: local jShapley = -0.0001231405883607258\n",
      "k = 2, review 34, coalition [174]: local jShapley = -8.755680025648728e-07\n",
      "k = 2, review 34, coalition [269]: local jShapley = -0.00023818915566384868\n",
      "k = 2, review 34, coalition [1003]: local jShapley = -7.682328836063796e-08\n",
      "k = 2, review 34, coalition [455]: local jShapley = 0.00018965196540302062\n",
      "k = 2, review 34, coalition [848]: local jShapley = -0.0008347717873945177\n",
      "k = 2, review 35, coalition [209, 978]: local jShapley = 1.032205933026933e-05\n",
      "k = 2, review 35, coalition [101, 434]: local jShapley = -4.131261518818639e-05\n",
      "k = 2, review 35, coalition [3, 174]: local jShapley = -1.0297985181058747e-06\n",
      "k = 2, review 35, coalition [269, 1003]: local jShapley = -8.748521374503883e-06\n",
      "k = 2, review 35, coalition [455, 848]: local jShapley = 5.598664035754418e-05\n",
      "k = 2, review 35, coalition [209]: local jShapley = 8.72698243361551e-05\n",
      "k = 2, review 35, coalition [978]: local jShapley = -0.00033312944578942267\n",
      "k = 2, review 35, coalition [101]: local jShapley = -0.00016533181892499797\n",
      "k = 2, review 35, coalition [434]: local jShapley = -6.1869676859206e-05\n",
      "k = 2, review 35, coalition [3]: local jShapley = -6.547681063248454e-05\n",
      "k = 2, review 35, coalition [174]: local jShapley = -3.5212997933660784e-05\n",
      "k = 2, review 35, coalition [269]: local jShapley = -0.0002327972930209352\n",
      "k = 2, review 35, coalition [1003]: local jShapley = -1.0042251554841317e-05\n",
      "k = 2, review 35, coalition [455]: local jShapley = 0.0004931822276142105\n",
      "k = 2, review 35, coalition [848]: local jShapley = -0.0013306692054573601\n",
      "k = 2, review 36, coalition [209, 978]: local jShapley = 9.573345988421596e-06\n",
      "k = 2, review 36, coalition [101, 434]: local jShapley = -1.7593256836358785e-07\n",
      "k = 2, review 36, coalition [3, 174]: local jShapley = 2.2508515479708252e-07\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "k = 2, review 36, coalition [269, 1003]: local jShapley = -6.27293241006139e-06\n",
      "k = 2, review 36, coalition [455, 848]: local jShapley = -1.2466576056838035e-05\n",
      "k = 2, review 36, coalition [209]: local jShapley = 0.0001290299686830628\n",
      "k = 2, review 36, coalition [978]: local jShapley = -0.00038520092309450224\n",
      "k = 2, review 36, coalition [101]: local jShapley = -4.347604569091726e-05\n",
      "k = 2, review 36, coalition [434]: local jShapley = -1.5017449671110488e-05\n",
      "k = 2, review 36, coalition [3]: local jShapley = 3.953540065818716e-05\n",
      "k = 2, review 36, coalition [174]: local jShapley = 3.49030608480071e-05\n",
      "k = 2, review 36, coalition [269]: local jShapley = -0.0001981307788176888\n",
      "k = 2, review 36, coalition [1003]: local jShapley = -5.312815466410722e-05\n",
      "k = 2, review 36, coalition [455]: local jShapley = 0.00037882537907582586\n",
      "k = 2, review 36, coalition [848]: local jShapley = -0.0006886935732377854\n",
      "k = 2, review 37, coalition [209, 978]: local jShapley = -4.548745017420267e-06\n",
      "k = 2, review 37, coalition [101, 434]: local jShapley = 2.365752550856139e-05\n",
      "k = 2, review 37, coalition [3, 174]: local jShapley = 1.4225358952476705e-06\n",
      "k = 2, review 37, coalition [269, 1003]: local jShapley = -2.729886378776299e-05\n",
      "k = 2, review 37, coalition [455, 848]: local jShapley = -1.1677477591713592e-05\n",
      "k = 2, review 37, coalition [209]: local jShapley = 1.1681574813880808e-05\n",
      "k = 2, review 37, coalition [978]: local jShapley = -7.974884199632666e-05\n",
      "k = 2, review 37, coalition [101]: local jShapley = 0.0004915795782535835\n",
      "k = 2, review 37, coalition [434]: local jShapley = -1.326656953038827e-06\n",
      "k = 2, review 37, coalition [3]: local jShapley = -6.421761659489758e-05\n",
      "k = 2, review 37, coalition [174]: local jShapley = 6.173055991600187e-06\n",
      "k = 2, review 37, coalition [269]: local jShapley = -7.4997269372238e-06\n",
      "k = 2, review 37, coalition [1003]: local jShapley = -3.371653230215843e-05\n",
      "k = 2, review 37, coalition [455]: local jShapley = 0.00013745888853826277\n",
      "k = 2, review 37, coalition [848]: local jShapley = 0.0\n",
      "k = 2, review 38, coalition [209, 978]: local jShapley = 6.968183381300277e-06\n",
      "k = 2, review 38, coalition [101, 434]: local jShapley = 4.1514019274866596e-10\n",
      "k = 2, review 38, coalition [3, 174]: local jShapley = -1.0734453274256899e-07\n",
      "k = 2, review 38, coalition [269, 1003]: local jShapley = -3.9095645053671355e-06\n",
      "k = 2, review 38, coalition [455, 848]: local jShapley = -9.109832557335565e-06\n",
      "k = 2, review 38, coalition [209]: local jShapley = 8.92741621598232e-05\n",
      "k = 2, review 38, coalition [978]: local jShapley = -0.00026875161543134387\n",
      "k = 2, review 38, coalition [101]: local jShapley = 3.677052987042679e-05\n",
      "k = 2, review 38, coalition [434]: local jShapley = 2.3390271254959712e-06\n",
      "k = 2, review 38, coalition [3]: local jShapley = -6.196971984254991e-05\n",
      "k = 2, review 38, coalition [174]: local jShapley = 5.116094116681908e-06\n",
      "k = 2, review 38, coalition [269]: local jShapley = -0.00033140088448774886\n",
      "k = 2, review 38, coalition [1003]: local jShapley = -7.518055357616473e-05\n",
      "k = 2, review 38, coalition [455]: local jShapley = 0.00017157064606191795\n",
      "k = 2, review 38, coalition [848]: local jShapley = -0.0009912154365053433\n",
      "k = 2, review 39, coalition [209, 978]: local jShapley = 9.381183503500534e-06\n",
      "k = 2, review 39, coalition [101, 434]: local jShapley = -2.7701889649048777e-05\n",
      "k = 2, review 39, coalition [3, 174]: local jShapley = -7.468438679380341e-06\n",
      "k = 2, review 39, coalition [269, 1003]: local jShapley = -1.8769795258143344e-05\n",
      "k = 2, review 39, coalition [455, 848]: local jShapley = -3.6591836532380852e-06\n",
      "k = 2, review 39, coalition [209]: local jShapley = 2.6818769027714955e-05\n",
      "k = 2, review 39, coalition [978]: local jShapley = -0.00010588454796397658\n",
      "k = 2, review 39, coalition [101]: local jShapley = -0.0004516338137297875\n",
      "k = 2, review 39, coalition [434]: local jShapley = -5.303813303672487e-06\n",
      "k = 2, review 39, coalition [3]: local jShapley = -5.351246833472455e-06\n",
      "k = 2, review 39, coalition [174]: local jShapley = 5.622449779182166e-05\n",
      "k = 2, review 39, coalition [269]: local jShapley = -2.422728902012352e-05\n",
      "k = 2, review 39, coalition [1003]: local jShapley = -3.78458426871361e-05\n",
      "k = 2, review 39, coalition [455]: local jShapley = 6.903904020224171e-05\n",
      "k = 2, review 39, coalition [848]: local jShapley = -0.0003256488660386956\n",
      "k = 2, review 40, coalition [209, 978]: local jShapley = -4.530157346773957e-07\n",
      "k = 2, review 40, coalition [101, 434]: local jShapley = -1.0154106605130612e-07\n",
      "k = 2, review 40, coalition [3, 174]: local jShapley = 1.1325947805364462e-05\n",
      "k = 2, review 40, coalition [269, 1003]: local jShapley = -2.531393406142849e-05\n",
      "k = 2, review 40, coalition [455, 848]: local jShapley = -2.330252413536511e-07\n",
      "k = 2, review 40, coalition [209]: local jShapley = 6.883955125250478e-05\n",
      "k = 2, review 40, coalition [978]: local jShapley = -1.3258040716803965e-06\n",
      "k = 2, review 40, coalition [101]: local jShapley = -0.0003199760109712302\n",
      "k = 2, review 40, coalition [434]: local jShapley = -1.973825993070225e-06\n",
      "k = 2, review 40, coalition [3]: local jShapley = 3.656345027659983e-05\n",
      "k = 2, review 40, coalition [174]: local jShapley = 5.73570815917496e-05\n",
      "k = 2, review 40, coalition [269]: local jShapley = -0.0001508169509163767\n",
      "k = 2, review 40, coalition [1003]: local jShapley = -1.6359650386906712e-05\n",
      "k = 2, review 40, coalition [455]: local jShapley = 0.0012250931969446978\n",
      "k = 2, review 40, coalition [848]: local jShapley = -9.528429182573424e-05\n",
      "k = 2, review 41, coalition [209, 978]: local jShapley = -2.0154587177945415e-10\n",
      "k = 2, review 41, coalition [101, 434]: local jShapley = -4.373704429171546e-05\n",
      "k = 2, review 41, coalition [3, 174]: local jShapley = -5.827383369495969e-06\n",
      "k = 2, review 41, coalition [269, 1003]: local jShapley = -6.343813330410883e-06\n",
      "k = 2, review 41, coalition [455, 848]: local jShapley = -3.412801720116453e-05\n",
      "k = 2, review 41, coalition [209]: local jShapley = 0.00010737017238232484\n",
      "k = 2, review 41, coalition [978]: local jShapley = -1.7888674764267165e-05\n",
      "k = 2, review 41, coalition [101]: local jShapley = -6.514964534339055e-05\n",
      "k = 2, review 41, coalition [434]: local jShapley = -2.7652801708124257e-05\n",
      "k = 2, review 41, coalition [3]: local jShapley = -6.463697302832941e-05\n",
      "k = 2, review 41, coalition [174]: local jShapley = 2.4954711530728995e-05\n",
      "k = 2, review 41, coalition [269]: local jShapley = -7.050998069383878e-05\n",
      "k = 2, review 41, coalition [1003]: local jShapley = -7.339896970653903e-05\n",
      "k = 2, review 41, coalition [455]: local jShapley = 0.0002286380465002766\n",
      "k = 2, review 41, coalition [848]: local jShapley = -0.0002990820943844678\n",
      "k = 2, review 42, coalition [209, 978]: local jShapley = -1.9343897589376536e-06\n",
      "k = 2, review 42, coalition [101, 434]: local jShapley = -4.1692923973967656e-05\n",
      "k = 2, review 42, coalition [3, 174]: local jShapley = -5.557087069789842e-06\n",
      "k = 2, review 42, coalition [269, 1003]: local jShapley = -4.4783209201856176e-06\n",
      "k = 2, review 42, coalition [455, 848]: local jShapley = -2.430238244818528e-07\n",
      "k = 2, review 42, coalition [209]: local jShapley = 1.3243882886254016e-05\n",
      "k = 2, review 42, coalition [978]: local jShapley = -0.0003280389807575616\n",
      "k = 2, review 42, coalition [101]: local jShapley = -0.0006513180519757557\n",
      "k = 2, review 42, coalition [434]: local jShapley = -1.9114403869552706e-07\n",
      "k = 2, review 42, coalition [3]: local jShapley = -5.428948056581427e-05\n",
      "k = 2, review 42, coalition [174]: local jShapley = 2.4673857699397794e-07\n",
      "k = 2, review 42, coalition [269]: local jShapley = -7.255794339899059e-05\n",
      "k = 2, review 42, coalition [1003]: local jShapley = -4.7491845562850556e-05\n",
      "k = 2, review 42, coalition [455]: local jShapley = 0.001338886248261092\n",
      "k = 2, review 42, coalition [848]: local jShapley = -0.0004549559360833355\n",
      "k = 2, review 43, coalition [209, 978]: local jShapley = -2.4299854615501586e-06\n",
      "k = 2, review 43, coalition [101, 434]: local jShapley = 2.592294224038933e-05\n",
      "k = 2, review 43, coalition [3, 174]: local jShapley = 2.4072489801820392e-09\n",
      "k = 2, review 43, coalition [269, 1003]: local jShapley = -8.965161613722664e-06\n",
      "k = 2, review 43, coalition [455, 848]: local jShapley = 5.571333144732185e-05\n",
      "k = 2, review 43, coalition [209]: local jShapley = 1.2700341596526184e-05\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "k = 2, review 43, coalition [978]: local jShapley = -2.9993790460744615e-05\n",
      "k = 2, review 43, coalition [101]: local jShapley = 0.0002525566777567841\n",
      "k = 2, review 43, coalition [434]: local jShapley = -2.101329090901358e-06\n",
      "k = 2, review 43, coalition [3]: local jShapley = 8.4222887026382e-06\n",
      "k = 2, review 43, coalition [174]: local jShapley = -1.7458484722400565e-06\n",
      "k = 2, review 43, coalition [269]: local jShapley = -2.0782842365965625e-05\n",
      "k = 2, review 43, coalition [1003]: local jShapley = -1.7077477982229842e-05\n",
      "k = 2, review 43, coalition [455]: local jShapley = 6.69033399925956e-05\n",
      "k = 2, review 43, coalition [848]: local jShapley = -8.530869028380003e-05\n",
      "k = 2, review 44, coalition [209, 978]: local jShapley = -2.2702127919131475e-06\n",
      "k = 2, review 44, coalition [101, 434]: local jShapley = -5.432565540801674e-06\n",
      "k = 2, review 44, coalition [3, 174]: local jShapley = 4.217249273798079e-06\n",
      "k = 2, review 44, coalition [269, 1003]: local jShapley = -2.6999722262081903e-05\n",
      "k = 2, review 44, coalition [455, 848]: local jShapley = -6.63872481876963e-05\n",
      "k = 2, review 44, coalition [209]: local jShapley = 4.089438181471051e-05\n",
      "k = 2, review 44, coalition [978]: local jShapley = -0.000151883031292381\n",
      "k = 2, review 44, coalition [101]: local jShapley = -0.0004896953074684028\n",
      "k = 2, review 44, coalition [434]: local jShapley = -5.19934386607832e-05\n",
      "k = 2, review 44, coalition [3]: local jShapley = 3.2484118739226184e-05\n",
      "k = 2, review 44, coalition [174]: local jShapley = 1.2853519088500322e-05\n",
      "k = 2, review 44, coalition [269]: local jShapley = -0.0002568544322100518\n",
      "k = 2, review 44, coalition [1003]: local jShapley = -7.061032018671746e-05\n",
      "k = 2, review 44, coalition [455]: local jShapley = 0.0004464916640876056\n",
      "k = 2, review 44, coalition [848]: local jShapley = -0.00041483142874062335\n",
      "k = 2, review 45, coalition [209, 978]: local jShapley = 2.0762079351597273e-05\n",
      "k = 2, review 45, coalition [101, 434]: local jShapley = -1.0665057001414349e-07\n",
      "k = 2, review 45, coalition [3, 174]: local jShapley = -9.520079704615019e-07\n",
      "k = 2, review 45, coalition [269, 1003]: local jShapley = -8.325455847659459e-06\n",
      "k = 2, review 45, coalition [455, 848]: local jShapley = 5.72224284301911e-05\n",
      "k = 2, review 45, coalition [209]: local jShapley = 4.752128596124189e-05\n",
      "k = 2, review 45, coalition [978]: local jShapley = 0.0\n",
      "k = 2, review 45, coalition [101]: local jShapley = -3.056999310861897e-05\n",
      "k = 2, review 45, coalition [434]: local jShapley = -1.5908028385583737e-05\n",
      "k = 2, review 45, coalition [3]: local jShapley = -1.4123715295611042e-06\n",
      "k = 2, review 45, coalition [174]: local jShapley = 3.243315907805995e-06\n",
      "k = 2, review 45, coalition [269]: local jShapley = -5.9555852377851656e-06\n",
      "k = 2, review 45, coalition [1003]: local jShapley = -2.6702947739240076e-05\n",
      "k = 2, review 45, coalition [455]: local jShapley = 4.0485339915207184e-05\n",
      "k = 2, review 45, coalition [848]: local jShapley = -1.7961681408548826e-07\n",
      "k = 2, review 46, coalition [209, 978]: local jShapley = 3.9913467449480506e-07\n",
      "k = 2, review 46, coalition [101, 434]: local jShapley = -1.7893543331039627e-05\n",
      "k = 2, review 46, coalition [3, 174]: local jShapley = 1.259098640305326e-07\n",
      "k = 2, review 46, coalition [269, 1003]: local jShapley = -1.7202864975886417e-05\n",
      "k = 2, review 46, coalition [455, 848]: local jShapley = 1.0724134165954645e-05\n",
      "k = 2, review 46, coalition [209]: local jShapley = -6.104131583983027e-05\n",
      "k = 2, review 46, coalition [978]: local jShapley = 0.0001587981080584006\n",
      "k = 2, review 46, coalition [101]: local jShapley = -0.00034862838963143516\n",
      "k = 2, review 46, coalition [434]: local jShapley = -2.3252861407099558e-05\n",
      "k = 2, review 46, coalition [3]: local jShapley = 5.2086477355971004e-05\n",
      "k = 2, review 46, coalition [174]: local jShapley = -1.95219425656618e-05\n",
      "k = 2, review 46, coalition [269]: local jShapley = -0.0004930212675798407\n",
      "k = 2, review 46, coalition [1003]: local jShapley = -4.086391262818058e-05\n",
      "k = 2, review 46, coalition [455]: local jShapley = 1.8509346859728798e-09\n",
      "k = 2, review 46, coalition [848]: local jShapley = -0.00039027622816021723\n",
      "k = 2, review 47, coalition [209, 978]: local jShapley = -9.79056370189022e-06\n",
      "k = 2, review 47, coalition [101, 434]: local jShapley = -3.99671125019802e-05\n",
      "k = 2, review 47, coalition [3, 174]: local jShapley = -9.379863351639465e-06\n",
      "k = 2, review 47, coalition [269, 1003]: local jShapley = -4.242718245382345e-05\n",
      "k = 2, review 47, coalition [455, 848]: local jShapley = 2.9204964933865717e-05\n",
      "k = 2, review 47, coalition [209]: local jShapley = 1.9526072377114573e-06\n",
      "k = 2, review 47, coalition [978]: local jShapley = -8.297682736171487e-07\n",
      "k = 2, review 47, coalition [101]: local jShapley = -0.0002787234189859788\n",
      "k = 2, review 47, coalition [434]: local jShapley = -2.2174515531059315e-06\n",
      "k = 2, review 47, coalition [3]: local jShapley = -7.074951508860826e-05\n",
      "k = 2, review 47, coalition [174]: local jShapley = 3.2370920060928476e-05\n",
      "k = 2, review 47, coalition [269]: local jShapley = -0.000560238361302169\n",
      "k = 2, review 47, coalition [1003]: local jShapley = -7.257593919565347e-05\n",
      "k = 2, review 47, coalition [455]: local jShapley = 2.342865091608909e-07\n",
      "k = 2, review 47, coalition [848]: local jShapley = -0.0005344708751588896\n",
      "k = 2, review 48, coalition [209, 978]: local jShapley = 6.235837986552896e-06\n",
      "k = 2, review 48, coalition [101, 434]: local jShapley = -2.5978851605122988e-06\n",
      "k = 2, review 48, coalition [3, 174]: local jShapley = 3.3895363667373997e-06\n",
      "k = 2, review 48, coalition [269, 1003]: local jShapley = -5.3181525632006485e-05\n",
      "k = 2, review 48, coalition [455, 848]: local jShapley = -1.6045020992289216e-05\n",
      "k = 2, review 48, coalition [209]: local jShapley = 0.0001571234328670542\n",
      "k = 2, review 48, coalition [978]: local jShapley = -0.00014507759242498764\n",
      "k = 2, review 48, coalition [101]: local jShapley = -0.0006046090448897747\n",
      "k = 2, review 48, coalition [434]: local jShapley = -9.9387330799618e-05\n",
      "k = 2, review 48, coalition [3]: local jShapley = 2.478038258106578e-05\n",
      "k = 2, review 48, coalition [174]: local jShapley = 2.093499640030965e-05\n",
      "k = 2, review 48, coalition [269]: local jShapley = -0.00041177163157911763\n",
      "k = 2, review 48, coalition [1003]: local jShapley = -5.7203776167571696e-05\n",
      "k = 2, review 48, coalition [455]: local jShapley = 0.00025429826605078283\n",
      "k = 2, review 48, coalition [848]: local jShapley = 0.0\n",
      "k = 2, review 49, coalition [209, 978]: local jShapley = -1.3452273712781986e-09\n",
      "k = 2, review 49, coalition [101, 434]: local jShapley = -2.3953543381623166e-06\n",
      "k = 2, review 49, coalition [3, 174]: local jShapley = -3.5737130238666347e-06\n",
      "k = 2, review 49, coalition [269, 1003]: local jShapley = -9.852880116964637e-06\n",
      "k = 2, review 49, coalition [455, 848]: local jShapley = -4.136627267760906e-05\n",
      "k = 2, review 49, coalition [209]: local jShapley = 7.953722347452032e-06\n",
      "k = 2, review 49, coalition [978]: local jShapley = -0.0001905190285792894\n",
      "k = 2, review 49, coalition [101]: local jShapley = -0.00025731367683851574\n",
      "k = 2, review 49, coalition [434]: local jShapley = 0.0\n",
      "k = 2, review 49, coalition [3]: local jShapley = -0.0001619095898302272\n",
      "k = 2, review 49, coalition [174]: local jShapley = 3.625999508927021e-05\n",
      "k = 2, review 49, coalition [269]: local jShapley = -0.00013100263095949824\n",
      "k = 2, review 49, coalition [1003]: local jShapley = -9.300637098431557e-05\n",
      "k = 2, review 49, coalition [455]: local jShapley = 0.0004282185583815343\n",
      "k = 2, review 49, coalition [848]: local jShapley = -0.0004272615348787308\n",
      "k = 2, review 50, coalition [209, 978]: local jShapley = -1.804978235885592e-05\n",
      "k = 2, review 50, coalition [101, 434]: local jShapley = -1.7904080968495316e-05\n",
      "k = 2, review 50, coalition [3, 174]: local jShapley = 8.603673692333952e-07\n",
      "k = 2, review 50, coalition [269, 1003]: local jShapley = -1.8892184398389437e-08\n",
      "k = 2, review 50, coalition [455, 848]: local jShapley = 0.00010395109145282363\n",
      "k = 2, review 50, coalition [209]: local jShapley = 1.3841877985463399e-05\n",
      "k = 2, review 50, coalition [978]: local jShapley = -3.3938426165924604e-05\n",
      "k = 2, review 50, coalition [101]: local jShapley = -7.00752617349382e-05\n",
      "k = 2, review 50, coalition [434]: local jShapley = -1.1140458905516011e-05\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "k = 2, review 50, coalition [3]: local jShapley = -3.009791661359202e-06\n",
      "k = 2, review 50, coalition [174]: local jShapley = 8.911377515511606e-07\n",
      "k = 2, review 50, coalition [269]: local jShapley = -3.429255771062548e-05\n",
      "k = 2, review 50, coalition [1003]: local jShapley = -3.571717341818856e-05\n",
      "k = 2, review 50, coalition [455]: local jShapley = 0.0\n",
      "k = 2, review 50, coalition [848]: local jShapley = -0.0004687227188646594\n",
      "k = 2, review 51, coalition [209, 978]: local jShapley = 3.17278742472091e-07\n",
      "k = 2, review 51, coalition [101, 434]: local jShapley = -6.674329945114995e-05\n",
      "k = 2, review 51, coalition [3, 174]: local jShapley = -4.412345777792491e-06\n",
      "k = 2, review 51, coalition [269, 1003]: local jShapley = -3.8818512384543675e-05\n",
      "k = 2, review 51, coalition [455, 848]: local jShapley = -5.91409167663645e-05\n",
      "k = 2, review 51, coalition [209]: local jShapley = 8.211139777417117e-05\n",
      "k = 2, review 51, coalition [978]: local jShapley = 0.0\n",
      "k = 2, review 51, coalition [101]: local jShapley = -0.00045847674739390087\n",
      "k = 2, review 51, coalition [434]: local jShapley = -3.180664575842805e-05\n",
      "k = 2, review 51, coalition [3]: local jShapley = -1.6711237400648509e-06\n",
      "k = 2, review 51, coalition [174]: local jShapley = 1.0235844962188086e-05\n",
      "k = 2, review 51, coalition [269]: local jShapley = -4.211297869963618e-05\n",
      "k = 2, review 51, coalition [1003]: local jShapley = -3.444057527038112e-06\n",
      "k = 2, review 51, coalition [455]: local jShapley = 0.00011216411188789354\n",
      "k = 2, review 51, coalition [848]: local jShapley = -0.00011958931831642446\n",
      "k = 2, review 52, coalition [209, 978]: local jShapley = -3.4054430903907595e-06\n",
      "k = 2, review 52, coalition [101, 434]: local jShapley = -3.026538450210826e-05\n",
      "k = 2, review 52, coalition [3, 174]: local jShapley = -3.412534564380355e-06\n",
      "k = 2, review 52, coalition [269, 1003]: local jShapley = -2.407926295525843e-06\n",
      "k = 2, review 52, coalition [455, 848]: local jShapley = -3.413542258934162e-05\n",
      "k = 2, review 52, coalition [209]: local jShapley = 5.705893559087622e-05\n",
      "k = 2, review 52, coalition [978]: local jShapley = -0.00015388174809484616\n",
      "k = 2, review 52, coalition [101]: local jShapley = -0.0008717711559944284\n",
      "k = 2, review 52, coalition [434]: local jShapley = -2.0156763482775666e-05\n",
      "k = 2, review 52, coalition [3]: local jShapley = -3.328288477546438e-05\n",
      "k = 2, review 52, coalition [174]: local jShapley = 2.8173443133378224e-06\n",
      "k = 2, review 52, coalition [269]: local jShapley = -0.0003057183773108201\n",
      "k = 2, review 52, coalition [1003]: local jShapley = -2.545073133726677e-05\n",
      "k = 2, review 52, coalition [455]: local jShapley = 0.00021615668619040884\n",
      "k = 2, review 52, coalition [848]: local jShapley = -0.00032929131976123014\n",
      "k = 2, review 53, coalition [209, 978]: local jShapley = -1.2905898612559163e-08\n",
      "k = 2, review 53, coalition [101, 434]: local jShapley = -1.5558743059306436e-05\n",
      "k = 2, review 53, coalition [3, 174]: local jShapley = -1.9847781910383878e-06\n",
      "k = 2, review 53, coalition [269, 1003]: local jShapley = -3.477483417910673e-06\n",
      "k = 2, review 53, coalition [455, 848]: local jShapley = -3.4896014440068315e-05\n",
      "k = 2, review 53, coalition [209]: local jShapley = 1.0034329086597772e-06\n",
      "k = 2, review 53, coalition [978]: local jShapley = -1.7548766894627377e-06\n",
      "k = 2, review 53, coalition [101]: local jShapley = -0.0002994007612605337\n",
      "k = 2, review 53, coalition [434]: local jShapley = -9.03449227222819e-06\n",
      "k = 2, review 53, coalition [3]: local jShapley = -1.593457231892421e-07\n",
      "k = 2, review 53, coalition [174]: local jShapley = -4.4811519304998855e-07\n",
      "k = 2, review 53, coalition [269]: local jShapley = -7.132436911783461e-06\n",
      "k = 2, review 53, coalition [1003]: local jShapley = -1.5002033174243293e-06\n",
      "k = 2, review 53, coalition [455]: local jShapley = 0.00042594230865452724\n",
      "k = 2, review 53, coalition [848]: local jShapley = -0.00044883722974807836\n",
      "k = 2, review 54, coalition [209, 978]: local jShapley = 6.878241951266221e-06\n",
      "k = 2, review 54, coalition [101, 434]: local jShapley = -5.600434484316714e-05\n",
      "k = 2, review 54, coalition [3, 174]: local jShapley = 3.0011836910080307e-06\n",
      "k = 2, review 54, coalition [269, 1003]: local jShapley = -2.02985370133801e-06\n",
      "k = 2, review 54, coalition [455, 848]: local jShapley = -7.766918033116757e-07\n",
      "k = 2, review 54, coalition [209]: local jShapley = 3.8101280653986074e-05\n",
      "k = 2, review 54, coalition [978]: local jShapley = -0.00011054984201875794\n",
      "k = 2, review 54, coalition [101]: local jShapley = -0.0002843091948667485\n",
      "k = 2, review 54, coalition [434]: local jShapley = -2.125367685251437e-05\n",
      "k = 2, review 54, coalition [3]: local jShapley = 0.00011356183518012358\n",
      "k = 2, review 54, coalition [174]: local jShapley = -1.27063650711201e-05\n",
      "k = 2, review 54, coalition [269]: local jShapley = -0.00028214388841430675\n",
      "k = 2, review 54, coalition [1003]: local jShapley = -3.520293393363131e-05\n",
      "k = 2, review 54, coalition [455]: local jShapley = 0.0003541022674779787\n",
      "k = 2, review 54, coalition [848]: local jShapley = -0.0002212783626821071\n",
      "k = 2, review 55, coalition [209, 978]: local jShapley = -6.007325230764576e-06\n",
      "k = 2, review 55, coalition [101, 434]: local jShapley = -7.419293441734258e-05\n",
      "k = 2, review 55, coalition [3, 174]: local jShapley = -5.575073585760639e-06\n",
      "k = 2, review 55, coalition [269, 1003]: local jShapley = -9.407564415271707e-06\n",
      "k = 2, review 55, coalition [455, 848]: local jShapley = -4.420720776948206e-05\n",
      "k = 2, review 55, coalition [209]: local jShapley = 9.174253707224467e-06\n",
      "k = 2, review 55, coalition [978]: local jShapley = -5.045662108001009e-05\n",
      "k = 2, review 55, coalition [101]: local jShapley = -0.0002708245329119925\n",
      "k = 2, review 55, coalition [434]: local jShapley = -1.5088681256064916e-05\n",
      "k = 2, review 55, coalition [3]: local jShapley = -3.19518807927518e-06\n",
      "k = 2, review 55, coalition [174]: local jShapley = 5.02562472658638e-06\n",
      "k = 2, review 55, coalition [269]: local jShapley = -0.0003091138525834786\n",
      "k = 2, review 55, coalition [1003]: local jShapley = -1.2998422298670562e-05\n",
      "k = 2, review 55, coalition [455]: local jShapley = 1.346102648011045e-06\n",
      "k = 2, review 55, coalition [848]: local jShapley = -0.0006173150368253006\n",
      "k = 2, review 56, coalition [209, 978]: local jShapley = -1.961199904442426e-08\n",
      "k = 2, review 56, coalition [101, 434]: local jShapley = -4.782396587198945e-05\n",
      "k = 2, review 56, coalition [3, 174]: local jShapley = -5.702014668624895e-06\n",
      "k = 2, review 56, coalition [269, 1003]: local jShapley = -5.0912863914636995e-05\n",
      "k = 2, review 56, coalition [455, 848]: local jShapley = -5.563606702444501e-07\n",
      "k = 2, review 56, coalition [209]: local jShapley = 0.00015940777124897552\n",
      "k = 2, review 56, coalition [978]: local jShapley = -0.00017112881087418298\n",
      "k = 2, review 56, coalition [101]: local jShapley = -0.000512389712823019\n",
      "k = 2, review 56, coalition [434]: local jShapley = -3.275425348018568e-05\n",
      "k = 2, review 56, coalition [3]: local jShapley = -0.00013304822345196765\n",
      "k = 2, review 56, coalition [174]: local jShapley = 5.517374795823514e-06\n",
      "k = 2, review 56, coalition [269]: local jShapley = -0.0003102318264538997\n",
      "k = 2, review 56, coalition [1003]: local jShapley = 0.0\n",
      "k = 2, review 56, coalition [455]: local jShapley = 0.0001525300697349544\n",
      "k = 2, review 56, coalition [848]: local jShapley = -0.0006129296213270196\n",
      "k = 2, review 57, coalition [209, 978]: local jShapley = -7.252781572006309e-07\n",
      "k = 2, review 57, coalition [101, 434]: local jShapley = -3.6652166704115584e-07\n",
      "k = 2, review 57, coalition [3, 174]: local jShapley = 5.143605590063393e-06\n",
      "k = 2, review 57, coalition [269, 1003]: local jShapley = -2.593554183728008e-05\n",
      "k = 2, review 57, coalition [455, 848]: local jShapley = -3.7789706792109563e-06\n",
      "k = 2, review 57, coalition [209]: local jShapley = 0.0001883327191894103\n",
      "k = 2, review 57, coalition [978]: local jShapley = -0.0003195964787667285\n",
      "k = 2, review 57, coalition [101]: local jShapley = -0.0005990614354497949\n",
      "k = 2, review 57, coalition [434]: local jShapley = -7.481057364287754e-05\n",
      "k = 2, review 57, coalition [3]: local jShapley = 0.00010198561253604293\n",
      "k = 2, review 57, coalition [174]: local jShapley = 9.463315688738614e-06\n",
      "k = 2, review 57, coalition [269]: local jShapley = -0.000280704754499463\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "k = 2, review 57, coalition [1003]: local jShapley = -4.1672666767169164e-05\n",
      "k = 2, review 57, coalition [455]: local jShapley = 0.0002450305754635508\n",
      "k = 2, review 57, coalition [848]: local jShapley = -1.6825558150983398e-05\n",
      "k = 2, review 58, coalition [209, 978]: local jShapley = -3.2858004560276924e-06\n",
      "k = 2, review 58, coalition [101, 434]: local jShapley = -2.138117069167675e-05\n",
      "k = 2, review 58, coalition [3, 174]: local jShapley = -8.364183590338522e-06\n",
      "k = 2, review 58, coalition [269, 1003]: local jShapley = -2.718315109429974e-06\n",
      "k = 2, review 58, coalition [455, 848]: local jShapley = 5.415144607057498e-05\n",
      "k = 2, review 58, coalition [209]: local jShapley = 0.00010788761647462576\n",
      "k = 2, review 58, coalition [978]: local jShapley = -0.00019533622775865506\n",
      "k = 2, review 58, coalition [101]: local jShapley = -0.00018594958610403936\n",
      "k = 2, review 58, coalition [434]: local jShapley = -4.571981396443927e-05\n",
      "k = 2, review 58, coalition [3]: local jShapley = -7.064100725778193e-05\n",
      "k = 2, review 58, coalition [174]: local jShapley = -5.042952543904089e-10\n",
      "k = 2, review 58, coalition [269]: local jShapley = -5.783320261009349e-05\n",
      "k = 2, review 58, coalition [1003]: local jShapley = -2.8756771338476845e-05\n",
      "k = 2, review 58, coalition [455]: local jShapley = 2.1189552168004492e-05\n",
      "k = 2, review 58, coalition [848]: local jShapley = -0.0002811577129592115\n",
      "k = 2, review 59, coalition [209, 978]: local jShapley = 1.4910822038325376e-07\n",
      "k = 2, review 59, coalition [101, 434]: local jShapley = -2.9625800794778575e-06\n",
      "k = 2, review 59, coalition [3, 174]: local jShapley = -7.811640943091706e-07\n",
      "k = 2, review 59, coalition [269, 1003]: local jShapley = -8.107054053848408e-06\n",
      "k = 2, review 59, coalition [455, 848]: local jShapley = 3.58557611554897e-05\n",
      "k = 2, review 59, coalition [209]: local jShapley = 2.098636118012113e-05\n",
      "k = 2, review 59, coalition [978]: local jShapley = -0.0007691819273379733\n",
      "k = 2, review 59, coalition [101]: local jShapley = -0.00042158846659092576\n",
      "k = 2, review 59, coalition [434]: local jShapley = -2.7625829335163888e-05\n",
      "k = 2, review 59, coalition [3]: local jShapley = -0.00011589165118694851\n",
      "k = 2, review 59, coalition [174]: local jShapley = 0.0\n",
      "k = 2, review 59, coalition [269]: local jShapley = -0.0003804496169958381\n",
      "k = 2, review 59, coalition [1003]: local jShapley = -2.5874330688878417e-05\n",
      "k = 2, review 59, coalition [455]: local jShapley = 0.0009200579189663873\n",
      "k = 2, review 59, coalition [848]: local jShapley = 0.0\n",
      "k = 2, review 60, coalition [209, 978]: local jShapley = 1.6869825140165508e-06\n",
      "k = 2, review 60, coalition [101, 434]: local jShapley = 0.0\n",
      "k = 2, review 60, coalition [3, 174]: local jShapley = -1.2465948304807381e-05\n",
      "k = 2, review 60, coalition [269, 1003]: local jShapley = -7.3273897335761885e-06\n",
      "k = 2, review 60, coalition [455, 848]: local jShapley = 0.0\n",
      "k = 2, review 60, coalition [209]: local jShapley = 1.9338125977199603e-05\n",
      "k = 2, review 60, coalition [978]: local jShapley = -0.0002515371424595294\n",
      "k = 2, review 60, coalition [101]: local jShapley = -0.0005528232828397694\n",
      "k = 2, review 60, coalition [434]: local jShapley = -2.2376792336736607e-05\n",
      "k = 2, review 60, coalition [3]: local jShapley = -0.00010569478023758646\n",
      "k = 2, review 60, coalition [174]: local jShapley = 0.0\n",
      "k = 2, review 60, coalition [269]: local jShapley = -0.0003110146825932841\n",
      "k = 2, review 60, coalition [1003]: local jShapley = -3.094294613301658e-05\n",
      "k = 2, review 60, coalition [455]: local jShapley = 0.0005313898199295249\n",
      "k = 2, review 60, coalition [848]: local jShapley = -0.0003312405268008384\n",
      "k = 2, review 61, coalition [209, 978]: local jShapley = 6.269506099721414e-06\n",
      "k = 2, review 61, coalition [101, 434]: local jShapley = -4.191573725988288e-05\n",
      "k = 2, review 61, coalition [3, 174]: local jShapley = -9.952584951068034e-10\n",
      "k = 2, review 61, coalition [269, 1003]: local jShapley = -4.127936666415826e-06\n",
      "k = 2, review 61, coalition [455, 848]: local jShapley = 2.3646287623654674e-05\n",
      "k = 2, review 61, coalition [209]: local jShapley = 9.999734353021853e-05\n",
      "k = 2, review 61, coalition [978]: local jShapley = -0.00012112682482377534\n",
      "k = 2, review 61, coalition [101]: local jShapley = -0.00015852245680335585\n",
      "k = 2, review 61, coalition [434]: local jShapley = -1.7212851575846742e-06\n",
      "k = 2, review 61, coalition [3]: local jShapley = -5.629016965642081e-09\n",
      "k = 2, review 61, coalition [174]: local jShapley = 6.465949442670048e-06\n",
      "k = 2, review 61, coalition [269]: local jShapley = -0.00047109784565121184\n",
      "k = 2, review 61, coalition [1003]: local jShapley = -4.758485227498742e-05\n",
      "k = 2, review 61, coalition [455]: local jShapley = 0.00018710376112860682\n",
      "k = 2, review 61, coalition [848]: local jShapley = -0.00023170134112084312\n",
      "k = 2, review 62, coalition [209, 978]: local jShapley = 1.681783494169838e-06\n",
      "k = 2, review 62, coalition [101, 434]: local jShapley = -4.212368878871913e-05\n",
      "k = 2, review 62, coalition [3, 174]: local jShapley = 7.285445374115158e-06\n",
      "k = 2, review 62, coalition [269, 1003]: local jShapley = -1.4571544555283295e-05\n",
      "k = 2, review 62, coalition [455, 848]: local jShapley = 4.14872841398236e-07\n",
      "k = 2, review 62, coalition [209]: local jShapley = 6.330686723629744e-05\n",
      "k = 2, review 62, coalition [978]: local jShapley = -0.0001440697425237302\n",
      "k = 2, review 62, coalition [101]: local jShapley = -5.880042337563871e-05\n",
      "k = 2, review 62, coalition [434]: local jShapley = -1.3320130479697713e-05\n",
      "k = 2, review 62, coalition [3]: local jShapley = 6.823050867444948e-10\n",
      "k = 2, review 62, coalition [174]: local jShapley = -3.0183044834180373e-06\n",
      "k = 2, review 62, coalition [269]: local jShapley = -8.02667861842846e-05\n",
      "k = 2, review 62, coalition [1003]: local jShapley = -3.637450507265651e-05\n",
      "k = 2, review 62, coalition [455]: local jShapley = 0.0003557104685631982\n",
      "k = 2, review 62, coalition [848]: local jShapley = -0.00019597053694695387\n",
      "k = 2, review 63, coalition [209, 978]: local jShapley = -7.0596235772300436e-06\n",
      "k = 2, review 63, coalition [101, 434]: local jShapley = -2.024135208969629e-05\n",
      "k = 2, review 63, coalition [3, 174]: local jShapley = -1.222528474729508e-06\n",
      "k = 2, review 63, coalition [269, 1003]: local jShapley = -8.090629865286942e-07\n",
      "k = 2, review 63, coalition [455, 848]: local jShapley = 0.0\n",
      "k = 2, review 63, coalition [209]: local jShapley = 1.847803094157624e-05\n",
      "k = 2, review 63, coalition [978]: local jShapley = -0.00011856195508936832\n",
      "k = 2, review 63, coalition [101]: local jShapley = -8.012393288778562e-05\n",
      "k = 2, review 63, coalition [434]: local jShapley = -2.5550226610863318e-06\n",
      "k = 2, review 63, coalition [3]: local jShapley = 3.3917385862068836e-06\n",
      "k = 2, review 63, coalition [174]: local jShapley = -3.1634648906229286e-06\n",
      "k = 2, review 63, coalition [269]: local jShapley = -8.269103214901327e-06\n",
      "k = 2, review 63, coalition [1003]: local jShapley = -2.2063875496836905e-05\n",
      "k = 2, review 63, coalition [455]: local jShapley = 0.0002379063928441644\n",
      "k = 2, review 63, coalition [848]: local jShapley = -0.00011120456105775214\n",
      "k = 2, review 64, coalition [209, 978]: local jShapley = -1.8585344967641938e-06\n",
      "k = 2, review 64, coalition [101, 434]: local jShapley = -3.959522362576917e-06\n",
      "k = 2, review 64, coalition [3, 174]: local jShapley = 8.965860777948526e-06\n",
      "k = 2, review 64, coalition [269, 1003]: local jShapley = -3.0161737205555096e-06\n",
      "k = 2, review 64, coalition [455, 848]: local jShapley = 4.831636334077765e-05\n",
      "k = 2, review 64, coalition [209]: local jShapley = 0.00010812672545551565\n",
      "k = 2, review 64, coalition [978]: local jShapley = -0.00013420277074800403\n",
      "k = 2, review 64, coalition [101]: local jShapley = -0.00012393117206643153\n",
      "k = 2, review 64, coalition [434]: local jShapley = -4.900755690155641e-05\n",
      "k = 2, review 64, coalition [3]: local jShapley = 2.787004391638776e-05\n",
      "k = 2, review 64, coalition [174]: local jShapley = -1.8031454849563599e-06\n",
      "k = 2, review 64, coalition [269]: local jShapley = -4.6314583439698515e-05\n",
      "k = 2, review 64, coalition [1003]: local jShapley = -6.735736472062052e-06\n",
      "k = 2, review 64, coalition [455]: local jShapley = 0.00010656632903674973\n",
      "k = 2, review 64, coalition [848]: local jShapley = -0.00013882858201791072\n",
      "k = 2, review 65, coalition [209, 978]: local jShapley = 1.5126353125197232e-05\n",
      "k = 2, review 65, coalition [101, 434]: local jShapley = -2.8101363975132187e-06\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "k = 2, review 65, coalition [3, 174]: local jShapley = 7.610491584181356e-07\n",
      "k = 2, review 65, coalition [269, 1003]: local jShapley = -5.4799016993027314e-06\n",
      "k = 2, review 65, coalition [455, 848]: local jShapley = -8.981103369338818e-06\n",
      "k = 2, review 65, coalition [209]: local jShapley = 4.420650392610789e-05\n",
      "k = 2, review 65, coalition [978]: local jShapley = -0.00011385565280810293\n",
      "k = 2, review 65, coalition [101]: local jShapley = -0.0006518246261891042\n",
      "k = 2, review 65, coalition [434]: local jShapley = -1.0579753990104791e-07\n",
      "k = 2, review 65, coalition [3]: local jShapley = 0.00016905383581725713\n",
      "k = 2, review 65, coalition [174]: local jShapley = 4.487460587298028e-06\n",
      "k = 2, review 65, coalition [269]: local jShapley = -0.0001692694868687363\n",
      "k = 2, review 65, coalition [1003]: local jShapley = -3.278217412145523e-05\n",
      "k = 2, review 65, coalition [455]: local jShapley = 2.969776067174184e-05\n",
      "k = 2, review 65, coalition [848]: local jShapley = -0.0009338354923626792\n",
      "k = 2, review 66, coalition [209, 978]: local jShapley = -4.112073034453459e-06\n",
      "k = 2, review 66, coalition [101, 434]: local jShapley = -7.73980432643544e-05\n",
      "k = 2, review 66, coalition [3, 174]: local jShapley = -1.555979659445116e-07\n",
      "k = 2, review 66, coalition [269, 1003]: local jShapley = -1.3084520511387061e-05\n",
      "k = 2, review 66, coalition [455, 848]: local jShapley = -1.60464384961311e-06\n",
      "k = 2, review 66, coalition [209]: local jShapley = 1.1593216305147396e-06\n",
      "k = 2, review 66, coalition [978]: local jShapley = -0.00029450475184576773\n",
      "k = 2, review 66, coalition [101]: local jShapley = -0.00038296590485066686\n",
      "k = 2, review 66, coalition [434]: local jShapley = -2.7020987197798855e-05\n",
      "k = 2, review 66, coalition [3]: local jShapley = 0.0\n",
      "k = 2, review 66, coalition [174]: local jShapley = 1.910198378477056e-06\n",
      "k = 2, review 66, coalition [269]: local jShapley = -0.00017660375482242457\n",
      "k = 2, review 66, coalition [1003]: local jShapley = -6.877038257433606e-06\n",
      "k = 2, review 66, coalition [455]: local jShapley = 0.0003147050335998573\n",
      "k = 2, review 66, coalition [848]: local jShapley = -6.469957985054671e-05\n",
      "k = 2, review 67, coalition [209, 978]: local jShapley = -1.3764381766354906e-06\n",
      "k = 2, review 67, coalition [101, 434]: local jShapley = -4.981434709462127e-05\n",
      "k = 2, review 67, coalition [3, 174]: local jShapley = -4.246562084286959e-07\n",
      "k = 2, review 67, coalition [269, 1003]: local jShapley = -3.974469705067337e-06\n",
      "k = 2, review 67, coalition [455, 848]: local jShapley = -2.7409757823220285e-06\n",
      "k = 2, review 67, coalition [209]: local jShapley = 0.00013345537515524258\n",
      "k = 2, review 67, coalition [978]: local jShapley = -0.00034808194854508864\n",
      "k = 2, review 67, coalition [101]: local jShapley = -0.0006047991521445689\n",
      "k = 2, review 67, coalition [434]: local jShapley = -3.2078658941428264e-05\n",
      "k = 2, review 67, coalition [3]: local jShapley = -6.454866249417241e-05\n",
      "k = 2, review 67, coalition [174]: local jShapley = 1.0483340471387672e-05\n",
      "k = 2, review 67, coalition [269]: local jShapley = -0.00014522995967967126\n",
      "k = 2, review 67, coalition [1003]: local jShapley = -0.00012797024227317877\n",
      "k = 2, review 67, coalition [455]: local jShapley = 0.00034864929588573364\n",
      "k = 2, review 67, coalition [848]: local jShapley = -0.000411153548458663\n",
      "k = 2, review 68, coalition [209, 978]: local jShapley = -2.996587316975649e-06\n",
      "k = 2, review 68, coalition [101, 434]: local jShapley = -1.3634823427112458e-06\n",
      "k = 2, review 68, coalition [3, 174]: local jShapley = -5.7858304135340835e-08\n",
      "k = 2, review 68, coalition [269, 1003]: local jShapley = -2.438242900813888e-05\n",
      "k = 2, review 68, coalition [455, 848]: local jShapley = -4.480673298049339e-05\n",
      "k = 2, review 68, coalition [209]: local jShapley = 5.485035267127084e-05\n",
      "k = 2, review 68, coalition [978]: local jShapley = -8.532624897876672e-06\n",
      "k = 2, review 68, coalition [101]: local jShapley = -0.0006385880087859223\n",
      "k = 2, review 68, coalition [434]: local jShapley = -1.9517166430054586e-05\n",
      "k = 2, review 68, coalition [3]: local jShapley = -0.00010908725709921924\n",
      "k = 2, review 68, coalition [174]: local jShapley = 5.7550168600789804e-06\n",
      "k = 2, review 68, coalition [269]: local jShapley = -0.00019939013810103896\n",
      "k = 2, review 68, coalition [1003]: local jShapley = -4.513959877629891e-05\n",
      "k = 2, review 68, coalition [455]: local jShapley = 0.0003702834524406338\n",
      "k = 2, review 68, coalition [848]: local jShapley = -0.0005737700276807914\n",
      "k = 2, review 69, coalition [209, 978]: local jShapley = -1.6174120781576571e-06\n",
      "k = 2, review 69, coalition [101, 434]: local jShapley = -6.162414311354821e-05\n",
      "k = 2, review 69, coalition [3, 174]: local jShapley = -8.413897262919856e-06\n",
      "k = 2, review 69, coalition [269, 1003]: local jShapley = -2.3060934385765435e-06\n",
      "k = 2, review 69, coalition [455, 848]: local jShapley = 9.979944957223688e-06\n",
      "k = 2, review 69, coalition [209]: local jShapley = 1.1174999767640501e-05\n",
      "k = 2, review 69, coalition [978]: local jShapley = -1.1293172643251507e-05\n",
      "k = 2, review 69, coalition [101]: local jShapley = -7.738460589671024e-05\n",
      "k = 2, review 69, coalition [434]: local jShapley = -6.738756871435306e-06\n",
      "k = 2, review 69, coalition [3]: local jShapley = -7.123323208155067e-05\n",
      "k = 2, review 69, coalition [174]: local jShapley = 1.2559655453651798e-06\n",
      "k = 2, review 69, coalition [269]: local jShapley = -0.00015309848850780593\n",
      "k = 2, review 69, coalition [1003]: local jShapley = -6.271090039556857e-06\n",
      "k = 2, review 69, coalition [455]: local jShapley = 0.00019271894811599897\n",
      "k = 2, review 69, coalition [848]: local jShapley = -0.0005296936627889631\n",
      "k = 2, review 70, coalition [209, 978]: local jShapley = 1.268407808234154e-07\n",
      "k = 2, review 70, coalition [101, 434]: local jShapley = -1.267674017678752e-05\n",
      "k = 2, review 70, coalition [3, 174]: local jShapley = 1.3184066055573371e-05\n",
      "k = 2, review 70, coalition [269, 1003]: local jShapley = -1.4088361013435774e-07\n",
      "k = 2, review 70, coalition [455, 848]: local jShapley = 4.589105114306417e-05\n",
      "k = 2, review 70, coalition [209]: local jShapley = 0.00022418412947028022\n",
      "k = 2, review 70, coalition [978]: local jShapley = -0.00011336392406089977\n",
      "k = 2, review 70, coalition [101]: local jShapley = -0.0005520093355153512\n",
      "k = 2, review 70, coalition [434]: local jShapley = -2.2614533015399142e-05\n",
      "k = 2, review 70, coalition [3]: local jShapley = 7.601889330743413e-05\n",
      "k = 2, review 70, coalition [174]: local jShapley = 1.2649914986208972e-05\n",
      "k = 2, review 70, coalition [269]: local jShapley = -0.00043626625626104124\n",
      "k = 2, review 70, coalition [1003]: local jShapley = -1.1571521135592316e-06\n",
      "k = 2, review 70, coalition [455]: local jShapley = 0.0008856887298657068\n",
      "k = 2, review 70, coalition [848]: local jShapley = -0.0007052838640660457\n",
      "k = 2, review 71, coalition [209, 978]: local jShapley = 1.7176918091696385e-07\n",
      "k = 2, review 71, coalition [101, 434]: local jShapley = -2.1083190291183526e-06\n",
      "k = 2, review 71, coalition [3, 174]: local jShapley = 2.7743544496598006e-07\n",
      "k = 2, review 71, coalition [269, 1003]: local jShapley = -2.1179194371136535e-05\n",
      "k = 2, review 71, coalition [455, 848]: local jShapley = -3.625653658192349e-05\n",
      "k = 2, review 71, coalition [209]: local jShapley = 0.0001548402641400269\n",
      "k = 2, review 71, coalition [978]: local jShapley = 3.036715554802413e-06\n",
      "k = 2, review 71, coalition [101]: local jShapley = -0.0005778748283877313\n",
      "k = 2, review 71, coalition [434]: local jShapley = -1.885446428828277e-05\n",
      "k = 2, review 71, coalition [3]: local jShapley = 5.96502770052469e-05\n",
      "k = 2, review 71, coalition [174]: local jShapley = 6.799681918223949e-06\n",
      "k = 2, review 71, coalition [269]: local jShapley = -0.0003223948358088243\n",
      "k = 2, review 71, coalition [1003]: local jShapley = -3.416232539244738e-05\n",
      "k = 2, review 71, coalition [455]: local jShapley = 0.00023150368522053557\n",
      "k = 2, review 71, coalition [848]: local jShapley = -0.0001047686923408058\n",
      "k = 2, review 72, coalition [209, 978]: local jShapley = 6.404067510292371e-08\n",
      "k = 2, review 72, coalition [101, 434]: local jShapley = -2.158795640519065e-05\n",
      "k = 2, review 72, coalition [3, 174]: local jShapley = -2.999608801490836e-06\n",
      "k = 2, review 72, coalition [269, 1003]: local jShapley = -3.158100617725075e-05\n",
      "k = 2, review 72, coalition [455, 848]: local jShapley = 2.7162835872349145e-05\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "k = 2, review 72, coalition [209]: local jShapley = 5.028486143543915e-05\n",
      "k = 2, review 72, coalition [978]: local jShapley = -0.0001644315173630386\n",
      "k = 2, review 72, coalition [101]: local jShapley = -0.00034431939846627007\n",
      "k = 2, review 72, coalition [434]: local jShapley = -3.9445272420635006e-05\n",
      "k = 2, review 72, coalition [3]: local jShapley = -0.0001244876518328922\n",
      "k = 2, review 72, coalition [174]: local jShapley = 1.038123191600381e-05\n",
      "k = 2, review 72, coalition [269]: local jShapley = -0.0003256419630302008\n",
      "k = 2, review 72, coalition [1003]: local jShapley = -2.833395540503487e-05\n",
      "k = 2, review 72, coalition [455]: local jShapley = 0.0006798494707373014\n",
      "k = 2, review 72, coalition [848]: local jShapley = -0.0007475157131050131\n",
      "k = 2, review 73, coalition [209, 978]: local jShapley = 3.021799953171849e-07\n",
      "k = 2, review 73, coalition [101, 434]: local jShapley = -4.562246048509391e-06\n",
      "k = 2, review 73, coalition [3, 174]: local jShapley = 7.704610184091877e-06\n",
      "k = 2, review 73, coalition [269, 1003]: local jShapley = -1.2732692201074474e-05\n",
      "k = 2, review 73, coalition [455, 848]: local jShapley = -7.578173192734346e-07\n",
      "k = 2, review 73, coalition [209]: local jShapley = 7.426478920854569e-06\n",
      "k = 2, review 73, coalition [978]: local jShapley = -1.9961394634142622e-05\n",
      "k = 2, review 73, coalition [101]: local jShapley = -0.0003123209849996531\n",
      "k = 2, review 73, coalition [434]: local jShapley = -1.2360748226887317e-05\n",
      "k = 2, review 73, coalition [3]: local jShapley = -8.65152188975039e-07\n",
      "k = 2, review 73, coalition [174]: local jShapley = 6.28750400782528e-06\n",
      "k = 2, review 73, coalition [269]: local jShapley = -7.922681588820318e-06\n",
      "k = 2, review 73, coalition [1003]: local jShapley = -3.968638645745758e-06\n",
      "k = 2, review 73, coalition [455]: local jShapley = 0.0\n",
      "k = 2, review 73, coalition [848]: local jShapley = -1.99498544652204e-05\n",
      "k = 2, review 74, coalition [209, 978]: local jShapley = -5.830000810252913e-07\n",
      "k = 2, review 74, coalition [101, 434]: local jShapley = -1.962028617788593e-05\n",
      "k = 2, review 74, coalition [3, 174]: local jShapley = 2.3025808505045165e-07\n",
      "k = 2, review 74, coalition [269, 1003]: local jShapley = -5.879440820112724e-09\n",
      "k = 2, review 74, coalition [455, 848]: local jShapley = -7.870172438716801e-09\n",
      "k = 2, review 74, coalition [209]: local jShapley = 6.531203395403575e-05\n",
      "k = 2, review 74, coalition [978]: local jShapley = -6.837822772572966e-05\n",
      "k = 2, review 74, coalition [101]: local jShapley = -0.00043109353082215957\n",
      "k = 2, review 74, coalition [434]: local jShapley = -3.660187258179713e-05\n",
      "k = 2, review 74, coalition [3]: local jShapley = 2.3473231291219684e-05\n",
      "k = 2, review 74, coalition [174]: local jShapley = 1.3338510072971894e-05\n",
      "k = 2, review 74, coalition [269]: local jShapley = -4.0757107894816855e-06\n",
      "k = 2, review 74, coalition [1003]: local jShapley = -7.789839062226192e-05\n",
      "k = 2, review 74, coalition [455]: local jShapley = 0.00029021535445859895\n",
      "k = 2, review 74, coalition [848]: local jShapley = -0.0004439126574698812\n",
      "k = 2, review 75, coalition [209, 978]: local jShapley = -2.180146279334042e-05\n",
      "k = 2, review 75, coalition [101, 434]: local jShapley = -3.096512343653852e-06\n",
      "k = 2, review 75, coalition [3, 174]: local jShapley = -3.8882728396637027e-07\n",
      "k = 2, review 75, coalition [269, 1003]: local jShapley = -3.689335755804001e-05\n",
      "k = 2, review 75, coalition [455, 848]: local jShapley = -1.4284100103093768e-05\n",
      "k = 2, review 75, coalition [209]: local jShapley = 0.00010746912794193675\n",
      "k = 2, review 75, coalition [978]: local jShapley = -8.977871082126451e-05\n",
      "k = 2, review 75, coalition [101]: local jShapley = -0.0001133231563319668\n",
      "k = 2, review 75, coalition [434]: local jShapley = -5.220806625463227e-06\n",
      "k = 2, review 75, coalition [3]: local jShapley = -7.871228730684952e-05\n",
      "k = 2, review 75, coalition [174]: local jShapley = 1.9063305615165733e-05\n",
      "k = 2, review 75, coalition [269]: local jShapley = -0.00012369167765047574\n",
      "k = 2, review 75, coalition [1003]: local jShapley = -8.78600422234773e-05\n",
      "k = 2, review 75, coalition [455]: local jShapley = 1.7364664457647392e-07\n",
      "k = 2, review 75, coalition [848]: local jShapley = -0.0006812175350802919\n",
      "k = 2, review 76, coalition [209, 978]: local jShapley = -2.2187735632503255e-06\n",
      "k = 2, review 76, coalition [101, 434]: local jShapley = -5.125671766802916e-06\n",
      "k = 2, review 76, coalition [3, 174]: local jShapley = -3.575481421539423e-06\n",
      "k = 2, review 76, coalition [269, 1003]: local jShapley = -3.373878711120566e-05\n",
      "k = 2, review 76, coalition [455, 848]: local jShapley = 7.50483548556964e-09\n",
      "k = 2, review 76, coalition [209]: local jShapley = 0.00014297042642728952\n",
      "k = 2, review 76, coalition [978]: local jShapley = -0.00017625881761802427\n",
      "k = 2, review 76, coalition [101]: local jShapley = -0.0002080694266095148\n",
      "k = 2, review 76, coalition [434]: local jShapley = -1.5679306927286606e-05\n",
      "k = 2, review 76, coalition [3]: local jShapley = -8.453443392559973e-05\n",
      "k = 2, review 76, coalition [174]: local jShapley = 4.6823186577840955e-08\n",
      "k = 2, review 76, coalition [269]: local jShapley = -0.00018136786480248216\n",
      "k = 2, review 76, coalition [1003]: local jShapley = -2.9297088711683057e-05\n",
      "k = 2, review 76, coalition [455]: local jShapley = 0.00033756938622615774\n",
      "k = 2, review 76, coalition [848]: local jShapley = -0.0005981939591591181\n",
      "k = 2, review 77, coalition [209, 978]: local jShapley = -1.083023218622854e-05\n",
      "k = 2, review 77, coalition [101, 434]: local jShapley = -2.1539413663001563e-05\n",
      "k = 2, review 77, coalition [3, 174]: local jShapley = -2.159492743747448e-06\n",
      "k = 2, review 77, coalition [269, 1003]: local jShapley = -8.489645863426007e-06\n",
      "k = 2, review 77, coalition [455, 848]: local jShapley = 5.556745565770963e-07\n",
      "k = 2, review 77, coalition [209]: local jShapley = 5.8906809664085955e-05\n",
      "k = 2, review 77, coalition [978]: local jShapley = -0.00018861313458641817\n",
      "k = 2, review 77, coalition [101]: local jShapley = -0.0005564035721722913\n",
      "k = 2, review 77, coalition [434]: local jShapley = 0.0\n",
      "k = 2, review 77, coalition [3]: local jShapley = -5.6276949995365144e-05\n",
      "k = 2, review 77, coalition [174]: local jShapley = 6.129445102701247e-06\n",
      "k = 2, review 77, coalition [269]: local jShapley = -0.00022670318585795612\n",
      "k = 2, review 77, coalition [1003]: local jShapley = -5.469378897377831e-05\n",
      "k = 2, review 77, coalition [455]: local jShapley = 0.00034087506375279046\n",
      "k = 2, review 77, coalition [848]: local jShapley = -0.00037657824991670075\n",
      "k = 2, review 78, coalition [209, 978]: local jShapley = -9.356888284166846e-06\n",
      "k = 2, review 78, coalition [101, 434]: local jShapley = -8.40280761996984e-07\n",
      "k = 2, review 78, coalition [3, 174]: local jShapley = -6.291124231772033e-07\n",
      "k = 2, review 78, coalition [269, 1003]: local jShapley = -3.1967150583603984e-05\n",
      "k = 2, review 78, coalition [455, 848]: local jShapley = -4.960186213738634e-07\n",
      "k = 2, review 78, coalition [209]: local jShapley = 0.00022121166735987783\n",
      "k = 2, review 78, coalition [978]: local jShapley = -0.0001988334251248319\n",
      "k = 2, review 78, coalition [101]: local jShapley = -0.0003899690842610124\n",
      "k = 2, review 78, coalition [434]: local jShapley = -5.1231218590753765e-05\n",
      "k = 2, review 78, coalition [3]: local jShapley = -2.612230611042051e-05\n",
      "k = 2, review 78, coalition [174]: local jShapley = 1.5826727470091342e-05\n",
      "k = 2, review 78, coalition [269]: local jShapley = -0.000342414104155604\n",
      "k = 2, review 78, coalition [1003]: local jShapley = -6.261200347155005e-05\n",
      "k = 2, review 78, coalition [455]: local jShapley = 0.00039622270888950114\n",
      "k = 2, review 78, coalition [848]: local jShapley = -0.0008049740743580764\n",
      "k = 2, review 79, coalition [209, 978]: local jShapley = -8.70553863118602e-06\n",
      "k = 2, review 79, coalition [101, 434]: local jShapley = -3.3923439388629376e-05\n",
      "k = 2, review 79, coalition [3, 174]: local jShapley = 3.828321487206953e-08\n",
      "k = 2, review 79, coalition [269, 1003]: local jShapley = -1.2840894767580885e-05\n",
      "k = 2, review 79, coalition [455, 848]: local jShapley = -1.0004529883111201e-07\n",
      "k = 2, review 79, coalition [209]: local jShapley = 1.2259639141845366e-05\n",
      "k = 2, review 79, coalition [978]: local jShapley = 0.0\n",
      "k = 2, review 79, coalition [101]: local jShapley = -0.0001467871504638939\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "k = 2, review 79, coalition [434]: local jShapley = -4.804160755598645e-07\n",
      "k = 2, review 79, coalition [3]: local jShapley = -5.695626999735514e-06\n",
      "k = 2, review 79, coalition [174]: local jShapley = 2.0420058233927653e-05\n",
      "k = 2, review 79, coalition [269]: local jShapley = -0.0003154676227021868\n",
      "k = 2, review 79, coalition [1003]: local jShapley = -3.608071863794481e-05\n",
      "k = 2, review 79, coalition [455]: local jShapley = 0.00010553694654644614\n",
      "k = 2, review 79, coalition [848]: local jShapley = -0.00038027604386276073\n",
      "k = 2, review 80, coalition [209, 978]: local jShapley = 2.2248534064878607e-06\n",
      "k = 2, review 80, coalition [101, 434]: local jShapley = -3.120918397664563e-05\n",
      "k = 2, review 80, coalition [3, 174]: local jShapley = 3.486602191731186e-06\n",
      "k = 2, review 80, coalition [269, 1003]: local jShapley = -4.414209109455613e-05\n",
      "k = 2, review 80, coalition [455, 848]: local jShapley = 1.256494433333274e-05\n",
      "k = 2, review 80, coalition [209]: local jShapley = 2.783590467476233e-05\n",
      "k = 2, review 80, coalition [978]: local jShapley = -5.352165280085315e-05\n",
      "k = 2, review 80, coalition [101]: local jShapley = -0.0005210523434924629\n",
      "k = 2, review 80, coalition [434]: local jShapley = -1.8128291781918244e-05\n",
      "k = 2, review 80, coalition [3]: local jShapley = 2.0282780867943548e-05\n",
      "k = 2, review 80, coalition [174]: local jShapley = -1.2875310207208223e-06\n",
      "k = 2, review 80, coalition [269]: local jShapley = -0.0001373991575774317\n",
      "k = 2, review 80, coalition [1003]: local jShapley = -8.307439698911932e-05\n",
      "k = 2, review 80, coalition [455]: local jShapley = 0.0007496775914418546\n",
      "k = 2, review 80, coalition [848]: local jShapley = -0.0010063700668124487\n",
      "k = 2, review 81, coalition [209, 978]: local jShapley = -3.743204899069314e-06\n",
      "k = 2, review 81, coalition [101, 434]: local jShapley = -5.167324725190171e-07\n",
      "k = 2, review 81, coalition [3, 174]: local jShapley = 1.7697507440353432e-05\n",
      "k = 2, review 81, coalition [269, 1003]: local jShapley = -1.0024081881726732e-05\n",
      "k = 2, review 81, coalition [455, 848]: local jShapley = -1.5792279554849173e-05\n",
      "k = 2, review 81, coalition [209]: local jShapley = 3.686878779974004e-05\n",
      "k = 2, review 81, coalition [978]: local jShapley = -0.0002793501375301876\n",
      "k = 2, review 81, coalition [101]: local jShapley = -0.0008717485013333452\n",
      "k = 2, review 81, coalition [434]: local jShapley = -2.03949945682193e-05\n",
      "k = 2, review 81, coalition [3]: local jShapley = 5.4483168805718095e-05\n",
      "k = 2, review 81, coalition [174]: local jShapley = 2.391915631159376e-05\n",
      "k = 2, review 81, coalition [269]: local jShapley = -0.0001079587458077778\n",
      "k = 2, review 81, coalition [1003]: local jShapley = -4.324279063514922e-05\n",
      "k = 2, review 81, coalition [455]: local jShapley = 0.0005830218074706053\n",
      "k = 2, review 81, coalition [848]: local jShapley = -0.0007382192636540515\n",
      "k = 2, review 82, coalition [209, 978]: local jShapley = -4.993673543541261e-07\n",
      "k = 2, review 82, coalition [101, 434]: local jShapley = -3.6128385790070344e-06\n",
      "k = 2, review 82, coalition [3, 174]: local jShapley = -3.278180542475461e-07\n",
      "k = 2, review 82, coalition [269, 1003]: local jShapley = -2.98862560629997e-07\n",
      "k = 2, review 82, coalition [455, 848]: local jShapley = -2.361228043796206e-08\n",
      "k = 2, review 82, coalition [209]: local jShapley = 0.00031408443447939523\n",
      "k = 2, review 82, coalition [978]: local jShapley = -0.00010611780139560531\n",
      "k = 2, review 82, coalition [101]: local jShapley = -0.0006009015269806089\n",
      "k = 2, review 82, coalition [434]: local jShapley = -7.599224076498317e-05\n",
      "k = 2, review 82, coalition [3]: local jShapley = -7.260008943494013e-05\n",
      "k = 2, review 82, coalition [174]: local jShapley = 1.8166490278637003e-05\n",
      "k = 2, review 82, coalition [269]: local jShapley = -4.7480214393324965e-05\n",
      "k = 2, review 82, coalition [1003]: local jShapley = -0.000116926110986589\n",
      "k = 2, review 82, coalition [455]: local jShapley = 0.0004334328724476564\n",
      "k = 2, review 82, coalition [848]: local jShapley = -0.00021625966228604947\n",
      "k = 2, review 83, coalition [209, 978]: local jShapley = -2.578918873141296e-06\n",
      "k = 2, review 83, coalition [101, 434]: local jShapley = -2.1267793984806218e-05\n",
      "k = 2, review 83, coalition [3, 174]: local jShapley = -7.055414812444112e-06\n",
      "k = 2, review 83, coalition [269, 1003]: local jShapley = -2.5496003039134175e-05\n",
      "k = 2, review 83, coalition [455, 848]: local jShapley = 3.903537152743523e-05\n",
      "k = 2, review 83, coalition [209]: local jShapley = 8.479708940094542e-05\n",
      "k = 2, review 83, coalition [978]: local jShapley = -0.00041972214895833994\n",
      "k = 2, review 83, coalition [101]: local jShapley = -0.00010974438352911031\n",
      "k = 2, review 83, coalition [434]: local jShapley = -4.492925691127596e-05\n",
      "k = 2, review 83, coalition [3]: local jShapley = 0.0\n",
      "k = 2, review 83, coalition [174]: local jShapley = 5.358163168238479e-06\n",
      "k = 2, review 83, coalition [269]: local jShapley = 0.0\n",
      "k = 2, review 83, coalition [1003]: local jShapley = 0.0\n",
      "k = 2, review 83, coalition [455]: local jShapley = 0.0\n",
      "k = 2, review 83, coalition [848]: local jShapley = -0.0007162033254200669\n",
      "k = 2, review 84, coalition [209, 978]: local jShapley = -3.4160773192649153e-06\n",
      "k = 2, review 84, coalition [101, 434]: local jShapley = -3.831103231902685e-05\n",
      "k = 2, review 84, coalition [3, 174]: local jShapley = -6.097774071122887e-07\n",
      "k = 2, review 84, coalition [269, 1003]: local jShapley = -2.467283881709364e-05\n",
      "k = 2, review 84, coalition [455, 848]: local jShapley = -4.4857388228042465e-06\n",
      "k = 2, review 84, coalition [209]: local jShapley = 5.3987877730185005e-05\n",
      "k = 2, review 84, coalition [978]: local jShapley = -6.560166475650544e-05\n",
      "k = 2, review 84, coalition [101]: local jShapley = -0.0005842667983683201\n",
      "k = 2, review 84, coalition [434]: local jShapley = -1.8516352800004177e-05\n",
      "k = 2, review 84, coalition [3]: local jShapley = -1.556679055407565e-05\n",
      "k = 2, review 84, coalition [174]: local jShapley = -3.7043460900357655e-07\n",
      "k = 2, review 84, coalition [269]: local jShapley = -8.13563527806967e-07\n",
      "k = 2, review 84, coalition [1003]: local jShapley = -1.9209521463051683e-05\n",
      "k = 2, review 84, coalition [455]: local jShapley = 5.6194604300208666e-05\n",
      "k = 2, review 84, coalition [848]: local jShapley = -0.00015305668132971738\n",
      "k = 2, review 85, coalition [209, 978]: local jShapley = 5.606586126944835e-06\n",
      "k = 2, review 85, coalition [101, 434]: local jShapley = -1.3237247824769706e-05\n",
      "k = 2, review 85, coalition [3, 174]: local jShapley = 1.2351746214931879e-06\n",
      "k = 2, review 85, coalition [269, 1003]: local jShapley = -2.055869358802372e-06\n",
      "k = 2, review 85, coalition [455, 848]: local jShapley = 3.117890949268337e-05\n",
      "k = 2, review 85, coalition [209]: local jShapley = 0.0001842452745140031\n",
      "k = 2, review 85, coalition [978]: local jShapley = -8.406983942423307e-05\n",
      "k = 2, review 85, coalition [101]: local jShapley = -3.1855545178062815e-05\n",
      "k = 2, review 85, coalition [434]: local jShapley = -6.266741943781409e-05\n",
      "k = 2, review 85, coalition [3]: local jShapley = 9.302271432334649e-05\n",
      "k = 2, review 85, coalition [174]: local jShapley = 5.469128863213962e-06\n",
      "k = 2, review 85, coalition [269]: local jShapley = -0.0001960465073539561\n",
      "k = 2, review 85, coalition [1003]: local jShapley = -6.221684221615519e-05\n",
      "k = 2, review 85, coalition [455]: local jShapley = 0.0005882153565409039\n",
      "k = 2, review 85, coalition [848]: local jShapley = -0.00026509283969181237\n",
      "k = 2, review 86, coalition [209, 978]: local jShapley = -2.612777701828983e-06\n",
      "k = 2, review 86, coalition [101, 434]: local jShapley = -6.556156462807901e-05\n",
      "k = 2, review 86, coalition [3, 174]: local jShapley = 9.12225968518975e-06\n",
      "k = 2, review 86, coalition [269, 1003]: local jShapley = -3.2285716515958944e-05\n",
      "k = 2, review 86, coalition [455, 848]: local jShapley = 1.888319261543405e-05\n",
      "k = 2, review 86, coalition [209]: local jShapley = 0.00018618962956236965\n",
      "k = 2, review 86, coalition [978]: local jShapley = -0.00016695741079416674\n",
      "k = 2, review 86, coalition [101]: local jShapley = -0.0005653485492154438\n",
      "k = 2, review 86, coalition [434]: local jShapley = -1.8336949206258297e-07\n",
      "k = 2, review 86, coalition [3]: local jShapley = 7.984956728475732e-05\n",
      "k = 2, review 86, coalition [174]: local jShapley = -1.6412848861638823e-06\n",
      "k = 2, review 86, coalition [269]: local jShapley = -0.00013161970028386944\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "k = 2, review 86, coalition [1003]: local jShapley = -9.158901009880765e-05\n",
      "k = 2, review 86, coalition [455]: local jShapley = 0.00012791395210352236\n",
      "k = 2, review 86, coalition [848]: local jShapley = 0.0\n",
      "k = 2, review 87, coalition [209, 978]: local jShapley = -6.731008603953712e-07\n",
      "k = 2, review 87, coalition [101, 434]: local jShapley = -2.8008997683985914e-06\n",
      "k = 2, review 87, coalition [3, 174]: local jShapley = -3.629148054995802e-06\n",
      "k = 2, review 87, coalition [269, 1003]: local jShapley = -1.0065994212311892e-05\n",
      "k = 2, review 87, coalition [455, 848]: local jShapley = 4.191293343525547e-06\n",
      "k = 2, review 87, coalition [209]: local jShapley = 2.7978815607384363e-05\n",
      "k = 2, review 87, coalition [978]: local jShapley = -8.875803034475192e-06\n",
      "k = 2, review 87, coalition [101]: local jShapley = -0.00034310399189067575\n",
      "k = 2, review 87, coalition [434]: local jShapley = -9.717431689483016e-06\n",
      "k = 2, review 87, coalition [3]: local jShapley = -1.932934463077557e-05\n",
      "k = 2, review 87, coalition [174]: local jShapley = 1.3611186904279143e-06\n",
      "k = 2, review 87, coalition [269]: local jShapley = -5.330394417309675e-05\n",
      "k = 2, review 87, coalition [1003]: local jShapley = -3.036337193852218e-05\n",
      "k = 2, review 87, coalition [455]: local jShapley = 0.00033912616905990245\n",
      "k = 2, review 87, coalition [848]: local jShapley = -9.605292716273162e-05\n",
      "k = 2, review 88, coalition [209, 978]: local jShapley = -4.261391206326909e-07\n",
      "k = 2, review 88, coalition [101, 434]: local jShapley = -2.24707581108749e-06\n",
      "k = 2, review 88, coalition [3, 174]: local jShapley = 9.181852096151242e-08\n",
      "k = 2, review 88, coalition [269, 1003]: local jShapley = -1.4041541703371387e-05\n",
      "k = 2, review 88, coalition [455, 848]: local jShapley = -7.081095084959412e-06\n",
      "k = 2, review 88, coalition [209]: local jShapley = 6.783483035973106e-05\n",
      "k = 2, review 88, coalition [978]: local jShapley = -1.527463604474524e-05\n",
      "k = 2, review 88, coalition [101]: local jShapley = -9.104004650255727e-05\n",
      "k = 2, review 88, coalition [434]: local jShapley = -3.090472105663342e-05\n",
      "k = 2, review 88, coalition [3]: local jShapley = -5.099228387818942e-06\n",
      "k = 2, review 88, coalition [174]: local jShapley = 1.7248128881034827e-05\n",
      "k = 2, review 88, coalition [269]: local jShapley = -0.0001274200964834316\n",
      "k = 2, review 88, coalition [1003]: local jShapley = -2.2461925887833455e-05\n",
      "k = 2, review 88, coalition [455]: local jShapley = 0.00038477576173732455\n",
      "k = 2, review 88, coalition [848]: local jShapley = -0.0003504147283146341\n",
      "k = 2, review 89, coalition [209, 978]: local jShapley = -1.2510740424543867e-05\n",
      "k = 2, review 89, coalition [101, 434]: local jShapley = -3.094995324837923e-05\n",
      "k = 2, review 89, coalition [3, 174]: local jShapley = -9.365453576022562e-08\n",
      "k = 2, review 89, coalition [269, 1003]: local jShapley = -1.464746010930851e-06\n",
      "k = 2, review 89, coalition [455, 848]: local jShapley = -3.1867027459339115e-05\n",
      "k = 2, review 89, coalition [209]: local jShapley = 6.40014644756203e-05\n",
      "k = 2, review 89, coalition [978]: local jShapley = -9.789306133761361e-05\n",
      "k = 2, review 89, coalition [101]: local jShapley = -1.0766083176731293e-07\n",
      "k = 2, review 89, coalition [434]: local jShapley = -2.7892201507554363e-05\n",
      "k = 2, review 89, coalition [3]: local jShapley = -6.068481476357407e-05\n",
      "k = 2, review 89, coalition [174]: local jShapley = -3.431312281238064e-06\n",
      "k = 2, review 89, coalition [269]: local jShapley = -0.00021845984565690141\n",
      "k = 2, review 89, coalition [1003]: local jShapley = -3.222550578825674e-07\n",
      "k = 2, review 89, coalition [455]: local jShapley = 0.00016948178636300227\n",
      "k = 2, review 89, coalition [848]: local jShapley = -0.000571992633590839\n",
      "k = 2, review 90, coalition [209, 978]: local jShapley = 1.490296803467878e-05\n",
      "k = 2, review 90, coalition [101, 434]: local jShapley = -1.2870155218590783e-05\n",
      "k = 2, review 90, coalition [3, 174]: local jShapley = -2.645228662968478e-06\n",
      "k = 2, review 90, coalition [269, 1003]: local jShapley = -1.4283504970262715e-05\n",
      "k = 2, review 90, coalition [455, 848]: local jShapley = -5.892829437061535e-06\n",
      "k = 2, review 90, coalition [209]: local jShapley = 0.00017370178335629645\n",
      "k = 2, review 90, coalition [978]: local jShapley = -3.411525433722474e-10\n",
      "k = 2, review 90, coalition [101]: local jShapley = -0.0004017710006345678\n",
      "k = 2, review 90, coalition [434]: local jShapley = -2.6374737670482016e-05\n",
      "k = 2, review 90, coalition [3]: local jShapley = -6.380270047503806e-05\n",
      "k = 2, review 90, coalition [174]: local jShapley = -8.022455256551682e-07\n",
      "k = 2, review 90, coalition [269]: local jShapley = -0.00011167321470001483\n",
      "k = 2, review 90, coalition [1003]: local jShapley = -6.024455407478438e-05\n",
      "k = 2, review 90, coalition [455]: local jShapley = 0.0004501956611959135\n",
      "k = 2, review 90, coalition [848]: local jShapley = -0.0008774593949093966\n",
      "k = 2, review 91, coalition [209, 978]: local jShapley = -2.062068668667466e-05\n",
      "k = 2, review 91, coalition [101, 434]: local jShapley = -5.028274751476666e-08\n",
      "k = 2, review 91, coalition [3, 174]: local jShapley = 9.378737550287404e-06\n",
      "k = 2, review 91, coalition [269, 1003]: local jShapley = -8.837415446801618e-09\n",
      "k = 2, review 91, coalition [455, 848]: local jShapley = 5.4988785942137835e-06\n",
      "k = 2, review 91, coalition [209]: local jShapley = 1.952034874362323e-05\n",
      "k = 2, review 91, coalition [978]: local jShapley = -4.900782885118976e-06\n",
      "k = 2, review 91, coalition [101]: local jShapley = -2.3786861086629946e-07\n",
      "k = 2, review 91, coalition [434]: local jShapley = 0.0\n",
      "k = 2, review 91, coalition [3]: local jShapley = -4.68525010429692e-06\n",
      "k = 2, review 91, coalition [174]: local jShapley = 6.173760285034454e-06\n",
      "k = 2, review 91, coalition [269]: local jShapley = -8.439153365399468e-05\n",
      "k = 2, review 91, coalition [1003]: local jShapley = -9.700715214857776e-06\n",
      "k = 2, review 91, coalition [455]: local jShapley = 0.0\n",
      "k = 2, review 91, coalition [848]: local jShapley = -0.00024285785353981318\n",
      "k = 2, review 92, coalition [209, 978]: local jShapley = -8.05717330296825e-06\n",
      "k = 2, review 92, coalition [101, 434]: local jShapley = -2.868992375253232e-07\n",
      "k = 2, review 92, coalition [3, 174]: local jShapley = 1.7024796402733516e-07\n",
      "k = 2, review 92, coalition [269, 1003]: local jShapley = -3.0650585674348746e-06\n",
      "k = 2, review 92, coalition [455, 848]: local jShapley = 5.750211262930852e-05\n",
      "k = 2, review 92, coalition [209]: local jShapley = 0.00012307824539867874\n",
      "k = 2, review 92, coalition [978]: local jShapley = -5.3369370834305365e-05\n",
      "k = 2, review 92, coalition [101]: local jShapley = -0.0006087042826644831\n",
      "k = 2, review 92, coalition [434]: local jShapley = -3.489500178548349e-05\n",
      "k = 2, review 92, coalition [3]: local jShapley = 0.0\n",
      "k = 2, review 92, coalition [174]: local jShapley = 4.336517911008401e-06\n",
      "k = 2, review 92, coalition [269]: local jShapley = -0.00021153666651797673\n",
      "k = 2, review 92, coalition [1003]: local jShapley = -8.840135669328335e-05\n",
      "k = 2, review 92, coalition [455]: local jShapley = 0.0006637084778086623\n",
      "k = 2, review 92, coalition [848]: local jShapley = -0.0004693849507139908\n",
      "k = 2, review 93, coalition [209, 978]: local jShapley = -3.285255985574377e-08\n",
      "k = 2, review 93, coalition [101, 434]: local jShapley = -1.7048366737005503e-05\n",
      "k = 2, review 93, coalition [3, 174]: local jShapley = 1.32229419465793e-05\n",
      "k = 2, review 93, coalition [269, 1003]: local jShapley = -3.353453592562887e-05\n",
      "k = 2, review 93, coalition [455, 848]: local jShapley = 1.021928992721339e-05\n",
      "k = 2, review 93, coalition [209]: local jShapley = 8.130876200089626e-05\n",
      "k = 2, review 93, coalition [978]: local jShapley = -0.00026666101132352476\n",
      "k = 2, review 93, coalition [101]: local jShapley = -0.0003596531605111885\n",
      "k = 2, review 93, coalition [434]: local jShapley = -1.0087539554973983e-05\n",
      "k = 2, review 93, coalition [3]: local jShapley = 0.00013193006381020234\n",
      "k = 2, review 93, coalition [174]: local jShapley = 0.0\n",
      "k = 2, review 93, coalition [269]: local jShapley = -0.00030964945141555603\n",
      "k = 2, review 93, coalition [1003]: local jShapley = -2.850001140552131e-05\n",
      "k = 2, review 93, coalition [455]: local jShapley = 0.0010452934153208028\n",
      "k = 2, review 93, coalition [848]: local jShapley = -0.0006862299614678566\n",
      "k = 2, review 94, coalition [209, 978]: local jShapley = -1.9243451733109414e-06\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "k = 2, review 94, coalition [101, 434]: local jShapley = -7.88189710945586e-06\n",
      "k = 2, review 94, coalition [3, 174]: local jShapley = 1.9953855687665343e-07\n",
      "k = 2, review 94, coalition [269, 1003]: local jShapley = -3.752161764434351e-05\n",
      "k = 2, review 94, coalition [455, 848]: local jShapley = -4.22568456480555e-05\n",
      "k = 2, review 94, coalition [209]: local jShapley = 2.9208284064375777e-05\n",
      "k = 2, review 94, coalition [978]: local jShapley = -1.4415978416654724e-05\n",
      "k = 2, review 94, coalition [101]: local jShapley = -5.430472848535047e-06\n",
      "k = 2, review 94, coalition [434]: local jShapley = -2.0300085530865007e-06\n",
      "k = 2, review 94, coalition [3]: local jShapley = -4.48165985309633e-05\n",
      "k = 2, review 94, coalition [174]: local jShapley = 5.499064499159707e-06\n",
      "k = 2, review 94, coalition [269]: local jShapley = -0.0001946488480278279\n",
      "k = 2, review 94, coalition [1003]: local jShapley = -5.534887648417189e-05\n",
      "k = 2, review 94, coalition [455]: local jShapley = 8.459788296815847e-05\n",
      "k = 2, review 94, coalition [848]: local jShapley = -0.00048739748517353604\n",
      "k = 2, review 95, coalition [209, 978]: local jShapley = -1.946614807680147e-06\n",
      "k = 2, review 95, coalition [101, 434]: local jShapley = -4.424689197693477e-05\n",
      "k = 2, review 95, coalition [3, 174]: local jShapley = 4.776320097061863e-06\n",
      "k = 2, review 95, coalition [269, 1003]: local jShapley = -6.633552910089782e-06\n",
      "k = 2, review 95, coalition [455, 848]: local jShapley = 5.054105318701769e-05\n",
      "k = 2, review 95, coalition [209]: local jShapley = 3.8418051451524184e-05\n",
      "k = 2, review 95, coalition [978]: local jShapley = -0.0003634310475456929\n",
      "k = 2, review 95, coalition [101]: local jShapley = -9.969175868241608e-05\n",
      "k = 2, review 95, coalition [434]: local jShapley = -7.334779682503319e-09\n",
      "k = 2, review 95, coalition [3]: local jShapley = 3.0290294665003023e-05\n",
      "k = 2, review 95, coalition [174]: local jShapley = 1.1354622745126432e-05\n",
      "k = 2, review 95, coalition [269]: local jShapley = -0.00021758325419670644\n",
      "k = 2, review 95, coalition [1003]: local jShapley = -4.8031602191550356e-05\n",
      "k = 2, review 95, coalition [455]: local jShapley = 0.0011761250777165058\n",
      "k = 2, review 95, coalition [848]: local jShapley = -0.0012387398956965386\n",
      "k = 2, review 96, coalition [209, 978]: local jShapley = 4.349343460595628e-07\n",
      "k = 2, review 96, coalition [101, 434]: local jShapley = 0.0\n",
      "k = 2, review 96, coalition [3, 174]: local jShapley = 1.5225917651031969e-05\n",
      "k = 2, review 96, coalition [269, 1003]: local jShapley = -1.0553898739682414e-05\n",
      "k = 2, review 96, coalition [455, 848]: local jShapley = 1.974142702788937e-05\n",
      "k = 2, review 96, coalition [209]: local jShapley = 1.1735391627597781e-05\n",
      "k = 2, review 96, coalition [978]: local jShapley = -0.00014109721644722591\n",
      "k = 2, review 96, coalition [101]: local jShapley = -8.009801162446817e-05\n",
      "k = 2, review 96, coalition [434]: local jShapley = -4.5353074980314097e-05\n",
      "k = 2, review 96, coalition [3]: local jShapley = 2.3275673318183333e-05\n",
      "k = 2, review 96, coalition [174]: local jShapley = 1.9832689888605996e-05\n",
      "k = 2, review 96, coalition [269]: local jShapley = -0.00011524209674436774\n",
      "k = 2, review 96, coalition [1003]: local jShapley = -7.06558687154526e-05\n",
      "k = 2, review 96, coalition [455]: local jShapley = 0.0003917428602683271\n",
      "k = 2, review 96, coalition [848]: local jShapley = -0.00021391716100164503\n",
      "k = 2, review 97, coalition [209, 978]: local jShapley = -2.3156791170143306e-07\n",
      "k = 2, review 97, coalition [101, 434]: local jShapley = -7.520229588758555e-05\n",
      "k = 2, review 97, coalition [3, 174]: local jShapley = -1.1517876371268174e-06\n",
      "k = 2, review 97, coalition [269, 1003]: local jShapley = -5.395934730830764e-05\n",
      "k = 2, review 97, coalition [455, 848]: local jShapley = 5.8689766945913156e-05\n",
      "k = 2, review 97, coalition [209]: local jShapley = 0.00017557859142959098\n",
      "k = 2, review 97, coalition [978]: local jShapley = -9.471916997238386e-05\n",
      "k = 2, review 97, coalition [101]: local jShapley = -0.0005610184492366576\n",
      "k = 2, review 97, coalition [434]: local jShapley = -9.205315879508256e-05\n",
      "k = 2, review 97, coalition [3]: local jShapley = -0.00013063054980639555\n",
      "k = 2, review 97, coalition [174]: local jShapley = 4.196858588565387e-06\n",
      "k = 2, review 97, coalition [269]: local jShapley = -0.00019520296504640027\n",
      "k = 2, review 97, coalition [1003]: local jShapley = -7.248024590723756e-05\n",
      "k = 2, review 97, coalition [455]: local jShapley = 0.00023953569541355593\n",
      "k = 2, review 97, coalition [848]: local jShapley = -0.0006573861962308198\n",
      "k = 2, review 98, coalition [209, 978]: local jShapley = -8.819469878083499e-06\n",
      "k = 2, review 98, coalition [101, 434]: local jShapley = -1.704777214146003e-06\n",
      "k = 2, review 98, coalition [3, 174]: local jShapley = -1.015518379189183e-05\n",
      "k = 2, review 98, coalition [269, 1003]: local jShapley = -6.925422053815678e-07\n",
      "k = 2, review 98, coalition [455, 848]: local jShapley = -3.9119984872496493e-05\n",
      "k = 2, review 98, coalition [209]: local jShapley = 0.00015595027523543958\n",
      "k = 2, review 98, coalition [978]: local jShapley = -0.00013609401116262458\n",
      "k = 2, review 98, coalition [101]: local jShapley = -0.0004584206384615331\n",
      "k = 2, review 98, coalition [434]: local jShapley = -2.4490658783606897e-05\n",
      "k = 2, review 98, coalition [3]: local jShapley = -5.708405611187141e-05\n",
      "k = 2, review 98, coalition [174]: local jShapley = 4.213447130986863e-06\n",
      "k = 2, review 98, coalition [269]: local jShapley = -0.00044248307905891374\n",
      "k = 2, review 98, coalition [1003]: local jShapley = -1.6911571235981126e-05\n",
      "k = 2, review 98, coalition [455]: local jShapley = 0.0005265095048643813\n",
      "k = 2, review 98, coalition [848]: local jShapley = -0.0010993697853221686\n",
      "k = 2, review 99, coalition [209, 978]: local jShapley = 2.500765882966072e-06\n",
      "k = 2, review 99, coalition [101, 434]: local jShapley = -4.813173383412974e-05\n",
      "k = 2, review 99, coalition [3, 174]: local jShapley = 1.452387005263524e-06\n",
      "k = 2, review 99, coalition [269, 1003]: local jShapley = -2.7920430095680987e-05\n",
      "k = 2, review 99, coalition [455, 848]: local jShapley = 4.4253934133209476e-05\n",
      "k = 2, review 99, coalition [209]: local jShapley = 0.0001251765654175374\n",
      "k = 2, review 99, coalition [978]: local jShapley = -0.0001048931490530348\n",
      "k = 2, review 99, coalition [101]: local jShapley = -0.000485934505796369\n",
      "k = 2, review 99, coalition [434]: local jShapley = -2.1580414368302017e-05\n",
      "k = 2, review 99, coalition [3]: local jShapley = 3.079075795370171e-05\n",
      "k = 2, review 99, coalition [174]: local jShapley = 1.1370784846868691e-05\n",
      "k = 2, review 99, coalition [269]: local jShapley = -0.00015151000364086454\n",
      "k = 2, review 99, coalition [1003]: local jShapley = -3.146908331252394e-05\n",
      "k = 2, review 99, coalition [455]: local jShapley = 0.00042670656836047143\n",
      "k = 2, review 99, coalition [848]: local jShapley = -0.0003910646551790823\n"
     ]
    }
   ],
   "source": [
    "for n, review_oh in enumerate(oh_test.iloc):\n",
    "    for coalition in DSA_coalitions:\n",
    "        js = calculate_phi_t(\n",
    "            review_oh,\n",
    "            value_f,\n",
    "            coalition,\n",
    "            num_DSA_features,\n",
    "            q_values,\n",
    "            num_sampling_iterations\n",
    "        )\n",
    "        print(f'k = {k}, review {n}, coalition {coalition}: local jShapley = {js}')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7e3a018c-8507-4269-a23b-c29c1b4ffcc2",
   "metadata": {},
   "source": [
    "#### Also obtain Joint Shapley values for the target vocab"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "9f546506-5716-4ad8-80fd-82f228b05362",
   "metadata": {},
   "outputs": [],
   "source": [
    "target_vocab_DSA_scores = {}\n",
    "for key, ss_reviews in target_vocab_DSA.items():\n",
    "    scores = []\n",
    "    for review in ss_to_vc(ss_reviews, DSA_vectorizer):\n",
    "        try:\n",
    "            score = calculate_phi_t(\n",
    "                sample_review_oh,\n",
    "                value_f,\n",
    "                review,\n",
    "                num_DSA_features,\n",
    "                q_values,\n",
    "                num_sampling_iterations\n",
    "            )\n",
    "        except:\n",
    "            score = np.nan\n",
    "        scores.append(score)\n",
    "    target_vocab_DSA_scores[key] = scores"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "ea64ca4f-d79d-4889-a2d4-e41a8c0528c0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'t2dsa': [-8.450741946849841e-07,\n",
       "  3.116703822067041e-05,\n",
       "  -2.1688758331398024e-07,\n",
       "  -4.523688107136829e-05,\n",
       "  3.536020269738501e-05]}"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "target_vocab_DSA_scores"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4d3e0aba-5fa3-4c7e-ade0-8eb55753136b",
   "metadata": {},
   "source": [
    "#### Obtain local Joint Shapleys for the training set"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "afd7d9f4-813b-47bf-a565-ea6486ec3b7f",
   "metadata": {},
   "outputs": [],
   "source": [
    "local_js = []\n",
    "for review_vc in ss_to_vc(test_reviews_ss, DSA_vectorizer): \n",
    "    local_js.append(\n",
    "        calculate_phi_t(\n",
    "            sample_review_oh,\n",
    "            value_f,\n",
    "            review_vc,\n",
    "            num_DSA_features,\n",
    "            q_values,\n",
    "            num_sampling_iterations\n",
    "        )\n",
    "    )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "b25072f0-d143-4697-94f4-be959454250c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[-7.402459153879807e-07,\n",
       " -1.3678949492307517e-06,\n",
       " -1.1080664913381875e-05,\n",
       " -1.1236244416533324e-05,\n",
       " 4.330645862204569e-07,\n",
       " -1.228861955317951e-07,\n",
       " 1.0681923121222902e-06,\n",
       " -1.160797778545357e-05,\n",
       " -6.050747945754944e-07,\n",
       " -2.5867743711784743e-06,\n",
       " 2.2655398551014878e-07,\n",
       " -7.888861042691908e-07,\n",
       " -3.972665344648958e-06,\n",
       " 1.2370675424105868e-05,\n",
       " -1.3575481095945278e-06,\n",
       " -7.573600240587811e-07,\n",
       " -2.5901421454655703e-06,\n",
       " 1.35255635757637e-06,\n",
       " -2.261989164966636e-06,\n",
       " 1.0947966381797353e-06,\n",
       " 1.4659197825819656e-06,\n",
       " -1.0957644118733495e-06,\n",
       " 9.349390021555675e-09,\n",
       " 1.6133197548211296e-06,\n",
       " -8.613295497304406e-05,\n",
       " -6.110647657631004e-06,\n",
       " 3.335423390944894e-07,\n",
       " -3.68579690503407e-07,\n",
       " 3.31136159233496e-06,\n",
       " -2.6601624971077263e-06,\n",
       " -1.4803998726295828e-05,\n",
       " 1.296867650203927e-07,\n",
       " -2.799673424346092e-07,\n",
       " 8.160561470832455e-07,\n",
       " -4.560203744823152e-07,\n",
       " -1.0000839863972077e-06,\n",
       " -2.788643918913825e-06,\n",
       " -8.939362180664342e-06,\n",
       " 6.9136950065141095e-06,\n",
       " -2.330155943918116e-06,\n",
       " -4.5750574918159025e-06,\n",
       " -6.796777429614304e-06,\n",
       " -4.501938890378022e-08,\n",
       " -5.0889208776579374e-08,\n",
       " -1.8808542920095044e-07,\n",
       " -3.4278694849088085e-07,\n",
       " -5.509488727739745e-08,\n",
       " -1.2513795432892552e-06,\n",
       " -4.6222417990012105e-06,\n",
       " -3.2409193746683716e-06,\n",
       " 8.072836689029173e-06,\n",
       " 1.3878222106614698e-05,\n",
       " 2.736223668608938e-06,\n",
       " 2.6588914120161064e-07,\n",
       " -1.073701530523025e-06,\n",
       " 1.7569150177993834e-05,\n",
       " 5.041202081965139e-06,\n",
       " -2.0969363822703003e-06,\n",
       " -1.1920631945374223e-05,\n",
       " -1.214260205941428e-08,\n",
       " 5.703850402598357e-06,\n",
       " 5.463458598807189e-06,\n",
       " -6.136343262829275e-08,\n",
       " 1.0979277315380399e-05,\n",
       " -2.712447373239498e-07,\n",
       " 7.198059562430951e-08,\n",
       " -2.6003612174498994e-06,\n",
       " -9.637226445104492e-06,\n",
       " 3.6325484028784354e-06,\n",
       " 2.4593432415632993e-07,\n",
       " -1.3656903403131757e-09,\n",
       " 4.164582523225202e-07,\n",
       " 4.131059873022436e-08,\n",
       " 5.7278204998604935e-06,\n",
       " 5.231263928753219e-07,\n",
       " -1.2211931545953227e-06,\n",
       " 7.163759876085004e-06,\n",
       " 0.0001729245738963926,\n",
       " -1.67254594138181e-07,\n",
       " 0.000884232838399048,\n",
       " 2.1814440391320166e-06,\n",
       " 5.278868588776263e-07,\n",
       " 8.34942091793993e-08,\n",
       " 9.144458261021092e-06,\n",
       " 1.4827572029335093e-06,\n",
       " 1.3066732405633936e-06,\n",
       " -5.779347458321933e-07,\n",
       " 2.863204621874827e-07,\n",
       " 4.39503978301765e-06,\n",
       " 1.3372918570654326e-05,\n",
       " -1.5824111934895456e-06,\n",
       " 1.210100445118232e-05,\n",
       " -2.982617214785797e-10,\n",
       " -3.1449765103529066e-06,\n",
       " 2.500739188370418e-06,\n",
       " 1.1681926390365505e-06,\n",
       " 1.5708423403805741e-06,\n",
       " -2.037136520348618e-06,\n",
       " 1.5760372421883752e-05,\n",
       " 5.905004990486532e-08]"
      ]
     },
     "execution_count": 33,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "local_js"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "11931a47-f8d1-431a-8e6c-4700b706a05e",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
