{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "d71c06ce",
   "metadata": {},
   "outputs": [],
   "source": [
    "from rich.console import Console\n",
    "from rich.table import Table\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "2abfbc52",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<pre style=\"white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace\"><span style=\"font-style: italic\">             Survey Cost Summary             </span>\n",
       "┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━┓\n",
       "┃<span style=\"font-weight: bold\">                             Item </span>┃<span style=\"font-weight: bold\"> Value  </span>┃\n",
       "┡━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━┩\n",
       "│<span style=\"font-weight: bold\">                         Examples </span>│<span style=\"color: #c0c0c0; text-decoration-color: #c0c0c0\"> 100    </span>│\n",
       "│<span style=\"font-weight: bold\">          Evaluations per Example </span>│<span style=\"color: #c0c0c0; text-decoration-color: #c0c0c0\"> 5      </span>│\n",
       "│<span style=\"font-weight: bold\">                 Total Judgements </span>│<span style=\"color: #c0c0c0; text-decoration-color: #c0c0c0\"> 500    </span>│\n",
       "│<span style=\"font-weight: bold\">         Examples per Participant </span>│<span style=\"color: #c0c0c0; text-decoration-color: #c0c0c0\"> 10     </span>│\n",
       "│<span style=\"font-weight: bold\">            Required Participants </span>│<span style=\"color: #c0c0c0; text-decoration-color: #c0c0c0\"> 50     </span>│\n",
       "│<span style=\"font-weight: bold\"> Attention Checks per Participant </span>│<span style=\"color: #c0c0c0; text-decoration-color: #c0c0c0\"> 2      </span>│\n",
       "├──────────────────────────────────┼────────┤\n",
       "│<span style=\"font-weight: bold\">          Payment per Participant </span>│<span style=\"color: #c0c0c0; text-decoration-color: #c0c0c0\"> £3.24  </span>│\n",
       "│<span style=\"font-weight: bold\">       Total Participant Payments </span>│<span style=\"color: #c0c0c0; text-decoration-color: #c0c0c0\"> £162.0 </span>│\n",
       "│<span style=\"font-weight: bold\">                             Fees </span>│<span style=\"color: #c0c0c0; text-decoration-color: #c0c0c0\"> £54.0  </span>│\n",
       "│<span style=\"font-weight: bold\">                              VAT </span>│<span style=\"color: #c0c0c0; text-decoration-color: #c0c0c0\"> £10.8  </span>│\n",
       "│<span style=\"font-weight: bold\">                       Total Cost </span>│<span style=\"color: #c0c0c0; text-decoration-color: #c0c0c0\"> £226.8 </span>│\n",
       "└──────────────────────────────────┴────────┘\n",
       "</pre>\n"
      ],
      "text/plain": [
       "\u001b[3m             Survey Cost Summary             \u001b[0m\n",
       "┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┳━━━━━━━━┓\n",
       "┃\u001b[1m \u001b[0m\u001b[1m                            Item\u001b[0m\u001b[1m \u001b[0m┃\u001b[1m \u001b[0m\u001b[1mValue \u001b[0m\u001b[1m \u001b[0m┃\n",
       "┡━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━╇━━━━━━━━┩\n",
       "│\u001b[1m \u001b[0m\u001b[1m                        Examples\u001b[0m\u001b[1m \u001b[0m│\u001b[37m \u001b[0m\u001b[37m100   \u001b[0m\u001b[37m \u001b[0m│\n",
       "│\u001b[1m \u001b[0m\u001b[1m         Evaluations per Example\u001b[0m\u001b[1m \u001b[0m│\u001b[37m \u001b[0m\u001b[37m5     \u001b[0m\u001b[37m \u001b[0m│\n",
       "│\u001b[1m \u001b[0m\u001b[1m                Total Judgements\u001b[0m\u001b[1m \u001b[0m│\u001b[37m \u001b[0m\u001b[37m500   \u001b[0m\u001b[37m \u001b[0m│\n",
       "│\u001b[1m \u001b[0m\u001b[1m        Examples per Participant\u001b[0m\u001b[1m \u001b[0m│\u001b[37m \u001b[0m\u001b[37m10    \u001b[0m\u001b[37m \u001b[0m│\n",
       "│\u001b[1m \u001b[0m\u001b[1m           Required Participants\u001b[0m\u001b[1m \u001b[0m│\u001b[37m \u001b[0m\u001b[37m50    \u001b[0m\u001b[37m \u001b[0m│\n",
       "│\u001b[1m \u001b[0m\u001b[1mAttention Checks per Participant\u001b[0m\u001b[1m \u001b[0m│\u001b[37m \u001b[0m\u001b[37m2     \u001b[0m\u001b[37m \u001b[0m│\n",
       "├──────────────────────────────────┼────────┤\n",
       "│\u001b[1m \u001b[0m\u001b[1m         Payment per Participant\u001b[0m\u001b[1m \u001b[0m│\u001b[37m \u001b[0m\u001b[37m£3.24 \u001b[0m\u001b[37m \u001b[0m│\n",
       "│\u001b[1m \u001b[0m\u001b[1m      Total Participant Payments\u001b[0m\u001b[1m \u001b[0m│\u001b[37m \u001b[0m\u001b[37m£162.0\u001b[0m\u001b[37m \u001b[0m│\n",
       "│\u001b[1m \u001b[0m\u001b[1m                            Fees\u001b[0m\u001b[1m \u001b[0m│\u001b[37m \u001b[0m\u001b[37m£54.0 \u001b[0m\u001b[37m \u001b[0m│\n",
       "│\u001b[1m \u001b[0m\u001b[1m                             VAT\u001b[0m\u001b[1m \u001b[0m│\u001b[37m \u001b[0m\u001b[37m£10.8 \u001b[0m\u001b[37m \u001b[0m│\n",
       "│\u001b[1m \u001b[0m\u001b[1m                      Total Cost\u001b[0m\u001b[1m \u001b[0m│\u001b[37m \u001b[0m\u001b[37m£226.8\u001b[0m\u001b[37m \u001b[0m│\n",
       "└──────────────────────────────────┴────────┘\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Input parameters\n",
    "examples = 100\n",
    "evaluations_per_example = 5\n",
    "examples_per_participant = 10\n",
    "attention_checks = 2  # add these to each participant's load\n",
    "priming_time = 5  # minutes for instructions etc.\n",
    "hourly_rate = 11.44\n",
    "time_per_example = 1  # minutes\n",
    "\n",
    "# Calculations\n",
    "totalevaluations = examples * evaluations_per_example\n",
    "\n",
    "participants = totalevaluations // examples_per_participant\n",
    "time_per_participant = ((examples_per_participant + attention_checks) * time_per_example) + priming_time\n",
    "payment = round(time_per_participant / 60 * hourly_rate, 2)\n",
    "participantpayments = participants * payment\n",
    "fees = round(participantpayments / 3, 2)\n",
    "vat = round(0.2 * fees, 2)\n",
    "totalcost = participantpayments + fees + vat\n",
    "\n",
    "\n",
    "console = Console()\n",
    "table = Table(title='Survey Cost Summary')\n",
    "table.add_column('Item', style='bold', justify='right')\n",
    "table.add_column('Value', style='white')\n",
    "\n",
    "table.add_row('Examples', str(examples))\n",
    "table.add_row('Evaluations per Example', str(evaluations_per_example))\n",
    "table.add_row('Total Judgements', str(totalevaluations))\n",
    "table.add_row('Examples per Participant', str(examples_per_participant))\n",
    "table.add_row('Required Participants', str(participants))\n",
    "table.add_row('Attention Checks per Participant', str(attention_checks))\n",
    "table.add_section()  # <-- This adds a horizontal line\n",
    "table.add_row('Payment per Participant', f'£{payment}')\n",
    "table.add_row('Total Participant Payments', f'£{participantpayments}')\n",
    "table.add_row('Fees', f'£{fees}')\n",
    "table.add_row('VAT', f'£{vat}')\n",
    "table.add_row('Total Cost', f'£{totalcost}')\n",
    "\n",
    "console.print(table)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "frankenstein",
   "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.12.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
