AmjadKha commited on
Commit
330b8ea
Β·
verified Β·
1 Parent(s): 7f8cb00

Upload Football Winner Prediction.ipynb

Browse files
Files changed (1) hide show
  1. Football Winner Prediction.ipynb +481 -0
Football Winner Prediction.ipynb ADDED
@@ -0,0 +1,481 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {
2
+ "cells": [
3
+ {
4
+ "metadata": {
5
+ "ExecuteTime": {
6
+ "end_time": "2024-12-01T10:05:00.890729Z",
7
+ "start_time": "2024-12-01T10:05:00.885464Z"
8
+ }
9
+ },
10
+ "cell_type": "code",
11
+ "source": [
12
+ "import pandas as pd\n",
13
+ "import numpy as np\n",
14
+ "from sklearn.model_selection import train_test_split\n",
15
+ "from sklearn.preprocessing import LabelEncoder, StandardScaler\n",
16
+ "import tensorflow as tf\n",
17
+ "from tensorflow.keras.models import Sequential\n",
18
+ "from tensorflow.keras.layers import Dense, Dropout"
19
+ ],
20
+ "id": "e8f9a90ff28c2228",
21
+ "outputs": [],
22
+ "execution_count": 36
23
+ },
24
+ {
25
+ "metadata": {
26
+ "ExecuteTime": {
27
+ "end_time": "2024-12-01T10:05:06.623390Z",
28
+ "start_time": "2024-12-01T10:05:06.605514Z"
29
+ }
30
+ },
31
+ "cell_type": "code",
32
+ "source": [
33
+ "# Load the dataset\n",
34
+ "data = pd.read_csv(\"data/large_mock_football_data.csv\")"
35
+ ],
36
+ "id": "bcba25fa701b7739",
37
+ "outputs": [],
38
+ "execution_count": 37
39
+ },
40
+ {
41
+ "metadata": {
42
+ "ExecuteTime": {
43
+ "end_time": "2024-12-01T10:05:08.311068Z",
44
+ "start_time": "2024-12-01T10:05:08.301297Z"
45
+ }
46
+ },
47
+ "cell_type": "code",
48
+ "source": [
49
+ "# Encode categorical features\n",
50
+ "encoder = LabelEncoder()\n",
51
+ "data[\"team_a_name\"] = encoder.fit_transform(data[\"team_a_name\"])\n",
52
+ "data[\"team_b_name\"] = encoder.fit_transform(data[\"team_b_name\"])\n",
53
+ "data[\"match_location\"] = encoder.fit_transform(data[\"match_location\"])\n",
54
+ "data[\"weather_condition\"] = encoder.fit_transform(data[\"weather_condition\"])"
55
+ ],
56
+ "id": "6163fdf4954bdff9",
57
+ "outputs": [],
58
+ "execution_count": 38
59
+ },
60
+ {
61
+ "metadata": {
62
+ "ExecuteTime": {
63
+ "end_time": "2024-12-01T10:05:10.847483Z",
64
+ "start_time": "2024-12-01T10:05:10.841396Z"
65
+ }
66
+ },
67
+ "cell_type": "code",
68
+ "source": [
69
+ "# Encode the target (result)\n",
70
+ "data[\"result\"] = data[\"result\"].map({\"team_a_win\": 0, \"team_b_win\": 1, \"draw\": 2})"
71
+ ],
72
+ "id": "c2c51d8074b763ed",
73
+ "outputs": [],
74
+ "execution_count": 39
75
+ },
76
+ {
77
+ "metadata": {
78
+ "ExecuteTime": {
79
+ "end_time": "2024-12-01T10:05:12.607454Z",
80
+ "start_time": "2024-12-01T10:05:12.602100Z"
81
+ }
82
+ },
83
+ "cell_type": "code",
84
+ "source": [
85
+ "# Split features and labels\n",
86
+ "X = data.drop(\"result\", axis=1)\n",
87
+ "y = data[\"result\"]\n"
88
+ ],
89
+ "id": "426d1dd68fae7b22",
90
+ "outputs": [],
91
+ "execution_count": 40
92
+ },
93
+ {
94
+ "metadata": {
95
+ "ExecuteTime": {
96
+ "end_time": "2024-12-01T10:05:14.519744Z",
97
+ "start_time": "2024-12-01T10:05:14.511091Z"
98
+ }
99
+ },
100
+ "cell_type": "code",
101
+ "source": [
102
+ "# Normalize features\n",
103
+ "scaler = StandardScaler()\n",
104
+ "X = scaler.fit_transform(X)"
105
+ ],
106
+ "id": "69a891f01254baa",
107
+ "outputs": [],
108
+ "execution_count": 41
109
+ },
110
+ {
111
+ "metadata": {
112
+ "ExecuteTime": {
113
+ "end_time": "2024-12-01T10:05:17.798320Z",
114
+ "start_time": "2024-12-01T10:05:17.793462Z"
115
+ }
116
+ },
117
+ "cell_type": "code",
118
+ "source": "X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=42)\n",
119
+ "id": "ef4b241b01411c02",
120
+ "outputs": [],
121
+ "execution_count": 43
122
+ },
123
+ {
124
+ "metadata": {
125
+ "ExecuteTime": {
126
+ "end_time": "2024-12-01T10:05:19.045325Z",
127
+ "start_time": "2024-12-01T10:05:19.038713Z"
128
+ }
129
+ },
130
+ "cell_type": "code",
131
+ "source": "y_train",
132
+ "id": "2e9b7472e92eb8b4",
133
+ "outputs": [
134
+ {
135
+ "data": {
136
+ "text/plain": [
137
+ "642 1\n",
138
+ "700 1\n",
139
+ "226 2\n",
140
+ "1697 0\n",
141
+ "1010 0\n",
142
+ " ..\n",
143
+ "1638 2\n",
144
+ "1095 1\n",
145
+ "1130 2\n",
146
+ "1294 1\n",
147
+ "860 0\n",
148
+ "Name: result, Length: 2400, dtype: int64"
149
+ ]
150
+ },
151
+ "execution_count": 44,
152
+ "metadata": {},
153
+ "output_type": "execute_result"
154
+ }
155
+ ],
156
+ "execution_count": 44
157
+ },
158
+ {
159
+ "metadata": {
160
+ "ExecuteTime": {
161
+ "end_time": "2024-12-01T10:05:22.750495Z",
162
+ "start_time": "2024-12-01T10:05:22.713793Z"
163
+ }
164
+ },
165
+ "cell_type": "code",
166
+ "source": [
167
+ "# Build the model\n",
168
+ "model = Sequential([\n",
169
+ " Dense(64, input_dim=X_train.shape[1], activation='relu'),\n",
170
+ " Dropout(0.2),\n",
171
+ " Dense(32, activation='relu'),\n",
172
+ " Dropout(0.2),\n",
173
+ " Dense(3, activation='softmax') # 3 classes (team_a_win, team_b_win, draw)\n",
174
+ "])"
175
+ ],
176
+ "id": "35dbd98020d0a9c3",
177
+ "outputs": [
178
+ {
179
+ "name": "stderr",
180
+ "output_type": "stream",
181
+ "text": [
182
+ "C:\\ProgramData\\miniconda3\\Lib\\site-packages\\keras\\src\\layers\\core\\dense.py:87: UserWarning: Do not pass an `input_shape`/`input_dim` argument to a layer. When using Sequential models, prefer using an `Input(shape)` object as the first layer in the model instead.\n",
183
+ " super().__init__(activity_regularizer=activity_regularizer, **kwargs)\n"
184
+ ]
185
+ }
186
+ ],
187
+ "execution_count": 45
188
+ },
189
+ {
190
+ "metadata": {
191
+ "ExecuteTime": {
192
+ "end_time": "2024-12-01T10:05:27.003568Z",
193
+ "start_time": "2024-12-01T10:05:26.997249Z"
194
+ }
195
+ },
196
+ "cell_type": "code",
197
+ "source": [
198
+ "# Compile the model\n",
199
+ "model.compile(optimizer='adam', loss='sparse_categorical_crossentropy', metrics=['accuracy'])"
200
+ ],
201
+ "id": "97b5c68fc4d3c5ae",
202
+ "outputs": [],
203
+ "execution_count": 47
204
+ },
205
+ {
206
+ "metadata": {
207
+ "ExecuteTime": {
208
+ "end_time": "2024-12-01T10:06:52.058005Z",
209
+ "start_time": "2024-12-01T10:06:01.184361Z"
210
+ }
211
+ },
212
+ "cell_type": "code",
213
+ "source": [
214
+ "# Train the model\n",
215
+ "model.fit(X_train, y_train, epochs=64, batch_size=2, validation_split=0.3)"
216
+ ],
217
+ "id": "dd3ca9f254babc99",
218
+ "outputs": [
219
+ {
220
+ "name": "stdout",
221
+ "output_type": "stream",
222
+ "text": [
223
+ "Epoch 1/64\n",
224
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 1ms/step - accuracy: 0.4704 - loss: 1.0244 - val_accuracy: 0.4500 - val_loss: 1.0509\n",
225
+ "Epoch 2/64\n",
226
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 884us/step - accuracy: 0.4727 - loss: 1.0207 - val_accuracy: 0.4361 - val_loss: 1.0620\n",
227
+ "Epoch 3/64\n",
228
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 863us/step - accuracy: 0.5057 - loss: 1.0105 - val_accuracy: 0.4486 - val_loss: 1.0561\n",
229
+ "Epoch 4/64\n",
230
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 862us/step - accuracy: 0.4966 - loss: 1.0121 - val_accuracy: 0.4347 - val_loss: 1.0440\n",
231
+ "Epoch 5/64\n",
232
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 854us/step - accuracy: 0.4839 - loss: 1.0113 - val_accuracy: 0.4528 - val_loss: 1.0354\n",
233
+ "Epoch 6/64\n",
234
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 856us/step - accuracy: 0.4945 - loss: 1.0043 - val_accuracy: 0.4444 - val_loss: 1.0351\n",
235
+ "Epoch 7/64\n",
236
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 848us/step - accuracy: 0.4748 - loss: 1.0203 - val_accuracy: 0.4639 - val_loss: 1.0314\n",
237
+ "Epoch 8/64\n",
238
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 849us/step - accuracy: 0.4846 - loss: 1.0112 - val_accuracy: 0.4556 - val_loss: 1.0310\n",
239
+ "Epoch 9/64\n",
240
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 864us/step - accuracy: 0.5166 - loss: 0.9906 - val_accuracy: 0.4681 - val_loss: 1.0361\n",
241
+ "Epoch 10/64\n",
242
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 865us/step - accuracy: 0.4985 - loss: 1.0013 - val_accuracy: 0.4667 - val_loss: 1.0279\n",
243
+ "Epoch 11/64\n",
244
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 860us/step - accuracy: 0.4991 - loss: 0.9903 - val_accuracy: 0.4792 - val_loss: 1.0265\n",
245
+ "Epoch 12/64\n",
246
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 874us/step - accuracy: 0.5300 - loss: 0.9713 - val_accuracy: 0.4806 - val_loss: 1.0167\n",
247
+ "Epoch 13/64\n",
248
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 871us/step - accuracy: 0.4900 - loss: 1.0010 - val_accuracy: 0.4722 - val_loss: 1.0248\n",
249
+ "Epoch 14/64\n",
250
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 887us/step - accuracy: 0.5145 - loss: 0.9902 - val_accuracy: 0.4542 - val_loss: 1.0213\n",
251
+ "Epoch 15/64\n",
252
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 889us/step - accuracy: 0.5230 - loss: 0.9829 - val_accuracy: 0.4764 - val_loss: 1.0165\n",
253
+ "Epoch 16/64\n",
254
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 885us/step - accuracy: 0.5011 - loss: 0.9831 - val_accuracy: 0.4681 - val_loss: 1.0130\n",
255
+ "Epoch 17/64\n",
256
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 894us/step - accuracy: 0.5148 - loss: 0.9639 - val_accuracy: 0.4667 - val_loss: 1.0168\n",
257
+ "Epoch 18/64\n",
258
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 871us/step - accuracy: 0.5430 - loss: 0.9641 - val_accuracy: 0.4847 - val_loss: 1.0200\n",
259
+ "Epoch 19/64\n",
260
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 893us/step - accuracy: 0.5125 - loss: 0.9657 - val_accuracy: 0.4750 - val_loss: 1.0127\n",
261
+ "Epoch 20/64\n",
262
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 874us/step - accuracy: 0.5236 - loss: 0.9596 - val_accuracy: 0.4681 - val_loss: 1.0147\n",
263
+ "Epoch 21/64\n",
264
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 874us/step - accuracy: 0.5505 - loss: 0.9198 - val_accuracy: 0.4889 - val_loss: 1.0084\n",
265
+ "Epoch 22/64\n",
266
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 874us/step - accuracy: 0.5658 - loss: 0.9277 - val_accuracy: 0.4792 - val_loss: 1.0109\n",
267
+ "Epoch 23/64\n",
268
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 877us/step - accuracy: 0.5364 - loss: 0.9530 - val_accuracy: 0.4903 - val_loss: 1.0087\n",
269
+ "Epoch 24/64\n",
270
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 880us/step - accuracy: 0.5316 - loss: 0.9524 - val_accuracy: 0.4889 - val_loss: 1.0065\n",
271
+ "Epoch 25/64\n",
272
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 876us/step - accuracy: 0.5616 - loss: 0.9233 - val_accuracy: 0.4778 - val_loss: 1.0001\n",
273
+ "Epoch 26/64\n",
274
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 900us/step - accuracy: 0.5465 - loss: 0.9409 - val_accuracy: 0.4875 - val_loss: 1.0036\n",
275
+ "Epoch 27/64\n",
276
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 886us/step - accuracy: 0.5188 - loss: 0.9549 - val_accuracy: 0.4722 - val_loss: 1.0039\n",
277
+ "Epoch 28/64\n",
278
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 883us/step - accuracy: 0.5414 - loss: 0.9478 - val_accuracy: 0.4750 - val_loss: 0.9998\n",
279
+ "Epoch 29/64\n",
280
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 919us/step - accuracy: 0.5261 - loss: 0.9438 - val_accuracy: 0.4903 - val_loss: 0.9995\n",
281
+ "Epoch 30/64\n",
282
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 1ms/step - accuracy: 0.5610 - loss: 0.9234 - val_accuracy: 0.4708 - val_loss: 0.9909\n",
283
+ "Epoch 31/64\n",
284
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 1ms/step - accuracy: 0.5621 - loss: 0.9041 - val_accuracy: 0.4931 - val_loss: 0.9888\n",
285
+ "Epoch 32/64\n",
286
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 930us/step - accuracy: 0.5543 - loss: 0.9295 - val_accuracy: 0.4917 - val_loss: 0.9921\n",
287
+ "Epoch 33/64\n",
288
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 1ms/step - accuracy: 0.5428 - loss: 0.9415 - val_accuracy: 0.4889 - val_loss: 0.9916\n",
289
+ "Epoch 34/64\n",
290
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 897us/step - accuracy: 0.5690 - loss: 0.9042 - val_accuracy: 0.4889 - val_loss: 0.9945\n",
291
+ "Epoch 35/64\n",
292
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 1ms/step - accuracy: 0.5439 - loss: 0.9190 - val_accuracy: 0.5028 - val_loss: 0.9796\n",
293
+ "Epoch 36/64\n",
294
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 1ms/step - accuracy: 0.5537 - loss: 0.9207 - val_accuracy: 0.5000 - val_loss: 0.9795\n",
295
+ "Epoch 37/64\n",
296
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 1ms/step - accuracy: 0.5909 - loss: 0.8891 - val_accuracy: 0.4903 - val_loss: 0.9821\n",
297
+ "Epoch 38/64\n",
298
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 891us/step - accuracy: 0.5790 - loss: 0.9119 - val_accuracy: 0.5000 - val_loss: 0.9860\n",
299
+ "Epoch 39/64\n",
300
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 909us/step - accuracy: 0.5792 - loss: 0.8886 - val_accuracy: 0.5083 - val_loss: 0.9821\n",
301
+ "Epoch 40/64\n",
302
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 1ms/step - accuracy: 0.5800 - loss: 0.8886 - val_accuracy: 0.5194 - val_loss: 0.9789\n",
303
+ "Epoch 41/64\n",
304
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 1ms/step - accuracy: 0.5486 - loss: 0.9242 - val_accuracy: 0.4750 - val_loss: 0.9924\n",
305
+ "Epoch 42/64\n",
306
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 899us/step - accuracy: 0.5455 - loss: 0.9287 - val_accuracy: 0.5014 - val_loss: 0.9734\n",
307
+ "Epoch 43/64\n",
308
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 882us/step - accuracy: 0.5582 - loss: 0.9184 - val_accuracy: 0.5069 - val_loss: 0.9686\n",
309
+ "Epoch 44/64\n",
310
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 896us/step - accuracy: 0.5596 - loss: 0.8958 - val_accuracy: 0.4972 - val_loss: 0.9699\n",
311
+ "Epoch 45/64\n",
312
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 944us/step - accuracy: 0.5755 - loss: 0.8973 - val_accuracy: 0.4847 - val_loss: 0.9818\n",
313
+ "Epoch 46/64\n",
314
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 904us/step - accuracy: 0.5888 - loss: 0.8730 - val_accuracy: 0.5069 - val_loss: 0.9762\n",
315
+ "Epoch 47/64\n",
316
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 877us/step - accuracy: 0.5845 - loss: 0.8735 - val_accuracy: 0.5167 - val_loss: 0.9596\n",
317
+ "Epoch 48/64\n",
318
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 907us/step - accuracy: 0.5763 - loss: 0.9182 - val_accuracy: 0.4986 - val_loss: 0.9675\n",
319
+ "Epoch 49/64\n",
320
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 887us/step - accuracy: 0.5833 - loss: 0.8793 - val_accuracy: 0.5028 - val_loss: 0.9629\n",
321
+ "Epoch 50/64\n",
322
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 930us/step - accuracy: 0.5736 - loss: 0.8905 - val_accuracy: 0.5056 - val_loss: 0.9613\n",
323
+ "Epoch 51/64\n",
324
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 914us/step - accuracy: 0.6091 - loss: 0.8598 - val_accuracy: 0.5153 - val_loss: 0.9531\n",
325
+ "Epoch 52/64\n",
326
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 948us/step - accuracy: 0.5823 - loss: 0.8932 - val_accuracy: 0.5236 - val_loss: 0.9497\n",
327
+ "Epoch 53/64\n",
328
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 931us/step - accuracy: 0.5771 - loss: 0.8799 - val_accuracy: 0.5208 - val_loss: 0.9505\n",
329
+ "Epoch 54/64\n",
330
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 894us/step - accuracy: 0.5840 - loss: 0.8816 - val_accuracy: 0.5250 - val_loss: 0.9399\n",
331
+ "Epoch 55/64\n",
332
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 897us/step - accuracy: 0.6086 - loss: 0.8647 - val_accuracy: 0.5264 - val_loss: 0.9441\n",
333
+ "Epoch 56/64\n",
334
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 910us/step - accuracy: 0.5963 - loss: 0.8471 - val_accuracy: 0.5250 - val_loss: 0.9377\n",
335
+ "Epoch 57/64\n",
336
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 889us/step - accuracy: 0.5881 - loss: 0.8731 - val_accuracy: 0.5139 - val_loss: 0.9503\n",
337
+ "Epoch 58/64\n",
338
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 898us/step - accuracy: 0.5963 - loss: 0.8609 - val_accuracy: 0.5417 - val_loss: 0.9359\n",
339
+ "Epoch 59/64\n",
340
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 900us/step - accuracy: 0.6087 - loss: 0.8495 - val_accuracy: 0.5319 - val_loss: 0.9465\n",
341
+ "Epoch 60/64\n",
342
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 940us/step - accuracy: 0.5941 - loss: 0.8887 - val_accuracy: 0.5250 - val_loss: 0.9467\n",
343
+ "Epoch 61/64\n",
344
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 918us/step - accuracy: 0.5583 - loss: 0.8744 - val_accuracy: 0.5181 - val_loss: 0.9463\n",
345
+ "Epoch 62/64\n",
346
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 950us/step - accuracy: 0.5815 - loss: 0.8637 - val_accuracy: 0.5181 - val_loss: 0.9486\n",
347
+ "Epoch 63/64\n",
348
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 915us/step - accuracy: 0.6214 - loss: 0.8448 - val_accuracy: 0.5361 - val_loss: 0.9427\n",
349
+ "Epoch 64/64\n",
350
+ "\u001B[1m840/840\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m1s\u001B[0m 911us/step - accuracy: 0.6034 - loss: 0.8680 - val_accuracy: 0.5264 - val_loss: 0.9538\n"
351
+ ]
352
+ },
353
+ {
354
+ "data": {
355
+ "text/plain": [
356
+ "<keras.src.callbacks.history.History at 0x1db010a2150>"
357
+ ]
358
+ },
359
+ "execution_count": 49,
360
+ "metadata": {},
361
+ "output_type": "execute_result"
362
+ }
363
+ ],
364
+ "execution_count": 49
365
+ },
366
+ {
367
+ "metadata": {
368
+ "ExecuteTime": {
369
+ "end_time": "2024-12-01T10:06:56.633427Z",
370
+ "start_time": "2024-12-01T10:06:56.562087Z"
371
+ }
372
+ },
373
+ "cell_type": "code",
374
+ "source": [
375
+ "# Evaluate the model\n",
376
+ "loss, accuracy = model.evaluate(X_test, y_test)\n",
377
+ "print(f\"Test Accuracy: {accuracy:.2f}\")"
378
+ ],
379
+ "id": "33799f9e7377c32c",
380
+ "outputs": [
381
+ {
382
+ "name": "stdout",
383
+ "output_type": "stream",
384
+ "text": [
385
+ "\u001B[1m19/19\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m0s\u001B[0m 820us/step - accuracy: 0.5235 - loss: 0.9529\n",
386
+ "Test Accuracy: 0.49\n"
387
+ ]
388
+ }
389
+ ],
390
+ "execution_count": 50
391
+ },
392
+ {
393
+ "metadata": {
394
+ "ExecuteTime": {
395
+ "end_time": "2024-12-01T10:07:59.256655Z",
396
+ "start_time": "2024-12-01T10:07:59.198211Z"
397
+ }
398
+ },
399
+ "cell_type": "code",
400
+ "source": [
401
+ "# Predict for a new match\n",
402
+ "new_match = np.array([[8, 1, 8, 9, 1, 1, 1, 1]]) # Example data\n",
403
+ "new_match = scaler.transform(new_match)\n",
404
+ "prediction = model.predict(new_match)\n",
405
+ "predicted_class = np.argmax(prediction)\n",
406
+ "result_mapping = {0: \"team_a_win\", 1: \"team_b_win\", 2: \"draw\"}\n",
407
+ "print(f\"Predicted Result: {result_mapping[predicted_class]}\")"
408
+ ],
409
+ "id": "8afcc0c67d20c53d",
410
+ "outputs": [
411
+ {
412
+ "name": "stdout",
413
+ "output_type": "stream",
414
+ "text": [
415
+ "\u001B[1m1/1\u001B[0m \u001B[32m━━━━━━━━━━━━━━━━━━━━\u001B[0m\u001B[37m\u001B[0m \u001B[1m0s\u001B[0m 22ms/step\n",
416
+ "Predicted Result: team_a_win\n"
417
+ ]
418
+ },
419
+ {
420
+ "name": "stderr",
421
+ "output_type": "stream",
422
+ "text": [
423
+ "C:\\Users\\3176\\AppData\\Roaming\\Python\\Python312\\site-packages\\sklearn\\base.py:493: UserWarning: X does not have valid feature names, but StandardScaler was fitted with feature names\n",
424
+ " warnings.warn(\n"
425
+ ]
426
+ }
427
+ ],
428
+ "execution_count": 73
429
+ },
430
+ {
431
+ "metadata": {
432
+ "ExecuteTime": {
433
+ "end_time": "2024-12-01T10:13:49.624661Z",
434
+ "start_time": "2024-12-01T10:13:49.605519Z"
435
+ }
436
+ },
437
+ "cell_type": "code",
438
+ "source": "model.save(\"data/Football_Winner_Model.h5\")",
439
+ "id": "a314f0dcbe19c8de",
440
+ "outputs": [
441
+ {
442
+ "name": "stderr",
443
+ "output_type": "stream",
444
+ "text": [
445
+ "WARNING:absl:You are saving your model as an HDF5 file via `model.save()` or `keras.saving.save_model(model)`. This file format is considered legacy. We recommend using instead the native Keras format, e.g. `model.save('my_model.keras')` or `keras.saving.save_model(model, 'my_model.keras')`. \n"
446
+ ]
447
+ }
448
+ ],
449
+ "execution_count": 75
450
+ },
451
+ {
452
+ "metadata": {},
453
+ "cell_type": "code",
454
+ "outputs": [],
455
+ "execution_count": null,
456
+ "source": "",
457
+ "id": "3a11d48c49cb7314"
458
+ }
459
+ ],
460
+ "metadata": {
461
+ "kernelspec": {
462
+ "display_name": "Python 3",
463
+ "language": "python",
464
+ "name": "python3"
465
+ },
466
+ "language_info": {
467
+ "codemirror_mode": {
468
+ "name": "ipython",
469
+ "version": 2
470
+ },
471
+ "file_extension": ".py",
472
+ "mimetype": "text/x-python",
473
+ "name": "python",
474
+ "nbconvert_exporter": "python",
475
+ "pygments_lexer": "ipython2",
476
+ "version": "2.7.6"
477
+ }
478
+ },
479
+ "nbformat": 4,
480
+ "nbformat_minor": 5
481
+ }