{"cells":[{"cell_type":"markdown","metadata":{"id":"Ss4WkYFDOGTu"},"source":["# Contextual online advertising with user data from U.S. Census"]},{"cell_type":"markdown","metadata":{"id":"nAajOomTOSV6"},"source":["## Scenario\n","Consider an ad server that knows all of the information above about a user, except the education level. On the other hand, the ad network is managing ads that address a specific education level. For example, at any given time, the ad server has one ad that is targeting users with college education, one ad that is targeting users with elementary school education etc. If the target audience of the ad that is shown to a user matches the user's education level, there is a high probability of a click. If not, the probability of a click decreases gradually as the discrepancy between the target education level and the user's education level. In other words, the ad server is implicitly trying to predict users' education levels as close as possible."]},{"cell_type":"code","execution_count":null,"metadata":{"id":"sNtGmziSOCzY"},"outputs":[],"source":["from collections import namedtuple\n","from numpy.random import uniform as U\n","import pandas as pd\n","import numpy as np\n","import io\n","import requests\n","from tensorflow import keras\n","from tensorflow.keras.layers import Dense, Dropout"]},{"cell_type":"markdown","metadata":{"id":"BN7P31s6Nlbg"},"source":["## Data\n","\n","We will use a dataset that was modified from the 1994 U.S. Census and adapt it to an online advertising setting. The dataset is known as \"Census Income Dataset\" and available at https://archive.ics.uci.edu/ml/datasets/Census+Income.\n","\n","In this dataset we use the following information on the individuals participated in the census: Age, work class, education, marital status, occupation, relationship, race, gender, work hours per week, native country, and income level.\n","\n","With that, let's discuss how to turn this data into an online advertising scenario."]},{"cell_type":"code","execution_count":null,"metadata":{"id":"_J8jba_DOLre"},"outputs":[],"source":["url=\"https://archive.ics.uci.edu/ml/machine-learning-databases/adult/adult.data\"\n","s=requests.get(url).content\n","names = ['age', \n"," 'workclass', \n"," 'fnlwgt', \n"," 'education',\n"," 'education_num',\n"," 'marital_status',\n"," 'occupation',\n"," 'relationship',\n"," 'race',\n"," 'gender',\n"," 'capital_gain',\n"," 'capital_loss',\n"," 'hours_per_week',\n"," 'native_country',\n"," 'income']\n","usecols = ['age', \n"," 'workclass', \n"," 'education',\n"," 'marital_status',\n"," 'occupation',\n"," 'relationship',\n"," 'race',\n"," 'gender',\n"," 'hours_per_week',\n"," 'native_country',\n"," 'income']\n","df_census = pd.read_csv(io.StringIO(s.decode('utf-8')), \n"," sep=',',\n"," skipinitialspace=True,\n"," names=names,\n"," header=None,\n"," usecols=usecols)"]},{"cell_type":"markdown","metadata":{"id":"6AMRPeLXOvZi"},"source":["Next, let's prepare the data set for our scenario."]},{"cell_type":"code","execution_count":null,"metadata":{"id":"rMk4nUhLOfjl"},"outputs":[],"source":["# Cleanup\n","df_census = df_census.replace('?', np.nan).dropna()\n","edu_map = {'Preschool': 'Elementary',\n"," '1st-4th': 'Elementary',\n"," '5th-6th': 'Elementary',\n"," '7th-8th': 'Elementary',\n"," '9th': 'Middle',\n"," '10th': 'Middle',\n"," '11th': 'Middle',\n"," '12th': 'Middle',\n"," 'Some-college': 'Undergraduate',\n"," 'Bachelors': 'Undergraduate',\n"," 'Assoc-acdm': 'Undergraduate',\n"," 'Assoc-voc': 'Undergraduate',\n"," 'Prof-school': 'Graduate',\n"," 'Masters': 'Graduate',\n"," 'Doctorate': 'Graduate'}\n"," \n","for from_level, to_level in edu_map.items():\n"," df_census.education.replace(from_level, to_level, inplace=True)\n","\n","# Convert raw data to processed data\n","context_cols = [c for c in usecols if c != 'education']\n","df_data = pd.concat([pd.get_dummies(df_census[context_cols]),\n"," df_census['education']], axis=1)"]},{"cell_type":"markdown","metadata":{"id":"ntpHFmP0OxUm"},"source":["By doing this conversion at the beginning, we assume that we know all possible work class categories, native countries etc.\n","\n","That's it! We have the data ready. Next, we implement a logic to simulate an ad click based on the actual education level of the user and the education level the ad displayed targets."]},{"cell_type":"markdown","metadata":{"id":"gz8ZyCx-O1fs"},"source":["### Simulating ad clicks\n","In this example, the availability of ads is also random in addition to the ad clicks being stochastic. We need to come up with some logic to simulate this behavior. \n","\n","Let's start with determining the ad availability probabilities for each education category and implement the sampling of ads."]},{"cell_type":"code","execution_count":null,"metadata":{"id":"siw_xBqYPFIp"},"outputs":[],"source":["def get_ad_inventory():\n"," ad_inv_prob = {'Elementary': 0.9, \n"," 'Middle': 0.7, \n"," 'HS-grad': 0.7, \n"," 'Undergraduate': 0.9, \n"," 'Graduate': 0.8}\n"," ad_inventory = []\n"," for level, prob in ad_inv_prob.items():\n"," if U() < prob:\n"," ad_inventory.append(level)\n"," # Make sure there are at least one ad\n"," if not ad_inventory:\n"," ad_inventory = get_ad_inventory()\n"," return ad_inventory"]},{"cell_type":"markdown","metadata":{"id":"SNW09VX-PHXY"},"source":["As mentioned above, the ad server will have at most one ad for each target group. We also ensure that there is at least one ad in the inventory.\n","\n","Then, we define a function to generate a click probabilistically, where the likelihood of a click increases to the degree that the user's education level and the ad's target match."]},{"cell_type":"code","execution_count":null,"metadata":{"id":"tVd5ntyMPKw0"},"outputs":[],"source":["def get_ad_click_probs():\n"," base_prob = 0.8\n"," delta = 0.3\n"," ed_levels = {'Elementary': 1, \n"," 'Middle': 2, \n"," 'HS-grad': 3, \n"," 'Undergraduate': 4, \n"," 'Graduate': 5}\n"," ad_click_probs = {l1: {l2: max(0, base_prob - delta * abs(ed_levels[l1]- ed_levels[l2])) for l2 in ed_levels}\n"," for l1 in ed_levels}\n"," return ad_click_probs"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"GhJih_pyPNwl"},"outputs":[],"source":["def display_ad(ad_click_probs, user, ad):\n"," prob = ad_click_probs[ad][user['education']]\n"," click = 1 if U() < prob else 0\n"," return click"]},{"cell_type":"markdown","metadata":{"id":"lxEnZC7bPQtB"},"source":["So, when an ad is shown to a user, if the ad's target matches the user's education level, there will be chance of a click. This probability decreases by for each level of mismatch. For example, a person with a high school diploma has a chance to click on an ad that targets a user group of elementary school graduates (or college graduates). Note that this information is not known to the CB algorithm. It will be used only to simulate the clicks.\n","\n","We have the problem set up. Next, we turn to implementing a CB model."]},{"cell_type":"code","execution_count":null,"metadata":{"id":"Sj0E4CCQPYy0"},"outputs":[],"source":["def calc_regret(user, ad_inventory, ad_click_probs, ad_selected):\n"," this_p = 0\n"," max_p = 0\n"," for ad in ad_inventory:\n"," p = ad_click_probs[ad][user['education']]\n"," if ad == ad_selected:\n"," this_p = p\n"," if p > max_p:\n"," max_p = p\n"," regret = max_p - this_p\n"," return regret"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"vrwLopu9Pc9m"},"outputs":[],"source":["def get_model(n_input, dropout):\n"," inputs = keras.Input(shape=(n_input,))\n"," x = Dense(256, activation='relu')(inputs)\n"," if dropout > 0:\n"," x = Dropout(dropout)(x, training=True)\n"," x = Dense(256, activation='relu')(x)\n"," if dropout > 0:\n"," x = Dropout(dropout)(x, training=True)\n"," phat = Dense(1, activation='sigmoid')(x)\n"," model = keras.Model(inputs, phat)\n"," model.compile(loss=keras.losses.BinaryCrossentropy(),\n"," optimizer=keras.optimizers.Adam(),\n"," metrics=[keras.metrics.binary_accuracy])\n"," return model"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"XjfTZLr_Pb8A"},"outputs":[],"source":["def update_model(model, X, y):\n"," X = np.array(X)\n"," X = X.reshape((X.shape[0], X.shape[2]))\n"," y = np.array(y).reshape(-1)\n"," model.fit(X, y, epochs=10)\n"," return model"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"T6azuaN8PbJG"},"outputs":[],"source":["def ad_to_one_hot(ad):\n"," ed_levels = ['Elementary', \n"," 'Middle', \n"," 'HS-grad', \n"," 'Undergraduate', \n"," 'Graduate']\n"," ad_input = [0] * len(ed_levels)\n"," if ad in ed_levels:\n"," ad_input[ed_levels.index(ad)] = 1\n"," return ad_input"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"bt5SeP54PaaB"},"outputs":[],"source":["def select_ad(model, context, ad_inventory):\n"," selected_ad = None\n"," selected_x = None\n"," max_action_val = 0\n"," for ad in ad_inventory:\n"," ad_x = ad_to_one_hot(ad)\n"," x = np.array(context + ad_x).reshape((1, -1))\n"," action_val_pred = model.predict(x)[0][0]\n"," if action_val_pred >= max_action_val:\n"," selected_ad = ad\n"," selected_x = x\n"," max_action_val = action_val_pred\n"," return selected_ad, selected_x"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"e6e1-glpPZfw"},"outputs":[],"source":["def generate_user(df_data):\n"," user = df_data.sample(1)\n"," context = user.iloc[:, :-1].values.tolist()[0]\n"," return user.to_dict(orient='records')[0], context"]},{"cell_type":"code","execution_count":null,"metadata":{"colab":{"background_save":true,"base_uri":"https://localhost:8080/"},"id":"lyq_uwq7PkQl","outputId":"35832751-06fc-471d-842e-29b5a4fb9876","collapsed":true},"outputs":[{"name":"stdout","output_type":"stream","text":["Trying with dropout: 0\n","# of impressions: 0\n","# of impressions: 20\n","# of impressions: 40\n","# of impressions: 60\n","# of impressions: 80\n","# of impressions: 100\n","# of impressions: 120\n","# of impressions: 140\n","# of impressions: 160\n","# of impressions: 180\n","# of impressions: 200\n","# of impressions: 220\n","# of impressions: 240\n","# of impressions: 260\n","# of impressions: 280\n","# of impressions: 300\n","# of impressions: 320\n","# of impressions: 340\n","# of impressions: 360\n","# of impressions: 380\n","# of impressions: 400\n","# of impressions: 420\n","# of impressions: 440\n","# of impressions: 460\n","# of impressions: 480\n","Updating the model at 500\n","Epoch 1/10\n","16/16 [==============================] - 1s 3ms/step - loss: 0.8424 - binary_accuracy: 0.5600\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7275 - binary_accuracy: 0.5700\n","Epoch 3/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6772 - binary_accuracy: 0.6280\n","Epoch 4/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6462 - binary_accuracy: 0.6560\n","Epoch 5/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6463 - binary_accuracy: 0.6440\n","Epoch 6/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6442 - binary_accuracy: 0.6540\n","Epoch 7/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6532 - binary_accuracy: 0.6560\n","Epoch 8/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6247 - binary_accuracy: 0.6620\n","Epoch 9/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6254 - binary_accuracy: 0.6800\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6935 - binary_accuracy: 0.6100\n","# of impressions: 500\n","# of impressions: 520\n","# of impressions: 540\n","# of impressions: 560\n","# of impressions: 580\n","# of impressions: 600\n","# of impressions: 620\n","# of impressions: 640\n","# of impressions: 660\n","# of impressions: 680\n","# of impressions: 700\n","# of impressions: 720\n","# of impressions: 740\n","# of impressions: 760\n","# of impressions: 780\n","# of impressions: 800\n","# of impressions: 820\n","# of impressions: 840\n","# of impressions: 860\n","# of impressions: 880\n","# of impressions: 900\n","# of impressions: 920\n","# of impressions: 940\n","# of impressions: 960\n","# of impressions: 980\n","Updating the model at 1000\n","Epoch 1/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.7602 - binary_accuracy: 0.5100\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.8014 - binary_accuracy: 0.4860\n","Epoch 3/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.7363 - binary_accuracy: 0.5600\n","Epoch 4/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6868 - binary_accuracy: 0.5860\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6865 - binary_accuracy: 0.5420\n","Epoch 6/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6697 - binary_accuracy: 0.6020\n","Epoch 7/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6742 - binary_accuracy: 0.5760\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6855 - binary_accuracy: 0.5700\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6727 - binary_accuracy: 0.5840\n","Epoch 10/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6695 - binary_accuracy: 0.5940\n","# of impressions: 1000\n","# of impressions: 1020\n","# of impressions: 1040\n","# of impressions: 1060\n","# of impressions: 1080\n","# of impressions: 1100\n","# of impressions: 1120\n","# of impressions: 1140\n","# of impressions: 1160\n","# of impressions: 1180\n","# of impressions: 1200\n","# of impressions: 1220\n","# of impressions: 1240\n","# of impressions: 1260\n","# of impressions: 1280\n","# of impressions: 1300\n","# of impressions: 1320\n","# of impressions: 1340\n","# of impressions: 1360\n","# of impressions: 1380\n","# of impressions: 1400\n","# of impressions: 1420\n","# of impressions: 1440\n","# of impressions: 1460\n","# of impressions: 1480\n","Updating the model at 1500\n","Epoch 1/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.7112 - binary_accuracy: 0.4980\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7090 - binary_accuracy: 0.5460\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6822 - binary_accuracy: 0.5620\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6733 - binary_accuracy: 0.5980\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6872 - binary_accuracy: 0.5840\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6832 - binary_accuracy: 0.5740\n","Epoch 7/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6683 - binary_accuracy: 0.6000\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7067 - binary_accuracy: 0.5480\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6641 - binary_accuracy: 0.6240\n","Epoch 10/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6753 - binary_accuracy: 0.6000\n","# of impressions: 1500\n","# of impressions: 1520\n","# of impressions: 1540\n","# of impressions: 1560\n","# of impressions: 1580\n","# of impressions: 1600\n","# of impressions: 1620\n","# of impressions: 1640\n","# of impressions: 1660\n","# of impressions: 1680\n","# of impressions: 1700\n","# of impressions: 1720\n","# of impressions: 1740\n","# of impressions: 1760\n","# of impressions: 1780\n","# of impressions: 1800\n","# of impressions: 1820\n","# of impressions: 1840\n","# of impressions: 1860\n","# of impressions: 1880\n","# of impressions: 1900\n","# of impressions: 1920\n","# of impressions: 1940\n","# of impressions: 1960\n","# of impressions: 1980\n","Updating the model at 2000\n","Epoch 1/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.7047 - binary_accuracy: 0.5480\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6834 - binary_accuracy: 0.5920\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6927 - binary_accuracy: 0.5640\n","Epoch 4/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6886 - binary_accuracy: 0.5700\n","Epoch 5/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6585 - binary_accuracy: 0.6100\n","Epoch 6/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6880 - binary_accuracy: 0.5840\n","Epoch 7/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6924 - binary_accuracy: 0.5900\n","Epoch 8/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6759 - binary_accuracy: 0.5760\n","Epoch 9/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6593 - binary_accuracy: 0.6340\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6594 - binary_accuracy: 0.5740\n","# of impressions: 2000\n","# of impressions: 2020\n","# of impressions: 2040\n","# of impressions: 2060\n","# of impressions: 2080\n","# of impressions: 2100\n","# of impressions: 2120\n","# of impressions: 2140\n","# of impressions: 2160\n","# of impressions: 2180\n","# of impressions: 2200\n","# of impressions: 2220\n","# of impressions: 2240\n","# of impressions: 2260\n","# of impressions: 2280\n","# of impressions: 2300\n","# of impressions: 2320\n","# of impressions: 2340\n","# of impressions: 2360\n","# of impressions: 2380\n","# of impressions: 2400\n","# of impressions: 2420\n","# of impressions: 2440\n","# of impressions: 2460\n","# of impressions: 2480\n","Updating the model at 2500\n","Epoch 1/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6748 - binary_accuracy: 0.6140\n","Epoch 2/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6671 - binary_accuracy: 0.6380\n","Epoch 3/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6687 - binary_accuracy: 0.6200\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6667 - binary_accuracy: 0.6220\n","Epoch 5/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6570 - binary_accuracy: 0.6400\n","Epoch 6/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6470 - binary_accuracy: 0.6320\n","Epoch 7/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6573 - binary_accuracy: 0.6240\n","Epoch 8/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6706 - binary_accuracy: 0.6380\n","Epoch 9/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6372 - binary_accuracy: 0.6600\n","Epoch 10/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6384 - binary_accuracy: 0.6500\n","# of impressions: 2500\n","# of impressions: 2520\n","# of impressions: 2540\n","# of impressions: 2560\n","# of impressions: 2580\n","# of impressions: 2600\n","# of impressions: 2620\n","# of impressions: 2640\n","# of impressions: 2660\n","# of impressions: 2680\n","# of impressions: 2700\n","# of impressions: 2720\n","# of impressions: 2740\n","# of impressions: 2760\n","# of impressions: 2780\n","# of impressions: 2800\n","# of impressions: 2820\n","# of impressions: 2840\n","# of impressions: 2860\n","# of impressions: 2880\n","# of impressions: 2900\n","# of impressions: 2920\n","# of impressions: 2940\n","# of impressions: 2960\n","# of impressions: 2980\n","Updating the model at 3000\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7047 - binary_accuracy: 0.5280\n","Epoch 2/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6950 - binary_accuracy: 0.6000\n","Epoch 3/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6773 - binary_accuracy: 0.5880\n","Epoch 4/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6734 - binary_accuracy: 0.5920\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6644 - binary_accuracy: 0.5960\n","Epoch 6/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6815 - binary_accuracy: 0.5880\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6714 - binary_accuracy: 0.5920\n","Epoch 8/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6674 - binary_accuracy: 0.6000\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6491 - binary_accuracy: 0.6460\n","Epoch 10/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6584 - binary_accuracy: 0.6120\n","# of impressions: 3000\n","# of impressions: 3020\n","# of impressions: 3040\n","# of impressions: 3060\n","# of impressions: 3080\n","# of impressions: 3100\n","# of impressions: 3120\n","# of impressions: 3140\n","# of impressions: 3160\n","# of impressions: 3180\n","# of impressions: 3200\n","# of impressions: 3220\n","# of impressions: 3240\n","# of impressions: 3260\n","# of impressions: 3280\n","# of impressions: 3300\n","# of impressions: 3320\n","# of impressions: 3340\n","# of impressions: 3360\n","# of impressions: 3380\n","# of impressions: 3400\n","# of impressions: 3420\n","# of impressions: 3440\n","# of impressions: 3460\n","# of impressions: 3480\n","Updating the model at 3500\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7192 - binary_accuracy: 0.5240\n","Epoch 2/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6999 - binary_accuracy: 0.5240\n","Epoch 3/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6960 - binary_accuracy: 0.5520\n","Epoch 4/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6843 - binary_accuracy: 0.5440\n","Epoch 5/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6735 - binary_accuracy: 0.5940\n","Epoch 6/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6647 - binary_accuracy: 0.5920\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6557 - binary_accuracy: 0.5900\n","Epoch 8/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6777 - binary_accuracy: 0.5760\n","Epoch 9/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6630 - binary_accuracy: 0.5920\n","Epoch 10/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6650 - binary_accuracy: 0.5980\n","# of impressions: 3500\n","# of impressions: 3520\n","# of impressions: 3540\n","# of impressions: 3560\n","# of impressions: 3580\n","# of impressions: 3600\n","# of impressions: 3620\n","# of impressions: 3640\n","# of impressions: 3660\n","# of impressions: 3680\n","# of impressions: 3700\n","# of impressions: 3720\n","# of impressions: 3740\n","# of impressions: 3760\n","# of impressions: 3780\n","# of impressions: 3800\n","# of impressions: 3820\n","# of impressions: 3840\n","# of impressions: 3860\n","# of impressions: 3880\n","# of impressions: 3900\n","# of impressions: 3920\n","# of impressions: 3940\n","# of impressions: 3960\n","# of impressions: 3980\n","Updating the model at 4000\n","Epoch 1/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.7114 - binary_accuracy: 0.5680\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7233 - binary_accuracy: 0.5420\n","Epoch 3/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.7212 - binary_accuracy: 0.4840\n","Epoch 4/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.7029 - binary_accuracy: 0.5300\n","Epoch 5/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6793 - binary_accuracy: 0.5960\n","Epoch 6/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6729 - binary_accuracy: 0.6140\n","Epoch 7/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6804 - binary_accuracy: 0.5740\n","Epoch 8/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6612 - binary_accuracy: 0.5900\n","Epoch 9/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6541 - binary_accuracy: 0.6220\n","Epoch 10/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6443 - binary_accuracy: 0.6120\n","# of impressions: 4000\n","# of impressions: 4020\n","# of impressions: 4040\n","# of impressions: 4060\n","# of impressions: 4080\n","# of impressions: 4100\n","# of impressions: 4120\n","# of impressions: 4140\n","# of impressions: 4160\n","# of impressions: 4180\n","# of impressions: 4200\n","# of impressions: 4220\n","# of impressions: 4240\n","# of impressions: 4260\n","# of impressions: 4280\n","# of impressions: 4300\n","# of impressions: 4320\n","# of impressions: 4340\n","# of impressions: 4360\n","# of impressions: 4380\n","# of impressions: 4400\n","# of impressions: 4420\n","# of impressions: 4440\n","# of impressions: 4460\n","# of impressions: 4480\n","Updating the model at 4500\n","Epoch 1/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.7017 - binary_accuracy: 0.5300\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6915 - binary_accuracy: 0.5300\n","Epoch 3/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6861 - binary_accuracy: 0.5660\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6814 - binary_accuracy: 0.5720\n","Epoch 5/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6816 - binary_accuracy: 0.5900\n","Epoch 6/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6762 - binary_accuracy: 0.5940\n","Epoch 7/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6685 - binary_accuracy: 0.5960\n","Epoch 8/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6679 - binary_accuracy: 0.6160\n","Epoch 9/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6638 - binary_accuracy: 0.6180\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6589 - binary_accuracy: 0.6040\n","# of impressions: 4500\n","# of impressions: 4520\n","# of impressions: 4540\n","# of impressions: 4560\n","# of impressions: 4580\n","# of impressions: 4600\n","# of impressions: 4620\n","# of impressions: 4640\n","# of impressions: 4660\n","# of impressions: 4680\n","# of impressions: 4700\n","# of impressions: 4720\n","# of impressions: 4740\n","# of impressions: 4760\n","# of impressions: 4780\n","# of impressions: 4800\n","# of impressions: 4820\n","# of impressions: 4840\n","# of impressions: 4860\n","# of impressions: 4880\n","# of impressions: 4900\n","# of impressions: 4920\n","# of impressions: 4940\n","# of impressions: 4960\n","# of impressions: 4980\n","Updating the model at 5000\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6787 - binary_accuracy: 0.6060\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6713 - binary_accuracy: 0.6220\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6632 - binary_accuracy: 0.6220\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6589 - binary_accuracy: 0.6240\n","Epoch 5/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6574 - binary_accuracy: 0.6320\n","Epoch 6/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6572 - binary_accuracy: 0.6160\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6503 - binary_accuracy: 0.6300\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6458 - binary_accuracy: 0.6380\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6434 - binary_accuracy: 0.6400\n","Epoch 10/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6428 - binary_accuracy: 0.6400\n","Trying with dropout: 0.01\n","# of impressions: 0\n","# of impressions: 20\n","# of impressions: 40\n","# of impressions: 60\n","# of impressions: 80\n","# of impressions: 100\n","# of impressions: 120\n","# of impressions: 140\n","# of impressions: 160\n","# of impressions: 180\n","# of impressions: 200\n","# of impressions: 220\n","# of impressions: 240\n","# of impressions: 260\n","# of impressions: 280\n","# of impressions: 300\n","# of impressions: 320\n","# of impressions: 340\n","# of impressions: 360\n","# of impressions: 380\n","# of impressions: 400\n","# of impressions: 420\n","# of impressions: 440\n","# of impressions: 460\n","# of impressions: 480\n","Updating the model at 500\n","Epoch 1/10\n","16/16 [==============================] - 1s 3ms/step - loss: 1.5034 - binary_accuracy: 0.5400\n","Epoch 2/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.7648 - binary_accuracy: 0.5500\n","Epoch 3/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6662 - binary_accuracy: 0.5960\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7367 - binary_accuracy: 0.5400\n","Epoch 5/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.7202 - binary_accuracy: 0.5600\n","Epoch 6/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6967 - binary_accuracy: 0.5980\n","Epoch 7/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6763 - binary_accuracy: 0.5960\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7087 - binary_accuracy: 0.5440\n","Epoch 9/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6692 - binary_accuracy: 0.6100\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7623 - binary_accuracy: 0.5580\n","# of impressions: 500\n","# of impressions: 520\n","# of impressions: 540\n","# of impressions: 560\n","# of impressions: 580\n","# of impressions: 600\n","# of impressions: 620\n","# of impressions: 640\n","# of impressions: 660\n","# of impressions: 680\n","# of impressions: 700\n","# of impressions: 720\n","# of impressions: 740\n","# of impressions: 760\n","# of impressions: 780\n","# of impressions: 800\n","# of impressions: 820\n","# of impressions: 840\n","# of impressions: 860\n","# of impressions: 880\n","# of impressions: 900\n","# of impressions: 920\n","# of impressions: 940\n","# of impressions: 960\n","# of impressions: 980\n","Updating the model at 1000\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7131 - binary_accuracy: 0.5240\n","Epoch 2/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.7190 - binary_accuracy: 0.5260\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7115 - binary_accuracy: 0.5520\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6994 - binary_accuracy: 0.5300\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7226 - binary_accuracy: 0.5380\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7089 - binary_accuracy: 0.5420\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6813 - binary_accuracy: 0.5640\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6568 - binary_accuracy: 0.6100\n","Epoch 9/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.7108 - binary_accuracy: 0.5700\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7122 - binary_accuracy: 0.5660\n","# of impressions: 1000\n","# of impressions: 1020\n","# of impressions: 1040\n","# of impressions: 1060\n","# of impressions: 1080\n","# of impressions: 1100\n","# of impressions: 1120\n","# of impressions: 1140\n","# of impressions: 1160\n","# of impressions: 1180\n","# of impressions: 1200\n","# of impressions: 1220\n","# of impressions: 1240\n","# of impressions: 1260\n","# of impressions: 1280\n","# of impressions: 1300\n","# of impressions: 1320\n","# of impressions: 1340\n","# of impressions: 1360\n","# of impressions: 1380\n","# of impressions: 1400\n","# of impressions: 1420\n","# of impressions: 1440\n","# of impressions: 1460\n","# of impressions: 1480\n","Updating the model at 1500\n","Epoch 1/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.7689 - binary_accuracy: 0.5080\n","Epoch 2/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.7372 - binary_accuracy: 0.5600\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6954 - binary_accuracy: 0.5660\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6958 - binary_accuracy: 0.5720\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6695 - binary_accuracy: 0.5880\n","Epoch 6/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6546 - binary_accuracy: 0.6360\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6767 - binary_accuracy: 0.5960\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6611 - binary_accuracy: 0.6040\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6645 - binary_accuracy: 0.6140\n","Epoch 10/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.7341 - binary_accuracy: 0.5540\n","# of impressions: 1500\n","# of impressions: 1520\n","# of impressions: 1540\n","# of impressions: 1560\n","# of impressions: 1580\n","# of impressions: 1600\n","# of impressions: 1620\n","# of impressions: 1640\n","# of impressions: 1660\n","# of impressions: 1680\n","# of impressions: 1700\n","# of impressions: 1720\n","# of impressions: 1740\n","# of impressions: 1760\n","# of impressions: 1780\n","# of impressions: 1800\n","# of impressions: 1820\n","# of impressions: 1840\n","# of impressions: 1860\n","# of impressions: 1880\n","# of impressions: 1900\n","# of impressions: 1920\n","# of impressions: 1940\n","# of impressions: 1960\n","# of impressions: 1980\n","Updating the model at 2000\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7322 - binary_accuracy: 0.5600\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7008 - binary_accuracy: 0.5800\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6948 - binary_accuracy: 0.5680\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6803 - binary_accuracy: 0.5780\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6858 - binary_accuracy: 0.5920\n","Epoch 6/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6883 - binary_accuracy: 0.5560\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6837 - binary_accuracy: 0.5940\n","Epoch 8/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6399 - binary_accuracy: 0.6280\n","Epoch 9/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6560 - binary_accuracy: 0.6340\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6643 - binary_accuracy: 0.5980\n","# of impressions: 2000\n","# of impressions: 2020\n","# of impressions: 2040\n","# of impressions: 2060\n","# of impressions: 2080\n","# of impressions: 2100\n","# of impressions: 2120\n","# of impressions: 2140\n","# of impressions: 2160\n","# of impressions: 2180\n","# of impressions: 2200\n","# of impressions: 2220\n","# of impressions: 2240\n","# of impressions: 2260\n","# of impressions: 2280\n","# of impressions: 2300\n","# of impressions: 2320\n","# of impressions: 2340\n","# of impressions: 2360\n","# of impressions: 2380\n","# of impressions: 2400\n","# of impressions: 2420\n","# of impressions: 2440\n","# of impressions: 2460\n","# of impressions: 2480\n","Updating the model at 2500\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6871 - binary_accuracy: 0.5940\n","Epoch 2/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6683 - binary_accuracy: 0.6340\n","Epoch 3/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6588 - binary_accuracy: 0.6400\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6966 - binary_accuracy: 0.5480\n","Epoch 5/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6862 - binary_accuracy: 0.6120\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6529 - binary_accuracy: 0.6420\n","Epoch 7/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6500 - binary_accuracy: 0.6520\n","Epoch 8/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6326 - binary_accuracy: 0.6520\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6464 - binary_accuracy: 0.6320\n","Epoch 10/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6301 - binary_accuracy: 0.6540\n","# of impressions: 2500\n","# of impressions: 2520\n","# of impressions: 2540\n","# of impressions: 2560\n","# of impressions: 2580\n","# of impressions: 2600\n","# of impressions: 2620\n","# of impressions: 2640\n","# of impressions: 2660\n","# of impressions: 2680\n","# of impressions: 2700\n","# of impressions: 2720\n","# of impressions: 2740\n","# of impressions: 2760\n","# of impressions: 2780\n","# of impressions: 2800\n","# of impressions: 2820\n","# of impressions: 2840\n","# of impressions: 2860\n","# of impressions: 2880\n","# of impressions: 2900\n","# of impressions: 2920\n","# of impressions: 2940\n","# of impressions: 2960\n","# of impressions: 2980\n","Updating the model at 3000\n","Epoch 1/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6894 - binary_accuracy: 0.5820\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6624 - binary_accuracy: 0.6040\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6543 - binary_accuracy: 0.6140\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6708 - binary_accuracy: 0.5960\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6855 - binary_accuracy: 0.5940\n","Epoch 6/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6892 - binary_accuracy: 0.6000\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6642 - binary_accuracy: 0.6040\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6752 - binary_accuracy: 0.5820\n","Epoch 9/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6389 - binary_accuracy: 0.6220\n","Epoch 10/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6285 - binary_accuracy: 0.6640\n","# of impressions: 3000\n","# of impressions: 3020\n","# of impressions: 3040\n","# of impressions: 3060\n","# of impressions: 3080\n","# of impressions: 3100\n","# of impressions: 3120\n","# of impressions: 3140\n","# of impressions: 3160\n","# of impressions: 3180\n","# of impressions: 3200\n","# of impressions: 3220\n","# of impressions: 3240\n","# of impressions: 3260\n","# of impressions: 3280\n","# of impressions: 3300\n","# of impressions: 3320\n","# of impressions: 3340\n","# of impressions: 3360\n","# of impressions: 3380\n","# of impressions: 3400\n","# of impressions: 3420\n","# of impressions: 3440\n","# of impressions: 3460\n","# of impressions: 3480\n","Updating the model at 3500\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6938 - binary_accuracy: 0.6000\n","Epoch 2/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6976 - binary_accuracy: 0.5820\n","Epoch 3/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6909 - binary_accuracy: 0.5880\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6727 - binary_accuracy: 0.5840\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6619 - binary_accuracy: 0.6220\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6533 - binary_accuracy: 0.6040\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6569 - binary_accuracy: 0.6200\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6566 - binary_accuracy: 0.6340\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6500 - binary_accuracy: 0.6320\n","Epoch 10/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6476 - binary_accuracy: 0.6240\n","# of impressions: 3500\n","# of impressions: 3520\n","# of impressions: 3540\n","# of impressions: 3560\n","# of impressions: 3580\n","# of impressions: 3600\n","# of impressions: 3620\n","# of impressions: 3640\n","# of impressions: 3660\n","# of impressions: 3680\n","# of impressions: 3700\n","# of impressions: 3720\n","# of impressions: 3740\n","# of impressions: 3760\n","# of impressions: 3780\n","# of impressions: 3800\n","# of impressions: 3820\n","# of impressions: 3840\n","# of impressions: 3860\n","# of impressions: 3880\n","# of impressions: 3900\n","# of impressions: 3920\n","# of impressions: 3940\n","# of impressions: 3960\n","# of impressions: 3980\n","Updating the model at 4000\n","Epoch 1/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6862 - binary_accuracy: 0.5920\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6774 - binary_accuracy: 0.6360\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6600 - binary_accuracy: 0.6060\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6576 - binary_accuracy: 0.6200\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6465 - binary_accuracy: 0.6420\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6671 - binary_accuracy: 0.5920\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6541 - binary_accuracy: 0.6160\n","Epoch 8/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6515 - binary_accuracy: 0.6220\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6366 - binary_accuracy: 0.6400\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6327 - binary_accuracy: 0.6480\n","# of impressions: 4000\n","# of impressions: 4020\n","# of impressions: 4040\n","# of impressions: 4060\n","# of impressions: 4080\n","# of impressions: 4100\n","# of impressions: 4120\n","# of impressions: 4140\n","# of impressions: 4160\n","# of impressions: 4180\n","# of impressions: 4200\n","# of impressions: 4220\n","# of impressions: 4240\n","# of impressions: 4260\n","# of impressions: 4280\n","# of impressions: 4300\n","# of impressions: 4320\n","# of impressions: 4340\n","# of impressions: 4360\n","# of impressions: 4380\n","# of impressions: 4400\n","# of impressions: 4420\n","# of impressions: 4440\n","# of impressions: 4460\n","# of impressions: 4480\n","Updating the model at 4500\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6963 - binary_accuracy: 0.5540\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6808 - binary_accuracy: 0.5780\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6785 - binary_accuracy: 0.5780\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6676 - binary_accuracy: 0.6020\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6620 - binary_accuracy: 0.6040\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6663 - binary_accuracy: 0.5780\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6683 - binary_accuracy: 0.5800\n","Epoch 8/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6672 - binary_accuracy: 0.5840\n","Epoch 9/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6665 - binary_accuracy: 0.5800\n","Epoch 10/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6581 - binary_accuracy: 0.6000\n","# of impressions: 4500\n","# of impressions: 4520\n","# of impressions: 4540\n","# of impressions: 4560\n","# of impressions: 4580\n","# of impressions: 4600\n","# of impressions: 4620\n","# of impressions: 4640\n","# of impressions: 4660\n","# of impressions: 4680\n","# of impressions: 4700\n","# of impressions: 4720\n","# of impressions: 4740\n","# of impressions: 4760\n","# of impressions: 4780\n","# of impressions: 4800\n","# of impressions: 4820\n","# of impressions: 4840\n","# of impressions: 4860\n","# of impressions: 4880\n","# of impressions: 4900\n","# of impressions: 4920\n","# of impressions: 4940\n","# of impressions: 4960\n","# of impressions: 4980\n","Updating the model at 5000\n","Epoch 1/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.7103 - binary_accuracy: 0.5280\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6982 - binary_accuracy: 0.5580\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6724 - binary_accuracy: 0.5960\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6622 - binary_accuracy: 0.6160\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6637 - binary_accuracy: 0.6060\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6502 - binary_accuracy: 0.6440\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6495 - binary_accuracy: 0.6200\n","Epoch 8/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6643 - binary_accuracy: 0.5860\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6513 - binary_accuracy: 0.6220\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6470 - binary_accuracy: 0.6320\n","Trying with dropout: 0.05\n","# of impressions: 0\n","# of impressions: 20\n","# of impressions: 40\n","# of impressions: 60\n","# of impressions: 80\n","# of impressions: 100\n","# of impressions: 120\n","# of impressions: 140\n","# of impressions: 160\n","# of impressions: 180\n","# of impressions: 200\n","# of impressions: 220\n","# of impressions: 240\n","# of impressions: 260\n","# of impressions: 280\n","# of impressions: 300\n","# of impressions: 320\n","# of impressions: 340\n","# of impressions: 360\n","# of impressions: 380\n","# of impressions: 400\n","# of impressions: 420\n","# of impressions: 440\n","# of impressions: 460\n","# of impressions: 480\n","Updating the model at 500\n","Epoch 1/10\n","16/16 [==============================] - 1s 3ms/step - loss: 0.8016 - binary_accuracy: 0.5700\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.8029 - binary_accuracy: 0.5700\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7046 - binary_accuracy: 0.6120\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6696 - binary_accuracy: 0.6200\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6876 - binary_accuracy: 0.5980\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6445 - binary_accuracy: 0.6280\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6531 - binary_accuracy: 0.6180\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6353 - binary_accuracy: 0.6460\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6844 - binary_accuracy: 0.6080\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6466 - binary_accuracy: 0.6560\n","# of impressions: 500\n","# of impressions: 520\n","# of impressions: 540\n","# of impressions: 560\n","# of impressions: 580\n","# of impressions: 600\n","# of impressions: 620\n","# of impressions: 640\n","# of impressions: 660\n","# of impressions: 680\n","# of impressions: 700\n","# of impressions: 720\n","# of impressions: 740\n","# of impressions: 760\n","# of impressions: 780\n","# of impressions: 800\n","# of impressions: 820\n","# of impressions: 840\n","# of impressions: 860\n","# of impressions: 880\n","# of impressions: 900\n","# of impressions: 920\n","# of impressions: 940\n","# of impressions: 960\n","# of impressions: 980\n","Updating the model at 1000\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7171 - binary_accuracy: 0.5400\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7333 - binary_accuracy: 0.5060\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6868 - binary_accuracy: 0.5580\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6944 - binary_accuracy: 0.5540\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6704 - binary_accuracy: 0.5760\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6894 - binary_accuracy: 0.5620\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6757 - binary_accuracy: 0.5660\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6497 - binary_accuracy: 0.6080\n","Epoch 9/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6460 - binary_accuracy: 0.6240\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6662 - binary_accuracy: 0.5700\n","# of impressions: 1000\n","# of impressions: 1020\n","# of impressions: 1040\n","# of impressions: 1060\n","# of impressions: 1080\n","# of impressions: 1100\n","# of impressions: 1120\n","# of impressions: 1140\n","# of impressions: 1160\n","# of impressions: 1180\n","# of impressions: 1200\n","# of impressions: 1220\n","# of impressions: 1240\n","# of impressions: 1260\n","# of impressions: 1280\n","# of impressions: 1300\n","# of impressions: 1320\n","# of impressions: 1340\n","# of impressions: 1360\n","# of impressions: 1380\n","# of impressions: 1400\n","# of impressions: 1420\n","# of impressions: 1440\n","# of impressions: 1460\n","# of impressions: 1480\n","Updating the model at 1500\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7188 - binary_accuracy: 0.5440\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6956 - binary_accuracy: 0.5680\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7030 - binary_accuracy: 0.5560\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6991 - binary_accuracy: 0.5640\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6999 - binary_accuracy: 0.5540\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6921 - binary_accuracy: 0.5700\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6708 - binary_accuracy: 0.5980\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6667 - binary_accuracy: 0.6000\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6702 - binary_accuracy: 0.6000\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6865 - binary_accuracy: 0.5700\n","# of impressions: 1500\n","# of impressions: 1520\n","# of impressions: 1540\n","# of impressions: 1560\n","# of impressions: 1580\n","# of impressions: 1600\n","# of impressions: 1620\n","# of impressions: 1640\n","# of impressions: 1660\n","# of impressions: 1680\n","# of impressions: 1700\n","# of impressions: 1720\n","# of impressions: 1740\n","# of impressions: 1760\n","# of impressions: 1780\n","# of impressions: 1800\n","# of impressions: 1820\n","# of impressions: 1840\n","# of impressions: 1860\n","# of impressions: 1880\n","# of impressions: 1900\n","# of impressions: 1920\n","# of impressions: 1940\n","# of impressions: 1960\n","# of impressions: 1980\n","Updating the model at 2000\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7352 - binary_accuracy: 0.5580\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6909 - binary_accuracy: 0.5500\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7130 - binary_accuracy: 0.5740\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6912 - binary_accuracy: 0.5460\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6799 - binary_accuracy: 0.5900\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6799 - binary_accuracy: 0.5980\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6567 - binary_accuracy: 0.6140\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6618 - binary_accuracy: 0.6120\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6665 - binary_accuracy: 0.6060\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7091 - binary_accuracy: 0.5680\n","# of impressions: 2000\n","# of impressions: 2020\n","# of impressions: 2040\n","# of impressions: 2060\n","# of impressions: 2080\n","# of impressions: 2100\n","# of impressions: 2120\n","# of impressions: 2140\n","# of impressions: 2160\n","# of impressions: 2180\n","# of impressions: 2200\n","# of impressions: 2220\n","# of impressions: 2240\n","# of impressions: 2260\n","# of impressions: 2280\n","# of impressions: 2300\n","# of impressions: 2320\n","# of impressions: 2340\n","# of impressions: 2360\n","# of impressions: 2380\n","# of impressions: 2400\n","# of impressions: 2420\n","# of impressions: 2440\n","# of impressions: 2460\n","# of impressions: 2480\n","Updating the model at 2500\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7086 - binary_accuracy: 0.5400\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6824 - binary_accuracy: 0.5800\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6741 - binary_accuracy: 0.6040\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6949 - binary_accuracy: 0.5620\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6811 - binary_accuracy: 0.5780\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6588 - binary_accuracy: 0.5980\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7057 - binary_accuracy: 0.5560\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7061 - binary_accuracy: 0.5580\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6653 - binary_accuracy: 0.6200\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6638 - binary_accuracy: 0.6020\n","# of impressions: 2500\n","# of impressions: 2520\n","# of impressions: 2540\n","# of impressions: 2560\n","# of impressions: 2580\n","# of impressions: 2600\n","# of impressions: 2620\n","# of impressions: 2640\n","# of impressions: 2660\n","# of impressions: 2680\n","# of impressions: 2700\n","# of impressions: 2720\n","# of impressions: 2740\n","# of impressions: 2760\n","# of impressions: 2780\n","# of impressions: 2800\n","# of impressions: 2820\n","# of impressions: 2840\n","# of impressions: 2860\n","# of impressions: 2880\n","# of impressions: 2900\n","# of impressions: 2920\n","# of impressions: 2940\n","# of impressions: 2960\n","# of impressions: 2980\n","Updating the model at 3000\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6878 - binary_accuracy: 0.5820\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6770 - binary_accuracy: 0.5720\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6869 - binary_accuracy: 0.5700\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6680 - binary_accuracy: 0.5860\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6654 - binary_accuracy: 0.5980\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6540 - binary_accuracy: 0.6400\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6570 - binary_accuracy: 0.6220\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6701 - binary_accuracy: 0.6120\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6388 - binary_accuracy: 0.6360\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6397 - binary_accuracy: 0.6520\n","# of impressions: 3000\n","# of impressions: 3020\n","# of impressions: 3040\n","# of impressions: 3060\n","# of impressions: 3080\n","# of impressions: 3100\n","# of impressions: 3120\n","# of impressions: 3140\n","# of impressions: 3160\n","# of impressions: 3180\n","# of impressions: 3200\n","# of impressions: 3220\n","# of impressions: 3240\n","# of impressions: 3260\n","# of impressions: 3280\n","# of impressions: 3300\n","# of impressions: 3320\n","# of impressions: 3340\n","# of impressions: 3360\n","# of impressions: 3380\n","# of impressions: 3400\n","# of impressions: 3420\n","# of impressions: 3440\n","# of impressions: 3460\n","# of impressions: 3480\n","Updating the model at 3500\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7046 - binary_accuracy: 0.5380\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6993 - binary_accuracy: 0.5480\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7059 - binary_accuracy: 0.5420\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6962 - binary_accuracy: 0.5480\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6715 - binary_accuracy: 0.5800\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6710 - binary_accuracy: 0.5800\n","Epoch 7/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6701 - binary_accuracy: 0.5800\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6563 - binary_accuracy: 0.6020\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6519 - binary_accuracy: 0.6060\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6578 - binary_accuracy: 0.6160\n","# of impressions: 3500\n","# of impressions: 3520\n","# of impressions: 3540\n","# of impressions: 3560\n","# of impressions: 3580\n","# of impressions: 3600\n","# of impressions: 3620\n","# of impressions: 3640\n","# of impressions: 3660\n","# of impressions: 3680\n","# of impressions: 3700\n","# of impressions: 3720\n","# of impressions: 3740\n","# of impressions: 3760\n","# of impressions: 3780\n","# of impressions: 3800\n","# of impressions: 3820\n","# of impressions: 3840\n","# of impressions: 3860\n","# of impressions: 3880\n","# of impressions: 3900\n","# of impressions: 3920\n","# of impressions: 3940\n","# of impressions: 3960\n","# of impressions: 3980\n","Updating the model at 4000\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6873 - binary_accuracy: 0.5660\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6753 - binary_accuracy: 0.5680\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6653 - binary_accuracy: 0.5880\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6629 - binary_accuracy: 0.5880\n","Epoch 5/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6724 - binary_accuracy: 0.5780\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6657 - binary_accuracy: 0.6000\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6574 - binary_accuracy: 0.5760\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6437 - binary_accuracy: 0.6240\n","Epoch 9/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6496 - binary_accuracy: 0.6100\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6472 - binary_accuracy: 0.6380\n","# of impressions: 4000\n","# of impressions: 4020\n","# of impressions: 4040\n","# of impressions: 4060\n","# of impressions: 4080\n","# of impressions: 4100\n","# of impressions: 4120\n","# of impressions: 4140\n","# of impressions: 4160\n","# of impressions: 4180\n","# of impressions: 4200\n","# of impressions: 4220\n","# of impressions: 4240\n","# of impressions: 4260\n","# of impressions: 4280\n","# of impressions: 4300\n","# of impressions: 4320\n","# of impressions: 4340\n","# of impressions: 4360\n","# of impressions: 4380\n","# of impressions: 4400\n","# of impressions: 4420\n","# of impressions: 4440\n","# of impressions: 4460\n","# of impressions: 4480\n","Updating the model at 4500\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7081 - binary_accuracy: 0.5620\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6928 - binary_accuracy: 0.5540\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6886 - binary_accuracy: 0.5860\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6752 - binary_accuracy: 0.5760\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6925 - binary_accuracy: 0.5640\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6689 - binary_accuracy: 0.5700\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6720 - binary_accuracy: 0.5740\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6671 - binary_accuracy: 0.5940\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6657 - binary_accuracy: 0.5920\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6640 - binary_accuracy: 0.6080\n","# of impressions: 4500\n","# of impressions: 4520\n","# of impressions: 4540\n","# of impressions: 4560\n","# of impressions: 4580\n","# of impressions: 4600\n","# of impressions: 4620\n","# of impressions: 4640\n","# of impressions: 4660\n","# of impressions: 4680\n","# of impressions: 4700\n","# of impressions: 4720\n","# of impressions: 4740\n","# of impressions: 4760\n","# of impressions: 4780\n","# of impressions: 4800\n","# of impressions: 4820\n","# of impressions: 4840\n","# of impressions: 4860\n","# of impressions: 4880\n","# of impressions: 4900\n","# of impressions: 4920\n","# of impressions: 4940\n","# of impressions: 4960\n","# of impressions: 4980\n","Updating the model at 5000\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6828 - binary_accuracy: 0.5960\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6700 - binary_accuracy: 0.5820\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6599 - binary_accuracy: 0.6040\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6520 - binary_accuracy: 0.6240\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6579 - binary_accuracy: 0.6220\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6452 - binary_accuracy: 0.6380\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6448 - binary_accuracy: 0.6220\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6395 - binary_accuracy: 0.6420\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6481 - binary_accuracy: 0.6020\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6379 - binary_accuracy: 0.6520\n","Trying with dropout: 0.1\n","# of impressions: 0\n","# of impressions: 20\n","# of impressions: 40\n","# of impressions: 60\n","# of impressions: 80\n","# of impressions: 100\n","# of impressions: 120\n","# of impressions: 140\n","# of impressions: 160\n","# of impressions: 180\n","# of impressions: 200\n","# of impressions: 220\n","# of impressions: 240\n","# of impressions: 260\n","# of impressions: 280\n","# of impressions: 300\n","# of impressions: 320\n","# of impressions: 340\n","# of impressions: 360\n","# of impressions: 380\n","# of impressions: 400\n","# of impressions: 420\n","# of impressions: 440\n","# of impressions: 460\n","# of impressions: 480\n","Updating the model at 500\n","Epoch 1/10\n","16/16 [==============================] - 1s 3ms/step - loss: 0.9884 - binary_accuracy: 0.4940\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7877 - binary_accuracy: 0.5840\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6771 - binary_accuracy: 0.5860\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6991 - binary_accuracy: 0.5820\n","Epoch 5/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6906 - binary_accuracy: 0.5980\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7296 - binary_accuracy: 0.5380\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6380 - binary_accuracy: 0.6400\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6671 - binary_accuracy: 0.6140\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6816 - binary_accuracy: 0.6280\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6397 - binary_accuracy: 0.6280\n","# of impressions: 500\n","# of impressions: 520\n","# of impressions: 540\n","# of impressions: 560\n","# of impressions: 580\n","# of impressions: 600\n","# of impressions: 620\n","# of impressions: 640\n","# of impressions: 660\n","# of impressions: 680\n","# of impressions: 700\n","# of impressions: 720\n","# of impressions: 740\n","# of impressions: 760\n","# of impressions: 780\n","# of impressions: 800\n","# of impressions: 820\n","# of impressions: 840\n","# of impressions: 860\n","# of impressions: 880\n","# of impressions: 900\n","# of impressions: 920\n","# of impressions: 940\n","# of impressions: 960\n","# of impressions: 980\n","Updating the model at 1000\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7042 - binary_accuracy: 0.5280\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7512 - binary_accuracy: 0.5220\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6795 - binary_accuracy: 0.5680\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6938 - binary_accuracy: 0.5640\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7466 - binary_accuracy: 0.5640\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6878 - binary_accuracy: 0.5840\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6762 - binary_accuracy: 0.5700\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6555 - binary_accuracy: 0.6160\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6798 - binary_accuracy: 0.5720\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6696 - binary_accuracy: 0.5760\n","# of impressions: 1000\n","# of impressions: 1020\n","# of impressions: 1040\n","# of impressions: 1060\n","# of impressions: 1080\n","# of impressions: 1100\n","# of impressions: 1120\n","# of impressions: 1140\n","# of impressions: 1160\n","# of impressions: 1180\n","# of impressions: 1200\n","# of impressions: 1220\n","# of impressions: 1240\n","# of impressions: 1260\n","# of impressions: 1280\n","# of impressions: 1300\n","# of impressions: 1320\n","# of impressions: 1340\n","# of impressions: 1360\n","# of impressions: 1380\n","# of impressions: 1400\n","# of impressions: 1420\n","# of impressions: 1440\n","# of impressions: 1460\n","# of impressions: 1480\n","Updating the model at 1500\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7740 - binary_accuracy: 0.5060\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.8210 - binary_accuracy: 0.5000\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6919 - binary_accuracy: 0.5800\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7914 - binary_accuracy: 0.5460\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6909 - binary_accuracy: 0.5520\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6774 - binary_accuracy: 0.5820\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6563 - binary_accuracy: 0.6180\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6597 - binary_accuracy: 0.6000\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6667 - binary_accuracy: 0.5960\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6701 - binary_accuracy: 0.5840\n","# of impressions: 1500\n","# of impressions: 1520\n","# of impressions: 1540\n","# of impressions: 1560\n","# of impressions: 1580\n","# of impressions: 1600\n","# of impressions: 1620\n","# of impressions: 1640\n","# of impressions: 1660\n","# of impressions: 1680\n","# of impressions: 1700\n","# of impressions: 1720\n","# of impressions: 1740\n","# of impressions: 1760\n","# of impressions: 1780\n","# of impressions: 1800\n","# of impressions: 1820\n","# of impressions: 1840\n","# of impressions: 1860\n","# of impressions: 1880\n","# of impressions: 1900\n","# of impressions: 1920\n","# of impressions: 1940\n","# of impressions: 1960\n","# of impressions: 1980\n","Updating the model at 2000\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7469 - binary_accuracy: 0.5380\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6965 - binary_accuracy: 0.5600\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6811 - binary_accuracy: 0.5820\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6811 - binary_accuracy: 0.6100\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6682 - binary_accuracy: 0.5940\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6606 - binary_accuracy: 0.6100\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6767 - binary_accuracy: 0.5900\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6800 - binary_accuracy: 0.6200\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6595 - binary_accuracy: 0.6200\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7340 - binary_accuracy: 0.5320\n","# of impressions: 2000\n","# of impressions: 2020\n","# of impressions: 2040\n","# of impressions: 2060\n","# of impressions: 2080\n","# of impressions: 2100\n","# of impressions: 2120\n","# of impressions: 2140\n","# of impressions: 2160\n","# of impressions: 2180\n","# of impressions: 2200\n","# of impressions: 2220\n","# of impressions: 2240\n","# of impressions: 2260\n","# of impressions: 2280\n","# of impressions: 2300\n","# of impressions: 2320\n","# of impressions: 2340\n","# of impressions: 2360\n","# of impressions: 2380\n","# of impressions: 2400\n","# of impressions: 2420\n","# of impressions: 2440\n","# of impressions: 2460\n","# of impressions: 2480\n","Updating the model at 2500\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7531 - binary_accuracy: 0.5240\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6901 - binary_accuracy: 0.5520\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6713 - binary_accuracy: 0.5980\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6775 - binary_accuracy: 0.6020\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6795 - binary_accuracy: 0.5800\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6597 - binary_accuracy: 0.6020\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6707 - binary_accuracy: 0.6060\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6644 - binary_accuracy: 0.5860\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6541 - binary_accuracy: 0.6020\n","Epoch 10/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6560 - binary_accuracy: 0.6240\n","# of impressions: 2500\n","# of impressions: 2520\n","# of impressions: 2540\n","# of impressions: 2560\n","# of impressions: 2580\n","# of impressions: 2600\n","# of impressions: 2620\n","# of impressions: 2640\n","# of impressions: 2660\n","# of impressions: 2680\n","# of impressions: 2700\n","# of impressions: 2720\n","# of impressions: 2740\n","# of impressions: 2760\n","# of impressions: 2780\n","# of impressions: 2800\n","# of impressions: 2820\n","# of impressions: 2840\n","# of impressions: 2860\n","# of impressions: 2880\n","# of impressions: 2900\n","# of impressions: 2920\n","# of impressions: 2940\n","# of impressions: 2960\n","# of impressions: 2980\n","Updating the model at 3000\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6898 - binary_accuracy: 0.5780\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6807 - binary_accuracy: 0.5960\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6743 - binary_accuracy: 0.5800\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6842 - binary_accuracy: 0.6040\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6664 - binary_accuracy: 0.6280\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6678 - binary_accuracy: 0.6260\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6553 - binary_accuracy: 0.5960\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6554 - binary_accuracy: 0.6140\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6459 - binary_accuracy: 0.6400\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6478 - binary_accuracy: 0.6180\n","# of impressions: 3000\n","# of impressions: 3020\n","# of impressions: 3040\n","# of impressions: 3060\n","# of impressions: 3080\n","# of impressions: 3100\n","# of impressions: 3120\n","# of impressions: 3140\n","# of impressions: 3160\n","# of impressions: 3180\n","# of impressions: 3200\n","# of impressions: 3220\n","# of impressions: 3240\n","# of impressions: 3260\n","# of impressions: 3280\n","# of impressions: 3300\n","# of impressions: 3320\n","# of impressions: 3340\n","# of impressions: 3360\n","# of impressions: 3380\n","# of impressions: 3400\n","# of impressions: 3420\n","# of impressions: 3440\n","# of impressions: 3460\n","# of impressions: 3480\n","Updating the model at 3500\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7144 - binary_accuracy: 0.5320\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7065 - binary_accuracy: 0.5120\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7025 - binary_accuracy: 0.5760\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6843 - binary_accuracy: 0.5600\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6799 - binary_accuracy: 0.5480\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6753 - binary_accuracy: 0.5860\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6646 - binary_accuracy: 0.5980\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6763 - binary_accuracy: 0.5600\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6714 - binary_accuracy: 0.5880\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6625 - binary_accuracy: 0.5960\n","# of impressions: 3500\n","# of impressions: 3520\n","# of impressions: 3540\n","# of impressions: 3560\n","# of impressions: 3580\n","# of impressions: 3600\n","# of impressions: 3620\n","# of impressions: 3640\n","# of impressions: 3660\n","# of impressions: 3680\n","# of impressions: 3700\n","# of impressions: 3720\n","# of impressions: 3740\n","# of impressions: 3760\n","# of impressions: 3780\n","# of impressions: 3800\n","# of impressions: 3820\n","# of impressions: 3840\n","# of impressions: 3860\n","# of impressions: 3880\n","# of impressions: 3900\n","# of impressions: 3920\n","# of impressions: 3940\n","# of impressions: 3960\n","# of impressions: 3980\n","Updating the model at 4000\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7030 - binary_accuracy: 0.5580\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7124 - binary_accuracy: 0.5160\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6750 - binary_accuracy: 0.5620\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6727 - binary_accuracy: 0.5720\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6641 - binary_accuracy: 0.6240\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6603 - binary_accuracy: 0.6060\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6532 - binary_accuracy: 0.6020\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6373 - binary_accuracy: 0.6100\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6415 - binary_accuracy: 0.6200\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6376 - binary_accuracy: 0.6060\n","# of impressions: 4000\n","# of impressions: 4020\n","# of impressions: 4040\n","# of impressions: 4060\n","# of impressions: 4080\n","# of impressions: 4100\n","# of impressions: 4120\n","# of impressions: 4140\n","# of impressions: 4160\n","# of impressions: 4180\n","# of impressions: 4200\n","# of impressions: 4220\n","# of impressions: 4240\n","# of impressions: 4260\n","# of impressions: 4280\n","# of impressions: 4300\n","# of impressions: 4320\n","# of impressions: 4340\n","# of impressions: 4360\n","# of impressions: 4380\n","# of impressions: 4400\n","# of impressions: 4420\n","# of impressions: 4440\n","# of impressions: 4460\n","# of impressions: 4480\n","Updating the model at 4500\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7164 - binary_accuracy: 0.5260\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6955 - binary_accuracy: 0.5740\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6788 - binary_accuracy: 0.5720\n","Epoch 4/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6748 - binary_accuracy: 0.5860\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6714 - binary_accuracy: 0.5860\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6652 - binary_accuracy: 0.6100\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6619 - binary_accuracy: 0.6060\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6608 - binary_accuracy: 0.6120\n","Epoch 9/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6599 - binary_accuracy: 0.5980\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6496 - binary_accuracy: 0.6240\n","# of impressions: 4500\n","# of impressions: 4520\n","# of impressions: 4540\n","# of impressions: 4560\n","# of impressions: 4580\n","# of impressions: 4600\n","# of impressions: 4620\n","# of impressions: 4640\n","# of impressions: 4660\n","# of impressions: 4680\n","# of impressions: 4700\n","# of impressions: 4720\n","# of impressions: 4740\n","# of impressions: 4760\n","# of impressions: 4780\n","# of impressions: 4800\n","# of impressions: 4820\n","# of impressions: 4840\n","# of impressions: 4860\n","# of impressions: 4880\n","# of impressions: 4900\n","# of impressions: 4920\n","# of impressions: 4940\n","# of impressions: 4960\n","# of impressions: 4980\n","Updating the model at 5000\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6688 - binary_accuracy: 0.6060\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6715 - binary_accuracy: 0.5860\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6571 - binary_accuracy: 0.6040\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6531 - binary_accuracy: 0.6360\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6430 - binary_accuracy: 0.6220\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6498 - binary_accuracy: 0.6220\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6383 - binary_accuracy: 0.6360\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6485 - binary_accuracy: 0.6140\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6403 - binary_accuracy: 0.6400\n","Epoch 10/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6414 - binary_accuracy: 0.6420\n","Trying with dropout: 0.2\n","# of impressions: 0\n","# of impressions: 20\n","# of impressions: 40\n","# of impressions: 60\n","# of impressions: 80\n","# of impressions: 100\n","# of impressions: 120\n","# of impressions: 140\n","# of impressions: 160\n","# of impressions: 180\n","# of impressions: 200\n","# of impressions: 220\n","# of impressions: 240\n","# of impressions: 260\n","# of impressions: 280\n","# of impressions: 300\n","# of impressions: 320\n","# of impressions: 340\n","# of impressions: 360\n","# of impressions: 380\n","# of impressions: 400\n","# of impressions: 420\n","# of impressions: 440\n","# of impressions: 460\n","# of impressions: 480\n","Updating the model at 500\n","Epoch 1/10\n","16/16 [==============================] - 1s 3ms/step - loss: 1.4584 - binary_accuracy: 0.5060\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.9217 - binary_accuracy: 0.4840\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7640 - binary_accuracy: 0.5220\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6963 - binary_accuracy: 0.5580\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6786 - binary_accuracy: 0.5840\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6725 - binary_accuracy: 0.6020\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6635 - binary_accuracy: 0.5920\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7161 - binary_accuracy: 0.5880\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6580 - binary_accuracy: 0.5840\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6423 - binary_accuracy: 0.6340\n","# of impressions: 500\n","# of impressions: 520\n","# of impressions: 540\n","# of impressions: 560\n","# of impressions: 580\n","# of impressions: 600\n","# of impressions: 620\n","# of impressions: 640\n","# of impressions: 660\n","# of impressions: 680\n","# of impressions: 700\n","# of impressions: 720\n","# of impressions: 740\n","# of impressions: 760\n","# of impressions: 780\n","# of impressions: 800\n","# of impressions: 820\n","# of impressions: 840\n","# of impressions: 860\n","# of impressions: 880\n","# of impressions: 900\n","# of impressions: 920\n","# of impressions: 940\n","# of impressions: 960\n","# of impressions: 980\n","Updating the model at 1000\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7148 - binary_accuracy: 0.5420\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7069 - binary_accuracy: 0.5600\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7121 - binary_accuracy: 0.5400\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7156 - binary_accuracy: 0.5740\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7200 - binary_accuracy: 0.5620\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7199 - binary_accuracy: 0.5560\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6778 - binary_accuracy: 0.6040\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6632 - binary_accuracy: 0.5940\n","Epoch 9/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6599 - binary_accuracy: 0.6260\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6367 - binary_accuracy: 0.6200\n","# of impressions: 1000\n","# of impressions: 1020\n","# of impressions: 1040\n","# of impressions: 1060\n","# of impressions: 1080\n","# of impressions: 1100\n","# of impressions: 1120\n","# of impressions: 1140\n","# of impressions: 1160\n","# of impressions: 1180\n","# of impressions: 1200\n","# of impressions: 1220\n","# of impressions: 1240\n","# of impressions: 1260\n","# of impressions: 1280\n","# of impressions: 1300\n","# of impressions: 1320\n","# of impressions: 1340\n","# of impressions: 1360\n","# of impressions: 1380\n","# of impressions: 1400\n","# of impressions: 1420\n","# of impressions: 1440\n","# of impressions: 1460\n","# of impressions: 1480\n","Updating the model at 1500\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6940 - binary_accuracy: 0.5540\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7129 - binary_accuracy: 0.5500\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6761 - binary_accuracy: 0.5860\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7081 - binary_accuracy: 0.5340\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6923 - binary_accuracy: 0.5780\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7198 - binary_accuracy: 0.5460\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7137 - binary_accuracy: 0.5680\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6967 - binary_accuracy: 0.5940\n","Epoch 9/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6552 - binary_accuracy: 0.6180\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6607 - binary_accuracy: 0.6340\n","# of impressions: 1500\n","# of impressions: 1520\n","# of impressions: 1540\n","# of impressions: 1560\n","# of impressions: 1580\n","# of impressions: 1600\n","# of impressions: 1620\n","# of impressions: 1640\n","# of impressions: 1660\n","# of impressions: 1680\n","# of impressions: 1700\n","# of impressions: 1720\n","# of impressions: 1740\n","# of impressions: 1760\n","# of impressions: 1780\n","# of impressions: 1800\n","# of impressions: 1820\n","# of impressions: 1840\n","# of impressions: 1860\n","# of impressions: 1880\n","# of impressions: 1900\n","# of impressions: 1920\n","# of impressions: 1940\n","# of impressions: 1960\n","# of impressions: 1980\n","Updating the model at 2000\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6966 - binary_accuracy: 0.5620\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7105 - binary_accuracy: 0.5800\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7163 - binary_accuracy: 0.5920\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6696 - binary_accuracy: 0.5840\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6504 - binary_accuracy: 0.6300\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6688 - binary_accuracy: 0.6080\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6640 - binary_accuracy: 0.6340\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6558 - binary_accuracy: 0.6260\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6435 - binary_accuracy: 0.6400\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6349 - binary_accuracy: 0.6200\n","# of impressions: 2000\n","# of impressions: 2020\n","# of impressions: 2040\n","# of impressions: 2060\n","# of impressions: 2080\n","# of impressions: 2100\n","# of impressions: 2120\n","# of impressions: 2140\n","# of impressions: 2160\n","# of impressions: 2180\n","# of impressions: 2200\n","# of impressions: 2220\n","# of impressions: 2240\n","# of impressions: 2260\n","# of impressions: 2280\n","# of impressions: 2300\n","# of impressions: 2320\n","# of impressions: 2340\n","# of impressions: 2360\n","# of impressions: 2380\n","# of impressions: 2400\n","# of impressions: 2420\n","# of impressions: 2440\n","# of impressions: 2460\n","# of impressions: 2480\n","Updating the model at 2500\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7073 - binary_accuracy: 0.5900\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6805 - binary_accuracy: 0.6060\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6748 - binary_accuracy: 0.6040\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6645 - binary_accuracy: 0.6060\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6674 - binary_accuracy: 0.6140\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6551 - binary_accuracy: 0.6240\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6527 - binary_accuracy: 0.6160\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6659 - binary_accuracy: 0.6040\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6660 - binary_accuracy: 0.6160\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6415 - binary_accuracy: 0.6360\n","# of impressions: 2500\n","# of impressions: 2520\n","# of impressions: 2540\n","# of impressions: 2560\n","# of impressions: 2580\n","# of impressions: 2600\n","# of impressions: 2620\n","# of impressions: 2640\n","# of impressions: 2660\n","# of impressions: 2680\n","# of impressions: 2700\n","# of impressions: 2720\n","# of impressions: 2740\n","# of impressions: 2760\n","# of impressions: 2780\n","# of impressions: 2800\n","# of impressions: 2820\n","# of impressions: 2840\n","# of impressions: 2860\n","# of impressions: 2880\n","# of impressions: 2900\n","# of impressions: 2920\n","# of impressions: 2940\n","# of impressions: 2960\n","# of impressions: 2980\n","Updating the model at 3000\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6946 - binary_accuracy: 0.5920\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6908 - binary_accuracy: 0.5840\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6937 - binary_accuracy: 0.5620\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6862 - binary_accuracy: 0.5760\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6970 - binary_accuracy: 0.5740\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7177 - binary_accuracy: 0.5600\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6763 - binary_accuracy: 0.5820\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6582 - binary_accuracy: 0.6120\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6620 - binary_accuracy: 0.6040\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6574 - binary_accuracy: 0.6160\n","# of impressions: 3000\n","# of impressions: 3020\n","# of impressions: 3040\n","# of impressions: 3060\n","# of impressions: 3080\n","# of impressions: 3100\n","# of impressions: 3120\n","# of impressions: 3140\n","# of impressions: 3160\n","# of impressions: 3180\n","# of impressions: 3200\n","# of impressions: 3220\n","# of impressions: 3240\n","# of impressions: 3260\n","# of impressions: 3280\n","# of impressions: 3300\n","# of impressions: 3320\n","# of impressions: 3340\n","# of impressions: 3360\n","# of impressions: 3380\n","# of impressions: 3400\n","# of impressions: 3420\n","# of impressions: 3440\n","# of impressions: 3460\n","# of impressions: 3480\n","Updating the model at 3500\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6969 - binary_accuracy: 0.5600\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6870 - binary_accuracy: 0.5700\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6798 - binary_accuracy: 0.5680\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6741 - binary_accuracy: 0.6180\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6715 - binary_accuracy: 0.5960\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6594 - binary_accuracy: 0.6280\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6649 - binary_accuracy: 0.6060\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6922 - binary_accuracy: 0.5440\n","Epoch 9/10\n","16/16 [==============================] - 0s 2ms/step - loss: 0.6498 - binary_accuracy: 0.6320\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6347 - binary_accuracy: 0.6480\n","# of impressions: 3500\n","# of impressions: 3520\n","# of impressions: 3540\n","# of impressions: 3560\n","# of impressions: 3580\n","# of impressions: 3600\n","# of impressions: 3620\n","# of impressions: 3640\n","# of impressions: 3660\n","# of impressions: 3680\n","# of impressions: 3700\n","# of impressions: 3720\n","# of impressions: 3740\n","# of impressions: 3760\n","# of impressions: 3780\n","# of impressions: 3800\n","# of impressions: 3820\n","# of impressions: 3840\n","# of impressions: 3860\n","# of impressions: 3880\n","# of impressions: 3900\n","# of impressions: 3920\n","# of impressions: 3940\n","# of impressions: 3960\n","# of impressions: 3980\n","Updating the model at 4000\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6784 - binary_accuracy: 0.5860\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6692 - binary_accuracy: 0.5840\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7043 - binary_accuracy: 0.5880\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6630 - binary_accuracy: 0.5920\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6511 - binary_accuracy: 0.6280\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6511 - binary_accuracy: 0.6220\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6392 - binary_accuracy: 0.6500\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6514 - binary_accuracy: 0.5940\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6353 - binary_accuracy: 0.6320\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6330 - binary_accuracy: 0.6340\n","# of impressions: 4000\n","# of impressions: 4020\n","# of impressions: 4040\n","# of impressions: 4060\n","# of impressions: 4080\n","# of impressions: 4100\n","# of impressions: 4120\n","# of impressions: 4140\n","# of impressions: 4160\n","# of impressions: 4180\n","# of impressions: 4200\n","# of impressions: 4220\n","# of impressions: 4240\n","# of impressions: 4260\n","# of impressions: 4280\n","# of impressions: 4300\n","# of impressions: 4320\n","# of impressions: 4340\n","# of impressions: 4360\n","# of impressions: 4380\n","# of impressions: 4400\n","# of impressions: 4420\n","# of impressions: 4440\n","# of impressions: 4460\n","# of impressions: 4480\n","Updating the model at 4500\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7154 - binary_accuracy: 0.5240\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7046 - binary_accuracy: 0.5360\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6845 - binary_accuracy: 0.5620\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6823 - binary_accuracy: 0.5660\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6804 - binary_accuracy: 0.5740\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6737 - binary_accuracy: 0.5640\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6827 - binary_accuracy: 0.5660\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6837 - binary_accuracy: 0.5500\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6638 - binary_accuracy: 0.5860\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6593 - binary_accuracy: 0.6000\n","# of impressions: 4500\n","# of impressions: 4520\n","# of impressions: 4540\n","# of impressions: 4560\n","# of impressions: 4580\n","# of impressions: 4600\n","# of impressions: 4620\n","# of impressions: 4640\n","# of impressions: 4660\n","# of impressions: 4680\n","# of impressions: 4700\n","# of impressions: 4720\n","# of impressions: 4740\n","# of impressions: 4760\n","# of impressions: 4780\n","# of impressions: 4800\n","# of impressions: 4820\n","# of impressions: 4840\n","# of impressions: 4860\n","# of impressions: 4880\n","# of impressions: 4900\n","# of impressions: 4920\n","# of impressions: 4940\n","# of impressions: 4960\n","# of impressions: 4980\n","Updating the model at 5000\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6801 - binary_accuracy: 0.5900\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6607 - binary_accuracy: 0.6200\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6633 - binary_accuracy: 0.6220\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6600 - binary_accuracy: 0.6100\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6486 - binary_accuracy: 0.6380\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6485 - binary_accuracy: 0.6280\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6332 - binary_accuracy: 0.6400\n","Epoch 8/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6357 - binary_accuracy: 0.6360\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6339 - binary_accuracy: 0.6380\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6239 - binary_accuracy: 0.6560\n","Trying with dropout: 0.4\n","# of impressions: 0\n","# of impressions: 20\n","# of impressions: 40\n","# of impressions: 60\n","# of impressions: 80\n","# of impressions: 100\n","# of impressions: 120\n","# of impressions: 140\n","# of impressions: 160\n","# of impressions: 180\n","# of impressions: 200\n","# of impressions: 220\n","# of impressions: 240\n","# of impressions: 260\n","# of impressions: 280\n","# of impressions: 300\n","# of impressions: 320\n","# of impressions: 340\n","# of impressions: 360\n","# of impressions: 380\n","# of impressions: 400\n","# of impressions: 420\n","# of impressions: 440\n","# of impressions: 460\n","# of impressions: 480\n","Updating the model at 500\n","Epoch 1/10\n","16/16 [==============================] - 1s 3ms/step - loss: 1.2578 - binary_accuracy: 0.5080\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.8418 - binary_accuracy: 0.5180\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.8006 - binary_accuracy: 0.4920\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7543 - binary_accuracy: 0.5360\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6835 - binary_accuracy: 0.5580\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6767 - binary_accuracy: 0.6060\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6759 - binary_accuracy: 0.5760\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6739 - binary_accuracy: 0.5960\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6969 - binary_accuracy: 0.5740\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6963 - binary_accuracy: 0.6100\n","# of impressions: 500\n","# of impressions: 520\n","# of impressions: 540\n","# of impressions: 560\n","# of impressions: 580\n","# of impressions: 600\n","# of impressions: 620\n","# of impressions: 640\n","# of impressions: 660\n","# of impressions: 680\n","# of impressions: 700\n","# of impressions: 720\n","# of impressions: 740\n","# of impressions: 760\n","# of impressions: 780\n","# of impressions: 800\n","# of impressions: 820\n","# of impressions: 840\n","# of impressions: 860\n","# of impressions: 880\n","# of impressions: 900\n","# of impressions: 920\n","# of impressions: 940\n","# of impressions: 960\n","# of impressions: 980\n","Updating the model at 1000\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7266 - binary_accuracy: 0.5360\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7078 - binary_accuracy: 0.5380\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7576 - binary_accuracy: 0.5300\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7017 - binary_accuracy: 0.5420\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6974 - binary_accuracy: 0.5380\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7270 - binary_accuracy: 0.5320\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7037 - binary_accuracy: 0.5580\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6529 - binary_accuracy: 0.6100\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6757 - binary_accuracy: 0.5880\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6808 - binary_accuracy: 0.5840\n","# of impressions: 1000\n","# of impressions: 1020\n","# of impressions: 1040\n","# of impressions: 1060\n","# of impressions: 1080\n","# of impressions: 1100\n","# of impressions: 1120\n","# of impressions: 1140\n","# of impressions: 1160\n","# of impressions: 1180\n","# of impressions: 1200\n","# of impressions: 1220\n","# of impressions: 1240\n","# of impressions: 1260\n","# of impressions: 1280\n","# of impressions: 1300\n","# of impressions: 1320\n","# of impressions: 1340\n","# of impressions: 1360\n","# of impressions: 1380\n","# of impressions: 1400\n","# of impressions: 1420\n","# of impressions: 1440\n","# of impressions: 1460\n","# of impressions: 1480\n","Updating the model at 1500\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7177 - binary_accuracy: 0.5220\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7246 - binary_accuracy: 0.5480\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7166 - binary_accuracy: 0.5480\n","Epoch 4/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6939 - binary_accuracy: 0.5580\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6732 - binary_accuracy: 0.6100\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7052 - binary_accuracy: 0.5720\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6656 - binary_accuracy: 0.6000\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6968 - binary_accuracy: 0.5680\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6641 - binary_accuracy: 0.6140\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6701 - binary_accuracy: 0.5980\n","# of impressions: 1500\n","# of impressions: 1520\n","# of impressions: 1540\n","# of impressions: 1560\n","# of impressions: 1580\n","# of impressions: 1600\n","# of impressions: 1620\n","# of impressions: 1640\n","# of impressions: 1660\n","# of impressions: 1680\n","# of impressions: 1700\n","# of impressions: 1720\n","# of impressions: 1740\n","# of impressions: 1760\n","# of impressions: 1780\n","# of impressions: 1800\n","# of impressions: 1820\n","# of impressions: 1840\n","# of impressions: 1860\n","# of impressions: 1880\n","# of impressions: 1900\n","# of impressions: 1920\n","# of impressions: 1940\n","# of impressions: 1960\n","# of impressions: 1980\n","Updating the model at 2000\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7108 - binary_accuracy: 0.5920\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6958 - binary_accuracy: 0.5560\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7078 - binary_accuracy: 0.5560\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6714 - binary_accuracy: 0.5880\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6547 - binary_accuracy: 0.6200\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6507 - binary_accuracy: 0.6100\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6550 - binary_accuracy: 0.6120\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6668 - binary_accuracy: 0.6420\n","Epoch 9/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6764 - binary_accuracy: 0.6020\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6449 - binary_accuracy: 0.6220\n","# of impressions: 2000\n","# of impressions: 2020\n","# of impressions: 2040\n","# of impressions: 2060\n","# of impressions: 2080\n","# of impressions: 2100\n","# of impressions: 2120\n","# of impressions: 2140\n","# of impressions: 2160\n","# of impressions: 2180\n","# of impressions: 2200\n","# of impressions: 2220\n","# of impressions: 2240\n","# of impressions: 2260\n","# of impressions: 2280\n","# of impressions: 2300\n","# of impressions: 2320\n","# of impressions: 2340\n","# of impressions: 2360\n","# of impressions: 2380\n","# of impressions: 2400\n","# of impressions: 2420\n","# of impressions: 2440\n","# of impressions: 2460\n","# of impressions: 2480\n","Updating the model at 2500\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7030 - binary_accuracy: 0.5680\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6916 - binary_accuracy: 0.5800\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6891 - binary_accuracy: 0.5820\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6771 - binary_accuracy: 0.5980\n","Epoch 5/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6717 - binary_accuracy: 0.5780\n","Epoch 6/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6956 - binary_accuracy: 0.5660\n","Epoch 7/10\n","16/16 [==============================] - 0s 5ms/step - loss: 0.6649 - binary_accuracy: 0.6200\n","Epoch 8/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6590 - binary_accuracy: 0.6040\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6549 - binary_accuracy: 0.6180\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6528 - binary_accuracy: 0.6200\n","# of impressions: 2500\n","# of impressions: 2520\n","# of impressions: 2540\n","# of impressions: 2560\n","# of impressions: 2580\n","# of impressions: 2600\n","# of impressions: 2620\n","# of impressions: 2640\n","# of impressions: 2660\n","# of impressions: 2680\n","# of impressions: 2700\n","# of impressions: 2720\n","# of impressions: 2740\n","# of impressions: 2760\n","# of impressions: 2780\n","# of impressions: 2800\n","# of impressions: 2820\n","# of impressions: 2840\n","# of impressions: 2860\n","# of impressions: 2880\n","# of impressions: 2900\n","# of impressions: 2920\n","# of impressions: 2940\n","# of impressions: 2960\n","# of impressions: 2980\n","Updating the model at 3000\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6941 - binary_accuracy: 0.5740\n","Epoch 2/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.7142 - binary_accuracy: 0.5320\n","Epoch 3/10\n","16/16 [==============================] - 0s 5ms/step - loss: 0.6967 - binary_accuracy: 0.5560\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7075 - binary_accuracy: 0.5340\n","Epoch 5/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6652 - binary_accuracy: 0.6220\n","Epoch 6/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6733 - binary_accuracy: 0.5860\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6597 - binary_accuracy: 0.6160\n","Epoch 8/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6649 - binary_accuracy: 0.6080\n","Epoch 9/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6575 - binary_accuracy: 0.6100\n","Epoch 10/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6543 - binary_accuracy: 0.6220\n","# of impressions: 3000\n","# of impressions: 3020\n","# of impressions: 3040\n","# of impressions: 3060\n","# of impressions: 3080\n","# of impressions: 3100\n","# of impressions: 3120\n","# of impressions: 3140\n","# of impressions: 3160\n","# of impressions: 3180\n","# of impressions: 3200\n","# of impressions: 3220\n","# of impressions: 3240\n","# of impressions: 3260\n","# of impressions: 3280\n","# of impressions: 3300\n","# of impressions: 3320\n","# of impressions: 3340\n","# of impressions: 3360\n","# of impressions: 3380\n","# of impressions: 3400\n","# of impressions: 3420\n","# of impressions: 3440\n","# of impressions: 3460\n","# of impressions: 3480\n","Updating the model at 3500\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7185 - binary_accuracy: 0.5280\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6977 - binary_accuracy: 0.5580\n","Epoch 3/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6851 - binary_accuracy: 0.5780\n","Epoch 4/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6784 - binary_accuracy: 0.5920\n","Epoch 5/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6674 - binary_accuracy: 0.6120\n","Epoch 6/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6563 - binary_accuracy: 0.6240\n","Epoch 7/10\n","16/16 [==============================] - 0s 5ms/step - loss: 0.6550 - binary_accuracy: 0.6260\n","Epoch 8/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6576 - binary_accuracy: 0.6100\n","Epoch 9/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6577 - binary_accuracy: 0.6100\n","Epoch 10/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6429 - binary_accuracy: 0.6440\n","# of impressions: 3500\n","# of impressions: 3520\n","# of impressions: 3540\n","# of impressions: 3560\n","# of impressions: 3580\n","# of impressions: 3600\n","# of impressions: 3620\n","# of impressions: 3640\n","# of impressions: 3660\n","# of impressions: 3680\n","# of impressions: 3700\n","# of impressions: 3720\n","# of impressions: 3740\n","# of impressions: 3760\n","# of impressions: 3780\n","# of impressions: 3800\n","# of impressions: 3820\n","# of impressions: 3840\n","# of impressions: 3860\n","# of impressions: 3880\n","# of impressions: 3900\n","# of impressions: 3920\n","# of impressions: 3940\n","# of impressions: 3960\n","# of impressions: 3980\n","Updating the model at 4000\n","Epoch 1/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6994 - binary_accuracy: 0.5740\n","Epoch 2/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6851 - binary_accuracy: 0.5780\n","Epoch 3/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6551 - binary_accuracy: 0.6000\n","Epoch 4/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6564 - binary_accuracy: 0.6300\n","Epoch 5/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6596 - binary_accuracy: 0.5980\n","Epoch 6/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6509 - binary_accuracy: 0.6260\n","Epoch 7/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6498 - binary_accuracy: 0.6120\n","Epoch 8/10\n","16/16 [==============================] - 0s 5ms/step - loss: 0.6359 - binary_accuracy: 0.6360\n","Epoch 9/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6306 - binary_accuracy: 0.6360\n","Epoch 10/10\n","16/16 [==============================] - 0s 5ms/step - loss: 0.6317 - binary_accuracy: 0.6500\n","# of impressions: 4000\n","# of impressions: 4020\n","# of impressions: 4040\n","# of impressions: 4060\n","# of impressions: 4080\n","# of impressions: 4100\n","# of impressions: 4120\n","# of impressions: 4140\n","# of impressions: 4160\n","# of impressions: 4180\n","# of impressions: 4200\n","# of impressions: 4220\n","# of impressions: 4240\n","# of impressions: 4260\n","# of impressions: 4280\n","# of impressions: 4300\n","# of impressions: 4320\n","# of impressions: 4340\n","# of impressions: 4360\n","# of impressions: 4380\n","# of impressions: 4400\n","# of impressions: 4420\n","# of impressions: 4440\n","# of impressions: 4460\n","# of impressions: 4480\n","Updating the model at 4500\n","Epoch 1/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.7003 - binary_accuracy: 0.5380\n","Epoch 2/10\n","16/16 [==============================] - 0s 5ms/step - loss: 0.6897 - binary_accuracy: 0.5540\n","Epoch 3/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6833 - binary_accuracy: 0.5660\n","Epoch 4/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6748 - binary_accuracy: 0.5700\n","Epoch 5/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6815 - binary_accuracy: 0.5760\n","Epoch 6/10\n","16/16 [==============================] - 0s 5ms/step - loss: 0.6805 - binary_accuracy: 0.5660\n","Epoch 7/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6892 - binary_accuracy: 0.5640\n","Epoch 8/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6758 - binary_accuracy: 0.5960\n","Epoch 9/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6561 - binary_accuracy: 0.6180\n","Epoch 10/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6594 - binary_accuracy: 0.6240\n","# of impressions: 4500\n","# of impressions: 4520\n","# of impressions: 4540\n","# of impressions: 4560\n","# of impressions: 4580\n","# of impressions: 4600\n","# of impressions: 4620\n","# of impressions: 4640\n","# of impressions: 4660\n","# of impressions: 4680\n","# of impressions: 4700\n","# of impressions: 4720\n","# of impressions: 4740\n","# of impressions: 4760\n","# of impressions: 4780\n","# of impressions: 4800\n","# of impressions: 4820\n","# of impressions: 4840\n","# of impressions: 4860\n","# of impressions: 4880\n","# of impressions: 4900\n","# of impressions: 4920\n","# of impressions: 4940\n","# of impressions: 4960\n","# of impressions: 4980\n","Updating the model at 5000\n","Epoch 1/10\n","16/16 [==============================] - 0s 5ms/step - loss: 0.6957 - binary_accuracy: 0.5700\n","Epoch 2/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6753 - binary_accuracy: 0.6080\n","Epoch 3/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6657 - binary_accuracy: 0.6060\n","Epoch 4/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6588 - binary_accuracy: 0.6260\n","Epoch 5/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6611 - binary_accuracy: 0.6180\n","Epoch 6/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6545 - binary_accuracy: 0.6160\n","Epoch 7/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6479 - binary_accuracy: 0.6360\n","Epoch 8/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6563 - binary_accuracy: 0.6120\n","Epoch 9/10\n","16/16 [==============================] - 0s 4ms/step - loss: 0.6465 - binary_accuracy: 0.6320\n","Epoch 10/10\n","16/16 [==============================] - 0s 3ms/step - loss: 0.6458 - binary_accuracy: 0.6240\n"]}],"source":["#collapse-hide\n","ad_click_probs = get_ad_click_probs()\n","df_cbandits = pd.DataFrame()\n","dropout_levels = [0, 0.01, 0.05, 0.1, 0.2, 0.4]\n","\n","for d in dropout_levels:\n"," print(\"Trying with dropout:\", d)\n"," np.random.seed(0)\n"," context_n = df_data.shape[1] - 1\n"," ad_input_n = df_data.education.nunique()\n"," model = get_model(context_n + ad_input_n, 0.01)\n"," X = []\n"," y = []\n"," regret_vec = []\n"," total_regret = 0\n"," for i in range(5000):\n"," if i % 20 == 0:\n"," print(\"# of impressions:\", i)\n"," user, context = generate_user(df_data)\n"," ad_inventory = get_ad_inventory()\n"," ad, x = select_ad(model, context, ad_inventory)\n"," click = display_ad(ad_click_probs, user, ad)\n"," regret = calc_regret(user, ad_inventory, ad_click_probs, ad)\n"," total_regret += regret\n"," regret_vec.append(total_regret)\n"," X.append(x)\n"," y.append(click)\n"," if (i + 1) % 500 == 0:\n"," print('Updating the model at', i+1)\n"," model = update_model(model, X, y)\n"," X = []\n"," y = []\n"," \n"," df_cbandits['dropout: '+str(d)] = regret_vec"]},{"cell_type":"code","execution_count":null,"metadata":{"id":"Vf7v4dQgPoc5"},"outputs":[],"source":["df_cbandits.iplot(dash = ['dash', 'solid', 'dashdot', \n"," 'dot', 'longdash', 'longdashdot'],\n"," xTitle='Impressions', \n"," yTitle='Cumulative Regret')"]},{"cell_type":"markdown","metadata":{"id":"0u56gxY-PsPo"},"source":["![image.png]()"]},{"cell_type":"markdown","metadata":{"id":"amgt8394PtRG"},"source":["*Comparison of cumulative regret with various dropout rates*"]},{"cell_type":"markdown","metadata":{"id":"Kbi4wGKXP1oV"},"source":["The results on the above figure show that our bandit models learn after some observations how to select the ads given the user characteristics. As various dropout rates have led to different algorithm performances, an important question again becomes how to select the dropout rate. One obvious answer is to try different rates over time identify what works the best in similar online advertising problems. This approach usually works if the business has to solve similar problems again and again over a long time period. A better approach though is to learn the optimal dropout rate."]}],"metadata":{"accelerator":"GPU","colab":{"collapsed_sections":[],"name":"2022-01-24-contextual-mab.ipynb","provenance":[{"file_id":"https://github.com/recohut/nbs/blob/main/raw/T273396%20%7C%20Contextual%20online%20advertising%20with%20user%20data%20from%20U.S.%20Census.ipynb","timestamp":1644668852780}],"toc_visible":true,"authorship_tag":"ABX9TyM5xF93WDs5M5XRE3uy37c0"},"kernelspec":{"display_name":"Python 3","name":"python3"},"language_info":{"name":"python"}},"nbformat":4,"nbformat_minor":0}