<!doctype html>
<html lang="en"> 
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <script
      id="p5scripttag"
      src="https://cdnjs.cloudflare.com/ajax/libs/p5.js/1.9.0/p5.min.js"
      integrity="sha512-uaz5GpnQoE6t5echKlX8P52czvsIGgLPcvlzfvRubLZ1Hp8JemUDnbUiAahbVtPb+jUVrNETuXvAhDDF/N3M4w=="
      crossorigin="anonymous"
      referrerpolicy="no-referrer"
    ></script>

    <link
      rel="stylesheet"
      href="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.9.0/styles/atom-one-dark.min.css"
    />
    <script src="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.9.0/highlight.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.9.0/languages/python.min.js"></script>

    <script>
      const bgCol = "#F2F0E7";
const accentCol = "#fd4578";

hljs.initHighlightingOnLoad();

const updateTargetDims = () => {
  // width is max-width of `.contentContainer` - its padding
  // return [min(windowWidth, 900 - 80), 700]
  return [windowWidth * (1 / 2), windowHeight];
};

const setCodeAndPlan = (code, plan) => {
  const codeElm = document.getElementById("code");
  if (codeElm) {
    // codeElm.innerText = code;
    codeElm.innerHTML = hljs.highlight(code, { language: "python" }).value;
  }

  const planElm = document.getElementById("plan");
  if (planElm) {
    // planElm.innerText = plan.trim();
    planElm.innerHTML = hljs.highlight(plan, { language: "plaintext" }).value;
  }
};

windowResized = () => {
  resizeCanvas(...updateTargetDims());
  awaitingPostResizeOps = true;
};

const animEase = (t) => 1 - (1 - Math.min(t, 1.0)) ** 5;

// ---- global constants ----

const globalAnimSpeed = 1.1;
const scaleFactor = 0.57;

// ---- global vars ----

let globalTime = 0;
let manualSelection = false;

let currentElemInd = 0;

let treeStructData = {"edges": [[1, 8], [2, 6], [3, 5], [4, 18], [5, 7], [5, 11], [5, 10], [5, 9], [11, 15], [11, 23], [11, 22], [11, 17], [11, 14], [11, 13], [11, 12], [11, 20], [11, 16], [11, 19], [19, 21]], "layout": [[0.0, 0.0], [0.1111111111111111, 0.0], [0.2222222222222222, 0.0], [0.3333333333333333, 0.0], [0.4444444444444444, 0.0], [0.3333333333333333, 0.25], [0.2222222222222222, 0.25], [0.16666666666666666, 0.5], [0.1111111111111111, 0.25], [0.2777777777777778, 0.5], [0.3888888888888889, 0.5], [0.5, 0.5], [0.0, 0.75], [0.1111111111111111, 0.75], [0.2222222222222222, 0.75], [0.3333333333333333, 0.75], [0.4444444444444444, 0.75], [0.5555555555555556, 0.75], [0.4444444444444444, 0.25], [0.6666666666666666, 0.75], [0.7777777777777778, 0.75], [0.6666666666666666, 1.0], [0.8888888888888888, 0.75], [1.0, 0.75]], "plan": ["To tackle the classification of satellite image pixel time series into 24 land\ncover types, I propose using a simple feedforward neural network implemented\nwith PyTorch. The model will take the 46 float features as input and output the\npredicted class probabilities for each of the 24 land cover types. We'll use\nCross Entropy Loss for training and accuracy as the evaluation metric. The\ntraining will be performed using the provided training dataset, and the model\nwill be validated on the validation dataset, with the results being saved in a\n`submission.csv` file.", "To classify satellite image pixel time series into 24 land cover types, I\npropose using a simple feedforward neural network with one hidden layer\nimplemented in PyTorch. The model will take in the 46 float features and output\nprobabilities for each of the 24 classes using the softmax activation function.\nWe'll use Cross Entropy Loss for training and evaluate the model's performance\nusing accuracy on the validation set. The predictions will be saved in a\n`submission.csv` file for grading.", "To classify satellite image pixel time series into 24 land cover types, I\npropose using a simple feedforward neural network built with PyTorch. The model\nwill consist of an input layer with 46 nodes, followed by two hidden layers, and\nan output layer with 24 nodes representing the land cover types. We will employ\nCross Entropy Loss for training and accuracy as the evaluation metric. The model\nwill be trained on the provided training dataset, and the validation accuracy\nwill be reported after evaluating it on the validation set. The predictions will\nalso be saved in a `submission.csv` file.", "To classify satellite image pixel time series into 24 land cover types, I\npropose using a simple feedforward neural network implemented in PyTorch. The\nmodel will consist of a few fully connected layers with ReLU activations, and we\nwill utilize Cross Entropy Loss for the training process. The training will be\nconducted using the provided training dataset, and we will evaluate the model's\nperformance on the validation dataset by calculating the accuracy. Finally, the\npredictions for the validation set will be saved in a `submission.csv` file.", "To classify satellite image pixel time series into 24 land cover types, I will\nimplement a feedforward neural network using PyTorch with a few hidden layers\nand ReLU activations. The model will be trained on the provided training\ndataset, and I will use Cross Entropy Loss as the loss function. The evaluation\nmetric will be accuracy, and I will save the predictions for the validation set\nin a `submission.csv` file in the \"./working\" directory.", "To improve the model's performance, I suggest implementing batch normalization\nafter each fully connected layer. This technique can help stabilize and\naccelerate the training process by normalizing the inputs to each layer,\npotentially leading to better convergence and improved accuracy. Additionally, I\nwill increase the number of epochs to allow the model more time to learn from\nthe data, which can also contribute to better performance.", "The issue in the previous implementation is that the Pandas library (imported as\n`pd`) was not imported, which caused a `NameError` when attempting to create the\nsubmission DataFrame. To fix this, we need to import the Pandas library at the\nbeginning of the script. Additionally, I will ensure that the evaluation metric\nis printed correctly after validation.", "To further improve the model's performance, I suggest implementing a dropout\nlayer after the fully connected layers. Dropout is a regularization technique\nthat helps prevent overfitting by randomly setting a fraction of the input units\nto zero during training, which can lead to better generalization on the\nvalidation set. Additionally, I will adjust the dropout rate to 0.5, which is a\ncommon choice for regularization in neural networks. This should enhance the\nmodel's ability to generalize and potentially increase the validation accuracy.", "The issue in the previous implementation arises from the fact that the pandas\nlibrary (`pd`) was not imported, which leads to a `NameError` when attempting to\ncreate the submission DataFrame. To fix this, I will import the pandas library\nat the beginning of the script. Additionally, I will ensure that the code is\nproperly structured to load the data, train the model, and save the predictions\nto a CSV file without any interruptions.", "To improve the model's performance further, I propose adding a dropout layer\nafter each fully connected layer to reduce overfitting and enhance the model's\ngeneralization ability. This technique randomly sets a fraction of the input\nunits to zero during training, which can help the model learn more robust\nfeatures. I will set the dropout rate to 0.5, a commonly used value, and\nevaluate the model's performance on the validation set after implementing this\nchange.", "To enhance the model's performance, I propose implementing a learning rate\nscheduler that adjusts the learning rate during training. This can help the\nmodel converge more effectively by reducing the learning rate when the\nvalidation loss plateaus, allowing for finer updates to the weights.\nAdditionally, I will include early stopping to prevent overfitting by monitoring\nthe validation accuracy and stopping training if it does not improve for a\ncertain number of epochs. This combination should help optimize the training\nprocess and improve the validation accuracy.", "To enhance the model's performance, I propose implementing a learning rate\nscheduler that reduces the learning rate when the validation loss plateaus. This\nadjustment can help the model converge more effectively by allowing for finer\nupdates to the weights as training progresses. Additionally, I will incorporate\nearly stopping to prevent overfitting by monitoring the validation accuracy and\nhalting training if it does not improve for a specified number of epochs. This\ncombination should optimize the training process and improve validation\naccuracy.", "To further enhance the model's performance, I propose implementing a more\ncomplex neural network architecture by adding an additional hidden layer with\ndropout regularization. This new structure will allow the model to learn more\ncomplex patterns in the data, while dropout will help mitigate overfitting.\nSpecifically, I will add a new hidden layer with 32 neurons and a dropout layer\nwith a rate of 0.5 after the second fully connected layer. This adjustment\nshould lead to improved validation accuracy.", "To further enhance the model's performance, I propose increasing the complexity\nof the neural network by adding an additional hidden layer with 32 neurons and\ndropout regularization. This will allow the model to capture more complex\npatterns in the data while helping to prevent overfitting. The dropout rate will\nbe set to 0.5, which is a common choice for regularization in neural networks.\nThis adjustment should lead to improved validation accuracy.", "To enhance the model's performance, I propose increasing the complexity of the\nneural network by adding an additional hidden layer with 64 neurons and dropout\nregularization. This adjustment will allow the model to learn more intricate\npatterns from the data while dropout will help mitigate overfitting. The dropout\nrate will be set to 0.5, which is a common practice for regularization in neural\nnetworks. This change should lead to improved validation accuracy.", "To further enhance the model's performance, I propose adding an additional\nhidden layer with 64 neurons and dropout regularization after each fully\nconnected layer. This will allow the model to learn more complex patterns in the\ndata while mitigating overfitting. The dropout rate will be set to 0.5, a common\nchoice for regularization in neural networks. This adjustment should lead to\nimproved validation accuracy.", "To further enhance the model's performance, I propose increasing the complexity\nof the neural network by adding an additional hidden layer with 128 neurons and\ndropout regularization after each fully connected layer. This will allow the\nmodel to capture more intricate patterns in the data while helping to prevent\noverfitting. The dropout rate will be set to 0.5, which is a common practice for\nregularization in neural networks. This adjustment should lead to improved\nvalidation accuracy.", "To further enhance the model's performance, I propose increasing the number of\nneurons in the hidden layers of the neural network. Specifically, I will\nincrease the first hidden layer to 256 neurons and the second hidden layer to\n128 neurons. This increase in capacity should allow the model to learn more\ncomplex patterns in the data, potentially leading to improved validation\naccuracy. Additionally, I will retain the dropout layers to mitigate overfitting\nand ensure generalization.", "To fix the bug in the previous implementation, we need to import the pandas\nlibrary, which is required for creating the DataFrame to save the predictions.\nAdditionally, we should ensure that the evaluation metric is printed correctly\nafter the model validation. Below is the revised implementation that includes\nthe necessary import and prints the validation accuracy.", "To improve the model's performance, I propose increasing the complexity of the\nneural network by adding an additional hidden layer with 256 neurons. This will\nallow the model to learn more intricate patterns in the data, which is essential\nfor classifying satellite image pixel time series into 24 land cover types. I\nwill also retain the dropout layers to mitigate overfitting and ensure better\ngeneralization. This adjustment should lead to improved validation accuracy.", "To improve the model's performance, I propose incorporating an additional hidden\nlayer with 256 neurons, followed by dropout regularization after each fully\nconnected layer. This change aims to enhance the model's capacity to learn\ncomplex patterns from the data while mitigating overfitting through dropout. The\ndropout rate will be set to 0.5, which is a common practice for regularization\nin neural networks. This adjustment should lead to improved validation accuracy.", "The issue in the previous implementation seems to be related to the training\nloop and the way the model is validated. To improve the training efficiency and\navoid timeouts, I will introduce gradient accumulation, which allows for larger\neffective batch sizes without increasing memory usage. Additionally, I will\nensure that the validation phase does not interfere with the training phase, and\nI will add early stopping based on validation accuracy. Finally, I will ensure\nthat the model saves predictions correctly after training.", "To further enhance the model's performance, I propose implementing a more\nsophisticated architecture by adding an additional hidden layer with 256 neurons\nand dropout regularization after each fully connected layer. This will allow the\nmodel to capture more complex patterns in the data while helping to prevent\noverfitting through dropout. The dropout rate will be set to 0.5, which is a\nstandard practice for regularization in neural networks. This adjustment should\nlead to improved validation accuracy.", "To further enhance the model's performance, I propose increasing the number of\nneurons in the hidden layers of the neural network. Specifically, I will\nincrease the first hidden layer to 256 neurons and the second hidden layer to\n128 neurons. This increase in capacity should allow the model to learn more\ncomplex patterns in the data, potentially leading to improved validation\naccuracy. Additionally, I will retain the dropout layers to mitigate overfitting\nand ensure generalization."], "code": ["import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.model_selection import train_test_split\nfrom sklearn.metrics import accuracy_score\nimport pandas as pd\n\n# Load the data\ntrain_data = np.load(\"./input/train_data.npy\")\ntrain_label = np.load(\"./input/train_label.npy\")\nval_data = np.load(\"./input/val_data.npy\")\nval_label = np.load(\"./input/val_label.npy\")\n\n# Convert to PyTorch tensors\nX_train = torch.tensor(train_data, dtype=torch.float32)\ny_train = torch.tensor(train_label - 1, dtype=torch.long)  # Adjust for zero indexing\nX_val = torch.tensor(val_data, dtype=torch.float32)\ny_val = torch.tensor(val_label - 1, dtype=torch.long)\n\n\n# Define the model\nclass SimpleNN(nn.Module):\n    def __init__(self):\n        super(SimpleNN, self).__init__()\n        self.fc1 = nn.Linear(46, 128)\n        self.fc2 = nn.Linear(128, 64)\n        self.fc3 = nn.Linear(64, 24)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        x = self.fc3(x)\n        return x\n\n\n# Initialize model, loss function, and optimizer\nmodel = SimpleNN()\ncriterion = nn.CrossEntropyLoss()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Train the model\nnum_epochs = 20\nfor epoch in range(num_epochs):\n    model.train()\n    optimizer.zero_grad()\n    outputs = model(X_train)\n    loss = criterion(outputs, y_train)\n    loss.backward()\n    optimizer.step()\n\n# Validate the model\nmodel.eval()\nwith torch.no_grad():\n    val_outputs = model(X_val)\n    _, predicted = torch.max(val_outputs, 1)\n    accuracy = accuracy_score(y_val.numpy(), predicted.numpy())\n\n# Save predictions for submission\nsubmission = pd.DataFrame({\"Id\": range(len(predicted)), \"Label\": predicted.numpy() + 1})\nsubmission.to_csv(\"./working/submission.csv\", index=False)\n\nprint(f\"Validation Accuracy: {accuracy:.4f}\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.model_selection import train_test_split\nfrom sklearn.metrics import accuracy_score\n\n# Load the data\ntrain_data = np.load(\"./input/train_data.npy\")\ntrain_label = np.load(\"./input/train_label.npy\")\nval_data = np.load(\"./input/val_data.npy\")\nval_label = np.load(\"./input/val_label.npy\")\n\n# Convert to PyTorch tensors\nX_train = torch.tensor(train_data, dtype=torch.float32)\ny_train = torch.tensor(\n    train_label - 1, dtype=torch.long\n)  # Adjust labels to be zero-indexed\nX_val = torch.tensor(val_data, dtype=torch.float32)\ny_val = torch.tensor(\n    val_label - 1, dtype=torch.long\n)  # Adjust labels to be zero-indexed\n\n\n# Define the model\nclass FeedforwardNN(nn.Module):\n    def __init__(self):\n        super(FeedforwardNN, self).__init__()\n        self.fc1 = nn.Linear(46, 128)\n        self.fc2 = nn.Linear(128, 24)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return x\n\n\n# Instantiate the model, define the loss function and the optimizer\nmodel = FeedforwardNN()\ncriterion = nn.CrossEntropyLoss()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training loop\nnum_epochs = 50\nfor epoch in range(num_epochs):\n    model.train()\n    optimizer.zero_grad()\n    outputs = model(X_train)\n    loss = criterion(outputs, y_train)\n    loss.backward()\n    optimizer.step()\n\n# Validation\nmodel.eval()\nwith torch.no_grad():\n    val_outputs = model(X_val)\n    _, predicted = torch.max(val_outputs.data, 1)\n    accuracy = accuracy_score(y_val.numpy(), predicted.numpy())\n\n# Save predictions to submission file\nsubmission = pd.DataFrame(\n    {\"Id\": range(len(val_data)), \"Predicted\": predicted.numpy() + 1}\n)\nsubmission.to_csv(\"./working/submission.csv\", index=False)\n\nprint(f\"Validation Accuracy: {accuracy:.4f}\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.model_selection import train_test_split\nfrom sklearn.metrics import accuracy_score\n\n# Load data\ntrain_data = np.load(\"./input/train_data.npy\")\ntrain_label = np.load(\"./input/train_label.npy\")\nval_data = np.load(\"./input/val_data.npy\")\nval_label = np.load(\"./input/val_label.npy\")\n\n# Convert to PyTorch tensors\nX_train = torch.FloatTensor(train_data)\ny_train = torch.LongTensor(train_label - 1)  # Adjust for zero-indexing\nX_val = torch.FloatTensor(val_data)\ny_val = torch.LongTensor(val_label - 1)  # Adjust for zero-indexing\n\n\n# Define the neural network model\nclass SimpleNN(nn.Module):\n    def __init__(self):\n        super(SimpleNN, self).__init__()\n        self.fc1 = nn.Linear(46, 128)\n        self.fc2 = nn.Linear(128, 64)\n        self.fc3 = nn.Linear(64, 24)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        x = self.fc3(x)\n        return x\n\n\n# Initialize the model, define loss function and optimizer\nmodel = SimpleNN()\ncriterion = nn.CrossEntropyLoss()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training the model\nnum_epochs = 50\nfor epoch in range(num_epochs):\n    model.train()\n    optimizer.zero_grad()\n    outputs = model(X_train)\n    loss = criterion(outputs, y_train)\n    loss.backward()\n    optimizer.step()\n\n# Validate the model\nmodel.eval()\nwith torch.no_grad():\n    val_outputs = model(X_val)\n    _, predicted = torch.max(val_outputs, 1)\n    accuracy = accuracy_score(y_val.numpy(), predicted.numpy())\n\n# Save predictions to submission file\nsubmission = pd.DataFrame({\"id\": range(len(predicted)), \"label\": predicted.numpy() + 1})\nsubmission.to_csv(\"./working/submission.csv\", index=False)\n\n# Print the evaluation metric\nprint(\"Validation Accuracy:\", accuracy)\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import accuracy_score\nfrom sklearn.model_selection import train_test_split\n\n# Load data\ntrain_data = np.load(\"./input/train_data.npy\")\ntrain_labels = np.load(\"./input/train_label.npy\")\nval_data = np.load(\"./input/val_data.npy\")\nval_labels = np.load(\"./input/val_label.npy\")\n\n# Convert to PyTorch tensors\nX_train = torch.tensor(train_data, dtype=torch.float32)\ny_train = torch.tensor(\n    train_labels - 1, dtype=torch.long\n)  # Adjust labels to be zero-indexed\nX_val = torch.tensor(val_data, dtype=torch.float32)\ny_val = torch.tensor(val_labels - 1, dtype=torch.long)\n\n\n# Define a simple feedforward neural network\nclass SimpleNN(nn.Module):\n    def __init__(self):\n        super(SimpleNN, self).__init__()\n        self.fc1 = nn.Linear(46, 128)\n        self.fc2 = nn.Linear(128, 64)\n        self.fc3 = nn.Linear(64, 24)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        x = self.fc3(x)\n        return x\n\n\n# Initialize model, loss function, and optimizer\nmodel = SimpleNN()\ncriterion = nn.CrossEntropyLoss()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Train the model\nepochs = 50\nfor epoch in range(epochs):\n    model.train()\n    optimizer.zero_grad()\n    outputs = model(X_train)\n    loss = criterion(outputs, y_train)\n    loss.backward()\n    optimizer.step()\n\n# Validate the model\nmodel.eval()\nwith torch.no_grad():\n    val_outputs = model(X_val)\n    _, predicted = torch.max(val_outputs, 1)\n    accuracy = accuracy_score(y_val.numpy(), predicted.numpy())\n\n# Save predictions in submission.csv\nsubmission = np.column_stack(\n    (np.arange(len(predicted)), predicted.numpy() + 1)\n)  # Adjust back to 1-indexed\nnp.savetxt(\n    \"./working/submission.csv\",\n    submission,\n    delimiter=\",\",\n    header=\"Id,Label\",\n    comments=\"\",\n    fmt=\"%d\",\n)\n\n# Print the evaluation metric\nprint(f\"Validation Accuracy: {accuracy:.4f}\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.metrics import accuracy_score\n\n# Load data\ntrain_data = np.load(\"./input/train_data.npy\")\ntrain_label = np.load(\"./input/train_label.npy\")\nval_data = np.load(\"./input/val_data.npy\")\nval_label = np.load(\"./input/val_label.npy\")\n\n# Convert to PyTorch tensors\nX_train = torch.tensor(train_data, dtype=torch.float32)\ny_train = (\n    torch.tensor(train_label, dtype=torch.long) - 1\n)  # Adjusting labels to be zero-indexed\nX_val = torch.tensor(val_data, dtype=torch.float32)\ny_val = (\n    torch.tensor(val_label, dtype=torch.long) - 1\n)  # Adjusting labels to be zero-indexed\n\n# Create DataLoader\ntrain_dataset = TensorDataset(X_train, y_train)\ntrain_loader = DataLoader(train_dataset, batch_size=64, shuffle=True)\n\n\n# Define the neural network\nclass SimpleNN(nn.Module):\n    def __init__(self):\n        super(SimpleNN, self).__init__()\n        self.fc1 = nn.Linear(46, 128)\n        self.fc2 = nn.Linear(128, 64)\n        self.fc3 = nn.Linear(64, 24)\n        self.relu = nn.ReLU()\n\n    def forward(self, x):\n        x = self.relu(self.fc1(x))\n        x = self.relu(self.fc2(x))\n        x = self.fc3(x)\n        return x\n\n\n# Initialize model, loss function, and optimizer\nmodel = SimpleNN()\ncriterion = nn.CrossEntropyLoss()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Train the model\nnum_epochs = 50\nfor epoch in range(num_epochs):\n    model.train()\n    for inputs, labels in train_loader:\n        optimizer.zero_grad()\n        outputs = model(inputs)\n        loss = criterion(outputs, labels)\n        loss.backward()\n        optimizer.step()\n\n# Validate the model\nmodel.eval()\nwith torch.no_grad():\n    val_outputs = model(X_val)\n    _, predicted = torch.max(val_outputs, 1)\n    accuracy = accuracy_score(y_val.numpy(), predicted.numpy())\n\n# Save predictions to a submission file\nsubmission = pd.DataFrame({\"Id\": range(len(predicted)), \"Label\": predicted.numpy() + 1})\nsubmission.to_csv(\"./working/submission.csv\", index=False)\n\nprint(f\"Validation Accuracy: {accuracy:.4f}\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import accuracy_score\n\n# Load data\ntrain_data = np.load(\"./input/train_data.npy\")\ntrain_labels = np.load(\"./input/train_label.npy\")\nval_data = np.load(\"./input/val_data.npy\")\nval_labels = np.load(\"./input/val_label.npy\")\n\n# Convert to PyTorch tensors\nX_train = torch.tensor(train_data, dtype=torch.float32)\ny_train = torch.tensor(\n    train_labels - 1, dtype=torch.long\n)  # Adjust labels to be zero-indexed\nX_val = torch.tensor(val_data, dtype=torch.float32)\ny_val = torch.tensor(val_labels - 1, dtype=torch.long)\n\n\n# Define a feedforward neural network with batch normalization\nclass ImprovedNN(nn.Module):\n    def __init__(self):\n        super(ImprovedNN, self).__init__()\n        self.fc1 = nn.Linear(46, 128)\n        self.bn1 = nn.BatchNorm1d(128)\n        self.fc2 = nn.Linear(128, 64)\n        self.bn2 = nn.BatchNorm1d(64)\n        self.fc3 = nn.Linear(64, 24)\n\n    def forward(self, x):\n        x = torch.relu(self.bn1(self.fc1(x)))\n        x = torch.relu(self.bn2(self.fc2(x)))\n        x = self.fc3(x)\n        return x\n\n\n# Initialize model, loss function, and optimizer\nmodel = ImprovedNN()\ncriterion = nn.CrossEntropyLoss()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Train the model\nepochs = 100  # Increased number of epochs\nfor epoch in range(epochs):\n    model.train()\n    optimizer.zero_grad()\n    outputs = model(X_train)\n    loss = criterion(outputs, y_train)\n    loss.backward()\n    optimizer.step()\n\n# Validate the model\nmodel.eval()\nwith torch.no_grad():\n    val_outputs = model(X_val)\n    _, predicted = torch.max(val_outputs, 1)\n    accuracy = accuracy_score(y_val.numpy(), predicted.numpy())\n\n# Save predictions in submission.csv\nsubmission = np.column_stack(\n    (np.arange(len(predicted)), predicted.numpy() + 1)\n)  # Adjust back to 1-indexed\nnp.savetxt(\n    \"./working/submission.csv\",\n    submission,\n    delimiter=\",\",\n    header=\"Id,Label\",\n    comments=\"\",\n    fmt=\"%d\",\n)\n\n# Print the evaluation metric\nprint(f\"Validation Accuracy: {accuracy:.4f}\")\n", "import numpy as np\nimport pandas as pd\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import accuracy_score\n\n# Load data\ntrain_data = np.load(\"./input/train_data.npy\")\ntrain_label = np.load(\"./input/train_label.npy\")\nval_data = np.load(\"./input/val_data.npy\")\nval_label = np.load(\"./input/val_label.npy\")\n\n# Convert to PyTorch tensors\nX_train = torch.FloatTensor(train_data)\ny_train = torch.LongTensor(train_label - 1)  # Adjust for zero-indexing\nX_val = torch.FloatTensor(val_data)\ny_val = torch.LongTensor(val_label - 1)  # Adjust for zero-indexing\n\n\n# Define the neural network model\nclass SimpleNN(nn.Module):\n    def __init__(self):\n        super(SimpleNN, self).__init__()\n        self.fc1 = nn.Linear(46, 128)\n        self.fc2 = nn.Linear(128, 64)\n        self.fc3 = nn.Linear(64, 24)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = torch.relu(self.fc2(x))\n        x = self.fc3(x)\n        return x\n\n\n# Initialize the model, define loss function and optimizer\nmodel = SimpleNN()\ncriterion = nn.CrossEntropyLoss()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training the model\nnum_epochs = 50\nfor epoch in range(num_epochs):\n    model.train()\n    optimizer.zero_grad()\n    outputs = model(X_train)\n    loss = criterion(outputs, y_train)\n    loss.backward()\n    optimizer.step()\n\n# Validate the model\nmodel.eval()\nwith torch.no_grad():\n    val_outputs = model(X_val)\n    _, predicted = torch.max(val_outputs, 1)\n    accuracy = accuracy_score(y_val.numpy(), predicted.numpy())\n\n# Save predictions to submission file\nsubmission = pd.DataFrame({\"id\": range(len(predicted)), \"label\": predicted.numpy() + 1})\nsubmission.to_csv(\"./working/submission.csv\", index=False)\n\n# Print the evaluation metric\nprint(\"Validation Accuracy:\", accuracy)\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import accuracy_score\n\n# Load data\ntrain_data = np.load(\"./input/train_data.npy\")\ntrain_labels = np.load(\"./input/train_label.npy\")\nval_data = np.load(\"./input/val_data.npy\")\nval_labels = np.load(\"./input/val_label.npy\")\n\n# Convert to PyTorch tensors\nX_train = torch.tensor(train_data, dtype=torch.float32)\ny_train = torch.tensor(\n    train_labels - 1, dtype=torch.long\n)  # Adjust labels to be zero-indexed\nX_val = torch.tensor(val_data, dtype=torch.float32)\ny_val = torch.tensor(val_labels - 1, dtype=torch.long)\n\n\n# Define a feedforward neural network with batch normalization and dropout\nclass ImprovedNN(nn.Module):\n    def __init__(self):\n        super(ImprovedNN, self).__init__()\n        self.fc1 = nn.Linear(46, 128)\n        self.bn1 = nn.BatchNorm1d(128)\n        self.dropout1 = nn.Dropout(0.5)  # Dropout layer\n        self.fc2 = nn.Linear(128, 64)\n        self.bn2 = nn.BatchNorm1d(64)\n        self.dropout2 = nn.Dropout(0.5)  # Dropout layer\n        self.fc3 = nn.Linear(64, 24)\n\n    def forward(self, x):\n        x = torch.relu(self.bn1(self.fc1(x)))\n        x = self.dropout1(x)  # Apply dropout\n        x = torch.relu(self.bn2(self.fc2(x)))\n        x = self.dropout2(x)  # Apply dropout\n        x = self.fc3(x)\n        return x\n\n\n# Initialize model, loss function, and optimizer\nmodel = ImprovedNN()\ncriterion = nn.CrossEntropyLoss()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Train the model\nepochs = 100  # Increased number of epochs\nfor epoch in range(epochs):\n    model.train()\n    optimizer.zero_grad()\n    outputs = model(X_train)\n    loss = criterion(outputs, y_train)\n    loss.backward()\n    optimizer.step()\n\n# Validate the model\nmodel.eval()\nwith torch.no_grad():\n    val_outputs = model(X_val)\n    _, predicted = torch.max(val_outputs, 1)\n    accuracy = accuracy_score(y_val.numpy(), predicted.numpy())\n\n# Save predictions in submission.csv\nsubmission = np.column_stack(\n    (np.arange(len(predicted)), predicted.numpy() + 1)\n)  # Adjust back to 1-indexed\nnp.savetxt(\n    \"./working/submission.csv\",\n    submission,\n    delimiter=\",\",\n    header=\"Id,Label\",\n    comments=\"\",\n    fmt=\"%d\",\n)\n\n# Print the evaluation metric\nprint(f\"Validation Accuracy: {accuracy:.4f}\")\n", "import numpy as np\nimport pandas as pd\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import accuracy_score\n\n# Load the data\ntrain_data = np.load(\"./input/train_data.npy\")\ntrain_label = np.load(\"./input/train_label.npy\")\nval_data = np.load(\"./input/val_data.npy\")\nval_label = np.load(\"./input/val_label.npy\")\n\n# Convert to PyTorch tensors\nX_train = torch.tensor(train_data, dtype=torch.float32)\ny_train = torch.tensor(\n    train_label - 1, dtype=torch.long\n)  # Adjust labels to be zero-indexed\nX_val = torch.tensor(val_data, dtype=torch.float32)\ny_val = torch.tensor(\n    val_label - 1, dtype=torch.long\n)  # Adjust labels to be zero-indexed\n\n\n# Define the model\nclass FeedforwardNN(nn.Module):\n    def __init__(self):\n        super(FeedforwardNN, self).__init__()\n        self.fc1 = nn.Linear(46, 128)\n        self.fc2 = nn.Linear(128, 24)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.fc2(x)\n        return x\n\n\n# Instantiate the model, define the loss function and the optimizer\nmodel = FeedforwardNN()\ncriterion = nn.CrossEntropyLoss()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Training loop\nnum_epochs = 50\nfor epoch in range(num_epochs):\n    model.train()\n    optimizer.zero_grad()\n    outputs = model(X_train)\n    loss = criterion(outputs, y_train)\n    loss.backward()\n    optimizer.step()\n\n# Validation\nmodel.eval()\nwith torch.no_grad():\n    val_outputs = model(X_val)\n    _, predicted = torch.max(val_outputs.data, 1)\n    accuracy = accuracy_score(y_val.numpy(), predicted.numpy())\n\n# Save predictions to submission file\nsubmission = pd.DataFrame(\n    {\"Id\": range(len(val_data)), \"Predicted\": predicted.numpy() + 1}\n)\nsubmission.to_csv(\"./working/submission.csv\", index=False)\n\nprint(f\"Validation Accuracy: {accuracy:.4f}\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import accuracy_score\n\n# Load data\ntrain_data = np.load(\"./input/train_data.npy\")\ntrain_labels = np.load(\"./input/train_label.npy\")\nval_data = np.load(\"./input/val_data.npy\")\nval_labels = np.load(\"./input/val_label.npy\")\n\n# Convert to PyTorch tensors\nX_train = torch.tensor(train_data, dtype=torch.float32)\ny_train = torch.tensor(\n    train_labels - 1, dtype=torch.long\n)  # Adjust labels to be zero-indexed\nX_val = torch.tensor(val_data, dtype=torch.float32)\ny_val = torch.tensor(val_labels - 1, dtype=torch.long)\n\n\n# Define a feedforward neural network with batch normalization and dropout\nclass ImprovedNN(nn.Module):\n    def __init__(self):\n        super(ImprovedNN, self).__init__()\n        self.fc1 = nn.Linear(46, 128)\n        self.bn1 = nn.BatchNorm1d(128)\n        self.dropout1 = nn.Dropout(0.5)\n        self.fc2 = nn.Linear(128, 64)\n        self.bn2 = nn.BatchNorm1d(64)\n        self.dropout2 = nn.Dropout(0.5)\n        self.fc3 = nn.Linear(64, 24)\n\n    def forward(self, x):\n        x = torch.relu(self.bn1(self.fc1(x)))\n        x = self.dropout1(x)\n        x = torch.relu(self.bn2(self.fc2(x)))\n        x = self.dropout2(x)\n        x = self.fc3(x)\n        return x\n\n\n# Initialize model, loss function, and optimizer\nmodel = ImprovedNN()\ncriterion = nn.CrossEntropyLoss()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Train the model\nepochs = 100  # Increased number of epochs\nfor epoch in range(epochs):\n    model.train()\n    optimizer.zero_grad()\n    outputs = model(X_train)\n    loss = criterion(outputs, y_train)\n    loss.backward()\n    optimizer.step()\n\n# Validate the model\nmodel.eval()\nwith torch.no_grad():\n    val_outputs = model(X_val)\n    _, predicted = torch.max(val_outputs, 1)\n    accuracy = accuracy_score(y_val.numpy(), predicted.numpy())\n\n# Save predictions in submission.csv\nsubmission = np.column_stack(\n    (np.arange(len(predicted)), predicted.numpy() + 1)\n)  # Adjust back to 1-indexed\nnp.savetxt(\n    \"./working/submission.csv\",\n    submission,\n    delimiter=\",\",\n    header=\"Id,Label\",\n    comments=\"\",\n    fmt=\"%d\",\n)\n\n# Print the evaluation metric\nprint(f\"Validation Accuracy: {accuracy:.4f}\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import accuracy_score\nfrom torch.optim.lr_scheduler import ReduceLROnPlateau\n\n# Load data\ntrain_data = np.load(\"./input/train_data.npy\")\ntrain_labels = np.load(\"./input/train_label.npy\")\nval_data = np.load(\"./input/val_data.npy\")\nval_labels = np.load(\"./input/val_label.npy\")\n\n# Convert to PyTorch tensors\nX_train = torch.tensor(train_data, dtype=torch.float32)\ny_train = torch.tensor(\n    train_labels - 1, dtype=torch.long\n)  # Adjust labels to be zero-indexed\nX_val = torch.tensor(val_data, dtype=torch.float32)\ny_val = torch.tensor(val_labels - 1, dtype=torch.long)\n\n\n# Define a feedforward neural network with batch normalization\nclass ImprovedNN(nn.Module):\n    def __init__(self):\n        super(ImprovedNN, self).__init__()\n        self.fc1 = nn.Linear(46, 128)\n        self.bn1 = nn.BatchNorm1d(128)\n        self.fc2 = nn.Linear(128, 64)\n        self.bn2 = nn.BatchNorm1d(64)\n        self.fc3 = nn.Linear(64, 24)\n\n    def forward(self, x):\n        x = torch.relu(self.bn1(self.fc1(x)))\n        x = torch.relu(self.bn2(self.fc2(x)))\n        x = self.fc3(x)\n        return x\n\n\n# Initialize model, loss function, and optimizer\nmodel = ImprovedNN()\ncriterion = nn.CrossEntropyLoss()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\nscheduler = ReduceLROnPlateau(optimizer, \"min\", patience=5, verbose=True)\n\n# Train the model\nepochs = 100\nbest_accuracy = 0.0\npatience_counter = 0\nfor epoch in range(epochs):\n    model.train()\n    optimizer.zero_grad()\n    outputs = model(X_train)\n    loss = criterion(outputs, y_train)\n    loss.backward()\n    optimizer.step()\n\n    # Validate the model\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(X_val)\n        _, predicted = torch.max(val_outputs, 1)\n        accuracy = accuracy_score(y_val.numpy(), predicted.numpy())\n\n    # Step the scheduler\n    scheduler.step(loss)\n\n    # Check for improvement\n    if accuracy > best_accuracy:\n        best_accuracy = accuracy\n        patience_counter = 0\n    else:\n        patience_counter += 1\n\n    # Early stopping\n    if patience_counter >= 10:\n        print(\"Early stopping triggered.\")\n        break\n\n# Save predictions in submission.csv\nsubmission = np.column_stack(\n    (np.arange(len(predicted)), predicted.numpy() + 1)\n)  # Adjust back to 1-indexed\nnp.savetxt(\n    \"./working/submission.csv\",\n    submission,\n    delimiter=\",\",\n    header=\"Id,Label\",\n    comments=\"\",\n    fmt=\"%d\",\n)\n\n# Print the evaluation metric\nprint(f\"Validation Accuracy: {best_accuracy:.4f}\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import accuracy_score\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom torch.optim.lr_scheduler import ReduceLROnPlateau\n\n# Load data\ntrain_data = np.load(\"./input/train_data.npy\")\ntrain_labels = np.load(\"./input/train_label.npy\")\nval_data = np.load(\"./input/val_data.npy\")\nval_labels = np.load(\"./input/val_label.npy\")\n\n# Convert to PyTorch tensors\nX_train = torch.tensor(train_data, dtype=torch.float32)\ny_train = torch.tensor(\n    train_labels - 1, dtype=torch.long\n)  # Adjust labels to be zero-indexed\nX_val = torch.tensor(val_data, dtype=torch.float32)\ny_val = torch.tensor(val_labels - 1, dtype=torch.long)\n\n# Create DataLoader for training\ntrain_dataset = TensorDataset(X_train, y_train)\ntrain_loader = DataLoader(train_dataset, batch_size=32, shuffle=True)\n\n\n# Define a feedforward neural network with batch normalization\nclass ImprovedNN(nn.Module):\n    def __init__(self):\n        super(ImprovedNN, self).__init__()\n        self.fc1 = nn.Linear(46, 128)\n        self.bn1 = nn.BatchNorm1d(128)\n        self.fc2 = nn.Linear(128, 64)\n        self.bn2 = nn.BatchNorm1d(64)\n        self.fc3 = nn.Linear(64, 24)\n\n    def forward(self, x):\n        x = torch.relu(self.bn1(self.fc1(x)))\n        x = torch.relu(self.bn2(self.fc2(x)))\n        x = self.fc3(x)\n        return x\n\n\n# Initialize model, loss function, and optimizer\nmodel = ImprovedNN()\ncriterion = nn.CrossEntropyLoss()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\nscheduler = ReduceLROnPlateau(optimizer, \"min\", patience=5, verbose=True)\n\n# Train the model with early stopping\nepochs = 100\nbest_accuracy = 0\npatience = 10\npatience_counter = 0\n\nfor epoch in range(epochs):\n    model.train()\n    for batch_X, batch_y in train_loader:\n        optimizer.zero_grad()\n        outputs = model(batch_X)\n        loss = criterion(outputs, batch_y)\n        loss.backward()\n        optimizer.step()\n\n    # Validate the model\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(X_val)\n        _, predicted = torch.max(val_outputs, 1)\n        accuracy = accuracy_score(y_val.numpy(), predicted.numpy())\n        scheduler.step(loss)  # Step the scheduler based on the current loss\n\n    # Check for early stopping\n    if accuracy > best_accuracy:\n        best_accuracy = accuracy\n        patience_counter = 0\n    else:\n        patience_counter += 1\n\n    if patience_counter >= patience:\n        print(f\"Early stopping at epoch {epoch + 1}\")\n        break\n\n# Save predictions in submission.csv\nsubmission = np.column_stack(\n    (np.arange(len(predicted)), predicted.numpy() + 1)\n)  # Adjust back to 1-indexed\nnp.savetxt(\n    \"./working/submission.csv\",\n    submission,\n    delimiter=\",\",\n    header=\"Id,Label\",\n    comments=\"\",\n    fmt=\"%d\",\n)\n\n# Print the evaluation metric\nprint(f\"Validation Accuracy: {accuracy:.4f}\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import accuracy_score\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom torch.optim.lr_scheduler import ReduceLROnPlateau\n\n# Load data\ntrain_data = np.load(\"./input/train_data.npy\")\ntrain_labels = np.load(\"./input/train_label.npy\")\nval_data = np.load(\"./input/val_data.npy\")\nval_labels = np.load(\"./input/val_label.npy\")\n\n# Convert to PyTorch tensors\nX_train = torch.tensor(train_data, dtype=torch.float32)\ny_train = torch.tensor(\n    train_labels - 1, dtype=torch.long\n)  # Adjust labels to be zero-indexed\nX_val = torch.tensor(val_data, dtype=torch.float32)\ny_val = torch.tensor(val_labels - 1, dtype=torch.long)\n\n# Create DataLoader for training\ntrain_dataset = TensorDataset(X_train, y_train)\ntrain_loader = DataLoader(train_dataset, batch_size=32, shuffle=True)\n\n\n# Define a feedforward neural network with batch normalization and dropout\nclass ImprovedNN(nn.Module):\n    def __init__(self):\n        super(ImprovedNN, self).__init__()\n        self.fc1 = nn.Linear(46, 128)\n        self.bn1 = nn.BatchNorm1d(128)\n        self.fc2 = nn.Linear(128, 64)\n        self.bn2 = nn.BatchNorm1d(64)\n        self.fc3 = nn.Linear(64, 32)\n        self.dropout = nn.Dropout(0.5)\n        self.fc4 = nn.Linear(32, 24)\n\n    def forward(self, x):\n        x = torch.relu(self.bn1(self.fc1(x)))\n        x = torch.relu(self.bn2(self.fc2(x)))\n        x = self.dropout(x)\n        x = self.fc4(self.fc3(x))\n        return x\n\n\n# Initialize model, loss function, and optimizer\nmodel = ImprovedNN()\ncriterion = nn.CrossEntropyLoss()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\nscheduler = ReduceLROnPlateau(optimizer, \"min\", patience=5, verbose=True)\n\n# Train the model with early stopping\nepochs = 100\nbest_accuracy = 0\npatience = 10\npatience_counter = 0\n\nfor epoch in range(epochs):\n    model.train()\n    for batch_X, batch_y in train_loader:\n        optimizer.zero_grad()\n        outputs = model(batch_X)\n        loss = criterion(outputs, batch_y)\n        loss.backward()\n        optimizer.step()\n\n    # Validate the model\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(X_val)\n        _, predicted = torch.max(val_outputs, 1)\n        accuracy = accuracy_score(y_val.numpy(), predicted.numpy())\n        scheduler.step(loss)  # Step the scheduler based on the current loss\n\n    # Check for early stopping\n    if accuracy > best_accuracy:\n        best_accuracy = accuracy\n        patience_counter = 0\n    else:\n        patience_counter += 1\n\n    if patience_counter >= patience:\n        print(f\"Early stopping at epoch {epoch + 1}\")\n        break\n\n# Save predictions in submission.csv\nsubmission = np.column_stack(\n    (np.arange(len(predicted)), predicted.numpy() + 1)\n)  # Adjust back to 1-indexed\nnp.savetxt(\n    \"./working/submission.csv\",\n    submission,\n    delimiter=\",\",\n    header=\"Id,Label\",\n    comments=\"\",\n    fmt=\"%d\",\n)\n\n# Print the evaluation metric\nprint(f\"Validation Accuracy: {accuracy:.4f}\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import accuracy_score\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom torch.optim.lr_scheduler import ReduceLROnPlateau\n\n# Load data\ntrain_data = np.load(\"./input/train_data.npy\")\ntrain_labels = np.load(\"./input/train_label.npy\")\nval_data = np.load(\"./input/val_data.npy\")\nval_labels = np.load(\"./input/val_label.npy\")\n\n# Convert to PyTorch tensors\nX_train = torch.tensor(train_data, dtype=torch.float32)\ny_train = torch.tensor(\n    train_labels - 1, dtype=torch.long\n)  # Adjust labels to be zero-indexed\nX_val = torch.tensor(val_data, dtype=torch.float32)\ny_val = torch.tensor(val_labels - 1, dtype=torch.long)\n\n# Create DataLoader for training\ntrain_dataset = TensorDataset(X_train, y_train)\ntrain_loader = DataLoader(train_dataset, batch_size=32, shuffle=True)\n\n\n# Define a feedforward neural network with an additional hidden layer and dropout\nclass ImprovedNN(nn.Module):\n    def __init__(self):\n        super(ImprovedNN, self).__init__()\n        self.fc1 = nn.Linear(46, 128)\n        self.bn1 = nn.BatchNorm1d(128)\n        self.dropout1 = nn.Dropout(0.5)\n        self.fc2 = nn.Linear(128, 64)\n        self.bn2 = nn.BatchNorm1d(64)\n        self.dropout2 = nn.Dropout(0.5)\n        self.fc3 = nn.Linear(64, 32)\n        self.dropout3 = nn.Dropout(0.5)\n        self.fc4 = nn.Linear(32, 24)\n\n    def forward(self, x):\n        x = torch.relu(self.bn1(self.fc1(x)))\n        x = self.dropout1(x)\n        x = torch.relu(self.bn2(self.fc2(x)))\n        x = self.dropout2(x)\n        x = self.dropout3(self.fc3(x))\n        x = self.fc4(x)\n        return x\n\n\n# Initialize model, loss function, and optimizer\nmodel = ImprovedNN()\ncriterion = nn.CrossEntropyLoss()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\nscheduler = ReduceLROnPlateau(optimizer, \"min\", patience=5, verbose=True)\n\n# Train the model with early stopping\nepochs = 100\nbest_accuracy = 0\npatience = 10\npatience_counter = 0\n\nfor epoch in range(epochs):\n    model.train()\n    for batch_X, batch_y in train_loader:\n        optimizer.zero_grad()\n        outputs = model(batch_X)\n        loss = criterion(outputs, batch_y)\n        loss.backward()\n        optimizer.step()\n\n    # Validate the model\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(X_val)\n        _, predicted = torch.max(val_outputs, 1)\n        accuracy = accuracy_score(y_val.numpy(), predicted.numpy())\n        scheduler.step(loss)  # Step the scheduler based on the current loss\n\n    # Check for early stopping\n    if accuracy > best_accuracy:\n        best_accuracy = accuracy\n        patience_counter = 0\n    else:\n        patience_counter += 1\n\n    if patience_counter >= patience:\n        print(f\"Early stopping at epoch {epoch + 1}\")\n        break\n\n# Save predictions in submission.csv\nsubmission = np.column_stack(\n    (np.arange(len(predicted)), predicted.numpy() + 1)\n)  # Adjust back to 1-indexed\nnp.savetxt(\n    \"./working/submission.csv\",\n    submission,\n    delimiter=\",\",\n    header=\"Id,Label\",\n    comments=\"\",\n    fmt=\"%d\",\n)\n\n# Print the evaluation metric\nprint(f\"Validation Accuracy: {accuracy:.4f}\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import accuracy_score\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom torch.optim.lr_scheduler import ReduceLROnPlateau\n\n# Load data\ntrain_data = np.load(\"./input/train_data.npy\")\ntrain_labels = np.load(\"./input/train_label.npy\")\nval_data = np.load(\"./input/val_data.npy\")\nval_labels = np.load(\"./input/val_label.npy\")\n\n# Convert to PyTorch tensors\nX_train = torch.tensor(train_data, dtype=torch.float32)\ny_train = torch.tensor(\n    train_labels - 1, dtype=torch.long\n)  # Adjust labels to be zero-indexed\nX_val = torch.tensor(val_data, dtype=torch.float32)\ny_val = torch.tensor(val_labels - 1, dtype=torch.long)\n\n# Create DataLoader for training\ntrain_dataset = TensorDataset(X_train, y_train)\ntrain_loader = DataLoader(train_dataset, batch_size=32, shuffle=True)\n\n\n# Define a feedforward neural network with an additional hidden layer and dropout\nclass ImprovedNN(nn.Module):\n    def __init__(self):\n        super(ImprovedNN, self).__init__()\n        self.fc1 = nn.Linear(46, 128)\n        self.bn1 = nn.BatchNorm1d(128)\n        self.dropout1 = nn.Dropout(0.5)\n        self.fc2 = nn.Linear(128, 64)\n        self.bn2 = nn.BatchNorm1d(64)\n        self.dropout2 = nn.Dropout(0.5)\n        self.fc3 = nn.Linear(64, 24)\n\n    def forward(self, x):\n        x = torch.relu(self.bn1(self.fc1(x)))\n        x = self.dropout1(x)\n        x = torch.relu(self.bn2(self.fc2(x)))\n        x = self.dropout2(x)\n        x = self.fc3(x)\n        return x\n\n\n# Initialize model, loss function, and optimizer\nmodel = ImprovedNN()\ncriterion = nn.CrossEntropyLoss()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\nscheduler = ReduceLROnPlateau(optimizer, \"min\", patience=5, verbose=True)\n\n# Train the model with early stopping\nepochs = 100\nbest_accuracy = 0\npatience = 10\npatience_counter = 0\n\nfor epoch in range(epochs):\n    model.train()\n    for batch_X, batch_y in train_loader:\n        optimizer.zero_grad()\n        outputs = model(batch_X)\n        loss = criterion(outputs, batch_y)\n        loss.backward()\n        optimizer.step()\n\n    # Validate the model\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(X_val)\n        _, predicted = torch.max(val_outputs, 1)\n        accuracy = accuracy_score(y_val.numpy(), predicted.numpy())\n        scheduler.step(loss)  # Step the scheduler based on the current loss\n\n    # Check for early stopping\n    if accuracy > best_accuracy:\n        best_accuracy = accuracy\n        patience_counter = 0\n    else:\n        patience_counter += 1\n\n    if patience_counter >= patience:\n        print(f\"Early stopping at epoch {epoch + 1}\")\n        break\n\n# Save predictions in submission.csv\nsubmission = np.column_stack(\n    (np.arange(len(predicted)), predicted.numpy() + 1)\n)  # Adjust back to 1-indexed\nnp.savetxt(\n    \"./working/submission.csv\",\n    submission,\n    delimiter=\",\",\n    header=\"Id,Label\",\n    comments=\"\",\n    fmt=\"%d\",\n)\n\n# Print the evaluation metric\nprint(f\"Validation Accuracy: {accuracy:.4f}\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import accuracy_score\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom torch.optim.lr_scheduler import ReduceLROnPlateau\n\n# Load data\ntrain_data = np.load(\"./input/train_data.npy\")\ntrain_labels = np.load(\"./input/train_label.npy\")\nval_data = np.load(\"./input/val_data.npy\")\nval_labels = np.load(\"./input/val_label.npy\")\n\n# Convert to PyTorch tensors\nX_train = torch.tensor(train_data, dtype=torch.float32)\ny_train = torch.tensor(\n    train_labels - 1, dtype=torch.long\n)  # Adjust labels to be zero-indexed\nX_val = torch.tensor(val_data, dtype=torch.float32)\ny_val = torch.tensor(val_labels - 1, dtype=torch.long)\n\n# Create DataLoader for training\ntrain_dataset = TensorDataset(X_train, y_train)\ntrain_loader = DataLoader(train_dataset, batch_size=32, shuffle=True)\n\n\n# Define a feedforward neural network with additional hidden layer and dropout\nclass ImprovedNN(nn.Module):\n    def __init__(self):\n        super(ImprovedNN, self).__init__()\n        self.fc1 = nn.Linear(46, 128)\n        self.dropout1 = nn.Dropout(0.5)\n        self.fc2 = nn.Linear(128, 64)\n        self.dropout2 = nn.Dropout(0.5)\n        self.fc3 = nn.Linear(64, 24)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.dropout1(x)\n        x = torch.relu(self.fc2(x))\n        x = self.dropout2(x)\n        x = self.fc3(x)\n        return x\n\n\n# Initialize model, loss function, and optimizer\nmodel = ImprovedNN()\ncriterion = nn.CrossEntropyLoss()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\nscheduler = ReduceLROnPlateau(optimizer, \"min\", patience=5, verbose=True)\n\n# Train the model with early stopping\nepochs = 100\nbest_accuracy = 0\npatience = 10\npatience_counter = 0\n\nfor epoch in range(epochs):\n    model.train()\n    for batch_X, batch_y in train_loader:\n        optimizer.zero_grad()\n        outputs = model(batch_X)\n        loss = criterion(outputs, batch_y)\n        loss.backward()\n        optimizer.step()\n\n    # Validate the model\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(X_val)\n        _, predicted = torch.max(val_outputs, 1)\n        accuracy = accuracy_score(y_val.numpy(), predicted.numpy())\n        scheduler.step(loss)  # Step the scheduler based on the current loss\n\n    # Check for early stopping\n    if accuracy > best_accuracy:\n        best_accuracy = accuracy\n        patience_counter = 0\n    else:\n        patience_counter += 1\n\n    if patience_counter >= patience:\n        print(f\"Early stopping at epoch {epoch + 1}\")\n        break\n\n# Save predictions in submission.csv\nsubmission = np.column_stack(\n    (np.arange(len(predicted)), predicted.numpy() + 1)\n)  # Adjust back to 1-indexed\nnp.savetxt(\n    \"./working/submission.csv\",\n    submission,\n    delimiter=\",\",\n    header=\"Id,Label\",\n    comments=\"\",\n    fmt=\"%d\",\n)\n\n# Print the evaluation metric\nprint(f\"Validation Accuracy: {accuracy:.4f}\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import accuracy_score\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom torch.optim.lr_scheduler import ReduceLROnPlateau\n\n# Load data\ntrain_data = np.load(\"./input/train_data.npy\")\ntrain_labels = np.load(\"./input/train_label.npy\")\nval_data = np.load(\"./input/val_data.npy\")\nval_labels = np.load(\"./input/val_label.npy\")\n\n# Convert to PyTorch tensors\nX_train = torch.tensor(train_data, dtype=torch.float32)\ny_train = torch.tensor(\n    train_labels - 1, dtype=torch.long\n)  # Adjust labels to be zero-indexed\nX_val = torch.tensor(val_data, dtype=torch.float32)\ny_val = torch.tensor(val_labels - 1, dtype=torch.long)\n\n# Create DataLoader for training\ntrain_dataset = TensorDataset(X_train, y_train)\ntrain_loader = DataLoader(train_dataset, batch_size=32, shuffle=True)\n\n\n# Define a feedforward neural network with additional hidden layer and dropout\nclass ImprovedNN(nn.Module):\n    def __init__(self):\n        super(ImprovedNN, self).__init__()\n        self.fc1 = nn.Linear(46, 128)\n        self.dropout1 = nn.Dropout(0.5)\n        self.bn1 = nn.BatchNorm1d(128)\n        self.fc2 = nn.Linear(128, 128)\n        self.dropout2 = nn.Dropout(0.5)\n        self.bn2 = nn.BatchNorm1d(128)\n        self.fc3 = nn.Linear(128, 24)\n\n    def forward(self, x):\n        x = torch.relu(self.bn1(self.fc1(x)))\n        x = self.dropout1(x)\n        x = torch.relu(self.bn2(self.fc2(x)))\n        x = self.dropout2(x)\n        x = self.fc3(x)\n        return x\n\n\n# Initialize model, loss function, and optimizer\nmodel = ImprovedNN()\ncriterion = nn.CrossEntropyLoss()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\nscheduler = ReduceLROnPlateau(optimizer, \"min\", patience=5, verbose=True)\n\n# Train the model with early stopping\nepochs = 100\nbest_accuracy = 0\npatience = 10\npatience_counter = 0\n\nfor epoch in range(epochs):\n    model.train()\n    for batch_X, batch_y in train_loader:\n        optimizer.zero_grad()\n        outputs = model(batch_X)\n        loss = criterion(outputs, batch_y)\n        loss.backward()\n        optimizer.step()\n\n    # Validate the model\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(X_val)\n        _, predicted = torch.max(val_outputs, 1)\n        accuracy = accuracy_score(y_val.numpy(), predicted.numpy())\n        scheduler.step(loss)  # Step the scheduler based on the current loss\n\n    # Check for early stopping\n    if accuracy > best_accuracy:\n        best_accuracy = accuracy\n        patience_counter = 0\n    else:\n        patience_counter += 1\n\n    if patience_counter >= patience:\n        print(f\"Early stopping at epoch {epoch + 1}\")\n        break\n\n# Save predictions in submission.csv\nsubmission = np.column_stack(\n    (np.arange(len(predicted)), predicted.numpy() + 1)\n)  # Adjust back to 1-indexed\nnp.savetxt(\n    \"./working/submission.csv\",\n    submission,\n    delimiter=\",\",\n    header=\"Id,Label\",\n    comments=\"\",\n    fmt=\"%d\",\n)\n\n# Print the evaluation metric\nprint(f\"Validation Accuracy: {accuracy:.4f}\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import accuracy_score\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom torch.optim.lr_scheduler import ReduceLROnPlateau\n\n# Load data\ntrain_data = np.load(\"./input/train_data.npy\")\ntrain_labels = np.load(\"./input/train_label.npy\")\nval_data = np.load(\"./input/val_data.npy\")\nval_labels = np.load(\"./input/val_label.npy\")\n\n# Convert to PyTorch tensors\nX_train = torch.tensor(train_data, dtype=torch.float32)\ny_train = torch.tensor(\n    train_labels - 1, dtype=torch.long\n)  # Adjust labels to be zero-indexed\nX_val = torch.tensor(val_data, dtype=torch.float32)\ny_val = torch.tensor(val_labels - 1, dtype=torch.long)\n\n# Create DataLoader for training\ntrain_dataset = TensorDataset(X_train, y_train)\ntrain_loader = DataLoader(train_dataset, batch_size=32, shuffle=True)\n\n\n# Define a feedforward neural network with increased complexity\nclass ImprovedNN(nn.Module):\n    def __init__(self):\n        super(ImprovedNN, self).__init__()\n        self.fc1 = nn.Linear(46, 256)\n        self.bn1 = nn.BatchNorm1d(256)\n        self.dropout1 = nn.Dropout(0.5)\n        self.fc2 = nn.Linear(256, 128)\n        self.bn2 = nn.BatchNorm1d(128)\n        self.dropout2 = nn.Dropout(0.5)\n        self.fc3 = nn.Linear(128, 24)\n\n    def forward(self, x):\n        x = torch.relu(self.bn1(self.fc1(x)))\n        x = self.dropout1(x)\n        x = torch.relu(self.bn2(self.fc2(x)))\n        x = self.dropout2(x)\n        x = self.fc3(x)\n        return x\n\n\n# Initialize model, loss function, and optimizer\nmodel = ImprovedNN()\ncriterion = nn.CrossEntropyLoss()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\nscheduler = ReduceLROnPlateau(optimizer, \"min\", patience=5, verbose=True)\n\n# Train the model with early stopping\nepochs = 100\nbest_accuracy = 0\npatience = 10\npatience_counter = 0\n\nfor epoch in range(epochs):\n    model.train()\n    for batch_X, batch_y in train_loader:\n        optimizer.zero_grad()\n        outputs = model(batch_X)\n        loss = criterion(outputs, batch_y)\n        loss.backward()\n        optimizer.step()\n\n    # Validate the model\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(X_val)\n        _, predicted = torch.max(val_outputs, 1)\n        accuracy = accuracy_score(y_val.numpy(), predicted.numpy())\n        scheduler.step(loss)  # Step the scheduler based on the current loss\n\n    # Check for early stopping\n    if accuracy > best_accuracy:\n        best_accuracy = accuracy\n        patience_counter = 0\n    else:\n        patience_counter += 1\n\n    if patience_counter >= patience:\n        print(f\"Early stopping at epoch {epoch + 1}\")\n        break\n\n# Save predictions in submission.csv\nsubmission = np.column_stack(\n    (np.arange(len(predicted)), predicted.numpy() + 1)\n)  # Adjust back to 1-indexed\nnp.savetxt(\n    \"./working/submission.csv\",\n    submission,\n    delimiter=\",\",\n    header=\"Id,Label\",\n    comments=\"\",\n    fmt=\"%d\",\n)\n\n# Print the evaluation metric\nprint(f\"Validation Accuracy: {accuracy:.4f}\")\n", "import numpy as np\nimport pandas as pd\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom sklearn.metrics import accuracy_score\n\n# Load data\ntrain_data = np.load(\"./input/train_data.npy\")\ntrain_label = np.load(\"./input/train_label.npy\")\nval_data = np.load(\"./input/val_data.npy\")\nval_label = np.load(\"./input/val_label.npy\")\n\n# Convert to PyTorch tensors\nX_train = torch.tensor(train_data, dtype=torch.float32)\ny_train = (\n    torch.tensor(train_label, dtype=torch.long) - 1\n)  # Adjusting labels to be zero-indexed\nX_val = torch.tensor(val_data, dtype=torch.float32)\ny_val = (\n    torch.tensor(val_label, dtype=torch.long) - 1\n)  # Adjusting labels to be zero-indexed\n\n# Create DataLoader\ntrain_dataset = TensorDataset(X_train, y_train)\ntrain_loader = DataLoader(train_dataset, batch_size=64, shuffle=True)\n\n\n# Define the neural network\nclass SimpleNN(nn.Module):\n    def __init__(self):\n        super(SimpleNN, self).__init__()\n        self.fc1 = nn.Linear(46, 128)\n        self.fc2 = nn.Linear(128, 64)\n        self.fc3 = nn.Linear(64, 24)\n        self.relu = nn.ReLU()\n\n    def forward(self, x):\n        x = self.relu(self.fc1(x))\n        x = self.relu(self.fc2(x))\n        x = self.fc3(x)\n        return x\n\n\n# Initialize model, loss function, and optimizer\nmodel = SimpleNN()\ncriterion = nn.CrossEntropyLoss()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\n\n# Train the model\nnum_epochs = 50\nfor epoch in range(num_epochs):\n    model.train()\n    for inputs, labels in train_loader:\n        optimizer.zero_grad()\n        outputs = model(inputs)\n        loss = criterion(outputs, labels)\n        loss.backward()\n        optimizer.step()\n\n# Validate the model\nmodel.eval()\nwith torch.no_grad():\n    val_outputs = model(X_val)\n    _, predicted = torch.max(val_outputs, 1)\n    accuracy = accuracy_score(y_val.numpy(), predicted.numpy())\n\n# Save predictions to a submission file\nsubmission = pd.DataFrame({\"Id\": range(len(predicted)), \"Label\": predicted.numpy() + 1})\nsubmission.to_csv(\"./working/submission.csv\", index=False)\n\nprint(f\"Validation Accuracy: {accuracy:.4f}\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import accuracy_score\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom torch.optim.lr_scheduler import ReduceLROnPlateau\n\n# Load data\ntrain_data = np.load(\"./input/train_data.npy\")\ntrain_labels = np.load(\"./input/train_label.npy\")\nval_data = np.load(\"./input/val_data.npy\")\nval_labels = np.load(\"./input/val_label.npy\")\n\n# Convert to PyTorch tensors\nX_train = torch.tensor(train_data, dtype=torch.float32)\ny_train = torch.tensor(\n    train_labels - 1, dtype=torch.long\n)  # Adjust labels to be zero-indexed\nX_val = torch.tensor(val_data, dtype=torch.float32)\ny_val = torch.tensor(val_labels - 1, dtype=torch.long)\n\n# Create DataLoader for training\ntrain_dataset = TensorDataset(X_train, y_train)\ntrain_loader = DataLoader(train_dataset, batch_size=32, shuffle=True)\n\n\n# Define a feedforward neural network with an additional hidden layer\nclass ImprovedNN(nn.Module):\n    def __init__(self):\n        super(ImprovedNN, self).__init__()\n        self.fc1 = nn.Linear(46, 256)\n        self.bn1 = nn.BatchNorm1d(256)\n        self.dropout1 = nn.Dropout(0.5)\n        self.fc2 = nn.Linear(256, 128)\n        self.bn2 = nn.BatchNorm1d(128)\n        self.dropout2 = nn.Dropout(0.5)\n        self.fc3 = nn.Linear(128, 64)\n        self.bn3 = nn.BatchNorm1d(64)\n        self.fc4 = nn.Linear(64, 24)\n\n    def forward(self, x):\n        x = torch.relu(self.bn1(self.fc1(x)))\n        x = self.dropout1(x)\n        x = torch.relu(self.bn2(self.fc2(x)))\n        x = self.dropout2(x)\n        x = torch.relu(self.bn3(self.fc3(x)))\n        x = self.fc4(x)\n        return x\n\n\n# Initialize model, loss function, and optimizer\nmodel = ImprovedNN()\ncriterion = nn.CrossEntropyLoss()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\nscheduler = ReduceLROnPlateau(optimizer, \"min\", patience=5, verbose=True)\n\n# Train the model with early stopping\nepochs = 100\nbest_accuracy = 0\npatience = 10\npatience_counter = 0\n\nfor epoch in range(epochs):\n    model.train()\n    for batch_X, batch_y in train_loader:\n        optimizer.zero_grad()\n        outputs = model(batch_X)\n        loss = criterion(outputs, batch_y)\n        loss.backward()\n        optimizer.step()\n\n    # Validate the model\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(X_val)\n        _, predicted = torch.max(val_outputs, 1)\n        accuracy = accuracy_score(y_val.numpy(), predicted.numpy())\n        scheduler.step(loss)  # Step the scheduler based on the current loss\n\n    # Check for early stopping\n    if accuracy > best_accuracy:\n        best_accuracy = accuracy\n        patience_counter = 0\n    else:\n        patience_counter += 1\n\n    if patience_counter >= patience:\n        print(f\"Early stopping at epoch {epoch + 1}\")\n        break\n\n# Save predictions in submission.csv\nsubmission = np.column_stack(\n    (np.arange(len(predicted)), predicted.numpy() + 1)\n)  # Adjust back to 1-indexed\nnp.savetxt(\n    \"./working/submission.csv\",\n    submission,\n    delimiter=\",\",\n    header=\"Id,Label\",\n    comments=\"\",\n    fmt=\"%d\",\n)\n\n# Print the evaluation metric\nprint(f\"Validation Accuracy: {accuracy:.4f}\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import accuracy_score\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom torch.optim.lr_scheduler import ReduceLROnPlateau\n\n# Load data\ntrain_data = np.load(\"./input/train_data.npy\")\ntrain_labels = np.load(\"./input/train_label.npy\")\nval_data = np.load(\"./input/val_data.npy\")\nval_labels = np.load(\"./input/val_label.npy\")\n\n# Convert to PyTorch tensors\nX_train = torch.tensor(train_data, dtype=torch.float32)\ny_train = torch.tensor(\n    train_labels - 1, dtype=torch.long\n)  # Adjust labels to be zero-indexed\nX_val = torch.tensor(val_data, dtype=torch.float32)\ny_val = torch.tensor(val_labels - 1, dtype=torch.long)\n\n# Create DataLoader for training\ntrain_dataset = TensorDataset(X_train, y_train)\ntrain_loader = DataLoader(train_dataset, batch_size=32, shuffle=True)\n\n\n# Define a feedforward neural network with additional complexity\nclass ImprovedNN(nn.Module):\n    def __init__(self):\n        super(ImprovedNN, self).__init__()\n        self.fc1 = nn.Linear(46, 256)\n        self.bn1 = nn.BatchNorm1d(256)\n        self.dropout1 = nn.Dropout(0.5)\n        self.fc2 = nn.Linear(256, 128)\n        self.bn2 = nn.BatchNorm1d(128)\n        self.dropout2 = nn.Dropout(0.5)\n        self.fc3 = nn.Linear(128, 24)\n\n    def forward(self, x):\n        x = torch.relu(self.bn1(self.fc1(x)))\n        x = self.dropout1(x)\n        x = torch.relu(self.bn2(self.fc2(x)))\n        x = self.dropout2(x)\n        x = self.fc3(x)\n        return x\n\n\n# Initialize model, loss function, and optimizer\nmodel = ImprovedNN()\ncriterion = nn.CrossEntropyLoss()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\nscheduler = ReduceLROnPlateau(optimizer, \"min\", patience=5, verbose=True)\n\n# Train the model with early stopping\nepochs = 100\nbest_accuracy = 0\npatience = 10\npatience_counter = 0\n\nfor epoch in range(epochs):\n    model.train()\n    for batch_X, batch_y in train_loader:\n        optimizer.zero_grad()\n        outputs = model(batch_X)\n        loss = criterion(outputs, batch_y)\n        loss.backward()\n        optimizer.step()\n\n    # Validate the model\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(X_val)\n        _, predicted = torch.max(val_outputs, 1)\n        accuracy = accuracy_score(y_val.numpy(), predicted.numpy())\n        scheduler.step(loss)  # Step the scheduler based on the current loss\n\n    # Check for early stopping\n    if accuracy > best_accuracy:\n        best_accuracy = accuracy\n        patience_counter = 0\n    else:\n        patience_counter += 1\n\n    if patience_counter >= patience:\n        print(f\"Early stopping at epoch {epoch + 1}\")\n        break\n\n# Save predictions in submission.csv\nsubmission = np.column_stack(\n    (np.arange(len(predicted)), predicted.numpy() + 1)\n)  # Adjust back to 1-indexed\nnp.savetxt(\n    \"./working/submission.csv\",\n    submission,\n    delimiter=\",\",\n    header=\"Id,Label\",\n    comments=\"\",\n    fmt=\"%d\",\n)\n\n# Print the evaluation metric\nprint(f\"Validation Accuracy: {accuracy:.4f}\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import accuracy_score\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom torch.optim.lr_scheduler import ReduceLROnPlateau\n\n# Load data\ntrain_data = np.load(\"./input/train_data.npy\")\ntrain_labels = np.load(\"./input/train_label.npy\")\nval_data = np.load(\"./input/val_data.npy\")\nval_labels = np.load(\"./input/val_label.npy\")\n\n# Convert to PyTorch tensors\nX_train = torch.tensor(train_data, dtype=torch.float32)\ny_train = torch.tensor(\n    train_labels - 1, dtype=torch.long\n)  # Adjust labels to be zero-indexed\nX_val = torch.tensor(val_data, dtype=torch.float32)\ny_val = torch.tensor(val_labels - 1, dtype=torch.long)\n\n# Create DataLoader for training\ntrain_dataset = TensorDataset(X_train, y_train)\ntrain_loader = DataLoader(train_dataset, batch_size=32, shuffle=True)\n\n\n# Define a feedforward neural network with an additional hidden layer\nclass ImprovedNN(nn.Module):\n    def __init__(self):\n        super(ImprovedNN, self).__init__()\n        self.fc1 = nn.Linear(46, 256)\n        self.bn1 = nn.BatchNorm1d(256)\n        self.dropout1 = nn.Dropout(0.5)\n        self.fc2 = nn.Linear(256, 128)\n        self.bn2 = nn.BatchNorm1d(128)\n        self.dropout2 = nn.Dropout(0.5)\n        self.fc3 = nn.Linear(128, 64)\n        self.bn3 = nn.BatchNorm1d(64)\n        self.fc4 = nn.Linear(64, 24)\n\n    def forward(self, x):\n        x = torch.relu(self.bn1(self.fc1(x)))\n        x = self.dropout1(x)\n        x = torch.relu(self.bn2(self.fc2(x)))\n        x = self.dropout2(x)\n        x = torch.relu(self.bn3(self.fc3(x)))\n        x = self.fc4(x)\n        return x\n\n\n# Initialize model, loss function, and optimizer\nmodel = ImprovedNN()\ncriterion = nn.CrossEntropyLoss()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\nscheduler = ReduceLROnPlateau(optimizer, \"min\", patience=5, verbose=True)\n\n# Train the model with early stopping\nepochs = 100\nbest_accuracy = 0\npatience = 10\npatience_counter = 0\n\nfor epoch in range(epochs):\n    model.train()\n    for batch_X, batch_y in train_loader:\n        optimizer.zero_grad()\n        outputs = model(batch_X)\n        loss = criterion(outputs, batch_y)\n        loss.backward()\n        optimizer.step()\n\n    # Validate the model\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(X_val)\n        _, predicted = torch.max(val_outputs, 1)\n        accuracy = accuracy_score(y_val.numpy(), predicted.numpy())\n        scheduler.step(loss)  # Step the scheduler based on the current loss\n\n    # Check for early stopping\n    if accuracy > best_accuracy:\n        best_accuracy = accuracy\n        patience_counter = 0\n    else:\n        patience_counter += 1\n\n    if patience_counter >= patience:\n        print(f\"Early stopping at epoch {epoch + 1}\")\n        break\n\n# Save predictions in submission.csv\nsubmission = np.column_stack(\n    (np.arange(len(predicted)), predicted.numpy() + 1)\n)  # Adjust back to 1-indexed\nnp.savetxt(\n    \"./working/submission.csv\",\n    submission,\n    delimiter=\",\",\n    header=\"Id,Label\",\n    comments=\"\",\n    fmt=\"%d\",\n)\n\n# Print the evaluation metric\nprint(f\"Validation Accuracy: {accuracy:.4f}\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import accuracy_score\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom torch.optim.lr_scheduler import ReduceLROnPlateau\n\n# Load data\ntrain_data = np.load(\"./input/train_data.npy\")\ntrain_labels = np.load(\"./input/train_label.npy\")\nval_data = np.load(\"./input/val_data.npy\")\nval_labels = np.load(\"./input/val_label.npy\")\n\n# Convert to PyTorch tensors\nX_train = torch.tensor(train_data, dtype=torch.float32)\ny_train = torch.tensor(\n    train_labels - 1, dtype=torch.long\n)  # Adjust labels to be zero-indexed\nX_val = torch.tensor(val_data, dtype=torch.float32)\ny_val = torch.tensor(val_labels - 1, dtype=torch.long)\n\n# Create DataLoader for training\ntrain_dataset = TensorDataset(X_train, y_train)\ntrain_loader = DataLoader(train_dataset, batch_size=32, shuffle=True)\n\n\n# Define a feedforward neural network with additional hidden layer and dropout\nclass ImprovedNN(nn.Module):\n    def __init__(self):\n        super(ImprovedNN, self).__init__()\n        self.fc1 = nn.Linear(46, 256)\n        self.dropout1 = nn.Dropout(0.5)\n        self.fc2 = nn.Linear(256, 128)\n        self.dropout2 = nn.Dropout(0.5)\n        self.fc3 = nn.Linear(128, 64)\n        self.dropout3 = nn.Dropout(0.5)\n        self.fc4 = nn.Linear(64, 24)\n\n    def forward(self, x):\n        x = torch.relu(self.fc1(x))\n        x = self.dropout1(x)\n        x = torch.relu(self.fc2(x))\n        x = self.dropout2(x)\n        x = torch.relu(self.fc3(x))\n        x = self.dropout3(x)\n        x = self.fc4(x)\n        return x\n\n\n# Initialize model, loss function, and optimizer\nmodel = ImprovedNN()\ncriterion = nn.CrossEntropyLoss()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\nscheduler = ReduceLROnPlateau(optimizer, \"min\", patience=5, verbose=True)\n\n# Train the model with early stopping\nepochs = 100\nbest_accuracy = 0\npatience = 10\npatience_counter = 0\n\nfor epoch in range(epochs):\n    model.train()\n    for batch_X, batch_y in train_loader:\n        optimizer.zero_grad()\n        outputs = model(batch_X)\n        loss = criterion(outputs, batch_y)\n        loss.backward()\n        optimizer.step()\n\n    # Validate the model\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(X_val)\n        _, predicted = torch.max(val_outputs, 1)\n        accuracy = accuracy_score(y_val.numpy(), predicted.numpy())\n        scheduler.step(loss)  # Step the scheduler based on the current loss\n\n    # Check for early stopping\n    if accuracy > best_accuracy:\n        best_accuracy = accuracy\n        patience_counter = 0\n    else:\n        patience_counter += 1\n\n    if patience_counter >= patience:\n        print(f\"Early stopping at epoch {epoch + 1}\")\n        break\n\n# Save predictions in submission.csv\nsubmission = np.column_stack(\n    (np.arange(len(predicted)), predicted.numpy() + 1)\n)  # Adjust back to 1-indexed\nnp.savetxt(\n    \"./working/submission.csv\",\n    submission,\n    delimiter=\",\",\n    header=\"Id,Label\",\n    comments=\"\",\n    fmt=\"%d\",\n)\n\n# Print the evaluation metric\nprint(f\"Validation Accuracy: {accuracy:.4f}\")\n", "import numpy as np\nimport torch\nimport torch.nn as nn\nimport torch.optim as optim\nfrom sklearn.metrics import accuracy_score\nfrom torch.utils.data import DataLoader, TensorDataset\nfrom torch.optim.lr_scheduler import ReduceLROnPlateau\n\n# Load data\ntrain_data = np.load(\"./input/train_data.npy\")\ntrain_labels = np.load(\"./input/train_label.npy\")\nval_data = np.load(\"./input/val_data.npy\")\nval_labels = np.load(\"./input/val_label.npy\")\n\n# Convert to PyTorch tensors\nX_train = torch.tensor(train_data, dtype=torch.float32)\ny_train = torch.tensor(\n    train_labels - 1, dtype=torch.long\n)  # Adjust labels to be zero-indexed\nX_val = torch.tensor(val_data, dtype=torch.float32)\ny_val = torch.tensor(val_labels - 1, dtype=torch.long)\n\n# Create DataLoader for training\ntrain_dataset = TensorDataset(X_train, y_train)\ntrain_loader = DataLoader(train_dataset, batch_size=32, shuffle=True)\n\n\n# Define a feedforward neural network with increased complexity\nclass ImprovedNN(nn.Module):\n    def __init__(self):\n        super(ImprovedNN, self).__init__()\n        self.fc1 = nn.Linear(46, 256)  # Increased to 256 neurons\n        self.bn1 = nn.BatchNorm1d(256)\n        self.dropout1 = nn.Dropout(0.5)\n        self.fc2 = nn.Linear(256, 128)  # Increased to 128 neurons\n        self.bn2 = nn.BatchNorm1d(128)\n        self.dropout2 = nn.Dropout(0.5)\n        self.fc3 = nn.Linear(128, 24)\n\n    def forward(self, x):\n        x = torch.relu(self.bn1(self.fc1(x)))\n        x = self.dropout1(x)\n        x = torch.relu(self.bn2(self.fc2(x)))\n        x = self.dropout2(x)\n        x = self.fc3(x)\n        return x\n\n\n# Initialize model, loss function, and optimizer\nmodel = ImprovedNN()\ncriterion = nn.CrossEntropyLoss()\noptimizer = optim.Adam(model.parameters(), lr=0.001)\nscheduler = ReduceLROnPlateau(optimizer, \"min\", patience=5, verbose=True)\n\n# Train the model with early stopping\nepochs = 100\nbest_accuracy = 0\npatience = 10\npatience_counter = 0\n\nfor epoch in range(epochs):\n    model.train()\n    for batch_X, batch_y in train_loader:\n        optimizer.zero_grad()\n        outputs = model(batch_X)\n        loss = criterion(outputs, batch_y)\n        loss.backward()\n        optimizer.step()\n\n    # Validate the model\n    model.eval()\n    with torch.no_grad():\n        val_outputs = model(X_val)\n        _, predicted = torch.max(val_outputs, 1)\n        accuracy = accuracy_score(y_val.numpy(), predicted.numpy())\n        scheduler.step(loss)  # Step the scheduler based on the current loss\n\n    # Check for early stopping\n    if accuracy > best_accuracy:\n        best_accuracy = accuracy\n        patience_counter = 0\n    else:\n        patience_counter += 1\n\n    if patience_counter >= patience:\n        print(f\"Early stopping at epoch {epoch + 1}\")\n        break\n\n# Save predictions in submission.csv\nsubmission = np.column_stack(\n    (np.arange(len(predicted)), predicted.numpy() + 1)\n)  # Adjust back to 1-indexed\nnp.savetxt(\n    \"./working/submission.csv\",\n    submission,\n    delimiter=\",\",\n    header=\"Id,Label\",\n    comments=\"\",\n    fmt=\"%d\",\n)\n\n# Print the evaluation metric\nprint(f\"Validation Accuracy: {accuracy:.4f}\")\n"], "term_out": ["Validation Accuracy: 0.3344\nExecution time: 26 seconds seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 61, in <module>\n    submission = pd.DataFrame(\nNameError: name 'pd' is not defined\nExecution time: 25 seconds seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 59, in <module>\n    submission = pd.DataFrame({\"id\": range(len(predicted)), \"label\": predicted.numpy() + 1})\nNameError: name 'pd' is not defined\nExecution time: 37 seconds seconds (time limit is an hour).", "Validation Accuracy: 0.4330\nExecution time: 35 seconds seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 69, in <module>\n    submission = pd.DataFrame({\"Id\": range(len(predicted)), \"Label\": predicted.numpy() + 1})\nNameError: name 'pd' is not defined\nExecution time: 16 minutes seconds (time limit is an hour).", "Validation Accuracy: 0.6984\nExecution time: a minute seconds (time limit is an hour).", "Validation Accuracy: 0.433\nExecution time: 35 seconds seconds (time limit is an hour).", "Validation Accuracy: 0.6703\nExecution time: 2 minutes seconds (time limit is an hour).", "Validation Accuracy: 0.4979\nExecution time: 24 seconds seconds (time limit is an hour).", "Validation Accuracy: 0.6703\nExecution time: 2 minutes seconds (time limit is an hour).", "Validation Accuracy: 0.6984\nExecution time: a minute seconds (time limit is an hour).", "Early stopping at epoch 43\nValidation Accuracy: 0.8318\nExecution time: 31 minutes seconds (time limit is an hour).", "Early stopping at epoch 44\nValidation Accuracy: 0.8114\nExecution time: 37 minutes seconds (time limit is an hour).", "Early stopping at epoch 29\nValidation Accuracy: 0.7618\nExecution time: 26 minutes seconds (time limit is an hour).", "Early stopping at epoch 32\nValidation Accuracy: 0.7701\nExecution time: 25 minutes seconds (time limit is an hour).", "Early stopping at epoch 31\nValidation Accuracy: 0.7664\nExecution time: 18 minutes seconds (time limit is an hour).", "Early stopping at epoch 31\nValidation Accuracy: 0.7844\nExecution time: 23 minutes seconds (time limit is an hour).", "Early stopping at epoch 26\nValidation Accuracy: 0.7999\nExecution time: 20 minutes seconds (time limit is an hour).", "Validation Accuracy: 0.8185\nExecution time: 17 minutes seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 71, in <module>\n    optimizer.step()\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/optim/optimizer.py\", line 493, in wrapper\n    out = func(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/optim/optimizer.py\", line 91, in _use_grad\n    ret = func(self, *args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/optim/adam.py\", line 244, in step\n    adam(\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/optim/optimizer.py\", line 154, in maybe_fallback\n    return func(*args, **kwargs)\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/optim/adam.py\", line 876, in adam\n    func(\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/optim/adam.py\", line 425, in _single_tensor_adam\n    exp_avg_sq.mul_(beta2).addcmul_(grad, grad.conj(), value=1 - beta2)\nKeyboardInterrupt\nTimeoutError: Execution exceeded the time limit of an hour", "Early stopping at epoch 26\nValidation Accuracy: 0.7999\nExecution time: 25 minutes seconds (time limit is an hour).", "Traceback (most recent call last):\n  File \"runfile.py\", line 70, in <module>\n    loss.backward()\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/_tensor.py\", line 626, in backward\n    torch.autograd.backward(\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/autograd/__init__.py\", line 347, in backward\n    _engine_run_backward(\n  File \"/home/aturcan/miniconda3/envs/aide3/lib/python3.10/site-packages/torch/autograd/graph.py\", line 823, in _engine_run_backward\n    return Variable._execution_engine.run_backward(  # Calls into the C++ engine to run the backward pass\nKeyboardInterrupt\nTimeoutError: Execution exceeded the time limit of an hour", "Early stopping at epoch 41\nValidation Accuracy: 0.7743\nExecution time: 50 minutes seconds (time limit is an hour).", "Early stopping at epoch 26\nValidation Accuracy: 0.7999\nExecution time: 25 minutes seconds (time limit is an hour)."], "analysis": ["The model achieved a validation accuracy of 33.44% on the task of classifying satellite image pixel time series into 24 land cover types. This result indicates that while the model is performing better than random guessing (which would be around 4.17% accuracy for 24 classes), there is significant room for improvement in model architecture or training procedures to enhance performance.", "The code execution failed due to a missing import statement for the pandas library, which is used to create a DataFrame and save the submission file. To fix this, add 'import pandas as pd' at the beginning of the script.", "The script failed due to an undefined reference to 'pd', which is an alias for the pandas library. To fix this issue, ensure that the pandas library is imported at the beginning of the script by adding 'import pandas as pd'.", "The model achieved a validation accuracy of 43.30% after training for 50 epochs. This result indicates that the model is functioning as expected but may require further tuning or a more complex architecture to improve performance. The accuracy metric, although not very high, suggests that the model has learned to some extent from the training data.", "The script failed due to a missing import statement for the pandas library, which is used for creating a DataFrame and saving it to a CSV file. To fix this issue, add 'import pandas as pd' at the beginning of the script.", "The neural network model achieved a validation accuracy of 69.84% after training for 100 epochs. This indicates that the model is capable of classifying satellite image pixel time series into 24 land cover types with moderate accuracy. The implementation appears to be correct and functional as there are no indications of bugs or errors in the execution output.", "The model achieved a validation accuracy of 43.3% on the classification of satellite image pixel time series into 24 land cover types. This result indicates a basic level of performance, suggesting that there is significant room for improvement in model architecture or training process to enhance accuracy.", "The script successfully trained a neural network for classifying satellite image pixel time series into 24 land cover types, achieving a validation accuracy of 67.03%. This indicates a reasonable performance given the complexity of the task and the model's architecture, which includes features like batch normalization and dropout to combat overfitting.", "The model achieved a validation accuracy of approximately 49.79% after training for 50 epochs. This indicates that the model could potentially benefit from further optimization, such as hyperparameter tuning, more complex model architectures, or additional training epochs to improve performance.", "The execution of the model training and validation for classifying satellite image pixel time series into 24 land cover types achieved a validation accuracy of 67.03%. This indicates a moderate level of performance, suggesting that the model has learned to some extent but there might be room for improvement in model architecture or training strategies.", "The provided script successfully trained a neural network model to classify satellite image pixel time series into 24 land cover types. The model achieved a validation accuracy of 69.84%, which indicates a decent performance given the complexity of the task. The script includes mechanisms like batch normalization, learning rate reduction on plateau, and early stopping to enhance training efficiency and prevent overfitting.", "The training process using a feedforward neural network with batch normalization and early stopping achieved a validation accuracy of 83.18%. Early stopping was triggered at epoch 43, indicating that the model did not improve further, which helped prevent overfitting. The model's performance is quite satisfactory for this task.", "The model achieved an early stopping at epoch 44 with a validation accuracy of 0.8114. This indicates that the model was effective in classifying satellite image pixel time series into the specified land cover types, showing good performance within the set time constraints.", "The training script successfully executed with early stopping at epoch 29 due to a lack of improvement in validation accuracy. The model achieved a validation accuracy of 76.18%, which indicates a fairly good performance given the complexity of classifying 24 different land cover types from satellite image pixel time series.", "The model achieved a validation accuracy of 77.01% after training for 32 epochs, with early stopping triggered due to lack of improvement in accuracy. The use of batch normalization and dropout layers likely helped in improving model generalization and combating overfitting.", "The implemented model successfully trained and validated on the satellite image pixel time series classification task, achieving a validation accuracy of 76.64%. The model utilized a feedforward neural network with dropout layers to prevent overfitting and employed early stopping to halt training when no improvement was observed, enhancing efficiency.", "The neural network model was trained and evaluated successfully with an early stopping at epoch 31 due to no improvement in validation accuracy. The best achieved validation accuracy is 0.7844, which indicates a reasonably good performance of the model for classifying satellite image pixel time series into 24 land cover types.", "The model successfully trained and achieved a validation accuracy of 0.7999 after 26 epochs, utilizing early stopping. The model incorporates layers such as Batch Normalization and Dropout to enhance performance and prevent overfitting. The accuracy metric shows that the model performs well on the validation set, suggesting good generalization.", "The code successfully trained a neural network model to classify satellite image pixel time series into 24 land cover types. The model achieved a validation accuracy of 81.85%, which indicates a good performance given the complexity of the task. The execution time was well within the provided limit, making the approach efficient.", "The execution of the code resulted in a `KeyboardInterrupt` and a `TimeoutError`, indicating that the training process was excessively long or stuck in an infinite loop. This suggests a potential inefficiency in the training loop or a configuration issue with the optimizer or the batch size. To resolve this, it would be advisable to inspect and potentially reduce the batch size or simplify the model architecture to ensure smoother training.", "The model trained successfully with early stopping at epoch 26, achieving a validation accuracy of 79.99%. This indicates a good fit without overfitting, as the model stopped improving after several epochs, prompting the early stopping mechanism.", "The execution of the script resulted in a TimeoutError due to the training process taking too long and exceeding the time limit. This indicates that the training loop might be inefficient or the model is too complex for the given hardware constraints. To address this issue, consider reducing the model complexity, implementing more efficient training procedures, or increasing hardware capabilities.", "The model was successfully trained and evaluated on the validation set, achieving an accuracy of 77.43%. The training process included early stopping, which halted training at epoch 41 to prevent overfitting. The implemented neural network with dropout layers likely contributed to the robustness of the model against overfitting.", "The model training and evaluation script successfully completed with early stopping at epoch 26 due to lack of improvement in validation accuracy. The model achieved a validation accuracy of 79.99%, which is a reasonable performance given the complexity of classifying satellite image pixel time series into 24 different classes."], "exp_name": "2-whispering-capuchin-of-peace", "metrics": [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]}

let lastClick = 0;
let firstFrameTime = undefined;

let nodes = [];
let edges = [];

let lastScrollPos = 0;

setup = () => {
  canvas = createCanvas(...updateTargetDims());
};

class Node {
  x;
  y;
  size;
  xT;
  yT;
  xB;
  yB;
  treeInd;
  color;
  relSize;
  animationStart = Number.MAX_VALUE;
  animationProgress = 0;
  isStatic = false;
  hasChildren = false;
  isRootNode = true;
  isStarred = false;
  selected = false;
  renderSize = 10;
  edges = [];
  bgCol;

  constructor(x, y, relSize, treeInd) {
    const minSize = 35;
    const maxSize = 60;

    const maxColor = 10;
    const minColor = 125;

    this.relSize = relSize;
    this.treeInd = treeInd;
    this.size = minSize + (maxSize - minSize) * relSize;
    this.color = minColor + (maxColor - minColor) * relSize;
    this.bgCol = Math.round(Math.max(this.color / 2, 0));

    this.x = x;
    this.y = y;
    this.xT = x;
    this.yT = y - this.size / 2;
    this.xB = x;
    this.yB = y + this.size / 2;

    nodes.push(this);
  }

  startAnimation = (offset = 0) => {
    if (this.animationStart == Number.MAX_VALUE)
      this.animationStart = globalTime + offset;
  };

  child = (node) => {
    let edge = new Edge(this, node);
    this.edges.push(edge);
    edges.push(edge);
    this.hasChildren = true;
    node.isRootNode = false;
    return node;
  };

  render = () => {
    if (globalTime - this.animationStart < 0) return;

    const mouseXlocalCoords = (mouseX - width / 2) / scaleFactor;
    const mouseYlocalCoords = (mouseY - height / 2) / scaleFactor;
    const isMouseOver =
      dist(mouseXlocalCoords, mouseYlocalCoords, this.x, this.y) <
      this.renderSize / 1.5;
    if (isMouseOver) cursor(HAND);
    if (isMouseOver && mouseIsPressed) {
      nodes.forEach((n) => (n.selected = false));
      this.selected = true;
      setCodeAndPlan(
        treeStructData.code[this.treeInd],
        treeStructData.plan[this.treeInd],
      );
      manualSelection = true;
    }

    this.renderSize = this.size;
    if (!this.isStatic) {
      this.animationProgress = animEase(
        (globalTime - this.animationStart) / 1000,
      );
      if (this.animationProgress >= 1) {
        this.isStatic = true;
      } else {
        this.renderSize =
          this.size *
          (0.8 +
            0.2 *
              (-3.33 * this.animationProgress ** 2 +
                4.33 * this.animationProgress));
      }
    }

    fill(this.color);
    if (this.selected) {
      fill(accentCol);
    }

    noStroke();
    square(
      this.x - this.renderSize / 2,
      this.y - this.renderSize / 2,
      this.renderSize,
      10,
    );

    noStroke();
    textAlign(CENTER, CENTER);
    textSize(this.renderSize / 2);
    fill(255);
    // fill(lerpColor(color(accentCol), color(255), this.animationProgress))
    text("{ }", this.x, this.y - 1);
    // DEBUG PRINT:
    // text(round(this.relSize, 2), this.x, this.y - 1)
    // text(this.treeInd, this.x, this.y + 15)

    const dotAnimThreshold = 0.85;
    if (this.isStarred && this.animationProgress >= dotAnimThreshold) {
      let dotAnimProgress =
        (this.animationProgress - dotAnimThreshold) / (1 - dotAnimThreshold);
      textSize(
        ((-3.33 * dotAnimProgress ** 2 + 4.33 * dotAnimProgress) *
          this.renderSize) /
          2,
      );
      if (this.selected) {
        fill(0);
        stroke(0);
      } else {
        fill(accentCol);
        stroke(accentCol);
      }
      strokeWeight((-(dotAnimProgress ** 2) + dotAnimProgress) * 2);
      text("*", this.x + 20, this.y - 11);
      noStroke();
    }

    if (!this.isStatic) {
      fill(bgCol);
      const progressAnimBaseSize = this.renderSize + 5;
      rect(
        this.x - progressAnimBaseSize / 2,
        this.y -
          progressAnimBaseSize / 2 +
          progressAnimBaseSize * this.animationProgress,
        progressAnimBaseSize,
        progressAnimBaseSize * (1 - this.animationProgress),
      );
    }
    if (this.animationProgress >= 0.9) {
      this.edges
        .sort((a, b) => a.color() - b.color())
        .forEach((e, i) => {
          e.startAnimation((i / this.edges.length) ** 2 * 1000);
        });
    }
  };
}

class Edge {
  nodeT;
  nodeB;
  animX = 0;
  animY = 0;
  animationStart = Number.MAX_VALUE;
  animationProgress = 0;
  isStatic = false;
  weight = 0;

  constructor(nodeT, nodeB) {
    this.nodeT = nodeT;
    this.nodeB = nodeB;
    this.weight = 2 + nodeB.relSize * 1;
  }

  color = () => this.nodeB.color;

  startAnimation = (offset = 0) => {
    if (this.animationStart == Number.MAX_VALUE)
      this.animationStart = globalTime + offset;
  };

  render = () => {
    if (globalTime - this.animationStart < 0) return;

    if (!this.isStatic) {
      this.animationProgress = animEase(
        (globalTime - this.animationStart) / 1000,
      );
      if (this.animationProgress >= 1) {
        this.isStatic = true;
        this.animX = this.nodeB.xT;
        this.animY = this.nodeB.yT;
      } else {
        this.animX = bezierPoint(
          this.nodeT.xB,
          this.nodeT.xB,
          this.nodeB.xT,
          this.nodeB.xT,
          this.animationProgress,
        );

        this.animY = bezierPoint(
          this.nodeT.yB,
          (this.nodeT.yB + this.nodeB.yT) / 2,
          (this.nodeT.yB + this.nodeB.yT) / 2,
          this.nodeB.yT,
          this.animationProgress,
        );
      }
    }
    if (this.animationProgress >= 0.97) {
      this.nodeB.startAnimation();
    }

    strokeWeight(this.weight);
    noFill();
    stroke(
      lerpColor(color(bgCol), color(accentCol), this.nodeB.relSize * 1 + 0.7),
    );
    bezier(
      this.nodeT.xB,
      this.nodeT.yB,
      this.nodeT.xB,
      (this.nodeT.yB + this.nodeB.yT) / 2,
      this.animX,
      (this.nodeT.yB + this.nodeB.yT) / 2,
      this.animX,
      this.animY,
    );
  };
}

draw = () => {
  cursor(ARROW);
  frameRate(120);
  if (!firstFrameTime && frameCount <= 1) {
    firstFrameTime = millis();
  }
  // ---- update global animation state ----
  const initialSpeedScalingEaseIO =
    (cos(min((millis() - firstFrameTime) / 8000, 1.0) * PI) + 1) / 2;
  const initialSpeedScalingEase =
    (cos(min((millis() - firstFrameTime) / 8000, 1.0) ** (1 / 2) * PI) + 1) / 2;
  const initAnimationSpeedFactor = 1.0 - 0.4 * initialSpeedScalingEaseIO;
  // update global scaling-aware clock
  globalTime += globalAnimSpeed * initAnimationSpeedFactor * deltaTime;

  if (nodes.length == 0) {
    const spacingHeight = height * 1.3;
    const spacingWidth = width * 1.3;
    treeStructData.layout.forEach((lay, index) => {
      new Node(
        spacingWidth * lay[0] - spacingWidth / 2,
        20 + spacingHeight * lay[1] - spacingHeight / 2,
        1 - treeStructData.metrics[index],
        index,
      );
    });
    treeStructData.edges.forEach((ind) => {
      nodes[ind[0]].child(nodes[ind[1]]);
    });
    nodes.forEach((n) => {
      if (n.isRootNode) n.startAnimation();
    });
    nodes[0].selected = true;
    setCodeAndPlan(
      treeStructData.code[0],
      treeStructData.plan[0],
    )
  }

  const staticNodes = nodes.filter(
    (n) => n.isStatic || n.animationProgress >= 0.7,
  );
  if (staticNodes.length > 0) {
    const largestNode = staticNodes.reduce((prev, current) =>
      prev.relSize > current.relSize ? prev : current,
    );
    if (!manualSelection) {
      if (!largestNode.selected) {
        setCodeAndPlan(
          treeStructData.code[largestNode.treeInd],
          treeStructData.plan[largestNode.treeInd],
        );
      }
      staticNodes.forEach((node) => {
        node.selected = node === largestNode;
      });
    }
  }
  background(bgCol);
  // global animation transforms
  translate(width / 2, height / 2);
  scale(scaleFactor);

  
  // ---- fg render ----
  edges.forEach((e) => e.render());
  nodes.forEach((n) => n.render());
  
};

    </script>
    <title>AIDE Run Visualization</title>
    <style>
      body,
      * {
        margin: 0;
        padding: 0;
        box-sizing: border-box;
        overflow: scroll;
      }
      body {
        background-color: #f2f0e7;
      }
      canvas {
        float: left;
        height: 100vh;
        width: 40vw;
      }
      #text-container {
        float: right;
        height: 100vh;
        width: 50vw;
        background-color: #282c34;
      }
      #plan {
        /* border-left: 2px solid #282c34; */
        background-color: #282c34;
        color: #f2f0e7;
        min-height: 5rem;
        padding: 1em 0 1em 1em;
      }
    </style>
  </head>
  <body>
    <pre
      id="text-container"
    ><div id="plan"></div><hr><code id="code" class="language-python"></code></pre>
  </body>
</html>
