{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import re\n",
    "import csv\n",
    "import pickle\n",
    "import numpy as np\n",
    "import scipy as sp\n",
    "from matplotlib import pyplot as plt\n",
    "\n",
    "# nlp\n",
    "import spacy\n",
    "import benepar\n",
    "import nltk\n",
    "# benepar_en didn't work\n",
    "fresh = False\n",
    "if fresh:\n",
    "    benepar.download('benepar_en3')\n",
    "from benepar import BeneparComponent\n",
    "#from benepar.spacy_plugin import BeneparComponent\n",
    "from spacy.matcher import Matcher\n",
    "\n",
    "## machine learning\n",
    "import sklearn\n",
    "from sklearn.metrics import pairwise_distances\n",
    "from sklearn.metrics.pairwise import pairwise_kernels\n",
    "from sklearn.decomposition import PCA\n",
    "from sentence_transformers import SentenceTransformer\n",
    "# clustering and dendrogram\n",
    "from scipy.cluster.hierarchy import dendrogram\n",
    "from scipy.cluster.hierarchy import linkage\n",
    "from scipy.cluster.hierarchy import cophenet\n",
    "from scipy.spatial.distance import pdist\n",
    "from sklearn.cluster import AgglomerativeClustering"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "## homegrown library functions\n",
    "from imp import reload\n",
    "import concept_processing\n",
    "\n",
    "import concept_processing.io\n",
    "reload(concept_processing.io)\n",
    "# for loading original data\n",
    "from concept_processing.io import get_datapoint_iterator\n",
    "from concept_processing.io import load_concept_examples\n",
    "from concept_processing.io import capture_all_concepts\n",
    "from concept_processing.io import get_datapoint_iterator\n",
    "from concept_processing.io import store_concept_objects\n",
    "from concept_processing.io import load_concept_objects\n",
    "from concept_processing.io import store_pruned_results\n",
    "from concept_processing.io import load_pruned_results\n",
    "from concept_processing.io import form_data_dirname\n",
    "from concept_processing.io import form_processed_fname\n",
    "from concept_processing.io import groupings_to_csv\n",
    "from concept_processing.io import get_file_info\n",
    "\n",
    "# nlp functionality for extracting concepts from text\n",
    "import concept_processing.extraction\n",
    "reload(concept_processing.extraction)\n",
    "from concept_processing.extraction import add_inc_and_exc_matchers\n",
    "from concept_processing.extraction import is_concept\n",
    "from concept_processing.extraction import iterate_concepts\n",
    "from concept_processing.extraction import iterate_concepts_in_span\n",
    "from concept_processing.extraction import extract_concepts\n",
    "\n",
    "# dealing with the concepts as strings\n",
    "import concept_processing.concepts\n",
    "reload(concept_processing.concepts)\n",
    "from concept_processing.concepts import concept_dict_to_list\n",
    "from concept_processing.concepts import display_most_frequent_concepts\n",
    "from concept_processing.concepts import build_embedding_matrix\n",
    "from concept_processing.concepts import complete_pam_with_substrings\n",
    "from concept_processing.concepts import get_concept_indices_by_substring\n",
    "\n",
    "# manipulating data as a presence/absence matrix\n",
    "import concept_processing.pam\n",
    "reload(concept_processing.pam)\n",
    "from concept_processing.pam import convert_raw_bof_to_pam\n",
    "from concept_processing.pam import prune_and_reindex_concepts\n",
    "from concept_processing.pam import prune_concepts_general\n",
    "from concept_processing.pam import filter_pruned_groups\n",
    "from concept_processing.pam import count_features_in_each_datapoint\n",
    "from concept_processing.pam import count_datapoints_in_each_feature\n",
    "from concept_processing.pam import group_concepts\n",
    "from concept_processing.pam import merge_datapoints_by_id\n",
    "from concept_processing.pam import get_merged_label_ids\n",
    "from concept_processing.pam import calc_independent_mis\n",
    "from concept_processing.pam import calc_post_mis\n",
    "from concept_processing.pam import calc_cummulative_mi\n",
    "from concept_processing.pam import prune_concepts_by_cummulative_mi\n",
    "from concept_processing.pam import convert_rows_to_unique_integers\n",
    "\n",
    "import concept_processing.labels\n",
    "reload(concept_processing.labels)\n",
    "from concept_processing.labels import create_labels_as_indices\n",
    "from concept_processing.labels import label_indices_to_one_hot\n",
    "from concept_processing.labels import calculate_concept_purity_measures\n",
    "from concept_processing.labels import calc_log_evidence\n",
    "from concept_processing.labels import calc_log_evidence_indiv_model\n",
    "from concept_processing.labels import calc_log_evidence_combined_model\n",
    "from concept_processing.labels import calc_log_evidence_ratio\n",
    "\n",
    "import concept_processing.grouping\n",
    "reload(concept_processing.grouping)\n",
    "from concept_processing.grouping import find_pairwise_nearest\n",
    "from concept_processing.grouping import display_best_closest_neighbours\n",
    "from concept_processing.grouping import calc_prox_mtx_embedding\n",
    "from concept_processing.grouping import calc_prox_mtx_labels_evidence_ratio\n",
    "from concept_processing.grouping import calc_prox_mtx_labels_beta_ratio\n",
    "from concept_processing.grouping import calc_prox_mtx_labels\n",
    "\n",
    "# Dendrogram/hierarchical clustering\n",
    "import concept_processing.plot_support\n",
    "reload(concept_processing.plot_support)\n",
    "from concept_processing.plot_support import plot_rank_versus_freq\n",
    "from concept_processing.plot_support import plot_dendrogram\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Load the stored data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "datastem = '20210504'\n",
    "modelstem = 'lg'\n",
    "datapath = form_processed_fname(datastem, modelstem, 'pkl', 'raw_concepts')\n",
    "\n",
    "#concepts, ids, categories, labels_as_indices, pam = load_concept_objects(datapath)\n",
    "resultsdict = pickle.load(open( datapath, \"rb\" ))\n",
    "concepts = resultsdict['concepts']\n",
    "ids = resultsdict['ids']\n",
    "categories = resultsdict['categories']\n",
    "labels_as_indices = resultsdict['labels_as_indices']\n",
    "pam = resultsdict['pam']\n",
    "rows_to_remove = resultsdict['rows_to_remove']\n",
    "#labels = label_indices_to_one_hot(labels_as_indices, num_categories=len(categories))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Concept Similarity\n",
    "\n",
    "### BERT with `SentenceTransformer`\n",
    "\n",
    "Requires installation of the sentence-transfomer library with:\n",
    "\n",
    "`pip install -U sentence-transformers`\n",
    "\n",
    "In this part, we consider that modern sentence embedding models can be used to generate vector representations for sentences or phrases and then arithmetic operations performed on those vectors. IN particular, we are interested in measuring the distance between phrases so that we can consider merging apparently distinct but semantically similar concepts into a single umbrella concept.\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/luke/.local/lib/python3.8/site-packages/torch/cuda/__init__.py:52: UserWarning: CUDA initialization: Found no NVIDIA driver on your system. Please check that you have an NVIDIA GPU and installed a driver from http://www.nvidia.com/Download/index.aspx (Triggered internally at  /pytorch/c10/cuda/CUDAFunctions.cpp:100.)\n",
      "  return torch._C._cuda_getDeviceCount() > 0\n"
     ]
    }
   ],
   "source": [
    "distilroberta_model = SentenceTransformer('paraphrase-distilroberta-base-v1')\n",
    "stsb_roberta_model =  SentenceTransformer('stsb-roberta-base')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "model_lookup = dict(distil=distilroberta_model, stsb=stsb_roberta_model)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "# we fix the model and then build a matrix of embedding vectors over the concepts\n",
    "model = stsb_roberta_model\n",
    "embeds = build_embedding_matrix(concepts, model)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "prox_mtx_embedding.shape = (1915, 1915)\n",
      "Number of non-finite values = 0\n"
     ]
    }
   ],
   "source": [
    "# embedding distances\n",
    "metric = 'manhattan'\n",
    "#if metric == 'manhattan':\n",
    "#    prox_mtx_embedding = pairwise_distances(embeds, metric='cosine')\n",
    "#elif metric == 'manhattan':\n",
    "#    prox_mtx_embedding = pairwise_distances(embeds, metric='manhattan')\n",
    "#elif metric == 'minkowski':\n",
    "#    ## for minkowski we have to clean up the non-finite values\n",
    "#    prox_mtx_embedding = pairwise_distances(embeds, metric='minkowski', p=768)\n",
    "#    dummy_dist = np.max(prox_mtx_embedding[np.isfinite(prox_mtx_embedding)])*1.1\n",
    "#    prox_mtx_embedding[~np.isfinite(prox_mtx_embedding)] = dummy_dist \n",
    "#elif metric == 'chebyshev':\n",
    "#    prox_mtx_embedding = pairwise_distances(embeds, metric='chebyshev')\n",
    "prox_mtx_embedding = calc_prox_mtx_embedding(embeds, metric)\n",
    "print(f\"prox_mtx_embedding.shape = {prox_mtx_embedding.shape}\")\n",
    "print(f\"Number of non-finite values = {len(np.where(~np.isfinite(prox_mtx_embedding))[0])}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Calculate the label purity of each concept\n",
    "\n",
    "Each concept will appear in one or more text each associated with a video and label. Each label can be different but if they are the same then that concept can be thought of as purely associated with that concept.\n",
    "\n",
    "Note also that we are doing this on the full set of concepts rather than the pruned set. We may miss important concepts if they are written slightly differently each time"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "labels = label_indices_to_one_hot(labels_as_indices, K=len(categories))\n",
    "label_counts_mtx, concept_mean_labels = calculate_concept_purity_measures(pam, labels)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "concept_mean_labels[:10,:] = [[1. 0. 0. 0. 0.]\n",
      " [0. 0. 0. 1. 0.]\n",
      " [0. 0. 0. 0. 1.]\n",
      " [0. 1. 0. 0. 0.]\n",
      " [0. 0. 0. 0. 1.]\n",
      " [0. 0. 1. 0. 0.]\n",
      " [0. 0. 1. 0. 0.]\n",
      " [0. 1. 0. 0. 0.]\n",
      " [0. 1. 0. 0. 0.]\n",
      " [0. 0. 0. 0. 1.]]\n",
      "label_counts_mtx[:10,:] = [[1. 0. 0. 0. 0.]\n",
      " [0. 0. 0. 1. 0.]\n",
      " [0. 0. 0. 0. 2.]\n",
      " [0. 1. 0. 0. 0.]\n",
      " [0. 0. 0. 0. 1.]\n",
      " [0. 0. 1. 0. 0.]\n",
      " [0. 0. 1. 0. 0.]\n",
      " [0. 1. 0. 0. 0.]\n",
      " [0. 1. 0. 0. 0.]\n",
      " [0. 0. 0. 0. 1.]]\n",
      "label_counts_mtx.shape = (1915, 5)\n"
     ]
    }
   ],
   "source": [
    "print(f\"concept_mean_labels[:10,:] = {concept_mean_labels[:10,:]}\")\n",
    "print(f\"label_counts_mtx[:10,:] = {label_counts_mtx[:10,:]}\")\n",
    "\n",
    "print(f\"label_counts_mtx.shape = {label_counts_mtx.shape}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Beta-binomial bayes-factor\n",
    "#### How distant are two concept label counts?\n",
    "\n",
    "$$\\newcommand{\\expected}{\\mathbb{E}}$$\n",
    "Consider that we have two vectors which are the label counts for the different categories for two concepts $i$ and $j$, call these $\\textbf{n}_i^T = (n_{ik})_{k=1}^{K}$ and  $\\textbf{n}_j^T = (n_{jk})_{k=1}^{K}$. We consider two models: the independent model, $M_I(\\alpha)$ where each vector is assumed to be drawn from a separate multinomial; and the combined model $M_C$ where both vectors are assumed to be drawn from the same multinomial (this is equivalent to the combined vector $\\textbf{n}_i^T + \\textbf{n}_j^T$ being drawn from a single multinomial).\n",
    "\n",
    "In either case, we consider the evidence for some multinomial distribution to be a vector $\\textbf{n}_{i}^T = (n_{ik})_{k=1}^{K}$ and so this constitutes $\\sum_k n_{ik} = N_i$ draws $X$ from the same multinoulli distribution with parameters $\\boldsymbol\\mu_i = (\\mu_{ik})_{k=1}^{K}$ such that $\\Pr(X=k) = \\mu_{ik}$. The standard approach to this is to assume that $\\boldsymbol\\mu$ is drawn from a Dirichlet, and for simplicity we'll assume this is symmetric with single parameter $\\alpha$. The updated parameter vector after counting this evidence is $\\boldsymbol\\alpha'_i = (\\alpha'_{ik})_{k=1}^{K}$ where $\\alpha'_{ik} = n_{ik} + \\alpha$. Finally, the expected probability for this distribution is:\n",
    "\n",
    "$$\\expected [\\boldsymbol\\mu] = \\tilde{\\boldsymbol\\mu} = (\\tilde{\\mu}_{ik})_{k=1}^{K}$$\n",
    "\n",
    "where \n",
    "\n",
    "$$\\tilde{\\mu}_{ik} = \\frac{\\alpha'_{ik}}{\\sum_l \\alpha'_{il}} = \\frac{n_{ik}+\\alpha}{N_i + K\\alpha}$$\n",
    "\n",
    "Thus the probability of seeing some vector $\\textbf{n}_i$ from this distribution is:\n",
    "\n",
    "$$\\Pr(\\textbf{n}_i| \\tilde{\\boldsymbol\\mu}_i) = \\prod_{k=1}^{K} \\tilde{\\mu}_{ik}^{n_{ik}} \n",
    "= \\prod_{k=1}^{K} \\left(\\frac{n_{ik}+\\alpha}{N_i + K\\alpha}\\right)^{n_{ik}}$$\n",
    "\n",
    "And the log of this is:\n",
    "$$\\log\\Pr(\\textbf{n}_i| \\tilde{\\boldsymbol\\mu}) = \\sum_{k=1}^{K} n_{ik}\\log\\tilde{\\mu}_{ik} \n",
    "= \\sum_{k=1}^{K} n_{ik}\\log\\left(\\frac{n_{ik}+\\alpha}{N_i + K\\alpha}\\right)\n",
    "= - N_{i} \\log \\left(N_i + K\\alpha\\right) + \\sum_{k=1}^{K} n_{ik}\\log\\left(n_{ik}+\\alpha\\right) \n",
    "$$\n",
    "\n",
    "Note that in the limit $\\alpha \\to 0$ then we have maximum likelihood.\n",
    "\n",
    "#### The two models\n",
    "\n",
    "So now recall that we have two vectors of label counts, $\\textbf{n}_{i}$ and  $\\textbf{n}_{j}$. The first model, $M_I$, is that they come from independent distributions, so\n",
    "\n",
    "$$\n",
    "\\begin{aligned}\n",
    "\\Pr(\\textbf{n}_{i}, \\textbf{n}_{j}|M_I)\n",
    "& = \\Pr(\\textbf{n}_i| \\tilde{\\boldsymbol\\mu}_i)\n",
    "\\Pr(\\textbf{n}_j| \\tilde{\\boldsymbol\\mu}_j)\n",
    "\\\\\n",
    "& = \n",
    "\\left(\\prod_{k=1}^{K} \\left(\\frac{n_{ik}+\\alpha}{N_i + K\\alpha}\\right)^{n_{ik}}\\right)\n",
    "\\left(\\prod_{k=1}^{K} \\left(\\frac{n_{jk}+\\alpha}{N_j + K\\alpha}\\right)^{n_{jk}}\\right)\n",
    "\\end{aligned}\n",
    "$$\n",
    "\n",
    "And the log:\n",
    "\n",
    "$$\n",
    "\\begin{aligned}\n",
    "\\log\\Pr(\\textbf{n}_{i}, \\textbf{n}_{j}|M_I)\n",
    "& = \n",
    "- N_{i} \\log \\left(N_i + K\\alpha\\right)\n",
    "- N_{j} \\log \\left(N_j + K\\alpha\\right)\n",
    "+ \\sum_{k=1}^{K} n_{ik}\\log\\left(n_{ik}+\\alpha\\right)\n",
    "    +  n_{jk}\\log\\left(n_{jk}+\\alpha\\right)\n",
    "\\end{aligned}\n",
    "$$\n",
    "\n",
    "The second model $M_C$ is that they both come from the same distribution so we define $\\textbf{n}_l = \\textbf{n}_i+\\textbf{n}_j$:\n",
    "\n",
    "$$\n",
    "\\begin{aligned}\n",
    "\\Pr(\\textbf{n}_{i}, \\textbf{n}_{j}|M_C)\n",
    "& = \\Pr(\\textbf{n}_{l}| \\tilde{\\boldsymbol\\mu}_l)\n",
    "\\\\\n",
    "& = \n",
    "\\prod_{k=1}^{K} \\left(\\frac{n_{ik}+n_{jk}+\\alpha}{N_i + N_j + K\\alpha}\\right)^{n_{ik} + n_{jk}}\n",
    "\\end{aligned}\n",
    "$$\n",
    "\n",
    "And the log:\n",
    "\n",
    "$$\n",
    "\\begin{aligned}\n",
    "\\log\\Pr(\\textbf{n}_{i}, \\textbf{n}_{j}|M_C)\n",
    "& = \n",
    "- (N_{i} + N_{j}) \\log \\left(N_i + N_j + K\\alpha\\right)\n",
    "+ \\sum_{k=1}^{K} (n_{ik}+n_{jk})\\log\\left(n_{ik}+n_{jk}+\\alpha\\right)\n",
    "\\end{aligned}\n",
    "$$\n",
    "\n",
    "The distance between two label count vectors are the ratio:\n",
    "\n",
    "$$\n",
    "\\rho_{ij}\n",
    "=\n",
    "\\frac{\\Pr(\\textbf{n}_{i}, \\textbf{n}_{j}|M_I)\n",
    "}{\\Pr(\\textbf{n}_{i}, \\textbf{n}_{j}|M_C)}$$\n",
    "\n",
    "For precision we calculate $\\log \\rho_{ij}$ and exponentiate.\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "log_rho = 0.6729444732424259\n",
      "np.exp(log_rho) = 1.9600000000000002\n"
     ]
    }
   ],
   "source": [
    "# testing the log-evidence ratio function\n",
    "alpha = 0.5\n",
    "ni = np.array([1,0,0])\n",
    "nj = np.array([0,1,0])\n",
    "\n",
    "log_rho = calc_log_evidence_ratio(ni, nj, alpha)\n",
    "print(f\"log_rho = {log_rho}\")\n",
    "print(f\"np.exp(log_rho) = {np.exp(log_rho)}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "# the distances based on purity of labels\n",
    "alpha = 0.5\n",
    "labelmetric = 'evidence_ratio'\n",
    "prox_mtx_labels = calc_prox_mtx_labels(label_counts_mtx, alpha, labelmetric)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### A hybrid distance metric\n",
    "\n",
    "We now consider a new distance metric between two concepts $i$ and $j$, which is based both on the embedding distance $d_e(v_i, v_j)$ and the label count distance $d_l(n_i, n_j)$ to avoid the label count metric having too much influence we also define a factor $\\lambda < 1$ such that the total semantic distance:\n",
    "\n",
    "$$d_s(i, j) = d_e(v_i, v_j) + \\lambda d_l(n_i, n_j)$$\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "# the combined distance\n",
    "lambda_ = 0.1\n",
    "prox_mtx_total = prox_mtx_embedding + lambda_ * prox_mtx_labels"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "dist: 0.021351963584350524:\n",
      "\tthe batter swung and missed\n",
      "\tthen the batter swung and missed\n",
      "dist: 0.021351963584350524:\n",
      "\tthe batter swung and missed the\n",
      "\tthe batter swung and missed\n",
      "dist: 0.021351963584350524:\n",
      "\tthen the batter swung and missed\n",
      "\tthe batter swung and missed\n",
      "dist: 0.031738201040046814:\n",
      "\tball was in the strike zone\n",
      "\tthe ball was in the strike zone\n",
      "dist: 0.031738201040046814:\n",
      "\tthe ball was in the strike zone\n",
      "\tball was in the strike zone\n",
      "dist: 0.03226131634613271:\n",
      "\tthe umpire called it a strike\n",
      "\tumpire called it a strike\n",
      "dist: 0.03226131634613271:\n",
      "\tumpire called it a strike\n",
      "\tthe umpire called it a strike\n",
      "dist: 0.03254611407573807:\n",
      "\tthe batter swung and missed the ball\n",
      "\tthen the batter swung and missed the ball\n",
      "dist: 0.03254611407573807:\n",
      "\tthen the batter swung and missed the ball\n",
      "\tthe batter swung and missed the ball\n",
      "dist: 0.03292961947004531:\n",
      "\tbatter swung and\n",
      "\tthe batter swung and\n",
      "dist: 0.03292961947004531:\n",
      "\tthe batter swung and\n",
      "\tbatter swung and\n",
      "dist: 0.0375028198621731:\n",
      "\tthen the batter hit the ball into the field of play\n",
      "\tthe batter hit the ball into the field of play\n",
      "dist: 0.0375028198621731:\n",
      "\tthe batter hit the ball into the field of play\n",
      "\tthen the batter hit the ball into the field of play\n",
      "dist: 0.0375028198621731:\n",
      "\tthe umpire called strike\n",
      "\tthe umpire called a strike\n",
      "dist: 0.0375028198621731:\n",
      "\tthe umpire called a strike\n",
      "\tthe umpire called strike\n",
      "dist: 0.041468024939692816:\n",
      "\tthe pitch was called a strike by the umpire\n",
      "\tpitch was called a strike by umpire\n",
      "dist: 0.041468024939692816:\n",
      "\tpitch was called a strike by umpire\n",
      "\tthe pitch was called a strike by the umpire\n",
      "dist: 0.04324742290715897:\n",
      "\tumpire called it a ball\n",
      "\tthe umpire called it a ball\n",
      "dist: 0.04324742290715897:\n",
      "\tthe umpire called it a ball\n",
      "\tthen the umpire called it a ball\n",
      "dist: 0.04324742290715897:\n",
      "\tthen the umpire called it a ball\n",
      "\tthe umpire called it a ball\n",
      "dist: 0.04350111911008066:\n",
      "\tthen the ball was in the strike zone\n",
      "\tthe ball was in the strike zone\n",
      "dist: 0.04360375350410503:\n",
      "\tthen the batter hit the ball into foul territory\n",
      "\tthe batter hit the ball into foul territory\n",
      "dist: 0.04360375350410503:\n",
      "\tthe batter hit the ball into foul territory\n",
      "\tthen the batter hit the ball into foul territory\n",
      "dist: 0.044119272588187285:\n",
      "\tbatter swung and missed the ball\n",
      "\tthe batter swung and missed the ball\n",
      "dist: 0.04545312629606117:\n",
      "\tthe batter hit the ball on the ground to the second baseman\n",
      "\tthen the batter hit the ball on the ground to the second baseman\n",
      "dist: 0.04545312629606117:\n",
      "\tthen the batter hit the ball on the ground to the second baseman\n",
      "\tthe batter hit the ball on the ground to the second baseman\n",
      "dist: 0.046420809839824766:\n",
      "\tthe batter hit a ground ball to the shortstop\n",
      "\tthen the batter hit a ground ball to the shortstop\n",
      "dist: 0.046420809839824766:\n",
      "\tthen the batter hit a ground ball to the shortstop\n",
      "\tthe batter hit a ground ball to the shortstop\n",
      "dist: 0.04688862778823082:\n",
      "\tit was outside the strike zone\n",
      "\tit was outside strike zone\n",
      "dist: 0.04688862778823082:\n",
      "\tit was outside strike zone\n",
      "\tit was outside the strike zone\n",
      "dist: 0.04807758570639907:\n",
      "\tthe batter fouled off the pitch\n",
      "\tthe batter fouled off a pitch\n",
      "dist: 0.04807758570639907:\n",
      "\tthe batter fouled off a pitch\n",
      "\tthe batter fouled off the pitch\n",
      "dist: 0.04807758570639907:\n",
      "\tpitch was outside the strike zone\n",
      "\tthe pitch was outside the strike zone\n",
      "dist: 0.04807758570639907:\n",
      "\ta pitch was outside the strike zone\n",
      "\tthe pitch was outside the strike zone\n",
      "dist: 0.04807758570639907:\n",
      "\tthe pitch was outside the strike zone\n",
      "\tpitch was outside the strike zone\n",
      "dist: 0.04998812226170233:\n",
      "\tthe batter hit ball on the ground\n",
      "\tthe batter hit the ball on the ground\n",
      "dist: 0.04998812226170233:\n",
      "\tthe batter hit the ball on the ground\n",
      "\tthe batter hit ball on the ground\n",
      "dist: 0.04998812226170233:\n",
      "\tthen the batter hit the ball on the ground\n",
      "\tthe batter hit the ball on the ground\n",
      "dist: 0.04998812226170233:\n",
      "\tbatter hit the ball on the ground\n",
      "\tthe batter hit the ball on the ground\n",
      "dist: 0.05124912778446455:\n",
      "\tthe batter hit the ball in the air\n",
      "\tbatter hit ball in air\n",
      "dist: 0.05124912778446455:\n",
      "\tbatter hit ball in air\n",
      "\tthe batter hit the ball in the air\n",
      "dist: 0.05132892159131226:\n",
      "\tthe batter hit the ball outside the field of play\n",
      "\tbatter hit the ball outside the field of play\n",
      "dist: 0.05132892159131226:\n",
      "\tthen the batter swung at the pitch and missed\n",
      "\tthe batter swung at the pitch and missed\n",
      "dist: 0.05132892159131226:\n",
      "\tbatter hit the ball outside the field of play\n",
      "\tthe batter hit the ball outside the field of play\n",
      "dist: 0.05132892159131226:\n",
      "\tthe batter swung at the pitch and missed\n",
      "\tthen the batter swung at the pitch and missed\n",
      "dist: 0.05132892159131226:\n",
      "\tthe hitter swung and missed the\n",
      "\tthe hitter swung and missed\n",
      "dist: 0.05132892159131226:\n",
      "\tthe batter hit a fly ball to right field\n",
      "\tthen the batter hit a fly ball to right field\n",
      "dist: 0.05132892159131226:\n",
      "\tit was caught by an outfielder\n",
      "\tit was caught by the outfielder\n",
      "dist: 0.05132892159131226:\n",
      "\tthen the batter hit a fly ball to right field\n",
      "\tthe batter hit a fly ball to right field\n",
      "dist: 0.05132892159131226:\n",
      "\tit was caught by the outfielder\n",
      "\tit was caught by an outfielder\n",
      "dist: 0.05132892159131226:\n",
      "\tthe hitter swung and missed\n",
      "\tthe hitter swung and missed the\n",
      "dist: 0.05558021464325666:\n",
      "\tbatter hit the\n",
      "\tthe batter hit the\n",
      "dist: 0.05558021464325666:\n",
      "\tthe batter hit the\n",
      "\tbatter hit the\n",
      "dist: 0.059510204081632656:\n",
      "\tthen the hitter fouled the ball behind him\n",
      "\tthe hitter fouled the ball behind him\n",
      "dist: 0.059510204081632656:\n",
      "\tbatter hit it in play\n",
      "\tthe batter hit it in play\n",
      "dist: 0.059510204081632656:\n",
      "\tthe pitch was called a ball\n",
      "\tpitch was called a ball\n",
      "dist: 0.059510204081632656:\n",
      "\tthe ball landed on the edge of the strike zone\n",
      "\tthe ball landed on edge of the strike zone\n",
      "dist: 0.059510204081632656:\n",
      "\tpitch was called a ball\n",
      "\tthe pitch was called a ball\n",
      "dist: 0.059510204081632656:\n",
      "\tthe batter swung at it and missed\n",
      "\tthen the batter swung at it and missed\n",
      "dist: 0.059510204081632656:\n",
      "\tthe batter took a ball\n",
      "\tthen the batter took a ball\n",
      "dist: 0.059510204081632656:\n",
      "\tthen the batter took a ball\n",
      "\tthe batter took a ball\n",
      "dist: 0.059510204081632656:\n",
      "\tbatter made contact\n",
      "\tthen the batter made contact\n",
      "dist: 0.059510204081632656:\n",
      "\twho caught the ball for an out\n",
      "\twho caught the ball for the out\n",
      "dist: 0.059510204081632656:\n",
      "\tthe ball crossed home plate outside the strike zone\n",
      "\tball crossed home plate outside the strike zone\n",
      "dist: 0.059510204081632656:\n",
      "\tthen the batter swung at it and missed\n",
      "\tthe batter swung at it and missed\n",
      "dist: 0.059510204081632656:\n",
      "\tthe batter made contact with ball\n",
      "\tthen the batter made contact with the ball\n",
      "dist: 0.059510204081632656:\n",
      "\tball crossed home plate outside the strike zone\n",
      "\tthe ball crossed home plate outside the strike zone\n",
      "dist: 0.059510204081632656:\n",
      "\tpitcher threw strike\n",
      "\tthe pitcher threw a strike\n",
      "dist: 0.059510204081632656:\n",
      "\tthe batter hit a ground ball to the second baseman\n",
      "\tthe batter hit a ground ball to second baseman\n",
      "dist: 0.059510204081632656:\n",
      "\tthe umpire called a ball\n",
      "\tumpire called a ball\n",
      "dist: 0.059510204081632656:\n",
      "\tbatter hit a home\n",
      "\tthe batter hit a home\n",
      "dist: 0.059510204081632656:\n",
      "\tthe batter fouled the pitch back behind home plate\n",
      "\tthe batter fouled a pitch back behind home plate\n",
      "dist: 0.059510204081632656:\n",
      "\tthe batter fouled a pitch back behind home plate\n",
      "\tthe batter fouled the pitch back behind home plate\n",
      "dist: 0.059510204081632656:\n",
      "\tthe ball was hit in the air and not caught\n",
      "\tthen the ball was hit in the air and not caught\n",
      "dist: 0.059510204081632656:\n",
      "\tthen the batter hit a home\n",
      "\tthe batter hit a home\n",
      "dist: 0.059510204081632656:\n",
      "\tthe batter tipped the ball\n",
      "\tbatter tipped ball\n",
      "dist: 0.059510204081632656:\n",
      "\tthe batter hit it in play\n",
      "\tbatter hit it in play\n",
      "dist: 0.059510204081632656:\n",
      "\tan outfielder caught it\n",
      "\tthen the outfielder caught it\n",
      "dist: 0.059510204081632656:\n",
      "\the threw runner out at first\n",
      "\the threw the runner out at first\n",
      "dist: 0.059510204081632656:\n",
      "\tthen the ball was hit in the air and not caught\n",
      "\tthe ball was hit in the air and not caught\n",
      "dist: 0.059510204081632656:\n",
      "\tthe pitcher threw a strike\n",
      "\tpitcher threw strike\n",
      "dist: 0.059510204081632656:\n",
      "\tthe ball landed on edge of the strike zone\n",
      "\tthe ball landed on the edge of the strike zone\n",
      "dist: 0.059510204081632656:\n",
      "\twho caught the ball for the out\n",
      "\twho caught the ball for an out\n",
      "dist: 0.059510204081632656:\n",
      "\tumpire called a ball\n",
      "\tthe umpire called a ball\n",
      "dist: 0.059510204081632656:\n",
      "\tthe hitter fouled it off\n",
      "\tthen the hitter fouled it off\n",
      "dist: 0.059510204081632656:\n",
      "\tthe umpire called it ball and not a strike\n",
      "\tthe umpire called it a ball and not a strike\n",
      "dist: 0.059510204081632656:\n",
      "\tthe batter hit a home\n",
      "\tthen the batter hit a home\n",
      "dist: 0.059510204081632656:\n",
      "\the threw the runner out at first\n",
      "\the threw runner out at first\n",
      "dist: 0.059510204081632656:\n",
      "\tthe batter hit a ground ball to second baseman\n",
      "\tthe batter hit a ground ball to the second baseman\n",
      "dist: 0.059510204081632656:\n",
      "\tthe umpire called it a ball and not a strike\n",
      "\tthe umpire called it ball and not a strike\n",
      "dist: 0.059510204081632656:\n",
      "\tthen the batter made contact with the ball\n",
      "\tthe batter made contact with ball\n",
      "dist: 0.059510204081632656:\n",
      "\tthen the batter made contact\n",
      "\tbatter made contact\n",
      "dist: 0.059510204081632656:\n",
      "\tbatter tipped ball\n",
      "\tthe batter tipped the ball\n",
      "dist: 0.059510204081632656:\n",
      "\tthen the hitter fouled it off\n",
      "\tthe hitter fouled it off\n",
      "dist: 0.059510204081632656:\n",
      "\tthen the outfielder caught it\n",
      "\tan outfielder caught it\n",
      "dist: 0.059510204081632656:\n",
      "\tthe batter hit a ground ball to the first baseman\n",
      "\tthe batter hit a ground ball to first baseman\n",
      "dist: 0.059510204081632656:\n",
      "\tthe hitter fouled the ball behind him\n",
      "\tthen the hitter fouled the ball behind him\n",
      "dist: 0.059510204081632656:\n",
      "\tthe batter hit a ground ball to first baseman\n",
      "\tthe batter hit a ground ball to the first baseman\n",
      "dist: 0.06393876742944796:\n",
      "\tthe batter made contact with the\n",
      "\tthe batter made contact with\n",
      "dist: 0.06393876742944796:\n",
      "\tthe batter made contact with\n",
      "\tthe batter made contact with the\n",
      "dist: 0.06606187626191055:\n",
      "\tthe batter didn't swing\n",
      "\tbatter didn't swing\n",
      "dist: 0.06606187626191055:\n",
      "\tbatter didn't swing\n",
      "\tthe batter didn't swing\n",
      "dist: 0.06823221275987296:\n",
      "\tthen the batter did not swing\n",
      "\tthe batter did not swing\n",
      "dist: 0.06823221275987296:\n",
      "\tthe batter did not swing\n",
      "\tthen the batter did not swing\n",
      "dist: 0.07561085335945547:\n",
      "\tbatter did not swing\n",
      "\tthe batter did not swing\n",
      "dist: 0.07571398230142706:\n",
      "\tthe batter made contact with the ball\n",
      "\tthen the batter made contact with the ball\n",
      "dist: 0.08305236221716557:\n",
      "\tthe the hitter did not swing\n",
      "\tthe hitter did not swing\n",
      "dist: 0.08305236221716557:\n",
      "\tthe hitter did not swing\n",
      "\tthe the hitter did not swing\n",
      "dist: 0.08450793650793646:\n",
      "\tbatter hit a\n",
      "\tthe batter hit\n",
      "dist: 0.08450793650793646:\n",
      "\tthe batter hit\n",
      "\tbatter hit a\n",
      "dist: 0.08450793650793646:\n",
      "\tthe batter took the pitch\n",
      "\tbatter took pitch\n",
      "dist: 0.08450793650793646:\n",
      "\tbatter took pitch\n",
      "\tthe batter took the pitch\n",
      "dist: 0.08450793650793646:\n",
      "\ta fielder caught the ball in the air\n",
      "\tthe fielder caught the ball in the air\n",
      "dist: 0.08450793650793646:\n",
      "\tthe fielder caught the ball in the air\n",
      "\ta fielder caught the ball in the air\n",
      "dist: 0.08888802948810984:\n",
      "\tthe batter made contact\n",
      "\tthen the batter made contact\n",
      "dist: 0.09887152788140824:\n",
      "\tthe batter hit the ball\n",
      "\tbatter hit the ball\n",
      "dist: 0.09887152788140824:\n",
      "\tbatter hit the ball\n",
      "\tthe batter hit the ball\n",
      "dist: 0.10300220304713428:\n",
      "\tbatter didnt swing\n",
      "\tthe batter didnt swing\n",
      "dist: 0.10300220304713428:\n",
      "\tthe batter didnt swing\n",
      "\tbatter didnt swing\n",
      "dist: 0.14867458896290495:\n",
      "\tthe batter did not swing at it\n",
      "\tthen the batter did not swing at it\n",
      "dist: 0.14867458896290495:\n",
      "\tthen the batter did not swing at it\n",
      "\tthe batter did not swing at it\n",
      "dist: 0.1653061224489796:\n",
      "\tit was a called strike\n",
      "\tit was called a strike\n",
      "dist: 0.1653061224489796:\n",
      "\tline drive\n",
      "\ta line drive\n",
      "dist: 0.1653061224489796:\n",
      "\ta line drive\n",
      "\tline drive\n",
      "dist: 0.1653061224489796:\n",
      "\tthe umpire called the ball a\n",
      "\tumpire called a ball\n",
      "dist: 0.1653061224489796:\n",
      "\tit was called a strike\n",
      "\tit was a called strike\n",
      "dist: 0.3065471718364279:\n",
      "\tthe batter hit the ball into the air\n",
      "\tthen the batter hit the ball into the air\n",
      "dist: 0.3065471718364279:\n",
      "\tbatter hit ball to right field\n",
      "\tthe batter hit the ball to right field\n",
      "dist: 0.3065471718364279:\n",
      "\tthen the batter hit the ball into the air\n",
      "\tthe batter hit the ball into the air\n",
      "dist: 0.3065471718364279:\n",
      "\tthe batter hit the ball to right field\n",
      "\tbatter hit ball to right field\n",
      "dist: 0.4087678338271097:\n",
      "\tthe pitcher threw the ball\n",
      "\tpitcher threw ball\n",
      "dist: 0.4087678338271097:\n",
      "\tpitcher threw ball\n",
      "\tthe pitcher threw the ball\n",
      "dist: 0.4353147386069194:\n",
      "\tpitcher threw the ball\n",
      "\tpitcher threw ball\n",
      "dist: 0.7043576258452287:\n",
      "\tit was a hit\n",
      "\tit was hit\n",
      "dist: 0.7043576258452287:\n",
      "\tit was hit\n",
      "\tit was a hit\n",
      "dist: 0.7564000041361014:\n",
      "\tthe batter hit it\n",
      "\tbatter hit it\n",
      "dist: 0.7564000041361014:\n",
      "\tbatter hit it\n",
      "\tthe batter hit it\n",
      "dist: 30.43791231159328:\n",
      "\tthe pitch did not cross the plate inside of the strike zone and was called a ball by the umpire\n",
      "\tthe pitch did not cross the plate inside the strike zone and was called a ball by the umpire\n",
      "dist: 30.43791231159328:\n",
      "\tthe pitch did not cross the plate inside the strike zone and was called a ball by the umpire\n",
      "\tthe pitch did not cross the plate inside of the strike zone and was called a ball by the umpire\n",
      "dist: 34.50701315426463:\n",
      "\tthe batter didn't swing at the pitch\n",
      "\tthe batter did not swing at the pitch\n",
      "dist: 34.50701315426463:\n",
      "\tthe batter did not swing at the pitch\n",
      "\tthe batter didn't swing at the pitch\n",
      "dist: 39.70536767204144:\n",
      "\tthe ball crossed the plate inside the strike zone and was called a strike by the umpire\n",
      "\tthe ball crossed the plate inside of the strike zone and was called a strike by the umpire\n",
      "dist: 39.70536767204144:\n",
      "\tthe ball crossed the plate inside of the strike zone and was called a strike by the umpire\n",
      "\tthe ball crossed the plate inside the strike zone and was called a strike by the umpire\n",
      "dist: 41.150067699695114:\n",
      "\tthe batter hits the ball\n",
      "\tbatter hit the ball\n",
      "dist: 41.387385909069046:\n",
      "\tthe batter didn't swing at it\n",
      "\tthe batter did not swing at it\n",
      "dist: 44.16122345660014:\n",
      "\tthe ball crossed the plate within the strike zone and was called a strike by the umpire\n",
      "\tthe ball crossed the plate inside of the strike zone and was called a strike by the umpire\n",
      "dist: 48.02239351524148:\n",
      "\tthe batter swung and hit the ball on the\n",
      "\tthe batter swung and hit the ball\n",
      "dist: 48.02239351524148:\n",
      "\tthe batter swung and hit the ball\n",
      "\tthe batter swung and hit the ball on the\n",
      "dist: 48.423260601906726:\n",
      "\tthe batter hit the ball outside of the field of play\n",
      "\tthe batter hit the ball outside the field of play\n",
      "dist: 48.43956270076237:\n",
      "\tthe batter swung at the ball and missed\n",
      "\tthe batter swung at the ball and missed it\n",
      "dist: 48.43956270076237:\n",
      "\tthe batter swung at the ball and missed it\n",
      "\tthe batter swung at the ball and missed\n",
      "dist: 49.001549411418836:\n",
      "\tthe batter hit the ball into play\n",
      "\tthe batter hit the ball into play on the\n",
      "dist: 49.001549411418836:\n",
      "\tthe batter hit the ball into play on the\n",
      "\tthe batter hit the ball into play\n",
      "dist: 50.93992201534191:\n",
      "\tthe batter hit the ball into foul territory on the ground\n",
      "\tthe batter hit the ball on the ground into foul territory\n",
      "dist: 50.93992201534191:\n",
      "\tthe batter hit the ball on the ground into foul territory\n",
      "\tthe batter hit the ball into foul territory on the ground\n",
      "dist: 52.079312927030585:\n",
      "\tthe batter hit a groundball to the first baseman\n",
      "\tthe batter hit a ground ball to first baseman\n",
      "dist: 52.80408366666493:\n",
      "\tthe ball was not caught in the air\n",
      "\tthe ball wasn't caught in the air\n",
      "dist: 52.80408366666493:\n",
      "\tthe ball wasn't caught in the air\n",
      "\tthe ball was not caught in the air\n",
      "dist: 53.06748913058183:\n",
      "\tthe batter hit the ball into the air in foul territory\n",
      "\tthe batter hit the ball in the air into foul territory\n",
      "dist: 53.06748913058183:\n",
      "\tthe batter hit the ball in the air into foul territory\n",
      "\tthe batter hit the ball into the air in foul territory\n",
      "dist: 53.940442020451044:\n",
      "\tthe batter swung and did not make contact\n",
      "\tthen the batter swung and didn't make contact\n",
      "dist: 53.940442020451044:\n",
      "\tthen the batter swung and didn't make contact\n",
      "\tthe batter swung and did not make contact\n",
      "dist: 55.35601628413392:\n",
      "\tit is a foul ball\n",
      "\tit was a foul ball\n",
      "dist: 55.35601628413392:\n",
      "\tit was a foul ball\n",
      "\tit is a foul ball\n",
      "dist: 55.92882594143847:\n",
      "\tit's a foul ball\n",
      "\tit is a foul ball\n",
      "dist: 56.3525927120671:\n",
      "\tthe batter swung at the ball but missed\n",
      "\tthe batter swung at the ball and missed\n",
      "dist: 57.181087548887334:\n",
      "\tthe batter hit the ball on the ground in play\n",
      "\tthe batter hit the ball into the ground in play\n",
      "dist: 57.181087548887334:\n",
      "\tthe batter hit the ball into the ground in play\n",
      "\tthe batter hit the ball on the ground in play\n",
      "dist: 57.376269381128694:\n",
      "\tthe batter gets a hit\n",
      "\tthe batter got a hit\n",
      "dist: 57.376269381128694:\n",
      "\tthe batter got a hit\n",
      "\tthe batter gets a hit\n",
      "dist: 57.75912062496283:\n",
      "\tthen the batter hit the ball in the air in foul territory\n",
      "\tthe batter hit the ball into the air in foul territory\n",
      "dist: 57.999462061976:\n",
      "\tthe hitter didn't swing\n",
      "\tthe the hitter did not swing\n",
      "dist: 58.35016475376111:\n",
      "\tit is not a strike\n",
      "\tit was not a strike\n",
      "dist: 58.35016475376111:\n",
      "\tit was not a strike\n",
      "\tit is not a strike\n",
      "dist: 58.68250393944801:\n",
      "\tthe batter is out\n",
      "\tthe batter was out\n",
      "dist: 58.68250393944801:\n",
      "\tthe batter was out\n",
      "\tthe batter is out\n",
      "dist: 58.70613726354971:\n",
      "\tit is a ball\n",
      "\tit was a ball\n",
      "dist: 58.70613726354971:\n",
      "\tit was a ball\n",
      "\tit is a ball\n",
      "dist: 58.89621759876703:\n",
      "\tthe batter hit the ball with his bat\n",
      "\tthe batter hit the ball with the bat\n",
      "dist: 58.89621759876703:\n",
      "\tthe batter hit the ball with the bat\n",
      "\tthe batter hit the ball with his bat\n",
      "dist: 60.19758543457542:\n",
      "\tthe batter hit the ball to the shortstop on the ground\n",
      "\tthe batter hit the ball on the ground to the shortstop\n",
      "dist: 60.19758543457542:\n",
      "\tthe batter hit the ball on the ground to the shortstop\n",
      "\tthe batter hit the ball to the shortstop on the ground\n",
      "dist: 60.81481621278325:\n",
      "\tit was caught in the air\n",
      "\tand it was caught in the air\n",
      "dist: 60.81481621278325:\n",
      "\tand it was caught in the air\n",
      "\tit was caught in the air\n",
      "dist: 61.26565377339928:\n",
      "\tthe batter swung at and missed\n",
      "\tthen the batter swung at it and missed\n",
      "dist: 64.48012498261149:\n",
      "\tthe batter did not swing the bat\n",
      "\tthe batter didn't swing the bat\n",
      "dist: 64.48012498261149:\n",
      "\tthe batter didn't swing the bat\n",
      "\tthe batter did not swing the bat\n",
      "dist: 64.76882928233212:\n",
      "\tthe batter did not swing at a ball in the strike zone\n",
      "\tbatter did not swing at pitch in strike zone\n",
      "dist: 64.76882928233212:\n",
      "\tbatter did not swing at pitch in strike zone\n",
      "\tthe batter did not swing at a ball in the strike zone\n",
      "dist: 64.98179985002466:\n",
      "\tthe batter hit the ball into centerfield\n",
      "\tthe batter hit the ball to centerfield\n",
      "dist: 64.98179985002466:\n",
      "\tthe batter hit the ball to centerfield\n",
      "\tthe batter hit the ball into centerfield\n",
      "dist: 65.87921617451251:\n",
      "\tit's a ball\n",
      "\tit is a ball\n",
      "dist: 66.15953512156747:\n",
      "\tthe batter swung and missed the pitch\n",
      "\tthe batter swung and missed at the pitch\n",
      "dist: 66.15953512156747:\n",
      "\tthe batter swung and missed at the pitch\n",
      "\tthe batter swung and missed the pitch\n",
      "dist: 66.84746462617392:\n",
      "\tthe ball was hit on the\n",
      "\tthe ball was hit\n",
      "dist: 66.84746462617392:\n",
      "\tthe ball was hit\n",
      "\tthe ball was hit on the\n",
      "dist: 66.93450041876993:\n",
      "\tthe batter hit a ground ball to second base\n",
      "\tthe batter hit a ground ball to second baseman\n",
      "dist: 67.02214601037765:\n",
      "\tthe batter swung but did not make contact with the ball\n",
      "\tthe batter swung and did not make contact with the ball\n",
      "dist: 67.02214601037765:\n",
      "\tthe batter swung and did not make contact with the ball\n",
      "\tthe batter swung but did not make contact with the ball\n",
      "dist: 67.43520412019195:\n",
      "\tthe batter hit it in the air\n",
      "\tbatter hits it into the air\n",
      "dist: 67.43520412019195:\n",
      "\tbatter hits it into the air\n",
      "\tthe batter hit it in the air\n",
      "dist: 68.62258104981706:\n",
      "\tthe ball crossed the plate outside of the strike zone\n",
      "\tthe ball crossed the plate outside the strike zone\n",
      "dist: 68.62258104981706:\n",
      "\tthe ball crossed the plate outside the strike zone\n",
      "\tthe ball crossed the plate outside of the strike zone\n",
      "dist: 68.67387122697171:\n",
      "\tthe ball is hit on the ground to the third baseman\n",
      "\tthe ball was hit to the third baseman on the ground\n",
      "dist: 68.67387122697171:\n",
      "\tthe ball was hit to the third baseman on the ground\n",
      "\tthe ball is hit on the ground to the third baseman\n",
      "dist: 69.1388559651046:\n",
      "\tthe batter hit the ball into the outfield\n",
      "\tthe batter hit the ball to the outfield\n",
      "dist: 69.1388559651046:\n",
      "\tthe batter hit the ball to the outfield\n",
      "\tthe batter hit the ball into the outfield\n",
      "dist: 69.25298685831565:\n",
      "\tthe batter swung at the ball\n",
      "\tthe batter swung at the ball and\n",
      "dist: 69.25298685831565:\n",
      "\tthe batter swung at the ball and\n",
      "\tthe batter swung at the ball\n",
      "dist: 69.82999678947273:\n",
      "\tthe batter swung at the pitch and missed making it a strike\n",
      "\tthe batter swung at the pitch and missed for a strike\n",
      "dist: 69.82999678947273:\n",
      "\tthe batter swung at the pitch and missed for a strike\n",
      "\tthe batter swung at the pitch and missed making it a strike\n",
      "dist: 69.85038945294907:\n",
      "\tthe batter hit the ball into the play of field\n",
      "\tthen the batter hit the ball into the field of play\n",
      "dist: 70.88708976078404:\n",
      "\tso it is a foul ball\n",
      "\tit is a foul ball\n",
      "dist: 71.01187873825515:\n",
      "\tthe batter swung at and missed the pitch\n",
      "\tthe batter swung and missed at the pitch\n",
      "dist: 71.25937398268692:\n",
      "\tit's a home run\n",
      "\tit was a home run\n",
      "dist: 71.25937398268692:\n",
      "\tit was a home run\n",
      "\tit's a home run\n",
      "dist: 71.61763722981595:\n",
      "\tthe umpire calls it a strike\n",
      "\tthe umpire called it a strike\n",
      "dist: 72.59417516219362:\n",
      "\tthe batter hit a foul\n",
      "\tthen the batter hit it foul\n",
      "dist: 72.59417516219362:\n",
      "\tthen the batter hit it foul\n",
      "\tthe batter hit a foul\n",
      "dist: 72.73895606819472:\n",
      "\tso it was called a ball\n",
      "\tit was called a ball\n",
      "dist: 72.73895606819472:\n",
      "\tit was called a ball\n",
      "\tso it was called a ball\n",
      "dist: 72.91495479301291:\n",
      "\tthe ball was thrown outside of the strike zone\n",
      "\tthe ball was thrown outside the strike zone\n",
      "dist: 72.91495479301291:\n",
      "\tthe ball was thrown outside the strike zone\n",
      "\tthe ball was thrown outside of the strike zone\n",
      "dist: 74.8322709145963:\n",
      "\tit was below the strike zone\n",
      "\tand it was below the strike zone\n",
      "dist: 74.8322709145963:\n",
      "\tand it was below the strike zone\n",
      "\tit was below the strike zone\n",
      "dist: 74.93700872281427:\n",
      "\tthe batter swung at the pitch\n",
      "\tthe batter swung at the pitch and\n",
      "dist: 74.93700872281427:\n",
      "\tthe batter swung at the pitch and\n",
      "\tthe batter swung at the pitch\n",
      "dist: 75.77347731094035:\n",
      "\tthe ball landed outside of the strike zone\n",
      "\tthe ball landed outside the strike zone\n",
      "dist: 75.77347731094035:\n",
      "\tthe ball landed outside the strike zone\n",
      "\tthe ball landed outside of the strike zone\n",
      "dist: 76.03581489053872:\n",
      "\tit was caught by and outfielder\n",
      "\tit was caught by an outfielder\n",
      "dist: 76.90695240980774:\n",
      "\twho threw on to first base for an out\n",
      "\twho threw to first base for the out\n",
      "dist: 76.90695240980774:\n",
      "\twho threw to first base for the out\n",
      "\twho threw on to first base for an out\n",
      "dist: 77.03416560399737:\n",
      "\tthe batter swung his bat at the ball\n",
      "\tthe batter swung his bat and hit the ball\n",
      "dist: 77.03416560399737:\n",
      "\tthe batter swung his bat and hit the ball\n",
      "\tthe batter swung his bat at the ball\n",
      "dist: 78.49381633552464:\n",
      "\tthe batter hit a ground ball back to the pitcher\n",
      "\tthe batter hit the ball on the ground back to the pitcher\n",
      "dist: 78.49381633552464:\n",
      "\tthe batter hit the ball on the ground back to the pitcher\n",
      "\tthe batter hit a ground ball back to the pitcher\n",
      "dist: 78.51752467696413:\n",
      "\tthe batter swung and did not make contact with the\n",
      "\tthe batter swung and did not make contact\n",
      "dist: 78.77609877068524:\n",
      "\tthe batter hit the ball into the ground in foul territory\n",
      "\tthe batter hit the ball on the ground into foul territory\n",
      "dist: 79.38733939303991:\n",
      "\tthe batter swung at the pitch but did not make contact with the ball\n",
      "\tthen the batter swung at but didn't make contact with the pitch\n",
      "dist: 79.38733939303991:\n",
      "\tthen the batter swung at but didn't make contact with the pitch\n",
      "\tthe batter swung at the pitch but did not make contact with the ball\n",
      "dist: 79.4325478101899:\n",
      "\tit is a foul\n",
      "\tit was foul\n",
      "dist: 79.4325478101899:\n",
      "\tit was foul\n",
      "\tit is a foul\n",
      "dist: 79.52601991403124:\n",
      "\twho threw it to first base for a out\n",
      "\twho threw to first base for the out\n",
      "dist: 79.66398579569098:\n",
      "\tthe batter did not\n",
      "\tthe batter didn't\n",
      "dist: 79.66398579569098:\n",
      "\tthe batter didn't\n",
      "\tthe batter did not\n",
      "dist: 80.26607666857096:\n",
      "\tthe batter hit a ground ball to the third baseman\n",
      "\tthe batter makes contact hitting a ground ball to the third baseman\n",
      "dist: 80.26607666857096:\n",
      "\tthe batter makes contact hitting a ground ball to the third baseman\n",
      "\tthe batter hit a ground ball to the third baseman\n",
      "dist: 80.37555627714275:\n",
      "\tthe batter hit it into left field\n",
      "\tthe batter hit the ball into left field\n",
      "dist: 80.37555627714275:\n",
      "\tthe batter hit the ball into left field\n",
      "\tthe batter hit it into left field\n",
      "dist: 80.66040248830481:\n",
      "\tit was not caught\n",
      "\tit wasn't caught\n",
      "dist: 80.66040248830481:\n",
      "\tit wasn't caught\n",
      "\tit was not caught\n",
      "dist: 81.1192151642343:\n",
      "\tthen the batter swung on the pitch but missed\n",
      "\tthe batter swung at the pitch and missed\n",
      "dist: 81.18177149865649:\n",
      "\tthe ball crossed the home plate area outside of the strike zone high and outside\n",
      "\tthe ball crossed the home plate area outside of the strike zone high\n",
      "dist: 81.18177149865649:\n",
      "\tthe ball crossed the home plate area outside of the strike zone high\n",
      "\tthe ball crossed the home plate area outside of the strike zone high and outside\n",
      "dist: 81.4989279373686:\n",
      "\tit was a called strike by the umpire\n",
      "\tit was called as a strike by the umpire\n",
      "dist: 81.4989279373686:\n",
      "\tit was called as a strike by the umpire\n",
      "\tit was a called strike by the umpire\n",
      "dist: 81.63655998174134:\n",
      "\tthe ball was not in the strike zone\n",
      "\tthe ball wasn't in the strike zone\n",
      "dist: 81.63655998174134:\n",
      "\tthe ball wasn't in the strike zone\n",
      "\tthe ball was not in the strike zone\n",
      "dist: 81.86657500684059:\n",
      "\the swung and missed it\n",
      "\the swung and missed\n",
      "dist: 81.86657500684059:\n",
      "\the swung and missed\n",
      "\the swung and missed it\n",
      "dist: 82.37433409162539:\n",
      "\tbatter made contact on the ball\n",
      "\tthen the batter made contact with the ball\n",
      "dist: 82.96147444886363:\n",
      "\tthe hitter did not swing at a\n",
      "\tthe hitter did not swing at it\n",
      "dist: 82.96147444886363:\n",
      "\tthe hitter did not swing at it\n",
      "\tthe hitter did not swing at a\n",
      "dist: 83.35808742872457:\n",
      "\tthe batter hit the ball to the third basemen\n",
      "\tthe batter hit the pitch to the third basemen\n",
      "dist: 83.35808742872457:\n",
      "\tthe batter hit the pitch to the third basemen\n",
      "\tthe batter hit the ball to the third basemen\n",
      "dist: 83.38137865155394:\n",
      "\tthe batter swung at it and hit the ball with his bat\n",
      "\tthe batter swung his bat and hit the ball\n",
      "dist: 83.69584180625596:\n",
      "\tthe batter hit it into foul\n",
      "\tthen the batter hit it foul\n",
      "dist: 83.72979975571988:\n",
      "\tthe batter hit the ball on the ground and was thrown out\n",
      "\tthe batter hit the ball on the ground but was thrown out\n",
      "dist: 83.72979975571988:\n",
      "\tthe batter hit the ball on the ground but was thrown out\n",
      "\tthe batter hit the ball on the ground and was thrown out\n",
      "dist: 84.40762882711631:\n",
      "\the was thrown out at first\n",
      "\tbut he was thrown out at first\n",
      "dist: 84.40762882711631:\n",
      "\tbut he was thrown out at first\n",
      "\the was thrown out at first\n",
      "dist: 85.31272604218688:\n",
      "\tthe batter swung and missed it\n",
      "\tthe batter swung and missed\n",
      "dist: 85.79010818171771:\n",
      "\tand the batter swung and missed\n",
      "\tand the batter swung and missed it\n",
      "dist: 85.79010818171771:\n",
      "\tand the batter swung and missed it\n",
      "\tand the batter swung and missed\n",
      "dist: 86.30272055833824:\n",
      "\tthe batter swung but missed the ball\n",
      "\tthe batter swung and missed the ball\n",
      "dist: 86.36912860351215:\n",
      "\tthe batter hit it in foul territory\n",
      "\tthe batter hit it into foul territory\n",
      "dist: 86.36912860351215:\n",
      "\tthe batter hit it into foul territory\n",
      "\tthe batter hit it in foul territory\n",
      "dist: 86.97532327816327:\n",
      "\tthe batter did not swing at the\n",
      "\tthe batter did not swing at it\n",
      "dist: 87.30460007697322:\n",
      "\tthe batter swung\n",
      "\tbatter swung and\n",
      "dist: 87.57782439807404:\n",
      "\tit was caught by the centerfielder for the out\n",
      "\tit was caught the centerfielder for an out\n",
      "dist: 87.57782439807404:\n",
      "\tit was caught the centerfielder for an out\n",
      "\tit was caught by the centerfielder for the out\n",
      "dist: 88.07393715188763:\n",
      "\tthe batter swung the ball and hit it\n",
      "\tthe batter swung at the ball and hit it\n",
      "dist: 88.07393715188763:\n",
      "\tthe batter swung at the ball and hit it\n",
      "\tthe batter swung the ball and hit it\n",
      "dist: 88.50440326121641:\n",
      "\tthe batter hit the ball to left field\n",
      "\tthe batter hit the ball into left field\n",
      "dist: 88.58930846450592:\n",
      "\tthe batter hit it up in the air\n",
      "\tthe batter hit it in the air\n",
      "dist: 88.64740395337796:\n",
      "\tthe batter made contact with the pitch and hit it into the air\n",
      "\tthe batter made contact with the pitch hitting it into the air\n",
      "dist: 88.64740395337796:\n",
      "\tthe batter made contact with the pitch hitting it into the air\n",
      "\tthe batter made contact with the pitch and hit it into the air\n",
      "dist: 88.80662690645757:\n",
      "\tthen the batter swung hard missing the ball\n",
      "\tthen the batter swung extremely hard missing the ball\n",
      "dist: 88.80662690645757:\n",
      "\tthen the batter swung extremely hard missing the ball\n",
      "\tthen the batter swung hard missing the ball\n",
      "dist: 88.807412063251:\n",
      "\tthe hitter swung and missed the ball for a strike\n",
      "\tthe hitter swung and missed for a strike\n",
      "dist: 88.807412063251:\n",
      "\tthe hitter swung and missed for a strike\n",
      "\tthe hitter swung and missed the ball for a strike\n",
      "dist: 89.18296234303781:\n",
      "\tthe batter swung at the ball and hit the ball\n",
      "\tthe batter swung at the ball and hit it\n",
      "dist: 89.21727548253043:\n",
      "\tthe ball landed outside of the strike zone without being swung at by the batter\n",
      "\tit landed outside of the strike zone without being swung at by the batter\n",
      "dist: 89.21727548253043:\n",
      "\tit landed outside of the strike zone without being swung at by the batter\n",
      "\tthe ball landed outside of the strike zone without being swung at by the batter\n",
      "dist: 89.52777073289509:\n",
      "\tthe batter is now out\n",
      "\tthe batter is out\n",
      "dist: 89.6074438047095:\n",
      "\tthen the batter swung but missed\n",
      "\tthe batter swung and missed\n",
      "dist: 89.95505480902779:\n",
      "\tthe ball was outside of the strike zone\n",
      "\tthe ball was outside the strike zone\n",
      "dist: 89.95505480902779:\n",
      "\tthe ball was outside the strike zone\n",
      "\tthe ball was outside of the strike zone\n",
      "dist: 90.43568816771116:\n",
      "\tthe center fielder caught the ball for an out\n",
      "\tthe center fielder caught it for an out\n",
      "dist: 90.43568816771116:\n",
      "\tthe center fielder caught it for an out\n",
      "\tthe center fielder caught the ball for an out\n",
      "dist: 90.6064736527795:\n",
      "\tthe pitch isn't in the strike zone\n",
      "\tthe pitch was not in the strike zone\n",
      "dist: 90.6064736527795:\n",
      "\tthe pitch was not in the strike zone\n",
      "\tthe pitch isn't in the strike zone\n",
      "dist: 90.63864052535708:\n",
      "\tthe batter swung his bat at the ball and missed\n",
      "\tthe batter swung the bat but missed the ball\n",
      "dist: 90.63864052535708:\n",
      "\tthe batter swung the bat but missed the ball\n",
      "\tthe batter swung his bat at the ball and missed\n",
      "dist: 90.74185222335694:\n",
      "\tthe batter hit a ball in foul territory\n",
      "\tthe batter hit the ball into foul territory\n",
      "dist: 90.76891400666759:\n",
      "\tthe batter doesn't swing\n",
      "\tbatter didn't swing\n",
      "dist: 91.28692089203021:\n",
      "\tthe batter didn't swing on a\n",
      "\tthe batter did not swing on it\n",
      "dist: 91.28692089203021:\n",
      "\tthe batter did not swing on it\n",
      "\tthe batter didn't swing on a\n",
      "dist: 91.6893455363889:\n",
      "\tbut it landed in foul territory\n",
      "\tit landed in foul territory\n",
      "dist: 91.6893455363889:\n",
      "\tit landed in foul territory\n",
      "\tbut it landed in foul territory\n",
      "dist: 91.88984280645589:\n",
      "\tthe batter hit the out side the field of play\n",
      "\tthen the batter hit the ball out side the field of play\n",
      "dist: 91.88984280645589:\n",
      "\tthen the batter hit the ball out side the field of play\n",
      "\tthe batter hit the out side the field of play\n",
      "dist: 91.94817353478359:\n",
      "\tthe batter hit the ball into center field\n",
      "\tthe batter hit the ball into centerfield\n",
      "dist: 92.01772008563383:\n",
      "\tthe batter fouled the pitch off\n",
      "\tthe batter fouled off the pitch\n",
      "dist: 92.17349307345087:\n",
      "\tthe batter took a swing at the pitch\n",
      "\tthe batter swung at the pitch\n",
      "dist: 92.22632413493088:\n",
      "\tthe batter swung at the pitch and missed making contact\n",
      "\tthe batter swung at the pitch and missed\n",
      "dist: 92.24658936512148:\n",
      "\tthe batter hit the ball on the ground to the third baseman\n",
      "\tthe batter hit a ground ball to the third baseman\n",
      "dist: 93.0821248596031:\n",
      "\tthe hitter hit a ground ball to the shortstop\n",
      "\tthe hitter hit the ball on the ground to the shortstop\n",
      "dist: 93.0821248596031:\n",
      "\tthe hitter hit the ball on the ground to the shortstop\n",
      "\tthe hitter hit a ground ball to the shortstop\n",
      "dist: 93.40823939528407:\n",
      "\tthe left fielder didn't catch it\n",
      "\tthe left fielder was not able to catch it\n",
      "dist: 93.40823939528407:\n",
      "\tthe left fielder was not able to catch it\n",
      "\tthe left fielder didn't catch it\n",
      "dist: 93.64960890130813:\n",
      "\tthe batter swung hard and missed the ball\n",
      "\tthen the batter swung hard missing the ball\n",
      "dist: 93.83322828689332:\n",
      "\tthe batter hit the ball on the infield\n",
      "\tthe batter hit the ball through the infield\n",
      "dist: 93.83322828689332:\n",
      "\tthe batter hit the ball through the infield\n",
      "\tthe batter hit the ball on the infield\n",
      "dist: 93.91434915263018:\n",
      "\tthe batter hit it on the ground towards the third baseman\n",
      "\tthe batter hit the ball on the ground to the third baseman\n",
      "dist: 94.87765578118055:\n",
      "\tthe pitch crossed the plate inside of the strike zone and was called a strike by the umpire\n",
      "\tthe ball crossed the plate inside of the strike zone and was called a strike by the umpire\n",
      "dist: 95.16687037986931:\n",
      "\tthe ball went outside the strike zone\n",
      "\tthe ball was outside the strike zone\n",
      "dist: 95.25444929326393:\n",
      "\tthe hitter hit the ball into foul\n",
      "\tthen the hitter hit the ball foul\n",
      "dist: 95.25444929326393:\n",
      "\tthen the hitter hit the ball foul\n",
      "\tthe hitter hit the ball into foul\n",
      "dist: 95.27686237336574:\n",
      "\the swung and miss\n",
      "\the swung and missed\n",
      "dist: 95.5105570278093:\n",
      "\tthe hitter had arrived at first base\n",
      "\tthe hitter arrived at first base\n",
      "dist: 95.5105570278093:\n",
      "\tthe hitter arrived at first base\n",
      "\tthe hitter had arrived at first base\n",
      "dist: 95.84325728695225:\n",
      "\tthe batter swings his bat\n",
      "\tthe batter swung his bat at the ball\n",
      "dist: 96.29560629252568:\n",
      "\tit would be a ball\n",
      "\tit was a ball\n",
      "dist: 96.37341484989845:\n",
      "\tit was caught mid air\n",
      "\tit was caught in the air\n",
      "dist: 96.89702376398711:\n",
      "\tit was low for a\n",
      "\tit was low\n",
      "dist: 96.89702376398711:\n",
      "\tit was low\n",
      "\tit was low for a\n",
      "dist: 97.01852180299805:\n",
      "\tthe batter swinged and missed the ball\n",
      "\tthe batter swung and missed the ball\n",
      "dist: 97.06341743808214:\n",
      "\tthe hitter swung at the ball and missed\n",
      "\tthe hitter swung and missed the ball\n",
      "dist: 97.06341743808214:\n",
      "\tthe hitter swung and missed the ball\n",
      "\tthe hitter swung at the ball and missed\n",
      "dist: 97.21437012070881:\n",
      "\tthe pitcher threw the ball outside the strike zone\n",
      "\tthe pitcher threw the ball which was outside the strike zone and the\n",
      "dist: 97.21437012070881:\n",
      "\tthe pitcher threw the ball which was outside the strike zone and the\n",
      "\tthe pitcher threw the ball outside the strike zone\n",
      "dist: 98.1158451040529:\n",
      "\tthe batter made contact smashing it through the right side of the infield for a hit\n",
      "\tthe batter hit it through the right side of the infield for a hit\n",
      "dist: 98.1158451040529:\n",
      "\tthe batter hit it through the right side of the infield for a hit\n",
      "\tthe batter made contact smashing it through the right side of the infield for a hit\n",
      "dist: 98.87634580397359:\n",
      "\tthe batter swung and missed for a strike\n",
      "\tthen the batter swung at the ball and missed for a strike\n",
      "dist: 98.87634580397359:\n",
      "\tthen the batter swung at the ball and missed for a strike\n",
      "\tthe batter swung and missed for a strike\n",
      "dist: 99.44984247097383:\n",
      "\tthe batter swung at the pitch and made contact\n",
      "\tthe batter swung and made contact with the pitch\n",
      "dist: 99.44984247097383:\n",
      "\tthe batter swung and made contact with the pitch\n",
      "\tthe batter swung at the pitch and made contact\n",
      "dist: 99.81943494484844:\n",
      "\tthe batter swung at the outside pitch but missed\n",
      "\tthe batter swung at the pitch and missed\n",
      "dist: 100.10139330445197:\n",
      "\tthe ball did not cross the plate inside of the strike zone and was called a ball by the umpire\n",
      "\tthe pitch did not cross the plate inside the strike zone and was called a ball by the umpire\n",
      "dist: 100.47108291205502:\n",
      "\tthen the batter hit it on the ground\n",
      "\tthe batter hit a ground\n",
      "dist: 100.47108291205502:\n",
      "\tthe batter hit a ground\n",
      "\tthen the batter hit it on the ground\n",
      "dist: 101.06316396182145:\n",
      "\tthe hit was a home run and went over the outfield fence\n",
      "\tit went over the outfield fence for a home run\n",
      "dist: 101.06316396182145:\n",
      "\tit went over the outfield fence for a home run\n",
      "\tthe hit was a home run and went over the outfield fence\n",
      "dist: 101.89682177775747:\n",
      "\tthe ball was hit in the air out to left field and was not caught\n",
      "\tthen the ball was hit out to left field and was not caught\n",
      "dist: 101.89682177775747:\n",
      "\tthen the ball was hit out to left field and was not caught\n",
      "\tthe ball was hit in the air out to left field and was not caught\n",
      "dist: 102.42443850099184:\n",
      "\tthe batter swung the bat at the pitch but missed\n",
      "\tthe batter swung at the pitch and missed\n",
      "dist: 102.45692266257176:\n",
      "\tthen the batter swung and hit the ball on the ground to the third baseman\n",
      "\tthe batter hit the ball on the ground to the third baseman\n",
      "dist: 102.91105065289489:\n",
      "\tthe batter hit the ball back to the pitcher\n",
      "\tthe batter hit a ground ball back to the pitcher\n",
      "dist: 103.30346401444953:\n",
      "\ttherefore it is a foul ball\n",
      "\tso it is a foul ball\n",
      "dist: 103.37895224268324:\n",
      "\tthe batter swung at a pitch and missed striking out\n",
      "\tthe batter swung at the pitch and missed for a strike\n",
      "dist: 103.4372357713199:\n",
      "\tthe batter swung at the pitch and missed it completely\n",
      "\tthe batter swung at the pitch and missed\n",
      "dist: 103.67194895823111:\n",
      "\twho throws him out\n",
      "\twho threw him out\n",
      "dist: 103.67194895823111:\n",
      "\twho threw him out\n",
      "\twho throws him out\n",
      "dist: 103.97496195076482:\n",
      "\tthe batter swung and made contact\n",
      "\tthe batter swung and made contact with the ball\n",
      "dist: 103.97496195076482:\n",
      "\tthe batter swung and made contact with the ball\n",
      "\tthe batter swung and made contact\n",
      "dist: 104.19777925517617:\n",
      "\ta ball hit into play on the ground\n",
      "\tthe ball was hit in play on the ground by the\n",
      "dist: 104.19777925517617:\n",
      "\tthe ball was hit in play on the ground by the\n",
      "\ta ball hit into play on the ground\n",
      "dist: 104.3074970088081:\n",
      "\tbatter swung and pitch and missed the ball which is a\n",
      "\tthe batter swung and missed the pitch\n",
      "dist: 104.91749453674387:\n",
      "\tit was not in play\n",
      "\tbut it was not in play\n",
      "dist: 104.91749453674387:\n",
      "\tbut it was not in play\n",
      "\tit was not in play\n",
      "dist: 105.39634400033454:\n",
      "\tit is a called strike\n",
      "\tit was a called strike\n",
      "dist: 105.61781548655365:\n",
      "\tthe batter takes the pitch\n",
      "\tthe batter took the pitch\n",
      "dist: 105.71281083831954:\n",
      "\tthe batter hit the ball in the air to the outfield\n",
      "\tthe batter hit the ball into the outfield\n",
      "dist: 105.74004478803803:\n",
      "\tthe fielder caught in the air\n",
      "\tthe fielder caught it in the air\n",
      "dist: 105.74004478803803:\n",
      "\tthe fielder caught it in the air\n",
      "\tthe fielder caught in the air\n",
      "dist: 105.9848184159226:\n",
      "\tthe centerfield caught the ball\n",
      "\tthe centerfielder caught the ball\n",
      "dist: 105.9848184159226:\n",
      "\tthe centerfielder caught the ball\n",
      "\tthe centerfield caught the ball\n",
      "dist: 105.98594450335335:\n",
      "\tthe batter hit a ground ball and was thrown out\n",
      "\tthe batter hit the ball on the ground and was thrown out\n",
      "dist: 106.23124062770246:\n",
      "\tthe ball crossed the plate in the strike zone\n",
      "\tthe ball crossed over the plate in the strike zone\n",
      "dist: 106.23124062770246:\n",
      "\tthe ball crossed over the plate in the strike zone\n",
      "\tthe ball crossed the plate in the strike zone\n",
      "dist: 106.27196612612086:\n",
      "\thit the ball to left center field\n",
      "\thit it to left center field\n",
      "dist: 106.27196612612086:\n",
      "\thit it to left center field\n",
      "\thit the ball to left center field\n",
      "dist: 107.38839994820775:\n",
      "\tbatter swung at pitch and missed ball which is a strike\n",
      "\tthe batter swung at the pitch and missed for a strike\n",
      "dist: 107.95544580028134:\n",
      "\tthen the batter swung hard and missed\n",
      "\tthe batter swung hard and missed the ball\n",
      "dist: 108.13396358776579:\n",
      "\tthe batter popped up the ball to the first baseman\n",
      "\tthe batter hit a pop up to the first baseman\n",
      "dist: 108.13396358776579:\n",
      "\tthe batter hit a pop up to the first baseman\n",
      "\tthe batter popped up the ball to the first baseman\n",
      "dist: 108.86406443019139:\n",
      "\tthen the batter swung at the pitch and missed the ball without making contact\n",
      "\tthe batter swung at the pitch and missed making contact\n",
      "dist: 109.1407953334422:\n",
      "\tthe batter did not swing at the ball\n",
      "\tthe batter did not swing at the pitch\n",
      "dist: 109.24007826590771:\n",
      "\tthe batter did not swing his bat\n",
      "\tthe batter didn't swing the bat\n",
      "dist: 109.85088661573451:\n",
      "\tball was hit into the\n",
      "\tthe ball was hit\n",
      "dist: 109.85472684977783:\n",
      "\tthe batter hit it into play on the ground\n",
      "\tthe batter hit the ball on the ground in play\n",
      "dist: 109.9410249584026:\n",
      "\tthe pitcher threw a ball just outside the strike box\n",
      "\tthe pitcher threw the ball outside the strike zone\n",
      "dist: 110.16152805793645:\n",
      "\tadditionally the batter did not swing at it\n",
      "\tadditionally the batter did not swing at the pitch\n",
      "dist: 110.16152805793645:\n",
      "\tadditionally the batter did not swing at the pitch\n",
      "\tadditionally the batter did not swing at it\n",
      "dist: 110.43161498198137:\n",
      "\tthe pitch missed crossing through the strike zone\n",
      "\tthe pitch missed going through the strike zone\n",
      "dist: 110.43161498198137:\n",
      "\tthe pitch missed going through the strike zone\n",
      "\tthe pitch missed crossing through the strike zone\n",
      "dist: 110.52007227529366:\n",
      "\tit did not cross the plate inside of the strike zone\n",
      "\tit did not cross the plate in the strike zone\n",
      "dist: 110.52007227529366:\n",
      "\tit did not cross the plate in the strike zone\n",
      "\tit did not cross the plate inside of the strike zone\n",
      "dist: 110.5657460721114:\n",
      "\tthe batter swung the bat and did not make contact with the ball\n",
      "\tthe batter swung and did not make contact with the ball\n",
      "dist: 110.62925082615318:\n",
      "\tthe batter swung and hit the ball on the ground\n",
      "\tthe batter swung and hit the ball on the ground towards the\n",
      "dist: 110.62925082615318:\n",
      "\tthe batter swung and hit the ball on the ground towards the\n",
      "\tthe batter swung and hit the ball on the ground\n",
      "dist: 110.70074898953672:\n",
      "\tthe batter didnt swing at\n",
      "\tthe batter didnt swing\n",
      "dist: 111.05137596846824:\n",
      "\tbatter hit the ball past the shortstop for a\n",
      "\tbatter hits it past shortstop for a hit\n",
      "dist: 111.05137596846824:\n",
      "\tbatter hits it past shortstop for a hit\n",
      "\tbatter hit the ball past the shortstop for a\n",
      "dist: 111.11578638581666:\n",
      "\tthe batter hit it towards right field\n",
      "\tthe batter hit the ball to right field\n",
      "dist: 111.79988351145501:\n",
      "\tthe first baseman made the catch in the air\n",
      "\tthe first baseman caught the ball in the air\n",
      "dist: 111.79988351145501:\n",
      "\tthe first baseman caught the ball in the air\n",
      "\tthe first baseman made the catch in the air\n",
      "dist: 112.42567310316448:\n",
      "\tthe ball landed outside of fair play without being caught\n",
      "\tthe ball landed beyond the boundaries of fair play without getting caught\n",
      "dist: 112.42567310316448:\n",
      "\tthe ball landed beyond the boundaries of fair play without getting caught\n",
      "\tthe ball landed outside of fair play without being caught\n",
      "dist: 112.99575081749865:\n",
      "\tthe batter did not swing at a called ball\n",
      "\tthe batter did not swing at a called\n",
      "dist: 112.99575081749865:\n",
      "\tthe batter did not swing at a called\n",
      "\tthe batter did not swing at a called ball\n",
      "dist: 113.24507834168055:\n",
      "\tthe batter struck the ball\n",
      "\tthe batter hits the ball\n",
      "dist: 113.3215413459686:\n",
      "\tbatter did not swing at ball not in strike zone\n",
      "\tthe batter did not swing at a ball in the strike zone\n",
      "dist: 113.47132155922995:\n",
      "\tthe ball was right in the center of the strike box\n",
      "\tthe ball was in the center of the strike box\n",
      "dist: 113.47132155922995:\n",
      "\tthe ball was in the center of the strike box\n",
      "\tthe ball was right in the center of the strike box\n",
      "dist: 113.48109193712214:\n",
      "\tthe batter hit the ball in the air to the left fielder\n",
      "\tthe batter hit the ball to the left fielder\n",
      "dist: 113.48109193712214:\n",
      "\tthe batter hit the ball to the left fielder\n",
      "\tthe batter hit the ball in the air to the left fielder\n",
      "dist: 113.6577808097347:\n",
      "\tit was caught by the catcher in the strike zone\n",
      "\tit was caught by the catcher outside of the strike zone\n",
      "dist: 113.6577808097347:\n",
      "\tit was caught by the catcher outside of the strike zone\n",
      "\tit was caught by the catcher in the strike zone\n",
      "dist: 113.82805980836683:\n",
      "\ttherefore it was a ball\n",
      "\tit is a ball\n",
      "dist: 114.21420520583601:\n",
      "\tit went through the strike zone\n",
      "\tit passed through the strike zone\n",
      "dist: 114.21420520583601:\n",
      "\tit passed through the strike zone\n",
      "\tit went through the strike zone\n",
      "dist: 114.47008381079578:\n",
      "\tthe batter hit a high ball in the outfield\n",
      "\tthe batter hit the ball hard into the outfield\n",
      "dist: 114.47008381079578:\n",
      "\tthe batter hit the ball hard into the outfield\n",
      "\tthe batter hit a high ball in the outfield\n",
      "dist: 114.59056647305675:\n",
      "\tthe right fielder caught the ball\n",
      "\tthe right fielder caught\n",
      "dist: 114.59056647305675:\n",
      "\tthe right fielder caught\n",
      "\tthe right fielder caught the ball\n",
      "dist: 114.72695046820233:\n",
      "\tthe batter hit a ground ball to the 3rd baseman\n",
      "\tthe batter hit a ground ball to the third baseman\n",
      "dist: 114.8321338212473:\n",
      "\tit was also a strike\n",
      "\tit is also a strike\n",
      "dist: 114.8321338212473:\n",
      "\tit is also a strike\n",
      "\tit was also a strike\n",
      "dist: 114.9443895658397:\n",
      "\tthe batter hit a ground ball between first and second base\n",
      "\tthe batter hit a ground ball to second base\n",
      "dist: 115.27628062952502:\n",
      "\tthe batter hit the ball in the air to center field\n",
      "\tthe batter hit the ball into center field\n",
      "dist: 115.31525010529647:\n",
      "\tthe ball crossed into the strike zone\n",
      "\tthe ball crossed the strike zone\n",
      "dist: 115.31525010529647:\n",
      "\tthe ball crossed the strike zone\n",
      "\tthe ball crossed into the strike zone\n",
      "dist: 115.49657808212332:\n",
      "\tthe batter hit the ball on the ground between the first and second baseman\n",
      "\tthe batter hit the ball on the ground to the second baseman\n",
      "dist: 115.55332830998059:\n",
      "\tthe batter hit the ball which bounced on the ground towards the second baseman\n",
      "\tthe batter hit the ball on the ground to the second baseman\n",
      "dist: 115.60903435954158:\n",
      "\tthe batter hit it down the left field line\n",
      "\tthe batter hit the ball down the left field line for a hit\n",
      "dist: 115.60903435954158:\n",
      "\tthe batter hit the ball down the left field line for a hit\n",
      "\tthe batter hit it down the left field line\n",
      "dist: 115.88448240977512:\n",
      "\tthe batter hit the ball into the left field for a hit\n",
      "\tthe batter hit the ball down the left field line for a hit\n",
      "dist: 115.88494340982204:\n",
      "\tthe batter hit the ball in the air to the centerfielder\n",
      "\tthe batter hit the ball in the air to center field\n",
      "dist: 116.1082940049408:\n",
      "\tthe batter hit the ball into play in the air\n",
      "\tbatter hit ball in air\n",
      "dist: 116.45007232004635:\n",
      "\tthe count went from 01 to 02 no balls and 2 strikes\n",
      "\tthe count was 02 no balls and 2 strikes\n",
      "dist: 116.45007232004635:\n",
      "\tthe count was 02 no balls and 2 strikes\n",
      "\tthe count went from 01 to 02 no balls and 2 strikes\n",
      "dist: 116.4995079438257:\n",
      "\tit was low and outside of the strike zone\n",
      "\tit was low and outside the strike zone\n",
      "dist: 116.4995079438257:\n",
      "\tit was low and outside the strike zone\n",
      "\tit was low and outside of the strike zone\n",
      "dist: 116.93527913386173:\n",
      "\tthe batter hit the ball to foul territory\n",
      "\tthe batter hit the ball into foul territory\n",
      "dist: 117.17636885045724:\n",
      "\the hit it on the ground\n",
      "\the hit it off the ground\n",
      "dist: 117.17636885045724:\n",
      "\the hit it off the ground\n",
      "\the hit it on the ground\n",
      "dist: 117.40353653366404:\n",
      "\tthe batter hit it towards center field\n",
      "\tthe batter hit the ball into center field\n",
      "dist: 117.50445969285418:\n",
      "\tthe ball was in foul territory\n",
      "\tthe ball landed in foul territory\n",
      "dist: 117.50445969285418:\n",
      "\tthe ball landed in foul territory\n",
      "\tthe ball was in foul territory\n",
      "dist: 117.52925069660621:\n",
      "\tthe ball crossed the plate outside of the strike zone resulting in a ball\n",
      "\tthe ball crossed the plate outside of the strike zone\n",
      "dist: 117.65345719773866:\n",
      "\tthe batter reached base safely\n",
      "\tthe batter was able to reach base safely\n",
      "dist: 117.65345719773866:\n",
      "\tthe batter was able to reach base safely\n",
      "\tthe batter reached base safely\n",
      "dist: 118.1931895482867:\n",
      "\tit went outside of the strike zone\n",
      "\tit was outside of the strike zone\n",
      "dist: 118.1931895482867:\n",
      "\tit was outside of the strike zone\n",
      "\tit went outside of the strike zone\n",
      "dist: 118.38152311703115:\n",
      "\tthe batter swung the bat\n",
      "\tthe batter swings his bat\n",
      "dist: 118.43716607610789:\n",
      "\tthe player hit it to the outfield\n",
      "\tthen he hit the ball into the outfield\n",
      "dist: 118.43716607610789:\n",
      "\tthen he hit the ball into the outfield\n",
      "\tthe player hit it to the outfield\n",
      "dist: 118.50991866515649:\n",
      "\tthe batter swung and hit the ball into play\n",
      "\tthe batter swung at the ball and hit the ball\n",
      "dist: 118.66003560129917:\n",
      "\tthe batter swung and hit the ball to the outfield\n",
      "\tthe batter hit the ball to the outfield\n",
      "dist: 118.70587958752103:\n",
      "\tthe batter did not swing at the pitch which was outside the strike zone\n",
      "\tbatter did not swing at pitch in strike zone\n",
      "dist: 118.81154636114577:\n",
      "\tthe batter made contact with the pitch and hit it in the air into foul territory\n",
      "\tthe batter made contact with the pitch and hit it into foul territory\n",
      "dist: 118.81154636114577:\n",
      "\tthe batter made contact with the pitch and hit it into foul territory\n",
      "\tthe batter made contact with the pitch and hit it in the air into foul territory\n",
      "dist: 119.24477991057127:\n",
      "\tthe umpire signaled for a strike\n",
      "\tthe umpire signaled a strike\n",
      "dist: 119.24477991057127:\n",
      "\tthe umpire signaled a strike\n",
      "\tthe umpire signaled for a strike\n",
      "dist: 119.24564202139943:\n",
      "\thit a ground ball to shortstop\n",
      "\tthe hitter hit a ground ball to the shortstop\n",
      "dist: 119.40836861155465:\n",
      "\tthe ball landed on the ground before reaching the shortstop\n",
      "\tit landed on the ground before reaching the shortstop\n",
      "dist: 119.40836861155465:\n",
      "\tit landed on the ground before reaching the shortstop\n",
      "\tthe ball landed on the ground before reaching the shortstop\n",
      "dist: 120.25538259848949:\n",
      "\tit did not land in the field of play\n",
      "\tit did not go in the field of play\n",
      "dist: 120.25538259848949:\n",
      "\tit did not go in the field of play\n",
      "\tit did not land in the field of play\n",
      "dist: 120.85318127304384:\n",
      "\tthe batter made contact and hit the ball into foul territory\n",
      "\tthe batter hit the ball into foul territory\n",
      "dist: 120.99847409398612:\n",
      "\tthe batter hit a fly\n",
      "\tthe batter hit a fly ball\n",
      "dist: 120.99847409398612:\n",
      "\tthe batter hit a fly ball\n",
      "\tthe batter hit a fly\n",
      "dist: 121.39361096399796:\n",
      "\tthe ball landed in the strike zone\n",
      "\tthe ball was in the strike zone\n",
      "dist: 121.649828554305:\n",
      "\tthe batter swung and connected with the pitch\n",
      "\tthe batter swung his bat and connected with the pitch\n",
      "dist: 121.649828554305:\n",
      "\tthe batter swung his bat and connected with the pitch\n",
      "\tthe batter swung and connected with the pitch\n",
      "dist: 121.98384791116321:\n",
      "\tthe ball went to outside of the strike zone\n",
      "\tthe ball went outside the strike zone\n",
      "dist: 122.15720855097138:\n",
      "\tthe batter hit the pitch into the air\n",
      "\tthe batter made contact with the pitch hitting it into the air\n",
      "dist: 122.18783856045147:\n",
      "\tthe batter was\n",
      "\tthe batter\n",
      "dist: 122.18783856045147:\n",
      "\tthe batter\n",
      "\tthe batter was\n",
      "dist: 122.33471063716257:\n",
      "\tit fell below the strike zone\n",
      "\tit was below the strike zone\n",
      "dist: 122.93977916949287:\n",
      "\tbatter hit a ground ball to third base and was thrown\n",
      "\tthe batter makes contact hitting a ground ball to the third baseman\n",
      "dist: 123.33909027691627:\n",
      "\tthe batter swung hit the\n",
      "\tthe batter swung and hit the ball on the\n",
      "dist: 123.42875646322416:\n",
      "\tthen the batter hit a home run\n",
      "\tthe batter hit a home\n",
      "dist: 123.46661958456728:\n",
      "\tit is called a ball\n",
      "\tit was called a ball\n",
      "dist: 123.66280465384361:\n",
      "\tthe pitcher threw the play\n",
      "\tthe pitcher threw the ball\n",
      "dist: 123.91458373967824:\n",
      "\tthe batter did not swing and just took the pitch\n",
      "\tthe batter did not swing at the ball and just took the pitch\n",
      "dist: 123.91458373967824:\n",
      "\tthe batter did not swing at the ball and just took the pitch\n",
      "\tthe batter did not swing and just took the pitch\n",
      "dist: 123.96845707259749:\n",
      "\tit was caught by the center fielder for the out\n",
      "\tthe center fielder caught it for an out\n",
      "dist: 124.28443693871584:\n",
      "\tit went behind them\n",
      "\tit went behind him\n",
      "dist: 124.28443693871584:\n",
      "\tit went behind him\n",
      "\tit went behind them\n",
      "dist: 124.35988131338588:\n",
      "\tthe batter hit the pitch on the ground between the first baseman and the second baseman\n",
      "\tthe batter hit the ball on the ground between the first and second baseman\n",
      "dist: 124.5803204632967:\n",
      "\tit was outside and low of the strike zone\n",
      "\tit was low and outside the strike zone\n",
      "dist: 124.60068821592651:\n",
      "\tthe batter hit it into centerleft field\n",
      "\tthe batter hit it into left field\n",
      "dist: 124.7252436759762:\n",
      "\tthe batter hit the ball in the air but into the stands in foul territory\n",
      "\tthe batter hit the ball into the stands in foul territory\n",
      "dist: 124.7252436759762:\n",
      "\tthe batter hit the ball into the stands in foul territory\n",
      "\tthe batter hit the ball in the air but into the stands in foul territory\n",
      "dist: 124.72571030092725:\n",
      "\tthe ball did not go through the strike zone\n",
      "\tthe ball was not thrown through the strike zone\n",
      "dist: 124.72571030092725:\n",
      "\tthe ball was not thrown through the strike zone\n",
      "\tthe ball did not go through the strike zone\n",
      "dist: 124.74132068213619:\n",
      "\tthe batter swung at it and missed the ball completely\n",
      "\tthe batter swung at the ball and missed it\n",
      "dist: 125.11390971370932:\n",
      "\tthe batter swung the bat and hit the ball into center field\n",
      "\tthe batter hit the ball into center field\n",
      "dist: 125.17061199010557:\n",
      "\tthe batter struck out and took a swing and a miss\n",
      "\tthe batter swung and missed striking out\n",
      "dist: 125.17061199010557:\n",
      "\tthe batter swung and missed striking out\n",
      "\tthe batter struck out and took a swing and a miss\n",
      "dist: 125.27106189096887:\n",
      "\tthe hitter did not swing at the pitch\n",
      "\tthe hitter did not swing at it\n",
      "dist: 125.40683012136931:\n",
      "\tthe hitter hit it into foul\n",
      "\tthe hitter hit the ball into foul\n",
      "dist: 125.84487792545664:\n",
      "\tthe batter swung and hit the ball in the air\n",
      "\tthe batter swung and hit the ball high in the air\n",
      "dist: 125.84487792545664:\n",
      "\tthe batter swung and hit the ball high in the air\n",
      "\tthe batter swung and hit the ball in the air\n",
      "dist: 126.33404940851582:\n",
      "\tthe batter hit the ball but went behind him foul\n",
      "\tthe batter hit the ball which landed behind the foul\n",
      "dist: 126.33404940851582:\n",
      "\tthe batter hit the ball which landed behind the foul\n",
      "\tthe batter hit the ball but went behind him foul\n",
      "dist: 126.36411973181156:\n",
      "\tthe batter hit out to the outfield\n",
      "\tthe batter hit the ball to the outfield\n",
      "dist: 126.4408626280194:\n",
      "\tball was thrown in the strike zone\n",
      "\tthe ball appeared to be thrown in the strike zone\n",
      "dist: 126.4408626280194:\n",
      "\tthe ball appeared to be thrown in the strike zone\n",
      "\tball was thrown in the strike zone\n",
      "dist: 126.67655494107119:\n",
      "\tthen it was hit on the ground\n",
      "\tit hit the ground\n",
      "dist: 126.67655494107119:\n",
      "\tit hit the ground\n",
      "\tthen it was hit on the ground\n",
      "dist: 127.23375269021115:\n",
      "\tthen the batter swung and hit it on the ground past the third basemen and into the outfield\n",
      "\tthen the batter swung and hit the ball on the ground to the third baseman\n",
      "dist: 127.59941018186426:\n",
      "\tthe batter swung and hit the ball into foul territory\n",
      "\tthe batter made contact and hit the ball into foul territory\n",
      "dist: 127.82420364475111:\n",
      "\tthen the umpire ruled it as a strike\n",
      "\tthe umpire ruled it a strike\n",
      "dist: 127.82420364475111:\n",
      "\tthe umpire ruled it a strike\n",
      "\tthen the umpire ruled it as a strike\n",
      "dist: 127.86357521112866:\n",
      "\tthe ball crossed the home plate area outside of the strike zone inside\n",
      "\tball crossed home plate outside the strike zone\n",
      "dist: 129.51945017879103:\n",
      "\tthe ball was hit into play and landed on the ground\n",
      "\tthe ball was hit in play on the ground by the\n",
      "dist: 129.53703206303823:\n",
      "\tthe second baseman fielded a ground ball and threw out the batter at first\n",
      "\tthe second baseman fielded the ball and threw the runner out at\n",
      "dist: 129.53703206303823:\n",
      "\tthe second baseman fielded the ball and threw the runner out at\n",
      "\tthe second baseman fielded a ground ball and threw out the batter at first\n",
      "dist: 129.54255040819336:\n",
      "\tit was low and\n",
      "\tit was low\n",
      "dist: 129.66536768942362:\n",
      "\tthe batter swung and missed hitting the ball\n",
      "\tthe batter swung and missed the ball\n",
      "dist: 129.704842471022:\n",
      "\tthe batter hit a fly ball to deep left field which was caught by the left fielder\n",
      "\tbatter hit a fly ball to left field which was caught by the left\n",
      "dist: 129.704842471022:\n",
      "\tbatter hit a fly ball to left field which was caught by the left\n",
      "\tthe batter hit a fly ball to deep left field which was caught by the left fielder\n",
      "dist: 129.7634129928767:\n",
      "\tthe batter hit and put the ball into play\n",
      "\tthe batter hit the ball into play\n",
      "dist: 129.94712532022353:\n",
      "\tit was caught by the right outfielder\n",
      "\tit was caught by an outfielder\n",
      "dist: 130.04319290081827:\n",
      "\tit ended up in foul territory\n",
      "\tit landed in foul territory\n",
      "dist: 130.4694402804009:\n",
      "\tit was way below the strike zone\n",
      "\tand it was below the strike zone\n",
      "dist: 130.505056208343:\n",
      "\tthe pitch did not cross the plate inside of the strike zone\n",
      "\tthe pitch did not cross home plate in the strike zone\n",
      "dist: 130.505056208343:\n",
      "\tthe pitch did not cross home plate in the strike zone\n",
      "\tthe pitch did not cross the plate inside of the strike zone\n",
      "dist: 130.5524286168357:\n",
      "\tthe hitter hit the ball up in the air and outside the field of play\n",
      "\tthe hitter hit the ball outside the field of play\n",
      "dist: 130.5524286168357:\n",
      "\tthe hitter hit the ball outside the field of play\n",
      "\tthe hitter hit the ball up in the air and outside the field of play\n",
      "dist: 130.66574506730745:\n",
      "\tthen the hitter swung hard missing the ball\n",
      "\tthe hitter swung at the ball and missed\n",
      "dist: 130.88879222044403:\n",
      "\tthe batter swung and hit the ball into right field\n",
      "\tbatter hit ball to right field\n",
      "dist: 131.26244160276752:\n",
      "\tthe pitch was caught by the catcher outside the strike zone\n",
      "\tit was caught by the catcher outside of the strike zone\n",
      "dist: 131.26323900326594:\n",
      "\tthe batter hit a single and ended up at first base\n",
      "\tthe batter ended up on first base for a hit\n",
      "dist: 131.26323900326594:\n",
      "\tthe batter ended up on first base for a hit\n",
      "\tthe batter hit a single and ended up at first base\n",
      "dist: 131.5821724269327:\n",
      "\tthe batter swung and connected with the ball\n",
      "\tthe batter swung and connected with the pitch\n",
      "dist: 131.70012630108664:\n",
      "\tthe right fielder caught the ball in the outfield\n",
      "\tthe right fielder caught the ball\n",
      "dist: 131.77041178119458:\n",
      "\tit crossed the plate outside of the strike zone for a ball\n",
      "\tthe ball crossed the plate outside of the strike zone resulting in a ball\n",
      "dist: 131.79687971295704:\n",
      "\tthe batter made contact and hit the ball towards the shortstop\n",
      "\tbatter hits it past shortstop for a hit\n",
      "dist: 133.07549658844331:\n",
      "\tit went in the strike zone\n",
      "\tit went into the strike zone\n",
      "dist: 133.07549658844331:\n",
      "\tit went into the strike zone\n",
      "\tit went in the strike zone\n",
      "dist: 133.16265504864245:\n",
      "\tthe centerfielder caught it\n",
      "\tthe centerfielder caught the ball\n",
      "dist: 133.22402417837935:\n",
      "\tthe ball is hit in the air to right field\n",
      "\tthe hitter hit the ball in the air to right field\n",
      "dist: 133.22402417837935:\n",
      "\tthe hitter hit the ball in the air to right field\n",
      "\tthe ball is hit in the air to right field\n",
      "dist: 133.32013446896855:\n",
      "\tthe ball hit the strike zone\n",
      "\tthe ball was in the strike zone\n",
      "dist: 133.79695931046984:\n",
      "\tthe umpire called it as a strike\n",
      "\tthe umpire called it a strike\n",
      "dist: 133.84071876986386:\n",
      "\tthen the batter swung and hit the ball behind him and into the stands\n",
      "\tthen the batter hit the ball behind him into the stands\n",
      "dist: 133.84071876986386:\n",
      "\tthen the batter hit the ball behind him into the stands\n",
      "\tthen the batter swung and hit the ball behind him and into the stands\n",
      "dist: 134.86702836143635:\n",
      "\tthe pitch missed the strike zone\n",
      "\tthe pitch missed going through the strike zone\n",
      "dist: 134.87138680864797:\n",
      "\tthe hitter swung and fouled off the ball\n",
      "\tthe hitter swung fouling the ball\n",
      "dist: 134.87138680864797:\n",
      "\tthe hitter swung fouling the ball\n",
      "\tthe hitter swung and fouled off the ball\n",
      "dist: 135.41147307793932:\n",
      "\tthe pitcher threw the ball that cross the plate outside of the strike zone\n",
      "\tthe pitcher threw the ball outside the strike zone\n",
      "dist: 135.58101295964954:\n",
      "\tthe batter swung and hit the ball deep into left field\n",
      "\tthe batter hit it into left field\n",
      "dist: 135.63567101345603:\n",
      "\tthe batter hit the ball in the air to the left of third base and into the stands\n",
      "\tthe batter hit it into the stands to the left of the third base foul line\n",
      "dist: 135.63567101345603:\n",
      "\tthe batter hit it into the stands to the left of the third base foul line\n",
      "\tthe batter hit the ball in the air to the left of third base and into the stands\n",
      "dist: 135.69952048269428:\n",
      "\tthe batter did not swing at the pitch with his bat\n",
      "\tthe batter did not swing his bat\n",
      "dist: 135.77795436205548:\n",
      "\tthe pitch was low\n",
      "\tthe pitch went low\n",
      "dist: 135.77795436205548:\n",
      "\tthe pitch went low\n",
      "\tthe pitch was low\n",
      "dist: 135.8206014172311:\n",
      "\tthe hitter swung at the pitch and missed the\n",
      "\tthe hitter swung at the ball and missed\n",
      "dist: 135.85340872484:\n",
      "\tthe batter hit the ball on the ground past a diving shortstop and into the outfield for a hit\n",
      "\tthe batter hit the ball on the ground through the infield and into the outfield for a base hit\n",
      "dist: 135.85340872484:\n",
      "\tthe batter hit the ball on the ground through the infield and into the outfield for a base hit\n",
      "\tthe batter hit the ball on the ground past a diving shortstop and into the outfield for a hit\n",
      "dist: 136.10683808570235:\n",
      "\tthe batter swung at the pitch but did not hit it\n",
      "\tthe batter swung at the pitch but did not make contact with the ball\n",
      "dist: 136.45279813907038:\n",
      "\tthe batter hit the ball to high left field\n",
      "\tthe batter hit the ball to left field\n",
      "dist: 136.6511683714991:\n",
      "\tthe right fielder caught it\n",
      "\tthe right fielder caught the ball\n",
      "dist: 136.7666053755043:\n",
      "\the hit it\n",
      "\the hit a\n",
      "dist: 136.7666053755043:\n",
      "\the hit a\n",
      "\the hit it\n",
      "dist: 136.7794248960991:\n",
      "\tit was the 3rd strike\n",
      "\tit was the third strike\n",
      "dist: 136.7794248960991:\n",
      "\tit was the third strike\n",
      "\tit was the 3rd strike\n",
      "dist: 136.8841258904859:\n",
      "\tit crossed the plate outside the strike zone\n",
      "\tit crossed the plate outside of the strike zone for a ball\n",
      "dist: 137.0678773535663:\n",
      "\tthe ball went into foul territory\n",
      "\tthe ball was in foul territory\n",
      "dist: 137.07036793243392:\n",
      "\tthe batter swung at the ball without making contact\n",
      "\tthe batter swung and did not make contact with the ball\n",
      "dist: 137.23594174885042:\n",
      "\tthe batter hit the ball on the ground before reaching the shortstop\n",
      "\tthe batter hit the ball on the ground to the shortstop\n",
      "dist: 137.436562926351:\n",
      "\tthe batter hit a fly ball into the outfield\n",
      "\tthe batter hit the ball in the air to the outfield\n",
      "dist: 137.499939379816:\n",
      "\tit was in the strike zone\n",
      "\tit went in the strike zone\n",
      "dist: 138.02501573966114:\n",
      "\tthe batter hit the ball into the stands which is a foul ball\n",
      "\tthen the batter hit a foul ball into the stands\n",
      "dist: 138.02501573966114:\n",
      "\tthen the batter hit a foul ball into the stands\n",
      "\tthe batter hit the ball into the stands which is a foul ball\n",
      "dist: 138.04768651712135:\n",
      "\tthe striker hit the ball in fair play\n",
      "\tthe striker hit the ball within the fair play\n",
      "dist: 138.04768651712135:\n",
      "\tthe striker hit the ball within the fair play\n",
      "\tthe striker hit the ball in fair play\n",
      "dist: 138.0729072633938:\n",
      "\tit to be in the strike zone\n",
      "\tit was in the strike zone\n",
      "dist: 138.4377711273401:\n",
      "\tthe batter hit the ball to the right fielder\n",
      "\tbatter hit ball to right field\n",
      "dist: 138.54582443488385:\n",
      "\tthe batter made contact with the pitch and grounded it to third base\n",
      "\tbatter hit a ground ball to third base and was thrown\n",
      "dist: 138.5479131992534:\n",
      "\tthe right fielder makes the catch\n",
      "\tthe right fielder caught\n",
      "dist: 138.85031414643092:\n",
      "\tthis ball was hit into the outfield\n",
      "\tthen he hit the ball into the outfield\n",
      "dist: 138.98522264622358:\n",
      "\tthe batter didn't go for the hit\n",
      "\tthe batter did not hit it\n",
      "dist: 138.98522264622358:\n",
      "\tthe batter did not hit it\n",
      "\tthe batter didn't go for the hit\n",
      "dist: 139.11582661163666:\n",
      "\tthe ball went into the strike zone\n",
      "\tthe ball went through the strike zone\n",
      "dist: 139.11582661163666:\n",
      "\tthe ball went through the strike zone\n",
      "\tthe ball went into the strike zone\n",
      "dist: 139.8737016490061:\n",
      "\tthe outfielder caught the ball\n",
      "\tthen the outfielder caught it\n",
      "dist: 139.92456927460358:\n",
      "\tthe batter fouled a pitched behind home plate\n",
      "\tthe batter fouled the pitch back behind home plate\n",
      "dist: 140.0599187895036:\n",
      "\tthe batter did not swing or make contact\n",
      "\tbatter did not swing\n",
      "dist: 140.1112984249074:\n",
      "\tthe center fielder caught it\n",
      "\tthe centerfielder caught it\n",
      "dist: 140.42401778490856:\n",
      "\tit went low\n",
      "\tit was low\n",
      "dist: 140.52636883262593:\n",
      "\tthe pitch crossed the plate over the top of the strike zone\n",
      "\tthe pitch crossed the plate in the strike zone\n",
      "dist: 140.52636883262593:\n",
      "\tthe pitch crossed the plate in the strike zone\n",
      "\tthe pitch crossed the plate over the top of the strike zone\n",
      "dist: 140.62201985740475:\n",
      "\tit was a hit home run\n",
      "\tit was a home run\n",
      "dist: 141.00344323103607:\n",
      "\tthe batter missed\n",
      "\tthe batter missed it\n",
      "dist: 141.00344323103607:\n",
      "\tthe batter missed it\n",
      "\tthe batter missed\n",
      "dist: 141.0473096243728:\n",
      "\tthe batter hit the ball foul\n",
      "\tthe batter hit a foul\n",
      "dist: 141.17523548726354:\n",
      "\tthe ball landed within the strike zone\n",
      "\tthe ball landed in the strike zone\n",
      "dist: 141.25906534220763:\n",
      "\tthe center baseman caught the ball for an out\n",
      "\tthe center fielder caught the ball for an out\n",
      "dist: 141.39321189671833:\n",
      "\tthe batter swung and missed for strike two\n",
      "\tthe batter swung and missed for a strike\n",
      "dist: 141.5656564188967:\n",
      "\tthe batter made contact and smashed the ball through the left side of the infield for a\n",
      "\tthe batter drove the ball through the infield on the left side for a single\n",
      "dist: 141.5656564188967:\n",
      "\tthe batter drove the ball through the infield on the left side for a single\n",
      "\tthe batter made contact and smashed the ball through the left side of the infield for a\n",
      "dist: 141.87058516366147:\n",
      "\tthe batter hit the ball to one of the\n",
      "\tthe batter hits the ball\n",
      "dist: 142.00910353807473:\n",
      "\tit was caught by the right fielder\n",
      "\tit was caught by the right outfielder\n",
      "dist: 142.10921604728998:\n",
      "\tthe player caught it in the\n",
      "\tthe player caught it\n",
      "dist: 142.10921604728998:\n",
      "\tthe player caught it\n",
      "\tthe player caught it in the\n",
      "dist: 142.18765114604108:\n",
      "\tthe batter hit a ground ball to third\n",
      "\tthe batter hit a ground ball to the third baseman\n",
      "dist: 142.53576141230502:\n",
      "\tthe batter put the ball into play\n",
      "\tthe batter hit and put the ball into play\n",
      "dist: 142.95350548346966:\n",
      "\tthen the batter swung and hit a fly ball into center field which was caught by the center fielder\n",
      "\tthe batter hit the ball in the air and was caught by the center fielder\n",
      "dist: 142.95350548346966:\n",
      "\tthe batter hit the ball in the air and was caught by the center fielder\n",
      "\tthen the batter swung and hit a fly ball into center field which was caught by the center fielder\n",
      "dist: 143.02732208411186:\n",
      "\tit was a strike\n",
      "\tit to be a strike\n",
      "dist: 143.02732208411186:\n",
      "\tit to be a strike\n",
      "\tit was a strike\n",
      "dist: 143.06366237299446:\n",
      "\tthe batter went for the swing and hit the ball\n",
      "\tthe batter swung and hit the ball on the\n",
      "dist: 143.10167668705895:\n",
      "\twho threw it to the 2nd baseman for the force out\n",
      "\twho threw the ball to second base for a force out\n",
      "dist: 143.10167668705895:\n",
      "\twho threw the ball to second base for a force out\n",
      "\twho threw it to the 2nd baseman for the force out\n",
      "dist: 143.1760514644404:\n",
      "\tthe batter hit the ball towards first base\n",
      "\tthe batter popped up the ball to the first baseman\n",
      "dist: 143.39967114236575:\n",
      "\tthe batter grounded the ball to the shortstop\n",
      "\tthe batter hit a ground ball to the shortstop\n",
      "dist: 143.4532195778495:\n",
      "\tthe batter hit the ball on the ground to the second\n",
      "\tthe batter hit the ball on the ground to the second baseman\n",
      "dist: 143.5375737286077:\n",
      "\tit was caught by the second baseman\n",
      "\tthe second baseman caught it\n",
      "dist: 143.5375737286077:\n",
      "\tthe second baseman caught it\n",
      "\tit was caught by the second baseman\n",
      "dist: 143.61427632356668:\n",
      "\tthe ball proceeding over the plate inside the strike zone\n",
      "\tthe ball crossed over the plate in the strike zone\n",
      "dist: 144.2819382349108:\n",
      "\tthe pitch being deemed a ball\n",
      "\tthe pitch was then deemed to be a ball\n",
      "dist: 144.2819382349108:\n",
      "\tthe pitch was then deemed to be a ball\n",
      "\tthe pitch being deemed a ball\n",
      "dist: 144.3234272510625:\n",
      "\tbatter did not swing at ball outside of the strike\n",
      "\tthe batter did not swing at a pitch outside the strike zone\n",
      "dist: 144.3234272510625:\n",
      "\tthe batter did not swing at a pitch outside the strike zone\n",
      "\tbatter did not swing at ball outside of the strike\n",
      "dist: 144.44271005767027:\n",
      "\tthird baseman caught the ball\n",
      "\tthe third baseman caught it\n",
      "dist: 144.44271005767027:\n",
      "\tthe third baseman caught it\n",
      "\tthird baseman caught the ball\n",
      "dist: 144.4495202630779:\n",
      "\tthe batter swung but didn't hit the ball\n",
      "\tthe batter swung at the pitch but did not hit it\n",
      "dist: 144.47597844184116:\n",
      "\tthe batter grounded out to the second baseman\n",
      "\tthe batter hit a ground ball to second baseman\n",
      "dist: 144.56127771368216:\n",
      "\tit crossed over the plate in the strike zone\n",
      "\tthe ball crossed over the plate in the strike zone\n",
      "dist: 144.62785963529228:\n",
      "\tthe batter hit a grounder to the 3rd baseman\n",
      "\tthe batter hit a ground ball to the 3rd baseman\n",
      "dist: 144.85628656337127:\n",
      "\tthe ball was over the plate and called a strike by the umpire\n",
      "\tthe ball crossed the plate inside the strike zone and was called a strike by the umpire\n",
      "dist: 144.8772448633236:\n",
      "\tit crossed home plate just high and outside of the strike zone\n",
      "\tthe ball crossed the home plate area outside of the strike zone high\n",
      "dist: 145.06798258588157:\n",
      "\tthen the batter hit a ground ball which resulted in an out\n",
      "\tthe batter hit a ground ball and was thrown out\n",
      "dist: 145.12102043548572:\n",
      "\tthe batter hit it via flyout to center field\n",
      "\tthe batter hit a high fly ball out towards center field\n",
      "dist: 145.12102043548572:\n",
      "\tthe batter hit a high fly ball out towards center field\n",
      "\tthe batter hit it via flyout to center field\n",
      "dist: 145.16870949715582:\n",
      "\tthe left fielder caught the ball on the fly\n",
      "\tthe left fielder caught the ball in the air for an out\n",
      "dist: 145.16870949715582:\n",
      "\tthe left fielder caught the ball in the air for an out\n",
      "\tthe left fielder caught the ball on the fly\n",
      "dist: 145.44971158662435:\n",
      "\tit ended up being a ball\n",
      "\tit would be a ball\n",
      "dist: 145.4718850265263:\n",
      "\tit was low hit the dirt and bounced off the catcher\n",
      "\tit hit the dirt and bounced away from the catcher\n",
      "dist: 145.4718850265263:\n",
      "\tit hit the dirt and bounced away from the catcher\n",
      "\tit was low hit the dirt and bounced off the catcher\n",
      "dist: 145.53368428501355:\n",
      "\tthe batter being out\n",
      "\tthe batter is out\n",
      "dist: 145.94608325557698:\n",
      "\tthe pitch was a ball\n",
      "\tthe pitch being deemed a ball\n",
      "dist: 145.98528984526237:\n",
      "\ta field could catch it\n",
      "\tthe fielder could catch it\n",
      "dist: 145.98528984526237:\n",
      "\tthe fielder could catch it\n",
      "\ta field could catch it\n",
      "dist: 146.06728052671428:\n",
      "\tit was caught by the center fielder\n",
      "\tthe center fielder caught it\n",
      "dist: 146.23320020602756:\n",
      "\tthe third baseman caught the ball and threw it to the first baseman\n",
      "\tthe third baseman caught the ball and threw it to the second baseman for a force out\n",
      "dist: 146.23320020602756:\n",
      "\tthe third baseman caught the ball and threw it to the second baseman for a force out\n",
      "\tthe third baseman caught the ball and threw it to the first baseman\n",
      "dist: 146.29827451459192:\n",
      "\tit hit the dirt and got away from the catcher\n",
      "\tit hit the dirt and bounced away from the catcher\n",
      "dist: 146.31834203748244:\n",
      "\tthe third baseman was able to catch it\n",
      "\tthe third baseman caught it\n",
      "dist: 146.5899297078715:\n",
      "\tthe batter fouled it off of their\n",
      "\tthe batter fouled off the\n",
      "dist: 146.5899297078715:\n",
      "\tthe batter fouled off the\n",
      "\tthe batter fouled it off of their\n",
      "dist: 146.64584493690163:\n",
      "\tball did not cross through strike zone\n",
      "\tthe ball did not go through the strike zone\n",
      "dist: 146.72550379975206:\n",
      "\tthe ball was caught by the right fielder in the air for an out\n",
      "\tit was caught by right fielder for an out\n",
      "dist: 146.72550379975206:\n",
      "\tit was caught by right fielder for an out\n",
      "\tthe ball was caught by the right fielder in the air for an out\n",
      "dist: 147.1575463807231:\n",
      "\tthe batter hit the ball to the third baseman who then through the hitter out at first\n",
      "\tthen the batter swung and hit the ball on the ground to the third baseman\n",
      "dist: 147.29170734081623:\n",
      "\tbut it did not go into the field of play\n",
      "\tit did not go in the field of play\n",
      "dist: 147.34126893952427:\n",
      "\tthe batter's swing\n",
      "\tthe batter taking a swing\n",
      "dist: 147.34126893952427:\n",
      "\tthe batter taking a swing\n",
      "\tthe batter's swing\n",
      "dist: 147.361115712075:\n",
      "\tand the batter hit the ball on the ground to the third\n",
      "\tthe ball is hit on the ground to the third baseman\n",
      "dist: 147.44384142722907:\n",
      "\tthe batter reached first base safely\n",
      "\tthe batter made it safely to first base\n",
      "dist: 147.44384142722907:\n",
      "\tthe batter made it safely to first base\n",
      "\tthe batter reached first base safely\n",
      "dist: 147.45519170451993:\n",
      "\tthe batter swung right over the pitch and missed it\n",
      "\tthe batter swung at the pitch and missed\n",
      "dist: 147.73684928400803:\n",
      "\tthe outfielder caught the ball in the air\n",
      "\tthe outfielder caught the ball\n",
      "dist: 147.82547034401725:\n",
      "\tthe batter to be out\n",
      "\tthe batter being out\n",
      "dist: 148.22586882692036:\n",
      "\tthe batter hit the ball which landed on the ground in the field of play\n",
      "\tthe batter hit the ball on the ground in play\n",
      "dist: 148.7873448959936:\n",
      "\tthe second baseman threw to first to forceout the batter\n",
      "\tthe second baseman fielded a ground ball and threw out the batter at first\n",
      "dist: 148.8150254828061:\n",
      "\tthe batter hit it to mid center field for a hit\n",
      "\tthe batter swung the bat and hit the ball into center field\n",
      "dist: 148.97690349149258:\n",
      "\tthe batter got a base hit to left field\n",
      "\tthe batter hit the ball into the left field for a hit\n",
      "dist: 148.98335463240716:\n",
      "\tthen it was caught in mid air by the outfielder\n",
      "\tit was hit into the air and caught by an outfielder\n",
      "dist: 148.98335463240716:\n",
      "\tit was hit into the air and caught by an outfielder\n",
      "\tthen it was caught in mid air by the outfielder\n",
      "dist: 149.0132081458065:\n",
      "\tit would be a foul\n",
      "\tit is a foul\n",
      "dist: 149.0508915741038:\n",
      "\tthe hitter took a swing at the ball\n",
      "\tthe hitter hit the ball\n",
      "dist: 149.0508915741038:\n",
      "\tthe hitter hit the ball\n",
      "\tthe hitter took a swing at the ball\n",
      "dist: 149.20389492211604:\n",
      "\tthe batter hit the ball foul and into the ground\n",
      "\tthe batter hit the ball into the ground in foul territory\n",
      "dist: 149.38937958505545:\n",
      "\tthe batter hit a fly ball to left that was caught\n",
      "\tbatter hit a fly ball to left field which was caught by the left\n",
      "dist: 149.417780795483:\n",
      "\tthe ball was hit on the ground out to left field\n",
      "\tthe ball traveled into left field on the ground\n",
      "dist: 149.417780795483:\n",
      "\tthe ball traveled into left field on the ground\n",
      "\tthe ball was hit on the ground out to left field\n",
      "dist: 149.70159544151016:\n",
      "\tthe batter made contact with the pitch and fouled it off\n",
      "\tthe batter fouled the pitch off\n",
      "dist: 149.7139185257393:\n",
      "\tthe batter hit a single to center field\n",
      "\tthe batter singled to center field\n",
      "dist: 149.7139185257393:\n",
      "\tthe batter singled to center field\n",
      "\tthe batter hit a single to center field\n",
      "dist: 150.2895600014736:\n",
      "\tthe ball did not land in the field of play\n",
      "\tthe ball did not end up in the field of play\n",
      "dist: 150.2895600014736:\n",
      "\tthe ball did not end up in the field of play\n",
      "\tthe ball did not land in the field of play\n",
      "dist: 150.40766329879477:\n",
      "\tit being caught\n",
      "\tit was caught\n",
      "dist: 150.40766329879477:\n",
      "\tit was caught\n",
      "\tit being caught\n",
      "dist: 150.4950610177612:\n",
      "\tit landed outside the strike zone\n",
      "\tit landed outside of the strike zone\n",
      "dist: 150.4950610177612:\n",
      "\tit landed outside of the strike zone\n",
      "\tit landed outside the strike zone\n",
      "dist: 150.8780407724326:\n",
      "\tthe second baseman caught the ball and threw it to the first baseman for the out\n",
      "\t2nd baseman threw to first baseman and got the hitter out\n",
      "dist: 150.8780407724326:\n",
      "\t2nd baseman threw to first baseman and got the hitter out\n",
      "\tthe second baseman caught the ball and threw it to the first baseman for the out\n",
      "dist: 151.00178534547857:\n",
      "\tthe fielder caught the ball\n",
      "\tthe outfielder caught the ball\n",
      "dist: 151.1774817042015:\n",
      "\tthe pitcher threw it in the strike zone\n",
      "\tpitcher threw strike\n",
      "dist: 151.33067692161882:\n",
      "\twhat appeared to be a double\n",
      "\twhat looks like a double\n",
      "dist: 151.33067692161882:\n",
      "\twhat looks like a double\n",
      "\twhat appeared to be a double\n",
      "dist: 151.51864094096442:\n",
      "\tthe 2nd baseman caught it on the\n",
      "\tthe second baseman caught it\n",
      "dist: 151.79862976197825:\n",
      "\tthe batter to reach first base\n",
      "\tthe batter to reach base\n",
      "dist: 151.79862976197825:\n",
      "\tthe batter to reach base\n",
      "\tthe batter to reach first base\n",
      "dist: 151.93517554948113:\n",
      "\tthe hitter hit it\n",
      "\tthe hitter hit the ball\n",
      "dist: 151.96772351844908:\n",
      "\tthe batter swung and connected with the ball which was collected by the infielder and thrown to first base\n",
      "\tthe batter swung and connected with the ball which was caught by the first baseman\n",
      "dist: 151.96772351844908:\n",
      "\tthe batter swung and connected with the ball which was caught by the first baseman\n",
      "\tthe batter swung and connected with the ball which was collected by the infielder and thrown to first base\n",
      "dist: 151.9828085274327:\n",
      "\tthe batter swung anyway and missed making it a strike\n",
      "\tthe batter swung and missed for a strike\n",
      "dist: 152.12705035773894:\n",
      "\tthe batter swung at the pitch and hit the ball on the ground into foul territory\n",
      "\tthe batter made contact with the pitch and hit it into foul territory\n",
      "dist: 152.1950349014235:\n",
      "\tit was caught by the centerfielder\n",
      "\tit was caught by the center fielder\n",
      "dist: 152.26585403301493:\n",
      "\tthe catcher caught the ball outside of the strikezone\n",
      "\tthe catcher caught it outside of the strike zone\n",
      "dist: 152.26585403301493:\n",
      "\tthe catcher caught it outside of the strike zone\n",
      "\tthe catcher caught the ball outside of the strikezone\n",
      "dist: 152.38538072890626:\n",
      "\tit will be a strike\n",
      "\tit to be a strike\n",
      "dist: 152.4104437631459:\n",
      "\tthe left fielder catches the ball in the air\n",
      "\tthe left fielder caught the ball in the air for an out\n",
      "dist: 152.49394866889548:\n",
      "\tthen the batter hit the ball into play and safely reached base\n",
      "\tthe batter was able to run to the base safely for a hit\n",
      "dist: 152.49394866889548:\n",
      "\tthe batter was able to run to the base safely for a hit\n",
      "\tthen the batter hit the ball into play and safely reached base\n",
      "dist: 152.55259710842716:\n",
      "\tit was a hit into left center field\n",
      "\thit the ball to left center field\n",
      "dist: 153.0888961733123:\n",
      "\tthe ball went right into the strike zone\n",
      "\tthe ball went into the strike zone\n",
      "dist: 153.24653916055033:\n",
      "\tbatter popped out to third baseman\n",
      "\tthe batter hit the ball to the third baseman who then through the hitter out at first\n",
      "dist: 153.5657868040946:\n",
      "\tthe pitch was called a ball by the umpire\n",
      "\tpitch was called a strike by umpire\n",
      "dist: 153.67406353144835:\n",
      "\tthe batter reached first base\n",
      "\tthe batter to reach first base\n",
      "dist: 153.76075168659665:\n",
      "\tthe outfielder wasn't able to catch the ball\n",
      "\tthe outfielder didn't catch it\n",
      "dist: 153.76075168659665:\n",
      "\tthe outfielder didn't catch it\n",
      "\tthe outfielder wasn't able to catch the ball\n",
      "dist: 153.9161319155092:\n",
      "\tthen the hitter hit a ground ball to third base\n",
      "\tand the batter hit the ball on the ground to the third\n",
      "dist: 154.09090748721707:\n",
      "\tthe batter hit it to second baseman\n",
      "\tthe batter hit a grounder to the second baseman\n",
      "dist: 154.09090748721707:\n",
      "\tthe batter hit a grounder to the second baseman\n",
      "\tthe batter hit it to second baseman\n",
      "dist: 154.12013849731193:\n",
      "\tit was way outside of the strike zone\n",
      "\tit was outside of the strike zone\n",
      "dist: 154.1351564984207:\n",
      "\tthen the ball landed behind home plate  outside of the foul line\n",
      "\tthe ball went behind home plate in foul territory\n",
      "dist: 154.1351564984207:\n",
      "\tthe ball went behind home plate in foul territory\n",
      "\tthen the ball landed behind home plate  outside of the foul line\n",
      "dist: 154.16736351996866:\n",
      "\tthe ball crossed the strike zone thus a strike\n",
      "\tthe ball crossed into the strike zone\n",
      "dist: 154.680849880052:\n",
      "\tthe batter hit the ball into the outfield and got on base\n",
      "\tthe batter hit the ball into the outfield\n",
      "dist: 154.68536050159224:\n",
      "\tthe batter fouled the pitch off to behind home plate resulting in a foul ball\n",
      "\tthe batter fouled a pitched behind home plate\n",
      "dist: 155.4096899985007:\n",
      "\tthe batter hit the ball over the shortstop and into center field\n",
      "\tbatter hit the ball past the shortstop for a\n",
      "dist: 155.55775053375606:\n",
      "\tthe left fielder caught the ball\n",
      "\tthe left fielder catches the ball in the air\n",
      "dist: 155.86501330581:\n",
      "\tthe hitter got a hit\n",
      "\tthe hitter hit it\n",
      "dist: 156.01612599266738:\n",
      "\tthe ball was hit to the right fielder\n",
      "\tthe batter hit the ball to the right fielder\n",
      "dist: 156.0203917352039:\n",
      "\twho was unable to catch the ball\n",
      "\tthe player couldn't catch the ball\n",
      "dist: 156.0203917352039:\n",
      "\tthe player couldn't catch the ball\n",
      "\twho was unable to catch the ball\n",
      "dist: 156.209034602757:\n",
      "\tthe batter made contact with the pitch and hit it on the ground to the shortstop\n",
      "\tthe batter hit the ball on the ground to the shortstop\n",
      "dist: 156.22949019465986:\n",
      "\tit crossed the plate below the strike zone and was called a ball by the umpire\n",
      "\tthe ball crossed the plate within the strike zone and was called a strike by the umpire\n",
      "dist: 156.45079696092495:\n",
      "\tthe batter hit a grounder to the shortstop\n",
      "\tthe batter hit a grounder to the second baseman\n",
      "dist: 156.86964695239553:\n",
      "\tit was ruled a foul ball\n",
      "\tit was a foul ball\n",
      "dist: 157.0461695602708:\n",
      "\the did offer at the pitch making it a strike\n",
      "\the offered at the pitch making it a strike\n",
      "dist: 157.0461695602708:\n",
      "\the offered at the pitch making it a strike\n",
      "\the did offer at the pitch making it a strike\n",
      "dist: 157.08863949410357:\n",
      "\tthe batter hit the ball into the air backwards\n",
      "\tthe batter hit it in the air backwards\n",
      "dist: 157.08863949410357:\n",
      "\tthe batter hit it in the air backwards\n",
      "\tthe batter hit the ball into the air backwards\n",
      "dist: 157.2578451453901:\n",
      "\tthe ump called it a strike\n",
      "\tthe umpire called it a strike\n",
      "dist: 157.31819960773197:\n",
      "\tthe batter swung at the pitch and hit the ball into the outfield in fair territory\n",
      "\tthe batter hit the ball into the outfield\n",
      "dist: 157.49080419838634:\n",
      "\tthe ball was hit fielded\n",
      "\tball hit and fielded in play\n",
      "dist: 157.49080419838634:\n",
      "\tball hit and fielded in play\n",
      "\tthe ball was hit fielded\n",
      "dist: 157.4988844728662:\n",
      "\tthe outfielder caught the\n",
      "\tthe outfielder caught the ball\n",
      "dist: 157.63347428076597:\n",
      "\tthe batter hit the ball in the air in foul territory to the left of third base\n",
      "\tthe batter hit the ball in the air to the left of third base and into the stands\n",
      "dist: 157.77553458332756:\n",
      "\tthe ball went outside the foul line\n",
      "\tthe ball went past the foul line\n",
      "dist: 157.77553458332756:\n",
      "\tthe ball went past the foul line\n",
      "\tthe ball went outside the foul line\n",
      "dist: 157.7879449143157:\n",
      "\tthe hitter swung and fouled the ball straight back\n",
      "\tthe hitter swung and fouled off the ball\n",
      "dist: 157.94946071035434:\n",
      "\tthe batter was walked\n",
      "\tthe batter got a walk\n",
      "dist: 157.94946071035434:\n",
      "\tthe batter got a walk\n",
      "\tthe batter was walked\n",
      "dist: 158.030021448999:\n",
      "\tthen the batter hit the ball fair and over the outfield wall\n",
      "\tthe batter hit the ball in the air to the outfield\n",
      "dist: 158.15174842389246:\n",
      "\tthe batter's knees\n",
      "\tthe batter's knees and chest\n",
      "dist: 158.15174842389246:\n",
      "\tthe batter's knees and chest\n",
      "\tthe batter's knees\n",
      "dist: 158.2057340145395:\n",
      "\tthe pitcher threw a ball inside the strike zone\n",
      "\tthe pitcher threw the ball outside the strike zone\n",
      "dist: 158.21016890404744:\n",
      "\tthe ball was low\n",
      "\tthe ball went low\n",
      "dist: 158.21016890404744:\n",
      "\tthe ball went low\n",
      "\tthe ball was low\n",
      "dist: 158.22279388458907:\n",
      "\tit was not caught for a hit\n",
      "\tit was hit but not caught for an\n",
      "dist: 158.22279388458907:\n",
      "\tit was hit but not caught for an\n",
      "\tit was not caught for a hit\n",
      "dist: 158.37008261026025:\n",
      "\tcenter fielder caught the ball\n",
      "\tthe center fielder caught it\n",
      "dist: 158.60536261662386:\n",
      "\tmade contact hitting the ball back to the pitcher\n",
      "\tthe batter hit the ball back to the pitcher\n",
      "dist: 158.91879060393657:\n",
      "\tbut it went into foul\n",
      "\tit went foul\n",
      "dist: 158.91879060393657:\n",
      "\tit went foul\n",
      "\tbut it went into foul\n",
      "dist: 159.17050793331788:\n",
      "\tthe ball went inside\n",
      "\tthe ball was inside\n",
      "dist: 159.17050793331788:\n",
      "\tthe ball was inside\n",
      "\tthe ball went inside\n",
      "dist: 159.24011082157014:\n",
      "\tthe batter hit the ball high\n",
      "\tthe batter hit it up high\n",
      "dist: 159.24011082157014:\n",
      "\tthe batter hit it up high\n",
      "\tthe batter hit the ball high\n",
      "dist: 159.30111854786725:\n",
      "\tand the batter swung at the ball and missed for a strike\n",
      "\tbatter swung at pitch and missed ball which is a strike\n",
      "dist: 159.456305443971:\n",
      "\tthe pitch went through the strike zone\n",
      "\tthe pitch was went into the strike zone\n",
      "dist: 159.456305443971:\n",
      "\tthe pitch was went into the strike zone\n",
      "\tthe pitch went through the strike zone\n",
      "dist: 159.52642458227754:\n",
      "\tit was hit on the ground to the second baseman\n",
      "\tthe batter hit the ball on the ground to the second baseman\n",
      "dist: 159.5430878386247:\n",
      "\tthe ball was over the plate\n",
      "\tthe ball went right over the plate\n",
      "dist: 159.5430878386247:\n",
      "\tthe ball went right over the plate\n",
      "\tthe ball was over the plate\n",
      "dist: 159.83480637388772:\n",
      "\tthe second baseman threw him out at first\n",
      "\tthe second baseman threw him out in time\n",
      "dist: 159.83480637388772:\n",
      "\tthe second baseman threw him out in time\n",
      "\tthe second baseman threw him out at first\n",
      "dist: 160.07698532289857:\n",
      "\tand the ball was fouled off to the right side\n",
      "\tthen the ball was fouled off to the right side\n",
      "dist: 160.07698532289857:\n",
      "\tthen the ball was fouled off to the right side\n",
      "\tand the ball was fouled off to the right side\n",
      "dist: 160.1586159188583:\n",
      "\tthe pitch was not delivered within the strike zone\n",
      "\tthe pitch isn't in the strike zone\n",
      "dist: 160.2440673473055:\n",
      "\tit entered the strike zone\n",
      "\tit went into the strike zone\n",
      "dist: 160.3461500688293:\n",
      "\tthe ball dipped below the strike zone\n",
      "\tthe ball was below the strike zone\n",
      "dist: 160.3461500688293:\n",
      "\tthe ball was below the strike zone\n",
      "\tthe ball dipped below the strike zone\n",
      "dist: 160.34809189632966:\n",
      "\tit went over the plate in strike zone\n",
      "\tthe ball crossed over the plate in the strike zone\n",
      "dist: 160.45950413514134:\n",
      "\tand the umpire called it a strike\n",
      "\tit was a called strike by the umpire\n",
      "dist: 160.76537042616025:\n",
      "\tthen the ball wound up outside the strike zone\n",
      "\tthe ball went to outside of the strike zone\n",
      "dist: 161.37333415153176:\n",
      "\tthe batter hit it up the middle\n",
      "\tthe batter hit it back up the middle\n",
      "dist: 161.37333415153176:\n",
      "\tthe batter hit it back up the middle\n",
      "\tthe batter hit it up the middle\n",
      "dist: 161.469214861979:\n",
      "\tthe batter hit a ground ball to the left fielder\n",
      "\tthe batter hit the ball to the left fielder\n",
      "dist: 161.58102634800804:\n",
      "\tthe batter hits the ball foul towards the\n",
      "\tthe batter hit the ball foul\n",
      "dist: 161.68352588145268:\n",
      "\tand the hitter hit the ball into right field which was caught by the right fielder\n",
      "\tthe ball was caught by the right fielder in the air for an out\n",
      "dist: 161.73406450929278:\n",
      "\ta fielder caught it\n",
      "\tthe fielder caught the ball\n",
      "dist: 161.78916531476816:\n",
      "\ttherefore it is a strike\n",
      "\tit will be a strike\n",
      "dist: 161.7892127312944:\n",
      "\tthe batter swung and fouled off the pitch\n",
      "\tthe batter fouled the pitch off\n",
      "dist: 161.95475004420754:\n",
      "\tthe batter swung at a pitch outside the strike\n",
      "\tthe batter swung at the pitch\n",
      "dist: 162.09791560911896:\n",
      "\tthe batter hit the ball over the outfield wall for a home run\n",
      "\tthen the batter hit the ball fair and over the outfield wall\n",
      "dist: 162.15377526536858:\n",
      "\tthe batter's bat\n",
      "\tthe batter swung the bat\n",
      "dist: 162.43575977093047:\n",
      "\ta fly ball to outfield caught by the center fielder\n",
      "\tit was caught on the fly by the center fielder\n",
      "dist: 162.43575977093047:\n",
      "\tit was caught on the fly by the center fielder\n",
      "\ta fly ball to outfield caught by the center fielder\n",
      "dist: 162.6847409850445:\n",
      "\tthe batter made it to first base\n",
      "\tthe batter reached first base\n",
      "dist: 162.70439628397693:\n",
      "\tthe ball was in the field of play\n",
      "\tthe ball was hit into the field of play\n",
      "dist: 162.70439628397693:\n",
      "\tthe ball was hit into the field of play\n",
      "\tthe ball was in the field of play\n",
      "dist: 162.82057601576057:\n",
      "\tthe pitch did not land in the strike zone\n",
      "\tthe pitch was not in the strike zone\n",
      "dist: 162.89299024474082:\n",
      "\tthe hitter hit a ground ball between shortstop and third\n",
      "\tthen the hitter hit a ground ball to third base\n",
      "dist: 163.23066625967007:\n",
      "\tthe batter hits the ball behind the foul line\n",
      "\tthe batter hit the ball which landed behind the foul\n",
      "dist: 163.37719415158705:\n",
      "\tthe batter hit it foul behind the plate\n",
      "\tthe batter hit a foul ball directly behind home plate\n",
      "dist: 163.37719415158705:\n",
      "\tthe batter hit a foul ball directly behind home plate\n",
      "\tthe batter hit it foul behind the plate\n",
      "dist: 163.4743015367995:\n",
      "\tthe hitter hit the ball on the ground to the 3rd baseman who then threw the batter out at first base\n",
      "\tthe ball is hit on the ground to the third baseman\n",
      "dist: 163.92349426652:\n",
      "\tthe hitter hit the ball to right center field\n",
      "\tthe hitter hit the ball in the air to right field\n",
      "dist: 164.08078946947282:\n",
      "\tthe batter swung at the pitch made contact with the ball and hit it into foul territory on the third base side of the field\n",
      "\tthe batter hit the ball in the air in foul territory to the left of third base\n",
      "dist: 164.24598719868195:\n",
      "\tthe ball could hit the ground\n",
      "\tit could hit the ground\n",
      "dist: 164.24598719868195:\n",
      "\tit could hit the ground\n",
      "\tthe ball could hit the ground\n",
      "dist: 164.74952702826255:\n",
      "\tthe batter swung the bat and hit the ball on the ground\n",
      "\tthe batter swung and hit the ball on the ground\n",
      "dist: 164.84963766520292:\n",
      "\tand the batter did swing at a pitch in the strike zone\n",
      "\tthe batter did swing at a pitch inside the strike zone\n",
      "dist: 164.84963766520292:\n",
      "\tthe batter did swing at a pitch inside the strike zone\n",
      "\tand the batter did swing at a pitch in the strike zone\n",
      "dist: 164.86998811393207:\n",
      "\tand batter did not swing at the pitch\n",
      "\tthe ball was not swung at by the batter\n",
      "dist: 164.86998811393207:\n",
      "\tthe ball was not swung at by the batter\n",
      "\tand batter did not swing at the pitch\n",
      "dist: 165.20742457059532:\n",
      "\tthe ball hit the ground\n",
      "\ta ball hit into play on the ground\n",
      "dist: 165.22893478472457:\n",
      "\tthe batter's knees and shoulders\n",
      "\tthe batter's knees and chest\n",
      "dist: 165.27489192098366:\n",
      "\tthe batter hit the ball on the ground to the right of first base\n",
      "\tthe batter hit a ground ball to first baseman\n",
      "dist: 165.32541159953618:\n",
      "\tthe fielder was able to catch the ball\n",
      "\tthe fielder caught the ball\n",
      "dist: 165.4066709701526:\n",
      "\tthe umpire called it a\n",
      "\tthe umpire called\n",
      "dist: 165.4066709701526:\n",
      "\tthe umpire called\n",
      "\tthe umpire called it a\n",
      "dist: 165.4347607187161:\n",
      "\tthe batter hit a ground ball\n",
      "\tthe batter hit the ball on the ground\n",
      "dist: 165.4955522541414:\n",
      "\tthe center fielder ran and caught the ball\n",
      "\tcenter fielder caught the ball\n",
      "dist: 165.57282669389937:\n",
      "\tthe pitcher threw his pitch\n",
      "\tpitcher threw ball\n",
      "dist: 165.9574687925917:\n",
      "\tthe pitcher threw the ball low in the strike zone\n",
      "\tthe pitcher threw it in the strike zone\n",
      "dist: 165.99755119161188:\n",
      "\tthe pitch was caught by the catcher\n",
      "\thit was caught by the catcher\n",
      "dist: 165.99755119161188:\n",
      "\thit was caught by the catcher\n",
      "\tthe pitch was caught by the catcher\n",
      "dist: 166.09626878122728:\n",
      "\tthe batter hit a line drive to leftcenter field\n",
      "\tthe batter hit a line drive to the left\n",
      "dist: 166.09626878122728:\n",
      "\tthe batter hit a line drive to the left\n",
      "\tthe batter hit a line drive to leftcenter field\n",
      "dist: 166.21498209781566:\n",
      "\tit was caught by the catcher\n",
      "\tthe pitch was caught by the catcher\n",
      "dist: 166.25487389723932:\n",
      "\tit was caught by second baseman for an out\n",
      "\tthe second baseman caught the ball and threw it to the first baseman for the out\n",
      "dist: 166.42664972222616:\n",
      "\tthe umpire ruled the pitch a strike for going through the strike zone\n",
      "\tthe umpire ruled the pitch a strike\n",
      "dist: 166.42664972222616:\n",
      "\tthe umpire ruled the pitch a strike\n",
      "\tthe umpire ruled the pitch a strike for going through the strike zone\n",
      "dist: 166.44787457574031:\n",
      "\tit was caught in the air by the center fielder\n",
      "\tit was caught in the air by the center fielder for the out\n",
      "dist: 166.44787457574031:\n",
      "\tit was caught in the air by the center fielder for the out\n",
      "\tit was caught in the air by the center fielder\n",
      "dist: 166.51362359603047:\n",
      "\tit was outside the strikezone\n",
      "\tit was outside the strike zone\n",
      "dist: 166.6422500387395:\n",
      "\tthe batter swung the bat and hit the ball which landed in an area that was outside of the field of play\n",
      "\tthe batter hit the ball outside of the field of play\n",
      "dist: 166.7427501289229:\n",
      "\tit was called a ball by the umpire\n",
      "\tit was called a ball by the umpire as well\n",
      "dist: 166.7427501289229:\n",
      "\tit was called a ball by the umpire as well\n",
      "\tit was called a ball by the umpire\n",
      "dist: 167.01484713698957:\n",
      "\tthe batter hit the pitch\n",
      "\tthe batter took a swing at the pitch\n",
      "dist: 167.0468493368963:\n",
      "\tthe ball crossed the plate in bottom of the strike zone\n",
      "\tthe ball crossed the plate in the strike zone\n",
      "dist: 167.225365747351:\n",
      "\tthe outfielder caught it in the air\n",
      "\tthe outfielder caught the ball in the air\n",
      "dist: 167.23783464736977:\n",
      "\tthe batter hit the ball on the ground to the short stop\n",
      "\tthe batter hit the ball on the ground to the short\n",
      "dist: 167.23783464736977:\n",
      "\tthe batter hit the ball on the ground to the short\n",
      "\tthe batter hit the ball on the ground to the short stop\n",
      "dist: 167.24682740582725:\n",
      "\tthe pitch was not thrown through the strike zone\n",
      "\tthe pitch did not cross the plate inside of the strike zone\n",
      "dist: 167.26666240995024:\n",
      "\tit was a grounder to the third baseman\n",
      "\tthe ball was hit to the third baseman\n",
      "dist: 167.26666240995024:\n",
      "\tthe ball was hit to the third baseman\n",
      "\tit was a grounder to the third baseman\n",
      "dist: 167.4830213185042:\n",
      "\tthe ball went high\n",
      "\tit was a ball high\n",
      "dist: 167.4830213185042:\n",
      "\tit was a ball high\n",
      "\tthe ball went high\n",
      "dist: 167.5855320475667:\n",
      "\tthe ball hit out to center field and was not caught\n",
      "\tthen the ball was hit out to left field and was not caught\n",
      "dist: 167.80885806353692:\n",
      "\tthe batter hit the ball over the outfielders and into the seats\n",
      "\tthe batter hit a fly ball into the outfield\n",
      "dist: 168.0024003247374:\n",
      "\tthe batter made contact with the ball and sent it into the outfield\n",
      "\tthe batter hit the ball into the outfield\n",
      "dist: 168.00256830693894:\n",
      "\tthe batter could reach first base\n",
      "\tthe batter to reach first base\n",
      "dist: 168.1437946986982:\n",
      "\tthe ball crossed the plate below the strike zone\n",
      "\tthe ball crossed the plate in bottom of the strike zone\n",
      "dist: 168.41618089705557:\n",
      "\tthe batter reached base\n",
      "\tthe batter to reach base\n",
      "dist: 168.7297402389224:\n",
      "\tthe ball crossed home plate high in the strike zone\n",
      "\tthe ball crossed the home plate area outside of the strike zone high\n",
      "dist: 168.7634923018732:\n",
      "\tthe batter hit a fly ball to left field\n",
      "\tbatter hit a fly ball to left field which was caught by the left\n",
      "dist: 168.8036512322069:\n",
      "\tthen the batter swung at the pitch and made some contact but failed to put the ball into the field of play\n",
      "\tthe batter swung at the pitch and missed making contact\n",
      "dist: 168.891055184663:\n",
      "\tit was caught by the first baseman\n",
      "\tit was caught by the second baseman\n",
      "dist: 169.04675227352624:\n",
      "\tthe batter hit the ball for a single\n",
      "\tthe batter hit the ball to one of the\n",
      "dist: 169.24502060979927:\n",
      "\the hit a ground ball out to the 2nd baseman\n",
      "\tit was hit on the ground to the second baseman\n",
      "dist: 169.3611397401683:\n",
      "\tthe ball was hit to straight center field and caught by the center fielder\n",
      "\tthe batter hit the ball in the air and was caught by the center fielder\n",
      "dist: 169.3652521885374:\n",
      "\tthe umpire didn't call it a strike\n",
      "\tthe umpire did not signal for a strike\n",
      "dist: 169.3652521885374:\n",
      "\tthe umpire did not signal for a strike\n",
      "\tthe umpire didn't call it a strike\n",
      "dist: 169.91185976209348:\n",
      "\tthe pitcher got the ball and threw it to first base for the out\n",
      "\tthe pitcher fielded it and threw to first base for the out\n",
      "dist: 169.91185976209348:\n",
      "\tthe pitcher fielded it and threw to first base for the out\n",
      "\tthe pitcher got the ball and threw it to first base for the out\n",
      "dist: 169.9644106469182:\n",
      "\tthen the batter hit a line drive to the center fielder\n",
      "\tthe batter hit the ball into center field\n",
      "dist: 170.03415928633973:\n",
      "\tball thrown ouside of strike zone\n",
      "\tthe ball was thrown outside the strike zone\n",
      "dist: 170.54622668572048:\n",
      "\tthe batter attempted to hit the ball\n",
      "\tthe batter hit the ball into play on the\n",
      "dist: 170.79408610025627:\n",
      "\tit was caught by the catcher outside of the strike zone which is marked on the tv broadcast screen\n",
      "\tit was caught by the catcher outside of the strike zone\n",
      "dist: 171.00084077350297:\n",
      "\tthe batter hit the ball into the stands in right foul territory\n",
      "\tthe batter hit the ball into the stands in foul territory\n",
      "dist: 171.039000338059:\n",
      "\tin turn bounced on the ground\n",
      "\tit bounced off the ground\n",
      "dist: 171.039000338059:\n",
      "\tit bounced off the ground\n",
      "\tin turn bounced on the ground\n",
      "dist: 171.22755035954384:\n",
      "\tthen the batter hit the ball fouling it\n",
      "\tthen the batter hit it foul\n",
      "dist: 171.54001456774046:\n",
      "\tthe pitcher threw the ball low over the plate\n",
      "\tthe pitcher threw the ball high to the batter\n",
      "dist: 171.54001456774046:\n",
      "\tthe pitcher threw the ball high to the batter\n",
      "\tthe pitcher threw the ball low over the plate\n",
      "dist: 171.7965325579999:\n",
      "\ta ground ball was hit between the third baseman and shortstop\n",
      "\tthe hitter hit a ground ball between shortstop and third\n",
      "dist: 171.87244778076916:\n",
      "\tthe batter hit the ball on the ground down the third baseline\n",
      "\tthe batter hit a ground ball to third\n",
      "dist: 171.93075072803114:\n",
      "\tthe batter hit an infield pop up caught by the first baseman\n",
      "\tthe batter swung and connected with the ball which was collected by the infielder and thrown to first base\n",
      "dist: 171.9891683369926:\n",
      "\tthe ball was hit over the outfield wall on the fly in fair territory\n",
      "\tthe batter swung at the pitch and hit the ball into the outfield in fair territory\n",
      "dist: 172.03781044816338:\n",
      "\the hit it up the middle\n",
      "\tit was hit up the middle\n",
      "dist: 172.03781044816338:\n",
      "\tit was hit up the middle\n",
      "\the hit it up the middle\n",
      "dist: 172.16196444521398:\n",
      "\ta ground ball hit to third base\n",
      "\tthen the hitter hit a ground ball to third base\n",
      "dist: 172.51783851785953:\n",
      "\tthe ball was far outside the strike zone\n",
      "\tthe ball was outside of the strike zone\n",
      "dist: 172.5241774975721:\n",
      "\tthe batter drove the ball over the fence in right field for a home run\n",
      "\tthe batter drove the ball to deep rightcenter field and over the wall for a home run\n",
      "dist: 172.5241774975721:\n",
      "\tthe batter drove the ball to deep rightcenter field and over the wall for a home run\n",
      "\tthe batter drove the ball over the fence in right field for a home run\n",
      "dist: 172.5293221214152:\n",
      "\tthe hitter did not swing and just took the pitch\n",
      "\tthe batter did not swing and just took the pitch\n",
      "dist: 172.56781030226816:\n",
      "\tthe batter made it on base\n",
      "\tthe batter reached base\n",
      "dist: 172.6830403197519:\n",
      "\tit hit the strike zone\n",
      "\tthe ball hit the strike zone\n",
      "dist: 172.93679169287412:\n",
      "\tthe batter fouled with a pop fly behind the plate\n",
      "\tthe batter hit it foul behind the plate\n",
      "dist: 173.4021894717344:\n",
      "\tit crossed home plate which is a ball\n",
      "\tit reached home plate\n",
      "dist: 173.4021894717344:\n",
      "\tit reached home plate\n",
      "\tit crossed home plate which is a ball\n",
      "dist: 173.6040084864208:\n",
      "\tthe batter hit the air high into the air where the center fielder easily caught in his glove\n",
      "\tthe batter hit the ball in the air and was caught by the center fielder\n",
      "dist: 173.62453810390363:\n",
      "\tthen the hitter made contact with the ball and hit it into the field of play\n",
      "\tthe hitter hit the ball outside the field of play\n",
      "dist: 173.70136439958793:\n",
      "\tthe ball landed on the ground before reaching the third baseman\n",
      "\tthe ball was hit to the third baseman on the ground\n",
      "dist: 173.85306179394073:\n",
      "\tthe leftfielder caught the ball\n",
      "\tthe outfielder caught the ball\n",
      "dist: 173.88828999637153:\n",
      "\tthe pitch was delivered outside the strike zone\n",
      "\tthe pitch was outside the strike zone\n",
      "dist: 174.11303856239743:\n",
      "\tthe batter hit it over the wall in right field\n",
      "\tthe ball was hit over the right field wall\n",
      "dist: 174.11303856239743:\n",
      "\tthe ball was hit over the right field wall\n",
      "\tthe batter hit it over the wall in right field\n",
      "dist: 174.3043428476804:\n",
      "\tthe batter hit the ball inside the field with the\n",
      "\tthe batter hit the ball into the play of field\n",
      "dist: 174.40819016144002:\n",
      "\tthe ball was way past the foul line foul\n",
      "\tthe ball went past the foul line\n",
      "dist: 174.40885954008178:\n",
      "\tthe batter swung his bat at the ball but did not hit it at all\n",
      "\tthe batter swung at the pitch but did not hit it\n",
      "dist: 174.8501976846738:\n",
      "\twho fielded the ball and threw the runner out at first base\n",
      "\twho fielded the ball and threw the runner out at first\n",
      "dist: 174.8501976846738:\n",
      "\twho fielded the ball and threw the runner out at first\n",
      "\twho fielded the ball and threw the runner out at first base\n",
      "dist: 174.91610045656768:\n",
      "\tthe batter hit a ground ball to the pitcher and was then thrown out\n",
      "\tthe batter hit the ball on the ground back to the pitcher\n",
      "dist: 175.06429196784944:\n",
      "\tit was ruled strike three\n",
      "\tthe strike was strike three\n",
      "dist: 175.06429196784944:\n",
      "\tthe strike was strike three\n",
      "\tit was ruled strike three\n",
      "dist: 175.1281571924071:\n",
      "\tthe batter made contact with the ball and sent it into left field\n",
      "\tthe batter hit the ball into left field\n",
      "dist: 175.25937464519436:\n",
      "\tthe ball was not in the location that would be considered the strike zone\n",
      "\tthe ball was not in the strike zone\n",
      "dist: 175.39255569990115:\n",
      "\tthe batter swung at the pitch and knicked the pitch into the ground at home plate for a foul ball\n",
      "\tthe batter swung at the pitch and hit the ball on the ground into foul territory\n",
      "dist: 175.44523248856336:\n",
      "\tit was caught by the first basemen\n",
      "\tit was caught by the first baseman\n",
      "dist: 175.5534265745219:\n",
      "\twho threw the runner out at first\n",
      "\the threw runner out at first\n",
      "dist: 175.57955937713197:\n",
      "\tthe umpire ruled the pitch a ball\n",
      "\tthe umpire ruled the pitch a strike\n",
      "dist: 175.5826687868081:\n",
      "\tthe batter swung without hitting the ball\n",
      "\tthe batter swung at the ball without making contact\n",
      "dist: 175.6156986438403:\n",
      "\tit was caught by the fielder\n",
      "\tit was caught by the center fielder\n",
      "dist: 175.65284654067278:\n",
      "\tand the batter hit the ball down the 3rd base line\n",
      "\tthe hitter hit a foul ball towards the 3rd base side\n",
      "dist: 175.65284654067278:\n",
      "\tthe hitter hit a foul ball towards the 3rd base side\n",
      "\tand the batter hit the ball down the 3rd base line\n",
      "dist: 175.77408704296892:\n",
      "\tthe ball was right down the middle in the strike zone\n",
      "\tthe ball was right down the middle over the plate in the strike zone\n",
      "dist: 175.77408704296892:\n",
      "\tthe ball was right down the middle over the plate in the strike zone\n",
      "\tthe ball was right down the middle in the strike zone\n",
      "dist: 175.82839179958611:\n",
      "\tthe ball crossed the plate on the outside edge of the strike zone resulting in a called strike\n",
      "\tthe ball crossed the plate outside of the strike zone resulting in a ball\n",
      "dist: 175.84753560089945:\n",
      "\teventually the left fielder made the catch for the out\n",
      "\tthe left fielder caught the ball in the air for an out\n",
      "dist: 175.95657671331537:\n",
      "\tball was not in strike\n",
      "\tthe ball was not thrown through the strike zone\n",
      "dist: 175.9575645410651:\n",
      "\the threw the ball to first to get the out\n",
      "\the threw the ball to first for the out\n",
      "dist: 175.9575645410651:\n",
      "\the threw the ball to first for the out\n",
      "\the threw the ball to first to get the out\n",
      "dist: 175.96672093215278:\n",
      "\tthe umpire ruled it a ball\n",
      "\tthe umpire called it a ball\n",
      "dist: 175.99502098804734:\n",
      "\tthe batter hit the ball up the third base line\n",
      "\tthe batter hit the ball to the third basemen\n",
      "dist: 176.1233354305869:\n",
      "\tthe hitter hit a ground ball to the shortstop before being thrown out at first base\n",
      "\tthe hitter hit the ball on the ground to the shortstop\n",
      "dist: 176.24204866865972:\n",
      "\tthe batter hit a line drive that was caught by the second baseman\n",
      "\tthe batter hit the ball in the air towards right field and was caught by the second baseman\n",
      "dist: 176.24204866865972:\n",
      "\tthe batter hit the ball in the air towards right field and was caught by the second baseman\n",
      "\tthe batter hit a line drive that was caught by the second baseman\n",
      "dist: 176.2937983158507:\n",
      "\tthe batter hit it into the air which became a flyball\n",
      "\tthe batter hit a fly ball\n",
      "dist: 176.36165817678472:\n",
      "\tthe 3rd baseman fielded the ball and threw the runner out at first\n",
      "\tthe hitter hit the ball on the ground to the 3rd baseman who then threw the batter out at first base\n",
      "dist: 176.7553098614581:\n",
      "\tthe batter hit it to right center field for a hit\n",
      "\tthe batter hit it to mid center field for a hit\n",
      "dist: 176.87691316662207:\n",
      "\tthe batter hit a ground ball directly to a\n",
      "\tthe batter hit a ground ball\n",
      "dist: 176.90494420480087:\n",
      "\tit was caught by the fielder for the out\n",
      "\tit was caught by right fielder for an out\n",
      "dist: 177.71771140992027:\n",
      "\tthe ball landed just inside the strike zone\n",
      "\tthe ball landed within the strike zone\n",
      "dist: 177.7296019750058:\n",
      "\tthe hitter swung and fouled the ball off to the third base side\n",
      "\tthen the batter swung and hit it on the ground past the third basemen and into the outfield\n",
      "dist: 177.83162988978367:\n",
      "\ttherefore an out was recorded\n",
      "\tthe out was recorded\n",
      "dist: 177.83162988978367:\n",
      "\tthe out was recorded\n",
      "\ttherefore an out was recorded\n",
      "dist: 177.84422811901226:\n",
      "\tthe batter hit a ball that landed on the ground in front of him\n",
      "\tthe batter hit the ball on the ground\n",
      "dist: 177.87313295165865:\n",
      "\tthen the batter hit a long fly to center field that was caught in the air for a out\n",
      "\tthe batter hit a high fly ball out towards center field\n",
      "dist: 178.02168055590215:\n",
      "\tthe pitcher threw the ball a little low\n",
      "\tthe pitcher threw the ball low in the strike zone\n",
      "dist: 178.15894690954798:\n",
      "\tthe ball didn't fly in the air\n",
      "\tthe ball wasn't caught in the air\n",
      "dist: 178.40114486504086:\n",
      "\the threw him out\n",
      "\twho throws him out\n",
      "dist: 178.53478664245546:\n",
      "\tthe ball was outside\n",
      "\tthe ball was outside for a ball\n",
      "dist: 178.53478664245546:\n",
      "\tthe ball was outside for a ball\n",
      "\tthe ball was outside\n",
      "dist: 178.53770687071923:\n",
      "\tthe batter hit the ball on the ground up the\n",
      "\tthe batter hit a ground ball\n",
      "dist: 178.6111765739207:\n",
      "\tit was outside the strike zone without the batter swinging\n",
      "\tit landed outside of the strike zone without being swung at by the batter\n",
      "dist: 178.8220836991523:\n",
      "\tthe batter got a base hit\n",
      "\tthe batter got on base\n",
      "dist: 178.8220836991523:\n",
      "\tthe batter got on base\n",
      "\tthe batter got a base hit\n",
      "dist: 178.87587542593175:\n",
      "\tit was an out\n",
      "\the was out\n",
      "dist: 178.87587542593175:\n",
      "\the was out\n",
      "\tit was an out\n",
      "dist: 178.88157334121848:\n",
      "\tthen it was hit in the air and caught\n",
      "\tit was hit and caught in the air for an\n",
      "dist: 178.88157334121848:\n",
      "\tit was hit and caught in the air for an\n",
      "\tthen it was hit in the air and caught\n",
      "dist: 178.8984889678985:\n",
      "\tit was caught by the left fielder\n",
      "\tit was caught by the fielder\n",
      "dist: 179.07438391324618:\n",
      "\tthe batter hit the ball outside the fairplay\n",
      "\tthe batter hit the ball outside of the field of play\n",
      "dist: 179.07728479016913:\n",
      "\tit counts as a ball\n",
      "\tit was a ball\n",
      "dist: 179.66799351615106:\n",
      "\the hit safely\n",
      "\tit landed safely for a hit\n",
      "dist: 179.66799351615106:\n",
      "\tit landed safely for a hit\n",
      "\the hit safely\n",
      "dist: 179.80695726333857:\n",
      "\tit bounced on the ground back to the pitcher who then through the batter out at first base\n",
      "\tthe batter hit the ball on the ground back to the pitcher\n",
      "dist: 179.8309476304738:\n",
      "\tthe batter swung and missed the ball completely ie did not make contact\n",
      "\tthe batter swung and did not make contact with the ball\n",
      "dist: 179.883676264798:\n",
      "\tball landed outside the foul\n",
      "\tthe ball landed in foul territory\n",
      "dist: 180.05417652735863:\n",
      "\tit was thrown through the strike zone\n",
      "\tthe ball went through the strike zone\n",
      "dist: 180.06223214436528:\n",
      "\tthe batter took a swing yet failed to make contact\n",
      "\tthe batter swung but did not make contact with the ball\n",
      "dist: 180.09082637548187:\n",
      "\tthe third baseman threw to the second base for a forceout of the runner on first\n",
      "\tthe third baseman caught the ball and threw it to the second baseman for a force out\n",
      "dist: 180.09267629151788:\n",
      "\tthe batter hit the ball off of the leftcenter field wall resulting in likely at least a double\n",
      "\tthe batter hit the ball into the leftcenter gap for a double\n",
      "dist: 180.09267629151788:\n",
      "\tthe batter hit the ball into the leftcenter gap for a double\n",
      "\tthe batter hit the ball off of the leftcenter field wall resulting in likely at least a double\n",
      "dist: 180.16066249077195:\n",
      "\tbatter hit the ball low and ran to first base\n",
      "\tthe batter hit the ball towards first base\n",
      "dist: 180.25206838709624:\n",
      "\tthe batter hit it on the ground to left field\n",
      "\tthe batter hit it fair down the left field line on the ground for a hit\n",
      "dist: 180.25206838709624:\n",
      "\tthe batter hit it fair down the left field line on the ground for a hit\n",
      "\tthe batter hit it on the ground to left field\n",
      "dist: 180.44684768064968:\n",
      "\tthen the hitter hit a fly ball which was easily caught by the center fielder\n",
      "\tit was caught on the fly by the center fielder\n",
      "dist: 180.62177048357177:\n",
      "\twent to the outside of the plate resulting in a ball\n",
      "\tthe ball crossed the plate outside of the strike zone resulting in a ball\n",
      "dist: 180.73867135216443:\n",
      "\tit's a hit\n",
      "\tit was a hit\n",
      "dist: 181.24696911721463:\n",
      "\tit crossed the home plate area to the left of the strike zone\n",
      "\tball crossed home plate outside the strike zone\n",
      "dist: 181.38288562922506:\n",
      "\tthe ball was low of the strike zone\n",
      "\tthe ball was below the strike zone\n",
      "dist: 181.44475164321108:\n",
      "\tthe hitter hit a fly ball which was caught by an outfielder\n",
      "\tit was caught on the fly by the outfielder\n",
      "dist: 181.44475164321108:\n",
      "\tit was caught on the fly by the outfielder\n",
      "\tthe hitter hit a fly ball which was caught by an outfielder\n",
      "dist: 181.46607771435725:\n",
      "\tthe ball crossed the plate in the lower part of the strike zone resulting in a strike\n",
      "\tthe ball crossed the plate on the outside edge of the strike zone resulting in a called strike\n",
      "dist: 181.5383484790937:\n",
      "\tthe batter hit the ball in the rightcenter gap for a hit\n",
      "\tthe batter hit it to right center field for a hit\n",
      "dist: 182.1512447023552:\n",
      "\tthe runner was thrown out at first\n",
      "\trunning was thrown out at first\n",
      "dist: 182.1512447023552:\n",
      "\trunning was thrown out at first\n",
      "\tthe runner was thrown out at first\n",
      "dist: 182.23670821027105:\n",
      "\tand then the second baseman threw it to first for the double play\n",
      "\tthe second baseman caught the ball and threw it to the first baseman for the out\n",
      "dist: 182.293236300945:\n",
      "\tand he threw it to the first baseman for another out completing a double play\n",
      "\tand then the second baseman threw it to first for the double play\n",
      "dist: 182.40917413770427:\n",
      "\tit crossed the plate below the strike zone for a low ball\n",
      "\tthe ball crossed the plate below the strike zone\n",
      "dist: 182.51817518011893:\n",
      "\tit landed in the strike zone\n",
      "\tit hit the strike zone\n",
      "dist: 182.71151057263998:\n",
      "\tthe batter hit the ball on the ground to the first baseman who then stepped on first base\n",
      "\tthe batter hit the ball on the ground to the right of first base\n",
      "dist: 182.93877654693193:\n",
      "\twho threw the ball to first base for the force out\n",
      "\twho threw on to first base for an out\n",
      "dist: 183.09855092440472:\n",
      "\tthe hitter took a swing and a miss which made it a\n",
      "\tthe hitter swung and missed for a strike\n",
      "dist: 183.35567326874212:\n",
      "\tthe right fielder came on to catch it for an out\n",
      "\tit was caught by right fielder for an out\n",
      "dist: 183.36308061373626:\n",
      "\twho threw him out at first base\n",
      "\twho threw it to first base for a out\n",
      "dist: 183.37773919461966:\n",
      "\tthe ball was hit on the ground to the first baseman\n",
      "\tthe batter hit the ball on the ground to the first baseman who then stepped on first base\n",
      "dist: 183.7541442104112:\n",
      "\the hit it foul\n",
      "\the hit a foul ball\n",
      "dist: 183.7541442104112:\n",
      "\the hit a foul ball\n",
      "\the hit it foul\n",
      "dist: 184.00379900717493:\n",
      "\tthe ball was far outside the strike box\n",
      "\tthe ball was far outside the strike zone\n",
      "dist: 184.01708047583745:\n",
      "\tthe pitcher threw the ball towards home plate\n",
      "\tthe pitcher threw the ball low over the plate\n",
      "dist: 184.13599617838833:\n",
      "\tit crossed the plate in or close to the strike zone\n",
      "\tit crossed over the plate in the strike zone\n",
      "dist: 184.1575923987685:\n",
      "\tthen the hitter hit the ball into the outfield which was picked up by the outfielder on the first bounce which resulted in a hit\n",
      "\tthen the hitter lined a ball into the outfield for a hit and got on base\n",
      "dist: 184.1575923987685:\n",
      "\tthen the hitter lined a ball into the outfield for a hit and got on base\n",
      "\tthen the hitter hit the ball into the outfield which was picked up by the outfielder on the first bounce which resulted in a hit\n",
      "dist: 184.33104318273314:\n",
      "\tthe batter hit it past the infield on the ground\n",
      "\tthe batter hit the ball to the shortstop on the ground\n",
      "dist: 184.56059609779828:\n",
      "\tthen the hitter hit a line drive to center field which was not caught\n",
      "\tthe ball hit out to center field and was not caught\n",
      "dist: 184.87116186188274:\n",
      "\tthen the batter hit the ball beyond the foul line\n",
      "\tthe batter hits the ball behind the foul line\n",
      "dist: 185.0102740722352:\n",
      "\tthe batter swung and popped the ball up down the third base line\n",
      "\tthe batter hit the ball to the third baseman who then through the hitter out at first\n",
      "dist: 185.23853093181884:\n",
      "\tthe batter hit the ball on the ground to the 3rd baseman and reached 1st base before the throw\n",
      "\tthe hitter hit the ball on the ground to the 3rd baseman who then threw the batter out at first base\n",
      "dist: 185.39770694480018:\n",
      "\tthe third baseman caught it off the ground and threw to\n",
      "\tthe third baseman caught the ball and threw it to the first baseman\n",
      "dist: 185.4151686623946:\n",
      "\tit was caught outside of the strike zone for a called ball\n",
      "\tit was caught below the strike zone resulting in a called ball\n",
      "dist: 185.4151686623946:\n",
      "\tit was caught below the strike zone resulting in a called ball\n",
      "\tit was caught outside of the strike zone for a called ball\n",
      "dist: 185.5448881685014:\n",
      "\tthe infielder could catch it\n",
      "\tthe fielder could catch it\n",
      "dist: 185.6483323491284:\n",
      "\tthe umpire called the pitch a ball\n",
      "\tthe umpire ruled the pitch a ball\n",
      "dist: 185.79878544591995:\n",
      "\tthen the batter makes contact not in\n",
      "\tthe batter did not make contact\n",
      "dist: 185.79878544591995:\n",
      "\tthe batter did not make contact\n",
      "\tthen the batter makes contact not in\n",
      "dist: 185.8646474047408:\n",
      "\tthe center fielder caught it at the warning track for an out\n",
      "\tthe center fielder caught it for an out\n",
      "dist: 185.8703692300615:\n",
      "\tit went behind him and to the side\n",
      "\tit went behind him\n",
      "dist: 186.01788007272904:\n",
      "\tthe batter swung the bat and hit it into foul territory\n",
      "\tthe batter made contact with the pitch and hit it into foul territory\n",
      "dist: 186.02697853794876:\n",
      "\tthe batter made contact with the pitch and chopped it foul at the plate\n",
      "\tthe batter made contact with the pitch and hit it into foul territory\n",
      "dist: 186.17122691812912:\n",
      "\tthe batter fouled the pitch down left field line\n",
      "\tthe batter hit it down the left field line\n",
      "dist: 186.1866262050017:\n",
      "\tit was popped up and caught by the second baseman\n",
      "\tit was caught by the second baseman\n",
      "dist: 186.45302567556004:\n",
      "\tthen the batter hit the ball but landed in foul zone\n",
      "\tthe batter hit the ball which landed behind the foul\n",
      "dist: 186.64355103536735:\n",
      "\tthe ball looked outside the strike zone to me\n",
      "\tthe ball was outside the strike zone\n",
      "dist: 186.72081520058333:\n",
      "\tin turn causing a home run\n",
      "\tit's a home run\n",
      "dist: 186.7418664357062:\n",
      "\tthe ball was hit to left field\n",
      "\tthe batter hit the ball into left field\n",
      "dist: 186.883066533791:\n",
      "\tthe batter managed to make contact with the\n",
      "\tthen the batter made contact\n",
      "dist: 186.89779926965917:\n",
      "\tthe ball hit the ground before being fielded for a forced out at third base\n",
      "\tthe ball landed on the ground before reaching the third baseman\n",
      "dist: 187.0928902864535:\n",
      "\tthe fielder was unable to catch the ball in the air\n",
      "\tthe outfielder wasn't able to catch the ball\n",
      "dist: 187.36229298952193:\n",
      "\tthe umpire called it as such\n",
      "\tthe umpire called it a\n",
      "dist: 187.4315551802129:\n",
      "\tthe batter hit a foul down the right field line\n",
      "\tthe batter fouled it over the right field line\n",
      "dist: 187.4315551802129:\n",
      "\tthe batter fouled it over the right field line\n",
      "\tthe batter hit a foul down the right field line\n",
      "dist: 187.65844824859147:\n",
      "\tit went over the plate as a strike 1\n",
      "\tit went over the plate in strike zone\n",
      "dist: 187.72786421212297:\n",
      "\tthe left fielder ran in to catch the ball\n",
      "\tthe left fielder caught the ball in the air for an out\n",
      "dist: 187.72917211767603:\n",
      "\tit was caught by the left fielder before touching the ground\n",
      "\tit was caught by the left fielder\n",
      "dist: 187.7620055404834:\n",
      "\tget there in time to catch the ball\n",
      "\tgets into position to catch the ball\n",
      "dist: 187.7620055404834:\n",
      "\tgets into position to catch the ball\n",
      "\tget there in time to catch the ball\n",
      "dist: 187.77670722140016:\n",
      "\tthe ball popped up but not into the field of play\n",
      "\tthe ball did not land in the field of play\n",
      "dist: 187.819765162508:\n",
      "\tthe batter did not make put the ball in play on the swing\n",
      "\tthe batter did not swing making it a ball\n",
      "dist: 187.819765162508:\n",
      "\tthe batter did not swing making it a ball\n",
      "\tthe batter did not make put the ball in play on the swing\n",
      "dist: 187.84555361625215:\n",
      "\tthe batter hit it into a force out at first base by the second baseman\n",
      "\tthe batter hit the ball on the ground to the second baseman\n",
      "dist: 187.8600680242517:\n",
      "\tthen the batter made contact hitting the ground ball which was picked up and thrown to the first baseman for the out\n",
      "\tthe batter hit a ground ball to first baseman\n",
      "dist: 188.37001971156664:\n",
      "\tthe batter swung at a low pitch\n",
      "\tthe batter swung at the pitch\n",
      "dist: 188.43350876461872:\n",
      "\tit passed through the strike zone without the batter swinging\n",
      "\tit was outside the strike zone without the batter swinging\n",
      "dist: 188.62695217052448:\n",
      "\tit was within the strike zone\n",
      "\tit was delivered within the strike zone\n",
      "dist: 188.62695217052448:\n",
      "\tit was delivered within the strike zone\n",
      "\tit was within the strike zone\n",
      "dist: 188.6454653433244:\n",
      "\tthe ball wasn't caught for an out\n",
      "\tthe ball wasn't caught in the air\n",
      "dist: 188.90028069571332:\n",
      "\tthe first baseman made the catch\n",
      "\tthe first baseman made the catch in the air\n",
      "dist: 188.92686903847704:\n",
      "\tthe centerfielder caught the ball after running back\n",
      "\tthe centerfielder caught it on the run after leaping into the wall\n",
      "dist: 188.92686903847704:\n",
      "\tthe centerfielder caught it on the run after leaping into the wall\n",
      "\tthe centerfielder caught the ball after running back\n",
      "dist: 189.04249866258675:\n",
      "\tit's a perfect example of a ground ball\n",
      "\tit is a ground ball\n",
      "dist: 189.04249866258675:\n",
      "\tit is a ground ball\n",
      "\tit's a perfect example of a ground ball\n",
      "dist: 189.17047637625294:\n",
      "\tthe pitcher threw an offspeed pitch ball that crossed the plate in the strike zone\n",
      "\tthe pitcher threw the ball that cross the plate outside of the strike zone\n",
      "dist: 189.3143222574409:\n",
      "\tthe ball was caught by a player in the outfield\n",
      "\tthe ball was caught in the air by a fielder\n",
      "dist: 189.3143222574409:\n",
      "\tthe ball was caught in the air by a fielder\n",
      "\tthe ball was caught by a player in the outfield\n",
      "dist: 189.3543585481119:\n",
      "\tthe batted ball went into the stands in foul territory\n",
      "\tthe batter hit the ball into the stands in foul territory\n",
      "dist: 189.57860959840679:\n",
      "\tthe batter hit the ball in left foul territory\n",
      "\tthe batter hit a ball in foul territory\n",
      "dist: 190.02259746353886:\n",
      "\tthe ball being in play\n",
      "\tthe ball was outside\n",
      "dist: 190.26358097216786:\n",
      "\tthe centerfielder caught the ball on the fly\n",
      "\tit was caught on the fly by the center fielder\n",
      "dist: 190.7647187084651:\n",
      "\tthe hitter hit the ball but was thrown out at\n",
      "\tthe hitter hit it into foul\n",
      "dist: 191.14055441548322:\n",
      "\thit pitch to infield for a force play and second\n",
      "\twho threw the ball to second base for a force out\n",
      "dist: 191.29769980362272:\n",
      "\tthe ball was in the center of the strike zone\n",
      "\tthe ball was in the strike zone\n",
      "dist: 191.37200438567294:\n",
      "\tthen the batter hit a fly ball into foul territory\n",
      "\tthe batter hit the ball in the air into foul territory\n",
      "dist: 191.75807922398877:\n",
      "\tthe batter reached on a hit\n",
      "\tthe batter hit a home\n",
      "dist: 191.76805539465826:\n",
      "\tit landed on the ground\n",
      "\tit falling to the ground\n",
      "dist: 191.76805539465826:\n",
      "\tit falling to the ground\n",
      "\tit landed on the ground\n",
      "dist: 192.10479758372736:\n",
      "\twho caught it in the air for an out\n",
      "\the catches it in the air for the out\n",
      "dist: 192.10479758372736:\n",
      "\the catches it in the air for the out\n",
      "\twho caught it in the air for an out\n",
      "dist: 192.31552647684572:\n",
      "\tbatter popped it to shallow center which was caught by the shortstop\n",
      "\tthe batter hit an infield pop up caught by the first baseman\n",
      "dist: 192.33766930214446:\n",
      "\tthe ball was hit to centerfield\n",
      "\tthe batter hit the ball to centerfield\n",
      "dist: 192.47363518022672:\n",
      "\tthe ball was outside the strike box\n",
      "\tthe ball was far outside the strike box\n",
      "dist: 192.50375381918204:\n",
      "\tthe ball was hit into the field of play and not caught in the air\n",
      "\tthe ball did not land in the field of play\n",
      "dist: 192.53546301352532:\n",
      "\tball was hit on the ground to 2nd baseman altuve\n",
      "\tit was hit on the ground to the second baseman\n",
      "dist: 192.55392014094204:\n",
      "\tthe batter hit it successfully\n",
      "\tthe batter hit it up high\n",
      "dist: 192.59220703961824:\n",
      "\tbatter hit the ball into the stands to the right of first base\n",
      "\tthe batter hit the ball on the ground to the right of first base\n",
      "dist: 192.7610432955441:\n",
      "\tthe batter missed the ball\n",
      "\tthe batter swung and missed the ball\n",
      "dist: 193.48913583357267:\n",
      "\tthe batter hit the ball on the ground just in front of home plate\n",
      "\tthe batter hit a ground ball to first baseman\n",
      "dist: 193.50835927671798:\n",
      "\tthe right fielder fielded the base hit\n",
      "\tthe ball was hit to the right fielder\n",
      "dist: 194.10011589683094:\n",
      "\tit was not in the play of field\n",
      "\tit did not go in the field of play\n",
      "dist: 194.17603809575218:\n",
      "\tthe ball arrived\n",
      "\tthe ball got there\n",
      "dist: 194.17603809575218:\n",
      "\tthe ball got there\n",
      "\tthe ball arrived\n",
      "dist: 194.2233754437321:\n",
      "\tthe ball went foul\n",
      "\tball landed outside the foul\n",
      "dist: 194.2711566349745:\n",
      "\tit was a ground ball to the shortstop who then threw the runner to at\n",
      "\tthe hitter hit a ground ball to the shortstop before being thrown out at first base\n",
      "dist: 194.31112818515345:\n",
      "\tthe catcher fielded the ball and threw the batter out at first base\n",
      "\twho caught it and threw the batter out at first base\n",
      "dist: 194.31112818515345:\n",
      "\twho caught it and threw the batter out at first base\n",
      "\tthe catcher fielded the ball and threw the batter out at first base\n",
      "dist: 194.43868649056736:\n",
      "\the swung at the ball and missed it\n",
      "\the swung and missed it\n",
      "dist: 194.5352012604064:\n",
      "\tthe batter hits the ball which is caught out by the outfielder\n",
      "\tthen the batter made contact hitting the ground ball which was picked up and thrown to the first baseman for the out\n",
      "dist: 194.6996533829834:\n",
      "\twho threw the ball to 1st for a force out\n",
      "\twho threw the ball to first base for the force out\n",
      "dist: 194.8560012387598:\n",
      "\tin this case the umpire ruled it a strike\n",
      "\tand the umpire called it a strike\n",
      "dist: 194.98009444175028:\n",
      "\tthe batter hit it in the air to center field and was caught\n",
      "\tthe batter hit the ball in the air and was caught by the center fielder\n",
      "dist: 195.0900985418112:\n",
      "\tthe ball arrived at the plate within the strike zone\n",
      "\tthe ball crossed the plate in the strike zone\n",
      "dist: 195.1706845869121:\n",
      "\tthe ball was not caught\n",
      "\tthe ball wasn't caught in the air\n",
      "dist: 195.20453080459194:\n",
      "\tthe batter didn't run for the bases\n",
      "\tthe batter didn't go for the hit\n",
      "dist: 195.28760397561493:\n",
      "\tthe pitcher threw a nice pitch over the plate and in the strike zone\n",
      "\tthe pitcher threw the ball that cross the plate outside of the strike zone\n",
      "dist: 195.4835589420391:\n",
      "\tthe batter hit a grounder to left field and advanced to first base\n",
      "\tthe batter hit a grounder to the second baseman\n",
      "dist: 195.69546813991005:\n",
      "\tthe batter was thrown out at first base on a ground ball to the shortstop\n",
      "\tthe batter hit the ball on the ground to the shortstop\n",
      "dist: 195.78097772221287:\n",
      "\tthe batter got a piece of the ball\n",
      "\tthen the batter made contact with the ball\n",
      "dist: 195.81373029588107:\n",
      "\tthen the batter swung and made contact with the ball sending it up and back into the stands\n",
      "\tthen the batter swung and hit the ball behind him and into the stands\n",
      "dist: 195.90884323052802:\n",
      "\tit was caught by the catcher outside of the strike zone and called a ball by the umpire\n",
      "\tit was caught by the catcher outside of the strike zone\n",
      "dist: 196.2087737948887:\n",
      "\tthe ball went behind home plate\n",
      "\tthe ball went behind home plate in foul territory\n",
      "dist: 196.4831604528317:\n",
      "\tit touched the ground\n",
      "\tit landed on the ground\n",
      "dist: 196.62919553227331:\n",
      "\tit went very low and even hit the ground\n",
      "\tit falling to the ground\n",
      "dist: 196.6744351562075:\n",
      "\tfirst baseman throwing out the batter\n",
      "\tthrows to the first baseman to get the batter out\n",
      "dist: 196.6744351562075:\n",
      "\tthrows to the first baseman to get the batter out\n",
      "\tfirst baseman throwing out the batter\n",
      "dist: 196.70039364487556:\n",
      "\tthe batter's shoulders\n",
      "\tthe batter was\n",
      "dist: 197.37007422970697:\n",
      "\tthe center fielder failed to catch the ball\n",
      "\tthe left fielder was not able to catch it\n",
      "dist: 197.44752278379661:\n",
      "\tthen it was hit into the air and caught by the third baseman\n",
      "\tthe third baseman ran over and caught it in the air\n",
      "dist: 197.44752278379661:\n",
      "\tthe third baseman ran over and caught it in the air\n",
      "\tthen it was hit into the air and caught by the third baseman\n",
      "dist: 197.58908010110977:\n",
      "\tit was caught in the air by the right fielder\n",
      "\tit was caught by the right fielder\n",
      "dist: 197.6762548015857:\n",
      "\tthe ball crossed the home plate area in the strike zone according to the umpire\n",
      "\tthe ball crossed the plate within the strike zone and was called a strike by the umpire\n",
      "dist: 197.7847017305314:\n",
      "\tit was hit and bounced to third base\n",
      "\tthe hitter swung and fouled the ball off to the third base side\n",
      "dist: 197.9746503238121:\n",
      "\tthe thrown ball was thrown over the plate\n",
      "\tit was thrown over the plate\n",
      "dist: 197.9746503238121:\n",
      "\tit was thrown over the plate\n",
      "\tthe thrown ball was thrown over the plate\n",
      "dist: 198.25715681222124:\n",
      "\tthe batter hits the ball which lands safely on the field\n",
      "\tthen the batter hit the ball into play and safely reached base\n",
      "dist: 198.53546396291674:\n",
      "\tthe batter hit under the ball\n",
      "\tthe batter struck the ball\n",
      "dist: 198.80713545273963:\n",
      "\tthe batter popped the ball in the air\n",
      "\tthe batter hit the ball into the air\n",
      "dist: 199.04029114670908:\n",
      "\tit went over the plate in the strike zone without the batter swinging\n",
      "\tit went over the plate in strike zone\n",
      "dist: 199.3285392729004:\n",
      "\tthe batter popped the ball up in the infield in foul territory\n",
      "\tthe batter made contact grounding the ball into foul territory on the first base side of the field\n",
      "dist: 199.3285392729004:\n",
      "\tthe batter made contact grounding the ball into foul territory on the first base side of the field\n",
      "\tthe batter popped the ball up in the infield in foul territory\n",
      "dist: 199.3791120290544:\n",
      "\tball hit outside of play\n",
      "\tthe ball was hit and went outside of the baseline\n",
      "dist: 199.3791120290544:\n",
      "\tthe ball was hit and went outside of the baseline\n",
      "\tball hit outside of play\n",
      "dist: 199.5607276064248:\n",
      "\tthe ball flew over the left field fence resulting in a home run for the batter\n",
      "\tit went over the outfield fence for a home run\n",
      "dist: 199.6923041140537:\n",
      "\tbut it went into the stands in foul territory in this case behind home plate\n",
      "\tit fell behind the plate into foul territory\n",
      "dist: 199.6923041140537:\n",
      "\tit fell behind the plate into foul territory\n",
      "\tbut it went into the stands in foul territory in this case behind home plate\n",
      "dist: 200.10554731936938:\n",
      "\tthe batter fouled the ball off on the left side\n",
      "\tthe batter fouled off the\n",
      "dist: 200.24719189766284:\n",
      "\tit was hit on the ground to the shortstop\n",
      "\tit landed on the ground before reaching the shortstop\n",
      "dist: 200.46367089475356:\n",
      "\tthe bat missed the ball\n",
      "\tthe batter swung the bat but missed the ball\n",
      "dist: 200.52399196280865:\n",
      "\tthe ball was below the strike\n",
      "\tthe ball was below the strike zone\n",
      "dist: 200.5308751888908:\n",
      "\tthe ball was to\n",
      "\tthe ball got there\n",
      "dist: 200.90796534308365:\n",
      "\tit was caught in the air by the left fielder\n",
      "\tit was caught by the left fielder\n",
      "dist: 201.12732656383113:\n",
      "\tit was fielded by the pitcher\n",
      "\tit was fielded by the pitcher and thrown to first\n",
      "dist: 201.12732656383113:\n",
      "\tit was fielded by the pitcher and thrown to first\n",
      "\tit was fielded by the pitcher\n",
      "dist: 201.29872049370974:\n",
      "\tthen the pitch crossed over the plate in the lower part of the strike zone\n",
      "\tthe pitch crossed the plate in the strike zone\n",
      "dist: 201.42379047598624:\n",
      "\tthe pitch was in the strike zone\n",
      "\tthe pitch was went into the strike zone\n",
      "dist: 201.5346032470578:\n",
      "\tthe ball was inside the strike zone\n",
      "\tthe ball landed just inside the strike zone\n",
      "dist: 201.94686721086242:\n",
      "\tbatter hit a fly ball over the fence for a home\n",
      "\tthe batter drove the ball over the fence in right field for a home run\n",
      "dist: 202.08825764544514:\n",
      "\tthe man on plate hit the ball on the ground and was thrown out at first base\n",
      "\tthe ball was hit on the ground to the first baseman\n",
      "dist: 202.09755398601519:\n",
      "\tthe ball landed high and outside the strike zone\n",
      "\tthe ball landed outside the strike zone\n",
      "dist: 202.13470566442908:\n",
      "\tthe batter ramirez swung and missed making contact with the pitch\n",
      "\tthe batter swung at the pitch and missed making contact\n",
      "dist: 202.61389499816784:\n",
      "\tit was pitched outside the strike zone\n",
      "\tthe ball was thrown outside the strike zone\n",
      "dist: 202.83283381302232:\n",
      "\tit landed in foul territory in the stands\n",
      "\tit landed in foul territory\n",
      "dist: 203.14946251125625:\n",
      "\tit was ruled a ball by the ump\n",
      "\tit was called a ball by the umpire\n",
      "dist: 203.1762711625772:\n",
      "\tthe ball crossed the plate high and inside\n",
      "\tthe ball went right over the plate\n",
      "dist: 203.2818667247912:\n",
      "\ta ground ball was hit up the middle\n",
      "\ta ground ball hit\n",
      "dist: 203.2818667247912:\n",
      "\ta ground ball hit\n",
      "\ta ground ball was hit up the middle\n",
      "dist: 203.29234269291834:\n",
      "\tthe batter bunted the ball towards the left side of the field\n",
      "\tthe batter hit the ball to left field\n",
      "dist: 203.29980906695624:\n",
      "\tthe third baseman caught it on the fly\n",
      "\tthen it was hit into the air and caught by the third baseman\n",
      "dist: 203.30651466031765:\n",
      "\tthe ball went along the ground towards third base\n",
      "\tthe ball is hit on the ground to the third baseman\n",
      "dist: 203.30867222345756:\n",
      "\tthe batter failed to try to hit it\n",
      "\tthe batter did not swing or make contact\n",
      "dist: 203.50867053326425:\n",
      "\tthe batter hit the pitch for a single scoring a run\n",
      "\tthe batter hit the ball for a single\n",
      "dist: 203.55890251802253:\n",
      "\the threw it in the strike zone\n",
      "\tball was thrown in the strike zone\n",
      "dist: 203.66333072570077:\n",
      "\tbatter swung past the plate\n",
      "\tbatter hit ball in air\n",
      "dist: 203.69063919236856:\n",
      "\tthe batter swung but missed resulting in the 3rd strike and a strike out\n",
      "\tthe batter swung but missed for strike three\n",
      "dist: 203.69063919236856:\n",
      "\tthe batter swung but missed for strike three\n",
      "\tthe batter swung but missed resulting in the 3rd strike and a strike out\n",
      "dist: 203.80083895097016:\n",
      "\tit was both outside the strike zone\n",
      "\tit was outside the strike zone\n",
      "dist: 203.83832459752654:\n",
      "\tit hit the dirt\n",
      "\tit hit the dirt before reaching the\n",
      "dist: 203.83832459752654:\n",
      "\tit hit the dirt before reaching the\n",
      "\tit hit the dirt\n",
      "dist: 203.91949928300423:\n",
      "\twho threw him out at first\n",
      "\twho threw him out\n",
      "dist: 203.97810763359232:\n",
      "\tthe ball was not in play\n",
      "\tthe ball wasn't caught in the air\n",
      "dist: 204.09774616541037:\n",
      "\tthe hitter swung hard\n",
      "\tthe hitter hit it\n",
      "dist: 204.42290254640608:\n",
      "\tthe batter hit the ball on the ground towards the fielder\n",
      "\tthe batter hit the ball which landed on the ground in the field of play\n",
      "dist: 204.55814281829868:\n",
      "\tthe ball landed on the ground before reaching the outfield\n",
      "\tthe ball flew in the air landing on the ground in the outfield\n",
      "dist: 204.55814281829868:\n",
      "\tthe ball flew in the air landing on the ground in the outfield\n",
      "\tthe ball landed on the ground before reaching the outfield\n",
      "dist: 204.88138743646329:\n",
      "\tthe batter lined the ball safely into left field\n",
      "\tthe batter hits the ball which lands safely on the field\n",
      "dist: 205.3461203212963:\n",
      "\ta fielder's choice ball\n",
      "\ta fielder's choice\n",
      "dist: 205.3461203212963:\n",
      "\ta fielder's choice\n",
      "\ta fielder's choice ball\n",
      "dist: 205.38286531489504:\n",
      "\tthe ball rolled into the outfield\n",
      "\tthen he hit the ball into the outfield\n",
      "dist: 205.58314502180207:\n",
      "\tthe ball hit the ground before being fielded for a forced out at second base\n",
      "\tit was hit on the ground to the second baseman\n",
      "dist: 205.60335411421985:\n",
      "\tmade contact sending a fly ball to the outfield\n",
      "\tthe ball was hit over the outfield wall on the fly in fair territory\n",
      "dist: 205.8820162327748:\n",
      "\tand the player caught the ball\n",
      "\tthe fielder caught the ball\n",
      "dist: 205.99978331309362:\n",
      "\tthe pitch was not a strike\n",
      "\tthe pitch was not in the strike zone\n",
      "dist: 206.1765266921859:\n",
      "\tthe batter swung and popped into foul territory\n",
      "\tthe batter swung and hit the ball into foul territory\n",
      "dist: 206.66681784468443:\n",
      "\tno fielder caught it\n",
      "\tnobody in the outfield caught it\n",
      "dist: 206.66681784468443:\n",
      "\tnobody in the outfield caught it\n",
      "\tno fielder caught it\n",
      "dist: 206.81260154659762:\n",
      "\tthe pitch was a strike\n",
      "\tthe pitch was in the strike zone\n",
      "dist: 207.0474603562522:\n",
      "\tthe umpire to rule it ball\n",
      "\tthe umpire ruled it a ball\n",
      "dist: 207.23182727135924:\n",
      "\tthe batter hit it over the fence on the fly\n",
      "\tbatter hit a fly ball over the fence for a home\n",
      "dist: 207.2424278830833:\n",
      "\the hit it towards the left of the third base line\n",
      "\tthe ball was hit to the third baseman\n",
      "dist: 207.48734989771154:\n",
      "\tan outfielder caught the ball that was hit inside the diamond\n",
      "\tthe outfielder caught the ball\n",
      "dist: 207.90591438931105:\n",
      "\tthe infielder caught it in play\n",
      "\tthe infielder could catch it\n",
      "dist: 208.05819887078457:\n",
      "\tanother out double play on the batter running to first base\n",
      "\tand then the second baseman threw it to first for the double play\n",
      "dist: 208.11543550221455:\n",
      "\tthe hitter hit a high fly ball into right field which was caught\n",
      "\tthe hitter hit a fly ball which was caught by an outfielder\n",
      "dist: 208.13653716060713:\n",
      "\tthen the batter hit the ball outside of the park fair for a home run\n",
      "\tthe batter hit the ball over the outfield wall for a home run\n",
      "dist: 208.14875119270692:\n",
      "\tit was pitched in the strike zone\n",
      "\tthe ball was in the strike zone\n",
      "dist: 208.39796366776778:\n",
      "\the swung and hit the ball\n",
      "\tthe batter went for the swing and hit the ball\n",
      "dist: 208.41813214565556:\n",
      "\tthe pitcher threw a strike on inside corner of the plate\n",
      "\tthe pitcher threw a ball just outside the strike box\n",
      "dist: 208.4450897872294:\n",
      "\tpitcher threw the ball and was called a strike on the outer half of the plate\n",
      "\tthe pitcher threw a strike on inside corner of the plate\n",
      "dist: 208.56576080878116:\n",
      "\tthe ball was hit foul on strike 2\n",
      "\tyou hit a foul ball with 2 strikes\n",
      "dist: 208.56576080878116:\n",
      "\tyou hit a foul ball with 2 strikes\n",
      "\tthe ball was hit foul on strike 2\n",
      "dist: 209.1124979077859:\n",
      "\tthe pitch was low and outside\n",
      "\tthe pitch went low\n",
      "dist: 209.41944924592013:\n",
      "\tthe batter hit it foul territory behind the catcher\n",
      "\tthe batter hit it foul behind the plate\n",
      "dist: 209.43347720907974:\n",
      "\tit was caught by the catcher and was called a strike\n",
      "\tit was caught by the catcher in the strike zone\n",
      "dist: 209.66450188694495:\n",
      "\tit was inside the strike zone\n",
      "\tit was within the strike zone\n",
      "dist: 209.69402188777082:\n",
      "\tthe player hit the ball\n",
      "\tthe ball was hit\n",
      "dist: 209.8517446261604:\n",
      "\tthe batter checked his swing\n",
      "\tthe batter tried to check his swing\n",
      "dist: 209.8517446261604:\n",
      "\tthe batter tried to check his swing\n",
      "\tthe batter checked his swing\n",
      "dist: 210.00687328197733:\n",
      "\ta long fly ball hit to center field and caught\n",
      "\tthe centerfielder caught the ball on the fly\n",
      "dist: 210.60573014880615:\n",
      "\tin the batter missed it\n",
      "\tand the batter swung and missed it\n",
      "dist: 210.81243144727983:\n",
      "\tthrew it to the first baseman to beat the runner and get the ground out\n",
      "\tand he threw it to the first baseman for another out completing a double play\n",
      "dist: 210.98353642990625:\n",
      "\tthe batter took it\n",
      "\tthe batter was\n",
      "dist: 211.4306450307477:\n",
      "\tthe batter hit a line drive toward center\n",
      "\tthe batter hit a line drive to the left\n",
      "dist: 211.5919772424814:\n",
      "\twho threw the batter out at first base\n",
      "\tfirst baseman throwing out the batter\n",
      "dist: 211.80731102809224:\n",
      "\tthe hitter was thrown out\n",
      "\tthe hitter hit the ball but was thrown out at\n",
      "dist: 212.31273233216695:\n",
      "\tthe batted ball landed in shallow center field for a hit\n",
      "\tthe batter hit it to mid center field for a hit\n",
      "dist: 212.59533946879603:\n",
      "\ta ground ball was hit by the batter yet rolled into foul territory before clearing third base\n",
      "\ta ground ball hit to third base\n",
      "dist: 212.67718094799335:\n",
      "\tthe ball got there first\n",
      "\tthe ball got there\n",
      "dist: 212.72530509316093:\n",
      "\tit was fielded by the infielder\n",
      "\tit was fielded by the shortstop\n",
      "dist: 212.72530509316093:\n",
      "\tit was fielded by the shortstop\n",
      "\tit was fielded by the infielder\n",
      "dist: 212.9570721561606:\n",
      "\tthe batter hit the ball down inside the left foul line\n",
      "\tthe batter hit the ball in left foul territory\n",
      "dist: 213.15235830664375:\n",
      "\tthe batter hits the ball backwards for a\n",
      "\tthe batter hit the ball into the air backwards\n",
      "dist: 213.19808639363586:\n",
      "\ta base hit\n",
      "\tthe batter got a base hit\n",
      "dist: 213.6278988377008:\n",
      "\tthen the ball went high and right\n",
      "\tthe ball went high\n",
      "dist: 213.65293255982655:\n",
      "\tit was too high\n",
      "\tit went high\n",
      "dist: 213.65293255982655:\n",
      "\tit went high\n",
      "\tit was too high\n",
      "dist: 213.68294953504923:\n",
      "\tit was in the strike zone for a called strike\n",
      "\tit went into the strike zone so was called a strike\n",
      "dist: 213.68294953504923:\n",
      "\tit went into the strike zone so was called a strike\n",
      "\tit was in the strike zone for a called strike\n",
      "dist: 213.76056312089992:\n",
      "\tthe batter hit a ball that hit the ground almost\n",
      "\tthe batter hit the ball on the ground up the\n",
      "dist: 214.01138616307398:\n",
      "\tthe ball was above the strike zone\n",
      "\tit was above the strike zone\n",
      "dist: 214.01138616307398:\n",
      "\tit was above the strike zone\n",
      "\tthe ball was above the strike zone\n",
      "dist: 214.16552776562372:\n",
      "\tand the batter grounded to the short stop who then turned the double play for 2 outs\n",
      "\tanother out double play on the batter running to first base\n",
      "dist: 214.17709869978646:\n",
      "\tthe hitter got a piece of the ball\n",
      "\tthe hitter took a swing at the ball\n",
      "dist: 214.2498815623249:\n",
      "\thowever the batter was thrown out at first base\n",
      "\twho threw the batter out at first base\n",
      "dist: 214.33020555727623:\n",
      "\tthe ball was hit in the air into foul territory\n",
      "\tthe ball was in foul territory\n",
      "dist: 214.4140154288753:\n",
      "\tthe batter hit the ball on the infield and did not reach base safely\n",
      "\tthe batter was thrown out at first base on a ground ball to the shortstop\n",
      "dist: 214.58856423095773:\n",
      "\tthe batter hit it low on the field\n",
      "\tthe batter hit the ball into the play of field\n",
      "dist: 214.7620124017213:\n",
      "\tit did not land in the field of play and is considered\n",
      "\tit did not land in the field of play\n",
      "dist: 214.92250052096014:\n",
      "\tthe hitter hit the ball high\n",
      "\tthe hitter swung hard\n",
      "dist: 214.93961714954898:\n",
      "\tthe batter made it to first\n",
      "\tthe batter made it to first base\n",
      "dist: 214.96779249020548:\n",
      "\tthe batter made contact with the ball and hit it into the air past the foul line\n",
      "\tthen the batter hit the ball beyond the foul line\n",
      "dist: 215.19612690394484:\n",
      "\tthe ball bounced a couple of times and was fielded by the second baseman\n",
      "\tthe batter hit the ball which bounced on the ground towards the second baseman\n",
      "dist: 215.32211553257625:\n",
      "\tfielder's\n",
      "\ta fielder's choice\n",
      "dist: 215.54864272720974:\n",
      "\tthe fielder caught the ball on a hop\n",
      "\tthe fielder caught the ball in the air\n",
      "dist: 215.6182168519716:\n",
      "\tthe batter took a pitch for a called ball\n",
      "\tthe batter took a called ball\n",
      "dist: 215.6182168519716:\n",
      "\tthe batter took a called ball\n",
      "\tthe batter took a pitch for a called ball\n",
      "dist: 215.71655852172904:\n",
      "\tit was fielded and thrown to first for an out\n",
      "\the threw the ball to first for the out\n",
      "dist: 216.5350868722479:\n",
      "\tthe ball was caught in the air\n",
      "\tthe ball was caught in the air by a fielder\n",
      "dist: 216.56318074797952:\n",
      "\tthe left fielder and center fielder made their way towards the ball in the air\n",
      "\tthe left fielder catches the ball in the air\n",
      "dist: 216.59192988712954:\n",
      "\t the correct answer is ground ball\n",
      "\tit is a ground ball\n",
      "dist: 216.8222936103368:\n",
      "\tthe hitter was thrown out at first\n",
      "\tthe hitter was thrown out\n",
      "dist: 216.93947778608623:\n",
      "\tan out was recorded on a infield flyball that was caught by the third baseman\n",
      "\tthe third baseball caught the ball for the out\n",
      "dist: 216.93947778608623:\n",
      "\tthe third baseball caught the ball for the out\n",
      "\tan out was recorded on a infield flyball that was caught by the third baseman\n",
      "dist: 216.9550425267799:\n",
      "\tthrew to first base to complete the double play\n",
      "\tthrew it to first base to record the out\n",
      "dist: 216.9550425267799:\n",
      "\tthrew it to first base to record the out\n",
      "\tthrew to first base to complete the double play\n",
      "dist: 217.01908853085408:\n",
      "\tthe hitter put it in play\n",
      "\tthe hitter got a piece of the ball\n",
      "dist: 217.06126228991602:\n",
      "\twho snatched the ball and threw to first base for the out\n",
      "\twho caught it and threw the batter out at first base\n",
      "dist: 217.08433383573635:\n",
      "\tthe ball was a strike over the plate\n",
      "\tthe ball was over the plate and called a strike by the umpire\n",
      "dist: 217.3594357065004:\n",
      "\tit is was over the plate and in the strike zone but was hit by the batter\n",
      "\tit went over the plate in the strike zone without the batter swinging\n",
      "dist: 217.51293593758515:\n",
      "\tthe third basemen threw him out at first base\n",
      "\tthe hitter hit the ball on the ground to the 3rd baseman who then threw the batter out at first base\n",
      "dist: 217.54277924842538:\n",
      "\tthe pitch sailed a bit on the pitcher crossing the plate well above the strike zone\n",
      "\tthe pitcher threw an offspeed pitch ball that crossed the plate in the strike zone\n",
      "dist: 217.76087726134503:\n",
      "\tthen the batter hit it above the fielders\n",
      "\tthe batter hit the ball in the air to center field\n",
      "dist: 217.8370311174795:\n",
      "\tthe first baseman fielded the grounder and threw the ball to the covering pitcher for an out at first base\n",
      "\twho fielded the ball and threw the runner out at first base\n",
      "dist: 217.8453513362209:\n",
      "\tit was not caught in the air\n",
      "\tit was not caught in mid air\n",
      "dist: 217.8453513362209:\n",
      "\tit was not caught in mid air\n",
      "\tit was not caught in the air\n",
      "dist: 218.34620726319483:\n",
      "\tthe ball was thrown too high\n",
      "\tthe ball went high\n",
      "dist: 218.35695198988748:\n",
      "\tthe batter fouled it of the end of the\n",
      "\tthe batter fouled it off of their\n",
      "dist: 218.39164860892475:\n",
      "\tthe batter hit a popup which was caught by the left fielder\n",
      "\tthe batter hit a fly ball to deep left field which was caught by the left fielder\n",
      "dist: 218.39401381085833:\n",
      "\tball went outside the 3rd base\n",
      "\tthe hitter hit a foul ball towards the 3rd base side\n",
      "dist: 218.61744324381203:\n",
      "\tthe batter took a big swing and miss which made it a\n",
      "\tthe batter swung hard and missed the ball\n",
      "dist: 218.81696277408557:\n",
      "\tthere was no swing from the batter\n",
      "\tand batter did not swing at the pitch\n",
      "dist: 219.34859605731532:\n",
      "\tthe shortstop or third baseman fielded the ball and threw the batter out at first\n",
      "\tthe batter hit the ball to the third baseman who then through the hitter out at first\n",
      "dist: 219.49937164512:\n",
      "\tthe shortstop threw the ball to the first baseman for the out\n",
      "\t2nd baseman threw to first baseman and got the hitter out\n",
      "dist: 219.60321615308845:\n",
      "\the hits the ball over the fence for a home run\n",
      "\tthe ball flew over the left field fence resulting in a home run for the batter\n",
      "dist: 219.68651922880878:\n",
      "\tthe ball flying into foul territory on the first base side of the diamond\n",
      "\tthe batter made contact grounding the ball into foul territory on the first base side of the field\n",
      "dist: 219.80189610261482:\n",
      "\tit was caught for an out\n",
      "\twho caught it for an out\n",
      "dist: 219.80189610261482:\n",
      "\twho caught it for an out\n",
      "\tit was caught for an out\n",
      "dist: 219.97635902329154:\n",
      "\tit crossed the plate below the strike zone without the batter swinging at it\n",
      "\tit crossed the plate below the strike zone for a low ball\n",
      "dist: 220.32608929782802:\n",
      "\tthe ball hit by the batter\n",
      "\tthe ball was hit on the\n",
      "dist: 220.33093490348514:\n",
      "\tthe ball was not caught by the outfielder\n",
      "\tthen the batter hit the ball and was not caught by the outfielder\n",
      "dist: 220.33093490348514:\n",
      "\tthen the batter hit the ball and was not caught by the outfielder\n",
      "\tthe ball was not caught by the outfielder\n",
      "dist: 220.46520235562568:\n",
      "\tit was hit to the 3rd base who easily throws out\n",
      "\tand the batter hit the ball down the 3rd base line\n",
      "dist: 220.4684596696454:\n",
      "\tit was taken by the batter\n",
      "\ttherefore the batter is\n",
      "dist: 220.4684596696454:\n",
      "\ttherefore the batter is\n",
      "\tit was taken by the batter\n",
      "dist: 220.60978133676605:\n",
      "\tthe ball was hit to the first baseman within the field of play\n",
      "\tthe batter hit the ball on the ground through the infield and into the outfield for a base hit\n",
      "dist: 220.7416559131662:\n",
      "\tthe hitter hit a ground ball up the middle for a base hit\n",
      "\tthe hitter hit a ground ball to the shortstop\n",
      "dist: 220.80182753064497:\n",
      "\the threw out the lead runner at 2nd base\n",
      "\tthe second baseman fielded a ground ball and threw out the batter at first\n",
      "dist: 221.0751311351915:\n",
      "\tthe ball crossed over the outside edge of the plate at the batters knees\n",
      "\tthe ball traveled over the plate and between the batters shoulders and knees\n",
      "dist: 221.0751311351915:\n",
      "\tthe ball traveled over the plate and between the batters shoulders and knees\n",
      "\tthe ball crossed over the outside edge of the plate at the batters knees\n",
      "dist: 221.12848079200472:\n",
      "\tthe shortstop caught the ball in the air\n",
      "\tshort stop caught the ball in the\n",
      "dist: 221.12848079200472:\n",
      "\tshort stop caught the ball in the\n",
      "\tthe shortstop caught the ball in the air\n",
      "dist: 221.2163254315738:\n",
      "\tthe ball to fly back into the stands in foul territory\n",
      "\tthe batted ball went into the stands in foul territory\n",
      "dist: 221.3675868561414:\n",
      "\tit hit the strike\n",
      "\tit was hit\n",
      "dist: 221.80055474896886:\n",
      "\tthe catcher caught it\n",
      "\tthe catcher caught it outside of the strike zone\n",
      "dist: 222.2678977039314:\n",
      "\tno opportunity to catch\n",
      "\tno one catches the ball\n",
      "dist: 222.2678977039314:\n",
      "\tno one catches the ball\n",
      "\tno opportunity to catch\n",
      "dist: 222.360753449465:\n",
      "\tthe hitter fouled off the pitch to the left side\n",
      "\tthe batter fouled the pitch down left field line\n",
      "dist: 222.56115133415648:\n",
      "\twho couldn't catch the ball in the air\n",
      "\twho was unable to catch the ball\n",
      "dist: 222.6360275597754:\n",
      "\the hit safely to left field\n",
      "\tthe batter lined the ball safely into left field\n",
      "dist: 222.827305467381:\n",
      "\tthe left fielder fielded the ball off the ground\n",
      "\tthe leftfielder fielded the ball\n",
      "dist: 222.827305467381:\n",
      "\tthe leftfielder fielded the ball\n",
      "\tthe left fielder fielded the ball off the ground\n",
      "dist: 223.05045116368916:\n",
      "\tit ended up in the stands for a foul ball\n",
      "\tit was ruled a foul ball\n",
      "dist: 223.08904893523055:\n",
      "\tthe batter hit the ball to the short stop within the field of play\n",
      "\tthe batter hit the ball on the ground to the short stop\n",
      "dist: 223.16827149818639:\n",
      "\tthe hitter hit it to the first baseman\n",
      "\tthe ball was hit to the first baseman within the field of play\n",
      "dist: 223.26032125666012:\n",
      "\tthese stands are in foul territory\n",
      "\tit landed in foul territory in the stands\n",
      "dist: 223.26476628793085:\n",
      "\tit was hit and caught\n",
      "\tit was hit to center and caught\n",
      "dist: 223.26476628793085:\n",
      "\tit was hit to center and caught\n",
      "\tit was hit and caught\n",
      "dist: 223.52070314590205:\n",
      "\tthe batter swung and hit the ball and completed an infield single\n",
      "\tthe batter swung his bat and hit the ball\n",
      "dist: 223.550209991764:\n",
      "\tthe ball was popped up and caught on the infield\n",
      "\tthe ball flew in the air toward the edge of the infield and was caught by the shortstop\n",
      "dist: 223.550209991764:\n",
      "\tthe ball flew in the air toward the edge of the infield and was caught by the shortstop\n",
      "\tthe ball was popped up and caught on the infield\n",
      "dist: 223.66832699727007:\n",
      "\tthe hitter swung and fouled off the pitch to the right side\n",
      "\tthe hitter fouled off the pitch to the left side\n",
      "dist: 223.88619647945526:\n",
      "\tthe batter looks at the pitch\n",
      "\tthe batter takes the pitch\n",
      "dist: 223.97410688357124:\n",
      "\tthe ball left the field of play\n",
      "\tthe ball was in the field of play\n",
      "dist: 223.98589639347716:\n",
      "\tthen the batter hit the ball into the outfield but ended up being a foul ball\n",
      "\tthen the batter hit the ball but landed in foul zone\n",
      "dist: 224.05625738187433:\n",
      "\tthe ball was too low to be a strike\n",
      "\tthe ball was below the strike\n",
      "dist: 224.13045230974882:\n",
      "\tthe player checked his swing\n",
      "\tthe batter checked his swing\n",
      "dist: 224.1390817774802:\n",
      "\tthe batter had no strikes on them\n",
      "\tthe batter didn't go for the hit\n",
      "dist: 224.20410940621443:\n",
      "\tthe ball was caught for an out before hitting the ground\n",
      "\tthe ball was hit into play and landed on the ground\n",
      "dist: 224.25020899416924:\n",
      "\tthe second baseman is going to catch a fly ball in the infield\n",
      "\tthe second baseman caught the ball and threw it to the first baseman for the out\n",
      "dist: 224.3908482612306:\n",
      "\tthe batter hit a ground ball safely into center field\n",
      "\tthe batter hits the ball which lands safely on the field\n",
      "dist: 224.78320916680883:\n",
      "\tthe ball was outside the box and did batter did not swing\n",
      "\tand batter did not swing at the pitch\n",
      "dist: 224.84234845051748:\n",
      "\tboth the left fielder and center fielder moved in to catch it\n",
      "\tthe left fielder catches the ball in the air\n",
      "dist: 225.2814539845122:\n",
      "\tit was directly in the center of the strike box\n",
      "\tthe ball was right in the center of the strike box\n",
      "dist: 225.4406594724124:\n",
      "\tthe pitch clipped the corner of the strike zone on the side of the plate opposite the batter\n",
      "\tthe pitcher threw a strike on inside corner of the plate\n",
      "dist: 225.57091620127832:\n",
      "\tit travels below the strike zone\n",
      "\tand it was below the strike zone\n",
      "dist: 225.9139155392575:\n",
      "\tthe ball went to the right of the strike zone\n",
      "\tthe ball went into the strike zone\n",
      "dist: 226.0036655843297:\n",
      "\tit landed and rolled on the ground\n",
      "\tit landed on the ground\n",
      "dist: 226.00839320076156:\n",
      "\tthe umpire did not call it a\n",
      "\tthe umpire didn't call it a strike\n",
      "dist: 226.07855146411663:\n",
      "\tthe left fielder caught the ball in foul ground which is still an out\n",
      "\tthe left fielder caught the ball in the air for an out\n",
      "dist: 226.2533584126059:\n",
      "\tand it was ruled outside the strike zone per the umpire too high\n",
      "\tit was outside the strike zone per the umpire\n",
      "dist: 226.2533584126059:\n",
      "\tit was outside the strike zone per the umpire\n",
      "\tand it was ruled outside the strike zone per the umpire too high\n",
      "dist: 226.43536790113941:\n",
      "\tthe hitter hit a line drive in the air to the shortstop\n",
      "\tthe hitter hit a ground ball to the shortstop\n",
      "dist: 227.2422995014342:\n",
      "\tthen the batter swung made contact and sent the ball straight down and into the dirt behind the plate\n",
      "\tthe batter made contact and smashed the ball through the left side of the infield for a\n",
      "dist: 227.45489264770262:\n",
      "\tit was fielded by the second baseman\n",
      "\tthe ball bounced a couple of times and was fielded by the second baseman\n",
      "dist: 227.50959087275174:\n",
      "\tthe batter hit the ball inside the bounds of the\n",
      "\tthe batter hit the ball inside the field with the\n",
      "dist: 227.73252573319698:\n",
      "\tit reached the hitter\n",
      "\the hit a\n",
      "dist: 227.83359561847723:\n",
      "\tthe batter took an inside pitch for a called ball\n",
      "\tthe batter took a pitch for a called ball\n",
      "dist: 228.01497268195348:\n",
      "\tit landed for a base hit\n",
      "\tit counts as a base hit\n",
      "dist: 228.01497268195348:\n",
      "\tit counts as a base hit\n",
      "\tit landed for a base hit\n",
      "dist: 228.10404840763587:\n",
      "\tbatter hit a shallow fly ball just behind second base\n",
      "\tthe batter hit a ground ball between first and second base\n",
      "dist: 228.25366465654153:\n",
      "\tthe ball did not appear to be in the strike zone from the angle\n",
      "\tthe ball wasn't in the strike zone\n",
      "dist: 228.28075694838395:\n",
      "\tthe runner going to second base instead of getting the batter out\n",
      "\tanother out double play on the batter running to first base\n",
      "dist: 228.3267517980558:\n",
      "\tthe batter swing and the ball went to the shortstop after taking several bounces off the ground\n",
      "\tthe batter made contact and hit the ball towards the shortstop\n",
      "dist: 228.35199677108832:\n",
      "\ta fly ball hit deep to the outfield\n",
      "\tthe ball was hit over the outfield wall on the fly in fair territory\n",
      "dist: 228.4633469805842:\n",
      "\tthe batter took a pitch in the strike zone for a called strike\n",
      "\tthe batter hit the pitch\n",
      "dist: 228.52767813356846:\n",
      "\tthe batter hit the ball outside of the field of play for a foul ball\n",
      "\tthen the batter hit the ball in the air in foul territory\n",
      "dist: 228.6886483514837:\n",
      "\tthe ball was not caught by a defender\n",
      "\tthe outfielder wasn't able to catch the ball\n",
      "dist: 228.83500646463568:\n",
      "\tthe batter popped it up to right field\n",
      "\tthe batter hit it towards right field\n",
      "dist: 229.24536647218596:\n",
      "\tthen the batter swung made contact and hit the ball behind him into the netting\n",
      "\tthen the batter swung and hit the ball behind him and into the stands\n",
      "dist: 229.25157341787332:\n",
      "\tthe batter hit the ball in the air which was caught by a\n",
      "\tthe batter hit a fly ball to left that was caught\n",
      "dist: 229.2600097063833:\n",
      "\tit was caught by shortstop for an out\n",
      "\tthe ball flew in the air toward the edge of the infield and was caught by the shortstop\n",
      "dist: 229.31238655147814:\n",
      "\tthe strike had to be called by the umpire\n",
      "\tit was a called strike by the umpire\n",
      "dist: 230.02902026741555:\n",
      "\the did not make contact with the ball\n",
      "\tthe ball was not caught in the air\n",
      "dist: 230.0758356693978:\n",
      "\tthe ball went over the wall for a home run\n",
      "\the hits the ball over the fence for a home run\n",
      "dist: 230.16055745396574:\n",
      "\ta batted ball settled on foul\n",
      "\ta batted ball fell over foul\n",
      "dist: 230.16055745396574:\n",
      "\ta batted ball fell over foul\n",
      "\ta batted ball settled on foul\n",
      "dist: 230.1723452477209:\n",
      "\tit was outside the striking box\n",
      "\tthe ball was outside the strike box\n",
      "dist: 230.26759443348598:\n",
      "\tbatter struck out\n",
      "\tthe batter struck the ball\n",
      "dist: 230.48519764052327:\n",
      "\tit was not in the strike zone\n",
      "\tthe ball was not in the strike zone\n",
      "dist: 230.62193288916714:\n",
      "\tthe pitch was outside the strikezone low\n",
      "\tthe pitch was outside the strike zone\n",
      "dist: 230.7187684365483:\n",
      "\tthe batter took the pitch which was low and inside of the strikezone thus a called ball\n",
      "\tthe batter took a pitch in the strike zone for a called strike\n",
      "dist: 231.05520101367367:\n",
      "\tthe hitter reached the base\n",
      "\tit reached the hitter\n",
      "dist: 231.21811889138118:\n",
      "\tand the batter made contact\n",
      "\ttherefore the batter is\n",
      "dist: 231.22484338837896:\n",
      "\tstriker hit the ball which landed outside the foul line\n",
      "\tthe striker hit the ball in fair play\n",
      "dist: 231.30486351358522:\n",
      "\tthe pitch was outside\n",
      "\tthe pitch was outside the strike zone\n",
      "dist: 231.33216520539924:\n",
      "\tthe defensive center outfielder caught it in the air\n",
      "\tthen it was caught in mid air by the outfielder\n",
      "dist: 231.5037672107927:\n",
      "\tthe ball was caught by the out\n",
      "\tthe ball was caught in the air\n",
      "dist: 231.55260887018727:\n",
      "\tthe pitch crossed the plate high\n",
      "\tthe pitch crossed the plate over the top of the strike zone\n",
      "dist: 231.64486256401784:\n",
      "\tthe ball was fouled straight back\n",
      "\tthen the ball was fouled off to the right side\n",
      "dist: 231.78986406868282:\n",
      "\tthe pitch was thrown\n",
      "\tthe pitch was a ball\n",
      "dist: 231.81937056772514:\n",
      "\tthe batter smoked the hit past the centerfielder for a hit\n",
      "\tthe batter hit the ball in the air to the centerfielder\n",
      "dist: 231.8974256341455:\n",
      "\tthe center fielder fielded the ball and threw it back into the infield area\n",
      "\tthe center fielder caught the ball for an out\n",
      "dist: 232.01072314887935:\n",
      "\tthe hitter ran to first base\n",
      "\tthe hitter hit it to the first baseman\n",
      "dist: 232.03163209463932:\n",
      "\tthe ball was caught in the air after being hit\n",
      "\tthe ball was caught in the air\n",
      "dist: 232.16251210922115:\n",
      "\tthe batter swung and missed at a high ball almost chesthigh\n",
      "\tthen the batter swung hard and missed\n",
      "dist: 232.17577681214522:\n",
      "\tthe batter checked his swing at a pitch outsside the zone\n",
      "\tthe batter checked his swing\n",
      "dist: 232.28144589709615:\n",
      "\tthen the batter grounded the ball up the middle\n",
      "\tthe batter hit it up the middle\n",
      "dist: 232.48485514124246:\n",
      "\tit crossed into foul territory before landing\n",
      "\tit landed in foul territory\n",
      "dist: 232.54579762050622:\n",
      "\twho made it to first base but caused a focreout at second base\n",
      "\twho threw the ball to second base for a force out\n",
      "dist: 232.62469556486673:\n",
      "\tthrew the ball to the first baseman to complete the out\n",
      "\tthrows to the first baseman to get the batter out\n",
      "dist: 233.00209243818867:\n",
      "\the grounded out to the pitcher\n",
      "\tthe batter hit the ball on the ground back to the pitcher\n",
      "dist: 233.06337268435092:\n",
      "\tthe batter did not hit the ball in fair play\n",
      "\tthe batter swung at the pitch but did not hit it\n",
      "dist: 233.07310146764127:\n",
      "\tthe ball crossed the plate on the inner part of the plate resulting in a strike\n",
      "\tthe ball crossed the plate in the strike zone\n",
      "dist: 233.11923197712082:\n",
      "\tin addition the batter did not swing\n",
      "\tthe ball was outside the box and did batter did not swing\n",
      "dist: 233.4032377749673:\n",
      "\tit was thrown down and away outside of the strike zone resulting in a ball\n",
      "\tthe ball was thrown outside of the strike zone\n",
      "dist: 233.45992032383134:\n",
      "\tthe batter was unable to check his swing and called out on\n",
      "\tthe batter took a swing yet failed to make contact\n",
      "dist: 233.6262956871935:\n",
      "\tthe batter hit the ball deep and to the fence\n",
      "\tthe batter drove the ball over the fence in right field for a home run\n",
      "dist: 233.63548407431432:\n",
      "\tit went off the outfield wall in play\n",
      "\tthis ball was hit into the outfield\n",
      "dist: 233.6410111424219:\n",
      "\tit hit the ground before being fielded\n",
      "\tit hit the ground before being picked up by the outfielder\n",
      "dist: 233.6410111424219:\n",
      "\tit hit the ground before being picked up by the outfielder\n",
      "\tit hit the ground before being fielded\n",
      "dist: 233.69928485354725:\n",
      "\tit missed going through the strike zone\n",
      "\tthe pitch missed going through the strike zone\n",
      "dist: 233.97083713154936:\n",
      "\tthe hitter hit the ball in foul territory on the right field side\n",
      "\tthe hitter hit the ball in the air to right field\n",
      "dist: 234.02520229389413:\n",
      "\tthe pitch is located\n",
      "\tthe pitch was outside\n",
      "dist: 234.49720360567068:\n",
      "\tit was a foul that was counted as a strike\n",
      "\tit counts as a foul ball and also a strike\n",
      "dist: 234.49720360567068:\n",
      "\tit counts as a foul ball and also a strike\n",
      "\tit was a foul that was counted as a strike\n",
      "dist: 234.69977329735326:\n",
      "\tthe pitcher through the ball outside and high therefore it was a ball\n",
      "\tthe pitcher threw the ball low over the plate\n",
      "dist: 234.75476004260332:\n",
      "\tthe ball was hit over the wall\n",
      "\tthe ball went over the wall for a home run\n",
      "dist: 234.76240764872142:\n",
      "\tthe catcher was still able to catch the ball\n",
      "\tthe catcher caught it\n",
      "dist: 235.00968956852654:\n",
      "\tthe batter grounded out to\n",
      "\tthe batter hit it into play on the ground\n",
      "dist: 235.0111888541313:\n",
      "\tthe ball was far outside\n",
      "\tthe ball was far outside the strike zone\n",
      "dist: 235.29152423359446:\n",
      "\tthe pitch was outside of home plate\n",
      "\tthe pitch was outside the strike zone\n",
      "dist: 235.30681963749436:\n",
      "\tthe batter reached base well before the throw classified as an infield single\n",
      "\tthen the batter hit the ball into play and safely reached base\n",
      "dist: 235.31097144269287:\n",
      "\tthe ball was inside the strike\n",
      "\tthe batter hit the ball inside the bounds of the\n",
      "dist: 235.3367201810898:\n",
      "\tthe hitter ended up on second base\n",
      "\tit was hit on the ground to the second baseman\n",
      "dist: 235.3383259231334:\n",
      "\tit went over the plate above the shoulders of the\n",
      "\tthen it was over the plate\n",
      "dist: 235.3383259231334:\n",
      "\tthen it was over the plate\n",
      "\tit went over the plate above the shoulders of the\n",
      "dist: 235.393063968214:\n",
      "\tit counts as a strike\n",
      "\tit is a called strike\n",
      "dist: 235.5033340094406:\n",
      "\thit a pop fly ball to shallow leftcenter field\n",
      "\tthe batter hit a fly ball to deep left field which was caught by the left fielder\n",
      "dist: 236.0968926664784:\n",
      "\tthe batter hit it outside the area\n",
      "\tthe batter hit it low on the field\n",
      "dist: 236.14083796269466:\n",
      "\tthe batter hit it backwards and to the right\n",
      "\tthe batter hits the ball backwards for a\n",
      "dist: 236.3995449305067:\n",
      "\tthe batter hit it on the ground to the 1st\n",
      "\tthen the batter hit it on the ground\n",
      "dist: 236.81093216779033:\n",
      "\the hit a ground ball to short stop and was thrown out at\n",
      "\tit was a ground ball and thrown out at\n",
      "dist: 236.81093216779033:\n",
      "\tit was a ground ball and thrown out at\n",
      "\the hit a ground ball to short stop and was thrown out at\n",
      "dist: 236.81651741407663:\n",
      "\tit was hit into the air and caught by a player in short left field by an\n",
      "\tit was caught in the air by the left fielder\n",
      "dist: 236.87399034383913:\n",
      "\tthe third baseman grabbed it and threw him out\n",
      "\tthe third baseman caught it off the ground and threw to\n",
      "dist: 236.9575971270817:\n",
      "\tthe 1st baseman caught it on the hop and touched\n",
      "\tit was caught by the first basemen\n",
      "dist: 237.10827374410817:\n",
      "\tthe unpire called it a ball\n",
      "\tthe umpire called it a ball\n",
      "dist: 237.31351716107662:\n",
      "\tit was determined to be a ball by the umpire\n",
      "\tit was ruled a ball by the ump\n",
      "dist: 237.51401886275477:\n",
      "\tthe batter did swing at a called strike\n",
      "\tthe batter did swing at a pitch inside the strike zone\n",
      "dist: 237.82570839162423:\n",
      "\tthe ball landed on the ground before reaching the defender\n",
      "\tthe ball landed on the ground before reaching the outfield\n",
      "dist: 237.9408275491033:\n",
      "\ta batted ball caught by a left\n",
      "\tbatter hit a fly ball to left field which was caught by the left\n",
      "dist: 238.0929842661272:\n",
      "\tit was caught mid air by a defender\n",
      "\ta defender caught the ball in mid air\n",
      "dist: 238.0929842661272:\n",
      "\ta defender caught the ball in mid air\n",
      "\tit was caught mid air by a defender\n",
      "dist: 238.6583076546513:\n",
      "\tit passed home plate to the right of the strike zone\n",
      "\tit crossed the home plate area to the left of the strike zone\n",
      "dist: 238.98984669484986:\n",
      "\tit was far outside the strike\n",
      "\tit was way outside of the strike zone\n",
      "dist: 239.57575289196308:\n",
      "\the threw it to first base but not in time\n",
      "\tthe man on plate hit the ball on the ground and was thrown out at first base\n",
      "dist: 239.60602482811288:\n",
      "\tit was below the strike\n",
      "\tit fell below the strike zone\n",
      "dist: 239.73193994768286:\n",
      "\tit was above the knees and inside the left edge of the plate called a strike\n",
      "\tthe ball crossed over the outside edge of the plate at the batters knees\n",
      "dist: 239.73986942118705:\n",
      "\tthen the batter popped it up\n",
      "\tthe batter hit a pop up\n",
      "dist: 239.73986942118705:\n",
      "\tthe batter hit a pop up\n",
      "\tthen the batter popped it up\n",
      "dist: 239.85322571559195:\n",
      "\tthe batter hit the ball away from any fielder\n",
      "\tthen the batter hit the ball and was not caught by the outfielder\n",
      "dist: 240.15626209213139:\n",
      "\tit went the foul side of the foul posts\n",
      "\tit went foul\n",
      "dist: 240.17109900055135:\n",
      "\tthe ball grounded weakly to second base\n",
      "\tit was hit on the ground to the second baseman\n",
      "dist: 240.22316031277575:\n",
      "\tthe batter leaves the ball which travels in the strike zone\n",
      "\tthe batter swung at a pitch outside the strike\n",
      "dist: 240.37815089414568:\n",
      "\tit did not go into play\n",
      "\tbut it did not go into the field of play\n",
      "dist: 240.4809087694876:\n",
      "\twho fielded it and tried to throw him out at 1st\n",
      "\tthe fielder fielded it and threw him out\n",
      "dist: 240.4809087694876:\n",
      "\tthe fielder fielded it and threw him out\n",
      "\twho fielded it and tried to throw him out at 1st\n",
      "dist: 240.68711329514832:\n",
      "\tthe pitch was very low and inside\n",
      "\tthe pitch was low\n",
      "dist: 240.8793732281185:\n",
      "\twho collected it and threw to second base\n",
      "\tit was popped up and caught by the second baseman\n",
      "dist: 240.92271619704758:\n",
      "\tthe third baseman caught a line drive\n",
      "\tthird baseman caught the ball\n",
      "dist: 240.96434419196072:\n",
      "\tthe batter hit the ball at an angle that caused the ball to immediately leave the field of play\n",
      "\tthen the batter hit the ball out side the field of play\n",
      "dist: 241.0020412971015:\n",
      "\tthe ball was within the strike box\n",
      "\tthe ball was in the center of the strike box\n",
      "dist: 241.01780814277558:\n",
      "\tthe pitch landed low and outside the strike zone\n",
      "\tthe pitch was outside the strikezone low\n",
      "dist: 241.14424003579103:\n",
      "\tthe pitch was over the plate but low missing the strike zone\n",
      "\tthe pitch missed the strike zone\n",
      "dist: 241.48662545795293:\n",
      "\twho caught the ball on a fly for an out\n",
      "\twho caught the ball for the out\n",
      "dist: 241.5009604074386:\n",
      "\tthe batter decided not to swing\n",
      "\tthe batter didn't swing\n",
      "dist: 241.5768378945059:\n",
      "\tthe batter made contact with the ball and kept it in the field of play\n",
      "\tthe batter made contact with the ball and kept it in the infield\n",
      "dist: 241.5768378945059:\n",
      "\tthe batter made contact with the ball and kept it in the infield\n",
      "\tthe batter made contact with the ball and kept it in the field of play\n",
      "dist: 241.60458491170635:\n",
      "\tbatter hit pitched ball safely for a single\n",
      "\tthe batter hits the ball which lands safely on the field\n",
      "dist: 241.64909159573932:\n",
      "\tthe ball went down and to the left of the strike zone\n",
      "\tthe ball went low and left missing the strike zone\n",
      "dist: 241.64909159573932:\n",
      "\tthe ball went low and left missing the strike zone\n",
      "\tthe ball went down and to the left of the strike zone\n",
      "dist: 241.70140582510723:\n",
      "\tthe shortstop caught it and threw to second for an out\n",
      "\tthe shortstop caught the ball in the air\n",
      "dist: 242.40008418199346:\n",
      "\tthe batter hit the ball on the ground and started running to the\n",
      "\tthe batter swung and hit the ball on the ground towards the\n",
      "dist: 242.60913011807392:\n",
      "\tthe batter did not take a full swing\n",
      "\tthen the batter did not swing\n",
      "dist: 242.6376478394223:\n",
      "\tit was thrown high and away resulting in a called ball\n",
      "\tthe ball went way outside and was called a ball\n",
      "dist: 242.6376478394223:\n",
      "\tthe ball went way outside and was called a ball\n",
      "\tit was thrown high and away resulting in a called ball\n",
      "dist: 242.67146784280982:\n",
      "\twho caught it in the air\n",
      "\twho caught it in the air for an out\n",
      "dist: 242.94872783651155:\n",
      "\tit was ball 3\n",
      "\tit was the 3rd strike\n",
      "dist: 242.97900691245655:\n",
      "\tit bounced to the shortstop\n",
      "\tit reached the shortstop\n",
      "dist: 242.97900691245655:\n",
      "\tit reached the shortstop\n",
      "\tit bounced to the shortstop\n",
      "dist: 243.17301604292794:\n",
      "\tit fell in the floor\n",
      "\tit falling to the ground\n",
      "dist: 243.2725010192508:\n",
      "\tthe runner reached first base safely\n",
      "\tthe runner made it to the base\n",
      "dist: 243.2725010192508:\n",
      "\tthe runner made it to the base\n",
      "\tthe runner reached first base safely\n",
      "dist: 243.3456311954206:\n",
      "\tthe ball bounced on home plate missing the strike zone\n",
      "\tthe ball crossed the home plate area outside of the strike zone high\n",
      "dist: 243.36477464840488:\n",
      "\twent into foul territory making it a foul ball\n",
      "\tso it is a foul ball\n",
      "dist: 243.89677789110542:\n",
      "\thowever the ball did not land in the field of play and is considered\n",
      "\tthe ball did not land in the field of play\n",
      "dist: 243.92141671113424:\n",
      "\tit went to the middle right of the strike zone\n",
      "\tthe ball went to the right of the strike zone\n",
      "dist: 243.96034174175222:\n",
      "\tthe ball was pitched\n",
      "\tthe pitch was a ball\n",
      "dist: 244.48474573537084:\n",
      "\tthe ball was well outside the strike zone and hit the backstop behind the plate\n",
      "\tthe ball crossed the home plate area outside of the strike zone high and outside\n",
      "dist: 244.55140999682007:\n",
      "\tit was way high and outside the strike zone\n",
      "\tit was above the strike zone\n",
      "dist: 244.66844612402116:\n",
      "\ta fielder on the infield grass caught the ball\n",
      "\ta fielder caught the ball in the air\n",
      "dist: 244.87771478052224:\n",
      "\tthe umpire called it a ball instead of a strike\n",
      "\tumpire called a ball\n",
      "dist: 244.95179884688625:\n",
      "\tthen the ball is hit backwards\n",
      "\tthe ball was hit on the\n",
      "dist: 245.50424965833287:\n",
      "\tit hit the outside corner of the strike zone\n",
      "\tthe ball landed on edge of the strike zone\n",
      "dist: 245.92576702233697:\n",
      "\tthe ball got past the 2nd basemen\n",
      "\t2nd baseman threw to first baseman and got the hitter out\n",
      "dist: 245.98992345621724:\n",
      "\tthe batter takes it in the strike zone\n",
      "\tthe batter took a swing at the pitch\n",
      "dist: 246.33409095097073:\n",
      "\tran in from outfield to catch it\n",
      "\tthe right fielder caught the ball in the outfield\n",
      "dist: 246.42403706746614:\n",
      "\tthe ball went out to center field for a home run which makes it a\n",
      "\tthe ball went over the wall for a home run\n",
      "dist: 246.5123268279087:\n",
      "\tthe short stop caught after bouncing on the ground\n",
      "\tshort stop caught the ball in the\n",
      "dist: 246.78368952784427:\n",
      "\tit bounced backwards off the bat to the net behind home\n",
      "\tthen the batter swung made contact and hit the ball behind him into the netting\n",
      "dist: 246.8365603225821:\n",
      "\tthe pitch was low and inside for a ball\n",
      "\tthe pitch was a ball\n",
      "dist: 246.85532681892715:\n",
      "\tthe batter hit the ball straight back to the back stop for a foul ball\n",
      "\tthe batter hits the ball behind the foul line\n",
      "dist: 246.85733121127038:\n",
      "\twho flipped to the pitcher for the out\n",
      "\tmade contact hitting the ball back to the pitcher\n",
      "dist: 246.8714754965468:\n",
      "\tthe ball went down and bounced backwards behind the catcher making it a foul ball\n",
      "\tthe batter hit it foul territory behind the catcher\n",
      "dist: 247.07501267087494:\n",
      "\tthe player didn't swing\n",
      "\tthe hitter didn't swing\n",
      "dist: 247.1143702572436:\n",
      "\tthe batter hit the ball over the wall in fair territory which counts as a home run\n",
      "\tthe batter hit the ball over the outfield wall for a home run\n",
      "dist: 247.2809067487388:\n",
      "\tthe hitter hit the ball and reached second base without being thrown out\n",
      "\tthen the batter hit the ball into play and safely reached base\n",
      "dist: 247.29066299843458:\n",
      "\tthe hitter popped the ball up behind home plate which was caught\n",
      "\tthe hitter hit a fly ball which was caught by an outfielder\n",
      "dist: 247.47416921910119:\n",
      "\tit crossed the plate\n",
      "\tit went right across the plate\n",
      "dist: 247.47416921910119:\n",
      "\tit went right across the plate\n",
      "\tit crossed the plate\n",
      "dist: 247.55397519987952:\n",
      "\tthat ball hit into the air\n",
      "\tthe ball was caught in the air after being hit\n",
      "dist: 247.66988493555897:\n",
      "\tit was a swing and a miss at the pitch\n",
      "\tthe hitter swung at the pitch and missed the\n",
      "dist: 247.9613123893351:\n",
      "\tthe infielder could not make a play\n",
      "\tthe fielder was unable to catch the ball in the air\n",
      "dist: 248.12639268226448:\n",
      "\tthe umpire deemed to not be in the area that would be considered a strike\n",
      "\tthe umpire did not signal for a strike\n",
      "dist: 248.14408664017432:\n",
      "\tit landed on the ground before reaching the pitcher\n",
      "\the grounded out to the pitcher\n",
      "dist: 248.65276770079714:\n",
      "\tthe batter bunted the ball and was thrown out at first\n",
      "\tbatter hit the ball low and ran to first base\n",
      "dist: 249.44125540104784:\n",
      "\tthe hitter hit the ball which sailed in the back of home plate into the crowd\n",
      "\tthe ball was tipped by the batter and landed in the crowd behind the plate\n",
      "dist: 249.44125540104784:\n",
      "\tthe ball was tipped by the batter and landed in the crowd behind the plate\n",
      "\tthe hitter hit the ball which sailed in the back of home plate into the crowd\n",
      "dist: 249.53643125378684:\n",
      "\ttherefore it was considered a strike\n",
      "\ttherefore it is a strike\n",
      "dist: 249.55900833937545:\n",
      "\tthe pitch was below the bottom of the strike zone\n",
      "\tthe pitch was low\n",
      "dist: 249.8765647685352:\n",
      "\twho caught it and threw the runner out\n",
      "\twho caught the ball for the out\n",
      "dist: 249.90711755253832:\n",
      "\tit was higher then the strike zone\n",
      "\tit was above the strike zone\n",
      "dist: 250.03052881942045:\n",
      "\tthe pitch was outside the string zone\n",
      "\tthe pitch was outside\n",
      "dist: 250.16535937262162:\n",
      "\tthe bat crossed the plate\n",
      "\tbatter swung past the plate\n",
      "dist: 250.195457687735:\n",
      "\the went to second base\n",
      "\tit was fielded by the second baseman\n",
      "dist: 250.50986604201813:\n",
      "\tthe umpire ruled the pitch a strike all the same\n",
      "\tthe umpire ruled the pitch a strike\n",
      "dist: 250.54793987466948:\n",
      "\tthe pitch is a 93 mile per hour fastball over the plate at the top of the strike zone\n",
      "\tit was a 96 miles per hour fastball at the top of the strike zone\n",
      "dist: 250.54793987466948:\n",
      "\tit was a 96 miles per hour fastball at the top of the strike zone\n",
      "\tthe pitch is a 93 mile per hour fastball over the plate at the top of the strike zone\n",
      "dist: 250.89176147968016:\n",
      "\tthe batter made contact but hit it into the stands in left\n",
      "\tthen the batter hit the ball behind him into the stands\n",
      "dist: 250.9704978646251:\n",
      "\tstepped on second base to force the runner out\n",
      "\tthe ball hit the ground before being fielded for a forced out at second base\n",
      "dist: 251.02661470927234:\n",
      "\tno one caught it\n",
      "\tit was not caught\n",
      "dist: 251.03208645676133:\n",
      "\tthe fielder's glove\n",
      "\tthe fielder caught it with his glove\n",
      "dist: 251.03208645676133:\n",
      "\tthe fielder caught it with his glove\n",
      "\tthe fielder's glove\n",
      "dist: 251.19260539290468:\n",
      "\tthe pitch was the third strike\n",
      "\tit was the third strike\n",
      "dist: 251.2659676753529:\n",
      "\tit was catch in the\n",
      "\tthe player caught it\n",
      "dist: 251.3221192575266:\n",
      "\twho caught it\n",
      "\twho caught it in the air\n",
      "dist: 251.40848870889678:\n",
      "\tthe pitch is a 95 mile per hour fastball\n",
      "\tit was a 96 miles per hour fastball at the top of the strike zone\n",
      "dist: 251.417211498555:\n",
      "\tthe pitch was called a ball landing low and outside off the plate\n",
      "\tthe pitch was outside of home plate\n",
      "dist: 251.57306663582773:\n",
      "\tthe batter hit a pop\n",
      "\tthe batter hit a pop up\n",
      "dist: 251.69625328092576:\n",
      "\tit went over the home run fence\n",
      "\tthe hit was a home run and went over the outfield fence\n",
      "dist: 251.9344742290394:\n",
      "\tthe batter singled to left\n",
      "\tthe batter's bat\n",
      "dist: 251.942225302045:\n",
      "\tthrew the ball to the catcher to record an out\n",
      "\tit was caught by the catcher in the strike zone\n",
      "dist: 252.0390490834827:\n",
      "\tthe hitter fouled it on the ground on the right side\n",
      "\tthen the hitter fouled it off\n",
      "dist: 252.10626073922236:\n",
      "\thowever the ball was hit foul outside of the line of play\n",
      "\tball landed outside the foul\n",
      "dist: 252.13686618518756:\n",
      "\tthe batter hit the ball up high for the pop up catch for the out\n",
      "\tthe batter hit a pop up to the first baseman\n",
      "dist: 252.73727167300154:\n",
      "\tthe ball is an offspeed pitch that misses the strike zone\n",
      "\tthe pitcher threw an offspeed pitch ball that crossed the plate in the strike zone\n",
      "dist: 252.75990535779155:\n",
      "\ta batted ball bounced on and caught in fair\n",
      "\tthe batter hit the ball in the air which was caught by a\n",
      "dist: 253.20040182686267:\n",
      "\tpicture threw the ball in on the hitter\n",
      "\tthe pitcher threw the ball high to the batter\n",
      "dist: 253.5979671172383:\n",
      "\tit was caught by the pitcher\n",
      "\tthe pitch was caught by the catcher\n",
      "dist: 253.60297203822378:\n",
      "\ttherefore the ball was hit foul and not fair\n",
      "\tit did was not a fair ball\n",
      "dist: 253.60297203822378:\n",
      "\tit did was not a fair ball\n",
      "\ttherefore the ball was hit foul and not fair\n",
      "dist: 253.64441328105679:\n",
      "\tthe ball went low and into the dirt\n",
      "\tthe ball was hit into play and landed on the ground\n",
      "dist: 253.86364912676714:\n",
      "\tthe batter swung at the pitch grounding the ball to the second baseman astro's jose altuve\n",
      "\tball was hit on the ground to 2nd baseman altuve\n",
      "dist: 253.93195289414072:\n",
      "\tthe batter made weak contact which resulted in an infield pop\n",
      "\tthe batter made contact with the pitch and hit it on the ground to the shortstop\n",
      "dist: 254.01041592088663:\n",
      "\tit dropped in for a hit\n",
      "\tit was a hit\n",
      "dist: 254.44829773418243:\n",
      "\tthe batter hit the ball which was picked up by a\n",
      "\tthe batter hit the ball in the air which was caught by a\n",
      "dist: 254.69230874584863:\n",
      "\tit was caught in the air otherwise known as a catch\n",
      "\tit was caught in the air\n",
      "dist: 254.69311479346567:\n",
      "\tthe player made connection with the ball towards the 3 rd baseman\n",
      "\tthe ball was hit to the third baseman\n",
      "dist: 254.7099979223413:\n",
      "\tit landed beyond the foul line\n",
      "\tthe ball was way past the foul line foul\n",
      "dist: 255.05465642023688:\n",
      "\tit was grounded through the hole at second base\n",
      "\tit was hit on the ground to the second baseman\n",
      "dist: 255.14740448811705:\n",
      "\tthe batter hit a pop up that was caught in foul territory\n",
      "\tthe batter hit the ball into the air in foul territory\n",
      "dist: 255.22216934576792:\n",
      "\tthe hitter pulled the hit outsideto the right of the fair line down the first base side\n",
      "\tthe hitter hit a line drive in the air to the shortstop\n",
      "dist: 255.7163763854906:\n",
      "\tthe keeper caught the ball\n",
      "\tthe fielder caught the ball\n",
      "dist: 255.7495604832388:\n",
      "\tthe batter's feet\n",
      "\tthe batter's knees\n",
      "dist: 256.02942982542953:\n",
      "\tand it was grounded to third\n",
      "\tit was ball 3\n",
      "dist: 256.10688560461784:\n",
      "\tthe ball was hit by the batter toward thirdshort with no play for the out\n",
      "\tthe batter swung at the pitch made contact with the ball and hit it into foul territory on the third base side of the field\n",
      "dist: 256.2050287540324:\n",
      "\tthere were less then 2 strikes\n",
      "\tthe count was 02 no balls and 2 strikes\n",
      "dist: 256.63032595829543:\n",
      "\tit was high and outside\n",
      "\tit went high\n",
      "dist: 256.89057279816257:\n",
      "\tthe umpire caught the ball\n",
      "\tthe umpire ruled it a ball\n",
      "dist: 256.9949882151114:\n",
      "\tit bounced off the wall for a hit\n",
      "\tthe ball was hit over the wall\n",
      "dist: 257.145657141885:\n",
      "\tthe ball was thrown too low\n",
      "\tthe ball went low\n",
      "dist: 257.19472963271545:\n",
      "\the could catch it\n",
      "\ta field could catch it\n",
      "dist: 257.2995099549435:\n",
      "\tthe ball was high and not swung at\n",
      "\tand batter did not swing at the pitch\n",
      "dist: 257.3775855939594:\n",
      "\tthen he swung and hit to right field and got on first\n",
      "\tthe batter swung and hit the ball into right field\n",
      "dist: 257.81169731750475:\n",
      "\tthe batter fouled it off hard and to the right\n",
      "\tthen the batter hit the ball fouling it\n",
      "dist: 258.0325506594134:\n",
      "\tthe ball was hit and landed in the fair zone before being caught\n",
      "\tthe ball landed in fair play\n",
      "dist: 258.0325506594134:\n",
      "\tthe ball landed in fair play\n",
      "\tthe ball was hit and landed in the fair zone before being caught\n",
      "dist: 258.1575110676486:\n",
      "\tthe batter popped up to second\n",
      "\tthen the batter popped it up\n",
      "dist: 258.275321419059:\n",
      "\tany defensive player could catch it\n",
      "\tthe player caught it\n",
      "dist: 258.2832055769896:\n",
      "\tthe batter hit a pop fly that was caught by an\n",
      "\tthe batter hit a fly ball to left that was caught\n",
      "dist: 258.3348834851051:\n",
      "\tthe batter hit it to deep center\n",
      "\tthe batter hit a home\n",
      "dist: 258.65762891767287:\n",
      "\tit was a double play which resulted in two outs\n",
      "\tand the batter grounded to the short stop who then turned the double play for 2 outs\n",
      "dist: 259.33974559901907:\n",
      "\tthe batter could make it there\n",
      "\tthe batter managed to make contact with the\n",
      "dist: 259.76697174443603:\n",
      "\tbatter hit a line drive that was caught for the out\n",
      "\tthe batter hit a line drive to the left\n",
      "dist: 259.969576146761:\n",
      "\tthe umpire called the pitch a ball for being too high\n",
      "\tthe umpire called the pitch a ball\n",
      "dist: 260.117173029531:\n",
      "\tthe runner made it to second base without being tagged or forced out\n",
      "\tthe runner made it to the base\n",
      "dist: 260.1269856141726:\n",
      "\tthe ball clears the fence giving aaron judge a home run\n",
      "\the hits the ball over the fence for a home run\n",
      "dist: 260.1774701770183:\n",
      "\tthe batter hit the ball into right field and got on\n",
      "\tthen he swung and hit to right field and got on first\n",
      "dist: 260.2324571221407:\n",
      "\tit went into the lower left part of the strike zone\n",
      "\tit was low and outside of the strike zone\n",
      "dist: 260.39634478108115:\n",
      "\tthen the pitch was not in the strike zone making it a ball\n",
      "\tthe ball wasn't in the strike zone\n",
      "dist: 260.41603373510503:\n",
      "\tthe batter hit a foul ball down right field side of the stadium\n",
      "\tthe batter hit a foul down the right field line\n",
      "dist: 261.6129727435901:\n",
      "\tthey threw it to second and got the runner out\n",
      "\tthe second baseman fielded the ball and threw the runner out at\n",
      "dist: 261.90556414048393:\n",
      "\tit passed first base in foul territory\n",
      "\tthe ball flying into foul territory on the first base side of the diamond\n",
      "dist: 262.0023184063022:\n",
      "\tthe ball was to the side of the strike zone counting as a ball\n",
      "\tball was thrown in the strike zone\n",
      "dist: 262.011392569998:\n",
      "\tthe ball was directly above home plate\n",
      "\tthe ball went right over the plate\n",
      "dist: 262.1082907882074:\n",
      "\tit is also an out\n",
      "\tit was an out\n",
      "dist: 262.41335873219856:\n",
      "\the reached base after the\n",
      "\tthe runner made it to the base\n",
      "dist: 262.5752598938116:\n",
      "\tit was right down the middle of the plate\n",
      "\tthe ball was right down the middle over the plate in the strike zone\n",
      "dist: 262.7557436336494:\n",
      "\tthe batter made contat with the pitch\n",
      "\tthe batter hit the pitch\n",
      "dist: 262.7674825093264:\n",
      "\tit bounced off the wall\n",
      "\tit bounced off the wall for a hit\n",
      "dist: 263.2853374844516:\n",
      "\tit counts as a homerun\n",
      "\tit was a home run\n",
      "dist: 263.3998703535463:\n",
      "\tthere was not a hit but rather a ground ball to the first baseman\n",
      "\tnot a hit the runner was thrown out at first\n",
      "dist: 263.3998703535463:\n",
      "\tnot a hit the runner was thrown out at first\n",
      "\tthere was not a hit but rather a ground ball to the first baseman\n",
      "dist: 263.92615753582305:\n",
      "\tit was counted as a hit\n",
      "\tit's a hit\n",
      "dist: 264.408019973139:\n",
      "\tballs thrown\n",
      "\tthe ball was to\n",
      "dist: 264.4404268054487:\n",
      "\tthe ball was up and in but didn't hit him\n",
      "\tthe ball was high and not swung at\n",
      "dist: 264.7048072682365:\n",
      "\tthe ball sailed a couple of feet to the left of the plate\n",
      "\twent to the outside of the plate resulting in a ball\n",
      "dist: 264.983911147544:\n",
      "\tthe hitter made it safe to 1st base\n",
      "\tthe batter made it safely to first base\n",
      "dist: 265.0697714630507:\n",
      "\tthe ball was too far inside and possibly too high to be called a strike\n",
      "\tthe ball was thrown too high\n",
      "dist: 265.3163279440915:\n",
      "\tit got away too far from the catcher\n",
      "\tit hit the dirt and got away from the catcher\n",
      "dist: 265.3827235479685:\n",
      "\talso the pitch was not within the strike zone\n",
      "\tthen the pitch was not in the strike zone making it a ball\n",
      "dist: 265.46161875421154:\n",
      "\the got on base\n",
      "\tthe batter got on base\n",
      "dist: 266.24003372511567:\n",
      "\tthe opposing team caught it\n",
      "\tthe player caught it\n",
      "dist: 266.26330989978504:\n",
      "\tthe batter hit it over the wall and was in bounds\n",
      "\tthen the batter hit the ball behind him into the stands\n",
      "dist: 266.3767147084171:\n",
      "\thowever the umpire messed up the call and officially called it a ball\n",
      "\tit was called a ball by the umpire\n",
      "dist: 266.403933531886:\n",
      "\tthe ball was not throw over the plate and between the shoulders  the knees\n",
      "\tthe batter did not swing at the pitch\n",
      "dist: 266.42951927364544:\n",
      "\the considered to be the strike zone\n",
      "\tit to be in the strike zone\n",
      "dist: 266.5756248955868:\n",
      "\tit hit the ground in center field\n",
      "\tthe ball traveled into left field on the ground\n",
      "dist: 266.70946409396055:\n",
      "\tit was with two strikes\n",
      "\tthe 2nd number is the strike count\n",
      "dist: 266.70946409396055:\n",
      "\tthe 2nd number is the strike count\n",
      "\tit was with two strikes\n",
      "dist: 267.0027243113138:\n",
      "\the reached first base\n",
      "\tthe runner reached first base safely\n",
      "dist: 268.2941015015959:\n",
      "\tthe batter was awarded a walk\n",
      "\tthe batter got a walk\n",
      "dist: 268.6888615357594:\n",
      "\tthe pitch was a foot off the plate for a\n",
      "\tthe pitch was outside of home plate\n",
      "dist: 268.9151009005282:\n",
      "\the missed thus making the pitch a strike\n",
      "\tthe hitter swung at the pitch and missed the\n",
      "dist: 268.96836997040634:\n",
      "\tit hit the ground before\n",
      "\tit hit the ground before being fielded\n",
      "dist: 269.07006009342075:\n",
      "\tthe batter's box\n",
      "\tthe batter was\n",
      "dist: 269.2197823678592:\n",
      "\tthe outfielder managed to slide catch\n",
      "\tthe outfielder caught the ball\n",
      "dist: 269.2401961890128:\n",
      "\tit did not cross the strike\n",
      "\tball did not cross through strike zone\n",
      "dist: 269.32168813028426:\n",
      "\tthe throw from the pitcher was not good\n",
      "\the grounded out to the pitcher\n",
      "dist: 269.35017762985734:\n",
      "\tand batter hit it in the hole for a\n",
      "\tthe ball hit by the batter\n",
      "dist: 269.54411879490624:\n",
      "\ta right fielder gained secure possession of a batted ball in\n",
      "\tthe right fielder caught it\n",
      "dist: 269.6849100150277:\n",
      "\tthe pitcher's mound\n",
      "\tthe pitcher threw his pitch\n",
      "dist: 269.7079307347005:\n",
      "\ta strike was thrown\n",
      "\tthe ball appeared to be thrown in the strike zone\n",
      "dist: 270.1140554707518:\n",
      "\tth pitch was high outside the strike zone\n",
      "\tit was pitched outside the strike zone\n",
      "dist: 270.20109606419084:\n",
      "\tthen it was hit right to the\n",
      "\tit was hit\n",
      "dist: 270.2661278873267:\n",
      "\tno attempt by the left fielder to throw him out\n",
      "\tthe left fielder caught the ball in the air for an out\n",
      "dist: 270.7704795478049:\n",
      "\tit was caught in foul territory by the third baseman\n",
      "\tan out was recorded on a infield flyball that was caught by the third baseman\n",
      "dist: 270.98336249588726:\n",
      "\the made it to first\n",
      "\tthe batter made it to first\n",
      "dist: 270.9999359088243:\n",
      "\tit was caught in the air by an infielder\n",
      "\tthe outfielder caught it in the air\n",
      "dist: 271.04882105912753:\n",
      "\tan attempt to swing at the ball\n",
      "\tthe batter attempted to hit the ball\n",
      "dist: 271.51690117703845:\n",
      "\ttechnically a home run is a hit\n",
      "\tit was a hit home run\n",
      "dist: 271.92897902929616:\n",
      "\tthe batter hit a fly ball off the wall in left field for a stand up\n",
      "\tthe batter hit a fly ball to left field\n",
      "dist: 272.74439993774746:\n",
      "\tan attempt to tag the batter out\n",
      "\tthe catcher fielded the ball and threw the batter out at first base\n",
      "dist: 272.9251065287527:\n",
      "\tit was hit fair into the infield\n",
      "\tthis ball was hit into the outfield\n",
      "dist: 272.9922249224756:\n",
      "\tthe batter corey seager swung and missed the pitch\n",
      "\tthe batter swung hard and missed the ball\n",
      "dist: 273.2052695778582:\n",
      "\twho caught the ball in the air\n",
      "\twho caught it in the air\n",
      "dist: 273.41117342661806:\n",
      "\the hit an out of the park home\n",
      "\tthen the batter hit the ball outside of the park fair for a home run\n",
      "dist: 273.4927341886351:\n",
      "\tbatter hit a pop up that was caught by the first\n",
      "\tthe batter hit the ball in the air which was caught by a\n",
      "dist: 273.85882474371:\n",
      "\tpitcher failed to hit the strike zone\n",
      "\tthe pitch missed going through the strike zone\n",
      "dist: 273.99494119371144:\n",
      "\the fouled it off\n",
      "\the hit it foul\n",
      "dist: 274.25947131615163:\n",
      "\ta defensive player could get the ball to someone at first base\n",
      "\tthe ball was hit to the first baseman within the field of play\n",
      "dist: 274.3613526795007:\n",
      "\tit went through the infield to the left of second base and into center field\n",
      "\tthe second baseman fielded a ground ball and threw out the batter at first\n",
      "dist: 274.40681329760906:\n",
      "\tthe ball was swung at and missed by altuve for a strike\n",
      "\tand the batter swung at the ball and missed for a strike\n",
      "dist: 274.6490421356421:\n",
      "\tit went on the ground past the pitcher\n",
      "\tit landed on the ground before reaching the pitcher\n",
      "dist: 274.8096189753594:\n",
      "\tit was just counted as a ball\n",
      "\tit was called a ball\n",
      "dist: 275.3990738922285:\n",
      "\tthe batter hit is into fair territory\n",
      "\tthe batter hit the ball over the wall in fair territory which counts as a home run\n",
      "dist: 275.6893731102237:\n",
      "\ta base hit up the middle\n",
      "\tthe hitter hit a ground ball up the middle for a base hit\n",
      "dist: 276.02481367750784:\n",
      "\tthe announcers declared it a ball\n",
      "\tit was called a ball\n",
      "dist: 276.33220196726967:\n",
      "\tthe ball flew over the short stop and landed on the ground\n",
      "\tthe ball flew in the air landing on the ground in the outfield\n",
      "dist: 276.3929194865187:\n",
      "\tthe swing with no contact equals a strike\n",
      "\tit passed through the strike zone without the batter swinging\n",
      "dist: 276.4356948570923:\n",
      "\tthe shortstop's glove\n",
      "\tthe fielder's glove\n",
      "dist: 276.5435932370594:\n",
      "\the received a single for the hit\n",
      "\the hit a\n",
      "dist: 276.5594165849753:\n",
      "\the struck out\n",
      "\the hit a strike and grounded out\n",
      "dist: 276.5594165849753:\n",
      "\the hit a strike and grounded out\n",
      "\the struck out\n",
      "dist: 276.7154543466268:\n",
      "\tthe ball was swung at and missed for a strike by taylor\n",
      "\tthe ball was swung at and missed by altuve for a strike\n",
      "dist: 276.7272989964651:\n",
      "\tthe pitch seemed to barely catch the outside corner and could have gone either way as a ball or a strike\n",
      "\tthe pitch was over the plate but low missing the strike zone\n",
      "dist: 276.9848569901242:\n",
      "\tit was slightly outside of the strike zone\n",
      "\tit was outside of the strike zone\n",
      "dist: 277.1946172291492:\n",
      "\tmade the play to first base to get the out\n",
      "\tanother out double play on the batter running to first base\n",
      "dist: 277.4896506438518:\n",
      "\tthe batter altuve made contact with the pitch\n",
      "\tthe batter hit the pitch\n",
      "dist: 277.5511583980688:\n",
      "\tthe batter didn't argue with the call\n",
      "\tthe batter did not swing at a called\n",
      "dist: 278.1084922258649:\n",
      "\tthe batter took a partial swing\n",
      "\tthe batter's swing\n",
      "dist: 278.21937520599664:\n",
      "\twho threw the ball to first\n",
      "\twho threw it to first base for a out\n",
      "dist: 278.46210182378053:\n",
      "\talso the catcher framed the pitch well as it may have been just off of the plate\n",
      "\tthe pitch was caught by the catcher outside the strike zone\n",
      "dist: 278.6713073065548:\n",
      "\tthe hitter swang at a pitch and\n",
      "\tthe hitter put it in play\n",
      "dist: 278.84325600954713:\n",
      "\tthe batter contacted for the outfielder t catch\n",
      "\tthe batter hits the ball which is caught out by the outfielder\n",
      "dist: 279.038018625447:\n",
      "\tfoul ball hit on strike 1\n",
      "\tthe ball was hit foul on strike 2\n",
      "dist: 279.33579974104856:\n",
      "\tthen the batter hit the ball on the ground into foul terrritory\n",
      "\tthe batter hit the ball foul and into the ground\n",
      "dist: 279.4080419804532:\n",
      "\tbut the umpire called it a\n",
      "\tit was called a ball by the umpire\n",
      "dist: 279.7110646078391:\n",
      "\tumpire called a strike on a pitched ball that batter simply took\n",
      "\tthe umpire called the batter out\n",
      "dist: 279.7110646078391:\n",
      "\tthe umpire called the batter out\n",
      "\tumpire called a strike on a pitched ball that batter simply took\n",
      "dist: 279.71897495068066:\n",
      "\tthe first baseman's mitt\n",
      "\tthe catcher's mitt\n",
      "dist: 279.71897495068066:\n",
      "\tthe catcher's mitt\n",
      "\tthe first baseman's mitt\n",
      "dist: 279.9956378085181:\n",
      "\tit bounced on the ground inside the diamond\n",
      "\tin turn bounced on the ground\n",
      "dist: 280.04917790768457:\n",
      "\tit goes too wide to the left of the batter away from the strike zone\n",
      "\tit landed outside of the strike zone without being swung at by the batter\n",
      "dist: 280.13919261908364:\n",
      "\tbut it went into the stands in foul territory in this case down the right field line\n",
      "\tthe hitter hit the ball in foul territory on the right field side\n",
      "dist: 280.4767736221684:\n",
      "\tit went backwards past home plate\n",
      "\tthe ball went behind home plate\n",
      "dist: 280.47700922902646:\n",
      "\tthe ball was hit directly downward\n",
      "\tball was hit into the\n",
      "dist: 280.486004489124:\n",
      "\tthere were already 2 strikes on the hitter\n",
      "\tthe batter grounded out to the second baseman\n",
      "dist: 280.5712848869727:\n",
      "\tthe hitter has 2 already\n",
      "\tthere were already 2 strikes on the hitter\n",
      "dist: 280.61059451231193:\n",
      "\tthe batter had a 01 count\n",
      "\tthe batter was\n",
      "dist: 280.6396474072963:\n",
      "\the did not catch it in the air\n",
      "\twho couldn't catch the ball in the air\n",
      "dist: 280.6722628752023:\n",
      "\tthe batter takes a weak swing waving at the pitch\n",
      "\tthe batter swung at a low pitch\n",
      "dist: 280.78301462079907:\n",
      "\tthe catcher dropped the ball making the runner eligible to run to first\n",
      "\twho fielded the ball and threw the runner out at first\n",
      "dist: 280.783671048862:\n",
      "\tthe ball was hit and did not go into play between the orthogonal white lines\n",
      "\tthe ball was outside the box and did batter did not swing\n",
      "dist: 280.9670370024971:\n",
      "\tit was a long hit to mid center field\n",
      "\tthe ball was hit to centerfield\n",
      "dist: 280.9949917472541:\n",
      "\tit fell into fair territory without being caught\n",
      "\tit went into fair territory\n",
      "dist: 280.9949917472541:\n",
      "\tit went into fair territory\n",
      "\tit fell into fair territory without being caught\n",
      "dist: 281.4253375989203:\n",
      "\tthen the batter watched the ball which was thrown at the corner over the plate\n",
      "\tthe pitcher threw the ball low over the plate\n",
      "dist: 281.53749110760606:\n",
      "\ttaken off the plate making it a ball\n",
      "\twent to the outside of the plate resulting in a ball\n",
      "dist: 281.8646511683028:\n",
      "\tthe fielder did not field the ball in the air but rather fielded the ball on the ground\n",
      "\tthe left fielder fielded the ball off the ground\n",
      "dist: 281.90689152712645:\n",
      "\tit landed very low just above the dirt\n",
      "\tit hit the dirt before reaching the\n",
      "dist: 281.9523324142347:\n",
      "\tit travels over the plate to the catcher\n",
      "\tit was thrown over the plate\n",
      "dist: 281.9888573444178:\n",
      "\tthe batter smoked a home run over the left field\n",
      "\tthe batter smoked the hit past the centerfielder for a hit\n",
      "dist: 282.0612015457146:\n",
      "\tthe second baseman couldn't catch the ball in the air\n",
      "\tthe outfielder wasn't able to catch the ball\n",
      "dist: 282.237869095362:\n",
      "\tthe batter made a run after hitting the\n",
      "\tthe batter hit the ball on the ground and started running to the\n",
      "dist: 282.3964843534139:\n",
      "\the outfield\n",
      "\tthe player hit it to the outfield\n",
      "dist: 283.1929146022514:\n",
      "\tthe batter takes the pitch inside for a\n",
      "\tthe batter takes the pitch\n",
      "dist: 283.9136699545916:\n",
      "\tthe shortstop caught it in the air\n",
      "\tthe shortstop caught the ball in the air\n",
      "dist: 284.7792039979824:\n",
      "\tcalled it strike 2\n",
      "\tit was with two strikes\n",
      "dist: 284.9440499335753:\n",
      "\tit was outside the zone\n",
      "\tit was outside of the field of play\n",
      "dist: 284.9440499335753:\n",
      "\tit was outside of the field of play\n",
      "\tit was outside the zone\n",
      "dist: 285.22079252738246:\n",
      "\tit missed going through the strike one\n",
      "\tit missed going through the strike zone\n",
      "dist: 285.5286294627578:\n",
      "\tthe swing combined with no contact\n",
      "\tthe swing did not count\n",
      "dist: 285.5286294627578:\n",
      "\tthe swing did not count\n",
      "\tthe swing combined with no contact\n",
      "dist: 285.72781998007764:\n",
      "\twent into the stands to be foul\n",
      "\tit landed in foul territory in the stands\n",
      "dist: 286.05248154416137:\n",
      "\tthen it landed outside the strike zone for the ump to rule it a\n",
      "\tthe ball crossed the plate within the strike zone and was called a strike by the umpire\n",
      "dist: 286.122149124406:\n",
      "\tit hit the ground and was not caught\n",
      "\the hit it on the ground\n",
      "dist: 286.58384270373705:\n",
      "\tthe batter was caught in\n",
      "\tthe batter was\n",
      "dist: 286.87048202996:\n",
      "\tthe pitch was thrown far too low coming nowhere close to the strike zone\n",
      "\tthe pitch missed the strike zone\n",
      "dist: 286.9049063862322:\n",
      "\tthe batter was later out at the first base\n",
      "\tthe batter hit a single and ended up at first base\n",
      "dist: 287.0684884438097:\n",
      "\tit crossed the plate without touching the strike\n",
      "\tit crossed the plate below the strike zone without the batter swinging at it\n",
      "dist: 287.08166690950674:\n",
      "\tthe shortstop threw to first\n",
      "\tthe shortstop caught the ball in the air\n",
      "dist: 287.1182011442134:\n",
      "\tit was not a complete swing\n",
      "\tthe batter did not take a full swing\n",
      "dist: 287.38047769380427:\n",
      "\tthe rightfielder ran toward the ball\n",
      "\tran in from outfield to catch it\n",
      "dist: 287.7659942213192:\n",
      "\tcontacted the screen behind home plate making it a foul ball\n",
      "\tthe batter fouled the pitch off to behind home plate resulting in a foul ball\n",
      "dist: 287.83647583139754:\n",
      "\tthe ball was low and to the right of the plate\n",
      "\tthe ball was a strike over the plate\n",
      "dist: 287.86662649556735:\n",
      "\tit was outside and not swung at\n",
      "\tit is not a strike\n",
      "dist: 288.1907322560574:\n",
      "\tthe defensive team didn't get an out\n",
      "\tthe defensive team didn't make a play\n",
      "dist: 288.1907322560574:\n",
      "\tthe defensive team didn't make a play\n",
      "\tthe defensive team didn't get an out\n",
      "dist: 288.20341222343194:\n",
      "\taltuve's batted ball landed in the right field grass for a hit\n",
      "\tthe ball was swung at and missed by altuve for a strike\n",
      "dist: 289.1838985145973:\n",
      "\the did not run\n",
      "\tit was not a strike\n",
      "dist: 289.235994898495:\n",
      "\tit went outside the foul lines\n",
      "\tthe ball went outside the foul line\n",
      "dist: 289.52633986194184:\n",
      "\tthen the batter hit the ball to the shortshop\n",
      "\tthe batter hit the ball to one of the\n",
      "dist: 289.56028638343486:\n",
      "\twas it caught by the opposing team\n",
      "\tthe opposing team caught it\n",
      "dist: 289.83140863975774:\n",
      "\tthe batter taking the strike\n",
      "\tthe batter takes it in the strike zone\n",
      "dist: 290.0567158812002:\n",
      "\tthe umpire gave the pitcher a replacement ball in lieu of the one that was hit into the foul ball area\n",
      "\tumpire called a strike on a pitched ball that batter simply took\n",
      "dist: 290.07261274552644:\n",
      "\thowever it went into foul territory towards the dugout\n",
      "\tbut it landed in foul territory\n",
      "dist: 290.60263424554347:\n",
      "\tget to the ball in time to produce an out\n",
      "\tget there in time to catch the ball\n",
      "dist: 290.90107770626406:\n",
      "\tit landed on the dirt left of the line in foul territory\n",
      "\tbut it landed in foul territory\n",
      "dist: 290.9013431057887:\n",
      "\tthe batter's armpits\n",
      "\tthe batter's knees\n",
      "dist: 290.9240467303527:\n",
      "\tthe right fielder dropped the ball\n",
      "\tthe center fielder failed to catch the ball\n",
      "dist: 291.018818520692:\n",
      "\tthe defender caught it for an out\n",
      "\tit was caught for an out\n",
      "dist: 291.33456479832967:\n",
      "\tit is at the upper outside of the strike box so also looks like a\n",
      "\tit was above the strike zone\n",
      "dist: 291.39595115440994:\n",
      "\tthe hitter hit the ball on the ground to altuive on the right side\n",
      "\tthen the hitter made contact with the ball and hit it into the field of play\n",
      "dist: 291.65508152483903:\n",
      "\tthe batter completed a full swing\n",
      "\tthe batter's swing\n",
      "dist: 292.1150537383938:\n",
      "\tthe batter hit a foul on 0 strikes\n",
      "\tthe batter hits the ball foul towards the\n",
      "dist: 293.04348817428314:\n",
      "\tthe count went to 01\n",
      "\tthe batter had a 01 count\n",
      "dist: 293.39360733686686:\n",
      "\tthe leftcenter gap leading to a double\n",
      "\twhat appeared to be a double\n",
      "dist: 293.5213892009917:\n",
      "\tit went between the batter and the strike zone\n",
      "\tthe batter leaves the ball which travels in the strike zone\n",
      "dist: 293.6668687368065:\n",
      "\tit crossed the strike\n",
      "\tthe ball crossed into the strike zone\n",
      "dist: 293.70856385040605:\n",
      "\tthe batter hit it to the defensive team which made an out\n",
      "\tthen the batter hit the ball behind him into the stands\n",
      "dist: 293.8872945367493:\n",
      "\tthe empire called it a strike\n",
      "\tthe umpire called it a strike\n",
      "dist: 293.9188278135254:\n",
      "\tit went straight down the strike zone\n",
      "\tit was way below the strike zone\n",
      "dist: 294.0530254898468:\n",
      "\tit crossed the plate low and inside\n",
      "\tit crossed the plate\n",
      "dist: 294.1891766547479:\n",
      "\tit was not delivered within the strike zone and was called a ball\n",
      "\tthe pitch did not cross the plate inside the strike zone and was called a ball by the umpire\n",
      "dist: 294.2369122161279:\n",
      "\tthe catcher's glove\n",
      "\tthe shortstop's glove\n",
      "dist: 294.7542846238785:\n",
      "\tthe batter fouled it off his foot\n",
      "\tthe batter fouled it off of their\n",
      "dist: 295.0590753791176:\n",
      "\tit was inside the striking box\n",
      "\tit was inside the strike zone\n",
      "dist: 295.4122615122641:\n",
      "\tthe umpire called it correctly as a strike\n",
      "\tthen the umpire ruled it as a strike\n",
      "dist: 295.4444867794073:\n",
      "\tthe third basemen caught the foul ball\n",
      "\tthird baseman caught the ball\n",
      "dist: 295.6430700944175:\n",
      "\tit did not make the field of play thus a foul ball\n",
      "\thowever the ball was hit foul outside of the line of play\n",
      "dist: 295.67370100326576:\n",
      "\the could not throw to second or first\n",
      "\tthe outfielder wasn't able to catch the ball\n",
      "dist: 296.28602210081505:\n",
      "\tthe batter hit a shallow popup\n",
      "\tthe batter hit a popup which was caught by the left fielder\n",
      "dist: 296.6625313433606:\n",
      "\tit went backwards outside of the foul line\n",
      "\tthe ball went outside the foul line\n",
      "dist: 296.6781391687102:\n",
      "\tit was way inside almost hitting the batter on the forearm\n",
      "\tit is was over the plate and in the strike zone but was hit by the batter\n",
      "dist: 296.915891985932:\n",
      "\tthe ground ball was not a hit\n",
      "\tthere was not a hit but rather a ground ball to the first baseman\n",
      "dist: 297.03010335293146:\n",
      "\the dropped it\n",
      "\the was out\n",
      "dist: 297.1901733689239:\n",
      "\tthe ball went foul towards the first base dugout\n",
      "\tthe batter made contact grounding the ball into foul territory on the first base side of the field\n",
      "dist: 298.17862777023316:\n",
      "\tit was caught outside of the strike\n",
      "\tthe catcher caught it outside of the strike zone\n",
      "dist: 298.29509895463633:\n",
      "\tit was not hit fair into play\n",
      "\tthe ball hit out to center field and was not caught\n",
      "dist: 298.4443229640812:\n",
      "\tit was a hit line drive straight up the center\n",
      "\tthe batter hit a line drive toward center\n",
      "dist: 298.6255369154456:\n",
      "\tit landed inside the fair play area\n",
      "\tthe ball landed in fair play\n",
      "dist: 299.11244216639824:\n",
      "\tthe fielders moved in on it\n",
      "\tfielder's\n",
      "dist: 299.7022618294424:\n",
      "\tthe umpire would consider to be the strike zone\n",
      "\tthe umpire signaled a strike\n",
      "dist: 300.16822646251154:\n",
      "\thowever it was not hit into fair territory\n",
      "\tit was not hit fair into play\n",
      "dist: 300.4375619500188:\n",
      "\tthe ball is an offspeed pitch that is low and doesn't go over the plate\n",
      "\tthe ball was not thrown through the strike zone\n",
      "dist: 300.87183847874775:\n",
      "\tit was low and away\n",
      "\tit went low\n",
      "dist: 301.04791500646314:\n",
      "\tthe batter took a check swing\n",
      "\tthe batter taking a swing\n",
      "dist: 301.0707022794441:\n",
      "\the will get a strike as well\n",
      "\tit was also a strike\n",
      "dist: 301.76584722412787:\n",
      "\tit was easy to catch\n",
      "\tit was caught\n",
      "dist: 301.80283304577387:\n",
      "\tthe side stands\n",
      "\tthe left stands\n",
      "dist: 301.80283304577387:\n",
      "\tthe left stands\n",
      "\tthe side stands\n",
      "dist: 301.98119677156416:\n",
      "\tthe count was 22 two balls and two strikes\n",
      "\tthe count was 02 no balls and 2 strikes\n",
      "dist: 301.9942463094622:\n",
      "\tthe ball was barely inside the strike box\n",
      "\tthe ball landed just inside the strike zone\n",
      "dist: 302.0367559610742:\n",
      "\tit went in the air backwards landing in the stands somewhere behind home plate\n",
      "\tthe ball was well outside the strike zone and hit the backstop behind the plate\n",
      "dist: 302.15354366210056:\n",
      "\tit was only a foul ball\n",
      "\tit was a foul ball\n",
      "dist: 303.0184010097137:\n",
      "\tit landed safey in outfield for a hit\n",
      "\tthen the hitter hit the ball into the outfield which was picked up by the outfielder on the first bounce which resulted in a hit\n",
      "dist: 303.25940288223427:\n",
      "\tthe batter got caught watching\n",
      "\tthe batter was caught in\n",
      "dist: 304.4624823511995:\n",
      "\the has to miss the pitch with 2 strikes to be called out\n",
      "\tthe second baseman couldn't catch the ball in the air\n",
      "dist: 304.94466371818186:\n",
      "\tthe first baseman to record the out\n",
      "\tthrew it to first base to record the out\n",
      "dist: 305.23991260306417:\n",
      "\tthe third baseman misplayed the ball\n",
      "\tthe fielder misplayed the ball\n",
      "dist: 305.23991260306417:\n",
      "\tthe fielder misplayed the ball\n",
      "\tthe third baseman misplayed the ball\n",
      "dist: 305.6598199383178:\n",
      "\tthe pitch was called a strike\n",
      "\tthe pitch was a strike\n",
      "dist: 305.9618661557608:\n",
      "\tit landed too far inside the plate and too close the\n",
      "\tthen it was over the plate\n",
      "dist: 306.1350054675559:\n",
      "\tthe pitch was too high\n",
      "\tit was too high\n",
      "dist: 306.22275213572635:\n",
      "\tit was also a single\n",
      "\tit was also a single and rbi\n",
      "dist: 306.22275213572635:\n",
      "\tit was also a single and rbi\n",
      "\tit was also a single\n",
      "dist: 306.297923636069:\n",
      "\tthe third baseman picked it up\n",
      "\tthe third baseman was able to catch it\n",
      "dist: 306.84209358609485:\n",
      "\ttherefore the count remains 02 in the foul ball\n",
      "\tyou hit a foul ball with 2 strikes\n",
      "dist: 306.88476772128996:\n",
      "\tthe pitch was perfectly placed to clear the strike zone in the lower left corner\n",
      "\tthe pitch was delivered outside the strike zone\n",
      "dist: 307.27090440057424:\n",
      "\tgrabbed the ball to start the double play\n",
      "\tand then the second baseman threw it to first for the double play\n",
      "dist: 308.0486562385186:\n",
      "\tthe announcers said he just got a piece of the ball enough to go foul\n",
      "\tthe batter hit the ball straight back to the back stop for a foul ball\n",
      "dist: 308.4735227032096:\n",
      "\tit was low and inside\n",
      "\tit was low and\n",
      "dist: 308.8200497878708:\n",
      "\thit it to center\n",
      "\tthe hitter hit the ball to right center field\n",
      "dist: 309.1967162689245:\n",
      "\tthe foul is a strike\n",
      "\tfoul ball hit on strike 1\n",
      "dist: 309.5151326961859:\n",
      "\tswung the bat hitting the ball behind home plate\n",
      "\tthe ball landed outside of the strike zone without being swung at by the batter\n",
      "dist: 309.8452898585667:\n",
      "\tmade the catch to get the out\n",
      "\twho caught it and threw the runner out\n",
      "dist: 309.9208912403548:\n",
      "\tthe player grounded out\n",
      "\tthen the batter hit a ground ball which resulted in an out\n",
      "dist: 310.1875927726351:\n",
      "\ta fastball clocked at 92mph\n",
      "\tit was a 96 miles per hour fastball at the top of the strike zone\n",
      "dist: 311.29914169367026:\n",
      "\tit was within the field of play\n",
      "\tit was outside of the field of play\n",
      "dist: 311.87213835744575:\n",
      "\tit passed the batter\n",
      "\ttherefore the batter is\n",
      "dist: 312.21943386555273:\n",
      "\tit was outside\n",
      "\tit was outside the zone\n",
      "dist: 312.41014593924734:\n",
      "\tthe fielder could return the ball\n",
      "\tthe fielder could catch it\n",
      "dist: 312.67091734406785:\n",
      "\tthe pitch was a foul tip\n",
      "\tthe pitch was thrown\n",
      "dist: 313.1408502399127:\n",
      "\tit was inside the box\n",
      "\tit was inside the striking box\n",
      "dist: 313.32128531330005:\n",
      "\tthen the 91 mph pitch was called a ball\n",
      "\tpitch was called a ball\n",
      "dist: 314.42637239737013:\n",
      "\tthere is less then 2 outs and runners on first and second or loaded\n",
      "\tthe count went from 01 to 02 no balls and 2 strikes\n",
      "dist: 314.93779031415676:\n",
      "\tthe batter stayed at first base\n",
      "\tthe batter made contact with the ball and kept it in the field of play\n",
      "dist: 314.9684561928289:\n",
      "\tit was fielded\n",
      "\tit was fielded by the defense\n",
      "dist: 314.9684561928289:\n",
      "\tit was fielded by the defense\n",
      "\tit was fielded\n",
      "dist: 315.12058823600734:\n",
      "\tit was hit and went into the stands\n",
      "\tit bounced off the wall for a hit\n",
      "dist: 317.49325415013226:\n",
      "\tpop fly to the shortstop\n",
      "\tthe hitter hit a line drive in the air to the shortstop\n",
      "dist: 317.82003291277476:\n",
      "\tthr umpire and announcer called it as a ball\n",
      "\tit was called a ball by the umpire\n",
      "dist: 318.80924097163285:\n",
      "\tit approached the hitter\n",
      "\tit reached the hitter\n",
      "dist: 318.8977536786834:\n",
      "\tit was right on the lower right corner of the strike\n",
      "\tthe ball was right in the center of the strike box\n",
      "dist: 319.6488141286529:\n",
      "\tthe catcher didn't catch it\n",
      "\twho was unable to catch the ball\n",
      "dist: 319.7859506909146:\n",
      "\tthe pitch was a bit too inside\n",
      "\tthe pitch is located\n",
      "dist: 319.8647170699706:\n",
      "\tit was able to land safely on the ground\n",
      "\tit landed on the ground\n",
      "dist: 320.0155156128886:\n",
      "\tis the only option that works it was a ground ball that resulted in an out\n",
      "\the hit a ground ball to short stop and was thrown out at\n",
      "dist: 320.19043833277743:\n",
      "\tthe swung offered at the pitch and missed\n",
      "\tit was a swing and a miss at the pitch\n",
      "dist: 320.94689126931684:\n",
      "\tlower right shows no strikes\n",
      "\tthe ball was not thrown through the strike zone\n",
      "dist: 321.1196910024366:\n",
      "\tthe ball was a grounder\n",
      "\tthe hitter got a piece of the ball\n",
      "dist: 321.12367409485086:\n",
      "\tannouncers thought it may have been a ball though\n",
      "\ttherefore it was a ball\n",
      "dist: 321.14844801992245:\n",
      "\tmotion with his arm to call it a strike\n",
      "\tit went into the strike zone so was called a strike\n",
      "dist: 321.2969209739668:\n",
      "\tbatter hit it into a gap\n",
      "\tthe batter hit the ball into the leftcenter gap for a double\n",
      "dist: 321.32912301718994:\n",
      "\tit was also a strike and a fielders choice\n",
      "\ta fielder's choice ball\n",
      "dist: 321.40498463567434:\n",
      "\tno one was able to get to it\n",
      "\tno one caught it\n",
      "dist: 322.4007514511023:\n",
      "\tthe opposition did not catch it mid air\n",
      "\the did not catch it in the air\n",
      "dist: 322.70148167601945:\n",
      "\tit bounced on the ground outside of the strike zone which is marked on the tv broadcast screen\n",
      "\tit bounced on the ground inside the diamond\n",
      "dist: 322.8889371930265:\n",
      "\tthe defense dropping the ball and creating a easy double play\n",
      "\tgrabbed the ball to start the double play\n",
      "dist: 323.4477160170928:\n",
      "\tit was a slider that started on the outside corner of the plate and took a sharp dip\n",
      "\tthe ball was right down the middle over the plate in the strike zone\n",
      "dist: 324.12490230608006:\n",
      "\tstrikes thrown\n",
      "\ta strike was thrown\n",
      "dist: 324.40536269610953:\n",
      "\tground ball turned into a double play 643\n",
      "\ta ground ball hit\n",
      "dist: 325.09522790379486:\n",
      "\tthe catcher dropped the ball\n",
      "\tthe right fielder dropped the ball\n",
      "dist: 325.3182262246401:\n",
      "\tthe ball went past the foul poles towards the crowd\n",
      "\tthe ball went outside the foul line\n",
      "dist: 325.3584137513819:\n",
      "\tthe batter was called out\n",
      "\tthen the batter hit it foul\n",
      "dist: 325.67402658449925:\n",
      "\tit was too close to the batters body and outside the stroke zone\n",
      "\tthe ball landed high and outside the strike zone\n",
      "dist: 325.811766132537:\n",
      "\tit's the end of the inning\n",
      "\tthe inning was then over\n",
      "dist: 325.811766132537:\n",
      "\tthe inning was then over\n",
      "\tit's the end of the inning\n",
      "dist: 326.1306484998923:\n",
      "\tit passed first or third base\n",
      "\tit passed first base in foul territory\n",
      "dist: 327.0638374823313:\n",
      "\the hit it outside the foulfair lines\n",
      "\tthe batter made contact with the ball and hit it into the air past the foul line\n",
      "dist: 327.1763943605467:\n",
      "\tit went high and to the left into the stands\n",
      "\tthe left stands\n",
      "dist: 327.8225574849485:\n",
      "\tit was grounded out to short\n",
      "\the hit a ground ball to short stop and was thrown out at\n",
      "dist: 327.8252006492249:\n",
      "\the scooped it up and threw the batter out\n",
      "\twho caught it and threw the batter out at first base\n",
      "dist: 328.58199428686845:\n",
      "\tit went in the stands\n",
      "\tit landed in the stands\n",
      "dist: 328.58199428686845:\n",
      "\tit landed in the stands\n",
      "\tit went in the stands\n",
      "dist: 329.9574976140421:\n",
      "\tthe ball sailed\n",
      "\tthe ball was to\n",
      "dist: 330.1743100104641:\n",
      "\the was going to get a double\n",
      "\tthe leftcenter gap leading to a double\n",
      "dist: 330.3220932067772:\n",
      "\tthe hitter got a single\n",
      "\tthe hitter got a piece of the ball\n",
      "dist: 332.4445883560248:\n",
      "\ttossed the ball to the second basement to start the double play\n",
      "\tand the batter grounded to the short stop who then turned the double play for 2 outs\n",
      "dist: 332.6951191407272:\n",
      "\tthe umpire caines a strike\n",
      "\tthe umpire would consider to be the strike zone\n",
      "dist: 333.8274789714042:\n",
      "\thitter stays at 1st\n",
      "\tthe batter stayed at first base\n",
      "dist: 334.0318832214244:\n",
      "\ta double play occured\n",
      "\tit was a double play which resulted in two outs\n",
      "dist: 334.26014429414033:\n",
      "\tit didn't stay in play\n",
      "\tit was not in play\n",
      "dist: 334.4441131854683:\n",
      "\tit got past both the infield and the outfield without being stopped\n",
      "\tthe ball rolled into the outfield\n",
      "dist: 335.62789721543874:\n",
      "\tthe runner made it to the\n",
      "\trecording an out on the runner coming form first\n",
      "dist: 335.62789721543874:\n",
      "\trecording an out on the runner coming form first\n",
      "\tthe runner made it to the\n",
      "dist: 335.9090327136211:\n",
      "\tthe batter smoked it into foul territory\n",
      "\tthe batter swung and popped into foul territory\n",
      "dist: 336.11644362393343:\n",
      "\the stayed alive to face another pitch\n",
      "\the did offer at the pitch making it a strike\n",
      "dist: 336.1631795197165:\n",
      "\tthe outfielder has to run to it\n",
      "\tthe rightfielder ran toward the ball\n",
      "dist: 337.43590445812066:\n",
      "\tit missed the plate\n",
      "\tit crossed the plate without touching the strike\n",
      "dist: 337.8062511680099:\n",
      "\ta strike is the count\n",
      "\tit counts as a ball\n",
      "dist: 338.1868039628744:\n",
      "\tthe batter flied out to\n",
      "\tthe batter to be out\n",
      "dist: 338.64732454832625:\n",
      "\tit didn't go far\n",
      "\tit was not in play\n",
      "dist: 339.27465286805733:\n",
      "\tthe play was valid\n",
      "\tit was still in play\n",
      "dist: 339.27465286805733:\n",
      "\tit was still in play\n",
      "\tthe play was valid\n",
      "dist: 340.04435215279153:\n",
      "\tit was 0 strikes in the count\n",
      "\tlower right shows no strikes\n",
      "dist: 340.21148090947923:\n",
      "\the watched the ball\n",
      "\tit's a ball\n",
      "dist: 343.4886512920048:\n",
      "\tit was not over the plate\n",
      "\tit did not cross the plate inside of the strike zone\n",
      "dist: 344.4762110253933:\n",
      "\tit was to the left of the line\n",
      "\tit went outside the foul lines\n",
      "dist: 344.95922919975334:\n",
      "\tthe ball went into the stands\n",
      "\tit went high and to the left into the stands\n",
      "dist: 345.50341859519455:\n",
      "\tthe batter faked a bump attempt and pulled back\n",
      "\tthe batter faked a bunt and was called a\n",
      "dist: 345.50341859519455:\n",
      "\tthe batter faked a bunt and was called a\n",
      "\tthe batter faked a bump attempt and pulled back\n",
      "dist: 346.8239137646297:\n",
      "\tthe umpire signaled it a foul and got some replacement balls\n",
      "\tthe announcers said he just got a piece of the ball enough to go foul\n",
      "dist: 347.18921055114976:\n",
      "\tthe ball was high which resulted in ball 4 and a walk\n",
      "\tthe ball went high\n",
      "dist: 348.0873063516694:\n",
      "\tboth players are out\n",
      "\the dropped it\n",
      "dist: 349.4603853811123:\n",
      "\tanyone could get to it\n",
      "\tno one was able to get to it\n",
      "dist: 350.89760850167573:\n",
      "\tit went straight back to the backstop\n",
      "\tit went behind him and to the side\n",
      "dist: 351.3584177105433:\n",
      "\tit was a strike anyway due to the location\n",
      "\tit was also a strike\n",
      "dist: 351.5676190514522:\n",
      "\tit bounced\n",
      "\tit bounced off the wall\n",
      "dist: 351.94033154992127:\n",
      "\the checked the swing but went too far\n",
      "\tthe hitter took a swing and a miss which made it a\n",
      "dist: 352.81471476946814:\n",
      "\the hit it behind himself\n",
      "\tthen the batter hit the ball behind him into the stands\n",
      "dist: 353.8983217750161:\n",
      "\tit landed\n",
      "\tit was able to land safely on the ground\n",
      "dist: 355.13495462816996:\n",
      "\tthe first baseman to register the out\n",
      "\tfirst baseman throwing out the batter\n",
      "dist: 355.59261578731747:\n",
      "\tit was inside\n",
      "\tit was inside the striking box\n",
      "dist: 357.3774302621451:\n",
      "\tthe play is a fly out\n",
      "\tthe fielder caught in the air\n",
      "dist: 358.44436058017817:\n",
      "\tit was inside the field\n",
      "\tit was within the field of play\n",
      "dist: 359.1482730903181:\n",
      "\tit went inside the zone\n",
      "\tit was inside the strike zone\n",
      "dist: 359.37458859762336:\n",
      "\the tagged the bag\n",
      "\the had the tag the runner as well for the out\n",
      "dist: 359.37458859762336:\n",
      "\the had the tag the runner as well for the out\n",
      "\the tagged the bag\n",
      "dist: 359.8724813609579:\n",
      "\tthe infield fly rule was in effect\n",
      "\tthe play is a fly out\n",
      "dist: 360.1294770032572:\n",
      "\the will remain 0\n",
      "\the did not run\n",
      "dist: 360.85601042312845:\n",
      "\the did so successfully\n",
      "\the made it to first\n",
      "dist: 361.39564988346643:\n",
      "\tthe correct answer is caught in air\n",
      "\tit was caught in the air\n",
      "dist: 361.407516162798:\n",
      "\ts pop up fly\n",
      "\tit was caught mid air\n",
      "dist: 361.79170183507:\n",
      "\tthe batter looked to bunt and pulled away and was called a strike\n",
      "\tthe batter decided not to swing\n",
      "dist: 362.78486116895425:\n",
      "\tthe slider looked good down and out over the plate\n",
      "\tthen the pitch crossed over the plate in the lower part of the strike zone\n",
      "dist: 363.1529588284004:\n",
      "\the missed\n",
      "\the swung and missed\n",
      "dist: 363.86060279382133:\n",
      "\the beat out\n",
      "\the was out\n",
      "dist: 363.9158219000601:\n",
      "\tthe right field stands\n",
      "\the outfield\n",
      "dist: 364.3208479999294:\n",
      "\tthe play was made on first\n",
      "\the made it to first\n",
      "dist: 364.6350685823864:\n",
      "\the was nearly hit\n",
      "\tit was hit\n",
      "dist: 366.4320127927486:\n",
      "\this throw was too late\n",
      "\the threw him out\n",
      "dist: 366.5669041077645:\n",
      "\thome run is the correct label but is not listed among the choices\n",
      "\tthen the batter hit the ball and was not caught by the outfielder\n",
      "dist: 366.8965553462759:\n",
      "\tit is wide of the\n",
      "\tit was high and outside\n",
      "dist: 367.6912785835403:\n",
      "\tit bounced a few times without being caught\n",
      "\tthe ball landed outside of fair play without being caught\n",
      "dist: 368.28283831570224:\n",
      "\twho failed to make the play\n",
      "\tbut it was not in play\n",
      "dist: 369.73216898218305:\n",
      "\tit was an 86 mile per hour changeup that landed right in the middle of the strike zone\n",
      "\tit was way high and outside the strike zone\n",
      "dist: 369.96098971618545:\n",
      "\ta foul tip is considered a strike\n",
      "\tthe foul is a strike\n",
      "dist: 371.798087609349:\n",
      "\tit goes a long way\n",
      "\tit is wide of the\n",
      "dist: 373.3129634670906:\n",
      "\tit was a ground rule double hopped over the fence into the crowd\n",
      "\tthe ball went past the foul poles towards the crowd\n",
      "dist: 373.3900593971947:\n",
      "\tthe outcome was a hit\n",
      "\tit dropped in for a hit\n",
      "dist: 375.01596821447225:\n",
      "\tit was in bounds\n",
      "\tit's a perfect example of a ground ball\n",
      "dist: 375.30170154732974:\n",
      "\tall runners were able to advance safely\n",
      "\tthe runner made it to the\n",
      "dist: 376.15181931742626:\n",
      "\the pulled his bat back in time\n",
      "\tit bounced on the ground back to the pitcher who then through the batter out at first base\n",
      "dist: 376.6295021094258:\n",
      "\the had to reach down far and missed it even\n",
      "\the did not catch it in the air\n",
      "dist: 378.254852422454:\n",
      "\tit went backwards\n",
      "\tit went behind him\n",
      "dist: 381.70396722773074:\n",
      "\twhat pitch was coming\n",
      "\tthe pitch was a ball\n",
      "dist: 383.3433848516426:\n",
      "\tit came into contact with anything\n",
      "\tanyone could get to it\n",
      "dist: 383.95421566232034:\n",
      "\tthe hitter is longest tenured dodger\n",
      "\tthen the hitter fouled it off\n",
      "dist: 384.99719826574363:\n",
      "\tit was called astrike\n",
      "\ts pop up fly\n",
      "dist: 385.59488200247796:\n",
      "\tit was not an out\n",
      "\tit was not over the plate\n",
      "dist: 388.1976734664633:\n",
      "\twhat to put for this answer\n",
      "\tthe correct answer is caught in air\n",
      "dist: 388.73816215242465:\n",
      "\tit went over the backstop into the fans\n",
      "\tthe ball went past the foul poles towards the crowd\n",
      "dist: 390.96867668523106:\n",
      "\tdude smacked the ball off the green monster for a hit\n",
      "\tin turn causing a home run\n",
      "dist: 390.9740454508711:\n",
      "\the popped out to the short stop\n",
      "\tthe shortstop caught it in the air\n",
      "dist: 391.1462885912617:\n",
      "\tit reached the striker\n",
      "\tit crossed the strike\n",
      "dist: 393.8555886901151:\n",
      "\tany strikes are already completed\n",
      "\tit was an out\n",
      "dist: 394.31471948690086:\n",
      "\twho did not hold on to it\n",
      "\the dropped it\n",
      "dist: 395.6750133346787:\n",
      "\tgot there ans was called out\n",
      "\the threw him out\n",
      "dist: 401.1647308085804:\n",
      "\tit went backwards into the net\n",
      "\tit went backwards\n",
      "dist: 405.70247932302226:\n",
      "\tdude smoked it down the line for a\n",
      "\tthe slider looked good down and out over the plate\n",
      "dist: 422.9007952680541:\n",
      "\tthis game took place in los angeles\n",
      "\tit was caught in the air by an infielder\n",
      "dist: 423.0569566852201:\n",
      "\tthen it is hit into the fans\n",
      "\tit went over the backstop into the fans\n",
      "dist: 424.42737581416367:\n",
      "\tit is also a pseudo linedrive to\n",
      "\tthe pitch was outside\n",
      "dist: 425.43346858613864:\n",
      "\tinstead it was a checkswing\n",
      "\tthe batter took a check swing\n",
      "dist: 430.0237580106614:\n",
      "\tand it went to the gap in right\n",
      "\tbatter hit it into a gap\n",
      "dist: 446.87654072705396:\n",
      "\tit sailed past\n",
      "\tit is wide of the\n",
      "dist: 461.0901225880604:\n",
      "\tthe instructions say\n",
      "\tthe umpire called it a\n",
      "dist: 466.36238740042535:\n",
      "\twho had a better view\n",
      "\tit was caught mid air\n"
     ]
    }
   ],
   "source": [
    "neighbours_adjusted  = find_pairwise_nearest(prox_mtx_total)\n",
    "display_best_closest_neighbours(neighbours_adjusted, prox_mtx_total, concepts)\n",
    "#print(f\"pruned_mtx.shape = {pruned_mtx.shape}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "# setting distance_threshold=0 ensures we compute the full tree.\n",
    "model = AgglomerativeClustering(distance_threshold=0, n_clusters=None, linkage='single', affinity='precomputed')\n",
    "model = model.fit(prox_mtx_total)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [],
   "source": [
    "concept_counts = count_datapoints_in_each_feature(pam)\n",
    "run_dendrogram = False\n",
    "if run_dendrogram:\n",
    "    plt.title('Hierarchical Clustering Dendrogram')\n",
    "    # plot the top three levels of the dendrogram\n",
    "    #plt.figure(figsize=(16,8))\n",
    "    leaf_labels = [concepts[i]+f\" ({concept_counts[i]})\" \n",
    "                   for children in model.children_ for i in range(len(concepts))]\n",
    "    plot_dendrogram(model, truncate_mode='level', p=670, labels=leaf_labels, leaf_font_size=12, orientation='right')\n",
    "    fig = plt.gcf()\n",
    "    fig.set_size_inches(12,170) \n",
    "    plt.ylabel(\"Number of points in node (or index of point if no parenthesis).\")\n",
    "    #plt.setp(ax.get_yticklabels(), fontsize=18)\n",
    "    plt.tight_layout()\n",
    "    pngfname = form_processed_fname(datastem, modelstem, 'png', identifier='concept_dendrogram')\n",
    "\n",
    "    plt.savefig(pngfname)\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Evaluating parameters\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [],
   "source": [
    "# critical parameter determines how to split the clusters\n",
    "# minkowski distance is 0.15\n",
    "# manhattan distance threshold 55-59\n",
    "#distance_threshold = 0.15\n",
    "## best parameters from concept_clustering_measures notebook\n",
    "init_previous = True\n",
    "if init_previous:\n",
    "    previous_modelname = None\n",
    "    previous_metric = None\n",
    "    previous_labelmetric = None\n",
    "    previous_alpha = None\n",
    "    previous_lambda = None\n",
    "    previous_rescaling = None\n",
    "    previous_threshold = None\n",
    "    previous_linkage = None\n",
    "best_modelname = 'stsb'\n",
    "stsb_roberta_model\n",
    "best_metric = 'manhattan'\n",
    "best_labelmetric = 'evidence_ratio'\n",
    "best_alpha = 0.5\n",
    "best_lambda = 0.2\n",
    "best_rescaling = 720.\n",
    "best_threshold = 240. # Good thresholds are 220 or 240.\n",
    "#best_n_clusters = 480\n",
    "best_linkage = 'single'\n",
    "rerun_embed_distances = False\n",
    "rerun_total_distances = False\n",
    "rerun_clustering = False"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "running embedding\n"
     ]
    }
   ],
   "source": [
    "if best_modelname != previous_modelname:\n",
    "    print(\"running embedding\")\n",
    "    best_model = model_lookup[best_modelname]\n",
    "    embeds = build_embedding_matrix(concepts, best_model)\n",
    "    rerun_embed_distances = True\n",
    "previous_model = best_model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "running proximity matrix embeddings\n"
     ]
    }
   ],
   "source": [
    "if rerun_embed_distances or best_metric != previous_metric:\n",
    "    print(\"running proximity matrix embeddings\")\n",
    "    prox_mtx_embedding = calc_prox_mtx_embedding(embeds, best_metric)\n",
    "    rerun_total_distances = True\n",
    "previous_metric = best_metric"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "running proximity matrix labels\n"
     ]
    }
   ],
   "source": [
    "if best_alpha != previous_alpha or best_labelmetric != previous_labelmetric:\n",
    "    print(\"running proximity matrix labels\")\n",
    "    prox_mtx_labels = calc_prox_mtx_labels(label_counts_mtx, best_alpha, best_labelmetric)\n",
    "    rerun_total_distances = True\n",
    "previous_alpha = best_alpha\n",
    "previous_labelmetric = best_labelmetric"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "running proximity matrix total\n",
      "running clustering\n"
     ]
    }
   ],
   "source": [
    "if rerun_total_distances or best_lambda != previous_lambda or best_rescaling != previous_rescaling:\n",
    "    print(\"running proximity matrix total\")\n",
    "    prox_mtx_total = prox_mtx_embedding + best_lambda * best_rescaling * prox_mtx_labels\n",
    "    rerun_clustering = True\n",
    "previous_lambda = best_lambda\n",
    "previous_rescaling = best_rescaling\n",
    "\n",
    "if rerun_clustering or best_threshold != previous_threshold or best_linkage != previous_linkage:\n",
    "    print(\"running clustering\")\n",
    "    model = AgglomerativeClustering(distance_threshold=best_threshold, n_clusters=None, linkage=best_linkage, affinity='precomputed')\n",
    "    model = model.fit(prox_mtx_total)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [],
   "source": [
    "group_concepts_results = group_concepts(pam.astype(int), concepts, model.labels_)\n",
    "grouped_pam = group_concepts_results['grouped_pam']\n",
    "grouped_concept_ids = group_concepts_results['grouped_concept_ids']\n",
    "grouped_concepts = group_concepts_results['grouped_concepts']\n",
    "grouped_concept_counts = group_concepts_results['grouped_concept_counts']\n",
    "dominant_concepts = group_concepts_results['dominant_concepts']\n",
    "max_child_counts = group_concepts_results['max_child_counts']\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Num clusters as function of threshold\n",
    "Testing`"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7fe23f318b20>]"
      ]
     },
     "execution_count": 43,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "thresholds = np.linspace(200, 300, 11)\n",
    "n_cluster_seq = []\n",
    "n_sig_cluster_seq = []\n",
    "for threshold in thresholds:\n",
    "    test_model = AgglomerativeClustering(distance_threshold=threshold, n_clusters=None, linkage=best_linkage, affinity='precomputed')\n",
    "    test_model = test_model.fit(prox_mtx_total)\n",
    "    n_cluster_seq.append(test_model.n_clusters_)\n",
    "    test_group_concepts_results = group_concepts(pam.astype(int), concepts, test_model.labels_)\n",
    "    test_grouped_concept_counts = test_group_concepts_results['grouped_concept_counts']\n",
    "    n_sig_cluster_seq.append(np.sum(test_grouped_concept_counts >= 3))\n",
    "plt.figure()\n",
    "plt.plot(thresholds, n_cluster_seq)\n",
    "plt.figure()\n",
    "plt.plot(thresholds, n_sig_cluster_seq)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Eyeballing the concepts in clusters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[['the batter swung right over the pitch and missed it',\n",
       "  'the batter swung at the pitch and missed it completely',\n",
       "  'the batter swung at it and missed the ball completely',\n",
       "  'the batter swung and missed',\n",
       "  'the batter swung at the pitch and missed for a strike',\n",
       "  'then the batter swung hard and missed',\n",
       "  'then the batter swung but missed',\n",
       "  'the batter swung and missed the pitch',\n",
       "  'the batter swung at the ball and missed',\n",
       "  'then the batter swung at it and missed',\n",
       "  'the batter swung and missed it',\n",
       "  'the batter swung at and missed the pitch',\n",
       "  'the batter swung and missed for a strike',\n",
       "  'the batter swung at the ball without making contact',\n",
       "  'the batter swung at the outside pitch but missed',\n",
       "  \"the batter swung but didn't hit the ball\",\n",
       "  'the batter swung and missed the ball',\n",
       "  'the batter swung and missed for strike two',\n",
       "  'the batter swung at the ball and missed it',\n",
       "  'the batter swung and did not make contact with the',\n",
       "  'and the batter swung and missed',\n",
       "  'then the batter swung and missed',\n",
       "  'the batter swung at the ball but missed',\n",
       "  'the batter swung and missed the',\n",
       "  'batter swung and pitch and missed the ball which is a',\n",
       "  'batter swung at pitch and missed ball which is a strike',\n",
       "  'the batter swung at the pitch and missed making it a strike',\n",
       "  'the batter swung hard and missed the ball',\n",
       "  'then the batter swung at the pitch and missed the ball without making contact',\n",
       "  'the batter swung but did not make contact with the ball',\n",
       "  'then the batter swung extremely hard missing the ball',\n",
       "  'batter swung and missed the ball',\n",
       "  'the batter swung his bat at the ball and missed',\n",
       "  'then the batter swung at the pitch and missed',\n",
       "  'the batter swung and missed at the pitch',\n",
       "  'the batter swung at and missed',\n",
       "  'and the batter swung and missed it',\n",
       "  'the batter swinged and missed the ball',\n",
       "  'the batter swung the bat and did not make contact with the ball',\n",
       "  'the batter swung at a pitch and missed striking out',\n",
       "  'the batter swung and did not make contact with the ball',\n",
       "  'then the batter swung and missed the ball',\n",
       "  'the batter swung at the pitch and missed making contact',\n",
       "  'and the batter swung at the ball and missed for a strike',\n",
       "  'the batter swung but missed the ball',\n",
       "  \"then the batter swung and didn't make contact\",\n",
       "  \"then the batter swung at but didn't make contact with the pitch\",\n",
       "  'the batter swung the bat but missed the ball',\n",
       "  'the batter swung and missed hitting the ball',\n",
       "  'the batter swung anyway and missed making it a strike',\n",
       "  'the batter swung and missed striking out',\n",
       "  'the batter struck out and took a swing and a miss',\n",
       "  'the batter swung and did not make contact',\n",
       "  'then the batter swung at the ball and missed for a strike',\n",
       "  'then the batter swung on the pitch but missed',\n",
       "  'the batter swung at the pitch but did not make contact with the ball',\n",
       "  'the batter swung at the pitch and missed',\n",
       "  'the batter swung at it and missed',\n",
       "  'the batter swung at the pitch but did not hit it',\n",
       "  'the batter swung the bat at the pitch but missed',\n",
       "  'then the batter swung hard missing the ball'],\n",
       " ['the batter hit the ball on the ground',\n",
       "  'the batter hit the ball on the ground to the second baseman',\n",
       "  'the batter grounded out to the second baseman',\n",
       "  'the batter made contact with the pitch and hit it on the ground to the shortstop',\n",
       "  'the batter hit it into play on the ground',\n",
       "  'the batter hit a ground ball to the shortstop',\n",
       "  'the batter hit a ground ball to first baseman',\n",
       "  'then the batter hit the ball on the ground to the second baseman',\n",
       "  'the batter hit a ground ball',\n",
       "  'the batter grounded the ball to the shortstop',\n",
       "  'the batter hit the ball through the infield',\n",
       "  'the batter swung and hit the ball on the ground',\n",
       "  'the batter hit the ball which bounced on the ground towards the second baseman',\n",
       "  'the batter hit ball on the ground',\n",
       "  'the batter hit the ball on the ground to the shortstop',\n",
       "  'the batter hit a ground ball to second baseman',\n",
       "  'the batter hit a ground ball to second base',\n",
       "  'the batter hit a ground ball to the first baseman',\n",
       "  'then the batter hit the ball on the ground',\n",
       "  'the batter hit the ball on the ground between the first and second baseman',\n",
       "  'the batter hit the ball into the ground in play',\n",
       "  'the batter hit the ball on the ground in play',\n",
       "  'the batter hit a groundball to the first baseman',\n",
       "  'the batter swung and hit the ball on the ground towards the',\n",
       "  'then the batter hit a ground ball to the shortstop',\n",
       "  'the batter hit the ball to the shortstop on the ground',\n",
       "  'the batter hit the ball on the infield',\n",
       "  'the batter hit a ground',\n",
       "  'the batter hit a ground ball between first and second base',\n",
       "  'it was hit on the ground to the second baseman',\n",
       "  'the batter hit the pitch on the ground between the first baseman and the second baseman',\n",
       "  'the batter hit the ball on the ground to the second',\n",
       "  'batter hit the ball on the ground',\n",
       "  'the batter hit the ball on the ground before reaching the shortstop',\n",
       "  'then the batter hit it on the ground',\n",
       "  'the batter hit a ground ball to the second baseman',\n",
       "  'the batter hit the ball which landed on the ground in the field of play'],\n",
       " ['the batter swung and hit the ball into play',\n",
       "  'the batter hit the ball',\n",
       "  'the batter hit it',\n",
       "  'the batter made contact with the ball',\n",
       "  'the batter swung and made contact with the ball',\n",
       "  'the batter swung and hit the ball',\n",
       "  'the batter struck the ball',\n",
       "  'then the batter made contact with the ball',\n",
       "  'the batter swung at the pitch and made contact',\n",
       "  'the batter made contact with ball',\n",
       "  'the batter hit the ball to one of the',\n",
       "  'batter hit the ball',\n",
       "  'batter made contact on the ball',\n",
       "  'batter hit it in play',\n",
       "  'the batter swung and made contact',\n",
       "  'the batter swung and hit the ball on the',\n",
       "  'the batter hit and put the ball into play',\n",
       "  'the batter put the ball into play',\n",
       "  'the batter hit the ball with the bat',\n",
       "  'the batter hits the ball',\n",
       "  'the batter swung the ball and hit it',\n",
       "  'the batter swung his bat and hit the ball',\n",
       "  'the batter hit',\n",
       "  'the batter hit the',\n",
       "  'the batter swung at it and hit the ball with his bat',\n",
       "  'the batter swung at the ball and hit it',\n",
       "  'the batter hit the ball with his bat',\n",
       "  'the batter swung at the ball and hit the ball',\n",
       "  'batter hit a',\n",
       "  'batter hit the',\n",
       "  'the batter hit the ball into play on the',\n",
       "  'the batter went for the swing and hit the ball',\n",
       "  'the batter hit it in play',\n",
       "  'the batter swung hit the'],\n",
       " ['it was caught by the right outfielder',\n",
       "  'the centerfielder caught the ball',\n",
       "  'the right fielder caught',\n",
       "  'it was caught by the center fielder',\n",
       "  'the right fielder caught the ball',\n",
       "  'center fielder caught the ball',\n",
       "  'it was caught by the left fielder',\n",
       "  'the centerfielder caught it',\n",
       "  'the right fielder caught it',\n",
       "  'the outfielder caught the',\n",
       "  'the leftfielder caught the ball',\n",
       "  'the center fielder caught it',\n",
       "  'the fielder caught the ball',\n",
       "  'it was caught by an outfielder',\n",
       "  'the outfielder caught the ball',\n",
       "  'the centerfield caught the ball',\n",
       "  'the right fielder caught the ball in the outfield',\n",
       "  'the fielder caught the ball in the air',\n",
       "  'the outfielder caught the ball in the air',\n",
       "  'a fielder caught the ball in the air',\n",
       "  'then the outfielder caught it',\n",
       "  'it was caught by the right fielder',\n",
       "  'the right fielder makes the catch',\n",
       "  'an outfielder caught it',\n",
       "  'it was caught by the outfielder',\n",
       "  'it was caught by the fielder',\n",
       "  'it was caught by and outfielder',\n",
       "  'it was caught by the centerfielder'],\n",
       " ['then the ball was in the strike zone',\n",
       "  'it was in the strike zone',\n",
       "  'the ball landed within the strike zone',\n",
       "  'the ball landed in the strike zone',\n",
       "  'the ball went through the strike zone',\n",
       "  'the ball went into the strike zone',\n",
       "  'it went through the strike zone',\n",
       "  'the ball landed on edge of the strike zone',\n",
       "  'it went into the strike zone',\n",
       "  'the ball was in the strike zone',\n",
       "  'the ball crossed into the strike zone',\n",
       "  'ball was thrown in the strike zone',\n",
       "  'the ball went right into the strike zone',\n",
       "  'it passed through the strike zone',\n",
       "  'it to be in the strike zone',\n",
       "  'it entered the strike zone',\n",
       "  'the ball crossed the strike zone',\n",
       "  'it landed in the strike zone',\n",
       "  'ball was in the strike zone',\n",
       "  'the ball hit the strike zone',\n",
       "  'it went in the strike zone',\n",
       "  'the ball crossed the strike zone thus a strike',\n",
       "  'the ball landed on the edge of the strike zone'],\n",
       " [\"the batter didn't swing\",\n",
       "  'the batter did not swing at it',\n",
       "  'the batter did not swing',\n",
       "  'the batter did not swing at the ball',\n",
       "  \"the batter didn't swing at it\",\n",
       "  'the batter didnt swing',\n",
       "  'the batter did not swing at the pitch',\n",
       "  'then the batter did not swing at it',\n",
       "  'then the batter did not swing',\n",
       "  'batter did not swing',\n",
       "  \"the batter didn't swing at the pitch\",\n",
       "  'the batter did not swing his bat',\n",
       "  \"the batter doesn't swing\",\n",
       "  'the batter did not swing the bat',\n",
       "  'the batter didnt swing at',\n",
       "  \"the batter didn't swing the bat\",\n",
       "  'the batter did not swing at the pitch with his bat',\n",
       "  'the batter did not swing at the',\n",
       "  'the batter did not swing or make contact',\n",
       "  'batter didnt swing',\n",
       "  \"batter didn't swing\",\n",
       "  \"the batter didn't swing on a\",\n",
       "  'the batter did not swing on it'],\n",
       " ['the batter hit it into foul territory',\n",
       "  'the batter hit the ball into foul territory',\n",
       "  'the batter made contact and hit the ball into foul territory',\n",
       "  'the batter hit the ball into the stands in foul territory',\n",
       "  'the batter hit the ball to foul territory',\n",
       "  'the batter hit the ball in the air into foul territory',\n",
       "  'the batter hit the ball foul and into the ground',\n",
       "  'the batter hit the ball on the ground into foul territory',\n",
       "  'then the batter hit the ball in the air in foul territory',\n",
       "  'the batter hit a ball in foul territory',\n",
       "  'then the batter hit the ball into foul territory',\n",
       "  'the batter hit it in foul territory',\n",
       "  'the batter hit the ball into foul territory on the ground',\n",
       "  'the batter hit the ball into the ground in foul territory',\n",
       "  'the batter hit the ball in the air but into the stands in foul territory',\n",
       "  'the batter swung and hit the ball into foul territory'],\n",
       " ['the batter made contact with the pitch and grounded it to third base',\n",
       "  'then the batter swung and hit the ball on the ground to the third baseman',\n",
       "  'the batter hit a ground ball to the third baseman',\n",
       "  'then the batter swung and hit it on the ground past the third basemen and into the outfield',\n",
       "  'the batter hit a grounder to the 3rd baseman',\n",
       "  'the batter hit the ball on the ground to the third baseman',\n",
       "  'the batter makes contact hitting a ground ball to the third baseman',\n",
       "  'the batter hit it on the ground towards the third baseman',\n",
       "  'the batter hit the ball to the third baseman who then through the hitter out at first',\n",
       "  'batter hit a ground ball to third base and was thrown',\n",
       "  'the ball was hit to the third baseman on the ground',\n",
       "  'the batter hit a ground ball to third',\n",
       "  'the batter hit a ground ball to the 3rd baseman',\n",
       "  'then the hitter hit a ground ball to third base',\n",
       "  'and the batter hit the ball on the ground to the third',\n",
       "  'the ball is hit on the ground to the third baseman'],\n",
       " ['the ball crossed the plate outside the strike zone',\n",
       "  'the ball crossed the home plate area outside of the strike zone high',\n",
       "  'the ball crossed the home plate area outside of the strike zone inside',\n",
       "  'the ball crossed the home plate area outside of the strike zone high and outside',\n",
       "  'it crossed the plate outside of the strike zone for a ball',\n",
       "  'ball crossed home plate outside the strike zone',\n",
       "  'the ball crossed home plate outside the strike zone',\n",
       "  'it crossed the plate outside the strike zone',\n",
       "  'the ball crossed the plate outside of the strike zone resulting in a ball',\n",
       "  'the ball crossed the plate outside of the strike zone',\n",
       "  'it crossed home plate just high and outside of the strike zone'],\n",
       " ['it would be a ball',\n",
       "  'it was called a ball',\n",
       "  'it was a ball',\n",
       "  'it ended up being a ball',\n",
       "  'it counts as a ball',\n",
       "  'so it was called a ball',\n",
       "  \"it's a ball\",\n",
       "  'it is a ball',\n",
       "  'therefore it was a ball',\n",
       "  'it is called a ball']]"
      ]
     },
     "execution_count": 44,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "largest_group_ids = np.argsort([len(concepts) for concepts in grouped_concepts])[::-1]\n",
    "largest_group_ids[:10]\n",
    "[grouped_concepts[gid] for gid in largest_group_ids[:10]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1914"
      ]
     },
     "execution_count": 45,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.max([ cid_ for cids in grouped_concept_ids for cid_ in cids])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "g_datapoints_per_concept = count_datapoints_in_each_feature(grouped_pam)\n",
    "plot_rank_versus_freq(g_datapoints_per_concept, lw=2, color='r')\n",
    "plt.title(\"Data-points per concept: grouped.\")\n",
    "plt.tight_layout()\n",
    "pngfname = form_processed_fname(datastem, modelstem, 'png', identifier='g_datapoints_per_concept')\n",
    "plt.savefig(pngfname)\n",
    "ylim = plt.ylim()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "g_concepts_per_datapoint = count_features_in_each_datapoint(grouped_pam)\n",
    "plot_rank_versus_freq(g_concepts_per_datapoint, lw=2, color='r')\n",
    "plt.title(\"Concepts per datapoint: grouped.\")\n",
    "plt.tight_layout()\n",
    "pngfname = form_processed_fname(datastem, modelstem, 'png', identifier='g_concepts_per_datapoint')\n",
    "plt.savefig(pngfname)\n",
    "ylim = plt.ylim()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "raw_datapoints_per_concept = count_datapoints_in_each_feature(pam)\n",
    "plot_rank_versus_freq(raw_datapoints_per_concept, lw=2, color='r')\n",
    "plt.ylim(ylim)\n",
    "plt.title(\"Data-points per concept: raw.\")\n",
    "plt.tight_layout()\n",
    "pngfname = form_processed_fname(datastem, modelstem, 'png', identifier='raw_datapoints_per_concept')\n",
    "plt.savefig(pngfname)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "raw_concepts_per_datapoint = count_features_in_each_datapoint(pam)\n",
    "plot_rank_versus_freq(raw_concepts_per_datapoint, lw=2, color='r')\n",
    "plt.ylim(ylim)\n",
    "plt.title(\"Concepts per data-point: raw.\")\n",
    "plt.tight_layout()\n",
    "pngfname = form_processed_fname(datastem, modelstem, 'png', identifier='raw_concepts_per_datapoint')\n",
    "plt.savefig(pngfname)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### After grouping\n",
    "\n",
    "We now have the following parameters:\n",
    "\n",
    "* `grouped_pam` - a pam where each column is a group of concepts\n",
    "* `grouped_concept_ids` - a list of list, for each group a list of concept ids (ints)\n",
    "* `grouped_concepts` - a list of lists for each group concept a list of the concepts in that group.\n",
    "* `grouped_concept_counts` - a total count of the number of covered instances from a group concept.\n",
    "* `max_child_counts` - of the contained concepts in a given group what is the max number of instances covered by a child concept.\n",
    "* `dominant_concepts` - the string of the most frequent child concept in each group.\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Completing concepts"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ids.shape = (2126,)\n"
     ]
    }
   ],
   "source": [
    "print(f\"ids.shape = {ids.shape}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "188_5sjzeb4w03.csv, 129_h8c8ny4x7u.csv, 197_ni25hikvxf.csv, 4_xu9afrhg0o.csv, 142_d8jaik03id.csv, 38_38doqz3unu.csv, 18_omkydub7qy.csv, 8_hfxm8dkunn.csv, 195_nwk7f5mq3h.csv, 119_hdkgwx4tgr.csv, 100_5397borrxc.csv, 31_jhmyyhmjh5.csv, 166_5lv4sjg1qv.csv, 10_ten3l2nuwn.csv, 184_hzlbex83q3.csv, 55_o97cc78tyd.csv, 179_enmmbxkd9b.csv, 135_7g73f18y8h.csv, 49_8fcz4c6oqy.csv, 164_qcoq7yni4y.csv, 118_66k0pevslq.csv, 54_07djfakfxh.csv, 141_tvldgnl6pt.csv, 138_yx53ai19ar.csv, 107_jfii3uf345.csv, 24_1y633kulxy.csv, 27_adgb2e3ry7.csv, 155_97dannvd9q.csv, 16_omnxwedc88.csv, 83_slgfcmc4xj.csv, 25_ceghr7ntgk.csv, 145_1p84lqxs5t.csv, 90_60znzzhvt3.csv, 187_kp3lfo9rti.csv, 109_ehl2s3ah2w.csv, 1_z949c1i541.csv, 151_8k3mbw3phz.csv, 3_5uxjfwf4c9.csv, 26_2k5thw2ykv.csv, 46_eg7yytwm57.csv, 102_r9vbr9i6qn.csv, 159_wmf9y5lb3d.csv, 122_hmocfdllhz.csv, 110_zq7vq985bq.csv, 53_4t2mju8m3y.csv, 26_kcs08kmlzv.csv, 150_hvfxdsp6uq.csv, 1_ofoaso8yxd.csv, 189_4mh7pjb6hj.csv, 21_x90g7ie9t7.csv, 20_z3zjd5sgm4.csv, 39_3064xz3lgl.csv, 51_km3hwahw1m.csv, 32_jitoqenvci.csv, 23_lce4ue1yit.csv, 2_wrrttduqx0.csv, 29_juqgc9mrcx.csv, 64_gjf3ihxyfj.csv, 73_4s2wt6mgps.csv, 146_umxfdzx3sg.csv, 79_wkvkhcnsn0.csv, 88_p169fqr8hl.csv, 35_g0ldvn0rjm.csv, 163_g4ownm07q9.csv, 58_lvcsk0yy8g.csv, 158_lhrhfgkazf.csv, 111_4dftcjzv4j.csv, 97_ksnb8zg7e2.csv, 131_bivn5or23h.csv, 178_7rflrddsnn.csv, 27_r6anjd4ie1.csv, 171_evt2lbu5wz.csv, 7_viucp080gt.csv, 59_tvvx1filo9.csv, 92_u8wrf1zhh5.csv, 191_yxm7fc16uc.csv, 113_s8v38lnghb.csv, 68_4fxf0cl1sa.csv, 47_qrdef2nnjn.csv, 71_jjxizibivj.csv, 28_7svph4yobz.csv, 182_icy94tmqbq.csv, 37_7swqi7vgnl.csv, 7_swfaqmk6y6.csv, 194_tnwwh3zbnj.csv, 20_1zahygarmq.csv, 161_qu7m9mil3a.csv, 125_onkofvwzgk.csv, 67_ip2ys2xhib.csv, 56_lxflttkcgn.csv, 148_nekma0liim.csv, 85_i7f88e7b7g.csv, 123_g66af1qsqo.csv, 140_rpfb54del9.csv, 114_fkhid5yyst.csv, 19_sevtqojtws.csv, 160_9xq61i8z5q.csv, 76_f4jqlrtl0d.csv, 57_l8ux51os5l.csv, 147_qz39am2soc.csv, 4_vet6mgh5md.csv, 106_oa27xk4eqt.csv, 33_zybtjc12ef.csv, 21_x8u5ofrlzo.csv, 66_8gquz8hbpz.csv, 63_j79b3nmr83.csv, 84_q4rh6yklie.csv, 86_kvt6l8gw8d.csv, 16_j1uppkkwpc.csv, 192_isa0drpmu4.csv, 5_lcampqa5d8.csv, 169_2y8d92hhek.csv, 74_08dh1ae49m.csv, 41_rrwls6y9fl.csv, 36_4bg4d4bf4q.csv, 117_mgq0ymf5hc.csv, 65_5y9bhpar44.csv, 174_vw5a8s9vzj.csv, 165_vcamdtt7pl.csv, 75_gginvgfabf.csv, 14_apv4u3qebs.csv, 69_4tlegp20n1.csv, 103_v129kmq3c5.csv, 17_qvtzqld86i.csv, 15_jzm9dvtw73.csv, 183_ex67vzlp8e.csv, 14_mx46s0fx52.csv, 6_qyv4vhzoe.csv, 78_tshg4zfas1.csv, 82_3qr5zxdcxe.csv, 48_u6mx1k6p64.csv, 193_kjtylxs5x6.csv, 91_6nvvo85k2r.csv, 185_9bjzxvbwca.csv, 156_yk739g3286.csv, 70_0b98yn7zuy.csv, 154_i7n85wzpa3.csv, 132_s5i7ngx7bu.csv, 180_jm6cn0n08c.csv, 104_jos9y36cxr.csv, 170_szpuak9x3b.csv, 61_l3jkp84irv.csv, 168_39vz7oesxk.csv, 101_9l21auewdi.csv, 15_j7tl3bmirm.csv, 134_behtf6grhp.csv, 124_4p9vzltfyn.csv, 80_zbkdixjx1u.csv, 157_7onih683qj.csv, 22_udsmb087i5.csv, 13_y1i6zh8y9w.csv, 96_fe55r9bnfd.csv, 120_tfdaxlk9n2.csv, 130_7a6m1my07s.csv, 121_aobrexg5sv.csv, 115_iocn2dpj2o.csv, 11_0na6xsa4cd.csv, 77_gup8yvrjg8.csv, 181_wk573tzjde.csv, 42_kr1ailiclk.csv, 43_1nemhlm74b.csv, 40_zh8fjx6tiy.csv, 11_7vk8oa1o24.csv, 198_shm86f7xzz.csv, 167_bk26q01ex6.csv, 99_7fcky2iv54.csv, 0_imfn3fsnqb.csv, 199_hzu91su6jo.csv, 44_zsqcy1dp0n.csv, 24_pa58yc2bsn.csv, 105_3acmrslh5t.csv, 18_o65lxoj85y.csv, 52_wfyl6gdoxn.csv, 62_6v7alh2xza.csv, 6_blz9uaf562.csv, 176_cl4orgir7l.csv, 25_zdmhvwm1pk.csv, 95_6ikda3av09.csv, 139_1qp7vpj70o.csv, 89_28gvnlaz8j.csv, 175_954mvwcwet.csv, 98_8et5hi6nqf.csv, 81_dbvr7ry56o.csv, 143_w11kkydg7n.csv, 2_9actgs9mi7.csv, 93_7s7jo61qgr.csv, 126_s6vu9wsf2o.csv, 50_tmt7xio73x.csv, 60_zry6xyk2v2.csv, 127_q2ifamcjop.csv, 173_op7k51t6eh.csv, 153_mwu7z89cr2.csv, 149_tvntt1n3zf.csv, 136_dd735psc8g.csv, 87_zzzdc841sd.csv, 186_77g5px55z1.csv, 133_c0kk72b3fm.csv, 12_i0qb55ygnr.csv, 128_y3nqk9k0x4.csv, 144_6g4qagf0aw.csv, 116_wf72qb1ctj.csv, 172_gg34wiyfxn.csv, 34_egy98kczu6.csv, 152_uhh1hem3ei.csv, 162_gzcq0eli5q.csv, 3_j0hn3a0xzt.csv, 9_m11ut0fzvo.csv, 13_xb7ph2k0m6.csv, 5_wa4f0flvdd.csv, 94_gcso78g1mh.csv, 112_7g35kmtkhr.csv, 72_37k8qe6uf3.csv, 45_4g2awfbbtn.csv, 196_h8ebmn0b4i.csv, 30_rb578trmsj.csv, 8_v4bqc7mvzy.csv, 108_qkxdz8djgt.csv, 137_eusnnkienm.csv, completed_grouped_pam.shape = (2126, 1368)\n"
     ]
    }
   ],
   "source": [
    "#concept_group_strings = concept_group_labels\n",
    "#grouped_pam = np.zeros((pam.shape[0],len(concept_group_strings)))\n",
    "\n",
    "\n",
    "path = form_data_dirname(datastem)\n",
    "#completed_grouped_pam = np.copy(grouped_pam)\n",
    "grouped_pam = group_concepts_results['grouped_pam']\n",
    "grouped_concept_ids = group_concepts_results['grouped_concept_ids']\n",
    "grouped_concepts = group_concepts_results['grouped_concepts']\n",
    "grouped_concept_counts = group_concepts_results['grouped_concept_counts']\n",
    "dominant_concepts = group_concepts_results['dominant_concepts']\n",
    "max_child_counts = group_concepts_results['max_child_counts']\n",
    "\n",
    "completed_grouped_pam = complete_pam_with_substrings(\n",
    "    path, grouped_pam, grouped_concept_ids, grouped_concepts, rows_to_remove=rows_to_remove)\n",
    "print(f\"completed_grouped_pam.shape = {completed_grouped_pam.shape}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "When grouped pam (unpruned) is completed with substring lookup we have 7054 presences in PAM\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "print(f\"When grouped pam (unpruned) is completed with substring lookup we have {np.sum(completed_grouped_pam)} presences in PAM\")\n",
    "\n",
    "cg_datapoints_per_concept = count_datapoints_in_each_feature(completed_grouped_pam)\n",
    "plot_rank_versus_freq(cg_datapoints_per_concept, lw=2, color='r')\n",
    "plt.title(\"Data-points per concept: grouped then completed.\")\n",
    "plt.tight_layout()\n",
    "plt.savefig(f\"{datastem}_data_points_per_concept_grouped_then_completed.png\")\n",
    "pngfname = form_processed_fname(datastem, modelstem, 'png', identifier='cg_datapoints_per_concept')\n",
    "plt.savefig(pngfname)\n",
    "\n",
    "plt.figure()\n",
    "cg_concepts_per_datapoint = count_features_in_each_datapoint(completed_grouped_pam)\n",
    "plot_rank_versus_freq(cg_concepts_per_datapoint, lw=2, color='r')\n",
    "plt.title(\"Concepts per datapoint: grouped then completed.\")\n",
    "plt.xscale('linear')\n",
    "plt.yscale('linear')\n",
    "plt.tight_layout()\n",
    "pngfname = form_processed_fname(datastem, modelstem, 'png', identifier='cg_concepts_per_datapoint')\n",
    "plt.savefig(pngfname)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      ".............................................................................When grouped pam (unpruned) is completed with substring lookup then pruned (threshold 3) we have 4699 presences in PAM\n",
      "There are 2126 datapoints with 78 concepts\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAa8AAAEYCAYAAADrpHnMAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8+yak3AAAACXBIWXMAAAsTAAALEwEAmpwYAAAsVElEQVR4nO3dd5xU1fnH8c9DEyS4oCBKkbYExYa4YoEoKioQsceoYI0SY2KNsf8iaiyxRDRBLKDEoGKLBbuiiAULiA0bKCioIIJgAxE4vz+eu9lhmO0ze+fufN+v17x2584tz23zzLn33HMshICIiEiSNIg7ABERkepS8hIRkcRR8hIRkcRR8hIRkcRR8hIRkcRR8hIRkcRR8qoDZnajmf1f3HFI/WRmk83s+FyNn2Rm1tnMgpk1qqPlBTMrztX49VVNtkMikpeZzTWz5Wb2nZktNbOXzexEM6tS/HV9AKcLIZwYQrikKuOa2Tgz+1uuY6rvomNmQNxxxM3MRpjZ+LjjSAIzO8bMXszh/AvmR0NdSETyigwJIbQAOgFXAGcDY+MNqf4ys4Zxx5DPtH2kvorrR361hRDy/gXMBQakDesDrAG2it7/GpgBfAvMA0akjPsZEIDvo9fOQDfgWWAx8DVwB9CyghhGAPcBdwPfAW8A26Z8vgUwGVgKzAT2S/lsHPC36P/+wHzgz8BXwJfAsdFnw4GfgZVRnBOj4WcDn0fL/RDYs5wYxwE3Ak9H4z4PdEr5fPPosyXRfA5Nm3Y08BjwQ/r2jsbZELgN+AL4Bngw5bMTgNnRvB8G2qV8FoATgVnR9hkFWNq070cxvwf0joa3A+4HFgFzgFOqsj+A/0THxvJoO55VxePsrGh/fAEcH8VdXN72qWSfTwaOT3l/DPBi2jY5BfgEP/6uAhqkfH5ctE2+AZ5M2497AR8Ay4B/Rfv5+AzrMzA6ln6OtsNbKbFdArwUbbungNYp0+0EvByt11tA/7T1KnfaDDHsD7yJn5cfAwNT9u3D0fEyGzghbd/eC4yPlvEO8EvgXPycmQfsnRbT5cBr0XIeAjaMPuscbetG0fsi/Efvl/g59TegYbQvVwCro221NBp/PeBq/DtkIX5+NUtZ9l8oO2aOI+WYSdsOl0bzXhHN/19VPDcqOg4qnLaa319z8e+Zt4GfgEbp60IVv8eyud0qPF+rM3JcLzIkr2j4Z8AfUjbm1nhpcptogx2Q6QCOhhXjXwLrAW2AKcDICmIYgX8JHAI0Bs7Ev1AbR6/ZwHlAE2CP6ADpUc5OXwVcHE03GPgRaJU+bvS+B36ytktZl27lxDguWu6u0XpdR/SFCTSP5nNsdGBuh39p9kyZdhnQN9qGTTPM/1H84G8Vxb5bNHyPaF69o+X+E5iSdpI9ArQENsOTUemX2G/wL5EdAIv2S6cohunAX6Nt2hX/ot+nsv1R3jGDn5hHlLPtBgILgC2B9fEvzvTklbp9WlSyzydTefJ6Dv9BsBnwUen4+Bf+bPwLtRFwAfBy9FnraDml6306fjytk7xSttP4tGGT8UTyS6BZ9P6K6LP2+A+6wdF67hW9b1PZtBmW3SfaZntF82oPbB59NgW4AWgK9IqOiT1SYl4B7BOt/+3Rvj0/WucTgDlp6/M5sBV+nN9fus6sm7weAG6KxtsYT3i/z7SPomHX4kl2w2ifTwQuTzlmFqYs904q+BJOPyaqcG6UexxUNm11vr9Szpc3gY5ESSZ9Xaje91jWtlu538k1SSZ1/aL85PUKcH4504wErs10AJcz/gHAjAo+HwG8kvK+Af7L4VfRawFr/3K+i6j0l2GnL2ftRPoVsFP6uNH74ujzAaUHWgUxjgMmpLz/Bf5rryPwW+CFtPFvAi5Mmfb2Cua9KV6aaZXhs7HAlWnL/RnonHIS9Ev5/B7gnOj/J4FTM8xzR+CztGHnArdVtj8qOmYqWL9bS0+ulO2enrxuT/m8sn0+mcqT18CU9ycBk6L/Hwd+l7ZuP+JJ/ai09Tb8F3B1k9cFact+Ivr/bOA/aeM/CRxd2bQZln0T0TmYNrxjdFy2SBl2OTAuJeanUz4bgpdWGkbvW0Tbr2VKTFekjN8TL3E2JOXcB9ripYrUEsDhwHPl7CPDS9ndUobtTJQ4o2Mmdbm/pGbJq7xzo9zjoLJpyzkOKjtfjssQW0XJK+P3WLa3W3mvJN3zyqQ9ftkBM9vRzJ4zs0VmtgwvTrcub0Iza2tmE8zsczP7Fv+l3Tr6bKiZfR+9Hk+ZbF7pPyGENfiXRrvoNS8aVurTKL5MFocQVqW8/xH/wl9HCGE2cBp+8H0VxdyuvPVKi/F7fPu0w7/4dowqvCw1s6XAUGCTTNNm0BFYEkL4JsNn7fD1TV3uYtZe/wUp/6eub0f8l3y6TkC7tHjPw7+A1ok3bX/URDvWXv9M2yJ1WHX3eSap8/uUstg7AdelrPcS/AuhfXqcwc/+ivZbecrbH52A36Rt9374j5fKpk1X3r5thx9L36UMS992C1P+Xw58HUJYnfKetOWmb8vGrHv+d4qGf5mybjfhJbBM2uCl8Okp4z8RDS9dj/Tl1kRF+6K846CyaTOp7Hyp7nFU3vdYnWy3xCYvM9sB34mltYPuxIupHUMIRfg1Vos+CxlmcVk0fOsQwgbAsNLxQwh3hBB+Eb0GpUzTMWX5DYAO+DXbL4COabUfN8MvZVTXOrGGEO4MIfTDD+YA/L2C6VNj/AVebP8CP1ieDyG0THn9IoTwh4qWnWIesKGZtczw2RdRbKXLbQ5sRNXWfx5+/zHT8Dlp8bYIIQxOGae8/VHZumTyZTT9OvNOkTrPyvb5D/gJXCr1R0KmZWxGWezz8EtZqeveLITwchRn6npbObFmirkq5uElr9RlNw8hXFHN+ZTOK9O+/QI/llqkDKvp+VIqfVv+jF/KTo/nJ/weXem6bRBC2DL6PH1bfY0nyi1Txi8KIZQmiLX2RbTcitRkX5R3HNRERedLpvh+pPJjOJNsb7eMEpe8zGwDM9sXmIBfDnkn+qgF/mtuhZn1AY5ImWwRfsmra8qwFviliGVm1h6/gViZ7c3soKg2zmn4ifAK8Cq+o88ys8Zm1h+/1DGhBqu4MDVOM+thZnuY2Xr4fYDl0bqUZ7CZ9TOzJviN9VdCCPPwa+O/NLMjoxgbm9kOZrZFVYIKIXyJX8a4wcxaRdPvGn18F3CsmfWK4rwMeDWEMLcKsx4DnGlm25srNrNO+L2I78zsbDNrZmYNzWyr6EdLqfL2B6Rtxyq4J1qHLcxsfaCy5/Iq2+dvAgeZ2frR8yu/yzCPv0TbsiNwKn4/EfyH17lmtiWAmRWZ2W+izx4FtkxZ71Oo+EtlIdC5qo+V4FcghpjZPtE2b2pm/c2sQ6VTrmssvk33NLMGZtbezDaPjseXgcuj+W+Db5/aVOkfZmY9o313MXBfSkkN+N8x/BRwTfQ90sDMupnZbtEoC4EO0blTWjq5BbjWzDYGiNZhn2j8e4BjUpZ7YSUxVveYrOg4qImKzpdM3gSOiI6DgcBuFYz7PznYbhklKXlNNLPv8F8j5wP/wCsflDoJuDga56/4BgIghPAjXtvnpagYuxNwEV7BYBn+hfDfKsTwEH7v6BvgSOCgEMLPIYSV+BfXIPxXxw3AUSGED2qwnmOBnlGcD+IVIK6I5rsAv8RxbgXT34kfDEuA7fESJdElmr2Bw/BfWwvwEtx61YjtSPwX7Qf49e3Tonk/g3/Z34//quoWLadSIYR78X1zJ14R4UG8pthqYF/8Zv4cfP3H4LXFSmXcH9FnlwMXRNvxTAAzm2lmQ8uJ43HgerwSxWzKTuqfyhm/sn1+LX7fZSHwb7w2a7qH8Eopb+LH4Nho3g/g+2aC+SXtd6PlEEL4Gq/kcgV+abY7XvOvPPdGfxeb2RsVjFe6XvPwigLn4T/65uE/7Kr9XRFCeA0/R6/Fz7PnKSuhH47fj/oCr0RxYXQc1dR/8HsyC/BKIKeUM95ReAWb9/Dj5j7KLok+i9caXWBmpaW2s4mOh2hfPINXoio9ZkZG082O/lbkOuAQM/vGzK6vbIUqOg5qqKLzJZNT8WN8KX6L4cFqLKvG283MzrO1b9dkZNENM6mEmY3AbygOizuW8pjZOGB+COGCuGPJtVzvj6hE+i6wXtp1/WzNPwDdo3uaUgtmNhm/CjMm7ljyVRK+v6orSSUvkZwyswPNbD0za4X/4p2Yi8QlIrWn5CVS5vf45dCP8arcf6h4dBGJiy4biohI4qjkJSIiiZOMBhjL0XqjjULnLl3iDkNERGph+vTpX4cQ2lQ+ZplEJ6/OS5YwrW9fGDYMhgyBZs3iDklERKrJzKrdykbyLxtOnAi//S20bQvHHQfPPgurV1c+nYiIJFayk9c228B118EOO8B338Ftt8Gee0KnTnDWWfD223FHKCIiOZDo2oYlJSVh2rRp/ubDD+GOO2D8eJgzp2ykrbf2y4qHHw4dK2oCTkRE4mBm00MIJdWapt4kr1IhwNSpnsTuvhuWLPHhZtC/PwwdCgcfDC1b1nW4IiKSQU2SV7IvG2ZiBrvsAjfcAF9+CQ89BL/5DTRpAs89B8cfD5ts4sMeeghWrow7YhERqab6l7xSNWkC++0H99wDCxfC2LGw++6esO67Dw44ADbdFE46CV5+2UttIiKS9+rfZcOqmDcP7rrLLy2+807Z8C5d/LLisGHQo0f2AhURkXIl+p5X1Ir3qXjvp5NCCKMrm6bGySvV2297ErvzTvg8pS+8khJPYocd5tXwRUQkJ/LunpeZ3WpmX5nZu2nDB5rZh2Y228zOAQghvB9COBE4FOiby7jWss02cOWV8OmnMGkSHHsstGgB06bBaadB+/YwaJDXZPzhhzoLS0REypfre17jgIGpA8ysITAK71StJ3C4mfWMPtsP75TvsRzHta6GDWGPPeDWW/3+2N13e6sdZvDEE14Ka9sWjjwSnnwSVqmnDBGRuOQ0eYUQpuA9+qbqA8wOIXwS9UY7Ae+5lRDCwyGEQXivnRmZ2XAzm2Zm0xYtWpSbwJs1g0MPhYcf9hqLo0bBzjt7yWv8eBg4EDp0gNNPhzfeUEUPEZE6Fkdtw/Z41+Kl5gPtzay/mV1vZjdRQckrhHBzCKEkhFDSpk212nGsmdaty2ojzp4NF10E3bt76WzkSNh+e+jZEy69FObOzX08IiKSP1XlQwiTQwinhBB+H0IYFXc8GXXrBn/9q7fm8eqrcPLJ0KYNfPABXHCB11b81a/gppvKHo4WEZGsiyN5fQ6kttPUIRpWZWY2xMxuXrZsWVYDq0YA0KcPXH+911B89FFvfqpZM3jxRTjxRH8Q+sAD4f77YcWKeOIUEamncl5V3sw6A4+EELaK3jcCPgL2xJPW68ARIYSZ1Z13VqrKZ9N338EDD/h9sUmTYM0aH15U5C16DBvmJbMGeVPgFRGJXT5Wlb8LmAr0MLP5Zva7EMIq4E/Ak8D7wD01SVx5qUULOOooeOopfxD6mmtgu+1g2TIYM8bbVuzcGc49F2bWj1UWEYlD3jykXBN5V/Iqz8yZ/pzYHXfAZ5+VDe/Vq6zF+3btYgtPRCROiW5hozrMbAgwpLi4+IRZs2bFHU7VrVnj98TGj/f2Fkvv2Zl5P2TDhsFBB3kJTkSkQBRM8iqVmJJXJitWwGOPeSJ79NGy1u2bNYP99/dEtvfe0LhxvHGKiORY3t3zkgo0beqlrP/+1x+Evukmr8yxfDlMmAD77uuXEk8+GV5/Pe5oRUTyipJXPthwQxg+HKZM8V6gL70UttgCvv4a/vUvr5Z/0kmqci8iEklk8or9Oa9c6twZzjvPK3m88YY3DtykCYwe7Z1sfvxx3BGKiMQukckrhDAxhDC8qKgo7lByx8yr2V97rTdN1bUrzJgBvXv7g88iIgUskcmr4Gy/PUyf7i12fPstHHKIl8hKK3mIiBQYJa+kaNnSS1wjR0KjRnDddV7BQ40Bi0gBSmTyqtf3vCpiBqee6s+KbbYZvPaaX1p8+OG4IxMRqVOJTF4Fcc+rIjvu6Pe/9t0Xli7158L+8hf4+ee4IxMRqROJTF6CV69/6CG48krvBfrqq73txHnzKp1URCTplLySrEEDL3E9/zy0b++1ErfbDh5/PO7IRERySsmrPujb1y8j7rMPLF4Mgwf7s2KrVsUdmYhITiQyeRVshY2KtGnjbSVeeqmXyC6/3Bv7/eKLuCMTEcm6RCavgq+wUZ4GDbzENWmS9+Q8ZYp3u/LMM3FHJiKSVYlMXlKJ/v3hzTe95LVokbdOP2IErF4dc2AiItmh5FVftW0LTz7pSQvgoov8ntjChbGGJSKSDUpe9VnDhnDhhfDUU7Dxxn45sVcvmDw57shERGpFyasQDBjgtRF32w0WLPDLiZdd5j07i4gkkJJXoWjXzitunHeeJ63zz4df/9r7DBMRSZhEJi9Vla+hRo28Kv1jj8FGG8ETT/hlxJdeijsyEZFqSWTyUlX5Who0yC8j7rILfP65X0686ipdRhSRxEhk8pIs6NjRK26ceaZXoT/rLG/gd8mSuCMTEamUklcha9zYS1wPPwytWsEjj3jbiK++GndkIiIVUvISGDIE3ngD+vSBzz7zTi5HjoQQ4o5MRCQjJS9xnTvDCy94Z5c//wynnw4HH+z9hYmI5BklLynTpImXuO67DzbYAB54AHr3hunT445MRGQtSl6yroMP9suIvXvDnDleK3HUKF1GFJG8oeQlmXXr5s9/nXQSrFwJf/oTHHqol8befBP0jJ2IxMhCAn9Nm9kQYEhxcfEJs2bNijuc+u/uu+H44+H779ce3rIldOmS+dW5MzRrFke0IpIwZjY9hFBSrWmSmLxKlZSUhGnTpsUdRmGYNcsvHc6a5ZcS586F5csrnmaTTdZNaKX/d+zoVfVFpOApeUndCQG++soTWabXZ5/BqlXlT9+wIXTosHZy69oV+vWDTp3qbj1EJHZKXpI/Vq3ypqdSE9rcuWX/f/FF+RVAttrKnz3bd1/YcUdPdCJSbyl5SXL89BN8+unaye2DD+DZZ9e+t7bRRjB4sCezvfcGtWcpUu8oeUny/fSTPyw9caK/5swp+6xRI9h1Vy+RDRkCxcXxxSkiWaPkJfVLCF4ae+QRf7344tot3/fo4Yls332hb19VABFJKCUvqd+WLPE+yB55BB5/fO2mq1q2hIEDPZENHOiXG0UkEZS8pHCsWgUvv+yJbOJEL6GVatDAay2OGAG77x5biCJSNTVJXmphQ5Kp9P7XlVfC++/782cjR8KAAV47ccoU2GMPGDYMFi6MO1oRyTIlL6kfiou9Rfynn4avv4a//Q2aNoU77vB7Y6NHe6ebIlIvKHlJ/bPBBnD++TBzJgwa5O0wnnQS7LyzNzgsIomXyORlZkPM7OZlahxWKtK1Kzz6qHfx0r49vP467LCDl9C+/Tbu6ESkFhKZvEIIE0MIw4v0wKpUxsy7eHn/fTjjDH9//fWw+ebe4HCCKyyJFLJEJi+RamvRAq65xjvW3Gkn+PJLOOwwr1avnglEEkfJSwrLttt6P2U33wytWsFTT8HWW8NFF8GKFXFHJyJVpOQlhadBAzjhBPjwQzj6aG+SasQIT2JPPx13dCJSBUpeUrjatIFx4+D556FnT5g92xv/Pfxwb/VeRPKWkpfIrrvCjBlwxRXe+/OECf5s2DXXwM8/xx2diGSg5CUC0KQJnH2210rcf3/vluXMM/0e2TPPxB2diKRR8hJJ1akTPPggPPYYdO/uyWyvveCQQ7z/MRHJC0peIpkMGgTvvOOXEps3h/vvhy228GanVCtRJHZKXiLlWW89v5T4wQf+TNjy5fB//wdbbumt2YtIbJS8RCrToQPcdRc89xxstRV88on35Lzvvl5DUUTqnJKXSFX17+8N+44c6Y3/Pvqol8LOPx9++CHu6EQKipKXSHU0buwN+370ERx7LKxcCZdd5m0ljhkDP/4Yd4QiBUHJS6Qm2raFW2+FqVOhd2+YP99b7ejQAc46C+bMiTtCkXpNyUukNnbaCV57DcaPhz594Jtv4KqroFs32G8/b25KLdeLZJ2Sl0htNWwIQ4fCq6/668gj/fLixIne3NQWW8A//6k+xESyKK+Sl5kdYGa3mNndZrZ33PGIVFufPnD77TBvHlx6qV9G/PBDOOUU7xDzT3/yqvciUis5T15mdquZfWVm76YNH2hmH5rZbDM7ByCE8GAI4QTgROC3uY5NJGc23hjOO8/vfd13H+y2mzc5NWqUl8T694fRo2HhwrgjFUmkuih5jQMGpg4ws4bAKGAQ0BM43Mx6poxyQfS5SLI1auQ9OU+eDG+/Db//Pay/vrdkf9JJ0K4d7Lmn9y+2aFHc0YokRs6TVwhhCrAkbXAfYHYI4ZMQwkpgArC/ub8Dj4cQ3sg0PzMbbmbTzGzaIp3skiRbbw033ujdrdx+uz/k3LAhPPusJ7VNN/V7ZGPGwOLFcUcrktfiuufVHpiX8n5+NOxkYABwiJmdmGnCEMLNIYSSEEJJmzZtch+pSLYVFXmljokT/bLhbbd5W4pmXjvxhBNgk01g4EBPdrNnq8aiSJpGcQeQKoRwPXB93HGI1JlWreCYY/y1ZIm3aH/33TBpEjz5pL8ANtsMBgzwS4x77OHJTaSAxVXy+hzomPK+QzSsSsxsiJndvGzZsqwHJhKbDTeE447zhLVgAdxyC/zmNz78s8/8oeihQ/3y4tZbw2mneQPB330Xd+Qidc5CHVyOMLPOwCMhhK2i942Aj4A98aT1OnBECGFmdeZbUlISpk2bluVoRfLMmjXw1lveKeakSTBlirdwX6pRI39Yeq+9/LXDDj5MJCHMbHoIoaRa0+Q6eZnZXUB/oDWwELgwhDDWzAYDI4GGwK0hhEurO28lLylIP/0Er7ziyeyZZ7yFjzVryj4vKoLddy9LZsXFfj9NJE/lZfLKJSUvEWDpUu+u5emn/ZXeTUufPnDBBV67UUlM8lDBJC8zGwIMKS4uPmHWrFlxhyOSX+bO9RLZ00/DU095cgPo1cuT2IEHQoO8alxHClzBJK9SKnmJVOKHH/wB6Kuugi+/9GGlfZAdeqg/ZyYSs5okL/38EqnPmjeH00/33p9HjYKOHWHmTDjiCOjZE/7xD+9U87331KGmJIpKXiKFZOVKb93j8ss9oaXbeGPo3Bm6dIGuXaF7d6/wUVzsz5bpnpnkQMFcNtQ9L5FaWrXKH4aeMsXvkc2ZA59+6smtPM2bexLbay9vMb9JkzoLV+q3gklepVTyEsmiNWv8vlhpMvv4Y5g1y2svzp69dnuL++wD99/vCU2klmqSvPQko4i4Bg28z7H27aFv33U//+YbmDbNW/l48kkvgT36qDdxJVLHVGFDRKqmVStPWC++6G0tTp3q/ZSV1mIUqUOJTF5q21AkRr/8pSewzTeHd96Bfv0yV/4QyaEqJS8zW+caQqZhdSWEMDGEMLyoqCiuEEQKW8eO8MILUFLiiatfP38oWtXtpY5UteT1zyoOE5FC0bq1d6S5++5+6XDvvWGDDWCrreDoo+Gf/4Q3MvYpK1JrFVbYMLOdgV2ANmZ2RspHG+AN6opIIWvRAh57DP76Vy95vfuuPwQ9c6Y/TwbepuI11/jlRpEsqazk1QT4BZ7kWqS8vgUOyW1oIpIITZvClVfCjBnet9irr3prHsce68ntkUe8SaozzihrZ1Gklqr0nJeZdQohfFoH8VSJHlIWSYiFC70x4LFjIQS/1HjJJTB8uBoHlv/J2UPKZvZL4EygMymXGkMIe1QzxqzSQ8oiCTFjhvf8PGWKvz/mGBgzRg0DC5Dbh5TvBW4ExgCrqxuYiBS47baDyZPhnnvguONg3DjvVPPf/4bGjeOOThKoqslrVQhhdE4jEZH6zQx++1tvwWPwYLjrLlixAiZMUDuJUm1Vveg80cxOMrNNzWzD0ldOIxOR+qn0mbCWLeGBB+CggzyJiVRDVe95zckwOIQQumY/pKrTPS+RBJsxw5ubWrwYdtoJ9tsPttjCX926QSM1vVoocnbPK4TQpWYhiYiUo/Q+2J57wiuv+KtUkyZw1FHeWWaLFrGFKPmrqiWvozINDyHcnvWIqkBV5UXqkQULYOJEeP/9sten0ZM5xcV+b6ykWj/KJWFyWVU+tSmopsCewBshhFgfVNZlQ5F66r334PDD4e23/fLhpZfCmWfq2bB6qibJq0pHQgjh5JTXCUBvvOUNEZHs69nTW+o45RTv9fnss2HXXb2Cx6pVcUcneaCmP2N+AHQfTERyp2lTuO46b16qTRt46SWvmdi5M1x8McyfH3eEEqOqXjacCJSO2BDYArgnhHBODmOrlC4bihSIpUv9webRo+Gjj8qGd+0Ku+wCO+8MPXr4s2Sliou900zJe7m857VbyttVwKchhNh/9ih5iRSYELwbltGj4YknKu8/rGtX77Jl991hwABo27Zu4pRqyVnyimbeFtghevtaCOGrasaXdUpeIgVs1SrvguXll/31xRdrf/bWW/Dtt2tPs+223u9Yl5S7Hm3aeGJr2bJOwpZ15bLkdShwFTAZMOBXwF9CCPfVIM6sUfISkXKtXu0PQj/3HDzzjDcKXF5LHo0awW67+T21449Xc1V1LJfJ6y1gr9LSlpm1AZ4JIWxbo0izRMlLRKpsxQp48UW/7PjNNz4sBPjgA3jhBVizxodtvTXcdhtsv318sRaYXLYq3yDtMuFial5TsdZSHlKOKwQRSZqmTf3y4IAB6362eLH3CH3xxfDOO7Djjl49//TTvQ8yyTtVTUBPmNmTZnaMmR0DPAo8lruwKhZCmBhCGF5UVBRXCCJSn2y0ERx5pN8nO/VUL4Vddhlsuinsv78/X1bF+gFSNypMXmZWbGZ9Qwh/AW4CtoleU4Gb6yA+EZG6s/76MHKk3x8bNMgT1sMP+72www6rvHaj1JnKSl4jgW8BQgj/DSGcEUI4A3gg+kxEpP7p188vI86fD1df7Y0D33OPP0/28cdxRydUnrzahhDeSR8YDeuck4hERPLFJpvAn//sTVX16FF2P+yr2J8UKniVJa+WFXzWLItxiIjkry22gNde89Y8Fi+GW26JO6KCV1nymmZmJ6QPNLPjgem5CUlEJA9tsAFceKH/f+ONaiA4ZpVVlT8NeMDMhlKWrEqAJsCBOYxLRCT/DBgA3bvDrFneB9mB+hqMS4UlrxDCwhDCLsBFwNzodVEIYecQwoLchycikkcaNIA//tH/HzUq3lgKXJXbNsxHamFDROrc0qXQvj38+KP3+rz55nFHlHg564xSREQiLVvCsGH+/w03xBpKIVPyEhGprtJLhzfd5O0iSp1LZPIysyFmdvOyZcviDkVECtE223gzUitXwgEHeAUOqVOJTF5q21BEYnfNNbDvvrBkCQweDF9/HXdEBSWRyUtEJHYNG8Jdd8F228Hs2d4Sh9QZJS8RkZr6xS/g3ns9kd1xB3zySdwRFQwlLxGR2ujWDYYO9Z6br7wy7mgKhpKXiEhtnXsumHkPzJ9/Hnc0BUHJS0SktjbfHA4+2GsfXnNN3NEUBCUvEZFsOP98/3vttbDeetC8OZx8Mvz8c7xx1VNKXiIi2dCrFxx9tP+/cqU3H/Wvf8Hee3s3KpJVSl4iItkybhysWOGvqVNh001h8mTo0AFatYKOHWH8+LijrBeUvEREsmm99fy1007egeWOO3oyW7oU5s+HI49Um4hZoOQlIpIrHTp4CWzJEn9ddZUP/+Mfy/6XGlHyEhHJJTO/ZNiqFZx5pjfmawZnneX3xKRGKutJWUREsmn4cP/7+997bcRFi6BTp3XH22gj+PWvoZG+pjPRVhERqWvDh8P333t7iBdfXP54Rx/tDz6b1V1sCaHkJSIShzPOgE02gWeeWfezEODuu+Hf//YKH3/4Q93Hl+cshBB3DDVWUlISpk2bFncYIiLZd+ed3mZio0aw5ZZlwzfYAMaOhe7d44sty8xsegihpDrT5E3Jy8y6AucDRSGEQ+KOR0QkVkccAW+95Y39vvXW2p8NGwYvvVTQ98NyWtvQzG41s6/M7N204QPN7EMzm21m5wCEED4JIfwul/GIiCTK3//ufYXNmOGv117z6vevvQZXXx13dLHKdVX5ccDA1AFm1hAYBQwCegKHm1nPHMchIpJM3bp501O9esEOO8CYMT68tCX7zTf3Z8gKTE6TVwhhCpC+VfsAs6OS1kpgArB/VedpZsPNbJqZTVu0aFEWoxURSYB99vFaiqU1ED/8EEaMiDWkOMTxkHJ7YF7K+/lAezPbyMxuBLYzs3PLmziEcHMIoSSEUNKmTZtcxyoikn+uvhrWrPF7YQ0aeHNT775b+XT1SN7c7QshLAZOjDsOEZHE2GYbf9h59Gjo29drIlamTx+4915PegkWR/L6HOiY8r5DNKzKzGwIMKS4uDibcYmIJM8ll8CDD8KXX8K331Y+/vz5MHEi7F/luzV5KefPeZlZZ+CREMJW0ftGwEfAnnjSeh04IoQws7rz1nNeIiLA8uXw9deVj/ef/3inmf36wQsv5D6uKqrJc145TV5mdhfQH2gNLAQuDCGMNbPBwEigIXBrCOHSmsxfyUtEpBq++w4228y7Z7nkEm8/MVXjxnDQQbDhhnUaVt4lr1xT8hIRqaZzzvHnx8ozdGidd5iZ6BY2qkP3vEREaui887ztxPT7Y6tXwy23wP33w6hRUFQUT3xVpJKXiIi4/v3h+ee97cTjjquzxRZMyUtERHLgyCM9eY0c6f2MAQwcCNtuG2tYmajkJSIibtky2HRTr71YqkMH+OyznPYpVjAlL93zEhHJgaIif2Zs0iR/f9tt/lzYG2/A9tvHGlq6RD5iHUKYGEIYXpTnNxRFRBJn7729NuLf/+7V5sEfas4ziUxeIiJSB/bbz/8qeYmISGLssQesv75fNtx447VfXbp4h5gxSWTyMrMhZnbzsmXL4g5FRKT+atrUe20Gr32Y+po7F269NbbQVNtQRETKFwIsXuxdsJR6+23Yay/o3h0++qjWiyiY2oYiIlJHzKB167WH9e8PzZvDrFmwcCG0bVvnYSXysqGIiMSoUSPYaSf/P6b7XkpeIiJSff36+d8XX4xl8YlMXqqwISISs9Lk9fLLsSw+kclLDymLiMSsd2//+/bb3iJ9HUtk8hIRkZhtuKF3bLl8eVZqHFaXkpeIiNTMdtv53zffrPNFK3mJiEjN9Orlf2fMqPNFK3mJiEjNxFjy0kPKIiJSM6Ulr6efhpYtM4+zzTbexUrjxllddCJLXqoqLyKSBzbbDPr08f+XLcv8euEFeO+9rC86kclLVeVFRPKAGUydCt98k/nVt6+P98knWV+0LhuKiEjNNWhQ/iXD3r29+agcJK9ElrxERCQBunb1v0peIiKSGN26+V8lLxERSQyVvEREJHG6dPG/c+dmvf1DVdgQEZHcWH992GQTWLAAzjwTOnb04dtvD7vtVqtZK3mJiEju9OjhyWvkyLJhf/5zYSYvMxsCDCkuLo47FBERqcjIkTB+PKxZUzZs111rPVsLIdR6JnEpKSkJ06ZNizsMERGpBTObHkIoqc40qrAhIiKJo+QlIiKJo+QlIiKJo+QlIiKJo+QlIiKJo+QlIiKJo+QlIiKJo+QlIiKJo+QlIiKJo+QlIiKJk8jkZWZDzOzmZcuWxR2KiIjEIJHJK4QwMYQwvKioKO5QREQkBolMXiIiUtiUvEREJHGUvEREJHGUvEREJHGUvEREJHGUvEREJHGUvEREJHGUvEREJHGUvEREJHGUvEREJHGUvEREJHGUvEREJHGUvEREJHGUvEREJHGUvEREJHEaxR1AKTNrDtwArAQmhxDuiDkkERHJUzkteZnZrWb2lZm9mzZ8oJl9aGazzeycaPBBwH0hhBOA/XIZl4iIJFuuLxuOAwamDjCzhsAoYBDQEzjczHoCHYB50WircxyXiIgkWE4vG4YQpphZ57TBfYDZIYRPAMxsArA/MB9PYG9SQVI1s+HA8OjtT+mlunqqCFgWdxDUTRzZWkZt51OT6aszTVXHrcp4rYGvq7jcJCuU8yCb86/NvHJ9DqSO36may4EQQk5fQGfg3ZT3hwBjUt4fCfwLaA7cBowGhlZx3tNyHX8+vICb446hruLI1jJqO5+aTF+daao6blXG03lQv+LI5vxrM69cnwO1jS9vKmyEEH4Ajo07jjw1Me4AInURR7aWUdv51GT66kxT1XHzZd/ng3zZFrmOI5vzr828cn0O1HQZAFiU/XImumz4SAhhq+j9zsCIEMI+0ftzAUIIl9dg3tNCCCVZDFckcXQeSCGK4zmv14HuZtbFzJoAhwEP13BeN2cvLJHE0nkgBSenJS8zuwvoj99QXghcGEIYa2aDgZFAQ+DWEMKlOQtCRETqnZxfNhQREck2NQ8lIiKJo+QlIiKJo+QlIiKJU6+Sl5k1N7N/m9ktZjY07nhE6pqZdTWzsWZ2X9yxiORS3icvNe4rha4650AI4ZMQwu/iiVSk7uR98kKN+4qMo+rngEhByPvkFUKYAixJG/y/xn1DCCuB9MZ9IQHrJlIV1TwHRApCUr/g21NWwgJPWu2B/wIHm9lo8qcdNJFcyHgOmNlGZnYjsF1p02si9VHeNMybDWrcVwpdCGExcGLccYjkWlJLXp8DHVPed4iGiRQKnQNS0JKavLLZuK9IEukckIKW98kratx3KtDDzOab2e9CCKuAPwFPAu8D94QQZsYZp0iu6BwQWZca5hURkcTJ+5KXiIhIOiUvERFJHCUvERFJHCUvERFJHCUvERFJHCUvERFJHCUvkTpmZqvN7E0ze9fMJppZy1rM6/sshiaSGEpeInVveQihVwhhK7y1+D/GHZBI0ih5icRrKt5CPGbWx8ymmtkMM3vZzHpEw48xs/+a2RNmNsvMrkyfiZm1jqb9dR3HLxKLetWqvEiSRB1K7gmMjQZ9APwqhLDKzAYAlwEHR5/1ArYDfgI+NLN/hhDmRfNpi7dreEEI4ek6XAWR2Ch5idS9Zmb2Jl7ieh8oTThFwL/NrDsQgMYp00wKISwDMLP3gE54f16NgUnAH0MIz9dN+CLx02VDkbq3PITQC09ARtk9r0uA56J7YUOApinT/JTy/2rKfniuAqYD++QyYJF8o+QlEpMQwo/AKcCfzawRXvIq7ZPrmKrOBjgO2NzMzs56kCJ5SslLJEYhhBnA28DhwJXA5WY2g2pc0g8hrI6m38PMTspJoCJ5Rl2iiIhI4qjkJSIiiaPkJSIiiaPkJSIiiaPkJSIiiaPkJSIiiaPkJSIiiaPkJSIiifP/2g3AGw7EyJAAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAagAAAEYCAYAAAAJeGK1AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8+yak3AAAACXBIWXMAAAsTAAALEwEAmpwYAAAgJElEQVR4nO3debhcVZ3u8e+biSEMAUJHAglhEkVUwKOogE0DDkQQ2+uALTI4pL3Sio8iauNAKzjQ6sVrq3QURJBBQLDFdgAEw7WFYAKoQKBJMBgggAkECNJqwu/+sVaRnaJOnaqTs6t2Vb2f56nn1Nnjbw9Vb+219qmjiMDMzKxqxnW7ADMzs0YcUGZmVkkOKDMzqyQHlJmZVZIDyszMKskBZWZmleSAGkCSQtKu3a6jnqTVknbudh1VI2mppEPKmr6XSTpQ0r0dWtes/NqZUMb0/WpD9kNlA0rSP0hakN+0lkv6iaT9u11XI/16InZ6uyJis4i4u5VpqxqynSbpHEmndruOXiDpFEnfLXH5A/PBoFMqGVCSPgicAXwWmAbMBL4OHNHFsiqv3wKyW5RU8rVhtqF66n0iIir1ALYEVgNvajLNRqQAuz8/zgA2yuMOBO4FPgQ8BCwHjivMuwnwJeAe4FHgl8AmedxLgV8Bq4DfAAcW5vsF8DngRuAx4D+ArfO4PwCR614NvAzYFZiX17EC+N4w2zIrzzsnb8ty4MTC+HHAR4ElwErg4sJ6a/O+M9dw3TDr+HBe7v3AO/I8u+ZxrwVuztu0DDilMF+j7doFuCbXsgI4H5hSmGcp8DHgduAR4NvAxoXx7wYWAw8DPwSmF8YV6zoH+Brwn8DjwHxglzzuujztE7mut7RwXo3Px30F8Hvgn/IyJhSO72nAfwFP5uP3cuDX+Rj+Gnh53XYeUvj9FOC7G3pM8/i3k87PlcDJ9esqTDcH+Cvwl7wfrijUdiLw21z79+qOwWHALaTz/FfAC+q2a9h5G9TwbmBRPka3A/vk4c/N+3QVcBvwusI855A+cP4k1/1fwLNIr+NHgDuAvVs5p8iv98K004HvA3/Mx/n9efhr8n76a17nbwrvN2flY3QfcCowvnDOfJF0ztwNHE/hnKnbD+cBT5HOndXASYXz4BjSa2kFcHKbr+2G8zZY/znAmcBV+VjMA3ase20dD9yV90tt+RMK0/wCeFd+fizpvfGLeZ//Hji07n16g/fbiK/b0YRImY98Iq1ptjHAp4EbgL8BtiW9yD5TOGHX5GkmArOBPwFb5fFfywdi+7wjX04KvO3zSTI7nzivzL9vWzh49wF7ApNJL4L6N6Tiwb6Q9OYyDtgY2H+YbanNe2Fe7vNJL65D8vgT8rbukOv8d+DCunnPzfNuMsz+fLBQ9wWsHwQH5nWOA16Qp319k+3aNe+bjfK+vw44o+7N5FZgBrA16c3n1DzuoHzS7pPn/yqFUOWZAbUSeAkwgRSEFzWatjBsVZP9/B7SG9wOwFbA1TwzoP4APC+vbxrphfn2/Ptb8+/bFLZzpIAazTHdg/QG94o87suk8/kZAVXYT6fWDVtK+iA1PR+DRcB78ri9SR/c9iWd/8fk6Tcaad4G634T6TXxYkD53NiR9LpbDPwzMCkf98eB3Qs1rwBeRHptXEN6Azw613QqcG2L59SB5IAincMLgU/m9e5MeoN8df0xKiz78rz/J5PeT24E/rFwztxRWO+1NHmjbXBO1M6Db5I+GL8Q+DPw3DZe2w3nHeY8eJx1581XgF/WvV6uytuxCa0F1F9JH0DGA/+b9GFLY73fmubBWIbLWDyAtwEPjDDNEmB24fdXA0sLJ+yTdTv+IdLV0bg87oUNlvkR4Ly6YT8DjikcvM8Xxu1B+kQ2fpiDfS4wF9hhhG2pzfucwrDTgbPy80XAwYVx2+UTZ0Jh3p2bLP/surqfTYM398L4M4D/U1dbsw8LrwdurnuRvqfw+2xgSX5+FnB6YdxmeVtmFV5ExYD6Vt1y7qh7wTXchmHqvKb2Asq/H8IzA+rThfFvB26sW8b1wLGF7RwpoEZzTD/J+kE8OZ9n7QbUUXXrPjM//wb5w1xh/J3A3440b4N1/ww4ocHwA4AHgHGFYReSr85zzd8sjHsfsKjw+/OBVS2eUweyLqD2Bf5QV8vHgG/XH6P8+zTSm/4mhWFvJYdjPmeK630VowuoHQrDbgSObOE8aDrvMOdB8bzZDFgLzCi8Xg5qUFuzgFpcGLdpnv5ZY73fmj2q2Ba5EpgqaUJErBlmmumkJpCae/Kwp5dRN++fSAdsKukT25IGy9wReJOkwwvDJpLSv2ZZ3Ton5mU2chLwGeBGSY8AX4qIs4eZttGyn1+o63JJTxXGryWdJI3mrTed9KmyuOynSdoX+DzpCmsS6dPXJcMtTNI00qezA4DNSaH/yAjbUjs204GbaiMiYrWklaSr16UNVvdA4XntGI7W9Lq6Gu2z4rD6c4z8+/ZtrHM0x3S9OiPiibyP2lW/72rHYEfgGEnvK4yfxPqvn+HmrTeDxq+l6cCyiChuX/2+e7Dw/MkGv9cf6+HOqaIdgemSVhWGjQf+X6PiWXe1t1xSbdi4wrrqz5n686FVw53Hrby223kNFM+b1ZIeZv1taPY+0bTuiPhT3kebka6KOrHfKnmTxPWkdH59k2nuJx3cmpl52EhWAP9D6kept4x0BTWl8JgcEZ8vTDOjbp1/zcuM+oVFxAMR8e6ImA78I/D1Ee46q192bXuWkdp+i3VtHBH3FVfXZLnLGyy76AJSX9CMiNiS1I5dO+saLfezefjzI2IL4KjC9CNty3rHTdJkYBtSM1HZlpOaUmpmNJimuL315xikbanV+gTpU2XNsxosbzTHdL3jJWlT0j4aTrNj38gy4LS6dW8aERe2uZzashq9lu4HZtTdaFLcd6Mx3L6sr+f3ddu2eUTMzuPr99Uy0nvN1ML0W0TE8/L4kV479UZzLEZ6bbejeN7UgqS4n4r1PZF/jnQONzLW+21YlQuoiHiU1MzxNUmvl7SppImSDpV0ep7sQuDjkraVNDVPP+Lto/kT3dnAlyVNlzRe0sskbZTnP1zSq/PwjfPfWBTf1I6StEd+0/g0cGlErCX1LzxFavMGQNKbCvM+Qjo5ip+U6n0ib+vzgONIndOQAuM0STvm5W4r6YiRtrXgYuDYQt2fqhu/OfBwRPyPpJcA/1AY94ztytOvBh6VtD3pBox6x0vaQdLWpH642rZcCBwnaa+8zz8LzI+IpW1sT82DdXWN5GLgBEnbS5pCatJt5sfAs/OfO0yQ9BZSs+6P8vhbgCPzuTkEvLHBMkZzTC8FDpO0v6RJpPOs2eu03f3wTeA9kvbNdytOlvRaSZu3sYyabwEnSnpRXtaueZvmkz7tn5T3z4HA4cBFo1hHzXDnVNGNwOOSPiJpk/w63lPSi/P4B4FZteCMiOXAlcCXJG0haZykXST9bZ7+YuD9eb1bkW5oaKbdY7Ghr+16swvnzWeAGyKi4VVTRPyR9IHhqLyf3kHjDxuN5h3r/TasygUUQER8Cfgg8HHSm+Qy0l1XP8iTnAosIN1p9DtSs1GrfwtyYp7n16Q7yb5AaitfRrqN/Z8L6/ww6++j80htvQ+Qmgrfn+v9E/kOMEmrJL2U1HE8X9Jq0hXKCdH8b3zmkTqWfw58MSKuzMO/kue/UtLjpE7VfVvcViLiJ6R+pWvy8q+pm+S9wKfzsj9JOrlq8zbarn8h3eTwKOkOu8sarPYC0gl8N6kJ6NS8vKuBT5BuMFlOekEc2eq21DkF+E6u683w9B/6HjDM9N/MNf2WdNfij0k3H6xtNHFErCTd7fYhUrPzScBhEbEiT/KJXP8jpH1yQYPFtH1MI+I20l1PF5D20SOku1KHcxawR94PP2gyXW27FpA6vv8tL3sxqb+hbRFxCen8uIDUQf8D0l1ofyEF0qGkFoavA0dHxB2jWU/W8Jyqq2ct6ZjtRbrpYgUpRLfMk9SarldKqjU1H01q4qzdIXgpqS8I0jnzM9IdvTfR+Fwv+hzpg/MqSSe2sE0b9Npu4ALSB9CHSTegHDXC9O8mvcetJN0c9Ks21jXq/SbpTElntrKS2h0ZNgJJvyB1sH5rjJc7i/Rimtikz61nSFpK6mi9utu1NCPpUFLnf30z3lgsexZ9dEy7rVfOqW6SdA7pZpGPd7uWsVTJKyizsZabfGbn5rrtSZ80L+92XWY2PAeUDQqRmuIeITXxLSI1aZpZRbmJz8zMKslXUGZmVkmV+kPdqVOnxqxZs7pdhpmZddDChQtXRMS29cMrFVCzZs1iwYIF3S7DzMw6SFLDb5twE5+ZmVWSA8rMzCrJAWVmZpXkgDIzs0pyQJmZWSU5oMzMrJIcUGZmVkmlBZSk3SXdUng8JukDZa3PzMz6S2l/qBsRd5L+LwuSxpP+OZa/PdrMzFrSqSa+g4ElEdH8f9OvXt2ZaszMrPI69VVHR5L+3fczSJoDzAHYa/z4DpVjZmZVV/q/25A0CbgfeF5EPNhs2qEJE2LBGv8DUjOzQSJpYUQM1Q/vRBPfocBNI4WTmZlZUScC6q0M07xnZmY2nFIDStJk4JXAZWWux8zM+k+pN0lExBPANm3MUF4xZmbWU/xNEmZmVkkOKDMzqyQHlJmZVVK1Asp9UGZmllUroMzMzDIHlJmZVZIDyszMKqlaAeU+KDMzy6oVUGZmZpkDyszMKskBZWZmlVS9gHI/lJmZ4YAyM7OKckCZmVklVS+gnnqq2xWYmVkFVC+gfAVlZmY4oMzMrKIcUGZmVknVCyj3QZmZGVUMKF9BmZkZDigzM6soB5SZmVVS9QLKfVBmZkYVA8pXUGZmhgPKzMwqqnoB5SY+MzOj5ICSNEXSpZLukLRI0stGnMlXUGZmBkwoeflfAX4aEW+UNAnYdMQ5HFBmZkaJV1CStgReAZwFEBF/iYhVI864446wyy5w771llWZmZj2gzCa+nYA/At+WdLOkb0maXD+RpDmSFkhaAMCTT8Ldd8P8+SWWZmZmVVdmQE0A9gG+ERF7A08AH62fKCLmRsRQRAyx995wxBG1ESWWZmZmVVdmQN0L3BsRtUuhS0mB1aSacTBxYnrugDIzG2ilBVREPAAsk7R7HnQwcPuIM0q1BZRVmpmZ9YCy7+J7H3B+voPvbuC4EeeoBZT/HsrMbKCVGlARcQsw1NZM48bVZh7zeszMrHdU75sk3MRnZmY4oMzMrKKqG1DugzIzG2jVCyj3QZmZGVUMKDfxmZkZVQ4oN/GZmQ206gaUr6DMzAZa9QLKfVBmZkYVA8pXUGZmRpUDyn1QZmYDrboB5SsoM7OBVr2Ach+UmZlRxYByE5+ZmVHlgPIVlJnZQHNAmZlZJVUvoNwHZWZmVDGg3AdlZmZUOaB8BWVmNtAcUGZmVknVCyj3QZmZGVUMKPdBmZkZVQ4oX0GZmQ00B5SZmVVS9QKq1gflJj4zs4FWvYDyFZSZmQETyly4pKXA48BaYE1EDLUwU/rpgDIzG2ilBlT2dxGxouWpHVBmZkZnAqo9tT6o+fPhzDNbm0eCV74Sdt65vLrMzKyjyg6oAK6UFMC/R8TcEefYdNP084or0qNV++4LN9wwqiLNzKx6yg6o/SPiPkl/A1wl6Y6IuK44gaQ5wByAmTNnwjveAQ8/DKtXt7aGRx+Fiy6ClSvHunYzM+siRYf6eiSdAqyOiC8ON83Q0FAsWLCgvQUvXgy77Qa77JKem5lZT5G0sNFNdKXdZi5psqTNa8+BVwG3jvmK/HdTZmZ9qcwmvmnA5Up35U0ALoiIn475WnzXn5lZXyotoCLibuCFZS3/aQ4oM7O+VL1vkmiXA8rMrC/1fkC5D8rMrC/1fkD5CsrMrC85oMzMrJL6J6DcxGdm1ld6P6BqfVC+gjIz6yu9H1Bu4jMz60sOKDMzq6T+CSj3QZmZ9ZXeDyj3QZmZ9aXeDyg38ZmZ9aWWAkrSfq0M6wo38ZmZ9aVWr6C+2uKwzvMVlJlZX2r6beaSXga8HNhW0gcLo7YAxpdZWMvcB2Vm1pdG+ncbk4DN8nSbF4Y/BryxrKLa4isoM7O+1DSgImIeME/SORFxT4dqao/7oMzM+lKr/7BwI0lzgVnFeSLioDKKaouvoMzM+lKrAXUJcCbwLWBteeWMgvugzMz6UqsBtSYivlFqJaPlKygzs77U6m3mV0h6r6TtJG1de5RaWavcB2Vm1pdavYI6Jv/8cGFYADuPbTmj4CsoM7O+1FJARcROZRcyau6DMjPrSy0FlKSjGw2PiHPHtpxRcBOfmVlfarWJ78WF5xsDBwM3AdUJKF9BmZn1lVab+N5X/F3SFOCiMgpqWy2gzMysr4z23208AVSjX6oYUL6KMjPrG632QV1BumsP0pfEPhe4uMV5xwMLgPsi4rDRFNnCSlI4PfUUjK/Gd9iamdmGabUP6ouF52uAeyLi3hbnPQFYRPoG9HLUAspXUGZmfaPVPqh5kqax7maJu1qZT9IOwGuB04APjjD56NWa+Z7znP7vk9pmG7joIpg1q9uVmJmVqtUmvjcD/wr8AhDwVUkfjohLR5j1DOAk1v9XHfXLngPMAZg5c2Yr5TzTC14AN98MS5aMbv5esngxXH01vOtd3a7EzKxUrTbxnQy8OCIeApC0LXA1MGxASToMeCgiFko6cLjpImIuMBdgaGhodG10N9wA91Tzv4GMqZNPhksu8d98mdlAaDWgxtXCKVvJyHcA7ge8TtJs0t9ObSHpuxFx1CjqbG7SJNhttzFfbOVMmZJ+uq/NzAZAqwH1U0k/Ay7Mv78F+HGzGSLiY8DHAPIV1ImlhNMg8R8lm9kAaRpQknYFpkXEhyW9Adg/j7oeOL/s4qyOA8rMBshIV1BnkK+CIuIy4DIASc/P4w5vZSUR8QvSDRa2IWpfjOs+KDMbACP1I02LiN/VD8zDZpVSkQ3PV1BmNkBGCqgpTcZtMoZ1WCscUGY2QEYKqAWS3l0/UNK7gIXllGTDchOfmQ2QkfqgPgBcLultrAukIWAS8Pcl1mWN+ArKzAZI04CKiAeBl0v6O2DPPPg/I+Ka0iuzZ3JAmdkAafW7+K4Fri25FhuJA8rMBsho/x+UdYP7oMxsgDigeomvoMxsgDigeokDyswGiAOql7iJz8wGiAOql/gKyswGiAOqlzigzGyAOKB6iQPKzAaIA6qXuA/KzAaIA6qX+ArKzAaIA6qXOKDMbIA4oHqJm/jMbIA4oHqJr6DMbIA4oHqJA8rMBogDqpc4oMxsgDigeon7oMxsgDigeomvoMxsgDigeokDyswGiAOqlzigzGyAOKB6ifugzGyAlBZQkjaWdKOk30i6TdK/lLWugeErKDMbIBNKXPafgYMiYrWkicAvJf0kIm4ocZ39zQFlZgOktICKiABW518n5offWTdErYlv8WK44oru1tLPJNhvP9hqq25XYjbQyryCQtJ4YCGwK/C1iJhf5vr63qRJ6ecPf5geVp5DDoGrrup2FWYDrdSAioi1wF6SpgCXS9ozIm4tTiNpDjAHYObMmWWW0/ve8AaYPx9Wrep2Jf3r8cdh3jy4//5uV2I28EoNqJqIWCXpWuA1wK114+YCcwGGhobcBNjM9Olw3nndrqK/3XYb7Lmn+/nMKqDMu/i2zVdOSNoEeCVwR1nrMxsTvhHFrDLKvILaDvhO7ocaB1wcET8qcX1mG85/a2ZWGWXexfdbYO+ylm9WCl9BmVWGv0nCrMgBZVYZDiizoloTnwPKrOscUGZFtSso90GZdZ0DyqzITXxmleGAMityQJlVhgPKrMh9UGaV4YAyK3IflFllOKDMitzEZ1YZDiizIjfxmVWGA8qsyFdQZpXhgDIrch+UWWU4oMyKfAVlVhkOKLMi90GZVYYDyqzIV1BmleGAMityH5RZZTigzIrcxGdWGQ4osyI38ZlVhgPKrMgBZVYZDiizIvdBmVWGA8qsyH1QZpXhgDIrchOfWWU4oMyKHFBmleGAMityH5RZZTigzIrcB2VWGQ4osyI38ZlVhgPKrMgBZVYZpQWUpBmSrpV0u6TbJJ1Q1rrMxkytic99UGZdN6HEZa8BPhQRN0naHFgo6aqIuL3EdZptGF9BmVVGaQEVEcuB5fn545IWAdsDDiirruJdfAce2NVSKm/SJPjUp2C//bpdifWpMq+gniZpFrA3ML/BuDnAHICZM2d2ohyz4UkwYwYsWwbz5nW7mup71rMcUFaa0gNK0mbA94EPRMRj9eMjYi4wF2BoaMjtKtZdEtx0E9x6a7crqbarr4bTToM1a7pdifWxUgNK0kRSOJ0fEZeVuS6zMTN1qpv3RrJ8efrpm0msRGXexSfgLGBRRHy5rPWYWRf4ZhLrgDL/Dmo/4O3AQZJuyY/ZJa7PzDrFAWUdUOZdfL8EVNbyzayL/JVQ1gH+Jgkza5+/VNc6wAFlZu1zE591gAPKzNrngLIOcECZWfvcB2Ud4IAys/a5D8o6wAFlZu1zE591gAPKzNrnJj7rAAeUmbXPV1DWAQ4oM2uf+6CsAxxQZtY+X0FZBzigzKx97oOyDnBAmVn7fAVlHeCAMrP2uQ/KOsABZWbtcxOfdYADysza5yY+6wAHlJm1zwFlHeCAMrP2uQ/KOsABZWbtcx+UdYADysza5yY+6wAHlJm1zwFlHeCAMrP2uQ/KOsABZWbtcx+UdYADysza5yY+6wAHlJm1zwFlHeCAMrP21Zr43AdlJXJAmVn7fAVlHVBaQEk6W9JDkm4tax1m1iUOKOuACSUu+xzg34BzS1yHmXVDLaCeeAIWLuxuLb1is83g2c9et+9sRKUFVERcJ2lWWcs3sy6akN867rwThoa6W0svOftsOO64blfRMxQlXqLngPpRROzZZJo5wJz86+7AnaUVNHamAiu6XUSLXGs5XGs5XGs5ql7rjhGxbf3ArgdUL5K0ICJ64mOjay2Hay2Hay1HL9Va5Lv4zMyskhxQZmZWSWXeZn4hcD2wu6R7Jb2zrHV1wdxuF9AG11oO11oO11qOXqr1aaX2QZmZmY2Wm/jMzKySHFBmZlZJDqgGJM2QdK2k2yXdJumEPPwUSfdJuiU/Zhfm+ZikxZLulPTqDte7VNLvck0L8rCtJV0l6a78c6s8XJL+b671t5L26VCNuxf22y2SHpP0gSrt00ZfzzWa/SjpmDz9XZKO6VCd/yrpjlzL5ZKm5OGzJD1Z2L9nFuZ5UT5vFudtGfOvOBim1raPuaTX5GGLJX10rOtsUuv3CnUulXRLHt7t/Trce1TlztcNEhF+1D2A7YB98vPNgf8G9gBOAU5sMP0ewG+AjYCdgCXA+A7WuxSYWjfsdOCj+flHgS/k57OBnwACXgrM78L+HQ88AOxYpX0KvALYB7h1tPsR2Bq4O//cKj/fqgN1vgqYkJ9/oVDnrOJ0dcu5MdeuvC2HdmiftnXM82MJsDMwKU+zRydqrRv/JeCTFdmvw71HVe583ZCHr6AaiIjlEXFTfv44sAjYvsksRwAXRcSfI+L3wGLgJeVX2tQRwHfy8+8Ary8MPzeSG4ApkrbrcG0HA0si4p4m03R8n0bEdcDDDepoZz++GrgqIh6OiEeAq4DXlF1nRFwZEWvyrzcAOzRbRq51i4i4IdI71bms27ZSa21iuGP+EmBxRNwdEX8BLsrTdqzWfBX0ZuDCZsvo4H4d7j2qcufrhnBAjUDp2zD2BubnQf+UL5HPrl0+k06MZYXZ7qV5oI21AK6UtFDpq6MApkXE8vz8AWBaft7tWgGOZP0XehX3aU27+7EKdb+D9Gm5ZidJN0uaJ+mAPGz7XFtNp+ts55hXYZ8eADwYEXcVhlViv9a9R/Xi+TosB1QTkjYDvg98ICIeA74B7ALsBSwnXfJXwf4RsQ9wKHC8pFcUR+ZPcpX4ewJJk4DXAZfkQVXdp89Qpf04HEknA2uA8/Og5cDMiNgb+CBwgaQtulVf1jPHvOCtrP+hqhL7tcF71NN64XwdiQNqGJImkg78+RFxGUBEPBgRayPiKeCbrGtyug+YUZh9hzysIyLivvzzIeDyXNeDtaa7/POhKtRKCtGbIuJBqO4+LWh3P3atbknHAocBb8tvTuTmspX5+UJSX86zc03FZsCO1TmKY97Vc0HSBOANwPdqw6qwXxu9R9FD52srHFAN5Pbms4BFEfHlwvBiX83fA7W7fX4IHClpI0k7AbuROko7UetkSZvXnpM6y2/NNdXuyDkG+I9CrUfnu3peCjxaaBLohPU+iVZxn9Zpdz/+DHiVpK1y09Wr8rBSSXoNcBLwuoj4U2H4tpLG5+c7k/bj3bnWxyS9NJ/vRxe2rexa2z3mvwZ2k7RTvgI/Mk/bKYcAd0TE00133d6vw71H0SPna8u6fZdGFR/A/qRL498Ct+THbOA84Hd5+A+B7QrznEz6FHUnJdy106TWnUl3Nf0GuA04OQ/fBvg5cBdwNbB1Hi7ga7nW3wFDHax1MrAS2LIwrDL7lBScy4G/ktri3zma/UjqA1qcH8d1qM7FpL6E2vl6Zp72f+Xz4hbgJuDwwnKGSOGwhPTPRdWhWts+5vn199953MmdOv55+DnAe+qm7fZ+He49qnLn64Y8/FVHZmZWSW7iMzOzSnJAmZlZJTmgzMyskhxQZmZWSQ4oMzOrJAeUWUkkrVX6putbJV2h/A3jo1zW6jEszawnOKDMyvNkROwVEXuSvoT0+G4XZNZLHFBmnXE9+Us4Jb1E0vX5i0Z/JWn3PPxYSZdJ+mn+3zyn1y9E0tQ872s7XL9Zx03odgFm/S5/Jc7BpK+mAbgDOCAi1kg6BPgs6ZsJIH2B6t7An4E7JX01Ipbl5UwjffPCxyPiqg5ugllXOKDMyrOJ0n9g3Z70/3pqobIl8B1Ju5G+rmZiYZ6fR8SjAJJuJ/1Tx2V5mp8Dx0fEvM6Ub9ZdbuIzK8+TEbEXKWTEuj6ozwDX5r6pw4GNC/P8ufB8Les+RK4BFpL+wZzZQHBAmZUs0reLvx/4UP7XDVuy7l8aHNvqYkhf6vkcSR8Z8yLNKsgBZdYBEXEz6Zun3wqcDnxO0s200cweEWvz/AdJem8phZpViL/N3MzMKslXUGZmVkkOKDMzqyQHlJmZVZIDyszMKskBZWZmleSAMjOzSnJAmZlZJf1/hgoGJXuIRb8AAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "label_ids = np.where(labels)[1]\n",
    "#pruning_method='by_count_threshold'\n",
    "#pruning_method='by_independent_mi'\n",
    "pruning_method='by_cummulative_mi'\n",
    "pruned_completed_grouped_pam, pruned2groupid = prune_concepts_general(\n",
    "    completed_grouped_pam, method=pruning_method, label_ids=label_ids,\n",
    "    K=78, threshold=3, frac_threshold=0.9)\n",
    "pruned_dominant_concepts = np.array([dominant_concepts[gid] for gid in pruned2groupid])\n",
    "print(f\"When grouped pam (unpruned) is completed with substring lookup then pruned (threshold 3) we have {np.sum(pruned_completed_grouped_pam)} presences in PAM\")\n",
    "N, K = pruned_completed_grouped_pam.shape\n",
    "print(f\"There are {N} datapoints with {K} concepts\")\n",
    "pcg_datapoints_per_concept = count_datapoints_in_each_feature(pruned_completed_grouped_pam)\n",
    "plot_rank_versus_freq(pcg_datapoints_per_concept, lw=2, color='r')\n",
    "plt.title(\"Data-points per concept: grouped then completed then pruned.\")\n",
    "plt.tight_layout()\n",
    "pngfname = form_processed_fname(datastem, modelstem, 'png', identifier='pcg_datapoints_per_concept')\n",
    "plt.savefig(pngfname)\n",
    "\n",
    "plt.figure()\n",
    "pcg_concepts_per_datapoint = count_features_in_each_datapoint(pruned_completed_grouped_pam)\n",
    "plot_rank_versus_freq(pcg_concepts_per_datapoint, lw=2, color='r')\n",
    "plt.title(\"Concepts per datapoint: grouped then completed then pruned.\")\n",
    "plt.xscale('linear')\n",
    "plt.yscale('linear')\n",
    "plt.tight_layout()\n",
    "pngfname = form_processed_fname(datastem, modelstem, 'png', identifier='pcg_concepts_per_datapoint')\n",
    "plt.savefig(pngfname)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([  34,   22,    5,    7,    2,    0,  721,  436,   75,  232, 1134,\n",
       "         28, 1187,   73, 1023,  821,  123,   18,   19,  550,  142, 1105,\n",
       "        395, 1087,  973,  269,   16,  264,  141,  218,  968,  289,  250,\n",
       "        148,   36,  186, 1125,  163,  111,  549, 1093, 1108,  129,  338,\n",
       "         64,  274,   62,  109,  785, 1121,  449,  161,    9,  900, 1323,\n",
       "        214,  938,   56,  556,  143,   72,  332,  666,  105,   70,  677,\n",
       "        419,   44,   48, 1128,  901,   77,  787,  133,  202,   46,  664,\n",
       "       1166])"
      ]
     },
     "execution_count": 83,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pruned2groupid"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([  34,   22,    5,    7,    2,    0,  721,  436,   75,  232, 1134,\n",
       "         28, 1187,   73, 1023,  821,  123,   18,   19,  550,  142, 1105,\n",
       "        395, 1087,  973,  269,   16,  264,  141,  218,  968,  289,  250,\n",
       "        148,   36,  186, 1125,  163,  111,  549, 1093, 1108,  129,  338,\n",
       "         64,  274,   62,  109,  785, 1121,  449,  161,    9,  900, 1323,\n",
       "        214,  938,   56,  556,  143,   72,  332,  666,  105,   70,  677,\n",
       "        419,   44,   48, 1128,  901,   77,  787,  133,  202,   46,  664,\n",
       "       1166, 1223,  644,  870, 1314,  501,   41,  386,  139,  140,  102,\n",
       "        136,   88,  284,  220, 1082,  382,  162,   45,  307,  471, 1367,\n",
       "         20])"
      ]
     },
     "execution_count": 84,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "reorder"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Merging data-points\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ids.size = 2126\n",
      "np.unique(ids).size = 1920\n"
     ]
    }
   ],
   "source": [
    "print(f\"ids.size = {ids.size}\")\n",
    "print(f\"np.unique(ids).size = {np.unique(ids).size}\")\n",
    "\n",
    "unique_ids, merged_pam = merge_datapoints_by_id(ids, pruned_completed_grouped_pam)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Writing groupings to 20210504_lg_concept_groupings_by_cummulative_mi.csv\n"
     ]
    }
   ],
   "source": [
    "csvfname = form_processed_fname(datastem, modelstem, 'csv', identifier=f'concept_groupings_{pruning_method}')\n",
    "groupings_to_csv(csvfname, grouped_concept_ids, concepts, concept_counts,\n",
    "    orderby='pruned_id', pruned2groupid=pruned2groupid)\n",
    "#\n",
    "pklfname = form_processed_fname(datastem, modelstem, 'pkl', identifier=f'mpcg_ids_and_pam_{pruning_method}')\n",
    "to_store = dict(\n",
    "    unique_ids=unique_ids, merged_pam=merged_pam, concepts=concepts,\n",
    "    grouped_concept_ids=grouped_concept_ids, pruned2groupid=pruned2groupid,\n",
    "    pruned_dominant_concepts=pruned_dominant_concepts)\n",
    "if pruning_method == 'by_independent_mi':\n",
    "    merged_label_ids = get_merged_label_ids(labels, ids)\n",
    "    mi_scores = calc_independent_mis(merged_pam, merged_label_ids) \n",
    "    to_store['mi_scores'] = mi_scores\n",
    "pickle.dump(to_store, open( pklfname, \"wb\" ))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "grouped_concepts[:3] = [['the batter hit the ball on the ground', 'the batter hit the ball on the ground to the second baseman', 'the batter grounded out to the second baseman', 'the batter made contact with the pitch and hit it on the ground to the shortstop', 'the batter hit it into play on the ground', 'the batter hit a ground ball to the shortstop', 'the batter hit a ground ball to first baseman', 'then the batter hit the ball on the ground to the second baseman', 'the batter hit a ground ball', 'the batter grounded the ball to the shortstop', 'the batter hit the ball through the infield', 'the batter swung and hit the ball on the ground', 'the batter hit the ball which bounced on the ground towards the second baseman', 'the batter hit ball on the ground', 'the batter hit the ball on the ground to the shortstop', 'the batter hit a ground ball to second baseman', 'the batter hit a ground ball to second base', 'the batter hit a ground ball to the first baseman', 'then the batter hit the ball on the ground', 'the batter hit the ball on the ground between the first and second baseman', 'the batter hit the ball into the ground in play', 'the batter hit the ball on the ground in play', 'the batter hit a groundball to the first baseman', 'the batter swung and hit the ball on the ground towards the', 'then the batter hit a ground ball to the shortstop', 'the batter hit the ball to the shortstop on the ground', 'the batter hit the ball on the infield', 'the batter hit a ground', 'the batter hit a ground ball between first and second base', 'it was hit on the ground to the second baseman', 'the batter hit the pitch on the ground between the first baseman and the second baseman', 'the batter hit the ball on the ground to the second', 'batter hit the ball on the ground', 'the batter hit the ball on the ground before reaching the shortstop', 'then the batter hit it on the ground', 'the batter hit a ground ball to the second baseman', 'the batter hit the ball which landed on the ground in the field of play'], ['the batter hit a grounder to the second baseman', 'the batter hit it to second baseman'], ['then the ball was in the strike zone', 'it was in the strike zone', 'the ball landed within the strike zone', 'the ball landed in the strike zone', 'the ball went through the strike zone', 'the ball went into the strike zone', 'it went through the strike zone', 'the ball landed on edge of the strike zone', 'it went into the strike zone', 'the ball was in the strike zone', 'the ball crossed into the strike zone', 'ball was thrown in the strike zone', 'the ball went right into the strike zone', 'it passed through the strike zone', 'it to be in the strike zone', 'it entered the strike zone', 'the ball crossed the strike zone', 'it landed in the strike zone', 'ball was in the strike zone', 'the ball hit the strike zone', 'it went in the strike zone', 'the ball crossed the strike zone thus a strike', 'the ball landed on the edge of the strike zone']]\n",
      "pruned_grouped_concepts[:3] = [['the batter swung and hit the ball into play', 'the batter hit the ball', 'the batter hit it', 'the batter made contact with the ball', 'the batter swung and made contact with the ball', 'the batter swung and hit the ball', 'the batter struck the ball', 'then the batter made contact with the ball', 'the batter swung at the pitch and made contact', 'the batter made contact with ball', 'the batter hit the ball to one of the', 'batter hit the ball', 'batter made contact on the ball', 'batter hit it in play', 'the batter swung and made contact', 'the batter swung and hit the ball on the', 'the batter hit and put the ball into play', 'the batter put the ball into play', 'the batter hit the ball with the bat', 'the batter hits the ball', 'the batter swung the ball and hit it', 'the batter swung his bat and hit the ball', 'the batter hit', 'the batter hit the', 'the batter swung at it and hit the ball with his bat', 'the batter swung at the ball and hit it', 'the batter hit the ball with his bat', 'the batter swung at the ball and hit the ball', 'batter hit a', 'batter hit the', 'the batter hit the ball into play on the', 'the batter went for the swing and hit the ball', 'the batter hit it in play', 'the batter swung hit the'], [\"the batter didn't swing\", 'the batter did not swing at it', 'the batter did not swing', 'the batter did not swing at the ball', \"the batter didn't swing at it\", 'the batter didnt swing', 'the batter did not swing at the pitch', 'then the batter did not swing at it', 'then the batter did not swing', 'batter did not swing', \"the batter didn't swing at the pitch\", 'the batter did not swing his bat', \"the batter doesn't swing\", 'the batter did not swing the bat', 'the batter didnt swing at', \"the batter didn't swing the bat\", 'the batter did not swing at the pitch with his bat', 'the batter did not swing at the', 'the batter did not swing or make contact', 'batter didnt swing', \"batter didn't swing\", \"the batter didn't swing on a\", 'the batter did not swing on it'], ['the batter swung right over the pitch and missed it', 'the batter swung at the pitch and missed it completely', 'the batter swung at it and missed the ball completely', 'the batter swung and missed', 'the batter swung at the pitch and missed for a strike', 'then the batter swung hard and missed', 'then the batter swung but missed', 'the batter swung and missed the pitch', 'the batter swung at the ball and missed', 'then the batter swung at it and missed', 'the batter swung and missed it', 'the batter swung at and missed the pitch', 'the batter swung and missed for a strike', 'the batter swung at the ball without making contact', 'the batter swung at the outside pitch but missed', \"the batter swung but didn't hit the ball\", 'the batter swung and missed the ball', 'the batter swung and missed for strike two', 'the batter swung at the ball and missed it', 'the batter swung and did not make contact with the', 'and the batter swung and missed', 'then the batter swung and missed', 'the batter swung at the ball but missed', 'the batter swung and missed the', 'batter swung and pitch and missed the ball which is a', 'batter swung at pitch and missed ball which is a strike', 'the batter swung at the pitch and missed making it a strike', 'the batter swung hard and missed the ball', 'then the batter swung at the pitch and missed the ball without making contact', 'the batter swung but did not make contact with the ball', 'then the batter swung extremely hard missing the ball', 'batter swung and missed the ball', 'the batter swung his bat at the ball and missed', 'then the batter swung at the pitch and missed', 'the batter swung and missed at the pitch', 'the batter swung at and missed', 'and the batter swung and missed it', 'the batter swinged and missed the ball', 'the batter swung the bat and did not make contact with the ball', 'the batter swung at a pitch and missed striking out', 'the batter swung and did not make contact with the ball', 'then the batter swung and missed the ball', 'the batter swung at the pitch and missed making contact', 'and the batter swung at the ball and missed for a strike', 'the batter swung but missed the ball', \"then the batter swung and didn't make contact\", \"then the batter swung at but didn't make contact with the pitch\", 'the batter swung the bat but missed the ball', 'the batter swung and missed hitting the ball', 'the batter swung anyway and missed making it a strike', 'the batter swung and missed striking out', 'the batter struck out and took a swing and a miss', 'the batter swung and did not make contact', 'then the batter swung at the ball and missed for a strike', 'then the batter swung on the pitch but missed', 'the batter swung at the pitch but did not make contact with the ball', 'the batter swung at the pitch and missed', 'the batter swung at it and missed', 'the batter swung at the pitch but did not hit it', 'the batter swung the bat at the pitch but missed', 'then the batter swung hard missing the ball']]\n",
      "grouped_concept_counts[pruned2groupid[0]] = 141\n",
      "grouped_concept_counts[pruned2groupid[1]] = 248\n",
      "grouped_concept_counts[:204] = [ 54   2  62   3   6 143   2  51   5  14   3   2   2  10   5   7  27   2\n",
      "  18   2   3   2 248   4   3   2   2   5  38   2  12   3   2   3 141   5\n",
      "  10   2   2   6   2   3   2   2   5   4   4   1   5   2   2   2   2   2\n",
      "   3   4   6   2   3   3   2   3   7   2  25   3   3   2   3  11   3   2\n",
      "   9  20   4   9   2   7   4   2   2   5   3   6   2   3   1   2   5   1\n",
      "   1   1   3   9   1   1   1   1   1   1   1   1   7   1   2   6   5   2\n",
      "   2   7   3   1   1   1   4   2   1   1   2   3   2   3   1  25   6   2\n",
      "   1   1   2   7   2   4   2   4   1   1   4   1   1   6   4   9  30   7\n",
      "   2   1   2   1   6   4   2   1   1   2   4   2   1   2   2   1   1   2\n",
      "   8   3   2   4   2   2   1   1   3   1   1   1   1   1   1   1   2   1\n",
      "   1   1   2   1   1   1   9   2   6   1   1   1   1   1   1   1   1   1\n",
      "   1   1   1   1   3   1]\n",
      "pruned_concept_counts = [141, 248, 143, 51, 62, 54, 7, 3, 9, 26, 46, 38, 6, 20, 2, 1, 25, 18, 2, 30, 30, 2, 12, 4, 2, 1, 27, 9, 9, 20, 2, 8, 10, 6, 10, 9, 3, 3, 1, 2, 8, 6, 7, 1, 25, 12, 7, 7, 3, 1, 1, 2, 14, 3, 1, 1, 2, 6, 3, 7, 9, 3, 3, 6, 3, 2, 2, 5, 5, 3, 3, 7, 1, 4, 3, 4, 1, 2]\n"
     ]
    }
   ],
   "source": [
    "pruned_grouped_concept_ids = [ grouped_concept_ids[gid] for gid in pruned2groupid]\n",
    "pruned_grouped_concepts = [ grouped_concepts[gid] for gid in pruned2groupid]\n",
    "pruned_concept_counts = [ grouped_concept_counts[gid] for gid in pruned2groupid ]\n",
    "print(f\"grouped_concepts[:3] = {grouped_concepts[:3]}\")\n",
    "print(f\"pruned_grouped_concepts[:3] = {pruned_grouped_concepts[:3]}\")\n",
    "print(f\"grouped_concept_counts[pruned2groupid[0]] = {grouped_concept_counts[pruned2groupid[0]]}\")\n",
    "print(f\"grouped_concept_counts[pruned2groupid[1]] = {grouped_concept_counts[pruned2groupid[1]]}\")\n",
    "print(f\"grouped_concept_counts[:204] = {grouped_concept_counts[:204]}\")\n",
    "print(f\"pruned_concept_counts = {pruned_concept_counts}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 88,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "When pruned completed grouped pam is row merged by id: \n",
      "\t1920 datapoints,\t78 concepts,\t4551 presences\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "print(f\"When pruned completed grouped pam is row merged by id: \")\n",
    "mpcg_N, mpcg_K = merged_pam.shape\n",
    "mpcg_M = np.sum(merged_pam)\n",
    "print(f\"\\t{mpcg_N} datapoints,\\t{mpcg_K} concepts,\\t{mpcg_M} presences\")\n",
    "\n",
    "mpcg_datapoints_per_concept = count_datapoints_in_each_feature(merged_pam)\n",
    "plot_rank_versus_freq(mpcg_datapoints_per_concept, lw=2, color='r')\n",
    "plt.title(\"Data-points per concept: grouped then completed then pruned then merged.\")\n",
    "plt.tight_layout()\n",
    "pngfname = form_processed_fname(datastem, modelstem, 'png', identifier='mpcg_datapoints_per_concept')\n",
    "plt.savefig(pngfname)\n",
    "\n",
    "plt.figure()\n",
    "mpcg_concepts_per_datapoint = count_features_in_each_datapoint(merged_pam)\n",
    "plot_rank_versus_freq(mpcg_concepts_per_datapoint, lw=2, color='r')\n",
    "plt.title(\"Concepts per datapoint: grouped then completed then pruned then merged.\")\n",
    "plt.xscale('linear')\n",
    "plt.yscale('linear')\n",
    "plt.tight_layout()\n",
    "pngfname = form_processed_fname(datastem, modelstem, 'png', identifier='mpcg_concepts_per_datapoint')\n",
    "plt.savefig(pngfname)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Summary information"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "In raw pam we have:\n",
      "\t2126 datapoints,\t1915 concepts,\t3039.0 presences\n",
      "When raw pam is grouped we have:\n",
      "\t2126 datapoints,\t1368 concepts,\t3037 presences\n",
      "When grouped pam (unpruned) is completed with substring lookup we have:\n",
      "\t2126 datapoints,\t1368 concepts,\t7054 presences\n",
      "When grouped pam (unpruned) is completed with substring lookup then pruned (threshold 3) we have: \n",
      "\t2126 datapoints,\t78 concepts,\t4699 presences\n",
      "When pruned completed grouped pam is row merged by id: \n",
      "\t1920 datapoints,\t78 concepts,\t4551 presences\n"
     ]
    }
   ],
   "source": [
    "print(f\"In raw pam we have:\")\n",
    "N, K = pam.shape\n",
    "M = np.sum(pam)\n",
    "print(f\"\\t{N} datapoints,\\t{K} concepts,\\t{M} presences\")\n",
    "\n",
    "print(f\"When raw pam is grouped we have:\")\n",
    "g_N, g_K = grouped_pam.shape\n",
    "g_M = np.sum(grouped_pam)\n",
    "print(f\"\\t{g_N} datapoints,\\t{g_K} concepts,\\t{g_M} presences\")\n",
    "\n",
    "print(f\"When grouped pam (unpruned) is completed with substring lookup we have:\")\n",
    "cg_N, cg_K = completed_grouped_pam.shape\n",
    "cg_M = np.sum(completed_grouped_pam)\n",
    "print(f\"\\t{cg_N} datapoints,\\t{cg_K} concepts,\\t{cg_M} presences\")\n",
    "\n",
    "print(f\"When grouped pam (unpruned) is completed with substring lookup then pruned (threshold 3) we have: \")\n",
    "pcg_N, pcg_K = pruned_completed_grouped_pam.shape\n",
    "pcg_M = np.sum(pruned_completed_grouped_pam)\n",
    "print(f\"\\t{pcg_N} datapoints,\\t{pcg_K} concepts,\\t{pcg_M} presences\")\n",
    "\n",
    "print(f\"When pruned completed grouped pam is row merged by id: \")\n",
    "mpcg_N, mpcg_K = merged_pam.shape\n",
    "mpcg_M = np.sum(merged_pam)\n",
    "print(f\"\\t{mpcg_N} datapoints,\\t{mpcg_K} concepts,\\t{mpcg_M} presences\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure()\n",
    "plot_rank_versus_freq(raw_datapoints_per_concept, lw=3, label='raw')\n",
    "plot_rank_versus_freq(g_datapoints_per_concept, lw=2, label='grouped')\n",
    "plot_rank_versus_freq(cg_datapoints_per_concept, lw=3, label='completed grouped')\n",
    "plot_rank_versus_freq(pcg_datapoints_per_concept, lw=2.5, label='pruned completed grouped')\n",
    "plot_rank_versus_freq(mpcg_datapoints_per_concept, lw=2, label='merged pruned completed grouped')\n",
    "plt.title(\"Data-points per concept\")\n",
    "#plt.xscale('linear')\n",
    "plt.yscale('linear')\n",
    "plt.ylim([None, 1500])\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "pngfname = form_processed_fname(datastem, modelstem, 'png', identifier=f'datapoints_per_concept_comparison_{pruning_method}')\n",
    "plt.savefig(pngfname)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 91,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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QnVC8ztPzoXyvYAkKBH5o4h8JyJbRWSeiER6sp5W8SkVWFVJUNVVWFjo1/2p4OH3BCUi5wOTgVRjTAIQBvzOk3W1ik/VNnPnziUpKYnu3btz4403As4SyeDBg0lKSmLIkCH8+OOPgPNb/x133EGfPn3o1KkTK1euZMKECXTr1o3x48fb22zQoAF//OMfiY+PZ8iQIWRlZZ2z3w0bNjBgwAAuvPBCRowYwf79+1m4cCHr169n7Nix9OjRg1OnTpW6nGv97t270717d2bMmFHqsRUVFXHnnXfStWtXhg0bxmWXXWaXWmJiYvjzn/9MSkoKCxYsYN68eSQmJpKQkMCf//znYsfisnDhQvs4x48fz+23305qaipdunSxu4kqLCzkvvvus4cUeeWVVwDnl9+77rqL2NhYhg4dysGDB6vycSkvC9RzUOFAlIjkA/WAcr+SRZxwDvn+ypZXWLJnCePixtGrdS/fR6mUJfGNRJ9s99tx35Y577vvvmPatGl89dVXtGjRgsOHDwNw9913M27cOMaNG8esWbOYPHkyixcvBuDIkSOsXr2aDz74gNGjR/Pll1/y2muv0bNnTzZv3kyPHj04ceIEqampPPPMM/z1r3/l0Ucf5YUXXrD3m5+fz913382SJUuIjo5m/vz5PPTQQ8yaNYsXXniB6dOnk5qaWu5yN998My+88AJpaWncd999pR7fe++9R2ZmJhkZGRw8eJBu3boxYcIEe37z5s3ZuHEjv/zyC3369GHDhg00bdqU4cOHs3jxYq644opyz21mZiZr165lz549DBo0iN27dzN37lwaN27MunXryMvLo1+/fgwfPpxNmzaxY8cOMjIyOHDgAHFxccViUYHh9wRljPlZRKYDPwKngGXGmGUllxORicBEgPNbdgJg55Gd7DyyEwcOTVCqxluxYgXXXHMNLVq0AKBZs2YArF69mvfeew+AG2+8kfvvv99e57e//S0iQmJiot1/H0B8fDyZmZn06NEDh8NhD9dxww03cOWVVxbb744dO9i6dSvDhg0DnKWO1q1bnxNfWcvl5OSQk5NDWlqaHePSpUvPWT89PZ1rrrkGh8PBeeedx6BBg4rNd8W4bt06Bg4cSHR0NABjx45l1apVFSaoa6+9FofDQefOnenUqRPbt29n2bJlbNmyxS6pHT16lF27drFq1Squv/56wsLCaNOm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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure()\n",
    "plot_rank_versus_freq(raw_concepts_per_datapoint, lw=3, label='raw')\n",
    "plot_rank_versus_freq(g_concepts_per_datapoint, lw=2, label='grouped')\n",
    "plot_rank_versus_freq(cg_concepts_per_datapoint, lw=2, label='completed grouped')\n",
    "plot_rank_versus_freq(pcg_concepts_per_datapoint, lw=2, label='pruned completed grouped')\n",
    "plot_rank_versus_freq(mpcg_concepts_per_datapoint, lw=2, label='merged pruned completed grouped')\n",
    "plt.title(\"Concepts per datapoint\")\n",
    "plt.xscale('linear')\n",
    "plt.yscale('linear')\n",
    "plt.ylim([0,10])\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "pngfname = form_processed_fname(datastem, modelstem, 'png', identifier=f'concepts_per_datapoint_comparison_{pruning_method}')\n",
    "plt.savefig(pngfname)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "metadata": {},
   "outputs": [],
   "source": [
    "datadir = form_data_dirname(datastem)\n",
    "csvfname = f\"{datastem}.csv\"\n",
    "file_info = np.array(get_file_info(datadir, csvfname, rows_to_remove=rows_to_remove))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "metadata": {},
   "outputs": [],
   "source": [
    "for i, row in enumerate(file_info):\n",
    "    if 'video' in row[0]:\n",
    "        print(f\"{i}: {row}\")\n",
    "        \n",
    "for c in concepts:\n",
    "    if 'video' in c:\n",
    "        print(f\"video in {c}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Random row with >=4 concepts uid= ZZOFCNXRNWWP\n",
      "ZZOFCNXRNWWP: the batter swung and missed at the pitch.\n",
      "\tgroup concept 5:the batter swung right over the pitch and missed it:the batter swung at the pitch and missed it completely:the batter swung at it and missed the ball completely\n",
      "\tgroup concept 1187:the batter swung\n",
      "\tgroup concept 18:the batter swung at the pitch:the batter swung and:the batter took a swing at the pitch\n",
      "\tgroup concept 1105:the batter\n"
     ]
    }
   ],
   "source": [
    "# find a random video with 4 or more concepts\n",
    "min_n_concepts = 4\n",
    "rich_rows = np.where(mpcg_concepts_per_datapoint >= min_n_concepts)[0]\n",
    "rand_rich_row = np.random.choice(rich_rows)\n",
    "these_pruned_concept_ids = np.where(merged_pam[rand_rich_row,:])[0]\n",
    "these_group_concept_ids = [pruned2groupid[id_] for id_ in these_pruned_concept_ids]\n",
    "uid = unique_ids[rand_rich_row]\n",
    "print(f\"Random row with >={min_n_concepts} concepts uid= {uid}\")\n",
    "for fname, uid2, label, text in file_info[file_info[:,1]==uid,:]: \n",
    "    print(f\"{uid2}: {text}\")\n",
    "for gid in these_group_concept_ids:\n",
    "    print(f\"\\tgroup concept {gid}:{':'.join(grouped_concepts[gid][:3])}\")\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Miscellaneous and deprecated"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "From this point some of the calculations may be stale."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Substring lookup method\n",
    "\n",
    "Take the existing pruned-grouped concepts, then use these to look up substrings in original text contributions."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# completing after the pruning.\n",
    "path = f'./data/{datastem}/surveys'\n",
    "pruned_grouped_concept_strings = [concept_group_labels[id_] for id_ in pruned_group_concept_ids]\n",
    "pruned_grouped_concept_ids = [concept_group_ids[id_] for id_ in pruned_group_concept_ids]\n",
    "\n",
    "pruned_concept_group_strings = pruned_concept_group_labels\n",
    "completed_pruned_grouped_pam = np.copy(pruned_grouped_pam)\n",
    "completed_pruned_grouped_pam = complete_pam_with_substrings(\n",
    "    path, completed_pruned_grouped_pam, pruned_grouped_concept_ids, pruned_grouped_concept_strings, rows_to_remove=rows_to_remove)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "len(concept_group_ids)\n",
    "pruned_group_concept_ids\n",
    "print(f\"Completed with substring lookup we have {np.sum(completed_pruned_grouped_pam)} presences in PAM\")\n",
    "\n",
    "cpg_datapoints_per_concept = count_datapoints_in_each_feature(completed_pruned_grouped_pam)\n",
    "plot_rank_versus_freq(cpg_datapoints_per_concept, lw=2, color='r')\n",
    "plt.title(\"Data-points per concept: grouped then pruned then completed.\")\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"data_points_per_concept_grouped.png\")\n",
    "\n",
    "plt.figure()\n",
    "completed_prngrp_concepts_per_datapoint = count_features_in_each_datapoint(completed_pruned_grouped_pam)\n",
    "plot_rank_versus_freq(completed_prngrp_concepts_per_datapoint, lw=2, color='r')\n",
    "plt.title(\"Concepts per datapoint: grouped then pruned then completed.\")\n",
    "plt.xscale('linear')\n",
    "plt.yscale('linear')\n",
    "plt.tight_layout()\n",
    "plt.savefig('concepts_per_datapoint_grouped_then_pruned_then_completed.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "ids.size"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.unique(ids).size"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "ids[:10]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.sum(np.abs(np.sum(merged_pam, axis=0)-985) <= 500 ) \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "merged_pam.shape"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Mutual information with label"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Independent MI Scores"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "#label_ids = np.where(labels)[1]\n",
    "#label_ids = merge_datapoints_by_id(ids, label_ids.reshape((-1,1)))[1].flatten()\n",
    "#merged_label_ids = get_merged_label_ids(labels, ids)\n",
    "#mi_scores = calc_independent_mis(merged_pam, merged_label_ids) \n",
    "mi_scores = calc_independent_mis(completed_grouped_pam, label_ids) \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "K = 100\n",
    "plt.figure(figsize=(20,5))\n",
    "reorder = np.argsort(mi_scores)[::-1][:K]\n",
    "xs = np.arange(completed_grouped_pam.shape[1])[:K]\n",
    "plt.plot(xs, mi_scores[reorder])\n",
    "plt.xticks(xs)\n",
    "plt.gca().set_xticklabels(dominant_concepts[reorder], rotation='vertical')\n",
    "plt.title(\"Best grouped concepts ranked by independent MI with label\")\n",
    "plt.xlabel(\"Rank\")\n",
    "plt.ylabel(\"MI\")\n",
    "\n",
    "plt.tight_layout()\n",
    "pngfname = form_processed_fname(datastem, modelstem, 'png', identifier=f'independent_mutual_information')\n",
    "plt.savefig(pngfname)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "sorted_mi_scores = np.sort(mi_scores)[::-1]\n",
    "summed_mi_scores = np.array([ np.sum(sorted_mi_scores[:k]) for k in range(sorted_mi_scores.size)])/np.sum(sorted_mi_scores)\n",
    "\n",
    "plt.figure(figsize=(12,3))\n",
    "plt.plot(np.arange(sorted_mi_scores.size), summed_mi_scores)\n",
    "thresholdFrac = 0.9\n",
    "filter_ = summed_mi_scores < thresholdFrac\n",
    "plt.plot(np.arange(sorted_mi_scores.size)[filter_], summed_mi_scores[filter_])\n",
    "thresholdK = np.where(filter_)[0][-1]\n",
    "print(f\"thresholdK = {thresholdK}\")\n",
    "plt.vlines(thresholdK,0,summed_mi_scores[thresholdK], 'r', linestyle=':')\n",
    "plt.hlines(summed_mi_scores[thresholdK], 0, thresholdK, 'r', linestyle=':', lw=2)\n",
    "plt.text(\n",
    "    thresholdK+10, summed_mi_scores[thresholdK]/2., f\"First {thresholdK} concepts...\",\n",
    "    color='r', rotation='vertical', verticalalignment='center' )\n",
    "plt.text(\n",
    "    thresholdK/2., summed_mi_scores[thresholdK]*1.05,\n",
    "    f\"...contain {thresholdFrac:.1f} proportion of summed independent MI with label\",\n",
    "    color='r', horizontalalignment='center' )\n",
    "\n",
    "\n",
    "plt.title(\"Normalised summed independent MI for K independently most informative concepts\")\n",
    "plt.ylabel(\"Normalised summed MI\")\n",
    "plt.xlabel(\"Rank\")\n",
    "pngfname = form_processed_fname(datastem, modelstem, 'png', identifier=f'summed_independent_mutual_information_K{thresholdK}')\n",
    "plt.savefig(pngfname)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "ranks = np.argsort(mi_scores)[::-1]\n",
    "\n",
    "np.where(ranks == 188)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "joint_concept = np.sum(merged_pam[:,[183,188]]*np.array([[2,1]]), axis=1)\n",
    "mi183 = sklearn.metrics.mutual_info_score(merged_pam[:,183], label_ids) \n",
    "mi188 = sklearn.metrics.mutual_info_score(merged_pam[:,188], label_ids) \n",
    "joint_mi = sklearn.metrics.mutual_info_score(joint_concept, label_ids)\n",
    "\n",
    "print(f\"mi183 ={mi183}\")\n",
    "print(f\"mi188 ={mi188}\")\n",
    "print(f\"joint_mi ={joint_mi}\")\n",
    "print(f\"joint_mi - mi183 ={joint_mi - mi183}\")\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Cummulative MI scores with greedy algorithm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "N, J = completed_grouped_pam.shape\n",
    "full_cum_mis, reorder = calc_cummulative_mi(completed_grouped_pam, label_ids, threshold=0, maxK=None)\n",
    "condition_Js = list(reorder)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "discarded = np.array([ j for j in range(J) if not j in condition_Js])\n",
    "extended_cum_mis = list(full_cum_mis) + [full_cum_mis[-1]]*discarded.size\n",
    "extended_cum_mis = np.array(extended_cum_mis)\n",
    "extended_reorder = np.array(list(reorder)+list(discarded))\n",
    "lastK = np.where(extended_cum_mis > 0)[0][-1]\n",
    "extended_cum_mis[extended_cum_mis == 0] =extended_cum_mis[lastK]\n",
    "plt.plot(np.arange(extended_cum_mis.size), extended_cum_mis)\n",
    "plt.title(f\"Cumulative mutual information for greedy method with threshold={1}\")\n",
    "plt.xlabel(\"Concept sequence by MI\")\n",
    "plt.ylabel(\"Cumulative Mutual Information\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_ranked_datapoints_per_concept(pam, reorder):\n",
    "    # how does the mi rank compare with the total number of data-points per concept\n",
    "    datapoints_per_concept = count_datapoints_in_each_feature(pam)[reorder]\n",
    "    plt.plot(np.arange(reorder.size), datapoints_per_concept)\n",
    "    plt.xlabel('Concept rank by cummulative mutual information')\n",
    "    plt.ylabel(\"Data-points per concept\")\n",
    "    plt.yscale('log')\n",
    "plt.figure()\n",
    "plot_ranked_datapoints_per_concept(completed_grouped_pam, extended_reorder)\n",
    "plt.title(f\"Concept rank by cummulative MI vs num data-points (threshold={1})\")\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Threshold $K$ as a portion of the whole"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "222"
      ]
     },
     "execution_count": 64,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "### How many datapoints at this threshold\n",
    "threshold = 3\n",
    "np.sum(count_datapoints_in_each_feature(completed_grouped_pam)>=threshold)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "..................................................................................................."
     ]
    }
   ],
   "source": [
    "maxK = 100\n",
    "cum_mis, reorder = calc_cummulative_mi(completed_grouped_pam, label_ids, threshold=threshold, maxK=maxK)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "completed_grouped_pam.shape = (2126, 1368)\n",
      "np.sum(completed_grouped_pam,axis=0).shape =(1368,)\n",
      "reorder  = [  34   22    5    7    2    0  721  436   75  232 1134   28 1187   73\n",
      " 1023  821  123   18   19  550  142 1105  395 1087  973  269   16  264\n",
      "  141  218  968  289  250  148   36  186 1125  163  111  549 1093 1108\n",
      "  129  338   64  274   62  109  785 1121  449  161    9  900 1323  214\n",
      "  938   56  556  143   72  332  666  105   70  677  419   44   48 1128\n",
      "  901   77  787  133  202   46  664 1166 1223  644  870 1314  501   41\n",
      "  386  139  140  102  136   88  284  220 1082  382  162   45  307  471\n",
      " 1367   20]\n",
      "Saving to 20210504_lg_cummulative_mutual_information_vs_threshold_group_countThreshold3_K78.png\n",
      "thresholdK = 78\n",
      "max_cum_mi = 1.158465504068403\n",
      "cum_mis = [0.2214478  0.31359414 0.40746751 0.46334279 0.50797246 0.55125556\n",
      " 0.5843723  0.60621984 0.62638578 0.64397804 0.66121247 0.67730622\n",
      " 0.69357074 0.70974658 0.72177413 0.73329624 0.7441782  0.75451021\n",
      " 0.76426592 0.77393287 0.78377272 0.79254663 0.80198479 0.81077701\n",
      " 0.81906157 0.82710345 0.83481265 0.84186326 0.8489854  0.85612096\n",
      " 0.86291835 0.8690266  0.87482407 0.88060082 0.88635187 0.89185041\n",
      " 0.89731886 0.90265539 0.90763882 0.91310421 0.91821592 0.92317199\n",
      " 0.92805097 0.93273142 0.93738866 0.94183633 0.94622729 0.95027419\n",
      " 0.95419156 0.9580521  0.96177834 0.96537916 0.96883616 0.97213065\n",
      " 0.97531712 0.97854977 0.98165509 0.98473144 0.98779002 0.99082824\n",
      " 0.99383881 0.99679463 0.99970666 1.00260931 1.00547514 1.00834032\n",
      " 1.01115532 1.0138992  1.01653558 1.01909214 1.02164109 1.02415567\n",
      " 1.0266674  1.02910655 1.03150203 1.03386793 1.03622591 1.03856482\n",
      " 1.04088371 1.04318473 1.04543317 1.04767558 1.04989195 1.05209836\n",
      " 1.05431009 1.05652181 1.05875243 1.06096861 1.06301655 1.06502364\n",
      " 1.06701462 1.06895302 1.07088265 1.07272857 1.0745545  1.07630777\n",
      " 1.07805708 1.07975864 1.08144463 1.08312737]\n"
     ]
    },
    {
     "data": {
      "image/png": "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KEk/8GdlGHZ2N+dji3fVg69TW1nGxw/YtthZERERERGRzcmxx4aXiEgX5Wrz6HTgDGA7M5sSG1UDLO/pjG1JXl60mvtfWsxFh+9ATWW/YmdHREREREQ2J0cfXewciEgfl6t+1JPAImAY8LPY8HrguZ7M1JbmNw/Npn95KeccNK7YWRERERERkc2NqqyJyEbKGjxy97eAt4ADNl12tjyz313Dvc8v4tPvncCg6vJiZ0dEREREREREpIO8bR6Z2f5m9qyZrTGzJjNrNbPVSSZuZh8ys1fNbLaZXZxh/JfM7CUze87M/mtmW1yDP799aDaVZaV86uDtip0VEREREREREZFOkjSY/WvgdOB1oAr4FPCbfD8ys9Io3ZHArsDpZrZrWrIZQJ27TwT+Bvw4edb7vreWreUfsxZy5n5jGTqgotjZERERERGRzZFZeImIdFGS4BHuPhsodfdWd78e+FCCn+0LzHb3N9y9Cfgr8JG06T7k7uuir/8DRifPet/3u4fnUFpinPee8cXOioiIiIiIiIhIRrkazE5ZZ2blwEwz+zGhEe0kQadRwLzY9/nAfjnSfxK4L9MIMzsPOA9g7NixCWbd+y1YuZ47ps/n9H3HslVtZbGzIyIiIiIimyv3YudARPq4JEGgjwGlwOeBtcAY4MTuzISZfRSoA36Saby7X+Pude5eN3z48O6cddH8/uE5AHz6vROKnBMRERERERERkezyljyKel0DWA98p4BpLyAEmlJGR8M6MLP3A98E3uvujQVMv89a09jCHdPnc9Lk0YwcVFXs7IiIiIiIiIiIZJU1eGRmzwNZyzdGjVzn8iywg5ltRwganQackTaPvYGrgQ+5+7tJM93XDago418XvYfyskRNTomIiIiIiHTdMceE97vvLm4+RKTPylXy6OiNmbC7t5jZ54F/E6q9XefuL5rZ5cBUd59CqKY2ALjdQuv/b7v7sRsz375i7NDqYmdBRERERES2BPfcU+wciEgflzV4FKuu1mXu/k/gn2nDvh37/P6NnYeIiIiIiIjkMGVKsXMgIn1c3jaPzKye9upr5UA/YK271/ZkxkRERERERKQbpKqtiYh0UZIGs2tSny3ULfsIsH9PZkpERERERERERHqHglps9uAu4IM9kx0RERERERHpVtdcE14iIl2UpNraCbGvJUAd0NBjORIREREREZHuc/754f2884qbDxHps/IGj4B4BdkW4E1C1TURERERERHp7c49t9g5EJE+LkmbR+dsioyIiIiIiIhID1CVNRHZSEmqrW0HXACMi6d392N7LlsiIiIiIiIiItIbJKm2dhdwLXA30NajuREREREREZHutXBheB85srj5EJE+K0nwqMHdf9XjOREREREREZHuN2pUeHcvbj5EpM9KEjy60swuBe4HGlMD3X16j+VKREREREREuseIEcXOgYj0cUmCR3sAHwPeR3u1NY++i4iIiIiISG+WqrYmItJFSYJHJwPj3b2ppzMjIiIiIiIiIiK9S0mCNC8Ag3o4HyIiIiIiIiIi0gslKXk0CHjFzJ6lY5tHx/ZUpkRERERERKSbTJ4c3qdNK24+RKTPShI8urTHcyEiIiIiIiI9Y7r6OhKRjZM3eOTujwCYWW2S9CIiIiIiItKLTJ1a7ByISB+XNxhkZucBlwMNhN7WjNDb2viezZqIiIiIiIhstFS1NRGRLkpSkuirwO7uvrSnMyMiIiIiIiIiIr1Lkt7W5gDrejojIiIiIiIi0gMuuyy8RES6yNw9dwKzvYHrgafp2NvahT2btczq6up8qursioiIiIiIJGMW3vPc+4nIls3Mprl7XaZxSaqtXQ08CDxPaPNIRERERERE+opL1YG2iGycJMGjfu7+pR7PiYiIiIiIiHQ/VVkTkY2UpM2j+8zsPDMbYWZDUq8ez5mIiIiIiIiIiBRdkpJHp0fvl8SGOTC++7MjIiIiIiIi3WratPA+eXJx8yEifVbe4JG7b7cpMiIiIiIiIiI9oC5q/1YNZotIF+UNHpnZxzMNd/c/d392REREREREpFtNmlTsHIhIH5ek2to+sc+VwOHAdEDBIxERERERkd4uVW1NRKSLklRbuyD+3cwGAX/tqQyJiIiIiIiIiEjvkaS3tXRrAbWDJCIiIiIiIiKyBUjS5tHdhN7VIASbdgVu68lMiYiIiIiISDcZOTK8L1xY3HyISJ+VpM2jn8Y+twBvufv8HsqPiIiIiIiIdKdFi4qdAxHp47IGj8xse2Brd38kbfhBZlbh7nN6PHciIiIiIiKycRYsKHYORKSPy9Xm0S+B1RmGr47GiYiIiIiISG83cmR71TURkS7IFTza2t2fTx8YDRvXYzkSEREREREREZFeI1fwaFCOcVXdnA8RERERERHpCeedF14iIl2UK3g01czOTR9oZp8CpvVclkRERERERKTb/OEP4SUi0kW5elv7AvB3MzuT9mBRHVAOHN/D+RIREREREZHucPXVxc6BiPRxWYNH7r4YONDMDgN2jwbf6+4PbpKciYiIiIiIyMZTlTUR2Ui5Sh4B4O4PAQ9tgryIiIiIiIiIiEgvk6vNIxEREREREenr7r47vEREuihvySMRERERERHpw449Nry7FzcfItJnKXgkIiIiIiKyOTv66GLnQET6OAWPRERERERENmeqsiYiG0ltHomIiIiIiIiISFY9Gjwysw+Z2atmNtvMLs4wvsLMbo3GP21m43oyPyIiIiIiIiIiUpgeCx6ZWSnwG+BIYFfgdDPbNS3ZJ4EV7r498AvgRz2VHxERERERkS2SWXiJiHRRT5Y82heY7e5vuHsT8FfgI2lpPgL8Kfr8N+BwMx3VRERERERERER6i54MHo0C5sW+z4+GZUzj7i3AKmBo+oTM7Dwzm2pmU5csWdJD2RUREREREdkMuYeXiEgX9YkGs939Gnevc/e64cOHFzs7IiIiIiIiIiJbjJ4MHi0AxsS+j46GZUxjZmXAQGBZD+ZJREREREREREQK0JPBo2eBHcxsOzMrB04DpqSlmQKcFX0+CXjQXeUpRURERERERER6i7KemrC7t5jZ54F/A6XAde7+opldDkx19ynAtcCNZjYbWE4IMImIiIiIiIiISC/RY8EjAHf/J/DPtGHfjn1uAE7uyTyIiIiIiIiIiEjX9YkGs0VEREREREREpDgUPBIRERERERERkawUPBIRERERERERkawUPBIRERERERERkawUPBIRERERERERkawUPBIRERERERERkazM3Yudh4KY2RLgrWLno5sMA5YWIV0x5608btp0xZy38tg70xVz3srjpk1XzHkrj5s2XTHnrTxu2nTFnLfyuGnTFXPeyuOmTVfMeSuPmzZdX7Ctuw/POMbd9SrSC5hajHTFnLfyqDz2pnlvTnncnJZFeVQee1M65VF57E3plEflsTelUx6Vx96Urq/ksS+/VG1NRERERERERESyUvBIRERERERERESyUvCouK4pUrpizlt53LTpijlv5bF3pivmvJXHTZuumPNWHjdtumLOW3nctOmKOW/lcdOmK+a8lcdNm66Y81YeN226Pq3PNZgtIiIiIiIiIiKbjkoeiYiIiIiI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\n",
      "text/plain": [
       "<Figure size 1440x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "N,J = completed_grouped_pam.shape\n",
    "print(f\"completed_grouped_pam.shape = {completed_grouped_pam.shape}\")\n",
    "K = cum_mis.size\n",
    "\n",
    "print(f\"np.sum(completed_grouped_pam,axis=0).shape ={np.sum(completed_grouped_pam,axis=0).shape}\")\n",
    "#thresholdFrac = 0.65\n",
    "#max_cum_method = 'all_concepts'\n",
    "thresholdFrac = 0.9\n",
    "max_cum_method = 'threshold_group'\n",
    "if max_cum_method == 'threshold_group':\n",
    "    included_Js = np.where(np.sum(completed_grouped_pam,axis=0)>=threshold)[0]\n",
    "    full_rows_as_ints = convert_rows_to_unique_integers(completed_grouped_pam, included_Js)\n",
    "    max_cum_mi = sklearn.metrics.mutual_info_score(full_rows_as_ints, label_ids)\n",
    "elif max_cum_method == 'all_concepts':\n",
    "    max_cum_mi = np.max(extended_cum_mis)\n",
    "normed_cum_mis = cum_mis/max_cum_mi\n",
    "xs = np.arange(K)\n",
    "plt.figure(figsize=(20,5))\n",
    "plt.plot(xs, normed_cum_mis)\n",
    "thresholdK = np.where(normed_cum_mis < thresholdFrac)[0][-1]\n",
    "plt.vlines(thresholdK, 0, normed_cum_mis[thresholdK], 'r', linestyle=':', lw=2)\n",
    "plt.hlines(normed_cum_mis[thresholdK], 0, thresholdK, 'r', linestyle=':', lw=2)\n",
    "plt.text(\n",
    "    thresholdK+1, normed_cum_mis[thresholdK]/2., f\"First {thresholdK} concepts...\",\n",
    "    color='r', rotation='vertical', verticalalignment='center' )\n",
    "plt.text(\n",
    "    thresholdK/2.2, normed_cum_mis[thresholdK]*1.04,\n",
    "    f\"...contain {normed_cum_mis[thresholdK]:.2f} proportion of cumulative MI with label\",\n",
    "    color='r', horizontalalignment='center' )\n",
    "if K <= 100:\n",
    "    plt.xticks(np.arange(K))\n",
    "    print(f\"reorder  = {reorder}\")\n",
    "    dominant_concepts = np.array(dominant_concepts)\n",
    "    plt.gca().set_xticklabels(dominant_concepts[reorder], rotation='vertical')\n",
    "plt.title(f\"Best grouped concepts greedily ranked by cummulative mutual information (threshold = {threshold})\")\n",
    "plt.ylabel(\"Cummulative mutual information upto rank K\")\n",
    "pngfname = form_processed_fname(datastem, modelstem, 'png', identifier=f'cummulative_mutual_information_vs_{max_cum_method}_countThreshold{threshold}_K{thresholdK}')\n",
    "print(f\"Saving to {pngfname}\")\n",
    "plt.savefig(pngfname)\n",
    "print(f\"thresholdK = {thresholdK}\")\n",
    "print(f\"max_cum_mi = {max_cum_mi}\")\n",
    "print(f\"cum_mis = {cum_mis}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'plot_ranked_datapoints_per_concept' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-67-cefb80112037>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfigure\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 2\u001b[0;31m \u001b[0mplot_ranked_datapoints_per_concept\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mcompleted_grouped_pam\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mreorder\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      3\u001b[0m \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtitle\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34mf\"Concept rank by cummulative MI vs num data-points (threshold={threshold})\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mNameError\u001b[0m: name 'plot_ranked_datapoints_per_concept' is not defined"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 432x288 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure()\n",
    "plot_ranked_datapoints_per_concept(completed_grouped_pam, reorder)\n",
    "plt.title(f\"Concept rank by cummulative MI vs num data-points (threshold={threshold})\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "100"
      ]
     },
     "execution_count": 70,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "reorder.size"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def test_calc_post_mis(pam, label_ids, condition_Js, preZ, included_Js):\n",
    "    N, J = pam.shape\n",
    "    #pre_mi = sklearn.metrics.mutual_info_score(Z, label_ids)\n",
    "    post_mi_scores = np.zeros(J)\n",
    "    for j in included_Js:\n",
    "        if not j in condition_Js:\n",
    "            #Z_j = convert_rows_to_unique_integers(pam, condition_Js + [j])\n",
    "            # for efficiency just do\n",
    "            Z_j = 2*preZ + pam[:,j]\n",
    "            post_mi = sklearn.metrics.mutual_info_score(Z_j, label_ids)\n",
    "            print(f\"post_mi = {post_mi}\")\n",
    "            post_mi_scores[j] = post_mi\n",
    "    return post_mi_scores\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "threshold = 3\n",
    "condition_Js = list(reorder)\n",
    "print(f\"condition_Js = {condition_Js}\")\n",
    "preZ = convert_rows_to_unique_integers(completed_grouped_pam, condition_Js)\n",
    "print(f\"preZ[:10] = preZ[:10]\")\n",
    "included_Js = [ j for j in range(J) if np.sum(completed_grouped_pam[:,j]) >= threshold]\n",
    "post_mis = test_calc_post_mis(completed_grouped_pam, label_ids, condition_Js, preZ, included_Js)\n",
    "plt.plot(np.arange(post_mis.size), post_mis)\n",
    "plt.figure()\n",
    "bar_condition_Js = np.zeros(J).astype(int)\n",
    "bar_condition_Js[condition_Js] = 1\n",
    "plt.bar(np.arange(bar_condition_Js.size), bar_condition_Js)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "noncondition_included_Js = [j for j in included_Js if not j in condition_Js]\n",
    "print(f\"noncondition_included_Js = {noncondition_included_Js}\")\n",
    "np.where(count_datapoints_in_each_feature(completed_grouped_pam[:,noncondition_included_Js]))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Removing articles from concepts\n",
    "\n",
    "We think that concepts will be cleaner if we remove articles before embedding for the linguistic distance."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def remove_articles(text):\n",
    "    articles = set(['a', 'an', 'the'])\n",
    "    rest = [ word for word in text.split() if not word in articles]\n",
    "    return ' '.join(rest)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "i = 0\n",
    "print(f\"concepts[i] = {concepts[i]}\")\n",
    "print(f\"remove_articles(concepts[i]) = {remove_articles(concepts[i])}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "rest = 'the umpire called it a strike'.split()\n",
    "rest\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "rest.pop(0)\n",
    "rest"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "pam_as_strs = np.array(list(map(str,merged_pam[:10,:5]))).reshape((-1,1))\n",
    "unique_strs = np.unique(pam_as_strs).reshape((1,-1))\n",
    "rows_as_ints = np.where((pam_as_strs == unique_strs))[1]\n",
    "\n",
    "print(f\"rows_as_ints = {rows_as_ints}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
