<!doctype html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <script>
      // Check if we're running under Live Server
      if (window.location.hostname === '127.0.0.1' || window.location.hostname === 'localhost') {
          let lastModified = '';

          // Check for file changes every second
          setInterval(async () => {
              try {
                  const response = await fetch(window.location.href, { method: 'HEAD' });
                  // get a timestamp that shows when the file was last changed
                  const currentModified = response.headers.get('last-modified');

                  if (lastModified && lastModified !== currentModified) {
                      window.location.reload();
                  }

                  lastModified = currentModified;
              } catch (e) {
                  console.error('Error checking for updates:', e);
              }
          }, 1000);
      }
  </script>
    <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 = "#FFFFFF";
const accentCol = "#1a439e";

hljs.initHighlightingOnLoad();

// Function to update background color globally
function updateBackgroundColor(color) {
  // Update the JS variable
  window.bgColCurrent = color;

  // Update body background
  document.body.style.backgroundColor = color;

  // Update canvas container background
  const canvasContainer = document.getElementById('canvas-container');
  if (canvasContainer) {
    canvasContainer.style.backgroundColor = color;
  }
}

// Store tree data for each stage
const stageData = {
  Stage_1: null,
  Stage_2: null,
  Stage_3: null,
  Stage_4: null
};

// Keep track of current selected stage
let currentStage = null;
let currentSketch = null;
let availableStages = [];

// Class definitions for nodes and edges
class Node {
  constructor(x, y, id, isRoot = false) {
    this.x = x;
    this.y = y;
    this.id = id;
    this.visible = isRoot; // Only root nodes are visible initially
    this.appearProgress = 0;
    this.popEffect = 0;
    this.selected = false;
    this.isRootNode = isRoot;
  }

  update() {
    if (this.visible) {
      // Handle the main appearance animation
      if (this.appearProgress < 1) {
        this.appearProgress += 0.06;

        // When we reach full size, trigger the pop effect
        if (this.appearProgress >= 1) {
          this.appearProgress = 1; // Cap at 1
          this.popEffect = 1; // Start the pop effect
        }
      }

      // Handle the pop effect animation
      if (this.popEffect > 0) {
        this.popEffect -= 0.15; // Control how quickly it shrinks back
        if (this.popEffect < 0) this.popEffect = 0; // Don't go negative
      }
    }
  }

  startAnimation() {
    this.visible = true;
  }

  color() {
    if (this.selected) {
      return accentCol; // Use the global accent color variable for selected node
    }
    return '#4263eb'; // Default blue color
  }

  render(p5) {
    if (this.visible) {
      const popBonus = this.popEffect * 0.1;
      const nodeScale = p5.map(this.appearProgress, 0, 1, 0, 1) + popBonus;
      const alpha = p5.map(this.appearProgress, 0, 1, 0, 255);

      p5.push();
      p5.translate(this.x, this.y);

      // Shadow effect
      p5.noStroke();
      p5.rectMode(p5.CENTER);

      for (let i = 1; i <= 4; i++) {
        p5.fill(0, 0, 0, alpha * 0.06);
        p5.rect(i, i, 30 * nodeScale, 30 * nodeScale, 10);
      }

      // Main square - use node's color with alpha
      let nodeColor = p5.color(this.color());
      nodeColor.setAlpha(alpha);
      p5.fill(nodeColor);
      p5.rect(0, 0, 30 * nodeScale, 30 * nodeScale, 10);

      // Draw checkmark icon if the node is selected
      if (this.selected && this.appearProgress >= 1) {
        p5.stroke(255);
        p5.strokeWeight(2 * nodeScale);
        p5.noFill();
        // Draw checkmark
        p5.beginShape();
        p5.vertex(-8, 0);
        p5.vertex(-3, 5);
        p5.vertex(8, -6);
        p5.endShape();
      }

      p5.pop();
    }
  }

  isMouseOver(p5) {
    return this.visible &&
           p5.mouseX > this.x - 15 &&
           p5.mouseX < this.x + 15 &&
           p5.mouseY > this.y - 15 &&
           p5.mouseY < this.y + 15;
  }

  // Connect this node to a child node
  child(childNode) {
    // Create an edge from this node to the child
    let isLeft = childNode.x < this.x;
    let isRight = childNode.x > this.x;
    let edge = new Edge(this, childNode, isLeft, isRight);
    return edge;
  }
}

class Edge {
  constructor(parent, child, isLeft, isRight) {
    this.parent = parent;
    this.child = child;
    this.isLeft = isLeft;
    this.isRight = isRight;
    this.progress = 0;

    // Calculate the midpoint where branching occurs
    this.midY = parent.y + (child.y - parent.y) * 0.6;

    // Use the actual child x-coordinate
    // This ensures the edge will connect directly to the child node
    this.branchX = child.x;
  }

  update() {
    if (this.parent.visible && this.progress < 1) {
      this.progress += 0.01; // Adjust animation speed
    }
    if (this.progress >= 1) {
      this.child.visible = true;
    }
  }

  color() {
    return this.child.color();
  }

  render(p5) {
    if (!this.parent.visible) return;

    // Calculate path lengths
    const verticalDist1 = this.midY - this.parent.y;
    const horizontalDist = Math.abs(this.branchX - this.parent.x);
    const verticalDist2 = this.child.y - this.midY;
    const totalLength = verticalDist1 + horizontalDist + verticalDist2;

    // Calculate how much of each segment to draw
    const currentLength = totalLength * this.progress;

    p5.stroke(180, 190, 205);
    p5.strokeWeight(1.5);
    p5.noFill();

    // Always draw the first vertical segment from parent
    if (currentLength > 0) {
      const firstSegmentLength = Math.min(currentLength, verticalDist1);
      const currentMidY = p5.lerp(this.parent.y, this.midY, firstSegmentLength / verticalDist1);
      p5.line(this.parent.x, this.parent.y, this.parent.x, currentMidY);
    }

    if (currentLength > verticalDist1) {
      // Draw second segment (horizontal)
      const secondSegmentLength = Math.min(currentLength - verticalDist1, horizontalDist);
      const currentBranchX = p5.lerp(this.parent.x, this.branchX, secondSegmentLength / horizontalDist);
      p5.line(this.parent.x, this.midY, currentBranchX, this.midY);

      if (currentLength > verticalDist1 + horizontalDist) {
        // Draw third segment (vertical to child)
        const thirdSegmentLength = currentLength - verticalDist1 - horizontalDist;
        const currentChildY = p5.lerp(this.midY, this.child.y, thirdSegmentLength / verticalDist2);
        p5.line(this.branchX, this.midY, this.branchX, currentChildY);
      }
    }
  }
}

// Create a modified sketch for each stage
function createTreeSketch(stageId) {
  return function(p5) {
    let nodes = [];
    let edges = [];
    let treeData = stageData[stageId];

    p5.setup = function() {
      const canvas = p5.createCanvas(p5.windowWidth * 0.4, p5.windowHeight);
      canvas.parent('canvas-container');
      p5.smooth();
      p5.frameRate(60);

      if (treeData) {
        createTreeFromData(treeData);
      }
    };

    p5.windowResized = function() {
      p5.resizeCanvas(p5.windowWidth * 0.4, p5.windowHeight);
    };

    function createTreeFromData(data) {
      // Clear existing nodes and edges
      nodes = [];
      edges = [];

      // Add defensive checks to prevent errors
      if (!data || !data.layout || !Array.isArray(data.layout) || !data.edges || !Array.isArray(data.edges)) {
        console.error("Invalid tree data format:", data);
        return; // Exit if data structure is invalid
      }

      // Find all parent nodes in edges
      const parentNodes = new Set();
      for (const [parentId, childId] of data.edges) {
        parentNodes.add(parentId);
      }

      // Create nodes
      for (let i = 0; i < data.layout.length; i++) {
        const [nx, ny] = data.layout[i];
        // A node is a root if it's a parent and not a child in any edge
        const isRoot = parentNodes.has(i) && data.edges.every(edge => edge[1] !== i);

        const node = new Node(
          nx * p5.width * 0.8 + p5.width * 0.1,
          ny * p5.height * 0.8 + p5.height * 0.1,
          i,
          isRoot
        );
        nodes.push(node);
      }

      // If no root was found, make the first parent node visible
      if (!nodes.some(node => node.visible) && parentNodes.size > 0) {
        // Get the first parent node
        const firstParentId = [...parentNodes][0];
        if (nodes[firstParentId]) {
          nodes[firstParentId].visible = true;
        }
      }

      // Create edges
      for (const [parentId, childId] of data.edges) {
        const parent = nodes[parentId];
        const child = nodes[childId];
        if (parent && child) { // Verify both nodes exist
          const isLeft = child.x < parent.x;
          const isRight = child.x > parent.x;
          edges.push(new Edge(parent, child, isLeft, isRight));
        }
      }

      // Select the first node by default
      if (nodes.length > 0) {
        nodes[0].selected = true;
        updateNodeInfo(0);
      }
    }

    p5.draw = function() {
      // Use the global background color if available, otherwise use the default bgCol
      const currentBgColor = window.bgColCurrent || bgCol;
      p5.background(currentBgColor);

      // Update and render edges
      for (const edge of edges) {
        edge.update();
        edge.render(p5);
      }

      // Update and render nodes
      for (const node of nodes) {
        node.update();
        node.render(p5);
      }

      // Handle mouse hover
      p5.cursor(p5.ARROW);
      for (const node of nodes) {
        if (node.isMouseOver(p5)) {
          p5.cursor(p5.HAND);
        }
      }
    };

    p5.mousePressed = function() {
      // Check if any node was clicked
      for (let i = 0; i < nodes.length; i++) {
        if (nodes[i].visible && nodes[i].isMouseOver(p5)) {
          // Deselect all nodes
          nodes.forEach(n => n.selected = false);
          // Select the clicked node
          nodes[i].selected = true;
          // Update the right panel with node info
          updateNodeInfo(i);
          break;
        }
      }
    };

    function updateNodeInfo(nodeIndex) {
      if (treeData) {
        setNodeInfo(
          treeData.code[nodeIndex],
          treeData.plan[nodeIndex],
          treeData.plot_code?.[nodeIndex],
          treeData.plot_plan?.[nodeIndex],
          treeData.metrics?.[nodeIndex],
          treeData.exc_type?.[nodeIndex] || '',
          treeData.exc_info?.[nodeIndex]?.args?.[0] || '',
          treeData.exc_stack?.[nodeIndex] || [],
          treeData.plots?.[nodeIndex] || [],
          treeData.plot_analyses?.[nodeIndex] || [],
          treeData.vlm_feedback_summary?.[nodeIndex] || '',
          treeData.datasets_successfully_tested?.[nodeIndex] || [],
          treeData.exec_time_feedback?.[nodeIndex] || '',
          treeData.exec_time?.[nodeIndex] || ''
        );
      }
    }
  };
}

// Start a new p5 sketch for the given stage
function startSketch(stageId) {
  if (currentSketch) {
    currentSketch.remove();
  }

  if (stageData[stageId]) {
    currentSketch = new p5(createTreeSketch(stageId));

    // Update stage info
    const stageNumber = stageId.split('_')[1];
    let stageDesc = '';
    switch(stageId) {
      case 'Stage_1': stageDesc = 'Preliminary Investigation'; break;
      case 'Stage_2': stageDesc = 'Baseline Tuning'; break;
      case 'Stage_3': stageDesc = 'Research Agenda Execution'; break;
      case 'Stage_4': stageDesc = 'Ablation Studies'; break;
    }

    document.getElementById('stage-info').innerHTML =
      `<strong>Current Stage: ${stageNumber} - ${stageDesc}</strong>`;
  }
}

// Handle tab selection
function selectStage(stageId) {
  if (!stageData[stageId] || !availableStages.includes(stageId)) {
    return; // Don't allow selection of unavailable stages
  }

  // Update active tab styles
  document.querySelectorAll('.tab').forEach(tab => {
    tab.classList.remove('active');
  });
  document.querySelector(`.tab[data-stage="${stageId}"]`).classList.add('active');

  // Start the new sketch
  currentStage = stageId;
  startSketch(stageId);
}

// Function to load the tree data for all stages
async function loadAllStageData(baseTreeData) {
  console.log("Loading stage data with base data:", baseTreeData);

  // The base tree data is for the current stage
  const currentStageId = baseTreeData.current_stage || 'Stage_1';

  // Ensure base tree data is valid and has required properties
  if (baseTreeData && baseTreeData.layout && baseTreeData.edges) {
    stageData[currentStageId] = baseTreeData;
    availableStages.push(currentStageId);
    console.log(`Added current stage ${currentStageId} to available stages`);
  } else {
    console.warn(`Current stage ${currentStageId} data is invalid:`, baseTreeData);
  }

  // Use relative path to load other stage trees
  const logDirPath = baseTreeData.log_dir_path || '.';
  console.log("Log directory path:", logDirPath);

  // Load data for each stage if available
  const stageNames = ['Stage_1', 'Stage_2', 'Stage_3', 'Stage_4'];
  const stageNames2actualNames = {
    'Stage_1': 'stage_1_initial_implementation_1_preliminary',
    'Stage_2': 'stage_2_baseline_tuning_1_first_attempt',
    'Stage_3': 'stage_3_creative_research_1_first_attempt',
    'Stage_4': 'stage_4_ablation_studies_1_first_attempt'
    }

  for (const stage of stageNames) {

    if (baseTreeData.completed_stages && baseTreeData.completed_stages.includes(stage)) {
      try {
        console.log(`Attempting to load data for ${stage} from ${logDirPath}/${stageNames2actualNames[stage]}/tree_data.json`);
        const response = await fetch(`${logDirPath}/${stageNames2actualNames[stage]}/tree_data.json`);

        if (response.ok) {
          const data = await response.json();

          // Validate the loaded data
          if (data && data.layout && data.edges) {
            stageData[stage] = data;
            availableStages.push(stage);
            console.log(`Successfully loaded and validated data for ${stage}`);
          } else {
            console.warn(`Loaded data for ${stage} is invalid:`, data);
          }
        } else {
          console.warn(`Failed to load data for ${stage} - HTTP status ${response.status}`);
        }
      } catch (error) {
        console.error(`Error loading data for ${stage}:`, error);
      }
    } else {
      console.log(`Skipping stage ${stage} - not in completed stages list:`, baseTreeData.completed_stages);
    }
  }

  // Update tab visibility based on available stages
  updateTabVisibility();

  // Start with the first available stage
  if (availableStages.length > 0) {
    selectStage(availableStages[0]);
  } else {
    console.warn("No stages available to display");
    // Display a message in the canvas area
    document.getElementById('canvas-container').innerHTML =
      '<div style="padding: 20px; color: #333; text-align: center;"><h3>No valid tree data available to display</h3></div>';
  }
}

// Update tab visibility based on available stages
function updateTabVisibility() {
  const tabs = document.querySelectorAll('.tab');
  tabs.forEach(tab => {
    const stageId = tab.getAttribute('data-stage');
    if (availableStages.includes(stageId)) {
      tab.classList.remove('disabled');
    } else {
      tab.classList.add('disabled');
    }
  });
}

// Utility function to set the node info in the right panel
const setNodeInfo = (code, plan, plot_code, plot_plan, metrics = null, exc_type = '', exc_info = '',
    exc_stack = [], plots = [], plot_analyses = [], vlm_feedback_summary = '',
    datasets_successfully_tested = [], exec_time_feedback = '', exec_time = '') => {
  const codeElm = document.getElementById("code");
  if (codeElm) {
    if (code) {
      codeElm.innerHTML = hljs.highlight(code, { language: "python" }).value;
    } else {
      codeElm.innerHTML = '<p>No code available</p>';
    }
  }

  const planElm = document.getElementById("plan");
  if (planElm) {
    if (plan) {
      planElm.innerHTML = hljs.highlight(plan, { language: "plaintext" }).value;
    } else {
      planElm.innerHTML = '<p>No plan available</p>';
    }
  }

  const plot_codeElm = document.getElementById("plot_code");
  if (plot_codeElm) {
    if (plot_code) {
      plot_codeElm.innerHTML = hljs.highlight(plot_code, { language: "python" }).value;
    } else {
      plot_codeElm.innerHTML = '<p>No plot code available</p>';
    }
  }

  const plot_planElm = document.getElementById("plot_plan");
  if (plot_planElm) {
    if (plot_plan) {
      plot_planElm.innerHTML = hljs.highlight(plot_plan, { language: "plaintext" }).value;
    } else {
      plot_planElm.innerHTML = '<p>No plot plan available</p>';
    }
  }

  const metricsElm = document.getElementById("metrics");
  if (metricsElm) {
      let metricsContent = `<h3>Metrics:</h3>`;
      if (metrics && metrics.metric_names) {
          for (const metric of metrics.metric_names) {
              metricsContent += `<div class="metric-group">`;
              metricsContent += `<h4>${metric.metric_name}</h4>`;
              metricsContent += `<p><strong>Description:</strong> ${metric.description || 'N/A'}</p>`;
              metricsContent += `<p><strong>Optimization:</strong> ${metric.lower_is_better ? 'Minimize' : 'Maximize'}</p>`;

              // Create table for dataset values
              metricsContent += `<table class="metric-table">
                  <tr>
                      <th>Dataset</th>
                      <th>Final Value</th>
                      <th>Best Value</th>
                  </tr>`;

              for (const dataPoint of metric.data) {
                  metricsContent += `<tr>
                      <td>${dataPoint.dataset_name}</td>
                      <td>${dataPoint.final_value?.toFixed(4) || 'N/A'}</td>
                      <td>${dataPoint.best_value?.toFixed(4) || 'N/A'}</td>
                  </tr>`;
              }

              metricsContent += `</table></div>`;
          }
      } else if (metrics === null) {
          metricsContent += `<p>No metrics available</p>`;
      }
      metricsElm.innerHTML = metricsContent;
  }

  // Add plots display
  const plotsElm = document.getElementById("plots");
  if (plotsElm) {
      if (plots && plots.length > 0) {
          let plotsContent = '';
          plots.forEach(plotPath => {
              plotsContent += `
                  <div class="plot-item">
                      <img src="${plotPath}" alt="Experiment Plot" onerror="console.error('Failed to load plot:', this.src)"/>
                  </div>`;
          });
          plotsElm.innerHTML = plotsContent;
      } else {
          plotsElm.innerHTML = '';
      }
  }

  // Add error info display
  const errorElm = document.getElementById("exc_info");
  if (errorElm) {
    if (exc_type) {
      let errorContent = `<h3 style="color: #ff5555">Exception Information:</h3>
                          <p><strong>Type:</strong> ${exc_type}</p>`;

      if (exc_info) {
        errorContent += `<p><strong>Details:</strong> <pre>${JSON.stringify(exc_info, null, 2)}</pre></p>`;
      }

      if (exc_stack) {
        errorContent += `<p><strong>Stack Trace:</strong> <pre>${exc_stack.join('\n')}</pre></p>`;
      }

      errorElm.innerHTML = errorContent;
    } else {
      errorElm.innerHTML = "No exception info available";
    }
  }

  const exec_timeElm = document.getElementById("exec_time");
  if (exec_timeElm) {
    let exec_timeContent = '<div id="exec_time"><h3>Execution Time (in seconds):</h3><p>' + exec_time + '</p></div>';
    exec_timeElm.innerHTML = exec_timeContent;
  }

  const exec_time_feedbackElm = document.getElementById("exec_time_feedback");
  if (exec_time_feedbackElm) {
    let exec_time_feedbackContent = '<div id="exec_time_feedback_content">'
    exec_time_feedbackContent += '<h3>Execution Time Feedback:</h3>'
    exec_time_feedbackContent += '<p>' + exec_time_feedback + '</p>'
    exec_time_feedbackContent += '</div>';
    exec_time_feedbackElm.innerHTML = exec_time_feedbackContent;
  }

  const vlm_feedbackElm = document.getElementById("vlm_feedback");
  if (vlm_feedbackElm) {
      let vlm_feedbackContent = '';

      if (plot_analyses && plot_analyses.length > 0) {
          vlm_feedbackContent += `<h3>Plot Analysis:</h3>`;
          plot_analyses.forEach(analysis => {
              if (analysis && analysis.plot_path) {  // Add null check
                  vlm_feedbackContent += `
                      <div class="plot-analysis">
                          <h4>Analysis for ${analysis.plot_path.split('/').pop()}</h4>
                          <p>${analysis.analysis || 'No analysis available'}</p>
                          <ul class="key-findings">
                              ${(analysis.key_findings || []).map(finding => `<li>${finding}</li>`).join('')}
                          </ul>
                      </div>`;
              } else {
                  console.warn('Received invalid plot analysis:', analysis);
                  vlm_feedbackContent += `
                      <div class="plot-analysis">
                          <p>Invalid plot analysis data received</p>
                      </div>`;
              }
          });
      }

      // Add actionable insights if available
      if (vlm_feedback_summary && typeof vlm_feedback_summary === 'string') {
          vlm_feedbackContent += `
              <div class="vlm_feedback">
                  <h3>VLM Feedback Summary:</h3>
                  <p>${vlm_feedback_summary}</p>
              </div>`;
      }

      console.log("Datasets successfully tested:", datasets_successfully_tested);
      if (datasets_successfully_tested && datasets_successfully_tested.length > 0) {
          vlm_feedbackContent += `
              <div id="datasets_successfully_tested">
                  <h3>Datasets Successfully Tested:</h3>
                  <p>${datasets_successfully_tested.join(', ')}</p>
              </div>`;
      }

      if (!vlm_feedbackContent) {
          vlm_feedbackContent = '<p>No insights available for this experiment.</p>';
      }

      vlm_feedbackElm.innerHTML = vlm_feedbackContent;
  }

  const datasets_successfully_testedElm = document.getElementById("datasets_successfully_tested");
  if (datasets_successfully_testedElm) {
      let datasets_successfully_testedContent = '';
      if (datasets_successfully_tested && datasets_successfully_tested.length > 0) {
          datasets_successfully_testedContent = `<h3>Datasets Successfully Tested:</h3><ul>`;
          datasets_successfully_tested.forEach(dataset => {
              datasets_successfully_testedContent += `<li>${dataset}</li>`;
          });
          datasets_successfully_testedContent += `</ul>`;
      } else {
          datasets_successfully_testedContent = '<p>No datasets tested yet</p>';
      }
      datasets_successfully_testedElm.innerHTML = datasets_successfully_testedContent;
  }
};

// Initialize with the provided tree data
const treeStructData = {"edges": [[0, 6], [0, 5], [0, 1], [0, 3], [0, 2], [1, 9], [1, 12], [1, 10], [1, 11], [2, 4], [6, 8], [6, 7]], "layout": [[0.6266666666666667, 0.0], [0.2, 0.5], [0.5333333333333333, 0.5], [0.6666666666666666, 0.5], [0.5333333333333333, 1.0], [0.8, 0.5], [0.9333333333333333, 0.5], [0.8666666666666667, 1.0], [1.0, 1.0], [0.0, 1.0], [0.13333333333333333, 1.0], [0.26666666666666666, 1.0], [0.4, 1.0]], "plan": ["Hyperparam tuning name: epochs. To implement hyperparameter tuning for the\nnumber of epochs, we will modify the training loop to iterate over a predefined\nlist of different epoch values. For each value, the model will be trained and\nvalidated, with the corresponding metrics and losses logged. The experiment data\nwill be saved as a numpy array after each epoch configuration to track the\nperformance across different epoch settings. This approach will allow us to\nassess how varying the number of epochs affects the model\u2019s learning and\ngeneralization capabilities.", "Ablation name: Feature Count Ablation. To implement the Feature Count Ablation\nstudy, we will modify the baseline code to experiment with different feature\ncounts for the synthetic data. We'll test feature counts of 8, 32, and 64 in\naddition to the original 16. For each feature count, we'll generate synthetic\ndata and train the SimpleGNN model for a set of epoch counts (5, 10, 20, 30).\nWe'll store the results for each feature count setting in the `experiment_data`\ndictionary under a new key, 'feature_count_ablation'. This will include metrics\nlike training losses, validation F1 scores, predictions, and ground truths for\neach configuration.", "Ablation name: Edge Connectivity Ablation. To implement the ablation study\nfocusing on edge connectivity, we'll modify the `generate_synthetic_data`\nfunction to create three types of graphs: sparse, dense, and random. We'll then\nrun experiments on these datasets, similar to the baseline, and store the\nresults in a structured format. For the sparse graph, we will reduce the number\nof edges. For the dense graph, we will add more edges, and for the random graph,\nwe will connect nodes randomly. The results will be saved as numpy arrays for\nfurther analysis.", "Ablation name: Learning Rate Ablation. To implement the learning rate ablation\nstudy, we'll modify the base code to iterate over different learning rates\n(0.001, 0.01, 0.1, 0.5) and record the model's performance for each. We'll\ncreate a loop to train and evaluate the model for each learning rate, keeping\nthe number of epochs constant. The results, including training loss and\nvalidation F1 scores, will be stored in a structured format and saved as a numpy\nfile. This will allow us to analyze how different learning rates affect the\nmodel's learning dynamics and performance.", "To fix the KeyError in the previous implementation, we need to ensure that the\nexperiment data dictionary is correctly initialized for each connectivity type\nbefore appending values to it. We need to check if the dictionary for each\nconnectivity type exists and initialize it if not. This ensures that we can\nsafely append metrics and losses without encountering a KeyError. Additionally,\nwe will ensure that predictions and ground truth data are correctly stored at\neach epoch.", "Ablation name: Activation Function Ablation. To perform the activation function\nablation study, we will modify the `SimpleGNN` class to allow the choice of\ndifferent activation functions: ReLU, Tanh, Sigmoid, and Leaky ReLU. We'll then\niterate through each activation function, training and evaluating the model for\neach. For each activation function, we will store the train losses, validation\nF1 scores, predictions, and ground truths. At the end of the script, we'll save\nall the collected experiment data as a numpy file using the specified naming\nconvention.", "Ablation name: Node Count Ablation. To implement the Node Count Ablation study,\nwe will modify the existing code to generate datasets with varying node counts\n(e.g., 50, 150, 200 nodes) and evaluate the model's performance on these\ndifferent graph sizes. We'll iterate over a list of node counts, train the model\nfor a fixed number of epochs on each dataset, and record the training losses and\nvalidation F1 scores. The results will be stored in a structured format that\ncaptures metrics for each node count scenario, and the data will be saved as\nnumpy arrays for further analysis.", "To address the issues in the previous implementation, we need to ensure correct\ndevice placement for both the model and the data, as well as store all relevant\nmetrics and experiment data properly. We should also include the Temporal Motif\nCoverage (TMC) metric as part of our evaluation. To fix the bug, we will ensure\nthe model and data are moved to the appropriate device, and track and save all\nmetrics, including TMC, throughout the training and evaluation process. The\nexperiment data will be saved as a numpy array for further analysis.", "To fix the issue in the previous implementation, we must ensure that we are\nsaving all relevant metrics and losses separately for each node count setting\ninstead of overwriting them. Additionally, we should update the experiment_data\ndictionary to store temporal motif coverage (TMC) as an evaluation metric. We\nwill also ensure that all model, data, and tensor operations are moved to the\nappropriate device (CPU or GPU). The code will also print out validation loss\nfor each epoch, following evaluation requirements. Lastly, we will save the\nresults using numpy's save function after completing the training loop.", "Seed node", "Seed node", "Seed node", "Aggregate results from multiple seeds"], "code": ["import os\nimport numpy as np\nimport torch\nimport torch.nn.functional as F\nfrom torch_geometric.data import Data\nfrom torch_geometric.nn import GCNConv\nfrom sklearn.metrics import f1_score\n\n# Set up working directory\nworking_dir = os.path.join(os.getcwd(), \"working\")\nos.makedirs(working_dir, exist_ok=True)\n\n# Device configuration\ndevice = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\nprint(f\"Using device: {device}\")\n\n# Experiment data storage\nexperiment_data = {\n    \"hyperparam_tuning_epochs\": {\n        \"synthetic_dynamic_network\": {\n            \"metrics\": {\"train\": [], \"val\": []},\n            \"losses\": {\"train\": [], \"val\": []},\n            \"predictions\": [],\n            \"ground_truth\": [],\n            \"epoch_settings\": [],\n        }\n    }\n}\n\n\n# Simple synthetic data generation\ndef generate_synthetic_data(num_nodes=100, num_features=16, num_classes=2):\n    x = torch.randn((num_nodes, num_features), dtype=torch.float)\n    edge_index = (\n        torch.tensor(\n            [[i, (i + 1) % num_nodes] for i in range(num_nodes)], dtype=torch.long\n        )\n        .t()\n        .contiguous()\n    )\n    y = torch.randint(0, num_classes, (num_nodes,), dtype=torch.long)\n    return Data(x=x, edge_index=edge_index, y=y)\n\n\n# Basic GNN model\nclass SimpleGNN(torch.nn.Module):\n    def __init__(self, num_features, num_classes):\n        super(SimpleGNN, self).__init__()\n        self.conv1 = GCNConv(num_features, 32)\n        self.conv2 = GCNConv(32, num_classes)\n\n    def forward(self, data):\n        x, edge_index = data.x, data.edge_index\n        x = F.relu(self.conv1(x, edge_index))\n        x = self.conv2(x, edge_index)\n        return F.log_softmax(x, dim=1)\n\n\n# Training function\ndef train(model, data, optimizer):\n    model.train()\n    optimizer.zero_grad()\n    out = model(data)\n    loss = F.nll_loss(out, data.y)\n    loss.backward()\n    optimizer.step()\n    return loss.item()\n\n\n# Evaluation function\ndef evaluate(model, data):\n    model.eval()\n    with torch.no_grad():\n        out = model(data)\n        pred = out.argmax(dim=1)\n        f1 = f1_score(data.y.cpu(), pred.cpu(), average=\"weighted\")\n    return f1, pred.cpu()\n\n\n# Generate data and model\ndata = generate_synthetic_data().to(device)\nepoch_list = [5, 10, 20, 30]  # Different epoch settings to evaluate\n\nfor epochs in epoch_list:\n    model = SimpleGNN(num_features=16, num_classes=2).to(device)\n    optimizer = torch.optim.Adam(model.parameters(), lr=0.01)\n    for epoch in range(1, epochs + 1):\n        train_loss = train(model, data, optimizer)\n        val_f1, predictions = evaluate(model, data)\n\n        # Track and save metrics and losses\n        experiment_data[\"hyperparam_tuning_epochs\"][\"synthetic_dynamic_network\"][\n            \"losses\"\n        ][\"train\"].append(train_loss)\n        experiment_data[\"hyperparam_tuning_epochs\"][\"synthetic_dynamic_network\"][\n            \"metrics\"\n        ][\"val\"].append(val_f1)\n        experiment_data[\"hyperparam_tuning_epochs\"][\"synthetic_dynamic_network\"][\n            \"predictions\"\n        ] = (predictions.cpu().numpy().tolist())\n        experiment_data[\"hyperparam_tuning_epochs\"][\"synthetic_dynamic_network\"][\n            \"ground_truth\"\n        ] = (data.y.cpu().numpy().tolist())\n        experiment_data[\"hyperparam_tuning_epochs\"][\"synthetic_dynamic_network\"][\n            \"epoch_settings\"\n        ].append(epochs)\n\n        print(\n            f\"Epoch {epoch}/{epochs}: train_loss = {train_loss:.4f}, val_f1 = {val_f1:.4f}\"\n        )\n\n# Save experiment data\nnp.save(os.path.join(working_dir, \"experiment_data.npy\"), experiment_data)\n", "import os\nimport numpy as np\nimport torch\nimport torch.nn.functional as F\nfrom torch_geometric.data import Data\nfrom torch_geometric.nn import GCNConv\nfrom sklearn.metrics import f1_score\n\n# Set up working directory\nworking_dir = os.path.join(os.getcwd(), \"working\")\nos.makedirs(working_dir, exist_ok=True)\n\n# Device configuration\ndevice = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\nprint(f\"Using device: {device}\")\n\n# Experiment data storage\nexperiment_data = {\n    \"feature_count_ablation\": {\n        \"synthetic_dynamic_network\": {\n            \"metrics\": {\"train\": [], \"val\": []},\n            \"losses\": {\"train\": [], \"val\": []},\n            \"predictions\": [],\n            \"ground_truth\": [],\n            \"epoch_settings\": [],\n            \"feature_counts\": [],\n        }\n    }\n}\n\n\n# Simple synthetic data generation\ndef generate_synthetic_data(num_nodes=100, num_features=16, num_classes=2):\n    x = torch.randn((num_nodes, num_features), dtype=torch.float)\n    edge_index = (\n        torch.tensor(\n            [[i, (i + 1) % num_nodes] for i in range(num_nodes)], dtype=torch.long\n        )\n        .t()\n        .contiguous()\n    )\n    y = torch.randint(0, num_classes, (num_nodes,), dtype=torch.long)\n    return Data(x=x, edge_index=edge_index, y=y)\n\n\n# Basic GNN model\nclass SimpleGNN(torch.nn.Module):\n    def __init__(self, num_features, num_classes):\n        super(SimpleGNN, self).__init__()\n        self.conv1 = GCNConv(num_features, 32)\n        self.conv2 = GCNConv(32, num_classes)\n\n    def forward(self, data):\n        x, edge_index = data.x, data.edge_index\n        x = F.relu(self.conv1(x, edge_index))\n        x = self.conv2(x, edge_index)\n        return F.log_softmax(x, dim=1)\n\n\n# Training function\ndef train(model, data, optimizer):\n    model.train()\n    optimizer.zero_grad()\n    out = model(data)\n    loss = F.nll_loss(out, data.y)\n    loss.backward()\n    optimizer.step()\n    return loss.item()\n\n\n# Evaluation function\ndef evaluate(model, data):\n    model.eval()\n    with torch.no_grad():\n        out = model(data)\n        pred = out.argmax(dim=1)\n        f1 = f1_score(data.y.cpu(), pred.cpu(), average=\"weighted\")\n    return f1, pred.cpu()\n\n\n# Feature count variations\nfeature_counts = [8, 16, 32, 64]\nepoch_list = [5, 10, 20, 30]  # Different epoch settings to evaluate\n\nfor num_features in feature_counts:\n    data = generate_synthetic_data(num_features=num_features).to(device)\n    for epochs in epoch_list:\n        model = SimpleGNN(num_features=num_features, num_classes=2).to(device)\n        optimizer = torch.optim.Adam(model.parameters(), lr=0.01)\n        for epoch in range(1, epochs + 1):\n            train_loss = train(model, data, optimizer)\n            val_f1, predictions = evaluate(model, data)\n\n            # Track and save metrics and losses\n            experiment_data[\"feature_count_ablation\"][\"synthetic_dynamic_network\"][\n                \"losses\"\n            ][\"train\"].append(train_loss)\n            experiment_data[\"feature_count_ablation\"][\"synthetic_dynamic_network\"][\n                \"metrics\"\n            ][\"val\"].append(val_f1)\n            experiment_data[\"feature_count_ablation\"][\"synthetic_dynamic_network\"][\n                \"predictions\"\n            ] = (predictions.cpu().numpy().tolist())\n            experiment_data[\"feature_count_ablation\"][\"synthetic_dynamic_network\"][\n                \"ground_truth\"\n            ] = (data.y.cpu().numpy().tolist())\n            experiment_data[\"feature_count_ablation\"][\"synthetic_dynamic_network\"][\n                \"epoch_settings\"\n            ].append(epochs)\n            experiment_data[\"feature_count_ablation\"][\"synthetic_dynamic_network\"][\n                \"feature_counts\"\n            ].append(num_features)\n\n            print(\n                f\"Features {num_features}, Epoch {epoch}/{epochs}: train_loss = {train_loss:.4f}, val_f1 = {val_f1:.4f}\"\n            )\n\n# Save experiment data\nnp.save(os.path.join(working_dir, \"experiment_data.npy\"), experiment_data)\n", "import os\nimport numpy as np\nimport torch\nimport torch.nn.functional as F\nfrom torch_geometric.data import Data\nfrom torch_geometric.nn import GCNConv\nfrom sklearn.metrics import f1_score\nimport random\n\n# Set up working directory\nworking_dir = os.path.join(os.getcwd(), \"working\")\nos.makedirs(working_dir, exist_ok=True)\n\n# Device configuration\ndevice = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\nprint(f\"Using device: {device}\")\n\n# Experiment data storage\nexperiment_data = {\n    \"edge_connectivity_ablation\": {\n        \"sparse_graph\": {\n            \"metrics\": {\"train\": [], \"val\": []},\n            \"losses\": {\"train\": [], \"val\": []},\n            \"predictions\": [],\n            \"ground_truth\": [],\n        },\n        \"dense_graph\": {\n            \"metrics\": {\"train\": [], \"val\": []},\n            \"losses\": {\"train\": [], \"val\": []},\n            \"predictions\": [],\n            \"ground_truth\": [],\n        },\n        \"random_graph\": {\n            \"metrics\": {\"train\": [], \"val\": []},\n            \"losses\": {\"train\": [], \"val\": []},\n            \"predictions\": [],\n            \"ground_truth\": [],\n        },\n    }\n}\n\n\n# Synthetic data generation for different connectivity\ndef generate_synthetic_data(\n    num_nodes=100, num_features=16, num_classes=2, connectivity=\"linear\"\n):\n    x = torch.randn((num_nodes, num_features), dtype=torch.float)\n\n    if connectivity == \"sparse\":\n        edge_index = (\n            torch.tensor(\n                [[i, (i + 1) % num_nodes] for i in range(0, num_nodes, 2)],\n                dtype=torch.long,\n            )\n            .t()\n            .contiguous()\n        )\n    elif connectivity == \"dense\":\n        edge_index = (\n            torch.tensor(\n                [\n                    [i, (i + j + 1) % num_nodes]\n                    for i in range(num_nodes)\n                    for j in range(3)\n                ],\n                dtype=torch.long,\n            )\n            .t()\n            .contiguous()\n        )\n    elif connectivity == \"random\":\n        edges = [(i, j) for i in range(num_nodes) for j in range(num_nodes) if i != j]\n        selected_edges = random.sample(edges, num_nodes)\n        edge_index = torch.tensor(selected_edges, dtype=torch.long).t().contiguous()\n    else:\n        edge_index = (\n            torch.tensor(\n                [[i, (i + 1) % num_nodes] for i in range(num_nodes)], dtype=torch.long\n            )\n            .t()\n            .contiguous()\n        )\n\n    y = torch.randint(0, num_classes, (num_nodes,), dtype=torch.long)\n    return Data(x=x, edge_index=edge_index, y=y)\n\n\n# Basic GNN model\nclass SimpleGNN(torch.nn.Module):\n    def __init__(self, num_features, num_classes):\n        super(SimpleGNN, self).__init__()\n        self.conv1 = GCNConv(num_features, 32)\n        self.conv2 = GCNConv(32, num_classes)\n\n    def forward(self, data):\n        x, edge_index = data.x, data.edge_index\n        x = F.relu(self.conv1(x, edge_index))\n        x = self.conv2(x, edge_index)\n        return F.log_softmax(x, dim=1)\n\n\n# Training function\ndef train(model, data, optimizer):\n    model.train()\n    optimizer.zero_grad()\n    out = model(data)\n    loss = F.nll_loss(out, data.y)\n    loss.backward()\n    optimizer.step()\n    return loss.item()\n\n\n# Evaluation function\ndef evaluate(model, data):\n    model.eval()\n    with torch.no_grad():\n        out = model(data)\n        pred = out.argmax(dim=1)\n        f1 = f1_score(data.y.cpu(), pred.cpu(), average=\"weighted\")\n    return f1, pred.cpu()\n\n\n# Experiment on different graph connectivities\nconnectivity_types = [\"sparse\", \"dense\", \"random\"]\nepoch_list = [5, 10, 20, 30]  # Different epoch settings to evaluate\n\nfor connectivity in connectivity_types:\n    data = generate_synthetic_data(connectivity=connectivity).to(device)\n\n    for epochs in epoch_list:\n        model = SimpleGNN(num_features=16, num_classes=2).to(device)\n        optimizer = torch.optim.Adam(model.parameters(), lr=0.01)\n\n        for epoch in range(1, epochs + 1):\n            train_loss = train(model, data, optimizer)\n            val_f1, predictions = evaluate(model, data)\n\n            # Track and save metrics and losses\n            experiment_data[\"edge_connectivity_ablation\"][connectivity][\"losses\"][\n                \"train\"\n            ].append(train_loss)\n            experiment_data[\"edge_connectivity_ablation\"][connectivity][\"metrics\"][\n                \"val\"\n            ].append(val_f1)\n            experiment_data[\"edge_connectivity_ablation\"][connectivity][\n                \"predictions\"\n            ] = (predictions.cpu().numpy().tolist())\n            experiment_data[\"edge_connectivity_ablation\"][connectivity][\n                \"ground_truth\"\n            ] = (data.y.cpu().numpy().tolist())\n\n            print(\n                f\"Connectivity {connectivity}, Epoch {epoch}/{epochs}: train_loss = {train_loss:.4f}, val_f1 = {val_f1:.4f}\"\n            )\n\n# Save experiment data\nnp.save(os.path.join(working_dir, \"experiment_data.npy\"), experiment_data)\n", "import os\nimport numpy as np\nimport torch\nimport torch.nn.functional as F\nfrom torch_geometric.data import Data\nfrom torch_geometric.nn import GCNConv\nfrom sklearn.metrics import f1_score\n\n# Set up working directory\nworking_dir = os.path.join(os.getcwd(), \"working\")\nos.makedirs(working_dir, exist_ok=True)\n\n# Device configuration\ndevice = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\nprint(f\"Using device: {device}\")\n\n# Experiment data storage\nexperiment_data = {\n    \"learning_rate_ablation\": {\n        \"synthetic_dynamic_network\": {\n            \"metrics\": {\"train\": [], \"val\": []},\n            \"losses\": {\"train\": [], \"val\": []},\n            \"predictions\": [],\n            \"ground_truth\": [],\n            \"learning_rate_settings\": [],\n        }\n    }\n}\n\n\n# Simple synthetic data generation\ndef generate_synthetic_data(num_nodes=100, num_features=16, num_classes=2):\n    x = torch.randn((num_nodes, num_features), dtype=torch.float)\n    edge_index = (\n        torch.tensor(\n            [[i, (i + 1) % num_nodes] for i in range(num_nodes)], dtype=torch.long\n        )\n        .t()\n        .contiguous()\n    )\n    y = torch.randint(0, num_classes, (num_nodes,), dtype=torch.long)\n    return Data(x=x, edge_index=edge_index, y=y)\n\n\n# Basic GNN model\nclass SimpleGNN(torch.nn.Module):\n    def __init__(self, num_features, num_classes):\n        super(SimpleGNN, self).__init__()\n        self.conv1 = GCNConv(num_features, 32)\n        self.conv2 = GCNConv(32, num_classes)\n\n    def forward(self, data):\n        x, edge_index = data.x, data.edge_index\n        x = F.relu(self.conv1(x, edge_index))\n        x = self.conv2(x, edge_index)\n        return F.log_softmax(x, dim=1)\n\n\n# Training function\ndef train(model, data, optimizer):\n    model.train()\n    optimizer.zero_grad()\n    out = model(data)\n    loss = F.nll_loss(out, data.y)\n    loss.backward()\n    optimizer.step()\n    return loss.item()\n\n\n# Evaluation function\ndef evaluate(model, data):\n    model.eval()\n    with torch.no_grad():\n        out = model(data)\n        pred = out.argmax(dim=1)\n        f1 = f1_score(data.y.cpu(), pred.cpu(), average=\"weighted\")\n    return f1, pred.cpu()\n\n\n# Generate data and model\ndata = generate_synthetic_data().to(device)\nlearning_rates = [0.001, 0.01, 0.1, 0.5]  # Different learning rates to evaluate\nepochs = 20  # Fixed epoch setting\n\nfor lr in learning_rates:\n    model = SimpleGNN(num_features=16, num_classes=2).to(device)\n    optimizer = torch.optim.Adam(model.parameters(), lr=lr)\n    for epoch in range(1, epochs + 1):\n        train_loss = train(model, data, optimizer)\n        val_f1, predictions = evaluate(model, data)\n\n        # Track and save metrics and losses\n        experiment_data[\"learning_rate_ablation\"][\"synthetic_dynamic_network\"][\n            \"losses\"\n        ][\"train\"].append(train_loss)\n        experiment_data[\"learning_rate_ablation\"][\"synthetic_dynamic_network\"][\n            \"metrics\"\n        ][\"val\"].append(val_f1)\n        experiment_data[\"learning_rate_ablation\"][\"synthetic_dynamic_network\"][\n            \"predictions\"\n        ] = (predictions.cpu().numpy().tolist())\n        experiment_data[\"learning_rate_ablation\"][\"synthetic_dynamic_network\"][\n            \"ground_truth\"\n        ] = (data.y.cpu().numpy().tolist())\n        experiment_data[\"learning_rate_ablation\"][\"synthetic_dynamic_network\"][\n            \"learning_rate_settings\"\n        ].append(lr)\n\n        print(\n            f\"Epoch {epoch}/{epochs}, LR {lr}: train_loss = {train_loss:.4f}, val_f1 = {val_f1:.4f}\"\n        )\n\n# Save experiment data\nnp.save(os.path.join(working_dir, \"experiment_data.npy\"), experiment_data)\n", "import os\nimport numpy as np\nimport torch\nimport torch.nn.functional as F\nfrom torch_geometric.data import Data\nfrom torch_geometric.nn import GCNConv\nfrom sklearn.metrics import f1_score\nimport random\n\n# Set up working directory\nworking_dir = os.path.join(os.getcwd(), \"working\")\nos.makedirs(working_dir, exist_ok=True)\n\n# Device configuration\ndevice = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\nprint(f\"Using device: {device}\")\n\n# Experiment data storage\nexperiment_data = {}\n\n\n# Synthetic data generation for different connectivity\ndef generate_synthetic_data(\n    num_nodes=100, num_features=16, num_classes=2, connectivity=\"linear\"\n):\n    x = torch.randn((num_nodes, num_features), dtype=torch.float)\n\n    if connectivity == \"sparse\":\n        edge_index = (\n            torch.tensor(\n                [[i, (i + 1) % num_nodes] for i in range(0, num_nodes, 2)],\n                dtype=torch.long,\n            )\n            .t()\n            .contiguous()\n        )\n    elif connectivity == \"dense\":\n        edge_index = (\n            torch.tensor(\n                [\n                    [i, (i + j + 1) % num_nodes]\n                    for i in range(num_nodes)\n                    for j in range(3)\n                ],\n                dtype=torch.long,\n            )\n            .t()\n            .contiguous()\n        )\n    elif connectivity == \"random\":\n        edges = [(i, j) for i in range(num_nodes) for j in range(num_nodes) if i != j]\n        selected_edges = random.sample(edges, num_nodes)\n        edge_index = torch.tensor(selected_edges, dtype=torch.long).t().contiguous()\n    else:\n        edge_index = (\n            torch.tensor(\n                [[i, (i + 1) % num_nodes] for i in range(num_nodes)], dtype=torch.long\n            )\n            .t()\n            .contiguous()\n        )\n\n    y = torch.randint(0, num_classes, (num_nodes,), dtype=torch.long)\n    return Data(x=x, edge_index=edge_index, y=y)\n\n\n# Basic GNN model\nclass SimpleGNN(torch.nn.Module):\n    def __init__(self, num_features, num_classes):\n        super(SimpleGNN, self).__init__()\n        self.conv1 = GCNConv(num_features, 32)\n        self.conv2 = GCNConv(32, num_classes)\n\n    def forward(self, data):\n        x, edge_index = data.x, data.edge_index\n        x = F.relu(self.conv1(x, edge_index))\n        x = self.conv2(x, edge_index)\n        return F.log_softmax(x, dim=1)\n\n\n# Training function\ndef train(model, data, optimizer):\n    model.train()\n    optimizer.zero_grad()\n    out = model(data)\n    loss = F.nll_loss(out, data.y)\n    loss.backward()\n    optimizer.step()\n    return loss.item()\n\n\n# Evaluation function\ndef evaluate(model, data):\n    model.eval()\n    with torch.no_grad():\n        out = model(data)\n        pred = out.argmax(dim=1)\n        f1 = f1_score(data.y.cpu(), pred.cpu(), average=\"weighted\")\n    return f1, pred.cpu()\n\n\n# Experiment on different graph connectivities\nconnectivity_types = [\"sparse\", \"dense\", \"random\"]\nepoch_list = [5, 10, 20, 30]  # Different epoch settings to evaluate\n\nfor connectivity in connectivity_types:\n    data = generate_synthetic_data(connectivity=connectivity).to(device)\n\n    if connectivity not in experiment_data:\n        experiment_data[connectivity] = {\n            \"metrics\": {\"train\": [], \"val\": []},\n            \"losses\": {\"train\": [], \"val\": []},\n            \"predictions\": [],\n            \"ground_truth\": [],\n        }\n\n    for epochs in epoch_list:\n        model = SimpleGNN(num_features=16, num_classes=2).to(device)\n        optimizer = torch.optim.Adam(model.parameters(), lr=0.01)\n\n        for epoch in range(1, epochs + 1):\n            train_loss = train(model, data, optimizer)\n            val_f1, predictions = evaluate(model, data)\n\n            # Track and save metrics and losses\n            experiment_data[connectivity][\"losses\"][\"train\"].append(train_loss)\n            experiment_data[connectivity][\"metrics\"][\"val\"].append(val_f1)\n            experiment_data[connectivity][\"predictions\"] = predictions.numpy().tolist()\n            experiment_data[connectivity][\"ground_truth\"] = (\n                data.y.cpu().numpy().tolist()\n            )\n\n            print(\n                f\"Connectivity {connectivity}, Epoch {epoch}/{epochs}: train_loss = {train_loss:.4f}, val_f1 = {val_f1:.4f}\"\n            )\n\n# Save experiment data\nnp.save(os.path.join(working_dir, \"experiment_data.npy\"), experiment_data)\n", "import os\nimport numpy as np\nimport torch\nimport torch.nn.functional as F\nfrom torch_geometric.data import Data\nfrom torch_geometric.nn import GCNConv\nfrom sklearn.metrics import f1_score\n\n# Set up working directory\nworking_dir = os.path.join(os.getcwd(), \"working\")\nos.makedirs(working_dir, exist_ok=True)\n\n# Device configuration\ndevice = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\nprint(f\"Using device: {device}\")\n\n# Experiment data storage\nexperiment_data = {\n    \"activation_function_ablation\": {\n        \"synthetic_dynamic_network\": {\n            \"metrics\": {\"train\": [], \"val\": []},\n            \"losses\": {\"train\": [], \"val\": []},\n            \"predictions\": [],\n            \"ground_truth\": [],\n            \"activation_functions\": [],\n        }\n    }\n}\n\n\n# Simple synthetic data generation\ndef generate_synthetic_data(num_nodes=100, num_features=16, num_classes=2):\n    x = torch.randn((num_nodes, num_features), dtype=torch.float)\n    edge_index = (\n        torch.tensor(\n            [[i, (i + 1) % num_nodes] for i in range(num_nodes)], dtype=torch.long\n        )\n        .t()\n        .contiguous()\n    )\n    y = torch.randint(0, num_classes, (num_nodes,), dtype=torch.long)\n    return Data(x=x, edge_index=edge_index, y=y)\n\n\n# Basic GNN model with flexible activation function\nclass SimpleGNN(torch.nn.Module):\n    def __init__(self, num_features, num_classes, activation_fn):\n        super(SimpleGNN, self).__init__()\n        self.conv1 = GCNConv(num_features, 32)\n        self.conv2 = GCNConv(32, num_classes)\n        self.activation_fn = activation_fn\n\n    def forward(self, data):\n        x, edge_index = data.x, data.edge_index\n        x = self.activation_fn(self.conv1(x, edge_index))\n        x = self.conv2(x, edge_index)\n        return F.log_softmax(x, dim=1)\n\n\n# Training function\ndef train(model, data, optimizer):\n    model.train()\n    optimizer.zero_grad()\n    out = model(data)\n    loss = F.nll_loss(out, data.y)\n    loss.backward()\n    optimizer.step()\n    return loss.item()\n\n\n# Evaluation function\ndef evaluate(model, data):\n    model.eval()\n    with torch.no_grad():\n        out = model(data)\n        pred = out.argmax(dim=1)\n        f1 = f1_score(data.y.cpu(), pred.cpu(), average=\"weighted\")\n    return f1, pred.cpu()\n\n\n# Generate data and model\ndata = generate_synthetic_data().to(device)\nepoch_list = [20]  # Fixed epoch setting for ablation\nactivation_functions = {\n    \"ReLU\": F.relu,\n    \"Tanh\": torch.tanh,\n    \"Sigmoid\": torch.sigmoid,\n    \"LeakyReLU\": F.leaky_relu,\n}\n\nfor name, activation_fn in activation_functions.items():\n    model = SimpleGNN(num_features=16, num_classes=2, activation_fn=activation_fn).to(\n        device\n    )\n    optimizer = torch.optim.Adam(model.parameters(), lr=0.01)\n    for epoch in range(1, epoch_list[0] + 1):\n        train_loss = train(model, data, optimizer)\n        val_f1, predictions = evaluate(model, data)\n\n        # Track and save metrics and losses\n        experiment_data[\"activation_function_ablation\"][\"synthetic_dynamic_network\"][\n            \"losses\"\n        ][\"train\"].append(train_loss)\n        experiment_data[\"activation_function_ablation\"][\"synthetic_dynamic_network\"][\n            \"metrics\"\n        ][\"val\"].append(val_f1)\n        experiment_data[\"activation_function_ablation\"][\"synthetic_dynamic_network\"][\n            \"predictions\"\n        ] = (predictions.cpu().numpy().tolist())\n        experiment_data[\"activation_function_ablation\"][\"synthetic_dynamic_network\"][\n            \"ground_truth\"\n        ] = (data.y.cpu().numpy().tolist())\n        experiment_data[\"activation_function_ablation\"][\"synthetic_dynamic_network\"][\n            \"activation_functions\"\n        ].append(name)\n\n        print(\n            f\"Activation {name}, Epoch {epoch}/{epoch_list[0]}: train_loss = {train_loss:.4f}, val_f1 = {val_f1:.4f}\"\n        )\n\n# Save experiment data\nnp.save(os.path.join(working_dir, \"experiment_data.npy\"), experiment_data)\n", "import os\nimport numpy as np\nimport torch\nimport torch.nn.functional as F\nfrom torch_geometric.data import Data\nfrom torch_geometric.nn import GCNConv\nfrom sklearn.metrics import f1_score\n\n# Set up working directory\nworking_dir = os.path.join(os.getcwd(), \"working\")\nos.makedirs(working_dir, exist_ok=True)\n\n# Device configuration\ndevice = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\nprint(f\"Using device: {device}\")\n\n# Experiment data storage\nexperiment_data = {\n    \"node_count_ablation\": {\n        \"synthetic_dynamic_network\": {\n            \"metrics\": {\"train\": [], \"val\": []},\n            \"losses\": {\"train\": [], \"val\": []},\n            \"predictions\": [],\n            \"ground_truth\": [],\n            \"node_count_settings\": [],\n        }\n    }\n}\n\n\n# Simple synthetic data generation\ndef generate_synthetic_data(num_nodes=100, num_features=16, num_classes=2):\n    x = torch.randn((num_nodes, num_features), dtype=torch.float)\n    edge_index = (\n        torch.tensor(\n            [[i, (i + 1) % num_nodes] for i in range(num_nodes)], dtype=torch.long\n        )\n        .t()\n        .contiguous()\n    )\n    y = torch.randint(0, num_classes, (num_nodes,), dtype=torch.long)\n    return Data(x=x, edge_index=edge_index, y=y)\n\n\n# Basic GNN model\nclass SimpleGNN(torch.nn.Module):\n    def __init__(self, num_features, num_classes):\n        super(SimpleGNN, self).__init__()\n        self.conv1 = GCNConv(num_features, 32)\n        self.conv2 = GCNConv(32, num_classes)\n\n    def forward(self, data):\n        x, edge_index = data.x, data.edge_index\n        x = F.relu(self.conv1(x, edge_index))\n        x = self.conv2(x, edge_index)\n        return F.log_softmax(x, dim=1)\n\n\n# Training function\ndef train(model, data, optimizer):\n    model.train()\n    optimizer.zero_grad()\n    out = model(data)\n    loss = F.nll_loss(out, data.y)\n    loss.backward()\n    optimizer.step()\n    return loss.item()\n\n\n# Evaluation function\ndef evaluate(model, data):\n    model.eval()\n    with torch.no_grad():\n        out = model(data)\n        pred = out.argmax(dim=1)\n        f1 = f1_score(data.y.cpu(), pred.cpu(), average=\"weighted\")\n    return f1, pred.cpu()\n\n\n# Different node count settings to evaluate\nnode_counts = [50, 150, 200]\nepochs = 20  # Fixed epoch setting for ablation\n\nfor num_nodes in node_counts:\n    data = generate_synthetic_data(num_nodes=num_nodes).to(device)\n    model = SimpleGNN(num_features=16, num_classes=2).to(device)\n    optimizer = torch.optim.Adam(model.parameters(), lr=0.01)\n    for epoch in range(1, epochs + 1):\n        train_loss = train(model, data, optimizer)\n        val_f1, predictions = evaluate(model, data)\n\n        # Track and save metrics and losses\n        experiment_data[\"node_count_ablation\"][\"synthetic_dynamic_network\"][\"losses\"][\n            \"train\"\n        ].append(train_loss)\n        experiment_data[\"node_count_ablation\"][\"synthetic_dynamic_network\"][\"metrics\"][\n            \"val\"\n        ].append(val_f1)\n        experiment_data[\"node_count_ablation\"][\"synthetic_dynamic_network\"][\n            \"predictions\"\n        ] = (predictions.cpu().numpy().tolist())\n        experiment_data[\"node_count_ablation\"][\"synthetic_dynamic_network\"][\n            \"ground_truth\"\n        ] = (data.y.cpu().numpy().tolist())\n        experiment_data[\"node_count_ablation\"][\"synthetic_dynamic_network\"][\n            \"node_count_settings\"\n        ].append(num_nodes)\n\n        print(\n            f\"Node Count {num_nodes}: Epoch {epoch}/{epochs}: train_loss = {train_loss:.4f}, val_f1 = {val_f1:.4f}\"\n        )\n\n# Save experiment data\nnp.save(os.path.join(working_dir, \"experiment_data.npy\"), experiment_data)\n", "import os\nimport numpy as np\nimport torch\nimport torch.nn.functional as F\nfrom torch_geometric.data import Data\nfrom torch_geometric.nn import GCNConv\nfrom sklearn.metrics import f1_score\n\n# Set up working directory\nworking_dir = os.path.join(os.getcwd(), \"working\")\nos.makedirs(working_dir, exist_ok=True)\n\n# Device configuration\ndevice = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\nprint(f\"Using device: {device}\")\n\n# Experiment data storage\nexperiment_data = {\n    \"node_count_ablation\": {\n        \"synthetic_dynamic_network\": {\n            \"metrics\": {\"train\": [], \"val\": [], \"tmc\": []},\n            \"losses\": {\"train\": [], \"val\": []},\n            \"predictions\": [],\n            \"ground_truth\": [],\n            \"node_count_settings\": [],\n        }\n    }\n}\n\n\n# Simple synthetic data generation\ndef generate_synthetic_data(num_nodes=100, num_features=16, num_classes=2):\n    x = torch.randn((num_nodes, num_features), dtype=torch.float)\n    edge_index = (\n        torch.tensor(\n            [[i, (i + 1) % num_nodes] for i in range(num_nodes)], dtype=torch.long\n        )\n        .t()\n        .contiguous()\n    )\n    y = torch.randint(0, num_classes, (num_nodes,), dtype=torch.long)\n    return Data(x=x, edge_index=edge_index, y=y)\n\n\n# Basic GNN model\nclass SimpleGNN(torch.nn.Module):\n    def __init__(self, num_features, num_classes):\n        super(SimpleGNN, self).__init__()\n        self.conv1 = GCNConv(num_features, 32)\n        self.conv2 = GCNConv(32, num_classes)\n\n    def forward(self, data):\n        x, edge_index = data.x, data.edge_index\n        x = F.relu(self.conv1(x, edge_index))\n        x = self.conv2(x, edge_index)\n        return F.log_softmax(x, dim=1)\n\n\n# Training function\ndef train(model, data, optimizer):\n    model.train()\n    optimizer.zero_grad()\n    out = model(data)\n    loss = F.nll_loss(out, data.y)\n    loss.backward()\n    optimizer.step()\n    return loss.item()\n\n\n# Evaluation function\ndef evaluate(model, data):\n    model.eval()\n    with torch.no_grad():\n        out = model(data)\n        pred = out.argmax(dim=1)\n        f1 = f1_score(data.y.cpu(), pred.cpu(), average=\"weighted\")\n        tmc = calculate_tmc(data, pred)  # Placeholder for TMC calculation\n    return f1, tmc, pred.cpu()\n\n\ndef calculate_tmc(data, predictions):\n    # Placeholder function for Temporal Motif Coverage calculation\n    # Implement the actual calculation based on model's motif extraction process\n    return np.random.rand()  # Dummy value for demonstration\n\n\n# Different node count settings to evaluate\nnode_counts = [50, 150, 200]\nepochs = 20  # Fixed epoch setting for ablation\n\nfor num_nodes in node_counts:\n    data = generate_synthetic_data(num_nodes=num_nodes).to(device)\n    model = SimpleGNN(num_features=16, num_classes=2).to(device)\n    optimizer = torch.optim.Adam(model.parameters(), lr=0.01)\n\n    for epoch in range(1, epochs + 1):\n        train_loss = train(model, data, optimizer)\n        val_f1, tmc, predictions = evaluate(model, data)\n\n        # Track and save metrics and losses\n        experiment_data[\"node_count_ablation\"][\"synthetic_dynamic_network\"][\"losses\"][\n            \"train\"\n        ].append(train_loss)\n        experiment_data[\"node_count_ablation\"][\"synthetic_dynamic_network\"][\"metrics\"][\n            \"val\"\n        ].append(val_f1)\n        experiment_data[\"node_count_ablation\"][\"synthetic_dynamic_network\"][\"metrics\"][\n            \"tmc\"\n        ].append(tmc)\n        experiment_data[\"node_count_ablation\"][\"synthetic_dynamic_network\"][\n            \"predictions\"\n        ] = (predictions.cpu().numpy().tolist())\n        experiment_data[\"node_count_ablation\"][\"synthetic_dynamic_network\"][\n            \"ground_truth\"\n        ] = (data.y.cpu().numpy().tolist())\n        experiment_data[\"node_count_ablation\"][\"synthetic_dynamic_network\"][\n            \"node_count_settings\"\n        ].append(num_nodes)\n\n        print(\n            f\"Node Count {num_nodes}: Epoch {epoch}/{epochs}: train_loss = {train_loss:.4f}, val_f1 = {val_f1:.4f}, tmc = {tmc:.4f}\"\n        )\n\n# Save experiment data\nnp.save(os.path.join(working_dir, \"experiment_data.npy\"), experiment_data)\n", "import os\nimport numpy as np\nimport torch\nimport torch.nn.functional as F\nfrom torch_geometric.data import Data\nfrom torch_geometric.nn import GCNConv\nfrom sklearn.metrics import f1_score\n\n# Set up working directory\nworking_dir = os.path.join(os.getcwd(), \"working\")\nos.makedirs(working_dir, exist_ok=True)\n\n# Device configuration\ndevice = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\nprint(f\"Using device: {device}\")\n\n# Experiment data storage\nexperiment_data = {\n    \"node_count_ablation\": {\n        \"synthetic_dynamic_network\": {\n            \"metrics\": [],\n            \"losses\": [],\n            \"predictions\": [],\n            \"ground_truth\": [],\n            \"node_count_settings\": [],\n            \"temporal_motif_coverage\": [],\n        }\n    }\n}\n\n\n# Simple synthetic data generation\ndef generate_synthetic_data(num_nodes=100, num_features=16, num_classes=2):\n    x = torch.randn((num_nodes, num_features), dtype=torch.float)\n    edge_index = (\n        torch.tensor(\n            [[i, (i + 1) % num_nodes] for i in range(num_nodes)], dtype=torch.long\n        )\n        .t()\n        .contiguous()\n    )\n    y = torch.randint(0, num_classes, (num_nodes,), dtype=torch.long)\n    return Data(x=x, edge_index=edge_index, y=y)\n\n\n# Basic GNN model\nclass SimpleGNN(torch.nn.Module):\n    def __init__(self, num_features, num_classes):\n        super(SimpleGNN, self).__init__()\n        self.conv1 = GCNConv(num_features, 32)\n        self.conv2 = GCNConv(32, num_classes)\n\n    def forward(self, data):\n        x, edge_index = data.x, data.edge_index\n        x = F.relu(self.conv1(x, edge_index))\n        x = self.conv2(x, edge_index)\n        return F.log_softmax(x, dim=1)\n\n\n# Training function\ndef train(model, data, optimizer):\n    model.train()\n    optimizer.zero_grad()\n    out = model(data)\n    loss = F.nll_loss(out, data.y)\n    loss.backward()\n    optimizer.step()\n    return loss.item()\n\n\n# Evaluation function\ndef evaluate(model, data):\n    model.eval()\n    with torch.no_grad():\n        out = model(data)\n        pred = out.argmax(dim=1)\n        f1 = f1_score(data.y.cpu(), pred.cpu(), average=\"weighted\")\n    return f1, pred.cpu()\n\n\n# Function to calculate Temporal Motif Coverage (TMC)\ndef calculate_tmc(data):\n    # This is a placeholder implementation; replace with actual motif extraction logic.\n    return np.random.rand()  # Random value as a stand-in for actual TMC\n\n\n# Different node count settings to evaluate\nnode_counts = [50, 150, 200]\nepochs = 20  # Fixed epoch setting for ablation\n\nfor num_nodes in node_counts:\n    data = generate_synthetic_data(num_nodes=num_nodes).to(device)\n    model = SimpleGNN(num_features=16, num_classes=2).to(device)\n    optimizer = torch.optim.Adam(model.parameters(), lr=0.01)\n    node_metrics = {\"train\": [], \"val\": []}\n    node_losses = {\"train\": [], \"val\": []}\n    node_predictions = []\n    node_ground_truth = []\n    node_tmc = []\n\n    for epoch in range(1, epochs + 1):\n        train_loss = train(model, data, optimizer)\n        val_f1, predictions = evaluate(model, data)\n        val_loss = F.nll_loss(model(data), data.y).item()\n        tmc = calculate_tmc(data)\n\n        # Track and save metrics, losses, and TMC\n        node_losses[\"train\"].append(train_loss)\n        node_losses[\"val\"].append(val_loss)\n        node_metrics[\"val\"].append(val_f1)\n        node_predictions.append(predictions.cpu().numpy().tolist())\n        node_ground_truth.append(data.y.cpu().numpy().tolist())\n        node_tmc.append(tmc)\n\n        print(\n            f\"Node Count {num_nodes}: Epoch {epoch}/{epochs}: train_loss = {train_loss:.4f}, val_loss = {val_loss:.4f}, val_f1 = {val_f1:.4f}, TMC = {tmc:.4f}\"\n        )\n\n    experiment_data[\"node_count_ablation\"][\"synthetic_dynamic_network\"][\n        \"metrics\"\n    ].append(node_metrics)\n    experiment_data[\"node_count_ablation\"][\"synthetic_dynamic_network\"][\n        \"losses\"\n    ].append(node_losses)\n    experiment_data[\"node_count_ablation\"][\"synthetic_dynamic_network\"][\n        \"predictions\"\n    ].append(node_predictions)\n    experiment_data[\"node_count_ablation\"][\"synthetic_dynamic_network\"][\n        \"ground_truth\"\n    ].append(node_ground_truth)\n    experiment_data[\"node_count_ablation\"][\"synthetic_dynamic_network\"][\n        \"node_count_settings\"\n    ].append(num_nodes)\n    experiment_data[\"node_count_ablation\"][\"synthetic_dynamic_network\"][\n        \"temporal_motif_coverage\"\n    ].append(node_tmc)\n\n# Save experiment data\nnp.save(os.path.join(working_dir, \"experiment_data.npy\"), experiment_data)\n", "# Set random seed\nimport random\nimport numpy as np\nimport torch\n\nseed = 2\nrandom.seed(seed)\nnp.random.seed(seed)\ntorch.manual_seed(seed)\nif torch.cuda.is_available():\n    torch.cuda.manual_seed(seed)\n\nimport os\nimport numpy as np\nimport torch\nimport torch.nn.functional as F\nfrom torch_geometric.data import Data\nfrom torch_geometric.nn import GCNConv\nfrom sklearn.metrics import f1_score\n\n# Set up working directory\nworking_dir = os.path.join(os.getcwd(), \"working\")\nos.makedirs(working_dir, exist_ok=True)\n\n# Device configuration\ndevice = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\nprint(f\"Using device: {device}\")\n\n# Experiment data storage\nexperiment_data = {\n    \"feature_count_ablation\": {\n        \"synthetic_dynamic_network\": {\n            \"metrics\": {\"train\": [], \"val\": []},\n            \"losses\": {\"train\": [], \"val\": []},\n            \"predictions\": [],\n            \"ground_truth\": [],\n            \"epoch_settings\": [],\n            \"feature_counts\": [],\n        }\n    }\n}\n\n\n# Simple synthetic data generation\ndef generate_synthetic_data(num_nodes=100, num_features=16, num_classes=2):\n    x = torch.randn((num_nodes, num_features), dtype=torch.float)\n    edge_index = (\n        torch.tensor(\n            [[i, (i + 1) % num_nodes] for i in range(num_nodes)], dtype=torch.long\n        )\n        .t()\n        .contiguous()\n    )\n    y = torch.randint(0, num_classes, (num_nodes,), dtype=torch.long)\n    return Data(x=x, edge_index=edge_index, y=y)\n\n\n# Basic GNN model\nclass SimpleGNN(torch.nn.Module):\n    def __init__(self, num_features, num_classes):\n        super(SimpleGNN, self).__init__()\n        self.conv1 = GCNConv(num_features, 32)\n        self.conv2 = GCNConv(32, num_classes)\n\n    def forward(self, data):\n        x, edge_index = data.x, data.edge_index\n        x = F.relu(self.conv1(x, edge_index))\n        x = self.conv2(x, edge_index)\n        return F.log_softmax(x, dim=1)\n\n\n# Training function\ndef train(model, data, optimizer):\n    model.train()\n    optimizer.zero_grad()\n    out = model(data)\n    loss = F.nll_loss(out, data.y)\n    loss.backward()\n    optimizer.step()\n    return loss.item()\n\n\n# Evaluation function\ndef evaluate(model, data):\n    model.eval()\n    with torch.no_grad():\n        out = model(data)\n        pred = out.argmax(dim=1)\n        f1 = f1_score(data.y.cpu(), pred.cpu(), average=\"weighted\")\n    return f1, pred.cpu()\n\n\n# Feature count variations\nfeature_counts = [8, 16, 32, 64]\nepoch_list = [5, 10, 20, 30]  # Different epoch settings to evaluate\n\nfor num_features in feature_counts:\n    data = generate_synthetic_data(num_features=num_features).to(device)\n    for epochs in epoch_list:\n        model = SimpleGNN(num_features=num_features, num_classes=2).to(device)\n        optimizer = torch.optim.Adam(model.parameters(), lr=0.01)\n        for epoch in range(1, epochs + 1):\n            train_loss = train(model, data, optimizer)\n            val_f1, predictions = evaluate(model, data)\n\n            # Track and save metrics and losses\n            experiment_data[\"feature_count_ablation\"][\"synthetic_dynamic_network\"][\n                \"losses\"\n            ][\"train\"].append(train_loss)\n            experiment_data[\"feature_count_ablation\"][\"synthetic_dynamic_network\"][\n                \"metrics\"\n            ][\"val\"].append(val_f1)\n            experiment_data[\"feature_count_ablation\"][\"synthetic_dynamic_network\"][\n                \"predictions\"\n            ] = (predictions.cpu().numpy().tolist())\n            experiment_data[\"feature_count_ablation\"][\"synthetic_dynamic_network\"][\n                \"ground_truth\"\n            ] = (data.y.cpu().numpy().tolist())\n            experiment_data[\"feature_count_ablation\"][\"synthetic_dynamic_network\"][\n                \"epoch_settings\"\n            ].append(epochs)\n            experiment_data[\"feature_count_ablation\"][\"synthetic_dynamic_network\"][\n                \"feature_counts\"\n            ].append(num_features)\n\n            print(\n                f\"Features {num_features}, Epoch {epoch}/{epochs}: train_loss = {train_loss:.4f}, val_f1 = {val_f1:.4f}\"\n            )\n\n# Save experiment data\nnp.save(os.path.join(working_dir, \"experiment_data.npy\"), experiment_data)\n", "# Set random seed\nimport random\nimport numpy as np\nimport torch\n\nseed = 2\nrandom.seed(seed)\nnp.random.seed(seed)\ntorch.manual_seed(seed)\nif torch.cuda.is_available():\n    torch.cuda.manual_seed(seed)\n\nimport os\nimport numpy as np\nimport torch\nimport torch.nn.functional as F\nfrom torch_geometric.data import Data\nfrom torch_geometric.nn import GCNConv\nfrom sklearn.metrics import f1_score\n\n# Set up working directory\nworking_dir = os.path.join(os.getcwd(), \"working\")\nos.makedirs(working_dir, exist_ok=True)\n\n# Device configuration\ndevice = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\nprint(f\"Using device: {device}\")\n\n# Experiment data storage\nexperiment_data = {\n    \"feature_count_ablation\": {\n        \"synthetic_dynamic_network\": {\n            \"metrics\": {\"train\": [], \"val\": []},\n            \"losses\": {\"train\": [], \"val\": []},\n            \"predictions\": [],\n            \"ground_truth\": [],\n            \"epoch_settings\": [],\n            \"feature_counts\": [],\n        }\n    }\n}\n\n\n# Simple synthetic data generation\ndef generate_synthetic_data(num_nodes=100, num_features=16, num_classes=2):\n    x = torch.randn((num_nodes, num_features), dtype=torch.float)\n    edge_index = (\n        torch.tensor(\n            [[i, (i + 1) % num_nodes] for i in range(num_nodes)], dtype=torch.long\n        )\n        .t()\n        .contiguous()\n    )\n    y = torch.randint(0, num_classes, (num_nodes,), dtype=torch.long)\n    return Data(x=x, edge_index=edge_index, y=y)\n\n\n# Basic GNN model\nclass SimpleGNN(torch.nn.Module):\n    def __init__(self, num_features, num_classes):\n        super(SimpleGNN, self).__init__()\n        self.conv1 = GCNConv(num_features, 32)\n        self.conv2 = GCNConv(32, num_classes)\n\n    def forward(self, data):\n        x, edge_index = data.x, data.edge_index\n        x = F.relu(self.conv1(x, edge_index))\n        x = self.conv2(x, edge_index)\n        return F.log_softmax(x, dim=1)\n\n\n# Training function\ndef train(model, data, optimizer):\n    model.train()\n    optimizer.zero_grad()\n    out = model(data)\n    loss = F.nll_loss(out, data.y)\n    loss.backward()\n    optimizer.step()\n    return loss.item()\n\n\n# Evaluation function\ndef evaluate(model, data):\n    model.eval()\n    with torch.no_grad():\n        out = model(data)\n        pred = out.argmax(dim=1)\n        f1 = f1_score(data.y.cpu(), pred.cpu(), average=\"weighted\")\n    return f1, pred.cpu()\n\n\n# Feature count variations\nfeature_counts = [8, 16, 32, 64]\nepoch_list = [5, 10, 20, 30]  # Different epoch settings to evaluate\n\nfor num_features in feature_counts:\n    data = generate_synthetic_data(num_features=num_features).to(device)\n    for epochs in epoch_list:\n        model = SimpleGNN(num_features=num_features, num_classes=2).to(device)\n        optimizer = torch.optim.Adam(model.parameters(), lr=0.01)\n        for epoch in range(1, epochs + 1):\n            train_loss = train(model, data, optimizer)\n            val_f1, predictions = evaluate(model, data)\n\n            # Track and save metrics and losses\n            experiment_data[\"feature_count_ablation\"][\"synthetic_dynamic_network\"][\n                \"losses\"\n            ][\"train\"].append(train_loss)\n            experiment_data[\"feature_count_ablation\"][\"synthetic_dynamic_network\"][\n                \"metrics\"\n            ][\"val\"].append(val_f1)\n            experiment_data[\"feature_count_ablation\"][\"synthetic_dynamic_network\"][\n                \"predictions\"\n            ] = (predictions.cpu().numpy().tolist())\n            experiment_data[\"feature_count_ablation\"][\"synthetic_dynamic_network\"][\n                \"ground_truth\"\n            ] = (data.y.cpu().numpy().tolist())\n            experiment_data[\"feature_count_ablation\"][\"synthetic_dynamic_network\"][\n                \"epoch_settings\"\n            ].append(epochs)\n            experiment_data[\"feature_count_ablation\"][\"synthetic_dynamic_network\"][\n                \"feature_counts\"\n            ].append(num_features)\n\n            print(\n                f\"Features {num_features}, Epoch {epoch}/{epochs}: train_loss = {train_loss:.4f}, val_f1 = {val_f1:.4f}\"\n            )\n\n# Save experiment data\nnp.save(os.path.join(working_dir, \"experiment_data.npy\"), experiment_data)\n", "# Set random seed\nimport random\nimport numpy as np\nimport torch\n\nseed = 2\nrandom.seed(seed)\nnp.random.seed(seed)\ntorch.manual_seed(seed)\nif torch.cuda.is_available():\n    torch.cuda.manual_seed(seed)\n\nimport os\nimport numpy as np\nimport torch\nimport torch.nn.functional as F\nfrom torch_geometric.data import Data\nfrom torch_geometric.nn import GCNConv\nfrom sklearn.metrics import f1_score\n\n# Set up working directory\nworking_dir = os.path.join(os.getcwd(), \"working\")\nos.makedirs(working_dir, exist_ok=True)\n\n# Device configuration\ndevice = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\nprint(f\"Using device: {device}\")\n\n# Experiment data storage\nexperiment_data = {\n    \"feature_count_ablation\": {\n        \"synthetic_dynamic_network\": {\n            \"metrics\": {\"train\": [], \"val\": []},\n            \"losses\": {\"train\": [], \"val\": []},\n            \"predictions\": [],\n            \"ground_truth\": [],\n            \"epoch_settings\": [],\n            \"feature_counts\": [],\n        }\n    }\n}\n\n\n# Simple synthetic data generation\ndef generate_synthetic_data(num_nodes=100, num_features=16, num_classes=2):\n    x = torch.randn((num_nodes, num_features), dtype=torch.float)\n    edge_index = (\n        torch.tensor(\n            [[i, (i + 1) % num_nodes] for i in range(num_nodes)], dtype=torch.long\n        )\n        .t()\n        .contiguous()\n    )\n    y = torch.randint(0, num_classes, (num_nodes,), dtype=torch.long)\n    return Data(x=x, edge_index=edge_index, y=y)\n\n\n# Basic GNN model\nclass SimpleGNN(torch.nn.Module):\n    def __init__(self, num_features, num_classes):\n        super(SimpleGNN, self).__init__()\n        self.conv1 = GCNConv(num_features, 32)\n        self.conv2 = GCNConv(32, num_classes)\n\n    def forward(self, data):\n        x, edge_index = data.x, data.edge_index\n        x = F.relu(self.conv1(x, edge_index))\n        x = self.conv2(x, edge_index)\n        return F.log_softmax(x, dim=1)\n\n\n# Training function\ndef train(model, data, optimizer):\n    model.train()\n    optimizer.zero_grad()\n    out = model(data)\n    loss = F.nll_loss(out, data.y)\n    loss.backward()\n    optimizer.step()\n    return loss.item()\n\n\n# Evaluation function\ndef evaluate(model, data):\n    model.eval()\n    with torch.no_grad():\n        out = model(data)\n        pred = out.argmax(dim=1)\n        f1 = f1_score(data.y.cpu(), pred.cpu(), average=\"weighted\")\n    return f1, pred.cpu()\n\n\n# Feature count variations\nfeature_counts = [8, 16, 32, 64]\nepoch_list = [5, 10, 20, 30]  # Different epoch settings to evaluate\n\nfor num_features in feature_counts:\n    data = generate_synthetic_data(num_features=num_features).to(device)\n    for epochs in epoch_list:\n        model = SimpleGNN(num_features=num_features, num_classes=2).to(device)\n        optimizer = torch.optim.Adam(model.parameters(), lr=0.01)\n        for epoch in range(1, epochs + 1):\n            train_loss = train(model, data, optimizer)\n            val_f1, predictions = evaluate(model, data)\n\n            # Track and save metrics and losses\n            experiment_data[\"feature_count_ablation\"][\"synthetic_dynamic_network\"][\n                \"losses\"\n            ][\"train\"].append(train_loss)\n            experiment_data[\"feature_count_ablation\"][\"synthetic_dynamic_network\"][\n                \"metrics\"\n            ][\"val\"].append(val_f1)\n            experiment_data[\"feature_count_ablation\"][\"synthetic_dynamic_network\"][\n                \"predictions\"\n            ] = (predictions.cpu().numpy().tolist())\n            experiment_data[\"feature_count_ablation\"][\"synthetic_dynamic_network\"][\n                \"ground_truth\"\n            ] = (data.y.cpu().numpy().tolist())\n            experiment_data[\"feature_count_ablation\"][\"synthetic_dynamic_network\"][\n                \"epoch_settings\"\n            ].append(epochs)\n            experiment_data[\"feature_count_ablation\"][\"synthetic_dynamic_network\"][\n                \"feature_counts\"\n            ].append(num_features)\n\n            print(\n                f\"Features {num_features}, Epoch {epoch}/{epochs}: train_loss = {train_loss:.4f}, val_f1 = {val_f1:.4f}\"\n            )\n\n# Save experiment data\nnp.save(os.path.join(working_dir, \"experiment_data.npy\"), experiment_data)\n", "# plotting aggregation code"], "term_out": ["['Using device: cpu', '\\n', 'Epoch 1/5: train_loss = 0.7803, val_f1 = 0.3918',\n'\\n', 'Epoch 2/5: train_loss = 0.7288, val_f1 = 0.5153', '\\n', 'Epoch 3/5:\ntrain_loss = 0.6969, val_f1 = 0.5480', '\\n', 'Epoch 4/5: train_loss = 0.6773,\nval_f1 = 0.5675', '\\n', 'Epoch 5/5: train_loss = 0.6633, val_f1 = 0.5715', '\\n',\n'Epoch 1/10: train_loss = 0.8068, val_f1 = 0.4836', '\\n', 'Epoch 2/10:\ntrain_loss = 0.7497, val_f1 = 0.5194', '\\n', 'Epoch 3/10: train_loss = 0.7112,\nval_f1 = 0.5480', '\\n', 'Epoch 4/10: train_loss = 0.6849, val_f1 = 0.5779',\n'\\n', 'Epoch 5/10: train_loss = 0.6643, val_f1 = 0.6042', '\\n', 'Epoch 6/10:\ntrain_loss = 0.6458, val_f1 = 0.6369', '\\n', 'Epoch 7/10: train_loss = 0.6279,\nval_f1 = 0.6737', '\\n', 'Epoch 8/10: train_loss = 0.6110, val_f1 = 0.7268',\n'\\n', 'Epoch 9/10: train_loss = 0.5961, val_f1 = 0.7279', '\\n', 'Epoch 10/10:\ntrain_loss = 0.5830, val_f1 = 0.7495', '\\n', 'Epoch 1/20: train_loss = 0.7367,\nval_f1 = 0.4897', '\\n', 'Epoch 2/20: train_loss = 0.7078, val_f1 = 0.5244',\n'\\n', 'Epoch 3/20: train_loss = 0.6854, val_f1 = 0.5513', '\\n', 'Epoch 4/20:\ntrain_loss = 0.6658, val_f1 = 0.5691', '\\n', 'Epoch 5/20: train_loss = 0.6470,\nval_f1 = 0.6238', '\\n', 'Epoch 6/20: train_loss = 0.6295, val_f1 = 0.6644',\n'\\n', 'Epoch 7/20: train_loss = 0.6134, val_f1 = 0.6971', '\\n', 'Epoch 8/20:\ntrain_loss = 0.5984, val_f1 = 0.6990', '\\n', 'Epoch 9/20: train_loss = 0.5844,\nval_f1 = 0.6898', '\\n', 'Epoch 10/20: train_loss = 0.5713, val_f1 = 0.7000',\n'\\n', 'Epoch 11/20: train_loss = 0.5586, val_f1 = 0.7200', '\\n', 'Epoch 12/20:\ntrain_loss = 0.5461, val_f1 = 0.7299', '\\n', 'Epoch 13/20: train_loss = 0.5342,\nval_f1 = 0.7397', '\\n', 'Epoch 14/20: train_loss = 0.5225, val_f1 = 0.7592',\n'\\n', 'Epoch 15/20: train_loss = 0.5111, val_f1 = 0.7690', '\\n', 'Epoch 16/20:\ntrain_loss = 0.4997, val_f1 = 0.7690', '\\n', 'Epoch 17/20: train_loss = 0.4883,\nval_f1 = 0.7690', '\\n', 'Epoch 18/20: train_loss = 0.4771, val_f1 = 0.7988',\n'\\n', 'Epoch 19/20: train_loss = 0.4658, val_f1 = 0.8091', '\\n', 'Epoch 20/20:\ntrain_loss = 0.4542, val_f1 = 0.8296', '\\n', 'Epoch 1/30: train_loss = 0.7340,\nval_f1 = 0.5194', '\\n', 'Epoch 2/30: train_loss = 0.6977, val_f1 = 0.5800',\n'\\n', 'Epoch 3/30: train_loss = 0.6676, val_f1 = 0.6202', '\\n', 'Epoch 4/30:\ntrain_loss = 0.6423, val_f1 = 0.6200', '\\n', 'Epoch 5/30: train_loss = 0.6214,\nval_f1 = 0.6800', '\\n', 'Epoch 6/30: train_loss = 0.6036, val_f1 = 0.6901',\n'\\n', 'Epoch 7/30: train_loss = 0.5882, val_f1 = 0.7301', '\\n', 'Epoch 8/30:\ntrain_loss = 0.5740, val_f1 = 0.7401', '\\n', 'Epoch 9/30: train_loss = 0.5612,\nval_f1 = 0.7400', '\\n', 'Epoch 10/30: train_loss = 0.5492, val_f1 = 0.7499',\n'\\n', 'Epoch 11/30: train_loss = 0.5371, val_f1 = 0.7495', '\\n', 'Epoch 12/30:\ntrain_loss = 0.5251, val_f1 = 0.7397', '\\n', 'Epoch 13/30: train_loss = 0.5136,\nval_f1 = 0.7597', '\\n', 'Epoch 14/30: train_loss = 0.5024, val_f1 = 0.7601',\n'\\n', 'Epoch 15/30: train_loss = 0.4911, val_f1 = 0.7800', '\\n', 'Epoch 16/30:\ntrain_loss = 0.4797, val_f1 = 0.7901', '\\n', 'Epoch 17/30: train_loss = 0.4682,\nval_f1 = 0.7901', '\\n', 'Epoch 18/30: train_loss = 0.4566, val_f1 = 0.7901',\n'\\n', 'Epoch 19/30: train_loss = 0.4449, val_f1 = 0.7800', '\\n', 'Epoch 20/30:\ntrain_loss = 0.4332, val_f1 = 0.7800', '\\n', 'Epoch 21/30: train_loss = 0.4216,\nval_f1 = 0.8000', '\\n', 'Epoch 22/30: train_loss = 0.4103, val_f1 = 0.8201',\n'\\n', 'Epoch 23/30: train_loss = 0.3992, val_f1 = 0.8301', '\\n', 'Epoch 24/30:\ntrain_loss = 0.3882, val_f1 = 0.8301', '\\n', 'Epoch 25/30: train_loss = 0.3769,\nval_f1 = 0.8500', '\\n', 'Epoch 26/30: train_loss = 0.3658, val_f1 = 0.8601',\n'\\n', 'Epoch 27/30: train_loss = 0.3549, val_f1 = 0.8700', '\\n', 'Epoch 28/30:\ntrain_loss = 0.3445, val_f1 = 0.8800', '\\n', 'Epoch 29/30: train_loss = 0.3344,\nval_f1 = 0.8900', '\\n', 'Epoch 30/30: train_loss = 0.3246, val_f1 = 0.8900',\n'\\n', 'Execution time: a second seconds (time limit is an hour).']", "['Using device: cpu', '\\n', 'Features 8, Epoch 1/5: train_loss = 0.6763, val_f1\n= 0.5586', '\\n', 'Features 8, Epoch 2/5: train_loss = 0.6624, val_f1 = 0.6473',\n'\\n', 'Features 8, Epoch 3/5: train_loss = 0.6509, val_f1 = 0.6982', '\\n',\n'Features 8, Epoch 4/5: train_loss = 0.6407, val_f1 = 0.7191', '\\n', 'Features\n8, Epoch 5/5: train_loss = 0.6316, val_f1 = 0.7197', '\\n', 'Features 8, Epoch\n1/10: train_loss = 0.7133, val_f1 = 0.5264', '\\n', 'Features 8, Epoch 2/10:\ntrain_loss = 0.6935, val_f1 = 0.6000', '\\n', 'Features 8, Epoch 3/10: train_loss\n= 0.6791, val_f1 = 0.5868', '\\n', 'Features 8, Epoch 4/10: train_loss = 0.6677,\nval_f1 = 0.5976', '\\n', 'Features 8, Epoch 5/10: train_loss = 0.6576, val_f1 =\n0.6092', '\\n', 'Features 8, Epoch 6/10: train_loss = 0.6487, val_f1 = 0.6283',\n'\\n', 'Features 8, Epoch 7/10: train_loss = 0.6412, val_f1 = 0.6790', '\\n',\n'Features 8, Epoch 8/10: train_loss = 0.6348, val_f1 = 0.6796', '\\n', 'Features\n8, Epoch 9/10: train_loss = 0.6291, val_f1 = 0.6800', '\\n', 'Features 8, Epoch\n10/10: train_loss = 0.6236, val_f1 = 0.6800', '\\n', 'Features 8, Epoch 1/20:\ntrain_loss = 0.7448, val_f1 = 0.5083', '\\n', 'Features 8, Epoch 2/20: train_loss\n= 0.7106, val_f1 = 0.5334', '\\n', 'Features 8, Epoch 3/20: train_loss = 0.6897,\nval_f1 = 0.6195', '\\n', 'Features 8, Epoch 4/20: train_loss = 0.6784, val_f1 =\n0.5852', '\\n', 'Features 8, Epoch 5/20: train_loss = 0.6714, val_f1 = 0.5335',\n'\\n', 'Features 8, Epoch 6/20: train_loss = 0.6651, val_f1 = 0.5575', '\\n',\n'Features 8, Epoch 7/20: train_loss = 0.6585, val_f1 = 0.6256', '\\n', 'Features\n8, Epoch 8/20: train_loss = 0.6515, val_f1 = 0.6070', '\\n', 'Features 8, Epoch\n9/20: train_loss = 0.6444, val_f1 = 0.6092', '\\n', 'Features 8, Epoch 10/20:\ntrain_loss = 0.6378, val_f1 = 0.6101', '\\n', 'Features 8, Epoch 11/20:\ntrain_loss = 0.6321, val_f1 = 0.6493', '\\n', 'Features 8, Epoch 12/20:\ntrain_loss = 0.6271, val_f1 = 0.6781', '\\n', 'Features 8, Epoch 13/20:\ntrain_loss = 0.6228, val_f1 = 0.6848', '\\n', 'Features 8, Epoch 14/20:\ntrain_loss = 0.6187, val_f1 = 0.6829', '\\n', 'Features 8, Epoch 15/20:\ntrain_loss = 0.6145, val_f1 = 0.6829', '\\n', 'Features 8, Epoch 16/20:\ntrain_loss = 0.6099, val_f1 = 0.6941', '\\n', 'Features 8, Epoch 17/20:\ntrain_loss = 0.6049, val_f1 = 0.6941', '\\n', 'Features 8, Epoch 18/20:\ntrain_loss = 0.5999, val_f1 = 0.6941', '\\n', 'Features 8, Epoch 19/20:\ntrain_loss = 0.5949, val_f1 = 0.7051', '\\n', 'Features 8, Epoch 20/20:\ntrain_loss = 0.5902, val_f1 = 0.7481', '\\n', 'Features 8, Epoch 1/30: train_loss\n= 0.7147, val_f1 = 0.5698', '\\n', 'Features 8, Epoch 2/30: train_loss = 0.6920,\nval_f1 = 0.6092', '\\n', 'Features 8, Epoch 3/30: train_loss = 0.6734, val_f1 =\n0.6146', '\\n', 'Features 8, Epoch 4/30: train_loss = 0.6579, val_f1 = 0.6177',\n'\\n', 'Features 8, Epoch 5/30: train_loss = 0.6451, val_f1 = 0.6188', '\\n',\n'Features 8, Epoch 6/30: train_loss = 0.6344, val_f1 = 0.6292', '\\n', 'Features\n8, Epoch 7/30: train_loss = 0.6254, val_f1 = 0.6493', '\\n', 'Features 8, Epoch\n8/30: train_loss = 0.6176, val_f1 = 0.6493', '\\n', 'Features 8, Epoch 9/30:\ntrain_loss = 0.6105, val_f1 = 0.6790', '\\n', 'Features 8, Epoch 10/30:\ntrain_loss = 0.6039, val_f1 = 0.6893', '\\n', 'Features 8, Epoch 11/30:\ntrain_loss = 0.5975, val_f1 = 0.6886', '\\n', 'Features 8, Epoch 12/30:\ntrain_loss = 0.5913, val_f1 = 0.7183', '\\n', 'Features 8, Epoch 13/30:\ntrain_loss = 0.5854, val_f1 = 0.7279', '\\n', 'Features 8, Epoch 14/30:\ntrain_loss = 0.5796, val_f1 = 0.7384', '\\n', 'Features 8, Epoch 15/30:\ntrain_loss = 0.5738, val_f1 = 0.7489', '\\n', 'Features 8, Epoch 16/30:\ntrain_loss = 0.5682, val_f1 = 0.7288', '\\n', 'Features 8, Epoch 17/30:\ntrain_loss = 0.5626, val_f1 = 0.7495', '\\n', 'Features 8, Epoch 18/30:\ntrain_loss = 0.5567, val_f1 = 0.7495', '\\n', 'Features 8, Epoch 19/30:\ntrain_loss = 0.5507, val_f1 = 0.7495', '\\n', 'Features 8, Epoch 20/30:\ntrain_loss = 0.5446, val_f1 = 0.7597', '\\n', 'Features 8, Epoch 21/30:\ntrain_loss = 0.5386, val_f1 = 0.7695', '\\n', 'Features 8, Epoch 22/30:\ntrain_loss = 0.5325, val_f1 = 0.7793', '\\n', 'Features 8, Epoch 23/30:\ntrain_loss = 0.5262, val_f1 = 0.7787', '\\n', 'Features 8, Epoch 24/30:\ntrain_loss = 0.5198, val_f1 = 0.7890', '\\n', 'Features 8, Epoch 25/30:\ntrain_loss = 0.5135, val_f1 = 0.7988', '\\n', 'Features 8, Epoch 26/30:\ntrain_loss = 0.5073, val_f1 = 0.7884', '\\n', 'Features 8, Epoch 27/30:\ntrain_loss = 0.5010, val_f1 = 0.7981', '\\n', 'Features 8, Epoch 28/30:\ntrain_loss = 0.4948, val_f1 = 0.8085', '\\n', 'Features 8, Epoch 29/30:\ntrain_loss = 0.4884, val_f1 = 0.8085', '\\n', 'Features 8, Epoch 30/30:\ntrain_loss = 0.4819, val_f1 = 0.8085', '\\n', 'Features 16, Epoch 1/5: train_loss\n= 0.7387, val_f1 = 0.5209', '\\n', 'Features 16, Epoch 2/5: train_loss = 0.7025,\nval_f1 = 0.5139', '\\n', 'Features 16, Epoch 3/5: train_loss = 0.6737, val_f1 =\n0.5510', '\\n', 'Features 16, Epoch 4/5: train_loss = 0.6500, val_f1 = 0.5802',\n'\\n', 'Features 16, Epoch 5/5: train_loss = 0.6300, val_f1 = 0.6326', '\\n',\n'Features 16, Epoch 1/10: train_loss = 0.6859, val_f1 = 0.5031', '\\n', 'Features\n16, Epoch 2/10: train_loss = 0.6643, val_f1 = 0.5279', '\\n', 'Features 16, Epoch\n3/10: train_loss = 0.6470, val_f1 = 0.5812', '\\n', 'Features 16, Epoch 4/10:\ntrain_loss = 0.6327, val_f1 = 0.5812', '\\n', 'Features 16, Epoch 5/10:\ntrain_loss = 0.6201, val_f1 = 0.5959', '\\n', 'Features 16, Epoch 6/10:\ntrain_loss = 0.6088, val_f1 = 0.6023', '\\n', 'Features 16, Epoch 7/10:\ntrain_loss = 0.5985, val_f1 = 0.6562', '\\n', 'Features 16, Epoch 8/10:\ntrain_loss = 0.5886, val_f1 = 0.6690', '\\n', 'Features 16, Epoch 9/10:\ntrain_loss = 0.5787, val_f1 = 0.6971', '\\n', 'Features 16, Epoch 10/10:\ntrain_loss = 0.5688, val_f1 = 0.7229', '\\n', 'Features 16, Epoch 1/20:\ntrain_loss = 0.7089, val_f1 = 0.5470', '\\n', 'Features 16, Epoch 2/20:\ntrain_loss = 0.6675, val_f1 = 0.6408', '\\n', 'Features 16, Epoch 3/20:\ntrain_loss = 0.6461, val_f1 = 0.6277', '\\n', 'Features 16, Epoch 4/20:\ntrain_loss = 0.6351, val_f1 = 0.6358', '\\n', 'Features 16, Epoch 5/20:\ntrain_loss = 0.6256, val_f1 = 0.6408', '\\n', 'Features 16, Epoch 6/20:\ntrain_loss = 0.6145, val_f1 = 0.6408', '\\n', 'Features 16, Epoch 7/20:\ntrain_loss = 0.6028, val_f1 = 0.6298', '\\n', 'Features 16, Epoch 8/20:\ntrain_loss = 0.5920, val_f1 = 0.6562', '\\n', 'Features 16, Epoch 9/20:\ntrain_loss = 0.5824, val_f1 = 0.6881', '\\n', 'Features 16, Epoch 10/20:\ntrain_loss = 0.5746, val_f1 = 0.6792', '\\n', 'Features 16, Epoch 11/20:\ntrain_loss = 0.5679, val_f1 = 0.6792', '\\n', 'Features 16, Epoch 12/20:\ntrain_loss = 0.5614, val_f1 = 0.6909', '\\n', 'Features 16, Epoch 13/20:\ntrain_loss = 0.5546, val_f1 = 0.6909', '\\n', 'Features 16, Epoch 14/20:\ntrain_loss = 0.5474, val_f1 = 0.6999', '\\n', 'Features 16, Epoch 15/20:\ntrain_loss = 0.5400, val_f1 = 0.6999', '\\n', 'Features 16, Epoch 16/20:\ntrain_loss = 0.5327, val_f1 = 0.7089', '\\n', 'Features 16, Epoch 17/20:\ntrain_loss = 0.5257, val_f1 = 0.7089', '\\n', 'Features 16, Epoch 18/20:\ntrain_loss = 0.5193, val_f1 = 0.7089', '\\n', 'Features 16, Epoch 19/20:\ntrain_loss = 0.5129, val_f1 = 0.7089', '\\n', 'Features 16, Epoch 20/20:\ntrain_loss = 0.5064, val_f1 = 0.7206', '\\n', 'Features 16, Epoch 1/30:\ntrain_loss = 0.8097, val_f1 = 0.4842', '\\n', 'Features 16, Epoch 2/30:\ntrain_loss = 0.7513, val_f1 = 0.4881', '\\n', 'Features 16, Epoch 3/30:\ntrain_loss = 0.7102, val_f1 = 0.5061', '\\n', 'Features 16, Epoch 4/30:\ntrain_loss = 0.6821, val_f1 = 0.5487', '\\n', 'Features 16, Epoch 5/30:\ntrain_loss = 0.6614, val_f1 = 0.5836', '\\n', 'Features 16, Epoch 6/30:\ntrain_loss = 0.6449, val_f1 = 0.6391', '\\n', 'Features 16, Epoch 7/30:\ntrain_loss = 0.6299, val_f1 = 0.6263', '\\n', 'Features 16, Epoch 8/30:\ntrain_loss = 0.6162, val_f1 = 0.6431', '\\n', 'Features 16, Epoch 9/30:\ntrain_loss = 0.6037, val_f1 = 0.6244', '\\n', 'Features 16, Epoch 10/30:\ntrain_loss = 0.5929, val_f1 = 0.6244', '\\n', 'Features 16, Epoch 11/30:\ntrain_loss = 0.5836, val_f1 = 0.6244', '\\n', 'Features 16, Epoch 12/30:\ntrain_loss = 0.5758, val_f1 = 0.6381', '\\n', 'Features 16, Epoch 13/30:\ntrain_loss = 0.5689, val_f1 = 0.6465', '\\n', 'Features 16, Epoch 14/30:\ntrain_loss = 0.5623, val_f1 = 0.6465', '\\n', 'Features 16, Epoch 15/30:\ntrain_loss = 0.5558, val_f1 = 0.6820', '\\n', 'Features 16, Epoch 16/30:\ntrain_loss = 0.5492, val_f1 = 0.6864', '\\n', 'Features 16, Epoch 17/30:\ntrain_loss = 0.5424, val_f1 = 0.6992', '\\n', 'Features 16, Epoch 18/30:\ntrain_loss = 0.5355, val_f1 = 0.7028', '\\n', 'Features 16, Epoch 19/30:\ntrain_loss = 0.5286, val_f1 = 0.6971', '\\n', 'Features 16, Epoch 20/30:\ntrain_loss = 0.5219, val_f1 = 0.7089', '\\n', 'Features 16, Epoch 21/30:\ntrain_loss = 0.5157, val_f1 = 0.7321', '\\n', 'Features 16, Epoch 22/30:\ntrain_loss = 0.5094, val_f1 = 0.7434', '\\n', 'Features 16, Epoch 23/30:\ntrain_loss = 0.5031, val_f1 = 0.7546', '\\n', 'Features 16, Epoch 24/30:\ntrain_loss = 0.4966, val_f1 = 0.7546', '\\n', 'Features 16, Epoch 25/30:\ntrain_loss = 0.4900, val_f1 = 0.7657', '\\n', 'Features 16, Epoch 26/30:\ntrain_loss = 0.4833, val_f1 = 0.7861', '\\n', 'Features 16, Epoch 27/30:\ntrain_loss = 0.4765, val_f1 = 0.7969', '\\n', 'Features 16, Epoch 28/30:\ntrain_loss = 0.4700, val_f1 = 0.7969', '\\n', 'Features 16, Epoch 29/30:\ntrain_loss = 0.4636, val_f1 = 0.7969', '\\n', 'Features 16, Epoch 30/30:\ntrain_loss = 0.4572, val_f1 = 0.8077', '\\n', 'Features 32, Epoch 1/5: train_loss\n= 0.7746, val_f1 = 0.5567', '\\n', 'Features 32, Epoch 2/5: train_loss = 0.7119,\nval_f1 = 0.5820', '\\n', 'Features 32, Epoch 3/5: train_loss = 0.6721, val_f1 =\n0.5965', '\\n', 'Features 32, Epoch 4/5: train_loss = 0.6442, val_f1 = 0.5965',\n'\\n', 'Features 32, Epoch 5/5: train_loss = 0.6207, val_f1 = 0.6040', '\\n',\n'Features 32, Epoch 1/10: train_loss = 0.8102, val_f1 = 0.4888', '\\n', 'Features\n32, Epoch 2/10: train_loss = 0.7306, val_f1 = 0.5890', '\\n', 'Features 32, Epoch\n3/10: train_loss = 0.6764, val_f1 = 0.5491', '\\n', 'Features 32, Epoch 4/10:\ntrain_loss = 0.6401, val_f1 = 0.5273', '\\n', 'Features 32, Epoch 5/10:\ntrain_loss = 0.6128, val_f1 = 0.5522', '\\n', 'Features 32, Epoch 6/10:\ntrain_loss = 0.5888, val_f1 = 0.6125', '\\n', 'Features 32, Epoch 7/10:\ntrain_loss = 0.5657, val_f1 = 0.6432', '\\n', 'Features 32, Epoch 8/10:\ntrain_loss = 0.5444, val_f1 = 0.7135', '\\n', 'Features 32, Epoch 9/10:\ntrain_loss = 0.5251, val_f1 = 0.7339', '\\n', 'Features 32, Epoch 10/10:\ntrain_loss = 0.5078, val_f1 = 0.7629', '\\n', 'Features 32, Epoch 1/20:\ntrain_loss = 0.7633, val_f1 = 0.5267', '\\n', 'Features 32, Epoch 2/20:\ntrain_loss = 0.6959, val_f1 = 0.5742', '\\n', 'Features 32, Epoch 3/20:\ntrain_loss = 0.6537, val_f1 = 0.5728', '\\n', 'Features 32, Epoch 4/20:\ntrain_loss = 0.6226, val_f1 = 0.6352', '\\n', 'Features 32, Epoch 5/20:\ntrain_loss = 0.5943, val_f1 = 0.6498', '\\n', 'Features 32, Epoch 6/20:\ntrain_loss = 0.5670, val_f1 = 0.6779', '\\n', 'Features 32, Epoch 7/20:\ntrain_loss = 0.5420, val_f1 = 0.7215', '\\n', 'Features 32, Epoch 8/20:\ntrain_loss = 0.5198, val_f1 = 0.7929', '\\n', 'Features 32, Epoch 9/20:\ntrain_loss = 0.5003, val_f1 = 0.8058', '\\n', 'Features 32, Epoch 10/20:\ntrain_loss = 0.4824, val_f1 = 0.8167', '\\n', 'Features 32, Epoch 11/20:\ntrain_loss = 0.4651, val_f1 = 0.8382', '\\n', 'Features 32, Epoch 12/20:\ntrain_loss = 0.4479, val_f1 = 0.8382', '\\n', 'Features 32, Epoch 13/20:\ntrain_loss = 0.4308, val_f1 = 0.8488', '\\n', 'Features 32, Epoch 14/20:\ntrain_loss = 0.4138, val_f1 = 0.8681', '\\n', 'Features 32, Epoch 15/20:\ntrain_loss = 0.3974, val_f1 = 0.8681', '\\n', 'Features 32, Epoch 16/20:\ntrain_loss = 0.3817, val_f1 = 0.8681', '\\n', 'Features 32, Epoch 17/20:\ntrain_loss = 0.3665, val_f1 = 0.8787', '\\n', 'Features 32, Epoch 18/20:\ntrain_loss = 0.3519, val_f1 = 0.8787', '\\n', 'Features 32, Epoch 19/20:\ntrain_loss = 0.3375, val_f1 = 0.8787', '\\n', 'Features 32, Epoch 20/20:\ntrain_loss = 0.3232, val_f1 = 0.8794', '\\n', 'Features 32, Epoch 1/30:\ntrain_loss = 0.7061, val_f1 = 0.5440', '\\n', 'Features 32, Epoch 2/30:\ntrain_loss = 0.6516, val_f1 = 0.6580', '\\n', 'Features 32, Epoch 3/30:\ntrain_loss = 0.6084, val_f1 = 0.7223', '\\n', 'Features 32, Epoch 4/30:\ntrain_loss = 0.5727, val_f1 = 0.7394', '\\n', 'Features 32, Epoch 5/30:\ntrain_loss = 0.5422, val_f1 = 0.7644', '\\n', 'Features 32, Epoch 6/30:\ntrain_loss = 0.5147, val_f1 = 0.7908', '\\n', 'Features 32, Epoch 7/30:\ntrain_loss = 0.4894, val_f1 = 0.7947', '\\n', 'Features 32, Epoch 8/30:\ntrain_loss = 0.4658, val_f1 = 0.7964', '\\n', 'Features 32, Epoch 9/30:\ntrain_loss = 0.4436, val_f1 = 0.8286', '\\n', 'Features 32, Epoch 10/30:\ntrain_loss = 0.4226, val_f1 = 0.8392', '\\n', 'Features 32, Epoch 11/30:\ntrain_loss = 0.4027, val_f1 = 0.8392', '\\n', 'Features 32, Epoch 12/30:\ntrain_loss = 0.3846, val_f1 = 0.8392', '\\n', 'Features 32, Epoch 13/30:\ntrain_loss = 0.3677, val_f1 = 0.8496', '\\n', 'Features 32, Epoch 14/30:\ntrain_loss = 0.3516, val_f1 = 0.8600', '\\n', 'Features 32, Epoch 15/30:\ntrain_loss = 0.3360, val_f1 = 0.8600', '\\n', 'Features 32, Epoch 16/30:\ntrain_loss = 0.3211, val_f1 = 0.8805', '\\n', 'Features 32, Epoch 17/30:\ntrain_loss = 0.3070, val_f1 = 0.8907', '\\n', 'Features 32, Epoch 18/30:\ntrain_loss = 0.2933, val_f1 = 0.8907', '\\n', 'Features 32, Epoch 19/30:\ntrain_loss = 0.2799, val_f1 = 0.9105', '\\n', 'Features 32, Epoch 20/30:\ntrain_loss = 0.2669, val_f1 = 0.9105', '\\n', 'Features 32, Epoch 21/30:\ntrain_loss = 0.2542, val_f1 = 0.9302', '\\n', 'Features 32, Epoch 22/30:\ntrain_loss = 0.2416, val_f1 = 0.9499', '\\n', 'Features 32, Epoch 23/30:\ntrain_loss = 0.2292, val_f1 = 0.9600', '\\n', 'Features 32, Epoch 24/30:\ntrain_loss = 0.2172, val_f1 = 0.9600', '\\n', 'Features 32, Epoch 25/30:\ntrain_loss = 0.2056, val_f1 = 0.9600', '\\n', 'Features 32, Epoch 26/30:\ntrain_loss = 0.1946, val_f1 = 0.9600', '\\n', 'Features 32, Epoch 27/30:\ntrain_loss = 0.1839, val_f1 = 0.9600', '\\n', 'Features 32, Epoch 28/30:\ntrain_loss = 0.1736, val_f1 = 0.9701', '\\n', 'Features 32, Epoch 29/30:\ntrain_loss = 0.1635, val_f1 = 0.9701', '\\n', 'Features 32, Epoch 30/30:\ntrain_loss = 0.1540, val_f1 = 0.9701', '\\n', 'Features 64, Epoch 1/5: train_loss\n= 0.8167, val_f1 = 0.6542', '\\n', 'Features 64, Epoch 2/5: train_loss = 0.6382,\nval_f1 = 0.7960', '\\n', 'Features 64, Epoch 3/5: train_loss = 0.5378, val_f1 =\n0.7783', '\\n', 'Features 64, Epoch 4/5: train_loss = 0.4872, val_f1 = 0.8183',\n'\\n', 'Features 64, Epoch 5/5: train_loss = 0.4571, val_f1 = 0.7876', '\\n',\n'Features 64, Epoch 1/10: train_loss = 0.7815, val_f1 = 0.5864', '\\n', 'Features\n64, Epoch 2/10: train_loss = 0.6651, val_f1 = 0.6686', '\\n', 'Features 64, Epoch\n3/10: train_loss = 0.5870, val_f1 = 0.7150', '\\n', 'Features 64, Epoch 4/10:\ntrain_loss = 0.5310, val_f1 = 0.7715', '\\n', 'Features 64, Epoch 5/10:\ntrain_loss = 0.4865, val_f1 = 0.7943', '\\n', 'Features 64, Epoch 6/10:\ntrain_loss = 0.4497, val_f1 = 0.7976', '\\n', 'Features 64, Epoch 7/10:\ntrain_loss = 0.4190, val_f1 = 0.8178', '\\n', 'Features 64, Epoch 8/10:\ntrain_loss = 0.3930, val_f1 = 0.8391', '\\n', 'Features 64, Epoch 9/10:\ntrain_loss = 0.3703, val_f1 = 0.8391', '\\n', 'Features 64, Epoch 10/10:\ntrain_loss = 0.3492, val_f1 = 0.8496', '\\n', 'Features 64, Epoch 1/20:\ntrain_loss = 0.8468, val_f1 = 0.5374', '\\n', 'Features 64, Epoch 2/20:\ntrain_loss = 0.7023, val_f1 = 0.6533', '\\n', 'Features 64, Epoch 3/20:\ntrain_loss = 0.6032, val_f1 = 0.7599', '\\n', 'Features 64, Epoch 4/20:\ntrain_loss = 0.5393, val_f1 = 0.7571', '\\n', 'Features 64, Epoch 5/20:\ntrain_loss = 0.4971, val_f1 = 0.7788', '\\n', 'Features 64, Epoch 6/20:\ntrain_loss = 0.4637, val_f1 = 0.8000', '\\n', 'Features 64, Epoch 7/20:\ntrain_loss = 0.4353, val_f1 = 0.7894', '\\n', 'Features 64, Epoch 8/20:\ntrain_loss = 0.4106, val_f1 = 0.7989', '\\n', 'Features 64, Epoch 9/20:\ntrain_loss = 0.3892, val_f1 = 0.7989', '\\n', 'Features 64, Epoch 10/20:\ntrain_loss = 0.3699, val_f1 = 0.8070', '\\n', 'Features 64, Epoch 11/20:\ntrain_loss = 0.3519, val_f1 = 0.8164', '\\n', 'Features 64, Epoch 12/20:\ntrain_loss = 0.3348, val_f1 = 0.8381', '\\n', 'Features 64, Epoch 13/20:\ntrain_loss = 0.3178, val_f1 = 0.8697', '\\n', 'Features 64, Epoch 14/20:\ntrain_loss = 0.3010, val_f1 = 0.8800', '\\n', 'Features 64, Epoch 15/20:\ntrain_loss = 0.2849, val_f1 = 0.8903', '\\n', 'Features 64, Epoch 16/20:\ntrain_loss = 0.2697, val_f1 = 0.8903', '\\n', 'Features 64, Epoch 17/20:\ntrain_loss = 0.2557, val_f1 = 0.9204', '\\n', 'Features 64, Epoch 18/20:\ntrain_loss = 0.2425, val_f1 = 0.9305', '\\n', 'Features 64, Epoch 19/20:\ntrain_loss = 0.2297, val_f1 = 0.9305', '\\n', 'Features 64, Epoch 20/20:\ntrain_loss = 0.2175, val_f1 = 0.9204', '\\n', 'Features 64, Epoch 1/30:\ntrain_loss = 0.7881, val_f1 = 0.6241', '\\n', 'Features 64, Epoch 2/30:\ntrain_loss = 0.6387, val_f1 = 0.7532', '\\n', 'Features 64, Epoch 3/30:\ntrain_loss = 0.5377, val_f1 = 0.7943', '\\n', 'Features 64, Epoch 4/30:\ntrain_loss = 0.4693, val_f1 = 0.8273', '\\n', 'Features 64, Epoch 5/30:\ntrain_loss = 0.4232, val_f1 = 0.8295', '\\n', 'Features 64, Epoch 6/30:\ntrain_loss = 0.3902, val_f1 = 0.8487', '\\n', 'Features 64, Epoch 7/30:\ntrain_loss = 0.3636, val_f1 = 0.8487', '\\n', 'Features 64, Epoch 8/30:\ntrain_loss = 0.3401, val_f1 = 0.8391', '\\n', 'Features 64, Epoch 9/30:\ntrain_loss = 0.3189, val_f1 = 0.8381', '\\n', 'Features 64, Epoch 10/30:\ntrain_loss = 0.2991, val_f1 = 0.8592', '\\n', 'Features 64, Epoch 11/30:\ntrain_loss = 0.2804, val_f1 = 0.8697', '\\n', 'Features 64, Epoch 12/30:\ntrain_loss = 0.2626, val_f1 = 0.8897', '\\n', 'Features 64, Epoch 13/30:\ntrain_loss = 0.2457, val_f1 = 0.9102', '\\n', 'Features 64, Epoch 14/30:\ntrain_loss = 0.2301, val_f1 = 0.9102', '\\n', 'Features 64, Epoch 15/30:\ntrain_loss = 0.2155, val_f1 = 0.9305', '\\n', 'Features 64, Epoch 16/30:\ntrain_loss = 0.2020, val_f1 = 0.9305', '\\n', 'Features 64, Epoch 17/30:\ntrain_loss = 0.1891, val_f1 = 0.9305', '\\n', 'Features 64, Epoch 18/30:\ntrain_loss = 0.1771, val_f1 = 0.9403', '\\n', 'Features 64, Epoch 19/30:\ntrain_loss = 0.1658, val_f1 = 0.9699', '\\n', 'Features 64, Epoch 20/30:\ntrain_loss = 0.1553, val_f1 = 0.9600', '\\n', 'Features 64, Epoch 21/30:\ntrain_loss = 0.1455, val_f1 = 0.9699', '\\n', 'Features 64, Epoch 22/30:\ntrain_loss = 0.1365, val_f1 = 0.9699', '\\n', 'Features 64, Epoch 23/30:\ntrain_loss = 0.1281, val_f1 = 0.9699', '\\n', 'Features 64, Epoch 24/30:\ntrain_loss = 0.1201, val_f1 = 0.9800', '\\n', 'Features 64, Epoch 25/30:\ntrain_loss = 0.1125, val_f1 = 0.9800', '\\n', 'Features 64, Epoch 26/30:\ntrain_loss = 0.1052, val_f1 = 0.9900', '\\n', 'Features 64, Epoch 27/30:\ntrain_loss = 0.0983, val_f1 = 0.9900', '\\n', 'Features 64, Epoch 28/30:\ntrain_loss = 0.0920, val_f1 = 0.9900', '\\n', 'Features 64, Epoch 29/30:\ntrain_loss = 0.0863, val_f1 = 0.9900', '\\n', 'Features 64, Epoch 30/30:\ntrain_loss = 0.0809, val_f1 = 1.0000', '\\n', 'Execution time: a second seconds\n(time limit is an hour).']", "['Using device: cpu', '\\n', 'Traceback (most recent call last):\\n  File\n\"runfile.py\", line 139, in <module>\\n\nexperiment_data[\"edge_connectivity_ablation\"][connectivity][\"losses\"][\\n\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^\\nKeyError:\n\\'sparse\\'\\n', 'Execution time: a second seconds (time limit is an hour).']", "['Using device: cpu', '\\n', 'Epoch 1/20, LR 0.001: train_loss = 0.7102, val_f1 =\n0.4960', '\\n', 'Epoch 2/20, LR 0.001: train_loss = 0.7065, val_f1 = 0.5087',\n'\\n', 'Epoch 3/20, LR 0.001: train_loss = 0.7029, val_f1 = 0.5249', '\\n', 'Epoch\n4/20, LR 0.001: train_loss = 0.6995, val_f1 = 0.5282', '\\n', 'Epoch 5/20, LR\n0.001: train_loss = 0.6963, val_f1 = 0.5194', '\\n', 'Epoch 6/20, LR 0.001:\ntrain_loss = 0.6932, val_f1 = 0.5194', '\\n', 'Epoch 7/20, LR 0.001: train_loss =\n0.6902, val_f1 = 0.5335', '\\n', 'Epoch 8/20, LR 0.001: train_loss = 0.6874,\nval_f1 = 0.5245', '\\n', 'Epoch 9/20, LR 0.001: train_loss = 0.6847, val_f1 =\n0.5372', '\\n', 'Epoch 10/20, LR 0.001: train_loss = 0.6820, val_f1 = 0.5480',\n'\\n', 'Epoch 11/20, LR 0.001: train_loss = 0.6795, val_f1 = 0.5586', '\\n',\n'Epoch 12/20, LR 0.001: train_loss = 0.6771, val_f1 = 0.5586', '\\n', 'Epoch\n13/20, LR 0.001: train_loss = 0.6747, val_f1 = 0.5691', '\\n', 'Epoch 14/20, LR\n0.001: train_loss = 0.6724, val_f1 = 0.5795', '\\n', 'Epoch 15/20, LR 0.001:\ntrain_loss = 0.6702, val_f1 = 0.5698', '\\n', 'Epoch 16/20, LR 0.001: train_loss\n= 0.6680, val_f1 = 0.5800', '\\n', 'Epoch 17/20, LR 0.001: train_loss = 0.6659,\nval_f1 = 0.6002', '\\n', 'Epoch 18/20, LR 0.001: train_loss = 0.6638, val_f1 =\n0.6101', '\\n', 'Epoch 19/20, LR 0.001: train_loss = 0.6618, val_f1 = 0.6101',\n'\\n', 'Epoch 20/20, LR 0.001: train_loss = 0.6598, val_f1 = 0.6200', '\\n',\n'Epoch 1/20, LR 0.01: train_loss = 0.7176, val_f1 = 0.5995', '\\n', 'Epoch 2/20,\nLR 0.01: train_loss = 0.6842, val_f1 = 0.5995', '\\n', 'Epoch 3/20, LR 0.01:\ntrain_loss = 0.6594, val_f1 = 0.6283', '\\n', 'Epoch 4/20, LR 0.01: train_loss =\n0.6392, val_f1 = 0.6693', '\\n', 'Epoch 5/20, LR 0.01: train_loss = 0.6219,\nval_f1 = 0.6698', '\\n', 'Epoch 6/20, LR 0.01: train_loss = 0.6066, val_f1 =\n0.7101', '\\n', 'Epoch 7/20, LR 0.01: train_loss = 0.5928, val_f1 = 0.7201',\n'\\n', 'Epoch 8/20, LR 0.01: train_loss = 0.5803, val_f1 = 0.7201', '\\n', 'Epoch\n9/20, LR 0.01: train_loss = 0.5689, val_f1 = 0.7301', '\\n', 'Epoch 10/20, LR\n0.01: train_loss = 0.5582, val_f1 = 0.7301', '\\n', 'Epoch 11/20, LR 0.01:\ntrain_loss = 0.5477, val_f1 = 0.7400', '\\n', 'Epoch 12/20, LR 0.01: train_loss =\n0.5375, val_f1 = 0.7400', '\\n', 'Epoch 13/20, LR 0.01: train_loss = 0.5271,\nval_f1 = 0.7501', '\\n', 'Epoch 14/20, LR 0.01: train_loss = 0.5167, val_f1 =\n0.7600', '\\n', 'Epoch 15/20, LR 0.01: train_loss = 0.5062, val_f1 = 0.7800',\n'\\n', 'Epoch 16/20, LR 0.01: train_loss = 0.4958, val_f1 = 0.7899', '\\n', 'Epoch\n17/20, LR 0.01: train_loss = 0.4853, val_f1 = 0.7899', '\\n', 'Epoch 18/20, LR\n0.01: train_loss = 0.4751, val_f1 = 0.7899', '\\n', 'Epoch 19/20, LR 0.01:\ntrain_loss = 0.4649, val_f1 = 0.7899', '\\n', 'Epoch 20/20, LR 0.01: train_loss =\n0.4548, val_f1 = 0.7800', '\\n', 'Epoch 1/20, LR 0.1: train_loss = 0.7794, val_f1\n= 0.3114', '\\n', 'Epoch 2/20, LR 0.1: train_loss = 0.8972, val_f1 = 0.5929',\n'\\n', 'Epoch 3/20, LR 0.1: train_loss = 0.6452, val_f1 = 0.6163', '\\n', 'Epoch\n4/20, LR 0.1: train_loss = 0.6350, val_f1 = 0.5796', '\\n', 'Epoch 5/20, LR 0.1:\ntrain_loss = 0.6555, val_f1 = 0.6280', '\\n', 'Epoch 6/20, LR 0.1: train_loss =\n0.6193, val_f1 = 0.6579', '\\n', 'Epoch 7/20, LR 0.1: train_loss = 0.5705, val_f1\n= 0.7191', '\\n', 'Epoch 8/20, LR 0.1: train_loss = 0.5518, val_f1 = 0.7255',\n'\\n', 'Epoch 9/20, LR 0.1: train_loss = 0.5496, val_f1 = 0.7255', '\\n', 'Epoch\n10/20, LR 0.1: train_loss = 0.5240, val_f1 = 0.7592', '\\n', 'Epoch 11/20, LR\n0.1: train_loss = 0.4903, val_f1 = 0.7695', '\\n', 'Epoch 12/20, LR 0.1:\ntrain_loss = 0.4711, val_f1 = 0.7682', '\\n', 'Epoch 13/20, LR 0.1: train_loss =\n0.4534, val_f1 = 0.7896', '\\n', 'Epoch 14/20, LR 0.1: train_loss = 0.4206,\nval_f1 = 0.8299', '\\n', 'Epoch 15/20, LR 0.1: train_loss = 0.3853, val_f1 =\n0.8401', '\\n', 'Epoch 16/20, LR 0.1: train_loss = 0.3586, val_f1 = 0.8500',\n'\\n', 'Epoch 17/20, LR 0.1: train_loss = 0.3304, val_f1 = 0.8699', '\\n', 'Epoch\n18/20, LR 0.1: train_loss = 0.3025, val_f1 = 0.8697', '\\n', 'Epoch 19/20, LR\n0.1: train_loss = 0.2806, val_f1 = 0.8697', '\\n', 'Epoch 20/20, LR 0.1:\ntrain_loss = 0.2534, val_f1 = 0.9100', '\\n', 'Epoch 1/20, LR 0.5: train_loss =\n0.6834, val_f1 = 0.5418', '\\n', 'Epoch 2/20, LR 0.5: train_loss = 3.0703, val_f1\n= 0.3777', '\\n', 'Epoch 3/20, LR 0.5: train_loss = 13.6322, val_f1 = 0.5000',\n'\\n', 'Epoch 4/20, LR 0.5: train_loss = 6.0413, val_f1 = 0.6188', '\\n', 'Epoch\n5/20, LR 0.5: train_loss = 2.0171, val_f1 = 0.6421', '\\n', 'Epoch 6/20, LR 0.5:\ntrain_loss = 1.3109, val_f1 = 0.5775', '\\n', 'Epoch 7/20, LR 0.5: train_loss =\n1.9774, val_f1 = 0.6292', '\\n', 'Epoch 8/20, LR 0.5: train_loss = 1.4277, val_f1\n= 0.6097', '\\n', 'Epoch 9/20, LR 0.5: train_loss = 1.3250, val_f1 = 0.6200',\n'\\n', 'Epoch 10/20, LR 0.5: train_loss = 1.0259, val_f1 = 0.5967', '\\n', 'Epoch\n11/20, LR 0.5: train_loss = 1.0193, val_f1 = 0.6971', '\\n', 'Epoch 12/20, LR\n0.5: train_loss = 0.6547, val_f1 = 0.7597', '\\n', 'Epoch 13/20, LR 0.5:\ntrain_loss = 0.6218, val_f1 = 0.7994', '\\n', 'Epoch 14/20, LR 0.5: train_loss =\n0.6308, val_f1 = 0.7800', '\\n', 'Epoch 15/20, LR 0.5: train_loss = 0.5840,\nval_f1 = 0.8194', '\\n', 'Epoch 16/20, LR 0.5: train_loss = 0.4639, val_f1 =\n0.7901', '\\n', 'Epoch 17/20, LR 0.5: train_loss = 0.3807, val_f1 = 0.8292',\n'\\n', 'Epoch 18/20, LR 0.5: train_loss = 0.3764, val_f1 = 0.8292', '\\n', 'Epoch\n19/20, LR 0.5: train_loss = 0.3845, val_f1 = 0.8198', '\\n', 'Epoch 20/20, LR\n0.5: train_loss = 0.3813, val_f1 = 0.8900', '\\n', 'Execution time: a second\nseconds (time limit is an hour).']", "['Using device: cpu', '\\n', 'Connectivity sparse, Epoch 1/5: train_loss =\n0.8971, val_f1 = 0.4351', '\\n', 'Connectivity sparse, Epoch 2/5: train_loss =\n0.8051, val_f1 = 0.4696', '\\n', 'Connectivity sparse, Epoch 3/5: train_loss =\n0.7377, val_f1 = 0.4990', '\\n', 'Connectivity sparse, Epoch 4/5: train_loss =\n0.6907, val_f1 = 0.5591', '\\n', 'Connectivity sparse, Epoch 5/5: train_loss =\n0.6584, val_f1 = 0.5857', '\\n', 'Connectivity sparse, Epoch 1/10: train_loss =\n0.8139, val_f1 = 0.5138', '\\n', 'Connectivity sparse, Epoch 2/10: train_loss =\n0.7230, val_f1 = 0.6205', '\\n', 'Connectivity sparse, Epoch 3/10: train_loss =\n0.6714, val_f1 = 0.6045', '\\n', 'Connectivity sparse, Epoch 4/10: train_loss =\n0.6498, val_f1 = 0.6260', '\\n', 'Connectivity sparse, Epoch 5/10: train_loss =\n0.6391, val_f1 = 0.6176', '\\n', 'Connectivity sparse, Epoch 6/10: train_loss =\n0.6273, val_f1 = 0.6440', '\\n', 'Connectivity sparse, Epoch 7/10: train_loss =\n0.6129, val_f1 = 0.6550', '\\n', 'Connectivity sparse, Epoch 8/10: train_loss =\n0.5971, val_f1 = 0.6515', '\\n', 'Connectivity sparse, Epoch 9/10: train_loss =\n0.5827, val_f1 = 0.6880', '\\n', 'Connectivity sparse, Epoch 10/10: train_loss =\n0.5706, val_f1 = 0.7102', '\\n', 'Connectivity sparse, Epoch 1/20: train_loss =\n0.8444, val_f1 = 0.4957', '\\n', 'Connectivity sparse, Epoch 2/20: train_loss =\n0.7672, val_f1 = 0.5400', '\\n', 'Connectivity sparse, Epoch 3/20: train_loss =\n0.7107, val_f1 = 0.5903', '\\n', 'Connectivity sparse, Epoch 4/20: train_loss =\n0.6703, val_f1 = 0.5805', '\\n', 'Connectivity sparse, Epoch 5/20: train_loss =\n0.6394, val_f1 = 0.6205', '\\n', 'Connectivity sparse, Epoch 6/20: train_loss =\n0.6144, val_f1 = 0.6502', '\\n', 'Connectivity sparse, Epoch 7/20: train_loss =\n0.5937, val_f1 = 0.6985', '\\n', 'Connectivity sparse, Epoch 8/20: train_loss =\n0.5763, val_f1 = 0.7176', '\\n', 'Connectivity sparse, Epoch 9/20: train_loss =\n0.5608, val_f1 = 0.6851', '\\n', 'Connectivity sparse, Epoch 10/20: train_loss =\n0.5465, val_f1 = 0.7054', '\\n', 'Connectivity sparse, Epoch 11/20: train_loss =\n0.5325, val_f1 = 0.7176', '\\n', 'Connectivity sparse, Epoch 12/20: train_loss =\n0.5189, val_f1 = 0.7081', '\\n', 'Connectivity sparse, Epoch 13/20: train_loss =\n0.5057, val_f1 = 0.7282', '\\n', 'Connectivity sparse, Epoch 14/20: train_loss =\n0.4933, val_f1 = 0.7387', '\\n', 'Connectivity sparse, Epoch 15/20: train_loss =\n0.4816, val_f1 = 0.7291', '\\n', 'Connectivity sparse, Epoch 16/20: train_loss =\n0.4707, val_f1 = 0.6994', '\\n', 'Connectivity sparse, Epoch 17/20: train_loss =\n0.4607, val_f1 = 0.7291', '\\n', 'Connectivity sparse, Epoch 18/20: train_loss =\n0.4514, val_f1 = 0.7483', '\\n', 'Connectivity sparse, Epoch 19/20: train_loss =\n0.4427, val_f1 = 0.7789', '\\n', 'Connectivity sparse, Epoch 20/20: train_loss =\n0.4347, val_f1 = 0.7789', '\\n', 'Connectivity sparse, Epoch 1/30: train_loss =\n0.7627, val_f1 = 0.5336', '\\n', 'Connectivity sparse, Epoch 2/30: train_loss =\n0.7038, val_f1 = 0.6424', '\\n', 'Connectivity sparse, Epoch 3/30: train_loss =\n0.6614, val_f1 = 0.6678', '\\n', 'Connectivity sparse, Epoch 4/30: train_loss =\n0.6296, val_f1 = 0.6773', '\\n', 'Connectivity sparse, Epoch 5/30: train_loss =\n0.6047, val_f1 = 0.7097', '\\n', 'Connectivity sparse, Epoch 6/30: train_loss =\n0.5843, val_f1 = 0.7302', '\\n', 'Connectivity sparse, Epoch 7/30: train_loss =\n0.5672, val_f1 = 0.7203', '\\n', 'Connectivity sparse, Epoch 8/30: train_loss =\n0.5518, val_f1 = 0.7203', '\\n', 'Connectivity sparse, Epoch 9/30: train_loss =\n0.5377, val_f1 = 0.7204', '\\n', 'Connectivity sparse, Epoch 10/30: train_loss =\n0.5246, val_f1 = 0.7104', '\\n', 'Connectivity sparse, Epoch 11/30: train_loss =\n0.5128, val_f1 = 0.7104', '\\n', 'Connectivity sparse, Epoch 12/30: train_loss =\n0.5018, val_f1 = 0.7204', '\\n', 'Connectivity sparse, Epoch 13/30: train_loss =\n0.4913, val_f1 = 0.7203', '\\n', 'Connectivity sparse, Epoch 14/30: train_loss =\n0.4814, val_f1 = 0.7302', '\\n', 'Connectivity sparse, Epoch 15/30: train_loss =\n0.4721, val_f1 = 0.7203', '\\n', 'Connectivity sparse, Epoch 16/30: train_loss =\n0.4632, val_f1 = 0.7302', '\\n', 'Connectivity sparse, Epoch 17/30: train_loss =\n0.4544, val_f1 = 0.7595', '\\n', 'Connectivity sparse, Epoch 18/30: train_loss =\n0.4460, val_f1 = 0.7692', '\\n', 'Connectivity sparse, Epoch 19/30: train_loss =\n0.4377, val_f1 = 0.7387', '\\n', 'Connectivity sparse, Epoch 20/30: train_loss =\n0.4298, val_f1 = 0.7291', '\\n', 'Connectivity sparse, Epoch 21/30: train_loss =\n0.4221, val_f1 = 0.7498', '\\n', 'Connectivity sparse, Epoch 22/30: train_loss =\n0.4146, val_f1 = 0.7600', '\\n', 'Connectivity sparse, Epoch 23/30: train_loss =\n0.4072, val_f1 = 0.7898', '\\n', 'Connectivity sparse, Epoch 24/30: train_loss =\n0.4001, val_f1 = 0.8094', '\\n', 'Connectivity sparse, Epoch 25/30: train_loss =\n0.3932, val_f1 = 0.8196', '\\n', 'Connectivity sparse, Epoch 26/30: train_loss =\n0.3864, val_f1 = 0.8094', '\\n', 'Connectivity sparse, Epoch 27/30: train_loss =\n0.3798, val_f1 = 0.8094', '\\n', 'Connectivity sparse, Epoch 28/30: train_loss =\n0.3732, val_f1 = 0.8294', '\\n', 'Connectivity sparse, Epoch 29/30: train_loss =\n0.3668, val_f1 = 0.8495', '\\n', 'Connectivity sparse, Epoch 30/30: train_loss =\n0.3604, val_f1 = 0.8495', '\\n', 'Connectivity dense, Epoch 1/5: train_loss =\n0.7103, val_f1 = 0.4954', '\\n', 'Connectivity dense, Epoch 2/5: train_loss =\n0.6830, val_f1 = 0.5689', '\\n', 'Connectivity dense, Epoch 3/5: train_loss =\n0.6655, val_f1 = 0.6364', '\\n', 'Connectivity dense, Epoch 4/5: train_loss =\n0.6520, val_f1 = 0.6328', '\\n', 'Connectivity dense, Epoch 5/5: train_loss =\n0.6395, val_f1 = 0.6673', '\\n', 'Connectivity dense, Epoch 1/10: train_loss =\n0.7654, val_f1 = 0.3503', '\\n', 'Connectivity dense, Epoch 2/10: train_loss =\n0.7187, val_f1 = 0.5249', '\\n', 'Connectivity dense, Epoch 3/10: train_loss =\n0.6876, val_f1 = 0.5994', '\\n', 'Connectivity dense, Epoch 4/10: train_loss =\n0.6673, val_f1 = 0.6602', '\\n', 'Connectivity dense, Epoch 5/10: train_loss =\n0.6532, val_f1 = 0.6875', '\\n', 'Connectivity dense, Epoch 6/10: train_loss =\n0.6414, val_f1 = 0.7220', '\\n', 'Connectivity dense, Epoch 7/10: train_loss =\n0.6298, val_f1 = 0.6940', '\\n', 'Connectivity dense, Epoch 8/10: train_loss =\n0.6181, val_f1 = 0.6940', '\\n', 'Connectivity dense, Epoch 9/10: train_loss =\n0.6068, val_f1 = 0.6970', '\\n', 'Connectivity dense, Epoch 10/10: train_loss =\n0.5964, val_f1 = 0.6885', '\\n', 'Connectivity dense, Epoch 1/20: train_loss =\n0.7035, val_f1 = 0.5192', '\\n', 'Connectivity dense, Epoch 2/20: train_loss =\n0.6825, val_f1 = 0.5539', '\\n', 'Connectivity dense, Epoch 3/20: train_loss =\n0.6662, val_f1 = 0.6236', '\\n', 'Connectivity dense, Epoch 4/20: train_loss =\n0.6517, val_f1 = 0.6595', '\\n', 'Connectivity dense, Epoch 5/20: train_loss =\n0.6383, val_f1 = 0.6697', '\\n', 'Connectivity dense, Epoch 6/20: train_loss =\n0.6261, val_f1 = 0.7000', '\\n', 'Connectivity dense, Epoch 7/20: train_loss =\n0.6147, val_f1 = 0.6900', '\\n', 'Connectivity dense, Epoch 8/20: train_loss =\n0.6042, val_f1 = 0.7097', '\\n', 'Connectivity dense, Epoch 9/20: train_loss =\n0.5943, val_f1 = 0.7100', '\\n', 'Connectivity dense, Epoch 10/20: train_loss =\n0.5850, val_f1 = 0.6999', '\\n', 'Connectivity dense, Epoch 11/20: train_loss =\n0.5761, val_f1 = 0.6799', '\\n', 'Connectivity dense, Epoch 12/20: train_loss =\n0.5678, val_f1 = 0.6799', '\\n', 'Connectivity dense, Epoch 13/20: train_loss =\n0.5599, val_f1 = 0.6900', '\\n', 'Connectivity dense, Epoch 14/20: train_loss =\n0.5524, val_f1 = 0.6900', '\\n', 'Connectivity dense, Epoch 15/20: train_loss =\n0.5450, val_f1 = 0.6999', '\\n', 'Connectivity dense, Epoch 16/20: train_loss =\n0.5378, val_f1 = 0.6999', '\\n', 'Connectivity dense, Epoch 17/20: train_loss =\n0.5305, val_f1 = 0.7100', '\\n', 'Connectivity dense, Epoch 18/20: train_loss =\n0.5234, val_f1 = 0.7200', '\\n', 'Connectivity dense, Epoch 19/20: train_loss =\n0.5165, val_f1 = 0.7100', '\\n', 'Connectivity dense, Epoch 20/20: train_loss =\n0.5099, val_f1 = 0.7097', '\\n', 'Connectivity dense, Epoch 1/30: train_loss =\n0.7122, val_f1 = 0.5076', '\\n', 'Connectivity dense, Epoch 2/30: train_loss =\n0.6866, val_f1 = 0.5584', '\\n', 'Connectivity dense, Epoch 3/30: train_loss =\n0.6664, val_f1 = 0.5920', '\\n', 'Connectivity dense, Epoch 4/30: train_loss =\n0.6491, val_f1 = 0.6236', '\\n', 'Connectivity dense, Epoch 5/30: train_loss =\n0.6339, val_f1 = 0.6970', '\\n', 'Connectivity dense, Epoch 6/30: train_loss =\n0.6203, val_f1 = 0.7076', '\\n', 'Connectivity dense, Epoch 7/30: train_loss =\n0.6079, val_f1 = 0.6989', '\\n', 'Connectivity dense, Epoch 8/30: train_loss =\n0.5963, val_f1 = 0.7196', '\\n', 'Connectivity dense, Epoch 9/30: train_loss =\n0.5857, val_f1 = 0.7196', '\\n', 'Connectivity dense, Epoch 10/30: train_loss =\n0.5758, val_f1 = 0.7298', '\\n', 'Connectivity dense, Epoch 11/30: train_loss =\n0.5663, val_f1 = 0.7196', '\\n', 'Connectivity dense, Epoch 12/30: train_loss =\n0.5573, val_f1 = 0.6897', '\\n', 'Connectivity dense, Epoch 13/30: train_loss =\n0.5487, val_f1 = 0.6897', '\\n', 'Connectivity dense, Epoch 14/30: train_loss =\n0.5407, val_f1 = 0.7097', '\\n', 'Connectivity dense, Epoch 15/30: train_loss =\n0.5330, val_f1 = 0.6999', '\\n', 'Connectivity dense, Epoch 16/30: train_loss =\n0.5256, val_f1 = 0.7200', '\\n', 'Connectivity dense, Epoch 17/30: train_loss =\n0.5183, val_f1 = 0.7200', '\\n', 'Connectivity dense, Epoch 18/30: train_loss =\n0.5113, val_f1 = 0.7200', '\\n', 'Connectivity dense, Epoch 19/30: train_loss =\n0.5047, val_f1 = 0.7300', '\\n', 'Connectivity dense, Epoch 20/30: train_loss =\n0.4983, val_f1 = 0.7300', '\\n', 'Connectivity dense, Epoch 21/30: train_loss =\n0.4921, val_f1 = 0.7300', '\\n', 'Connectivity dense, Epoch 22/30: train_loss =\n0.4861, val_f1 = 0.7500', '\\n', 'Connectivity dense, Epoch 23/30: train_loss =\n0.4803, val_f1 = 0.7700', '\\n', 'Connectivity dense, Epoch 24/30: train_loss =\n0.4746, val_f1 = 0.7700', '\\n', 'Connectivity dense, Epoch 25/30: train_loss =\n0.4689, val_f1 = 0.7498', '\\n', 'Connectivity dense, Epoch 26/30: train_loss =\n0.4633, val_f1 = 0.7498', '\\n', 'Connectivity dense, Epoch 27/30: train_loss =\n0.4576, val_f1 = 0.7694', '\\n', 'Connectivity dense, Epoch 28/30: train_loss =\n0.4521, val_f1 = 0.7694', '\\n', 'Connectivity dense, Epoch 29/30: train_loss =\n0.4466, val_f1 = 0.7792', '\\n', 'Connectivity dense, Epoch 30/30: train_loss =\n0.4413, val_f1 = 0.7792', '\\n', 'Connectivity random, Epoch 1/5: train_loss =\n0.9298, val_f1 = 0.3159', '\\n', 'Connectivity random, Epoch 2/5: train_loss =\n0.8094, val_f1 = 0.4508', '\\n', 'Connectivity random, Epoch 3/5: train_loss =\n0.7248, val_f1 = 0.6505', '\\n', 'Connectivity random, Epoch 4/5: train_loss =\n0.6721, val_f1 = 0.6247', '\\n', 'Connectivity random, Epoch 5/5: train_loss =\n0.6426, val_f1 = 0.6016', '\\n', 'Connectivity random, Epoch 1/10: train_loss =\n0.7600, val_f1 = 0.5039', '\\n', 'Connectivity random, Epoch 2/10: train_loss =\n0.7068, val_f1 = 0.5488', '\\n', 'Connectivity random, Epoch 3/10: train_loss =\n0.6633, val_f1 = 0.6015', '\\n', 'Connectivity random, Epoch 4/10: train_loss =\n0.6275, val_f1 = 0.6424', '\\n', 'Connectivity random, Epoch 5/10: train_loss =\n0.5974, val_f1 = 0.7241', '\\n', 'Connectivity random, Epoch 6/10: train_loss =\n0.5717, val_f1 = 0.7784', '\\n', 'Connectivity random, Epoch 7/10: train_loss =\n0.5485, val_f1 = 0.8081', '\\n', 'Connectivity random, Epoch 8/10: train_loss =\n0.5271, val_f1 = 0.8274', '\\n', 'Connectivity random, Epoch 9/10: train_loss =\n0.5073, val_f1 = 0.8167', '\\n', 'Connectivity random, Epoch 10/10: train_loss =\n0.4889, val_f1 = 0.8167', '\\n', 'Connectivity random, Epoch 1/20: train_loss =\n0.7455, val_f1 = 0.6103', '\\n', 'Connectivity random, Epoch 2/20: train_loss =\n0.6874, val_f1 = 0.6543', '\\n', 'Connectivity random, Epoch 3/20: train_loss =\n0.6406, val_f1 = 0.6872', '\\n', 'Connectivity random, Epoch 4/20: train_loss =\n0.6029, val_f1 = 0.7106', '\\n', 'Connectivity random, Epoch 5/20: train_loss =\n0.5715, val_f1 = 0.7726', '\\n', 'Connectivity random, Epoch 6/20: train_loss =\n0.5451, val_f1 = 0.7665', '\\n', 'Connectivity random, Epoch 7/20: train_loss =\n0.5226, val_f1 = 0.7759', '\\n', 'Connectivity random, Epoch 8/20: train_loss =\n0.5026, val_f1 = 0.7759', '\\n', 'Connectivity random, Epoch 9/20: train_loss =\n0.4837, val_f1 = 0.7759', '\\n', 'Connectivity random, Epoch 10/20: train_loss =\n0.4660, val_f1 = 0.8044', '\\n', 'Connectivity random, Epoch 11/20: train_loss =\n0.4490, val_f1 = 0.8263', '\\n', 'Connectivity random, Epoch 12/20: train_loss =\n0.4329, val_f1 = 0.8263', '\\n', 'Connectivity random, Epoch 13/20: train_loss =\n0.4176, val_f1 = 0.8274', '\\n', 'Connectivity random, Epoch 14/20: train_loss =\n0.4032, val_f1 = 0.8477', '\\n', 'Connectivity random, Epoch 15/20: train_loss =\n0.3900, val_f1 = 0.8477', '\\n', 'Connectivity random, Epoch 16/20: train_loss =\n0.3776, val_f1 = 0.8574', '\\n', 'Connectivity random, Epoch 17/20: train_loss =\n0.3663, val_f1 = 0.8574', '\\n', 'Connectivity random, Epoch 18/20: train_loss =\n0.3555, val_f1 = 0.8574', '\\n', 'Connectivity random, Epoch 19/20: train_loss =\n0.3454, val_f1 = 0.8477', '\\n', 'Connectivity random, Epoch 20/20: train_loss =\n0.3355, val_f1 = 0.8370', '\\n', 'Connectivity random, Epoch 1/30: train_loss =\n0.6798, val_f1 = 0.6683', '\\n', 'Connectivity random, Epoch 2/30: train_loss =\n0.6395, val_f1 = 0.6884', '\\n', 'Connectivity random, Epoch 3/30: train_loss =\n0.6042, val_f1 = 0.7273', '\\n', 'Connectivity random, Epoch 4/30: train_loss =\n0.5723, val_f1 = 0.7381', '\\n', 'Connectivity random, Epoch 5/30: train_loss =\n0.5432, val_f1 = 0.7475', '\\n', 'Connectivity random, Epoch 6/30: train_loss =\n0.5164, val_f1 = 0.7570', '\\n', 'Connectivity random, Epoch 7/30: train_loss =\n0.4920, val_f1 = 0.7793', '\\n', 'Connectivity random, Epoch 8/30: train_loss =\n0.4698, val_f1 = 0.7993', '\\n', 'Connectivity random, Epoch 9/30: train_loss =\n0.4496, val_f1 = 0.7993', '\\n', 'Connectivity random, Epoch 10/30: train_loss =\n0.4311, val_f1 = 0.7889', '\\n', 'Connectivity random, Epoch 11/30: train_loss =\n0.4142, val_f1 = 0.7889', '\\n', 'Connectivity random, Epoch 12/30: train_loss =\n0.3983, val_f1 = 0.7985', '\\n', 'Connectivity random, Epoch 13/30: train_loss =\n0.3832, val_f1 = 0.8283', '\\n', 'Connectivity random, Epoch 14/30: train_loss =\n0.3690, val_f1 = 0.8274', '\\n', 'Connectivity random, Epoch 15/30: train_loss =\n0.3557, val_f1 = 0.8380', '\\n', 'Connectivity random, Epoch 16/30: train_loss =\n0.3439, val_f1 = 0.8283', '\\n', 'Connectivity random, Epoch 17/30: train_loss =\n0.3331, val_f1 = 0.8283', '\\n', 'Connectivity random, Epoch 18/30: train_loss =\n0.3232, val_f1 = 0.8388', '\\n', 'Connectivity random, Epoch 19/30: train_loss =\n0.3139, val_f1 = 0.8388', '\\n', 'Connectivity random, Epoch 20/30: train_loss =\n0.3049, val_f1 = 0.8388', '\\n', 'Connectivity random, Epoch 21/30: train_loss =\n0.2962, val_f1 = 0.8485', '\\n', 'Connectivity random, Epoch 22/30: train_loss =\n0.2877, val_f1 = 0.8687', '\\n', 'Connectivity random, Epoch 23/30: train_loss =\n0.2795, val_f1 = 0.8687', '\\n', 'Connectivity random, Epoch 24/30: train_loss =\n0.2713, val_f1 = 0.8785', '\\n', 'Connectivity random, Epoch 25/30: train_loss =\n0.2634, val_f1 = 0.8883', '\\n', 'Connectivity random, Epoch 26/30: train_loss =\n0.2557, val_f1 = 0.8883', '\\n', 'Connectivity random, Epoch 27/30: train_loss =\n0.2483, val_f1 = 0.8988', '\\n', 'Connectivity random, Epoch 28/30: train_loss =\n0.2411, val_f1 = 0.9091', '\\n', 'Connectivity random, Epoch 29/30: train_loss =\n0.2341, val_f1 = 0.9190', '\\n', 'Connectivity random, Epoch 30/30: train_loss =\n0.2274, val_f1 = 0.9190', '\\n', 'Execution time: a second seconds (time limit is\nan hour).']", "['Using device: cpu', '\\n', 'Activation ReLU, Epoch 1/20: train_loss = 0.7711,\nval_f1 = 0.4584', '\\n', 'Activation ReLU, Epoch 2/20: train_loss = 0.7248,\nval_f1 = 0.5360', '\\n', 'Activation ReLU, Epoch 3/20: train_loss = 0.6908,\nval_f1 = 0.5426', '\\n', 'Activation ReLU, Epoch 4/20: train_loss = 0.6650,\nval_f1 = 0.6165', '\\n', 'Activation ReLU, Epoch 5/20: train_loss = 0.6449,\nval_f1 = 0.6276', '\\n', 'Activation ReLU, Epoch 6/20: train_loss = 0.6287,\nval_f1 = 0.6493', '\\n', 'Activation ReLU, Epoch 7/20: train_loss = 0.6155,\nval_f1 = 0.6880', '\\n', 'Activation ReLU, Epoch 8/20: train_loss = 0.6047,\nval_f1 = 0.7267', '\\n', 'Activation ReLU, Epoch 9/20: train_loss = 0.5959,\nval_f1 = 0.7267', '\\n', 'Activation ReLU, Epoch 10/20: train_loss = 0.5882,\nval_f1 = 0.7267', '\\n', 'Activation ReLU, Epoch 11/20: train_loss = 0.5813,\nval_f1 = 0.7360', '\\n', 'Activation ReLU, Epoch 12/20: train_loss = 0.5748,\nval_f1 = 0.7470', '\\n', 'Activation ReLU, Epoch 13/20: train_loss = 0.5682,\nval_f1 = 0.7470', '\\n', 'Activation ReLU, Epoch 14/20: train_loss = 0.5615,\nval_f1 = 0.7470', '\\n', 'Activation ReLU, Epoch 15/20: train_loss = 0.5547,\nval_f1 = 0.7188', '\\n', 'Activation ReLU, Epoch 16/20: train_loss = 0.5482,\nval_f1 = 0.7188', '\\n', 'Activation ReLU, Epoch 17/20: train_loss = 0.5418,\nval_f1 = 0.7200', '\\n', 'Activation ReLU, Epoch 18/20: train_loss = 0.5354,\nval_f1 = 0.7094', '\\n', 'Activation ReLU, Epoch 19/20: train_loss = 0.5291,\nval_f1 = 0.7094', '\\n', 'Activation ReLU, Epoch 20/20: train_loss = 0.5227,\nval_f1 = 0.7282', '\\n', 'Activation Tanh, Epoch 1/20: train_loss = 0.7201,\nval_f1 = 0.6227', '\\n', 'Activation Tanh, Epoch 2/20: train_loss = 0.6738,\nval_f1 = 0.6625', '\\n', 'Activation Tanh, Epoch 3/20: train_loss = 0.6428,\nval_f1 = 0.6569', '\\n', 'Activation Tanh, Epoch 4/20: train_loss = 0.6242,\nval_f1 = 0.6999', '\\n', 'Activation Tanh, Epoch 5/20: train_loss = 0.6138,\nval_f1 = 0.7115', '\\n', 'Activation Tanh, Epoch 6/20: train_loss = 0.6081,\nval_f1 = 0.7229', '\\n', 'Activation Tanh, Epoch 7/20: train_loss = 0.6042,\nval_f1 = 0.7115', '\\n', 'Activation Tanh, Epoch 8/20: train_loss = 0.6008,\nval_f1 = 0.7115', '\\n', 'Activation Tanh, Epoch 9/20: train_loss = 0.5972,\nval_f1 = 0.7024', '\\n', 'Activation Tanh, Epoch 10/20: train_loss = 0.5934,\nval_f1 = 0.7138', '\\n', 'Activation Tanh, Epoch 11/20: train_loss = 0.5896,\nval_f1 = 0.7046', '\\n', 'Activation Tanh, Epoch 12/20: train_loss = 0.5860,\nval_f1 = 0.7065', '\\n', 'Activation Tanh, Epoch 13/20: train_loss = 0.5828,\nval_f1 = 0.6972', '\\n', 'Activation Tanh, Epoch 14/20: train_loss = 0.5798,\nval_f1 = 0.7046', '\\n', 'Activation Tanh, Epoch 15/20: train_loss = 0.5771,\nval_f1 = 0.7157', '\\n', 'Activation Tanh, Epoch 16/20: train_loss = 0.5745,\nval_f1 = 0.7157', '\\n', 'Activation Tanh, Epoch 17/20: train_loss = 0.5721,\nval_f1 = 0.7157', '\\n', 'Activation Tanh, Epoch 18/20: train_loss = 0.5696,\nval_f1 = 0.7157', '\\n', 'Activation Tanh, Epoch 19/20: train_loss = 0.5670,\nval_f1 = 0.7470', '\\n', 'Activation Tanh, Epoch 20/20: train_loss = 0.5642,\nval_f1 = 0.7470', '\\n', 'Activation Sigmoid, Epoch 1/20: train_loss = 1.1640,\nval_f1 = 0.2384', '\\n', 'Activation Sigmoid, Epoch 2/20: train_loss = 1.0071,\nval_f1 = 0.2384', '\\n', 'Activation Sigmoid, Epoch 3/20: train_loss = 0.8759,\nval_f1 = 0.2384', '\\n', 'Activation Sigmoid, Epoch 4/20: train_loss = 0.7749,\nval_f1 = 0.4022', '\\n', 'Activation Sigmoid, Epoch 5/20: train_loss = 0.7063,\nval_f1 = 0.6291', '\\n', 'Activation Sigmoid, Epoch 6/20: train_loss = 0.6686,\nval_f1 = 0.5875', '\\n', 'Activation Sigmoid, Epoch 7/20: train_loss = 0.6563,\nval_f1 = 0.4602', '\\n', 'Activation Sigmoid, Epoch 8/20: train_loss = 0.6611,\nval_f1 = 0.4379', '\\n', 'Activation Sigmoid, Epoch 9/20: train_loss = 0.6738,\nval_f1 = 0.4379', '\\n', 'Activation Sigmoid, Epoch 10/20: train_loss = 0.6870,\nval_f1 = 0.4379', '\\n', 'Activation Sigmoid, Epoch 11/20: train_loss = 0.6957,\nval_f1 = 0.4379', '\\n', 'Activation Sigmoid, Epoch 12/20: train_loss = 0.6979,\nval_f1 = 0.4379', '\\n', 'Activation Sigmoid, Epoch 13/20: train_loss = 0.6933,\nval_f1 = 0.4379', '\\n', 'Activation Sigmoid, Epoch 14/20: train_loss = 0.6834,\nval_f1 = 0.4379', '\\n', 'Activation Sigmoid, Epoch 15/20: train_loss = 0.6698,\nval_f1 = 0.5022', '\\n', 'Activation Sigmoid, Epoch 16/20: train_loss = 0.6547,\nval_f1 = 0.5346', '\\n', 'Activation Sigmoid, Epoch 17/20: train_loss = 0.6402,\nval_f1 = 0.5800', '\\n', 'Activation Sigmoid, Epoch 18/20: train_loss = 0.6280,\nval_f1 = 0.6184', '\\n', 'Activation Sigmoid, Epoch 19/20: train_loss = 0.6190,\nval_f1 = 0.6648', '\\n', 'Activation Sigmoid, Epoch 20/20: train_loss = 0.6138,\nval_f1 = 0.6638', '\\n', 'Activation LeakyReLU, Epoch 1/20: train_loss = 0.7092,\nval_f1 = 0.6135', '\\n', 'Activation LeakyReLU, Epoch 2/20: train_loss = 0.6729,\nval_f1 = 0.6690', '\\n', 'Activation LeakyReLU, Epoch 3/20: train_loss = 0.6454,\nval_f1 = 0.6648', '\\n', 'Activation LeakyReLU, Epoch 4/20: train_loss = 0.6241,\nval_f1 = 0.6864', '\\n', 'Activation LeakyReLU, Epoch 5/20: train_loss = 0.6075,\nval_f1 = 0.6850', '\\n', 'Activation LeakyReLU, Epoch 6/20: train_loss = 0.5947,\nval_f1 = 0.6909', '\\n', 'Activation LeakyReLU, Epoch 7/20: train_loss = 0.5847,\nval_f1 = 0.7157', '\\n', 'Activation LeakyReLU, Epoch 8/20: train_loss = 0.5763,\nval_f1 = 0.7360', '\\n', 'Activation LeakyReLU, Epoch 9/20: train_loss = 0.5684,\nval_f1 = 0.7453', '\\n', 'Activation LeakyReLU, Epoch 10/20: train_loss = 0.5605,\nval_f1 = 0.7360', '\\n', 'Activation LeakyReLU, Epoch 11/20: train_loss = 0.5525,\nval_f1 = 0.7267', '\\n', 'Activation LeakyReLU, Epoch 12/20: train_loss = 0.5445,\nval_f1 = 0.7470', '\\n', 'Activation LeakyReLU, Epoch 13/20: train_loss = 0.5368,\nval_f1 = 0.7886', '\\n', 'Activation LeakyReLU, Epoch 14/20: train_loss = 0.5294,\nval_f1 = 0.7886', '\\n', 'Activation LeakyReLU, Epoch 15/20: train_loss = 0.5223,\nval_f1 = 0.7886', '\\n', 'Activation LeakyReLU, Epoch 16/20: train_loss = 0.5157,\nval_f1 = 0.7685', '\\n', 'Activation LeakyReLU, Epoch 17/20: train_loss = 0.5093,\nval_f1 = 0.7791', '\\n', 'Activation LeakyReLU, Epoch 18/20: train_loss = 0.5032,\nval_f1 = 0.7791', '\\n', 'Activation LeakyReLU, Epoch 19/20: train_loss = 0.4970,\nval_f1 = 0.7791', '\\n', 'Activation LeakyReLU, Epoch 20/20: train_loss = 0.4904,\nval_f1 = 0.8000', '\\n', 'Execution time: a second seconds (time limit is an\nhour).']", "['Using device: cpu', '\\n', 'Node Count 50: Epoch 1/20: train_loss = 0.8271,\nval_f1 = 0.4684', '\\n', 'Node Count 50: Epoch 2/20: train_loss = 0.7304, val_f1\n= 0.6019', '\\n', 'Node Count 50: Epoch 3/20: train_loss = 0.6645, val_f1 =\n0.7200', '\\n', 'Node Count 50: Epoch 4/20: train_loss = 0.6216, val_f1 =\n0.7512', '\\n', 'Node Count 50: Epoch 5/20: train_loss = 0.5918, val_f1 =\n0.7886', '\\n', 'Node Count 50: Epoch 6/20: train_loss = 0.5678, val_f1 =\n0.7648', '\\n', 'Node Count 50: Epoch 7/20: train_loss = 0.5450, val_f1 =\n0.7463', '\\n', 'Node Count 50: Epoch 8/20: train_loss = 0.5216, val_f1 =\n0.7463', '\\n', 'Node Count 50: Epoch 9/20: train_loss = 0.4978, val_f1 =\n0.7698', '\\n', 'Node Count 50: Epoch 10/20: train_loss = 0.4749, val_f1 =\n0.7739', '\\n', 'Node Count 50: Epoch 11/20: train_loss = 0.4537, val_f1 =\n0.8175', '\\n', 'Node Count 50: Epoch 12/20: train_loss = 0.4345, val_f1 =\n0.8387', '\\n', 'Node Count 50: Epoch 13/20: train_loss = 0.4176, val_f1 =\n0.8193', '\\n', 'Node Count 50: Epoch 14/20: train_loss = 0.4031, val_f1 =\n0.8400', '\\n', 'Node Count 50: Epoch 15/20: train_loss = 0.3904, val_f1 =\n0.8400', '\\n', 'Node Count 50: Epoch 16/20: train_loss = 0.3782, val_f1 =\n0.8400', '\\n', 'Node Count 50: Epoch 17/20: train_loss = 0.3664, val_f1 =\n0.8604', '\\n', 'Node Count 50: Epoch 18/20: train_loss = 0.3546, val_f1 =\n0.8604', '\\n', 'Node Count 50: Epoch 19/20: train_loss = 0.3424, val_f1 =\n0.8604', '\\n', 'Node Count 50: Epoch 20/20: train_loss = 0.3301, val_f1 =\n0.8604', '\\n', 'Node Count 150: Epoch 1/20: train_loss = 0.7737, val_f1 =\n0.4473', '\\n', 'Node Count 150: Epoch 2/20: train_loss = 0.7350, val_f1 =\n0.4892', '\\n', 'Node Count 150: Epoch 3/20: train_loss = 0.7046, val_f1 =\n0.5387', '\\n', 'Node Count 150: Epoch 4/20: train_loss = 0.6807, val_f1 =\n0.6068', '\\n', 'Node Count 150: Epoch 5/20: train_loss = 0.6614, val_f1 =\n0.6065', '\\n', 'Node Count 150: Epoch 6/20: train_loss = 0.6451, val_f1 =\n0.6433', '\\n', 'Node Count 150: Epoch 7/20: train_loss = 0.6315, val_f1 =\n0.6693', '\\n', 'Node Count 150: Epoch 8/20: train_loss = 0.6201, val_f1 =\n0.6744', '\\n', 'Node Count 150: Epoch 9/20: train_loss = 0.6104, val_f1 =\n0.6670', '\\n', 'Node Count 150: Epoch 10/20: train_loss = 0.6016, val_f1 =\n0.6744', '\\n', 'Node Count 150: Epoch 11/20: train_loss = 0.5937, val_f1 =\n0.6682', '\\n', 'Node Count 150: Epoch 12/20: train_loss = 0.5865, val_f1 =\n0.6693', '\\n', 'Node Count 150: Epoch 13/20: train_loss = 0.5796, val_f1 =\n0.6979', '\\n', 'Node Count 150: Epoch 14/20: train_loss = 0.5731, val_f1 =\n0.7056', '\\n', 'Node Count 150: Epoch 15/20: train_loss = 0.5668, val_f1 =\n0.7259', '\\n', 'Node Count 150: Epoch 16/20: train_loss = 0.5604, val_f1 =\n0.7064', '\\n', 'Node Count 150: Epoch 17/20: train_loss = 0.5540, val_f1 =\n0.7132', '\\n', 'Node Count 150: Epoch 18/20: train_loss = 0.5475, val_f1 =\n0.7129', '\\n', 'Node Count 150: Epoch 19/20: train_loss = 0.5411, val_f1 =\n0.7331', '\\n', 'Node Count 150: Epoch 20/20: train_loss = 0.5346, val_f1 =\n0.7194', '\\n', 'Node Count 200: Epoch 1/20: train_loss = 0.7146, val_f1 =\n0.5436', '\\n', 'Node Count 200: Epoch 2/20: train_loss = 0.6752, val_f1 =\n0.5978', '\\n', 'Node Count 200: Epoch 3/20: train_loss = 0.6549, val_f1 =\n0.6356', '\\n', 'Node Count 200: Epoch 4/20: train_loss = 0.6442, val_f1 =\n0.6203', '\\n', 'Node Count 200: Epoch 5/20: train_loss = 0.6347, val_f1 =\n0.6500', '\\n', 'Node Count 200: Epoch 6/20: train_loss = 0.6236, val_f1 =\n0.6506', '\\n', 'Node Count 200: Epoch 7/20: train_loss = 0.6120, val_f1 =\n0.6693', '\\n', 'Node Count 200: Epoch 8/20: train_loss = 0.6011, val_f1 =\n0.6824', '\\n', 'Node Count 200: Epoch 9/20: train_loss = 0.5919, val_f1 =\n0.6894', '\\n', 'Node Count 200: Epoch 10/20: train_loss = 0.5847, val_f1 =\n0.6885', '\\n', 'Node Count 200: Epoch 11/20: train_loss = 0.5788, val_f1 =\n0.6885', '\\n', 'Node Count 200: Epoch 12/20: train_loss = 0.5732, val_f1 =\n0.6885', '\\n', 'Node Count 200: Epoch 13/20: train_loss = 0.5670, val_f1 =\n0.6996', '\\n', 'Node Count 200: Epoch 14/20: train_loss = 0.5601, val_f1 =\n0.7161', '\\n', 'Node Count 200: Epoch 15/20: train_loss = 0.5526, val_f1 =\n0.7328', '\\n', 'Node Count 200: Epoch 16/20: train_loss = 0.5452, val_f1 =\n0.7494', '\\n', 'Node Count 200: Epoch 17/20: train_loss = 0.5381, val_f1 =\n0.7549', '\\n', 'Node Count 200: Epoch 18/20: train_loss = 0.5313, val_f1 =\n0.7504', '\\n', 'Node Count 200: Epoch 19/20: train_loss = 0.5246, val_f1 =\n0.7505', '\\n', 'Node Count 200: Epoch 20/20: train_loss = 0.5178, val_f1 =\n0.7604', '\\n', 'Execution time: a second seconds (time limit is an hour).']", "['Using device: cpu', '\\n', 'Node Count 50: Epoch 1/20: train_loss = 0.7978,\nval_f1 = 0.4294, tmc = 0.9651', '\\n', 'Node Count 50: Epoch 2/20: train_loss =\n0.7345, val_f1 = 0.5557, tmc = 0.8771', '\\n', 'Node Count 50: Epoch 3/20:\ntrain_loss = 0.6925, val_f1 = 0.6400, tmc = 0.6019', '\\n', 'Node Count 50: Epoch\n4/20: train_loss = 0.6667, val_f1 = 0.6579, tmc = 0.2963', '\\n', 'Node Count 50:\nEpoch 5/20: train_loss = 0.6509, val_f1 = 0.6637, tmc = 0.7298', '\\n', 'Node\nCount 50: Epoch 6/20: train_loss = 0.6389, val_f1 = 0.6816, tmc = 0.8456', '\\n',\n'Node Count 50: Epoch 7/20: train_loss = 0.6279, val_f1 = 0.6816, tmc = 0.9593',\n'\\n', 'Node Count 50: Epoch 8/20: train_loss = 0.6156, val_f1 = 0.6816, tmc =\n0.0860', '\\n', 'Node Count 50: Epoch 9/20: train_loss = 0.6028, val_f1 = 0.6875,\ntmc = 0.8366', '\\n', 'Node Count 50: Epoch 10/20: train_loss = 0.5905, val_f1 =\n0.7145, tmc = 0.4741', '\\n', 'Node Count 50: Epoch 11/20: train_loss = 0.5791,\nval_f1 = 0.7173, tmc = 0.2989', '\\n', 'Node Count 50: Epoch 12/20: train_loss =\n0.5692, val_f1 = 0.6982, tmc = 0.3443', '\\n', 'Node Count 50: Epoch 13/20:\ntrain_loss = 0.5610, val_f1 = 0.6996, tmc = 0.1167', '\\n', 'Node Count 50: Epoch\n14/20: train_loss = 0.5539, val_f1 = 0.7001, tmc = 0.7607', '\\n', 'Node Count\n50: Epoch 15/20: train_loss = 0.5471, val_f1 = 0.6596, tmc = 0.3038', '\\n',\n'Node Count 50: Epoch 16/20: train_loss = 0.5401, val_f1 = 0.6596, tmc =\n0.1943', '\\n', 'Node Count 50: Epoch 17/20: train_loss = 0.5327, val_f1 =\n0.7001, tmc = 0.1411', '\\n', 'Node Count 50: Epoch 18/20: train_loss = 0.5250,\nval_f1 = 0.7001, tmc = 0.9725', '\\n', 'Node Count 50: Epoch 19/20: train_loss =\n0.5174, val_f1 = 0.7200, tmc = 0.1200', '\\n', 'Node Count 50: Epoch 20/20:\ntrain_loss = 0.5101, val_f1 = 0.6996, tmc = 0.7885', '\\n', 'Node Count 150:\nEpoch 1/20: train_loss = 0.8062, val_f1 = 0.3979, tmc = 0.5134', '\\n', 'Node\nCount 150: Epoch 2/20: train_loss = 0.7471, val_f1 = 0.4593, tmc = 0.2389',\n'\\n', 'Node Count 150: Epoch 3/20: train_loss = 0.7086, val_f1 = 0.5192, tmc =\n0.4117', '\\n', 'Node Count 150: Epoch 4/20: train_loss = 0.6873, val_f1 =\n0.5798, tmc = 0.1451', '\\n', 'Node Count 150: Epoch 5/20: train_loss = 0.6762,\nval_f1 = 0.5916, tmc = 0.8149', '\\n', 'Node Count 150: Epoch 6/20: train_loss =\n0.6681, val_f1 = 0.6115, tmc = 0.5661', '\\n', 'Node Count 150: Epoch 7/20:\ntrain_loss = 0.6595, val_f1 = 0.6352, tmc = 0.3320', '\\n', 'Node Count 150:\nEpoch 8/20: train_loss = 0.6499, val_f1 = 0.6631, tmc = 0.4781', '\\n', 'Node\nCount 150: Epoch 9/20: train_loss = 0.6398, val_f1 = 0.6584, tmc = 0.3581',\n'\\n', 'Node Count 150: Epoch 10/20: train_loss = 0.6303, val_f1 = 0.6802, tmc =\n0.2336', '\\n', 'Node Count 150: Epoch 11/20: train_loss = 0.6221, val_f1 =\n0.6931, tmc = 0.5653', '\\n', 'Node Count 150: Epoch 12/20: train_loss = 0.6153,\nval_f1 = 0.6845, tmc = 0.9012', '\\n', 'Node Count 150: Epoch 13/20: train_loss =\n0.6098, val_f1 = 0.6963, tmc = 0.2560', '\\n', 'Node Count 150: Epoch 14/20:\ntrain_loss = 0.6048, val_f1 = 0.6890, tmc = 0.4870', '\\n', 'Node Count 150:\nEpoch 15/20: train_loss = 0.5997, val_f1 = 0.6953, tmc = 0.4303', '\\n', 'Node\nCount 150: Epoch 16/20: train_loss = 0.5940, val_f1 = 0.7026, tmc = 0.6706',\n'\\n', 'Node Count 150: Epoch 17/20: train_loss = 0.5879, val_f1 = 0.7106, tmc =\n0.5764', '\\n', 'Node Count 150: Epoch 18/20: train_loss = 0.5815, val_f1 =\n0.7318, tmc = 0.0369', '\\n', 'Node Count 150: Epoch 19/20: train_loss = 0.5751,\nval_f1 = 0.7318, tmc = 0.9877', '\\n', 'Node Count 150: Epoch 20/20: train_loss =\n0.5692, val_f1 = 0.7254, tmc = 0.4038', '\\n', 'Node Count 200: Epoch 1/20:\ntrain_loss = 0.7383, val_f1 = 0.5563, tmc = 0.0664', '\\n', 'Node Count 200:\nEpoch 2/20: train_loss = 0.7071, val_f1 = 0.5837, tmc = 0.0465', '\\n', 'Node\nCount 200: Epoch 3/20: train_loss = 0.6818, val_f1 = 0.5985, tmc = 0.6389',\n'\\n', 'Node Count 200: Epoch 4/20: train_loss = 0.6608, val_f1 = 0.6033, tmc =\n0.7252', '\\n', 'Node Count 200: Epoch 5/20: train_loss = 0.6433, val_f1 =\n0.5994, tmc = 0.3694', '\\n', 'Node Count 200: Epoch 6/20: train_loss = 0.6289,\nval_f1 = 0.6398, tmc = 0.7012', '\\n', 'Node Count 200: Epoch 7/20: train_loss =\n0.6168, val_f1 = 0.6600, tmc = 0.9773', '\\n', 'Node Count 200: Epoch 8/20:\ntrain_loss = 0.6062, val_f1 = 0.6752, tmc = 0.2807', '\\n', 'Node Count 200:\nEpoch 9/20: train_loss = 0.5967, val_f1 = 0.6749, tmc = 0.7424', '\\n', 'Node\nCount 200: Epoch 10/20: train_loss = 0.5876, val_f1 = 0.6951, tmc = 0.5094',\n'\\n', 'Node Count 200: Epoch 11/20: train_loss = 0.5788, val_f1 = 0.7001, tmc =\n0.0133', '\\n', 'Node Count 200: Epoch 12/20: train_loss = 0.5701, val_f1 =\n0.7098, tmc = 0.2818', '\\n', 'Node Count 200: Epoch 13/20: train_loss = 0.5614,\nval_f1 = 0.7051, tmc = 0.3421', '\\n', 'Node Count 200: Epoch 14/20: train_loss =\n0.5528, val_f1 = 0.7251, tmc = 0.6821', '\\n', 'Node Count 200: Epoch 15/20:\ntrain_loss = 0.5443, val_f1 = 0.7301, tmc = 0.3035', '\\n', 'Node Count 200:\nEpoch 16/20: train_loss = 0.5359, val_f1 = 0.7349, tmc = 0.5732', '\\n', 'Node\nCount 200: Epoch 17/20: train_loss = 0.5277, val_f1 = 0.7298, tmc = 0.5955',\n'\\n', 'Node Count 200: Epoch 18/20: train_loss = 0.5194, val_f1 = 0.7398, tmc =\n0.8419', '\\n', 'Node Count 200: Epoch 19/20: train_loss = 0.5110, val_f1 =\n0.7448, tmc = 0.5921', '\\n', 'Node Count 200: Epoch 20/20: train_loss = 0.5027,\nval_f1 = 0.7498, tmc = 0.2339', '\\n', 'Execution time: a second seconds (time\nlimit is an hour).']", "['Using device: cpu', '\\n', 'Node Count 50: Epoch 1/20: train_loss = 0.7326,\nval_loss = 0.6798, val_f1 = 0.4899, TMC = 0.7495', '\\n', 'Node Count 50: Epoch\n2/20: train_loss = 0.6798, val_loss = 0.6356, val_f1 = 0.5436, TMC = 0.0029',\n'\\n', 'Node Count 50: Epoch 3/20: train_loss = 0.6356, val_loss = 0.6001, val_f1\n= 0.5708, TMC = 0.7487', '\\n', 'Node Count 50: Epoch 4/20: train_loss = 0.6001,\nval_loss = 0.5711, val_f1 = 0.6253, TMC = 0.7758', '\\n', 'Node Count 50: Epoch\n5/20: train_loss = 0.5711, val_loss = 0.5475, val_f1 = 0.7214, TMC = 0.3535',\n'\\n', 'Node Count 50: Epoch 6/20: train_loss = 0.5475, val_loss = 0.5276, val_f1\n= 0.7214, TMC = 0.7331', '\\n', 'Node Count 50: Epoch 7/20: train_loss = 0.5276,\nval_loss = 0.5104, val_f1 = 0.7040, TMC = 0.6159', '\\n', 'Node Count 50: Epoch\n8/20: train_loss = 0.5104, val_loss = 0.4950, val_f1 = 0.7285, TMC = 0.7715',\n'\\n', 'Node Count 50: Epoch 9/20: train_loss = 0.4950, val_loss = 0.4803, val_f1\n= 0.7521, TMC = 0.5999', '\\n', 'Node Count 50: Epoch 10/20: train_loss = 0.4803,\nval_loss = 0.4660, val_f1 = 0.7934, TMC = 0.6873', '\\n', 'Node Count 50: Epoch\n11/20: train_loss = 0.4660, val_loss = 0.4524, val_f1 = 0.7934, TMC = 0.0830',\n'\\n', 'Node Count 50: Epoch 12/20: train_loss = 0.4524, val_loss = 0.4390,\nval_f1 = 0.7934, TMC = 0.3697', '\\n', 'Node Count 50: Epoch 13/20: train_loss =\n0.4390, val_loss = 0.4262, val_f1 = 0.8120, TMC = 0.9570', '\\n', 'Node Count 50:\nEpoch 14/20: train_loss = 0.4262, val_loss = 0.4144, val_f1 = 0.7934, TMC =\n0.9423', '\\n', 'Node Count 50: Epoch 15/20: train_loss = 0.4144, val_loss =\n0.4031, val_f1 = 0.7749, TMC = 0.0908', '\\n', 'Node Count 50: Epoch 16/20:\ntrain_loss = 0.4031, val_loss = 0.3925, val_f1 = 0.7749, TMC = 0.6283', '\\n',\n'Node Count 50: Epoch 17/20: train_loss = 0.3925, val_loss = 0.3823, val_f1 =\n0.8158, TMC = 0.5579', '\\n', 'Node Count 50: Epoch 18/20: train_loss = 0.3823,\nval_loss = 0.3723, val_f1 = 0.8158, TMC = 0.6147', '\\n', 'Node Count 50: Epoch\n19/20: train_loss = 0.3723, val_loss = 0.3625, val_f1 = 0.8158, TMC = 0.0183',\n'\\n', 'Node Count 50: Epoch 20/20: train_loss = 0.3625, val_loss = 0.3530,\nval_f1 = 0.8347, TMC = 0.2545', '\\n', 'Node Count 150: Epoch 1/20: train_loss =\n0.7637, val_loss = 0.7338, val_f1 = 0.4635, TMC = 0.2324', '\\n', 'Node Count\n150: Epoch 2/20: train_loss = 0.7338, val_loss = 0.7112, val_f1 = 0.4920, TMC =\n0.9146', '\\n', 'Node Count 150: Epoch 3/20: train_loss = 0.7112, val_loss =\n0.6922, val_f1 = 0.5119, TMC = 0.6409', '\\n', 'Node Count 150: Epoch 4/20:\ntrain_loss = 0.6922, val_loss = 0.6748, val_f1 = 0.5262, TMC = 0.5196', '\\n',\n'Node Count 150: Epoch 5/20: train_loss = 0.6748, val_loss = 0.6590, val_f1 =\n0.5842, TMC = 0.7091', '\\n', 'Node Count 150: Epoch 6/20: train_loss = 0.6590,\nval_loss = 0.6448, val_f1 = 0.6685, TMC = 0.3431', '\\n', 'Node Count 150: Epoch\n7/20: train_loss = 0.6448, val_loss = 0.6318, val_f1 = 0.6696, TMC = 0.2610',\n'\\n', 'Node Count 150: Epoch 8/20: train_loss = 0.6318, val_loss = 0.6199,\nval_f1 = 0.6784, TMC = 0.9415', '\\n', 'Node Count 150: Epoch 9/20: train_loss =\n0.6199, val_loss = 0.6088, val_f1 = 0.6982, TMC = 0.8329', '\\n', 'Node Count\n150: Epoch 10/20: train_loss = 0.6088, val_loss = 0.5982, val_f1 = 0.7250, TMC =\n0.6952', '\\n', 'Node Count 150: Epoch 11/20: train_loss = 0.5982, val_loss =\n0.5879, val_f1 = 0.7196, TMC = 0.8958', '\\n', 'Node Count 150: Epoch 12/20:\ntrain_loss = 0.5879, val_loss = 0.5780, val_f1 = 0.7128, TMC = 0.8864', '\\n',\n'Node Count 150: Epoch 13/20: train_loss = 0.5780, val_loss = 0.5684, val_f1 =\n0.7196, TMC = 0.1697', '\\n', 'Node Count 150: Epoch 14/20: train_loss = 0.5684,\nval_loss = 0.5592, val_f1 = 0.7186, TMC = 0.1346', '\\n', 'Node Count 150: Epoch\n15/20: train_loss = 0.5592, val_loss = 0.5502, val_f1 = 0.7116, TMC = 0.6564',\n'\\n', 'Node Count 150: Epoch 16/20: train_loss = 0.5502, val_loss = 0.5411,\nval_f1 = 0.7186, TMC = 0.6152', '\\n', 'Node Count 150: Epoch 17/20: train_loss =\n0.5411, val_loss = 0.5321, val_f1 = 0.7384, TMC = 0.6110', '\\n', 'Node Count\n150: Epoch 18/20: train_loss = 0.5321, val_loss = 0.5231, val_f1 = 0.7454, TMC =\n0.0465', '\\n', 'Node Count 150: Epoch 19/20: train_loss = 0.5231, val_loss =\n0.5141, val_f1 = 0.7658, TMC = 0.8998', '\\n', 'Node Count 150: Epoch 20/20:\ntrain_loss = 0.5141, val_loss = 0.5051, val_f1 = 0.7796, TMC = 0.2392', '\\n',\n'Node Count 200: Epoch 1/20: train_loss = 0.8642, val_loss = 0.7908, val_f1 =\n0.3566, TMC = 0.0849', '\\n', 'Node Count 200: Epoch 2/20: train_loss = 0.7908,\nval_loss = 0.7371, val_f1 = 0.3789, TMC = 0.6786', '\\n', 'Node Count 200: Epoch\n3/20: train_loss = 0.7371, val_loss = 0.7017, val_f1 = 0.4630, TMC = 0.8166',\n'\\n', 'Node Count 200: Epoch 4/20: train_loss = 0.7017, val_loss = 0.6809,\nval_f1 = 0.5489, TMC = 0.6484', '\\n', 'Node Count 200: Epoch 5/20: train_loss =\n0.6809, val_loss = 0.6697, val_f1 = 0.5758, TMC = 0.7168', '\\n', 'Node Count\n200: Epoch 6/20: train_loss = 0.6697, val_loss = 0.6628, val_f1 = 0.5709, TMC =\n0.3776', '\\n', 'Node Count 200: Epoch 7/20: train_loss = 0.6628, val_loss =\n0.6565, val_f1 = 0.5547, TMC = 0.7854', '\\n', 'Node Count 200: Epoch 8/20:\ntrain_loss = 0.6565, val_loss = 0.6493, val_f1 = 0.5580, TMC = 0.5191', '\\n',\n'Node Count 200: Epoch 9/20: train_loss = 0.6493, val_loss = 0.6406, val_f1 =\n0.6181, TMC = 0.1275', '\\n', 'Node Count 200: Epoch 10/20: train_loss = 0.6406,\nval_loss = 0.6309, val_f1 = 0.6435, TMC = 0.2291', '\\n', 'Node Count 200: Epoch\n11/20: train_loss = 0.6309, val_loss = 0.6213, val_f1 = 0.6294, TMC = 0.7925',\n'\\n', 'Node Count 200: Epoch 12/20: train_loss = 0.6213, val_loss = 0.6127,\nval_f1 = 0.6317, TMC = 0.9677', '\\n', 'Node Count 200: Epoch 13/20: train_loss =\n0.6127, val_loss = 0.6056, val_f1 = 0.6933, TMC = 0.0885', '\\n', 'Node Count\n200: Epoch 14/20: train_loss = 0.6056, val_loss = 0.6001, val_f1 = 0.6995, TMC =\n0.2898', '\\n', 'Node Count 200: Epoch 15/20: train_loss = 0.6001, val_loss =\n0.5961, val_f1 = 0.6998, TMC = 0.4366', '\\n', 'Node Count 200: Epoch 16/20:\ntrain_loss = 0.5961, val_loss = 0.5928, val_f1 = 0.7048, TMC = 0.3772', '\\n',\n'Node Count 200: Epoch 17/20: train_loss = 0.5928, val_loss = 0.5896, val_f1 =\n0.7048, TMC = 0.8903', '\\n', 'Node Count 200: Epoch 18/20: train_loss = 0.5896,\nval_loss = 0.5862, val_f1 = 0.7048, TMC = 0.6454', '\\n', 'Node Count 200: Epoch\n19/20: train_loss = 0.5862, val_loss = 0.5822, val_f1 = 0.7149, TMC = 0.1406',\n'\\n', 'Node Count 200: Epoch 20/20: train_loss = 0.5822, val_loss = 0.5776,\nval_f1 = 0.7149, TMC = 0.7661', '\\n', 'Execution time: a second seconds (time\nlimit is an hour).']", "['Using device: cpu', '\\n', 'Features 8, Epoch 1/5: train_loss = 0.7332, val_f1\n= 0.5400', '\\n', 'Features 8, Epoch 2/5: train_loss = 0.6984, val_f1 = 0.6158',\n'\\n', 'Features 8, Epoch 3/5: train_loss = 0.6765, val_f1 = 0.5721', '\\n',\n'Features 8, Epoch 4/5: train_loss = 0.6649, val_f1 = 0.5388', '\\n', 'Features\n8, Epoch 5/5: train_loss = 0.6595, val_f1 = 0.4792', '\\n', 'Features 8, Epoch\n1/10: train_loss = 0.7380, val_f1 = 0.5210', '\\n', 'Features 8, Epoch 2/10:\ntrain_loss = 0.7102, val_f1 = 0.5386', '\\n', 'Features 8, Epoch 3/10: train_loss\n= 0.6908, val_f1 = 0.5616', '\\n', 'Features 8, Epoch 4/10: train_loss = 0.6776,\nval_f1 = 0.5771', '\\n', 'Features 8, Epoch 5/10: train_loss = 0.6673, val_f1 =\n0.5771', '\\n', 'Features 8, Epoch 6/10: train_loss = 0.6582, val_f1 = 0.5761',\n'\\n', 'Features 8, Epoch 7/10: train_loss = 0.6495, val_f1 = 0.6043', '\\n',\n'Features 8, Epoch 8/10: train_loss = 0.6414, val_f1 = 0.6012', '\\n', 'Features\n8, Epoch 9/10: train_loss = 0.6342, val_f1 = 0.6143', '\\n', 'Features 8, Epoch\n10/10: train_loss = 0.6279, val_f1 = 0.5975', '\\n', 'Features 8, Epoch 1/20:\ntrain_loss = 0.8144, val_f1 = 0.3345', '\\n', 'Features 8, Epoch 2/20: train_loss\n= 0.7595, val_f1 = 0.4031', '\\n', 'Features 8, Epoch 3/20: train_loss = 0.7232,\nval_f1 = 0.4785', '\\n', 'Features 8, Epoch 4/20: train_loss = 0.7016, val_f1 =\n0.4568', '\\n', 'Features 8, Epoch 5/20: train_loss = 0.6902, val_f1 = 0.4869',\n'\\n', 'Features 8, Epoch 6/20: train_loss = 0.6833, val_f1 = 0.5302', '\\n',\n'Features 8, Epoch 7/20: train_loss = 0.6772, val_f1 = 0.5137', '\\n', 'Features\n8, Epoch 8/20: train_loss = 0.6705, val_f1 = 0.5229', '\\n', 'Features 8, Epoch\n9/20: train_loss = 0.6622, val_f1 = 0.5229', '\\n', 'Features 8, Epoch 10/20:\ntrain_loss = 0.6529, val_f1 = 0.5823', '\\n', 'Features 8, Epoch 11/20:\ntrain_loss = 0.6435, val_f1 = 0.6059', '\\n', 'Features 8, Epoch 12/20:\ntrain_loss = 0.6349, val_f1 = 0.6138', '\\n', 'Features 8, Epoch 13/20:\ntrain_loss = 0.6278, val_f1 = 0.6172', '\\n', 'Features 8, Epoch 14/20:\ntrain_loss = 0.6221, val_f1 = 0.6521', '\\n', 'Features 8, Epoch 15/20:\ntrain_loss = 0.6172, val_f1 = 0.6431', '\\n', 'Features 8, Epoch 16/20:\ntrain_loss = 0.6127, val_f1 = 0.6340', '\\n', 'Features 8, Epoch 17/20:\ntrain_loss = 0.6082, val_f1 = 0.6431', '\\n', 'Features 8, Epoch 18/20:\ntrain_loss = 0.6032, val_f1 = 0.6562', '\\n', 'Features 8, Epoch 19/20:\ntrain_loss = 0.5978, val_f1 = 0.6562', '\\n', 'Features 8, Epoch 20/20:\ntrain_loss = 0.5920, val_f1 = 0.6543', '\\n', 'Features 8, Epoch 1/30: train_loss\n= 0.7236, val_f1 = 0.4884', '\\n', 'Features 8, Epoch 2/30: train_loss = 0.7049,\nval_f1 = 0.4836', '\\n', 'Features 8, Epoch 3/30: train_loss = 0.6907, val_f1 =\n0.4858', '\\n', 'Features 8, Epoch 4/30: train_loss = 0.6792, val_f1 = 0.4934',\n'\\n', 'Features 8, Epoch 5/30: train_loss = 0.6690, val_f1 = 0.5366', '\\n',\n'Features 8, Epoch 6/30: train_loss = 0.6598, val_f1 = 0.5286', '\\n', 'Features\n8, Epoch 7/30: train_loss = 0.6515, val_f1 = 0.5420', '\\n', 'Features 8, Epoch\n8/30: train_loss = 0.6443, val_f1 = 0.5844', '\\n', 'Features 8, Epoch 9/30:\ntrain_loss = 0.6378, val_f1 = 0.5965', '\\n', 'Features 8, Epoch 10/30:\ntrain_loss = 0.6319, val_f1 = 0.5721', '\\n', 'Features 8, Epoch 11/30:\ntrain_loss = 0.6264, val_f1 = 0.5512', '\\n', 'Features 8, Epoch 12/30:\ntrain_loss = 0.6211, val_f1 = 0.5512', '\\n', 'Features 8, Epoch 13/30:\ntrain_loss = 0.6161, val_f1 = 0.5428', '\\n', 'Features 8, Epoch 14/30:\ntrain_loss = 0.6110, val_f1 = 0.5596', '\\n', 'Features 8, Epoch 15/30:\ntrain_loss = 0.6059, val_f1 = 0.5844', '\\n', 'Features 8, Epoch 16/30:\ntrain_loss = 0.6008, val_f1 = 0.5844', '\\n', 'Features 8, Epoch 17/30:\ntrain_loss = 0.5953, val_f1 = 0.5930', '\\n', 'Features 8, Epoch 18/30:\ntrain_loss = 0.5894, val_f1 = 0.5965', '\\n', 'Features 8, Epoch 19/30:\ntrain_loss = 0.5834, val_f1 = 0.6084', '\\n', 'Features 8, Epoch 20/30:\ntrain_loss = 0.5773, val_f1 = 0.6317', '\\n', 'Features 8, Epoch 21/30:\ntrain_loss = 0.5709, val_f1 = 0.6654', '\\n', 'Features 8, Epoch 22/30:\ntrain_loss = 0.5644, val_f1 = 0.6764', '\\n', 'Features 8, Epoch 23/30:\ntrain_loss = 0.5576, val_f1 = 0.7087', '\\n', 'Features 8, Epoch 24/30:\ntrain_loss = 0.5506, val_f1 = 0.6991', '\\n', 'Features 8, Epoch 25/30:\ntrain_loss = 0.5435, val_f1 = 0.7096', '\\n', 'Features 8, Epoch 26/30:\ntrain_loss = 0.5362, val_f1 = 0.7296', '\\n', 'Features 8, Epoch 27/30:\ntrain_loss = 0.5287, val_f1 = 0.7689', '\\n', 'Features 8, Epoch 28/30:\ntrain_loss = 0.5210, val_f1 = 0.8091', '\\n', 'Features 8, Epoch 29/30:\ntrain_loss = 0.5132, val_f1 = 0.8097', '\\n', 'Features 8, Epoch 30/30:\ntrain_loss = 0.5055, val_f1 = 0.7994', '\\n', 'Features 16, Epoch 1/5: train_loss\n= 0.7692, val_f1 = 0.5510', '\\n', 'Features 16, Epoch 2/5: train_loss = 0.7261,\nval_f1 = 0.6123', '\\n', 'Features 16, Epoch 3/5: train_loss = 0.6911, val_f1 =\n0.6181', '\\n', 'Features 16, Epoch 4/5: train_loss = 0.6626, val_f1 = 0.6594',\n'\\n', 'Features 16, Epoch 5/5: train_loss = 0.6393, val_f1 = 0.6891', '\\n',\n'Features 16, Epoch 1/10: train_loss = 0.6936, val_f1 = 0.5236', '\\n', 'Features\n16, Epoch 2/10: train_loss = 0.6641, val_f1 = 0.5772', '\\n', 'Features 16, Epoch\n3/10: train_loss = 0.6392, val_f1 = 0.5983', '\\n', 'Features 16, Epoch 4/10:\ntrain_loss = 0.6179, val_f1 = 0.6061', '\\n', 'Features 16, Epoch 5/10:\ntrain_loss = 0.5993, val_f1 = 0.6320', '\\n', 'Features 16, Epoch 6/10:\ntrain_loss = 0.5829, val_f1 = 0.6683', '\\n', 'Features 16, Epoch 7/10:\ntrain_loss = 0.5678, val_f1 = 0.6891', '\\n', 'Features 16, Epoch 8/10:\ntrain_loss = 0.5539, val_f1 = 0.7007', '\\n', 'Features 16, Epoch 9/10:\ntrain_loss = 0.5407, val_f1 = 0.7007', '\\n', 'Features 16, Epoch 10/10:\ntrain_loss = 0.5284, val_f1 = 0.7007', '\\n', 'Features 16, Epoch 1/20:\ntrain_loss = 0.6752, val_f1 = 0.6388', '\\n', 'Features 16, Epoch 2/20:\ntrain_loss = 0.6462, val_f1 = 0.6450', '\\n', 'Features 16, Epoch 3/20:\ntrain_loss = 0.6280, val_f1 = 0.6351', '\\n', 'Features 16, Epoch 4/20:\ntrain_loss = 0.6133, val_f1 = 0.6268', '\\n', 'Features 16, Epoch 5/20:\ntrain_loss = 0.5991, val_f1 = 0.6792', '\\n', 'Features 16, Epoch 6/20:\ntrain_loss = 0.5852, val_f1 = 0.6829', '\\n', 'Features 16, Epoch 7/20:\ntrain_loss = 0.5720, val_f1 = 0.6862', '\\n', 'Features 16, Epoch 8/20:\ntrain_loss = 0.5599, val_f1 = 0.7327', '\\n', 'Features 16, Epoch 9/20:\ntrain_loss = 0.5491, val_f1 = 0.7143', '\\n', 'Features 16, Epoch 10/20:\ntrain_loss = 0.5394, val_f1 = 0.7364', '\\n', 'Features 16, Epoch 11/20:\ntrain_loss = 0.5302, val_f1 = 0.7473', '\\n', 'Features 16, Epoch 12/20:\ntrain_loss = 0.5211, val_f1 = 0.7378', '\\n', 'Features 16, Epoch 13/20:\ntrain_loss = 0.5120, val_f1 = 0.7473', '\\n', 'Features 16, Epoch 14/20:\ntrain_loss = 0.5031, val_f1 = 0.7473', '\\n', 'Features 16, Epoch 15/20:\ntrain_loss = 0.4945, val_f1 = 0.7364', '\\n', 'Features 16, Epoch 16/20:\ntrain_loss = 0.4863, val_f1 = 0.7364', '\\n', 'Features 16, Epoch 17/20:\ntrain_loss = 0.4782, val_f1 = 0.7378', '\\n', 'Features 16, Epoch 18/20:\ntrain_loss = 0.4699, val_f1 = 0.7473', '\\n', 'Features 16, Epoch 19/20:\ntrain_loss = 0.4616, val_f1 = 0.7782', '\\n', 'Features 16, Epoch 20/20:\ntrain_loss = 0.4530, val_f1 = 0.7877', '\\n', 'Features 16, Epoch 1/30:\ntrain_loss = 0.7131, val_f1 = 0.5397', '\\n', 'Features 16, Epoch 2/30:\ntrain_loss = 0.6815, val_f1 = 0.5470', '\\n', 'Features 16, Epoch 3/30:\ntrain_loss = 0.6591, val_f1 = 0.5619', '\\n', 'Features 16, Epoch 4/30:\ntrain_loss = 0.6398, val_f1 = 0.6434', '\\n', 'Features 16, Epoch 5/30:\ntrain_loss = 0.6215, val_f1 = 0.7220', '\\n', 'Features 16, Epoch 6/30:\ntrain_loss = 0.6045, val_f1 = 0.7252', '\\n', 'Features 16, Epoch 7/30:\ntrain_loss = 0.5894, val_f1 = 0.7214', '\\n', 'Features 16, Epoch 8/30:\ntrain_loss = 0.5759, val_f1 = 0.7161', '\\n', 'Features 16, Epoch 9/30:\ntrain_loss = 0.5637, val_f1 = 0.7254', '\\n', 'Features 16, Epoch 10/30:\ntrain_loss = 0.5521, val_f1 = 0.7161', '\\n', 'Features 16, Epoch 11/30:\ntrain_loss = 0.5408, val_f1 = 0.7254', '\\n', 'Features 16, Epoch 12/30:\ntrain_loss = 0.5296, val_f1 = 0.7364', '\\n', 'Features 16, Epoch 13/30:\ntrain_loss = 0.5188, val_f1 = 0.7364', '\\n', 'Features 16, Epoch 14/30:\ntrain_loss = 0.5085, val_f1 = 0.7458', '\\n', 'Features 16, Epoch 15/30:\ntrain_loss = 0.4986, val_f1 = 0.7661', '\\n', 'Features 16, Epoch 16/30:\ntrain_loss = 0.4888, val_f1 = 0.7661', '\\n', 'Features 16, Epoch 17/30:\ntrain_loss = 0.4790, val_f1 = 0.7645', '\\n', 'Features 16, Epoch 18/30:\ntrain_loss = 0.4690, val_f1 = 0.7864', '\\n', 'Features 16, Epoch 19/30:\ntrain_loss = 0.4591, val_f1 = 0.7864', '\\n', 'Features 16, Epoch 20/30:\ntrain_loss = 0.4493, val_f1 = 0.8079', '\\n', 'Features 16, Epoch 21/30:\ntrain_loss = 0.4396, val_f1 = 0.7983', '\\n', 'Features 16, Epoch 22/30:\ntrain_loss = 0.4301, val_f1 = 0.8089', '\\n', 'Features 16, Epoch 23/30:\ntrain_loss = 0.4205, val_f1 = 0.8193', '\\n', 'Features 16, Epoch 24/30:\ntrain_loss = 0.4110, val_f1 = 0.8387', '\\n', 'Features 16, Epoch 25/30:\ntrain_loss = 0.4017, val_f1 = 0.8491', '\\n', 'Features 16, Epoch 26/30:\ntrain_loss = 0.3926, val_f1 = 0.8484', '\\n', 'Features 16, Epoch 27/30:\ntrain_loss = 0.3840, val_f1 = 0.8581', '\\n', 'Features 16, Epoch 28/30:\ntrain_loss = 0.3756, val_f1 = 0.8686', '\\n', 'Features 16, Epoch 29/30:\ntrain_loss = 0.3674, val_f1 = 0.8790', '\\n', 'Features 16, Epoch 30/30:\ntrain_loss = 0.3594, val_f1 = 0.8790', '\\n', 'Features 32, Epoch 1/5: train_loss\n= 0.9734, val_f1 = 0.4100', '\\n', 'Features 32, Epoch 2/5: train_loss = 0.8445,\nval_f1 = 0.4455', '\\n', 'Features 32, Epoch 3/5: train_loss = 0.7477, val_f1 =\n0.5435', '\\n', 'Features 32, Epoch 4/5: train_loss = 0.6813, val_f1 = 0.6197',\n'\\n', 'Features 32, Epoch 5/5: train_loss = 0.6390, val_f1 = 0.6559', '\\n',\n'Features 32, Epoch 1/10: train_loss = 0.8153, val_f1 = 0.4851', '\\n', 'Features\n32, Epoch 2/10: train_loss = 0.7328, val_f1 = 0.5780', '\\n', 'Features 32, Epoch\n3/10: train_loss = 0.6782, val_f1 = 0.6495', '\\n', 'Features 32, Epoch 4/10:\ntrain_loss = 0.6391, val_f1 = 0.6819', '\\n', 'Features 32, Epoch 5/10:\ntrain_loss = 0.6072, val_f1 = 0.7246', '\\n', 'Features 32, Epoch 6/10:\ntrain_loss = 0.5793, val_f1 = 0.7545', '\\n', 'Features 32, Epoch 7/10:\ntrain_loss = 0.5538, val_f1 = 0.7581', '\\n', 'Features 32, Epoch 8/10:\ntrain_loss = 0.5312, val_f1 = 0.7692', '\\n', 'Features 32, Epoch 9/10:\ntrain_loss = 0.5115, val_f1 = 0.7496', '\\n', 'Features 32, Epoch 10/10:\ntrain_loss = 0.4935, val_f1 = 0.7400', '\\n', 'Features 32, Epoch 1/20:\ntrain_loss = 0.6690, val_f1 = 0.6391', '\\n', 'Features 32, Epoch 2/20:\ntrain_loss = 0.6228, val_f1 = 0.6986', '\\n', 'Features 32, Epoch 3/20:\ntrain_loss = 0.5966, val_f1 = 0.7464', '\\n', 'Features 32, Epoch 4/20:\ntrain_loss = 0.5758, val_f1 = 0.7464', '\\n', 'Features 32, Epoch 5/20:\ntrain_loss = 0.5538, val_f1 = 0.7475', '\\n', 'Features 32, Epoch 6/20:\ntrain_loss = 0.5328, val_f1 = 0.7291', '\\n', 'Features 32, Epoch 7/20:\ntrain_loss = 0.5144, val_f1 = 0.7499', '\\n', 'Features 32, Epoch 8/20:\ntrain_loss = 0.4988, val_f1 = 0.7499', '\\n', 'Features 32, Epoch 9/20:\ntrain_loss = 0.4847, val_f1 = 0.7598', '\\n', 'Features 32, Epoch 10/20:\ntrain_loss = 0.4708, val_f1 = 0.7897', '\\n', 'Features 32, Epoch 11/20:\ntrain_loss = 0.4562, val_f1 = 0.8099', '\\n', 'Features 32, Epoch 12/20:\ntrain_loss = 0.4410, val_f1 = 0.8000', '\\n', 'Features 32, Epoch 13/20:\ntrain_loss = 0.4262, val_f1 = 0.8297', '\\n', 'Features 32, Epoch 14/20:\ntrain_loss = 0.4121, val_f1 = 0.8599', '\\n', 'Features 32, Epoch 15/20:\ntrain_loss = 0.3982, val_f1 = 0.8700', '\\n', 'Features 32, Epoch 16/20:\ntrain_loss = 0.3844, val_f1 = 0.8700', '\\n', 'Features 32, Epoch 17/20:\ntrain_loss = 0.3709, val_f1 = 0.8700', '\\n', 'Features 32, Epoch 18/20:\ntrain_loss = 0.3574, val_f1 = 0.8800', '\\n', 'Features 32, Epoch 19/20:\ntrain_loss = 0.3442, val_f1 = 0.8700', '\\n', 'Features 32, Epoch 20/20:\ntrain_loss = 0.3314, val_f1 = 0.8700', '\\n', 'Features 32, Epoch 1/30:\ntrain_loss = 0.6854, val_f1 = 0.6499', '\\n', 'Features 32, Epoch 2/30:\ntrain_loss = 0.6483, val_f1 = 0.6998', '\\n', 'Features 32, Epoch 3/30:\ntrain_loss = 0.6187, val_f1 = 0.7500', '\\n', 'Features 32, Epoch 4/30:\ntrain_loss = 0.5929, val_f1 = 0.7699', '\\n', 'Features 32, Epoch 5/30:\ntrain_loss = 0.5699, val_f1 = 0.7496', '\\n', 'Features 32, Epoch 6/30:\ntrain_loss = 0.5488, val_f1 = 0.7594', '\\n', 'Features 32, Epoch 7/30:\ntrain_loss = 0.5288, val_f1 = 0.7491', '\\n', 'Features 32, Epoch 8/30:\ntrain_loss = 0.5096, val_f1 = 0.7594', '\\n', 'Features 32, Epoch 9/30:\ntrain_loss = 0.4907, val_f1 = 0.7798', '\\n', 'Features 32, Epoch 10/30:\ntrain_loss = 0.4722, val_f1 = 0.7798', '\\n', 'Features 32, Epoch 11/30:\ntrain_loss = 0.4541, val_f1 = 0.7899', '\\n', 'Features 32, Epoch 12/30:\ntrain_loss = 0.4363, val_f1 = 0.8299', '\\n', 'Features 32, Epoch 13/30:\ntrain_loss = 0.4189, val_f1 = 0.8299', '\\n', 'Features 32, Epoch 14/30:\ntrain_loss = 0.4021, val_f1 = 0.8400', '\\n', 'Features 32, Epoch 15/30:\ntrain_loss = 0.3856, val_f1 = 0.8400', '\\n', 'Features 32, Epoch 16/30:\ntrain_loss = 0.3697, val_f1 = 0.8700', '\\n', 'Features 32, Epoch 17/30:\ntrain_loss = 0.3541, val_f1 = 0.8800', '\\n', 'Features 32, Epoch 18/30:\ntrain_loss = 0.3387, val_f1 = 0.8999', '\\n', 'Features 32, Epoch 19/30:\ntrain_loss = 0.3237, val_f1 = 0.8900', '\\n', 'Features 32, Epoch 20/30:\ntrain_loss = 0.3089, val_f1 = 0.8900', '\\n', 'Features 32, Epoch 21/30:\ntrain_loss = 0.2944, val_f1 = 0.9000', '\\n', 'Features 32, Epoch 22/30:\ntrain_loss = 0.2804, val_f1 = 0.9200', '\\n', 'Features 32, Epoch 23/30:\ntrain_loss = 0.2669, val_f1 = 0.9300', '\\n', 'Features 32, Epoch 24/30:\ntrain_loss = 0.2540, val_f1 = 0.9500', '\\n', 'Features 32, Epoch 25/30:\ntrain_loss = 0.2415, val_f1 = 0.9600', '\\n', 'Features 32, Epoch 26/30:\ntrain_loss = 0.2294, val_f1 = 0.9600', '\\n', 'Features 32, Epoch 27/30:\ntrain_loss = 0.2178, val_f1 = 0.9600', '\\n', 'Features 32, Epoch 28/30:\ntrain_loss = 0.2066, val_f1 = 0.9600', '\\n', 'Features 32, Epoch 29/30:\ntrain_loss = 0.1959, val_f1 = 0.9600', '\\n', 'Features 32, Epoch 30/30:\ntrain_loss = 0.1857, val_f1 = 0.9700', '\\n', 'Features 64, Epoch 1/5: train_loss\n= 0.6448, val_f1 = 0.8001', '\\n', 'Features 64, Epoch 2/5: train_loss = 0.5377,\nval_f1 = 0.8390', '\\n', 'Features 64, Epoch 3/5: train_loss = 0.4639, val_f1 =\n0.8690', '\\n', 'Features 64, Epoch 4/5: train_loss = 0.4079, val_f1 = 0.8592',\n'\\n', 'Features 64, Epoch 5/5: train_loss = 0.3632, val_f1 = 0.8796', '\\n',\n'Features 64, Epoch 1/10: train_loss = 0.9693, val_f1 = 0.4217', '\\n', 'Features\n64, Epoch 2/10: train_loss = 0.7983, val_f1 = 0.5741', '\\n', 'Features 64, Epoch\n3/10: train_loss = 0.6850, val_f1 = 0.6886', '\\n', 'Features 64, Epoch 4/10:\ntrain_loss = 0.6140, val_f1 = 0.7537', '\\n', 'Features 64, Epoch 5/10:\ntrain_loss = 0.5653, val_f1 = 0.7852', '\\n', 'Features 64, Epoch 6/10:\ntrain_loss = 0.5237, val_f1 = 0.7865', '\\n', 'Features 64, Epoch 7/10:\ntrain_loss = 0.4842, val_f1 = 0.8493', '\\n', 'Features 64, Epoch 8/10:\ntrain_loss = 0.4476, val_f1 = 0.8799', '\\n', 'Features 64, Epoch 9/10:\ntrain_loss = 0.4155, val_f1 = 0.8699', '\\n', 'Features 64, Epoch 10/10:\ntrain_loss = 0.3873, val_f1 = 0.8601', '\\n', 'Features 64, Epoch 1/20:\ntrain_loss = 0.8698, val_f1 = 0.4545', '\\n', 'Features 64, Epoch 2/20:\ntrain_loss = 0.7491, val_f1 = 0.5586', '\\n', 'Features 64, Epoch 3/20:\ntrain_loss = 0.6671, val_f1 = 0.6674', '\\n', 'Features 64, Epoch 4/20:\ntrain_loss = 0.6066, val_f1 = 0.7648', '\\n', 'Features 64, Epoch 5/20:\ntrain_loss = 0.5565, val_f1 = 0.8271', '\\n', 'Features 64, Epoch 6/20:\ntrain_loss = 0.5130, val_f1 = 0.8586', '\\n', 'Features 64, Epoch 7/20:\ntrain_loss = 0.4739, val_f1 = 0.8595', '\\n', 'Features 64, Epoch 8/20:\ntrain_loss = 0.4384, val_f1 = 0.8595', '\\n', 'Features 64, Epoch 9/20:\ntrain_loss = 0.4064, val_f1 = 0.8595', '\\n', 'Features 64, Epoch 10/20:\ntrain_loss = 0.3772, val_f1 = 0.8497', '\\n', 'Features 64, Epoch 11/20:\ntrain_loss = 0.3503, val_f1 = 0.8598', '\\n', 'Features 64, Epoch 12/20:\ntrain_loss = 0.3256, val_f1 = 0.8699', '\\n', 'Features 64, Epoch 13/20:\ntrain_loss = 0.3023, val_f1 = 0.9000', '\\n', 'Features 64, Epoch 14/20:\ntrain_loss = 0.2803, val_f1 = 0.9100', '\\n', 'Features 64, Epoch 15/20:\ntrain_loss = 0.2596, val_f1 = 0.9400', '\\n', 'Features 64, Epoch 16/20:\ntrain_loss = 0.2405, val_f1 = 0.9300', '\\n', 'Features 64, Epoch 17/20:\ntrain_loss = 0.2234, val_f1 = 0.9200', '\\n', 'Features 64, Epoch 18/20:\ntrain_loss = 0.2084, val_f1 = 0.9300', '\\n', 'Features 64, Epoch 19/20:\ntrain_loss = 0.1953, val_f1 = 0.9500', '\\n', 'Features 64, Epoch 20/20:\ntrain_loss = 0.1836, val_f1 = 0.9500', '\\n', 'Features 64, Epoch 1/30:\ntrain_loss = 0.7505, val_f1 = 0.6092', '\\n', 'Features 64, Epoch 2/30:\ntrain_loss = 0.6331, val_f1 = 0.7288', '\\n', 'Features 64, Epoch 3/30:\ntrain_loss = 0.5563, val_f1 = 0.7769', '\\n', 'Features 64, Epoch 4/30:\ntrain_loss = 0.4973, val_f1 = 0.8287', '\\n', 'Features 64, Epoch 5/30:\ntrain_loss = 0.4461, val_f1 = 0.8697', '\\n', 'Features 64, Epoch 6/30:\ntrain_loss = 0.4020, val_f1 = 0.8899', '\\n', 'Features 64, Epoch 7/30:\ntrain_loss = 0.3651, val_f1 = 0.9000', '\\n', 'Features 64, Epoch 8/30:\ntrain_loss = 0.3345, val_f1 = 0.9000', '\\n', 'Features 64, Epoch 9/30:\ntrain_loss = 0.3078, val_f1 = 0.9000', '\\n', 'Features 64, Epoch 10/30:\ntrain_loss = 0.2838, val_f1 = 0.9200', '\\n', 'Features 64, Epoch 11/30:\ntrain_loss = 0.2616, val_f1 = 0.9400', '\\n', 'Features 64, Epoch 12/30:\ntrain_loss = 0.2412, val_f1 = 0.9500', '\\n', 'Features 64, Epoch 13/30:\ntrain_loss = 0.2228, val_f1 = 0.9500', '\\n', 'Features 64, Epoch 14/30:\ntrain_loss = 0.2063, val_f1 = 0.9500', '\\n', 'Features 64, Epoch 15/30:\ntrain_loss = 0.1913, val_f1 = 0.9700', '\\n', 'Features 64, Epoch 16/30:\ntrain_loss = 0.1775, val_f1 = 0.9700', '\\n', 'Features 64, Epoch 17/30:\ntrain_loss = 0.1650, val_f1 = 0.9800', '\\n', 'Features 64, Epoch 18/30:\ntrain_loss = 0.1536, val_f1 = 0.9800', '\\n', 'Features 64, Epoch 19/30:\ntrain_loss = 0.1431, val_f1 = 0.9800', '\\n', 'Features 64, Epoch 20/30:\ntrain_loss = 0.1334, val_f1 = 0.9800', '\\n', 'Features 64, Epoch 21/30:\ntrain_loss = 0.1241, val_f1 = 0.9800', '\\n', 'Features 64, Epoch 22/30:\ntrain_loss = 0.1153, val_f1 = 0.9800', '\\n', 'Features 64, Epoch 23/30:\ntrain_loss = 0.1068, val_f1 = 0.9800', '\\n', 'Features 64, Epoch 24/30:\ntrain_loss = 0.0991, val_f1 = 0.9900', '\\n', 'Features 64, Epoch 25/30:\ntrain_loss = 0.0919, val_f1 = 1.0000', '\\n', 'Features 64, Epoch 26/30:\ntrain_loss = 0.0854, val_f1 = 1.0000', '\\n', 'Features 64, Epoch 27/30:\ntrain_loss = 0.0794, val_f1 = 1.0000', '\\n', 'Features 64, Epoch 28/30:\ntrain_loss = 0.0739, val_f1 = 1.0000', '\\n', 'Features 64, Epoch 29/30:\ntrain_loss = 0.0688, val_f1 = 1.0000', '\\n', 'Features 64, Epoch 30/30:\ntrain_loss = 0.0641, val_f1 = 1.0000', '\\n', 'Execution time: a second seconds\n(time limit is an hour).']", "['Using device: cpu', '\\n', 'Features 8, Epoch 1/5: train_loss = 0.7332, val_f1\n= 0.5400', '\\n', 'Features 8, Epoch 2/5: train_loss = 0.6984, val_f1 = 0.6158',\n'\\n', 'Features 8, Epoch 3/5: train_loss = 0.6765, val_f1 = 0.5721', '\\n',\n'Features 8, Epoch 4/5: train_loss = 0.6649, val_f1 = 0.5388', '\\n', 'Features\n8, Epoch 5/5: train_loss = 0.6595, val_f1 = 0.4792', '\\n', 'Features 8, Epoch\n1/10: train_loss = 0.7380, val_f1 = 0.5210', '\\n', 'Features 8, Epoch 2/10:\ntrain_loss = 0.7102, val_f1 = 0.5386', '\\n', 'Features 8, Epoch 3/10: train_loss\n= 0.6908, val_f1 = 0.5616', '\\n', 'Features 8, Epoch 4/10: train_loss = 0.6776,\nval_f1 = 0.5771', '\\n', 'Features 8, Epoch 5/10: train_loss = 0.6673, val_f1 =\n0.5771', '\\n', 'Features 8, Epoch 6/10: train_loss = 0.6582, val_f1 = 0.5761',\n'\\n', 'Features 8, Epoch 7/10: train_loss = 0.6495, val_f1 = 0.6043', '\\n',\n'Features 8, Epoch 8/10: train_loss = 0.6414, val_f1 = 0.6012', '\\n', 'Features\n8, Epoch 9/10: train_loss = 0.6342, val_f1 = 0.6143', '\\n', 'Features 8, Epoch\n10/10: train_loss = 0.6279, val_f1 = 0.5975', '\\n', 'Features 8, Epoch 1/20:\ntrain_loss = 0.8144, val_f1 = 0.3345', '\\n', 'Features 8, Epoch 2/20: train_loss\n= 0.7595, val_f1 = 0.4031', '\\n', 'Features 8, Epoch 3/20: train_loss = 0.7232,\nval_f1 = 0.4785', '\\n', 'Features 8, Epoch 4/20: train_loss = 0.7016, val_f1 =\n0.4568', '\\n', 'Features 8, Epoch 5/20: train_loss = 0.6902, val_f1 = 0.4869',\n'\\n', 'Features 8, Epoch 6/20: train_loss = 0.6833, val_f1 = 0.5302', '\\n',\n'Features 8, Epoch 7/20: train_loss = 0.6772, val_f1 = 0.5137', '\\n', 'Features\n8, Epoch 8/20: train_loss = 0.6705, val_f1 = 0.5229', '\\n', 'Features 8, Epoch\n9/20: train_loss = 0.6622, val_f1 = 0.5229', '\\n', 'Features 8, Epoch 10/20:\ntrain_loss = 0.6529, val_f1 = 0.5823', '\\n', 'Features 8, Epoch 11/20:\ntrain_loss = 0.6435, val_f1 = 0.6059', '\\n', 'Features 8, Epoch 12/20:\ntrain_loss = 0.6349, val_f1 = 0.6138', '\\n', 'Features 8, Epoch 13/20:\ntrain_loss = 0.6278, val_f1 = 0.6172', '\\n', 'Features 8, Epoch 14/20:\ntrain_loss = 0.6221, val_f1 = 0.6521', '\\n', 'Features 8, Epoch 15/20:\ntrain_loss = 0.6172, val_f1 = 0.6431', '\\n', 'Features 8, Epoch 16/20:\ntrain_loss = 0.6127, val_f1 = 0.6340', '\\n', 'Features 8, Epoch 17/20:\ntrain_loss = 0.6082, val_f1 = 0.6431', '\\n', 'Features 8, Epoch 18/20:\ntrain_loss = 0.6032, val_f1 = 0.6562', '\\n', 'Features 8, Epoch 19/20:\ntrain_loss = 0.5978, val_f1 = 0.6562', '\\n', 'Features 8, Epoch 20/20:\ntrain_loss = 0.5920, val_f1 = 0.6543', '\\n', 'Features 8, Epoch 1/30: train_loss\n= 0.7236, val_f1 = 0.4884', '\\n', 'Features 8, Epoch 2/30: train_loss = 0.7049,\nval_f1 = 0.4836', '\\n', 'Features 8, Epoch 3/30: train_loss = 0.6907, val_f1 =\n0.4858', '\\n', 'Features 8, Epoch 4/30: train_loss = 0.6792, val_f1 = 0.4934',\n'\\n', 'Features 8, Epoch 5/30: train_loss = 0.6690, val_f1 = 0.5366', '\\n',\n'Features 8, Epoch 6/30: train_loss = 0.6598, val_f1 = 0.5286', '\\n', 'Features\n8, Epoch 7/30: train_loss = 0.6515, val_f1 = 0.5420', '\\n', 'Features 8, Epoch\n8/30: train_loss = 0.6443, val_f1 = 0.5844', '\\n', 'Features 8, Epoch 9/30:\ntrain_loss = 0.6378, val_f1 = 0.5965', '\\n', 'Features 8, Epoch 10/30:\ntrain_loss = 0.6319, val_f1 = 0.5721', '\\n', 'Features 8, Epoch 11/30:\ntrain_loss = 0.6264, val_f1 = 0.5512', '\\n', 'Features 8, Epoch 12/30:\ntrain_loss = 0.6211, val_f1 = 0.5512', '\\n', 'Features 8, Epoch 13/30:\ntrain_loss = 0.6161, val_f1 = 0.5428', '\\n', 'Features 8, Epoch 14/30:\ntrain_loss = 0.6110, val_f1 = 0.5596', '\\n', 'Features 8, Epoch 15/30:\ntrain_loss = 0.6059, val_f1 = 0.5844', '\\n', 'Features 8, Epoch 16/30:\ntrain_loss = 0.6008, val_f1 = 0.5844', '\\n', 'Features 8, Epoch 17/30:\ntrain_loss = 0.5953, val_f1 = 0.5930', '\\n', 'Features 8, Epoch 18/30:\ntrain_loss = 0.5894, val_f1 = 0.5965', '\\n', 'Features 8, Epoch 19/30:\ntrain_loss = 0.5834, val_f1 = 0.6084', '\\n', 'Features 8, Epoch 20/30:\ntrain_loss = 0.5773, val_f1 = 0.6317', '\\n', 'Features 8, Epoch 21/30:\ntrain_loss = 0.5709, val_f1 = 0.6654', '\\n', 'Features 8, Epoch 22/30:\ntrain_loss = 0.5644, val_f1 = 0.6764', '\\n', 'Features 8, Epoch 23/30:\ntrain_loss = 0.5576, val_f1 = 0.7087', '\\n', 'Features 8, Epoch 24/30:\ntrain_loss = 0.5506, val_f1 = 0.6991', '\\n', 'Features 8, Epoch 25/30:\ntrain_loss = 0.5435, val_f1 = 0.7096', '\\n', 'Features 8, Epoch 26/30:\ntrain_loss = 0.5362, val_f1 = 0.7296', '\\n', 'Features 8, Epoch 27/30:\ntrain_loss = 0.5287, val_f1 = 0.7689', '\\n', 'Features 8, Epoch 28/30:\ntrain_loss = 0.5210, val_f1 = 0.8091', '\\n', 'Features 8, Epoch 29/30:\ntrain_loss = 0.5132, val_f1 = 0.8097', '\\n', 'Features 8, Epoch 30/30:\ntrain_loss = 0.5055, val_f1 = 0.7994', '\\n', 'Features 16, Epoch 1/5: train_loss\n= 0.7692, val_f1 = 0.5510', '\\n', 'Features 16, Epoch 2/5: train_loss = 0.7261,\nval_f1 = 0.6123', '\\n', 'Features 16, Epoch 3/5: train_loss = 0.6911, val_f1 =\n0.6181', '\\n', 'Features 16, Epoch 4/5: train_loss = 0.6626, val_f1 = 0.6594',\n'\\n', 'Features 16, Epoch 5/5: train_loss = 0.6393, val_f1 = 0.6891', '\\n',\n'Features 16, Epoch 1/10: train_loss = 0.6936, val_f1 = 0.5236', '\\n', 'Features\n16, Epoch 2/10: train_loss = 0.6641, val_f1 = 0.5772', '\\n', 'Features 16, Epoch\n3/10: train_loss = 0.6392, val_f1 = 0.5983', '\\n', 'Features 16, Epoch 4/10:\ntrain_loss = 0.6179, val_f1 = 0.6061', '\\n', 'Features 16, Epoch 5/10:\ntrain_loss = 0.5993, val_f1 = 0.6320', '\\n', 'Features 16, Epoch 6/10:\ntrain_loss = 0.5829, val_f1 = 0.6683', '\\n', 'Features 16, Epoch 7/10:\ntrain_loss = 0.5678, val_f1 = 0.6891', '\\n', 'Features 16, Epoch 8/10:\ntrain_loss = 0.5539, val_f1 = 0.7007', '\\n', 'Features 16, Epoch 9/10:\ntrain_loss = 0.5407, val_f1 = 0.7007', '\\n', 'Features 16, Epoch 10/10:\ntrain_loss = 0.5284, val_f1 = 0.7007', '\\n', 'Features 16, Epoch 1/20:\ntrain_loss = 0.6752, val_f1 = 0.6388', '\\n', 'Features 16, Epoch 2/20:\ntrain_loss = 0.6462, val_f1 = 0.6450', '\\n', 'Features 16, Epoch 3/20:\ntrain_loss = 0.6280, val_f1 = 0.6351', '\\n', 'Features 16, Epoch 4/20:\ntrain_loss = 0.6133, val_f1 = 0.6268', '\\n', 'Features 16, Epoch 5/20:\ntrain_loss = 0.5991, val_f1 = 0.6792', '\\n', 'Features 16, Epoch 6/20:\ntrain_loss = 0.5852, val_f1 = 0.6829', '\\n', 'Features 16, Epoch 7/20:\ntrain_loss = 0.5720, val_f1 = 0.6862', '\\n', 'Features 16, Epoch 8/20:\ntrain_loss = 0.5599, val_f1 = 0.7327', '\\n', 'Features 16, Epoch 9/20:\ntrain_loss = 0.5491, val_f1 = 0.7143', '\\n', 'Features 16, Epoch 10/20:\ntrain_loss = 0.5394, val_f1 = 0.7364', '\\n', 'Features 16, Epoch 11/20:\ntrain_loss = 0.5302, val_f1 = 0.7473', '\\n', 'Features 16, Epoch 12/20:\ntrain_loss = 0.5211, val_f1 = 0.7378', '\\n', 'Features 16, Epoch 13/20:\ntrain_loss = 0.5120, val_f1 = 0.7473', '\\n', 'Features 16, Epoch 14/20:\ntrain_loss = 0.5031, val_f1 = 0.7473', '\\n', 'Features 16, Epoch 15/20:\ntrain_loss = 0.4945, val_f1 = 0.7364', '\\n', 'Features 16, Epoch 16/20:\ntrain_loss = 0.4863, val_f1 = 0.7364', '\\n', 'Features 16, Epoch 17/20:\ntrain_loss = 0.4782, val_f1 = 0.7378', '\\n', 'Features 16, Epoch 18/20:\ntrain_loss = 0.4699, val_f1 = 0.7473', '\\n', 'Features 16, Epoch 19/20:\ntrain_loss = 0.4616, val_f1 = 0.7782', '\\n', 'Features 16, Epoch 20/20:\ntrain_loss = 0.4530, val_f1 = 0.7877', '\\n', 'Features 16, Epoch 1/30:\ntrain_loss = 0.7131, val_f1 = 0.5397', '\\n', 'Features 16, Epoch 2/30:\ntrain_loss = 0.6815, val_f1 = 0.5470', '\\n', 'Features 16, Epoch 3/30:\ntrain_loss = 0.6591, val_f1 = 0.5619', '\\n', 'Features 16, Epoch 4/30:\ntrain_loss = 0.6398, val_f1 = 0.6434', '\\n', 'Features 16, Epoch 5/30:\ntrain_loss = 0.6215, val_f1 = 0.7220', '\\n', 'Features 16, Epoch 6/30:\ntrain_loss = 0.6045, val_f1 = 0.7252', '\\n', 'Features 16, Epoch 7/30:\ntrain_loss = 0.5894, val_f1 = 0.7214', '\\n', 'Features 16, Epoch 8/30:\ntrain_loss = 0.5759, val_f1 = 0.7161', '\\n', 'Features 16, Epoch 9/30:\ntrain_loss = 0.5637, val_f1 = 0.7254', '\\n', 'Features 16, Epoch 10/30:\ntrain_loss = 0.5521, val_f1 = 0.7161', '\\n', 'Features 16, Epoch 11/30:\ntrain_loss = 0.5408, val_f1 = 0.7254', '\\n', 'Features 16, Epoch 12/30:\ntrain_loss = 0.5296, val_f1 = 0.7364', '\\n', 'Features 16, Epoch 13/30:\ntrain_loss = 0.5188, val_f1 = 0.7364', '\\n', 'Features 16, Epoch 14/30:\ntrain_loss = 0.5085, val_f1 = 0.7458', '\\n', 'Features 16, Epoch 15/30:\ntrain_loss = 0.4986, val_f1 = 0.7661', '\\n', 'Features 16, Epoch 16/30:\ntrain_loss = 0.4888, val_f1 = 0.7661', '\\n', 'Features 16, Epoch 17/30:\ntrain_loss = 0.4790, val_f1 = 0.7645', '\\n', 'Features 16, Epoch 18/30:\ntrain_loss = 0.4690, val_f1 = 0.7864', '\\n', 'Features 16, Epoch 19/30:\ntrain_loss = 0.4591, val_f1 = 0.7864', '\\n', 'Features 16, Epoch 20/30:\ntrain_loss = 0.4493, val_f1 = 0.8079', '\\n', 'Features 16, Epoch 21/30:\ntrain_loss = 0.4396, val_f1 = 0.7983', '\\n', 'Features 16, Epoch 22/30:\ntrain_loss = 0.4301, val_f1 = 0.8089', '\\n', 'Features 16, Epoch 23/30:\ntrain_loss = 0.4205, val_f1 = 0.8193', '\\n', 'Features 16, Epoch 24/30:\ntrain_loss = 0.4110, val_f1 = 0.8387', '\\n', 'Features 16, Epoch 25/30:\ntrain_loss = 0.4017, val_f1 = 0.8491', '\\n', 'Features 16, Epoch 26/30:\ntrain_loss = 0.3926, val_f1 = 0.8484', '\\n', 'Features 16, Epoch 27/30:\ntrain_loss = 0.3840, val_f1 = 0.8581', '\\n', 'Features 16, Epoch 28/30:\ntrain_loss = 0.3756, val_f1 = 0.8686', '\\n', 'Features 16, Epoch 29/30:\ntrain_loss = 0.3674, val_f1 = 0.8790', '\\n', 'Features 16, Epoch 30/30:\ntrain_loss = 0.3594, val_f1 = 0.8790', '\\n', 'Features 32, Epoch 1/5: train_loss\n= 0.9734, val_f1 = 0.4100', '\\n', 'Features 32, Epoch 2/5: train_loss = 0.8445,\nval_f1 = 0.4455', '\\n', 'Features 32, Epoch 3/5: train_loss = 0.7477, val_f1 =\n0.5435', '\\n', 'Features 32, Epoch 4/5: train_loss = 0.6813, val_f1 = 0.6197',\n'\\n', 'Features 32, Epoch 5/5: train_loss = 0.6390, val_f1 = 0.6559', '\\n',\n'Features 32, Epoch 1/10: train_loss = 0.8153, val_f1 = 0.4851', '\\n', 'Features\n32, Epoch 2/10: train_loss = 0.7328, val_f1 = 0.5780', '\\n', 'Features 32, Epoch\n3/10: train_loss = 0.6782, val_f1 = 0.6495', '\\n', 'Features 32, Epoch 4/10:\ntrain_loss = 0.6391, val_f1 = 0.6819', '\\n', 'Features 32, Epoch 5/10:\ntrain_loss = 0.6072, val_f1 = 0.7246', '\\n', 'Features 32, Epoch 6/10:\ntrain_loss = 0.5793, val_f1 = 0.7545', '\\n', 'Features 32, Epoch 7/10:\ntrain_loss = 0.5538, val_f1 = 0.7581', '\\n', 'Features 32, Epoch 8/10:\ntrain_loss = 0.5312, val_f1 = 0.7692', '\\n', 'Features 32, Epoch 9/10:\ntrain_loss = 0.5115, val_f1 = 0.7496', '\\n', 'Features 32, Epoch 10/10:\ntrain_loss = 0.4935, val_f1 = 0.7400', '\\n', 'Features 32, Epoch 1/20:\ntrain_loss = 0.6690, val_f1 = 0.6391', '\\n', 'Features 32, Epoch 2/20:\ntrain_loss = 0.6228, val_f1 = 0.6986', '\\n', 'Features 32, Epoch 3/20:\ntrain_loss = 0.5966, val_f1 = 0.7464', '\\n', 'Features 32, Epoch 4/20:\ntrain_loss = 0.5758, val_f1 = 0.7464', '\\n', 'Features 32, Epoch 5/20:\ntrain_loss = 0.5538, val_f1 = 0.7475', '\\n', 'Features 32, Epoch 6/20:\ntrain_loss = 0.5328, val_f1 = 0.7291', '\\n', 'Features 32, Epoch 7/20:\ntrain_loss = 0.5144, val_f1 = 0.7499', '\\n', 'Features 32, Epoch 8/20:\ntrain_loss = 0.4988, val_f1 = 0.7499', '\\n', 'Features 32, Epoch 9/20:\ntrain_loss = 0.4847, val_f1 = 0.7598', '\\n', 'Features 32, Epoch 10/20:\ntrain_loss = 0.4708, val_f1 = 0.7897', '\\n', 'Features 32, Epoch 11/20:\ntrain_loss = 0.4562, val_f1 = 0.8099', '\\n', 'Features 32, Epoch 12/20:\ntrain_loss = 0.4410, val_f1 = 0.8000', '\\n', 'Features 32, Epoch 13/20:\ntrain_loss = 0.4262, val_f1 = 0.8297', '\\n', 'Features 32, Epoch 14/20:\ntrain_loss = 0.4121, val_f1 = 0.8599', '\\n', 'Features 32, Epoch 15/20:\ntrain_loss = 0.3982, val_f1 = 0.8700', '\\n', 'Features 32, Epoch 16/20:\ntrain_loss = 0.3844, val_f1 = 0.8700', '\\n', 'Features 32, Epoch 17/20:\ntrain_loss = 0.3709, val_f1 = 0.8700', '\\n', 'Features 32, Epoch 18/20:\ntrain_loss = 0.3574, val_f1 = 0.8800', '\\n', 'Features 32, Epoch 19/20:\ntrain_loss = 0.3442, val_f1 = 0.8700', '\\n', 'Features 32, Epoch 20/20:\ntrain_loss = 0.3314, val_f1 = 0.8700', '\\n', 'Features 32, Epoch 1/30:\ntrain_loss = 0.6854, val_f1 = 0.6499', '\\n', 'Features 32, Epoch 2/30:\ntrain_loss = 0.6483, val_f1 = 0.6998', '\\n', 'Features 32, Epoch 3/30:\ntrain_loss = 0.6187, val_f1 = 0.7500', '\\n', 'Features 32, Epoch 4/30:\ntrain_loss = 0.5929, val_f1 = 0.7699', '\\n', 'Features 32, Epoch 5/30:\ntrain_loss = 0.5699, val_f1 = 0.7496', '\\n', 'Features 32, Epoch 6/30:\ntrain_loss = 0.5488, val_f1 = 0.7594', '\\n', 'Features 32, Epoch 7/30:\ntrain_loss = 0.5288, val_f1 = 0.7491', '\\n', 'Features 32, Epoch 8/30:\ntrain_loss = 0.5096, val_f1 = 0.7594', '\\n', 'Features 32, Epoch 9/30:\ntrain_loss = 0.4907, val_f1 = 0.7798', '\\n', 'Features 32, Epoch 10/30:\ntrain_loss = 0.4722, val_f1 = 0.7798', '\\n', 'Features 32, Epoch 11/30:\ntrain_loss = 0.4541, val_f1 = 0.7899', '\\n', 'Features 32, Epoch 12/30:\ntrain_loss = 0.4363, val_f1 = 0.8299', '\\n', 'Features 32, Epoch 13/30:\ntrain_loss = 0.4189, val_f1 = 0.8299', '\\n', 'Features 32, Epoch 14/30:\ntrain_loss = 0.4021, val_f1 = 0.8400', '\\n', 'Features 32, Epoch 15/30:\ntrain_loss = 0.3856, val_f1 = 0.8400', '\\n', 'Features 32, Epoch 16/30:\ntrain_loss = 0.3697, val_f1 = 0.8700', '\\n', 'Features 32, Epoch 17/30:\ntrain_loss = 0.3541, val_f1 = 0.8800', '\\n', 'Features 32, Epoch 18/30:\ntrain_loss = 0.3387, val_f1 = 0.8999', '\\n', 'Features 32, Epoch 19/30:\ntrain_loss = 0.3237, val_f1 = 0.8900', '\\n', 'Features 32, Epoch 20/30:\ntrain_loss = 0.3089, val_f1 = 0.8900', '\\n', 'Features 32, Epoch 21/30:\ntrain_loss = 0.2944, val_f1 = 0.9000', '\\n', 'Features 32, Epoch 22/30:\ntrain_loss = 0.2804, val_f1 = 0.9200', '\\n', 'Features 32, Epoch 23/30:\ntrain_loss = 0.2669, val_f1 = 0.9300', '\\n', 'Features 32, Epoch 24/30:\ntrain_loss = 0.2540, val_f1 = 0.9500', '\\n', 'Features 32, Epoch 25/30:\ntrain_loss = 0.2415, val_f1 = 0.9600', '\\n', 'Features 32, Epoch 26/30:\ntrain_loss = 0.2294, val_f1 = 0.9600', '\\n', 'Features 32, Epoch 27/30:\ntrain_loss = 0.2178, val_f1 = 0.9600', '\\n', 'Features 32, Epoch 28/30:\ntrain_loss = 0.2066, val_f1 = 0.9600', '\\n', 'Features 32, Epoch 29/30:\ntrain_loss = 0.1959, val_f1 = 0.9600', '\\n', 'Features 32, Epoch 30/30:\ntrain_loss = 0.1857, val_f1 = 0.9700', '\\n', 'Features 64, Epoch 1/5: train_loss\n= 0.6448, val_f1 = 0.8001', '\\n', 'Features 64, Epoch 2/5: train_loss = 0.5377,\nval_f1 = 0.8390', '\\n', 'Features 64, Epoch 3/5: train_loss = 0.4639, val_f1 =\n0.8690', '\\n', 'Features 64, Epoch 4/5: train_loss = 0.4079, val_f1 = 0.8592',\n'\\n', 'Features 64, Epoch 5/5: train_loss = 0.3632, val_f1 = 0.8796', '\\n',\n'Features 64, Epoch 1/10: train_loss = 0.9693, val_f1 = 0.4217', '\\n', 'Features\n64, Epoch 2/10: train_loss = 0.7983, val_f1 = 0.5741', '\\n', 'Features 64, Epoch\n3/10: train_loss = 0.6850, val_f1 = 0.6886', '\\n', 'Features 64, Epoch 4/10:\ntrain_loss = 0.6140, val_f1 = 0.7537', '\\n', 'Features 64, Epoch 5/10:\ntrain_loss = 0.5653, val_f1 = 0.7852', '\\n', 'Features 64, Epoch 6/10:\ntrain_loss = 0.5237, val_f1 = 0.7865', '\\n', 'Features 64, Epoch 7/10:\ntrain_loss = 0.4842, val_f1 = 0.8493', '\\n', 'Features 64, Epoch 8/10:\ntrain_loss = 0.4476, val_f1 = 0.8799', '\\n', 'Features 64, Epoch 9/10:\ntrain_loss = 0.4155, val_f1 = 0.8699', '\\n', 'Features 64, Epoch 10/10:\ntrain_loss = 0.3873, val_f1 = 0.8601', '\\n', 'Features 64, Epoch 1/20:\ntrain_loss = 0.8698, val_f1 = 0.4545', '\\n', 'Features 64, Epoch 2/20:\ntrain_loss = 0.7491, val_f1 = 0.5586', '\\n', 'Features 64, Epoch 3/20:\ntrain_loss = 0.6671, val_f1 = 0.6674', '\\n', 'Features 64, Epoch 4/20:\ntrain_loss = 0.6066, val_f1 = 0.7648', '\\n', 'Features 64, Epoch 5/20:\ntrain_loss = 0.5565, val_f1 = 0.8271', '\\n', 'Features 64, Epoch 6/20:\ntrain_loss = 0.5130, val_f1 = 0.8586', '\\n', 'Features 64, Epoch 7/20:\ntrain_loss = 0.4739, val_f1 = 0.8595', '\\n', 'Features 64, Epoch 8/20:\ntrain_loss = 0.4384, val_f1 = 0.8595', '\\n', 'Features 64, Epoch 9/20:\ntrain_loss = 0.4064, val_f1 = 0.8595', '\\n', 'Features 64, Epoch 10/20:\ntrain_loss = 0.3772, val_f1 = 0.8497', '\\n', 'Features 64, Epoch 11/20:\ntrain_loss = 0.3503, val_f1 = 0.8598', '\\n', 'Features 64, Epoch 12/20:\ntrain_loss = 0.3256, val_f1 = 0.8699', '\\n', 'Features 64, Epoch 13/20:\ntrain_loss = 0.3023, val_f1 = 0.9000', '\\n', 'Features 64, Epoch 14/20:\ntrain_loss = 0.2803, val_f1 = 0.9100', '\\n', 'Features 64, Epoch 15/20:\ntrain_loss = 0.2596, val_f1 = 0.9400', '\\n', 'Features 64, Epoch 16/20:\ntrain_loss = 0.2405, val_f1 = 0.9300', '\\n', 'Features 64, Epoch 17/20:\ntrain_loss = 0.2234, val_f1 = 0.9200', '\\n', 'Features 64, Epoch 18/20:\ntrain_loss = 0.2084, val_f1 = 0.9300', '\\n', 'Features 64, Epoch 19/20:\ntrain_loss = 0.1953, val_f1 = 0.9500', '\\n', 'Features 64, Epoch 20/20:\ntrain_loss = 0.1836, val_f1 = 0.9500', '\\n', 'Features 64, Epoch 1/30:\ntrain_loss = 0.7505, val_f1 = 0.6092', '\\n', 'Features 64, Epoch 2/30:\ntrain_loss = 0.6331, val_f1 = 0.7288', '\\n', 'Features 64, Epoch 3/30:\ntrain_loss = 0.5563, val_f1 = 0.7769', '\\n', 'Features 64, Epoch 4/30:\ntrain_loss = 0.4973, val_f1 = 0.8287', '\\n', 'Features 64, Epoch 5/30:\ntrain_loss = 0.4461, val_f1 = 0.8697', '\\n', 'Features 64, Epoch 6/30:\ntrain_loss = 0.4020, val_f1 = 0.8899', '\\n', 'Features 64, Epoch 7/30:\ntrain_loss = 0.3651, val_f1 = 0.9000', '\\n', 'Features 64, Epoch 8/30:\ntrain_loss = 0.3345, val_f1 = 0.9000', '\\n', 'Features 64, Epoch 9/30:\ntrain_loss = 0.3078, val_f1 = 0.9000', '\\n', 'Features 64, Epoch 10/30:\ntrain_loss = 0.2838, val_f1 = 0.9200', '\\n', 'Features 64, Epoch 11/30:\ntrain_loss = 0.2616, val_f1 = 0.9400', '\\n', 'Features 64, Epoch 12/30:\ntrain_loss = 0.2412, val_f1 = 0.9500', '\\n', 'Features 64, Epoch 13/30:\ntrain_loss = 0.2228, val_f1 = 0.9500', '\\n', 'Features 64, Epoch 14/30:\ntrain_loss = 0.2063, val_f1 = 0.9500', '\\n', 'Features 64, Epoch 15/30:\ntrain_loss = 0.1913, val_f1 = 0.9700', '\\n', 'Features 64, Epoch 16/30:\ntrain_loss = 0.1775, val_f1 = 0.9700', '\\n', 'Features 64, Epoch 17/30:\ntrain_loss = 0.1650, val_f1 = 0.9800', '\\n', 'Features 64, Epoch 18/30:\ntrain_loss = 0.1536, val_f1 = 0.9800', '\\n', 'Features 64, Epoch 19/30:\ntrain_loss = 0.1431, val_f1 = 0.9800', '\\n', 'Features 64, Epoch 20/30:\ntrain_loss = 0.1334, val_f1 = 0.9800', '\\n', 'Features 64, Epoch 21/30:\ntrain_loss = 0.1241, val_f1 = 0.9800', '\\n', 'Features 64, Epoch 22/30:\ntrain_loss = 0.1153, val_f1 = 0.9800', '\\n', 'Features 64, Epoch 23/30:\ntrain_loss = 0.1068, val_f1 = 0.9800', '\\n', 'Features 64, Epoch 24/30:\ntrain_loss = 0.0991, val_f1 = 0.9900', '\\n', 'Features 64, Epoch 25/30:\ntrain_loss = 0.0919, val_f1 = 1.0000', '\\n', 'Features 64, Epoch 26/30:\ntrain_loss = 0.0854, val_f1 = 1.0000', '\\n', 'Features 64, Epoch 27/30:\ntrain_loss = 0.0794, val_f1 = 1.0000', '\\n', 'Features 64, Epoch 28/30:\ntrain_loss = 0.0739, val_f1 = 1.0000', '\\n', 'Features 64, Epoch 29/30:\ntrain_loss = 0.0688, val_f1 = 1.0000', '\\n', 'Features 64, Epoch 30/30:\ntrain_loss = 0.0641, val_f1 = 1.0000', '\\n', 'Execution time: a second seconds\n(time limit is an hour).']", "['Using device: cpu', '\\n', 'Features 8, Epoch 1/5: train_loss = 0.7332, val_f1\n= 0.5400', '\\n', 'Features 8, Epoch 2/5: train_loss = 0.6984, val_f1 = 0.6158',\n'\\n', 'Features 8, Epoch 3/5: train_loss = 0.6765, val_f1 = 0.5721', '\\n',\n'Features 8, Epoch 4/5: train_loss = 0.6649, val_f1 = 0.5388', '\\n', 'Features\n8, Epoch 5/5: train_loss = 0.6595, val_f1 = 0.4792', '\\n', 'Features 8, Epoch\n1/10: train_loss = 0.7380, val_f1 = 0.5210', '\\n', 'Features 8, Epoch 2/10:\ntrain_loss = 0.7102, val_f1 = 0.5386', '\\n', 'Features 8, Epoch 3/10: train_loss\n= 0.6908, val_f1 = 0.5616', '\\n', 'Features 8, Epoch 4/10: train_loss = 0.6776,\nval_f1 = 0.5771', '\\n', 'Features 8, Epoch 5/10: train_loss = 0.6673, val_f1 =\n0.5771', '\\n', 'Features 8, Epoch 6/10: train_loss = 0.6582, val_f1 = 0.5761',\n'\\n', 'Features 8, Epoch 7/10: train_loss = 0.6495, val_f1 = 0.6043', '\\n',\n'Features 8, Epoch 8/10: train_loss = 0.6414, val_f1 = 0.6012', '\\n', 'Features\n8, Epoch 9/10: train_loss = 0.6342, val_f1 = 0.6143', '\\n', 'Features 8, Epoch\n10/10: train_loss = 0.6279, val_f1 = 0.5975', '\\n', 'Features 8, Epoch 1/20:\ntrain_loss = 0.8144, val_f1 = 0.3345', '\\n', 'Features 8, Epoch 2/20: train_loss\n= 0.7595, val_f1 = 0.4031', '\\n', 'Features 8, Epoch 3/20: train_loss = 0.7232,\nval_f1 = 0.4785', '\\n', 'Features 8, Epoch 4/20: train_loss = 0.7016, val_f1 =\n0.4568', '\\n', 'Features 8, Epoch 5/20: train_loss = 0.6902, val_f1 = 0.4869',\n'\\n', 'Features 8, Epoch 6/20: train_loss = 0.6833, val_f1 = 0.5302', '\\n',\n'Features 8, Epoch 7/20: train_loss = 0.6772, val_f1 = 0.5137', '\\n', 'Features\n8, Epoch 8/20: train_loss = 0.6705, val_f1 = 0.5229', '\\n', 'Features 8, Epoch\n9/20: train_loss = 0.6622, val_f1 = 0.5229', '\\n', 'Features 8, Epoch 10/20:\ntrain_loss = 0.6529, val_f1 = 0.5823', '\\n', 'Features 8, Epoch 11/20:\ntrain_loss = 0.6435, val_f1 = 0.6059', '\\n', 'Features 8, Epoch 12/20:\ntrain_loss = 0.6349, val_f1 = 0.6138', '\\n', 'Features 8, Epoch 13/20:\ntrain_loss = 0.6278, val_f1 = 0.6172', '\\n', 'Features 8, Epoch 14/20:\ntrain_loss = 0.6221, val_f1 = 0.6521', '\\n', 'Features 8, Epoch 15/20:\ntrain_loss = 0.6172, val_f1 = 0.6431', '\\n', 'Features 8, Epoch 16/20:\ntrain_loss = 0.6127, val_f1 = 0.6340', '\\n', 'Features 8, Epoch 17/20:\ntrain_loss = 0.6082, val_f1 = 0.6431', '\\n', 'Features 8, Epoch 18/20:\ntrain_loss = 0.6032, val_f1 = 0.6562', '\\n', 'Features 8, Epoch 19/20:\ntrain_loss = 0.5978, val_f1 = 0.6562', '\\n', 'Features 8, Epoch 20/20:\ntrain_loss = 0.5920, val_f1 = 0.6543', '\\n', 'Features 8, Epoch 1/30: train_loss\n= 0.7236, val_f1 = 0.4884', '\\n', 'Features 8, Epoch 2/30: train_loss = 0.7049,\nval_f1 = 0.4836', '\\n', 'Features 8, Epoch 3/30: train_loss = 0.6907, val_f1 =\n0.4858', '\\n', 'Features 8, Epoch 4/30: train_loss = 0.6792, val_f1 = 0.4934',\n'\\n', 'Features 8, Epoch 5/30: train_loss = 0.6690, val_f1 = 0.5366', '\\n',\n'Features 8, Epoch 6/30: train_loss = 0.6598, val_f1 = 0.5286', '\\n', 'Features\n8, Epoch 7/30: train_loss = 0.6515, val_f1 = 0.5420', '\\n', 'Features 8, Epoch\n8/30: train_loss = 0.6443, val_f1 = 0.5844', '\\n', 'Features 8, Epoch 9/30:\ntrain_loss = 0.6378, val_f1 = 0.5965', '\\n', 'Features 8, Epoch 10/30:\ntrain_loss = 0.6319, val_f1 = 0.5721', '\\n', 'Features 8, Epoch 11/30:\ntrain_loss = 0.6264, val_f1 = 0.5512', '\\n', 'Features 8, Epoch 12/30:\ntrain_loss = 0.6211, val_f1 = 0.5512', '\\n', 'Features 8, Epoch 13/30:\ntrain_loss = 0.6161, val_f1 = 0.5428', '\\n', 'Features 8, Epoch 14/30:\ntrain_loss = 0.6110, val_f1 = 0.5596', '\\n', 'Features 8, Epoch 15/30:\ntrain_loss = 0.6059, val_f1 = 0.5844', '\\n', 'Features 8, Epoch 16/30:\ntrain_loss = 0.6008, val_f1 = 0.5844', '\\n', 'Features 8, Epoch 17/30:\ntrain_loss = 0.5953, val_f1 = 0.5930', '\\n', 'Features 8, Epoch 18/30:\ntrain_loss = 0.5894, val_f1 = 0.5965', '\\n', 'Features 8, Epoch 19/30:\ntrain_loss = 0.5834, val_f1 = 0.6084', '\\n', 'Features 8, Epoch 20/30:\ntrain_loss = 0.5773, val_f1 = 0.6317', '\\n', 'Features 8, Epoch 21/30:\ntrain_loss = 0.5709, val_f1 = 0.6654', '\\n', 'Features 8, Epoch 22/30:\ntrain_loss = 0.5644, val_f1 = 0.6764', '\\n', 'Features 8, Epoch 23/30:\ntrain_loss = 0.5576, val_f1 = 0.7087', '\\n', 'Features 8, Epoch 24/30:\ntrain_loss = 0.5506, val_f1 = 0.6991', '\\n', 'Features 8, Epoch 25/30:\ntrain_loss = 0.5435, val_f1 = 0.7096', '\\n', 'Features 8, Epoch 26/30:\ntrain_loss = 0.5362, val_f1 = 0.7296', '\\n', 'Features 8, Epoch 27/30:\ntrain_loss = 0.5287, val_f1 = 0.7689', '\\n', 'Features 8, Epoch 28/30:\ntrain_loss = 0.5210, val_f1 = 0.8091', '\\n', 'Features 8, Epoch 29/30:\ntrain_loss = 0.5132, val_f1 = 0.8097', '\\n', 'Features 8, Epoch 30/30:\ntrain_loss = 0.5055, val_f1 = 0.7994', '\\n', 'Features 16, Epoch 1/5: train_loss\n= 0.7692, val_f1 = 0.5510', '\\n', 'Features 16, Epoch 2/5: train_loss = 0.7261,\nval_f1 = 0.6123', '\\n', 'Features 16, Epoch 3/5: train_loss = 0.6911, val_f1 =\n0.6181', '\\n', 'Features 16, Epoch 4/5: train_loss = 0.6626, val_f1 = 0.6594',\n'\\n', 'Features 16, Epoch 5/5: train_loss = 0.6393, val_f1 = 0.6891', '\\n',\n'Features 16, Epoch 1/10: train_loss = 0.6936, val_f1 = 0.5236', '\\n', 'Features\n16, Epoch 2/10: train_loss = 0.6641, val_f1 = 0.5772', '\\n', 'Features 16, Epoch\n3/10: train_loss = 0.6392, val_f1 = 0.5983', '\\n', 'Features 16, Epoch 4/10:\ntrain_loss = 0.6179, val_f1 = 0.6061', '\\n', 'Features 16, Epoch 5/10:\ntrain_loss = 0.5993, val_f1 = 0.6320', '\\n', 'Features 16, Epoch 6/10:\ntrain_loss = 0.5829, val_f1 = 0.6683', '\\n', 'Features 16, Epoch 7/10:\ntrain_loss = 0.5678, val_f1 = 0.6891', '\\n', 'Features 16, Epoch 8/10:\ntrain_loss = 0.5539, val_f1 = 0.7007', '\\n', 'Features 16, Epoch 9/10:\ntrain_loss = 0.5407, val_f1 = 0.7007', '\\n', 'Features 16, Epoch 10/10:\ntrain_loss = 0.5284, val_f1 = 0.7007', '\\n', 'Features 16, Epoch 1/20:\ntrain_loss = 0.6752, val_f1 = 0.6388', '\\n', 'Features 16, Epoch 2/20:\ntrain_loss = 0.6462, val_f1 = 0.6450', '\\n', 'Features 16, Epoch 3/20:\ntrain_loss = 0.6280, val_f1 = 0.6351', '\\n', 'Features 16, Epoch 4/20:\ntrain_loss = 0.6133, val_f1 = 0.6268', '\\n', 'Features 16, Epoch 5/20:\ntrain_loss = 0.5991, val_f1 = 0.6792', '\\n', 'Features 16, Epoch 6/20:\ntrain_loss = 0.5852, val_f1 = 0.6829', '\\n', 'Features 16, Epoch 7/20:\ntrain_loss = 0.5720, val_f1 = 0.6862', '\\n', 'Features 16, Epoch 8/20:\ntrain_loss = 0.5599, val_f1 = 0.7327', '\\n', 'Features 16, Epoch 9/20:\ntrain_loss = 0.5491, val_f1 = 0.7143', '\\n', 'Features 16, Epoch 10/20:\ntrain_loss = 0.5394, val_f1 = 0.7364', '\\n', 'Features 16, Epoch 11/20:\ntrain_loss = 0.5302, val_f1 = 0.7473', '\\n', 'Features 16, Epoch 12/20:\ntrain_loss = 0.5211, val_f1 = 0.7378', '\\n', 'Features 16, Epoch 13/20:\ntrain_loss = 0.5120, val_f1 = 0.7473', '\\n', 'Features 16, Epoch 14/20:\ntrain_loss = 0.5031, val_f1 = 0.7473', '\\n', 'Features 16, Epoch 15/20:\ntrain_loss = 0.4945, val_f1 = 0.7364', '\\n', 'Features 16, Epoch 16/20:\ntrain_loss = 0.4863, val_f1 = 0.7364', '\\n', 'Features 16, Epoch 17/20:\ntrain_loss = 0.4782, val_f1 = 0.7378', '\\n', 'Features 16, Epoch 18/20:\ntrain_loss = 0.4699, val_f1 = 0.7473', '\\n', 'Features 16, Epoch 19/20:\ntrain_loss = 0.4616, val_f1 = 0.7782', '\\n', 'Features 16, Epoch 20/20:\ntrain_loss = 0.4530, val_f1 = 0.7877', '\\n', 'Features 16, Epoch 1/30:\ntrain_loss = 0.7131, val_f1 = 0.5397', '\\n', 'Features 16, Epoch 2/30:\ntrain_loss = 0.6815, val_f1 = 0.5470', '\\n', 'Features 16, Epoch 3/30:\ntrain_loss = 0.6591, val_f1 = 0.5619', '\\n', 'Features 16, Epoch 4/30:\ntrain_loss = 0.6398, val_f1 = 0.6434', '\\n', 'Features 16, Epoch 5/30:\ntrain_loss = 0.6215, val_f1 = 0.7220', '\\n', 'Features 16, Epoch 6/30:\ntrain_loss = 0.6045, val_f1 = 0.7252', '\\n', 'Features 16, Epoch 7/30:\ntrain_loss = 0.5894, val_f1 = 0.7214', '\\n', 'Features 16, Epoch 8/30:\ntrain_loss = 0.5759, val_f1 = 0.7161', '\\n', 'Features 16, Epoch 9/30:\ntrain_loss = 0.5637, val_f1 = 0.7254', '\\n', 'Features 16, Epoch 10/30:\ntrain_loss = 0.5521, val_f1 = 0.7161', '\\n', 'Features 16, Epoch 11/30:\ntrain_loss = 0.5408, val_f1 = 0.7254', '\\n', 'Features 16, Epoch 12/30:\ntrain_loss = 0.5296, val_f1 = 0.7364', '\\n', 'Features 16, Epoch 13/30:\ntrain_loss = 0.5188, val_f1 = 0.7364', '\\n', 'Features 16, Epoch 14/30:\ntrain_loss = 0.5085, val_f1 = 0.7458', '\\n', 'Features 16, Epoch 15/30:\ntrain_loss = 0.4986, val_f1 = 0.7661', '\\n', 'Features 16, Epoch 16/30:\ntrain_loss = 0.4888, val_f1 = 0.7661', '\\n', 'Features 16, Epoch 17/30:\ntrain_loss = 0.4790, val_f1 = 0.7645', '\\n', 'Features 16, Epoch 18/30:\ntrain_loss = 0.4690, val_f1 = 0.7864', '\\n', 'Features 16, Epoch 19/30:\ntrain_loss = 0.4591, val_f1 = 0.7864', '\\n', 'Features 16, Epoch 20/30:\ntrain_loss = 0.4493, val_f1 = 0.8079', '\\n', 'Features 16, Epoch 21/30:\ntrain_loss = 0.4396, val_f1 = 0.7983', '\\n', 'Features 16, Epoch 22/30:\ntrain_loss = 0.4301, val_f1 = 0.8089', '\\n', 'Features 16, Epoch 23/30:\ntrain_loss = 0.4205, val_f1 = 0.8193', '\\n', 'Features 16, Epoch 24/30:\ntrain_loss = 0.4110, val_f1 = 0.8387', '\\n', 'Features 16, Epoch 25/30:\ntrain_loss = 0.4017, val_f1 = 0.8491', '\\n', 'Features 16, Epoch 26/30:\ntrain_loss = 0.3926, val_f1 = 0.8484', '\\n', 'Features 16, Epoch 27/30:\ntrain_loss = 0.3840, val_f1 = 0.8581', '\\n', 'Features 16, Epoch 28/30:\ntrain_loss = 0.3756, val_f1 = 0.8686', '\\n', 'Features 16, Epoch 29/30:\ntrain_loss = 0.3674, val_f1 = 0.8790', '\\n', 'Features 16, Epoch 30/30:\ntrain_loss = 0.3594, val_f1 = 0.8790', '\\n', 'Features 32, Epoch 1/5: train_loss\n= 0.9734, val_f1 = 0.4100', '\\n', 'Features 32, Epoch 2/5: train_loss = 0.8445,\nval_f1 = 0.4455', '\\n', 'Features 32, Epoch 3/5: train_loss = 0.7477, val_f1 =\n0.5435', '\\n', 'Features 32, Epoch 4/5: train_loss = 0.6813, val_f1 = 0.6197',\n'\\n', 'Features 32, Epoch 5/5: train_loss = 0.6390, val_f1 = 0.6559', '\\n',\n'Features 32, Epoch 1/10: train_loss = 0.8153, val_f1 = 0.4851', '\\n', 'Features\n32, Epoch 2/10: train_loss = 0.7328, val_f1 = 0.5780', '\\n', 'Features 32, Epoch\n3/10: train_loss = 0.6782, val_f1 = 0.6495', '\\n', 'Features 32, Epoch 4/10:\ntrain_loss = 0.6391, val_f1 = 0.6819', '\\n', 'Features 32, Epoch 5/10:\ntrain_loss = 0.6072, val_f1 = 0.7246', '\\n', 'Features 32, Epoch 6/10:\ntrain_loss = 0.5793, val_f1 = 0.7545', '\\n', 'Features 32, Epoch 7/10:\ntrain_loss = 0.5538, val_f1 = 0.7581', '\\n', 'Features 32, Epoch 8/10:\ntrain_loss = 0.5312, val_f1 = 0.7692', '\\n', 'Features 32, Epoch 9/10:\ntrain_loss = 0.5115, val_f1 = 0.7496', '\\n', 'Features 32, Epoch 10/10:\ntrain_loss = 0.4935, val_f1 = 0.7400', '\\n', 'Features 32, Epoch 1/20:\ntrain_loss = 0.6690, val_f1 = 0.6391', '\\n', 'Features 32, Epoch 2/20:\ntrain_loss = 0.6228, val_f1 = 0.6986', '\\n', 'Features 32, Epoch 3/20:\ntrain_loss = 0.5966, val_f1 = 0.7464', '\\n', 'Features 32, Epoch 4/20:\ntrain_loss = 0.5758, val_f1 = 0.7464', '\\n', 'Features 32, Epoch 5/20:\ntrain_loss = 0.5538, val_f1 = 0.7475', '\\n', 'Features 32, Epoch 6/20:\ntrain_loss = 0.5328, val_f1 = 0.7291', '\\n', 'Features 32, Epoch 7/20:\ntrain_loss = 0.5144, val_f1 = 0.7499', '\\n', 'Features 32, Epoch 8/20:\ntrain_loss = 0.4988, val_f1 = 0.7499', '\\n', 'Features 32, Epoch 9/20:\ntrain_loss = 0.4847, val_f1 = 0.7598', '\\n', 'Features 32, Epoch 10/20:\ntrain_loss = 0.4708, val_f1 = 0.7897', '\\n', 'Features 32, Epoch 11/20:\ntrain_loss = 0.4562, val_f1 = 0.8099', '\\n', 'Features 32, Epoch 12/20:\ntrain_loss = 0.4410, val_f1 = 0.8000', '\\n', 'Features 32, Epoch 13/20:\ntrain_loss = 0.4262, val_f1 = 0.8297', '\\n', 'Features 32, Epoch 14/20:\ntrain_loss = 0.4121, val_f1 = 0.8599', '\\n', 'Features 32, Epoch 15/20:\ntrain_loss = 0.3982, val_f1 = 0.8700', '\\n', 'Features 32, Epoch 16/20:\ntrain_loss = 0.3844, val_f1 = 0.8700', '\\n', 'Features 32, Epoch 17/20:\ntrain_loss = 0.3709, val_f1 = 0.8700', '\\n', 'Features 32, Epoch 18/20:\ntrain_loss = 0.3574, val_f1 = 0.8800', '\\n', 'Features 32, Epoch 19/20:\ntrain_loss = 0.3442, val_f1 = 0.8700', '\\n', 'Features 32, Epoch 20/20:\ntrain_loss = 0.3314, val_f1 = 0.8700', '\\n', 'Features 32, Epoch 1/30:\ntrain_loss = 0.6854, val_f1 = 0.6499', '\\n', 'Features 32, Epoch 2/30:\ntrain_loss = 0.6483, val_f1 = 0.6998', '\\n', 'Features 32, Epoch 3/30:\ntrain_loss = 0.6187, val_f1 = 0.7500', '\\n', 'Features 32, Epoch 4/30:\ntrain_loss = 0.5929, val_f1 = 0.7699', '\\n', 'Features 32, Epoch 5/30:\ntrain_loss = 0.5699, val_f1 = 0.7496', '\\n', 'Features 32, Epoch 6/30:\ntrain_loss = 0.5488, val_f1 = 0.7594', '\\n', 'Features 32, Epoch 7/30:\ntrain_loss = 0.5288, val_f1 = 0.7491', '\\n', 'Features 32, Epoch 8/30:\ntrain_loss = 0.5096, val_f1 = 0.7594', '\\n', 'Features 32, Epoch 9/30:\ntrain_loss = 0.4907, val_f1 = 0.7798', '\\n', 'Features 32, Epoch 10/30:\ntrain_loss = 0.4722, val_f1 = 0.7798', '\\n', 'Features 32, Epoch 11/30:\ntrain_loss = 0.4541, val_f1 = 0.7899', '\\n', 'Features 32, Epoch 12/30:\ntrain_loss = 0.4363, val_f1 = 0.8299', '\\n', 'Features 32, Epoch 13/30:\ntrain_loss = 0.4189, val_f1 = 0.8299', '\\n', 'Features 32, Epoch 14/30:\ntrain_loss = 0.4021, val_f1 = 0.8400', '\\n', 'Features 32, Epoch 15/30:\ntrain_loss = 0.3856, val_f1 = 0.8400', '\\n', 'Features 32, Epoch 16/30:\ntrain_loss = 0.3697, val_f1 = 0.8700', '\\n', 'Features 32, Epoch 17/30:\ntrain_loss = 0.3541, val_f1 = 0.8800', '\\n', 'Features 32, Epoch 18/30:\ntrain_loss = 0.3387, val_f1 = 0.8999', '\\n', 'Features 32, Epoch 19/30:\ntrain_loss = 0.3237, val_f1 = 0.8900', '\\n', 'Features 32, Epoch 20/30:\ntrain_loss = 0.3089, val_f1 = 0.8900', '\\n', 'Features 32, Epoch 21/30:\ntrain_loss = 0.2944, val_f1 = 0.9000', '\\n', 'Features 32, Epoch 22/30:\ntrain_loss = 0.2804, val_f1 = 0.9200', '\\n', 'Features 32, Epoch 23/30:\ntrain_loss = 0.2669, val_f1 = 0.9300', '\\n', 'Features 32, Epoch 24/30:\ntrain_loss = 0.2540, val_f1 = 0.9500', '\\n', 'Features 32, Epoch 25/30:\ntrain_loss = 0.2415, val_f1 = 0.9600', '\\n', 'Features 32, Epoch 26/30:\ntrain_loss = 0.2294, val_f1 = 0.9600', '\\n', 'Features 32, Epoch 27/30:\ntrain_loss = 0.2178, val_f1 = 0.9600', '\\n', 'Features 32, Epoch 28/30:\ntrain_loss = 0.2066, val_f1 = 0.9600', '\\n', 'Features 32, Epoch 29/30:\ntrain_loss = 0.1959, val_f1 = 0.9600', '\\n', 'Features 32, Epoch 30/30:\ntrain_loss = 0.1857, val_f1 = 0.9700', '\\n', 'Features 64, Epoch 1/5: train_loss\n= 0.6448, val_f1 = 0.8001', '\\n', 'Features 64, Epoch 2/5: train_loss = 0.5377,\nval_f1 = 0.8390', '\\n', 'Features 64, Epoch 3/5: train_loss = 0.4639, val_f1 =\n0.8690', '\\n', 'Features 64, Epoch 4/5: train_loss = 0.4079, val_f1 = 0.8592',\n'\\n', 'Features 64, Epoch 5/5: train_loss = 0.3632, val_f1 = 0.8796', '\\n',\n'Features 64, Epoch 1/10: train_loss = 0.9693, val_f1 = 0.4217', '\\n', 'Features\n64, Epoch 2/10: train_loss = 0.7983, val_f1 = 0.5741', '\\n', 'Features 64, Epoch\n3/10: train_loss = 0.6850, val_f1 = 0.6886', '\\n', 'Features 64, Epoch 4/10:\ntrain_loss = 0.6140, val_f1 = 0.7537', '\\n', 'Features 64, Epoch 5/10:\ntrain_loss = 0.5653, val_f1 = 0.7852', '\\n', 'Features 64, Epoch 6/10:\ntrain_loss = 0.5237, val_f1 = 0.7865', '\\n', 'Features 64, Epoch 7/10:\ntrain_loss = 0.4842, val_f1 = 0.8493', '\\n', 'Features 64, Epoch 8/10:\ntrain_loss = 0.4476, val_f1 = 0.8799', '\\n', 'Features 64, Epoch 9/10:\ntrain_loss = 0.4155, val_f1 = 0.8699', '\\n', 'Features 64, Epoch 10/10:\ntrain_loss = 0.3873, val_f1 = 0.8601', '\\n', 'Features 64, Epoch 1/20:\ntrain_loss = 0.8698, val_f1 = 0.4545', '\\n', 'Features 64, Epoch 2/20:\ntrain_loss = 0.7491, val_f1 = 0.5586', '\\n', 'Features 64, Epoch 3/20:\ntrain_loss = 0.6671, val_f1 = 0.6674', '\\n', 'Features 64, Epoch 4/20:\ntrain_loss = 0.6066, val_f1 = 0.7648', '\\n', 'Features 64, Epoch 5/20:\ntrain_loss = 0.5565, val_f1 = 0.8271', '\\n', 'Features 64, Epoch 6/20:\ntrain_loss = 0.5130, val_f1 = 0.8586', '\\n', 'Features 64, Epoch 7/20:\ntrain_loss = 0.4739, val_f1 = 0.8595', '\\n', 'Features 64, Epoch 8/20:\ntrain_loss = 0.4384, val_f1 = 0.8595', '\\n', 'Features 64, Epoch 9/20:\ntrain_loss = 0.4064, val_f1 = 0.8595', '\\n', 'Features 64, Epoch 10/20:\ntrain_loss = 0.3772, val_f1 = 0.8497', '\\n', 'Features 64, Epoch 11/20:\ntrain_loss = 0.3503, val_f1 = 0.8598', '\\n', 'Features 64, Epoch 12/20:\ntrain_loss = 0.3256, val_f1 = 0.8699', '\\n', 'Features 64, Epoch 13/20:\ntrain_loss = 0.3023, val_f1 = 0.9000', '\\n', 'Features 64, Epoch 14/20:\ntrain_loss = 0.2803, val_f1 = 0.9100', '\\n', 'Features 64, Epoch 15/20:\ntrain_loss = 0.2596, val_f1 = 0.9400', '\\n', 'Features 64, Epoch 16/20:\ntrain_loss = 0.2405, val_f1 = 0.9300', '\\n', 'Features 64, Epoch 17/20:\ntrain_loss = 0.2234, val_f1 = 0.9200', '\\n', 'Features 64, Epoch 18/20:\ntrain_loss = 0.2084, val_f1 = 0.9300', '\\n', 'Features 64, Epoch 19/20:\ntrain_loss = 0.1953, val_f1 = 0.9500', '\\n', 'Features 64, Epoch 20/20:\ntrain_loss = 0.1836, val_f1 = 0.9500', '\\n', 'Features 64, Epoch 1/30:\ntrain_loss = 0.7505, val_f1 = 0.6092', '\\n', 'Features 64, Epoch 2/30:\ntrain_loss = 0.6331, val_f1 = 0.7288', '\\n', 'Features 64, Epoch 3/30:\ntrain_loss = 0.5563, val_f1 = 0.7769', '\\n', 'Features 64, Epoch 4/30:\ntrain_loss = 0.4973, val_f1 = 0.8287', '\\n', 'Features 64, Epoch 5/30:\ntrain_loss = 0.4461, val_f1 = 0.8697', '\\n', 'Features 64, Epoch 6/30:\ntrain_loss = 0.4020, val_f1 = 0.8899', '\\n', 'Features 64, Epoch 7/30:\ntrain_loss = 0.3651, val_f1 = 0.9000', '\\n', 'Features 64, Epoch 8/30:\ntrain_loss = 0.3345, val_f1 = 0.9000', '\\n', 'Features 64, Epoch 9/30:\ntrain_loss = 0.3078, val_f1 = 0.9000', '\\n', 'Features 64, Epoch 10/30:\ntrain_loss = 0.2838, val_f1 = 0.9200', '\\n', 'Features 64, Epoch 11/30:\ntrain_loss = 0.2616, val_f1 = 0.9400', '\\n', 'Features 64, Epoch 12/30:\ntrain_loss = 0.2412, val_f1 = 0.9500', '\\n', 'Features 64, Epoch 13/30:\ntrain_loss = 0.2228, val_f1 = 0.9500', '\\n', 'Features 64, Epoch 14/30:\ntrain_loss = 0.2063, val_f1 = 0.9500', '\\n', 'Features 64, Epoch 15/30:\ntrain_loss = 0.1913, val_f1 = 0.9700', '\\n', 'Features 64, Epoch 16/30:\ntrain_loss = 0.1775, val_f1 = 0.9700', '\\n', 'Features 64, Epoch 17/30:\ntrain_loss = 0.1650, val_f1 = 0.9800', '\\n', 'Features 64, Epoch 18/30:\ntrain_loss = 0.1536, val_f1 = 0.9800', '\\n', 'Features 64, Epoch 19/30:\ntrain_loss = 0.1431, val_f1 = 0.9800', '\\n', 'Features 64, Epoch 20/30:\ntrain_loss = 0.1334, val_f1 = 0.9800', '\\n', 'Features 64, Epoch 21/30:\ntrain_loss = 0.1241, val_f1 = 0.9800', '\\n', 'Features 64, Epoch 22/30:\ntrain_loss = 0.1153, val_f1 = 0.9800', '\\n', 'Features 64, Epoch 23/30:\ntrain_loss = 0.1068, val_f1 = 0.9800', '\\n', 'Features 64, Epoch 24/30:\ntrain_loss = 0.0991, val_f1 = 0.9900', '\\n', 'Features 64, Epoch 25/30:\ntrain_loss = 0.0919, val_f1 = 1.0000', '\\n', 'Features 64, Epoch 26/30:\ntrain_loss = 0.0854, val_f1 = 1.0000', '\\n', 'Features 64, Epoch 27/30:\ntrain_loss = 0.0794, val_f1 = 1.0000', '\\n', 'Features 64, Epoch 28/30:\ntrain_loss = 0.0739, val_f1 = 1.0000', '\\n', 'Features 64, Epoch 29/30:\ntrain_loss = 0.0688, val_f1 = 1.0000', '\\n', 'Features 64, Epoch 30/30:\ntrain_loss = 0.0641, val_f1 = 1.0000', '\\n', 'Execution time: a second seconds\n(time limit is an hour).']", ""], "analysis": ["", "", "The execution output indicates a KeyError for the key 'sparse' in the\nexperiment_data dictionary. This suggests that the 'sparse' key was not properly\ninitialized in the experiment_data structure before it was accessed. To fix\nthis, ensure that the structure for 'sparse', 'dense', and 'random' connectivity\ntypes is correctly set up in the experiment_data dictionary before the training\nloop begins.", "", "", "", "", "", "", "", "", "", ""], "exc_type": [null, null, "KeyError", null, null, null, null, null, null, null, null, null, null], "exc_info": [null, null, {"args": ["sparse"]}, null, null, null, null, null, null, null, null, null, null], "exc_stack": [null, null, [["/Users/fourzeroo/repos/ai_scientist/ai_scientists/AI-Scientist-V2/ai_scientist/treesearch/interpreter.py", 144, "_run_session", "exec(compile(code, self.agent_file_name, \"exec\"), global_scope)"], ["runfile.py", 139, "<module>", "experiment_data[\"edge_connectivity_ablation\"][connectivity][\"losses\"]["]], null, null, null, null, null, null, null, null, null, null], "exp_name": "0-run", "metrics": [{"metric_names": [{"metric_name": "validation F1 score", "lower_is_better": false, "description": "The F1 score calculated on the validation dataset, representing the balance between precision and recall.", "data": [{"dataset_name": "synthetic_dynamic_network", "final_value": 0.8900330297267541, "best_value": 0.8900330297267541}]}]}, {"metric_names": [{"metric_name": "validation F1 score", "lower_is_better": false, "description": "The F1 score calculated on the validation dataset, indicating the balance between precision and recall.", "data": [{"dataset_name": "synthetic_dynamic_network", "final_value": 1.0, "best_value": 1.0}]}]}, {"metric_names": [{"metric_name": "value", "lower_is_better": true, "description": "", "data": [{"dataset_name": "default", "final_value": null, "best_value": null}]}]}, {"metric_names": [{"metric_name": "training loss", "lower_is_better": true, "description": "The loss value during training, indicating how well the model is learning.", "data": [{"dataset_name": "synthetic_dynamic_network", "final_value": 0.3812828063964844, "best_value": 0.3812828063964844}]}, {"metric_name": "validation F1 score", "lower_is_better": false, "description": "The F1 score on the validation set, measuring the balance between precision and recall.", "data": [{"dataset_name": "synthetic_dynamic_network", "final_value": 0.9100270243218899, "best_value": 0.9100270243218899}]}]}, {"metric_names": [{"metric_name": "train loss", "lower_is_better": true, "description": "Final training loss after training on the dataset", "data": [{"dataset_name": "sparse", "final_value": 0.3604, "best_value": 0.3604}, {"dataset_name": "dense", "final_value": 0.4413, "best_value": 0.4413}, {"dataset_name": "random", "final_value": 0.2274, "best_value": 0.2274}]}, {"metric_name": "validation F1 score", "lower_is_better": false, "description": "Best validation F1 score achieved during training", "data": [{"dataset_name": "sparse", "final_value": 0.8495, "best_value": 0.8495}, {"dataset_name": "dense", "final_value": 0.7792, "best_value": 0.7792}, {"dataset_name": "random", "final_value": 0.919, "best_value": 0.919}]}]}, {"metric_names": [{"metric_name": "training loss", "lower_is_better": true, "description": "Final training loss for the model", "data": [{"dataset_name": "synthetic_dynamic_network", "final_value": 0.49043452739715576, "best_value": 0.49043452739715576}]}, {"metric_name": "validation F1 score", "lower_is_better": false, "description": "Final validation F1 score for the model", "data": [{"dataset_name": "synthetic_dynamic_network", "final_value": 0.8, "best_value": 0.8}]}]}, {"metric_names": [{"metric_name": "value", "lower_is_better": true, "description": "", "data": [{"dataset_name": "default", "final_value": null, "best_value": null}]}]}, {"metric_names": [{"metric_name": "train loss", "lower_is_better": true, "description": "The loss value during training, lower is better.", "data": [{"dataset_name": "Synthetic Dynamic Network with Node Count 50", "final_value": 0.5027, "best_value": 0.5027}, {"dataset_name": "Synthetic Dynamic Network with Node Count 150", "final_value": 0.5027, "best_value": 0.5027}, {"dataset_name": "Synthetic Dynamic Network with Node Count 200", "final_value": 0.5027, "best_value": 0.5027}]}, {"metric_name": "validation F1 score", "lower_is_better": false, "description": "The F1 score on the validation set, higher is better.", "data": [{"dataset_name": "Synthetic Dynamic Network with Node Count 50", "final_value": 0.7498, "best_value": 0.7498}, {"dataset_name": "Synthetic Dynamic Network with Node Count 150", "final_value": 0.7498, "best_value": 0.7498}, {"dataset_name": "Synthetic Dynamic Network with Node Count 200", "final_value": 0.7498, "best_value": 0.7498}]}, {"metric_name": "temporal motif coverage (TMC)", "lower_is_better": false, "description": "The temporal motif coverage, higher is better.", "data": [{"dataset_name": "Synthetic Dynamic Network with Node Count 50", "final_value": 0.2339, "best_value": 0.2339}, {"dataset_name": "Synthetic Dynamic Network with Node Count 150", "final_value": 0.2339, "best_value": 0.2339}, {"dataset_name": "Synthetic Dynamic Network with Node Count 200", "final_value": 0.2339, "best_value": 0.2339}]}]}, {"metric_names": [{"metric_name": "validation F1 score", "lower_is_better": false, "description": "The F1 score on the validation dataset, measuring the balance between precision and recall.", "data": [{"dataset_name": "Dataset with Node Count: 50", "final_value": 0.8347, "best_value": 0.8347}, {"dataset_name": "Dataset with Node Count: 150", "final_value": 0.7796, "best_value": 0.7796}, {"dataset_name": "Dataset with Node Count: 200", "final_value": 0.7149, "best_value": 0.7149}]}, {"metric_name": "training loss", "lower_is_better": true, "description": "The loss on the training dataset, indicating how well the model fits the training data.", "data": [{"dataset_name": "Dataset with Node Count: 50", "final_value": 0.3625, "best_value": 0.3625}, {"dataset_name": "Dataset with Node Count: 150", "final_value": 0.5141, "best_value": 0.5141}, {"dataset_name": "Dataset with Node Count: 200", "final_value": 0.5822, "best_value": 0.5822}]}, {"metric_name": "validation loss", "lower_is_better": true, "description": "The loss on the validation dataset, indicating how well the model generalizes to unseen data.", "data": [{"dataset_name": "Dataset with Node Count: 50", "final_value": 0.353, "best_value": 0.353}, {"dataset_name": "Dataset with Node Count: 150", "final_value": 0.5051, "best_value": 0.5051}, {"dataset_name": "Dataset with Node Count: 200", "final_value": 0.5776, "best_value": 0.5776}]}]}, {"metric_names": [{"metric_name": "validation F1 score", "lower_is_better": false, "description": "The F1 score on the validation dataset, balancing precision and recall.", "data": [{"dataset_name": "synthetic_dynamic_network", "final_value": 1.0, "best_value": 1.0}]}]}, {"metric_names": [{"metric_name": "validation F1 score", "lower_is_better": false, "description": "The F1 score calculated on the validation set, indicating the balance between precision and recall.", "data": [{"dataset_name": "synthetic_dynamic_network", "final_value": 1.0, "best_value": 1.0}]}]}, {"metric_names": [{"metric_name": "validation F1 score", "lower_is_better": false, "description": "The F1 score on the validation dataset, indicating the balance between precision and recall.", "data": [{"dataset_name": "synthetic_dynamic_network", "final_value": 1.0, "best_value": 1.0}]}]}, {"metric_names": [{"metric_name": "value", "lower_is_better": true, "description": "", "data": [{"dataset_name": "default", "final_value": null, "best_value": null}]}]}], "is_best_node": [false, true, false, false, false, false, false, false, false, false, false, false, false], "plots": [["../../logs/0-run/experiment_results/experiment_49a53b1294bb40a5bfef9a8db8bfe5e2_proc_2848/synthetic_dynamic_network_training_loss.png", "../../logs/0-run/experiment_results/experiment_49a53b1294bb40a5bfef9a8db8bfe5e2_proc_2848/synthetic_dynamic_network_val_f1.png"], ["../../logs/0-run/experiment_results/experiment_46cb8cfd912a4171bf407c5fcb74ca71_proc_5657/synthetic_dynamic_network_feature_32_plot.png", "../../logs/0-run/experiment_results/experiment_46cb8cfd912a4171bf407c5fcb74ca71_proc_5657/synthetic_dynamic_network_feature_16_plot.png", "../../logs/0-run/experiment_results/experiment_46cb8cfd912a4171bf407c5fcb74ca71_proc_5657/synthetic_dynamic_network_feature_8_plot.png", "../../logs/0-run/experiment_results/experiment_46cb8cfd912a4171bf407c5fcb74ca71_proc_5657/synthetic_dynamic_network_feature_64_plot.png"], [], ["../../logs/0-run/experiment_results/experiment_a1f4f483e5ad466d8b14f84c8c718c65_proc_5660/plot_lr_0.01.png", "../../logs/0-run/experiment_results/experiment_a1f4f483e5ad466d8b14f84c8c718c65_proc_5660/plot_lr_0.1.png", "../../logs/0-run/experiment_results/experiment_a1f4f483e5ad466d8b14f84c8c718c65_proc_5660/plot_lr_0.5.png", "../../logs/0-run/experiment_results/experiment_a1f4f483e5ad466d8b14f84c8c718c65_proc_5660/plot_lr_0.001.png"], ["../../logs/0-run/experiment_results/experiment_bfe0c95097534586b1cad755f3cdd6d8_proc_5657/sparse_val_f1.png", "../../logs/0-run/experiment_results/experiment_bfe0c95097534586b1cad755f3cdd6d8_proc_5657/dense_val_f1.png", "../../logs/0-run/experiment_results/experiment_bfe0c95097534586b1cad755f3cdd6d8_proc_5657/sparse_train_loss.png", "../../logs/0-run/experiment_results/experiment_bfe0c95097534586b1cad755f3cdd6d8_proc_5657/dense_train_loss.png", "../../logs/0-run/experiment_results/experiment_bfe0c95097534586b1cad755f3cdd6d8_proc_5657/random_train_loss.png", "../../logs/0-run/experiment_results/experiment_bfe0c95097534586b1cad755f3cdd6d8_proc_5657/random_val_f1.png"], ["../../logs/0-run/experiment_results/experiment_7bea71f2c86a4af48c23912156d3f036_proc_5660/synthetic_dynamic_network_train_losses.png", "../../logs/0-run/experiment_results/experiment_7bea71f2c86a4af48c23912156d3f036_proc_5660/synthetic_dynamic_network_predictions_vs_ground_truth.png", "../../logs/0-run/experiment_results/experiment_7bea71f2c86a4af48c23912156d3f036_proc_5660/synthetic_dynamic_network_val_f1_scores.png"], [], ["../../logs/0-run/experiment_results/experiment_99725d84596f4b04b92a66c3890cff94_proc_5657/predictions_vs_ground_truth.png", "../../logs/0-run/experiment_results/experiment_99725d84596f4b04b92a66c3890cff94_proc_5657/validation_f1_scores.png", "../../logs/0-run/experiment_results/experiment_99725d84596f4b04b92a66c3890cff94_proc_5657/training_loss.png", "../../logs/0-run/experiment_results/experiment_99725d84596f4b04b92a66c3890cff94_proc_5657/tmc.png"], ["../../logs/0-run/experiment_results/experiment_5ebd38ccc6964f9a9d4e84de52f6e2fa_proc_5660/metrics_plot_nodes_200.png", "../../logs/0-run/experiment_results/experiment_5ebd38ccc6964f9a9d4e84de52f6e2fa_proc_5660/loss_plot_nodes_150.png", "../../logs/0-run/experiment_results/experiment_5ebd38ccc6964f9a9d4e84de52f6e2fa_proc_5660/metrics_plot_nodes_50.png", "../../logs/0-run/experiment_results/experiment_5ebd38ccc6964f9a9d4e84de52f6e2fa_proc_5660/tmc_plot_nodes_50.png", "../../logs/0-run/experiment_results/experiment_5ebd38ccc6964f9a9d4e84de52f6e2fa_proc_5660/tmc_plot_nodes_200.png", "../../logs/0-run/experiment_results/experiment_5ebd38ccc6964f9a9d4e84de52f6e2fa_proc_5660/tmc_plot_nodes_150.png", "../../logs/0-run/experiment_results/experiment_5ebd38ccc6964f9a9d4e84de52f6e2fa_proc_5660/loss_plot_nodes_50.png", "../../logs/0-run/experiment_results/experiment_5ebd38ccc6964f9a9d4e84de52f6e2fa_proc_5660/loss_plot_nodes_200.png", "../../logs/0-run/experiment_results/experiment_5ebd38ccc6964f9a9d4e84de52f6e2fa_proc_5660/metrics_plot_nodes_150.png"], ["../../logs/0-run/experiment_results/experiment_f58409f0f5ac4bf9be457b5cb8df4339_proc_5660/synthetic_dynamic_network_feature_32_plot.png", "../../logs/0-run/experiment_results/experiment_f58409f0f5ac4bf9be457b5cb8df4339_proc_5660/synthetic_dynamic_network_feature_16_plot.png", "../../logs/0-run/experiment_results/experiment_f58409f0f5ac4bf9be457b5cb8df4339_proc_5660/synthetic_dynamic_network_feature_8_plot.png", "../../logs/0-run/experiment_results/experiment_f58409f0f5ac4bf9be457b5cb8df4339_proc_5660/synthetic_dynamic_network_feature_64_plot.png"], ["../../logs/0-run/experiment_results/experiment_efef644de81f4f38a63ebe416507de69_proc_5657/synthetic_dynamic_network_feature_32_plot.png", "../../logs/0-run/experiment_results/experiment_efef644de81f4f38a63ebe416507de69_proc_5657/synthetic_dynamic_network_feature_16_plot.png", "../../logs/0-run/experiment_results/experiment_efef644de81f4f38a63ebe416507de69_proc_5657/synthetic_dynamic_network_feature_8_plot.png", "../../logs/0-run/experiment_results/experiment_efef644de81f4f38a63ebe416507de69_proc_5657/synthetic_dynamic_network_feature_64_plot.png"], ["../../logs/0-run/experiment_results/experiment_af46cdc8800c441e84b3bdaabfb80308_proc_5657/synthetic_dynamic_network_feature_32_plot.png", "../../logs/0-run/experiment_results/experiment_af46cdc8800c441e84b3bdaabfb80308_proc_5657/synthetic_dynamic_network_feature_16_plot.png", "../../logs/0-run/experiment_results/experiment_af46cdc8800c441e84b3bdaabfb80308_proc_5657/synthetic_dynamic_network_feature_8_plot.png", "../../logs/0-run/experiment_results/experiment_af46cdc8800c441e84b3bdaabfb80308_proc_5657/synthetic_dynamic_network_feature_64_plot.png"], ["../../logs/0-run/experiment_results/seed_aggregation_09cc3339188842758eb077ba9335b8ea/aggregated_training_loss.png", "../../logs/0-run/experiment_results/seed_aggregation_09cc3339188842758eb077ba9335b8ea/aggregated_validation_f1_score.png"]], "plot_paths": [["experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_49a53b1294bb40a5bfef9a8db8bfe5e2_proc_2848/synthetic_dynamic_network_training_loss.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_49a53b1294bb40a5bfef9a8db8bfe5e2_proc_2848/synthetic_dynamic_network_val_f1.png"], ["experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_46cb8cfd912a4171bf407c5fcb74ca71_proc_5657/synthetic_dynamic_network_feature_32_plot.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_46cb8cfd912a4171bf407c5fcb74ca71_proc_5657/synthetic_dynamic_network_feature_16_plot.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_46cb8cfd912a4171bf407c5fcb74ca71_proc_5657/synthetic_dynamic_network_feature_8_plot.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_46cb8cfd912a4171bf407c5fcb74ca71_proc_5657/synthetic_dynamic_network_feature_64_plot.png"], [], ["experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_a1f4f483e5ad466d8b14f84c8c718c65_proc_5660/plot_lr_0.01.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_a1f4f483e5ad466d8b14f84c8c718c65_proc_5660/plot_lr_0.1.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_a1f4f483e5ad466d8b14f84c8c718c65_proc_5660/plot_lr_0.5.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_a1f4f483e5ad466d8b14f84c8c718c65_proc_5660/plot_lr_0.001.png"], ["experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_bfe0c95097534586b1cad755f3cdd6d8_proc_5657/sparse_val_f1.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_bfe0c95097534586b1cad755f3cdd6d8_proc_5657/dense_val_f1.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_bfe0c95097534586b1cad755f3cdd6d8_proc_5657/sparse_train_loss.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_bfe0c95097534586b1cad755f3cdd6d8_proc_5657/dense_train_loss.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_bfe0c95097534586b1cad755f3cdd6d8_proc_5657/random_train_loss.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_bfe0c95097534586b1cad755f3cdd6d8_proc_5657/random_val_f1.png"], ["experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_7bea71f2c86a4af48c23912156d3f036_proc_5660/synthetic_dynamic_network_train_losses.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_7bea71f2c86a4af48c23912156d3f036_proc_5660/synthetic_dynamic_network_predictions_vs_ground_truth.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_7bea71f2c86a4af48c23912156d3f036_proc_5660/synthetic_dynamic_network_val_f1_scores.png"], [], ["experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_99725d84596f4b04b92a66c3890cff94_proc_5657/predictions_vs_ground_truth.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_99725d84596f4b04b92a66c3890cff94_proc_5657/validation_f1_scores.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_99725d84596f4b04b92a66c3890cff94_proc_5657/training_loss.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_99725d84596f4b04b92a66c3890cff94_proc_5657/tmc.png"], ["experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_5ebd38ccc6964f9a9d4e84de52f6e2fa_proc_5660/metrics_plot_nodes_200.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_5ebd38ccc6964f9a9d4e84de52f6e2fa_proc_5660/loss_plot_nodes_150.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_5ebd38ccc6964f9a9d4e84de52f6e2fa_proc_5660/metrics_plot_nodes_50.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_5ebd38ccc6964f9a9d4e84de52f6e2fa_proc_5660/tmc_plot_nodes_50.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_5ebd38ccc6964f9a9d4e84de52f6e2fa_proc_5660/tmc_plot_nodes_200.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_5ebd38ccc6964f9a9d4e84de52f6e2fa_proc_5660/tmc_plot_nodes_150.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_5ebd38ccc6964f9a9d4e84de52f6e2fa_proc_5660/loss_plot_nodes_50.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_5ebd38ccc6964f9a9d4e84de52f6e2fa_proc_5660/loss_plot_nodes_200.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_5ebd38ccc6964f9a9d4e84de52f6e2fa_proc_5660/metrics_plot_nodes_150.png"], ["experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_f58409f0f5ac4bf9be457b5cb8df4339_proc_5660/synthetic_dynamic_network_feature_32_plot.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_f58409f0f5ac4bf9be457b5cb8df4339_proc_5660/synthetic_dynamic_network_feature_16_plot.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_f58409f0f5ac4bf9be457b5cb8df4339_proc_5660/synthetic_dynamic_network_feature_8_plot.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_f58409f0f5ac4bf9be457b5cb8df4339_proc_5660/synthetic_dynamic_network_feature_64_plot.png"], ["experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_efef644de81f4f38a63ebe416507de69_proc_5657/synthetic_dynamic_network_feature_32_plot.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_efef644de81f4f38a63ebe416507de69_proc_5657/synthetic_dynamic_network_feature_16_plot.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_efef644de81f4f38a63ebe416507de69_proc_5657/synthetic_dynamic_network_feature_8_plot.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_efef644de81f4f38a63ebe416507de69_proc_5657/synthetic_dynamic_network_feature_64_plot.png"], ["experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_af46cdc8800c441e84b3bdaabfb80308_proc_5657/synthetic_dynamic_network_feature_32_plot.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_af46cdc8800c441e84b3bdaabfb80308_proc_5657/synthetic_dynamic_network_feature_16_plot.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_af46cdc8800c441e84b3bdaabfb80308_proc_5657/synthetic_dynamic_network_feature_8_plot.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_af46cdc8800c441e84b3bdaabfb80308_proc_5657/synthetic_dynamic_network_feature_64_plot.png"], ["experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/seed_aggregation_09cc3339188842758eb077ba9335b8ea/aggregated_training_loss.png", "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/seed_aggregation_09cc3339188842758eb077ba9335b8ea/aggregated_validation_f1_score.png"]], "plot_analyses": [[{"analysis": "The plot shows a consistent decrease in training loss over the epochs, indicating that the model is learning and fitting the training data well. The loss reduction suggests that the chosen hyperparameters, such as learning rate and batch size, are suitable for the model's convergence. However, since all epochs are labeled as 'Epochs: 5', it might indicate an issue with how the legend is configured, or there might be redundant information that could be clarified in future plots.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_49a53b1294bb40a5bfef9a8db8bfe5e2_proc_2848/synthetic_dynamic_network_training_loss.png"}, {"analysis": "The F1 score on the validation set improves steadily over the epochs, indicating that the model is not only learning the training data but also generalizing well to unseen data. This improvement in F1 score suggests that the anomaly detection capability of the model is becoming more robust with training. The plateau reached towards the end of the epochs might suggest that the model is nearing its optimal performance, or it may require further tuning to achieve better results.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_49a53b1294bb40a5bfef9a8db8bfe5e2_proc_2848/synthetic_dynamic_network_val_f1.png"}], [{"analysis": "The training loss decreases over time, indicating that the model is learning. However, there is a slight increase in loss around the 20th epoch, suggesting potential overfitting or learning instability. The validation F1 score increases steadily, reaching a peak close to 0.9, which indicates strong model performance and generalization capability for this feature count.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_46cb8cfd912a4171bf407c5fcb74ca71_proc_5657/synthetic_dynamic_network_feature_32_plot.png"}, {"analysis": "The training loss shows a decreasing trend, although there is a slight increase towards the end, indicating some instability. The validation F1 score improves significantly initially but then decreases slightly after reaching a peak around the 10th epoch. This suggests that the model may be overfitting or that the feature count is not optimal for capturing the necessary patterns.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_46cb8cfd912a4171bf407c5fcb74ca71_proc_5657/synthetic_dynamic_network_feature_16_plot.png"}, {"analysis": "The training loss decreases steadily, with a slight increase towards the end, indicating potential overfitting. The validation F1 score improves initially but then plateaus and decreases, suggesting that the feature count might not be sufficient for capturing complex patterns, leading to limited improvement in anomaly detection performance.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_46cb8cfd912a4171bf407c5fcb74ca71_proc_5657/synthetic_dynamic_network_feature_8_plot.png"}, {"analysis": "The training loss decreases significantly, showing effective learning. The validation F1 score increases rapidly and stabilizes at a high value, indicating that the model performs well with this feature count. The high peak in F1 score suggests that this configuration might be optimal for anomaly detection, balancing complexity and performance.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_46cb8cfd912a4171bf407c5fcb74ca71_proc_5657/synthetic_dynamic_network_feature_64_plot.png"}], [], [{"analysis": "The training loss decreases steadily over the epochs, indicating that the model is learning effectively with the chosen learning rate of 0.01. The validation F1 score shows a consistent upward trend, suggesting that the model's ability to generalize to unseen data is improving. This learning rate seems to balance well between convergence speed and stability.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_a1f4f483e5ad466d8b14f84c8c718c65_proc_5660/plot_lr_0.01.png"}, {"analysis": "With a learning rate of 0.1, the training loss decreases smoothly, indicating effective learning. However, the validation F1 score, while increasing, does so at a slower rate compared to the previous configuration. This might suggest that the model is not generalizing as well, possibly due to the higher learning rate causing less stable updates.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_a1f4f483e5ad466d8b14f84c8c718c65_proc_5660/plot_lr_0.1.png"}, {"analysis": "The learning rate of 0.5 shows a rapid decrease in training loss, but the validation F1 score plateaus after an initial increase. This could indicate overfitting, where the model learns the training data too well but fails to generalize to new data. The high learning rate may be causing the model to converge too quickly to a suboptimal solution.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_a1f4f483e5ad466d8b14f84c8c718c65_proc_5660/plot_lr_0.5.png"}, {"analysis": "The training loss with a learning rate of 0.001 starts high and decreases significantly, suggesting initial instability but eventual learning. The validation F1 score improves consistently, indicating good generalization. However, the initial instability might require additional epochs to stabilize fully.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_a1f4f483e5ad466d8b14f84c8c718c65_proc_5660/plot_lr_0.001.png"}], [{"analysis": "The plot shows a steady improvement in the F1 score over the epochs, indicating that the model is learning effectively with sparse connectivity. The F1 score starts around 0.5 and gradually increases to above 0.8, demonstrating a significant improvement in performance. This suggests that the model's ability to detect anomalies improves consistently as training progresses, even with sparse connectivity.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_bfe0c95097534586b1cad755f3cdd6d8_proc_5657/sparse_val_f1.png"}, {"analysis": "The plot exhibits a more fluctuating pattern compared to sparse connectivity, with the F1 score initially rising but experiencing several drops. However, it stabilizes around 0.75 towards the later epochs. This indicates that while the model can achieve reasonable performance with dense connectivity, it may require more careful tuning or additional regularization to handle the complexity introduced by dense connections.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_bfe0c95097534586b1cad755f3cdd6d8_proc_5657/dense_val_f1.png"}, {"analysis": "The training loss decreases steadily over the epochs, indicating effective learning and convergence with sparse connectivity. The loss starts high but shows a consistent downward trend, which is a positive sign of model training. The presence of spikes suggests possible adjustments or learning rate changes during training, but overall, the model appears to be learning well.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_bfe0c95097534586b1cad755f3cdd6d8_proc_5657/sparse_train_loss.png"}, {"analysis": "Similar to sparse connectivity, the training loss decreases over time, but the initial fluctuations are more pronounced. The steady decline in loss suggests that the model is learning, but the initial instability might be due to the increased complexity of dense connections. This could indicate a need for stabilization techniques or more refined hyperparameter tuning.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_bfe0c95097534586b1cad755f3cdd6d8_proc_5657/dense_train_loss.png"}, {"analysis": "The training loss for random connectivity also shows a consistent decrease, indicating effective learning. The loss starts high and decreases smoothly, suggesting that the model can adapt well to random connectivity. The pattern is similar to sparse connectivity, indicating that the model's learning dynamics are robust across different connectivity patterns.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_bfe0c95097534586b1cad755f3cdd6d8_proc_5657/random_train_loss.png"}, {"analysis": "The F1 score for random connectivity starts lower compared to sparse and dense connectivity but increases significantly, surpassing 0.9. This suggests that random connectivity allows the model to explore diverse patterns, potentially leading to better generalization and anomaly detection capabilities. The consistent improvement indicates that the model benefits from the randomness in connectivity, possibly enhancing its adaptability.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_bfe0c95097534586b1cad755f3cdd6d8_proc_5657/random_val_f1.png"}], [{"analysis": "The training loss plot shows fluctuations in the loss values across the epochs, with noticeable spikes around epochs 20 and 40. These spikes suggest potential instability or issues with convergence, possibly due to the choice of activation functions or learning rate. Despite the fluctuations, there is a general downward trend, indicating that the model is learning over time.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_7bea71f2c86a4af48c23912156d3f036_proc_5660/synthetic_dynamic_network_train_losses.png"}, {"analysis": "The predictions versus ground truth plot shows a good alignment between the predicted and actual class labels, suggesting that the model is effectively capturing the underlying patterns in the data. The scatter plot indicates that the model is making accurate predictions across the sample indices, with minimal misclassifications. This suggests that the anomaly detection framework is performing well in distinguishing between normal and anomalous instances.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_7bea71f2c86a4af48c23912156d3f036_proc_5660/synthetic_dynamic_network_predictions_vs_ground_truth.png"}, {"analysis": "The validation F1 score plot mirrors the instability seen in the training loss plot, with a significant drop around epoch 40. However, the overall trend is positive, with the F1 score improving over time, reaching a peak close to 0.8. This indicates that despite the fluctuations, the model's ability to balance precision and recall is improving, which is crucial for effective anomaly detection.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_7bea71f2c86a4af48c23912156d3f036_proc_5660/synthetic_dynamic_network_val_f1_scores.png"}], [], [{"analysis": "The plot shows a comparison between predictions and ground truth for a binary classification task. The predictions (orange) align well with the ground truth (blue), indicating that the model is performing accurately in distinguishing between the two classes. This suggests that the anomaly detection mechanism is functioning effectively, at least for the samples shown.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_99725d84596f4b04b92a66c3890cff94_proc_5657/predictions_vs_ground_truth.png"}, {"analysis": "The plot intended to show F1 scores over epochs for different node counts does not display any data points. This indicates a possible issue with the data logging or plotting process. Without this information, it is challenging to assess how the model's performance varies with different node counts over time.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_99725d84596f4b04b92a66c3890cff94_proc_5657/validation_f1_scores.png"}, {"analysis": "The training loss plot shows a decreasing trend with some fluctuations, indicating that the model is learning over time but might be experiencing some instability. The spikes in loss suggest that there might be abrupt changes in the learning process, possibly due to changes in learning rate or other training dynamics. Overall, the loss decreases, which is a positive sign of convergence.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_99725d84596f4b04b92a66c3890cff94_proc_5657/training_loss.png"}, {"analysis": "Similar to the F1 score plot, the temporal motif coverage plot lacks visible data points. This makes it difficult to interpret how well the temporal motifs are being covered over the epochs. The absence of data points suggests an issue with data collection or plotting, which needs to be addressed to evaluate this aspect of the model.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_99725d84596f4b04b92a66c3890cff94_proc_5657/tmc.png"}], [{"analysis": "The plot shows a steady increase in the validation F1 score over epochs, suggesting that the model is learning effectively. Starting from an F1 score of around 0.35, it rises to approximately 0.70 by the end of the training. This indicates that the model's ability to detect anomalies improves significantly as training progresses, reflecting the effectiveness of the temporal motif-enhanced contrastive learning approach in capturing dynamic network patterns.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_5ebd38ccc6964f9a9d4e84de52f6e2fa_proc_5660/metrics_plot_nodes_200.png"}, {"analysis": "This plot illustrates a consistent decrease in both training and validation loss over epochs, indicating effective learning and convergence. The training loss starts slightly higher than the validation loss, but both decrease at a similar rate, suggesting that the model is generalizing well without overfitting. The reduction in loss aligns with the improvement in F1 score, supporting the model's capacity to learn meaningful representations of network anomalies.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_5ebd38ccc6964f9a9d4e84de52f6e2fa_proc_5660/loss_plot_nodes_150.png"}, {"analysis": "The F1 score shows a notable increase from approximately 0.50 to 0.85 over the epochs, suggesting strong and consistent improvement in anomaly detection performance. The rapid increase in the early epochs indicates effective initial learning, while the continued rise suggests the model maintains its learning capability throughout training. This performance improvement highlights the benefit of the proposed model in adapting to dynamic network changes.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_5ebd38ccc6964f9a9d4e84de52f6e2fa_proc_5660/metrics_plot_nodes_50.png"}, {"analysis": "The temporal motif coverage (TMC) shows significant fluctuations over the epochs, indicating variability in the model's ability to capture temporal motifs effectively. The peaks and troughs suggest that while the model occasionally captures motifs well, there are periods where this capability drops sharply. This variability might reflect the model's sensitivity to motif size and temporal scales, as noted in the risk factors. Addressing these fluctuations could improve model stability and performance.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_5ebd38ccc6964f9a9d4e84de52f6e2fa_proc_5660/tmc_plot_nodes_50.png"}, {"analysis": "The TMC plot for a larger node count shows similar fluctuations as the previous TMC plot, with peaks and troughs indicating inconsistent motif capture. The variability may be more pronounced due to the increased complexity with a larger node count. This suggests that the model's motif extraction process might not scale smoothly with network size, highlighting a potential area for optimization to stabilize motif detection.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_5ebd38ccc6964f9a9d4e84de52f6e2fa_proc_5660/tmc_plot_nodes_200.png"}, {"analysis": "The TMC plot indicates variability in motif capture, with significant peaks and troughs. This inconsistency suggests challenges in maintaining stable motif detection across epochs. The fluctuations could be attributed to the complexity of motif extraction in dynamic networks, especially with varying node counts. Enhancing motif extraction consistency could lead to more robust anomaly detection.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_5ebd38ccc6964f9a9d4e84de52f6e2fa_proc_5660/tmc_plot_nodes_150.png"}, {"analysis": "The loss plot shows a consistent decrease in both training and validation loss, which is indicative of effective learning and convergence. The close alignment of training and validation loss suggests good generalization, with minimal overfitting. The reduction in loss corresponds with improvements in F1 score, reinforcing the model's capability to adaptively learn from dynamic network data.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_5ebd38ccc6964f9a9d4e84de52f6e2fa_proc_5660/loss_plot_nodes_50.png"}, {"analysis": "The loss plot shows a decrease in both training and validation loss, indicating effective learning. The gap between training and validation loss remains small, suggesting good generalization. However, the higher initial loss values compared to other node counts might indicate increased difficulty in learning with larger networks, potentially due to the computational complexity of motif extraction.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_5ebd38ccc6964f9a9d4e84de52f6e2fa_proc_5660/loss_plot_nodes_200.png"}, {"analysis": "The validation F1 score increases steadily from around 0.45 to 0.75 over the epochs, demonstrating effective learning and performance improvement in anomaly detection. The consistent upward trend highlights the model's ability to adapt to dynamic network changes and improve its detection capabilities, supporting the proposed framework's effectiveness.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_5ebd38ccc6964f9a9d4e84de52f6e2fa_proc_5660/metrics_plot_nodes_150.png"}], [{"analysis": "The plots show the training loss and validation F1 score for a feature count of 32. The training loss decreases sharply initially, indicating effective learning, but then increases slightly before dropping again. This could suggest overfitting or instability in the learning process. The validation F1 score improves steadily, showing the effectiveness of the model in generalizing to unseen data. The sharp increase at the end could indicate a sudden improvement in anomaly detection capability.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_f58409f0f5ac4bf9be457b5cb8df4339_proc_5660/synthetic_dynamic_network_feature_32_plot.png"}, {"analysis": "For a feature count of 16, the training loss decreases significantly and then stabilizes, suggesting effective learning. The validation F1 score shows a steady increase, indicating consistent improvement in performance. The final sharp increase in F1 score suggests a potential breakthrough in anomaly detection accuracy at this feature count.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_f58409f0f5ac4bf9be457b5cb8df4339_proc_5660/synthetic_dynamic_network_feature_16_plot.png"}, {"analysis": "With a feature count of 8, the training loss decreases initially but then stabilizes, showing limited learning. The validation F1 score increases initially but then drops sharply, indicating overfitting or a lack of capacity in the model to generalize well at this feature count.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_f58409f0f5ac4bf9be457b5cb8df4339_proc_5660/synthetic_dynamic_network_feature_8_plot.png"}, {"analysis": "The training loss for a feature count of 64 decreases consistently, showing effective learning. The validation F1 score shows a steady increase, with a final sharp rise, indicating a strong performance in anomaly detection. The model appears to perform well with a higher feature count, suggesting that more features may provide better discriminative power.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_f58409f0f5ac4bf9be457b5cb8df4339_proc_5660/synthetic_dynamic_network_feature_64_plot.png"}], [{"analysis": "The training loss decreases rapidly initially, indicating effective learning, but then shows some instability, particularly between epochs 20 and 30. This suggests potential overfitting or difficulty in learning complex patterns as the feature count increases. The validation F1 score improves steadily, peaking around epoch 30, which indicates the model is generalizing well despite fluctuations in training loss.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_efef644de81f4f38a63ebe416507de69_proc_5657/synthetic_dynamic_network_feature_32_plot.png"}, {"analysis": "The training loss follows a similar pattern, with a steep initial decrease followed by fluctuations. The validation F1 score also shows improvement, suggesting effective learning, but the overall performance is slightly lower compared to the previous feature count. This might indicate that a feature count of 16 is less optimal for capturing the necessary patterns for anomaly detection.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_efef644de81f4f38a63ebe416507de69_proc_5657/synthetic_dynamic_network_feature_16_plot.png"}, {"analysis": "Training loss decreases initially but stabilizes early, indicating limited learning capacity with a feature count of 8. The validation F1 score increases initially but drops significantly after epoch 20, suggesting that the model struggles to generalize with such a low feature count. This confirms the hypothesis that a larger feature space is necessary for effective anomaly detection.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_efef644de81f4f38a63ebe416507de69_proc_5657/synthetic_dynamic_network_feature_8_plot.png"}, {"analysis": "Training loss decreases significantly and stabilizes, indicating effective learning with a feature count of 64. The validation F1 score improves consistently and reaches a high level, suggesting that this feature count allows the model to capture complex patterns effectively. This supports the idea that a larger feature space enhances the model's ability to generalize and detect anomalies effectively.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_efef644de81f4f38a63ebe416507de69_proc_5657/synthetic_dynamic_network_feature_64_plot.png"}], [{"analysis": "The training loss decreases significantly initially, indicating effective learning, but shows a spike towards the end, suggesting potential overfitting or instability. The validation F1 score increases gradually, peaking towards the end, indicating improved model performance with a feature count of 32. However, the spike in training loss suggests that the model might not generalize well and could benefit from regularization or early stopping.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_af46cdc8800c441e84b3bdaabfb80308_proc_5657/synthetic_dynamic_network_feature_32_plot.png"}, {"analysis": "The training loss decreases steadily, showing effective learning, but increases sharply at the last epoch, indicating possible overfitting. The validation F1 score improves over time, reaching a peak before slightly dropping, indicating that the model performs well with a feature count of 16, but there might be room for optimization in terms of stability and generalization.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_af46cdc8800c441e84b3bdaabfb80308_proc_5657/synthetic_dynamic_network_feature_16_plot.png"}, {"analysis": "The training loss decreases initially but shows a significant increase at the last epoch, indicating potential overfitting or instability. The validation F1 score improves initially but drops sharply towards the end, suggesting that the model struggles to generalize well with a feature count of 8, possibly due to insufficient feature representation.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_af46cdc8800c441e84b3bdaabfb80308_proc_5657/synthetic_dynamic_network_feature_8_plot.png"}, {"analysis": "The training loss decreases effectively, indicating good learning, but spikes at the last epoch, suggesting overfitting or instability. The validation F1 score improves consistently, with a significant increase at the end, indicating strong model performance with a feature count of 64. However, the spike in training loss suggests the need for techniques to improve generalization, such as regularization or early stopping.", "plot_path": "experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_af46cdc8800c441e84b3bdaabfb80308_proc_5657/synthetic_dynamic_network_feature_64_plot.png"}], []], "vlm_feedback_summary": ["The plots indicate successful training and improvement in validation\nperformance, suggesting effective hyperparameter tuning. Further tuning might\nenhance results.", "The plots reveal varying performance based on feature count. Higher feature\ncounts (32 and 64) show better validation F1 scores, indicating improved model\ngeneralization and performance. Lower feature counts (8 and 16) show limitations\nin capturing complex patterns, leading to reduced performance and potential\noverfitting. The results suggest that a higher feature count may be necessary\nfor effective anomaly detection in dynamic networks.", "[]", "The experiments with different learning rates reveal the impact on both training\nloss and validation F1 score. A learning rate of 0.01 appears to provide the\nbest balance between learning and generalization, while 0.5 may lead to\noverfitting. Lower learning rates like 0.001 show potential but might need more\nepochs to stabilize.", "The plots reveal that the model's performance varies with different connectivity\npatterns. Sparse connectivity shows steady improvement, while dense connectivity\nhas fluctuations but stabilizes. Random connectivity results in the highest F1\nscores, indicating enhanced adaptability. Training loss decreases consistently\nacross all types, suggesting effective learning. The results highlight the\nimportance of connectivity patterns in model performance and suggest potential\nareas for further refinement and tuning.", "The experimental plots demonstrate both challenges and progress in the anomaly\ndetection framework. The training loss and validation F1 score plots indicate\nsome instability, likely due to hyperparameter settings or the choice of\nactivation functions. However, the overall trends are positive, suggesting that\nthe model is learning and improving its performance. The predictions versus\nground truth plot confirms the model's effectiveness in classification tasks,\nshowing accurate alignment with minimal misclassifications. Further tuning and\nstability improvements could enhance the model's robustness and performance.", "[]", "The analysis reveals that while the model predictions align well with ground\ntruth, indicating effective anomaly detection, there are issues with data\nvisualization in the F1 scores and temporal motif coverage plots. The training\nloss plot shows learning progress with some instability. Addressing the data\nlogging or plotting issues is crucial for a complete evaluation.", "The experiments demonstrate effective learning and improvement in anomaly\ndetection performance across different node counts. The validation F1 score\nconsistently improves, indicating the model's capability to adapt to dynamic\nnetworks. Loss plots show convergence and good generalization. However, temporal\nmotif coverage plots reveal variability, suggesting areas for optimization in\nmotif extraction stability. Overall, the results support the framework's\npotential for adaptive anomaly detection in dynamic networks.", "The experiments demonstrate varying performance across different feature counts.\nHigher feature counts, such as 64, show better learning and generalization,\nwhile lower feature counts, like 8, struggle with overfitting and limited\ncapacity. The sharp increases in F1 scores at the end of training suggest\npotential breakthroughs in anomaly detection accuracy. These results highlight\nthe importance of selecting appropriate feature counts for optimizing\nperformance in anomaly detection tasks.", "The experiments indicate that increasing the feature count improves the model's\nlearning and generalization capabilities. Lower feature counts result in\ninstability and poorer performance, while higher feature counts lead to better\nanomaly detection. The results support the hypothesis that a larger feature\nspace is beneficial for capturing complex patterns in dynamic networks.", "The plots indicate that the model generally learns effectively, as shown by the\ndecreasing training loss and increasing validation F1 scores. However, there are\nconsistent spikes in training loss at the last epoch across feature counts,\nsuggesting potential overfitting or instability. The validation F1 scores\nimprove with higher feature counts, indicating better performance with more\nfeatures, but the instability in training loss suggests a need for\nregularization or early stopping to ensure better generalization.", "[]"], "exec_time": [1.374830961227417, 1.4910080432891846, 1.1740539073944092, 1.309234857559204, 1.4108946323394775, 1.2610070705413818, 1.292912244796753, 1.225855827331543, 1.2580440044403076, 1.7995288372039795, 1.8052940368652344, 1.486327886581421, null], "exec_time_feedback": ["", "", "", "", "", "", "", "", "", "", "", "", ""], "datasets_successfully_tested": [["synthetic_dynamic_network"], ["[32", "64]"], [], ["[0.01]"], ["sparse", "dense", "random"], ["synthetic_dynamic_network"], [], ["synthetic_dynamic_network"], ["node_count_ablation_synthetic_dynamic_network"], ["[16", "32", "64]"], ["[32", "64]"], ["\"\""], []], "plot_code": ["import matplotlib.pyplot as plt\nimport numpy as np\nimport os\n\nworking_dir = os.path.join(os.getcwd(), \"working\")\n\ntry:\n    # Load experiment data\n    experiment_data = np.load(\n        os.path.join(working_dir, \"experiment_data.npy\"), allow_pickle=True\n    ).item()\n    data = experiment_data[\"hyperparam_tuning_epochs\"][\"synthetic_dynamic_network\"]\nexcept Exception as e:\n    print(f\"Error loading experiment data: {e}\")\n\ntry:\n    # Plot training loss\n    plt.figure()\n    for idx, epochs in enumerate(\n        data[\"epoch_settings\"][:5]\n    ):  # Plot only first 5 settings\n        plt.plot(data[\"losses\"][\"train\"][:epochs], label=f\"Epochs: {epochs}\")\n    plt.title(\"Training Loss over Epochs\")\n    plt.xlabel(\"Epoch\")\n    plt.ylabel(\"Loss\")\n    plt.legend()\n    plt.savefig(\n        os.path.join(working_dir, \"synthetic_dynamic_network_training_loss.png\")\n    )\n    plt.close()\nexcept Exception as e:\n    print(f\"Error creating training loss plot: {e}\")\n    plt.close()\n\ntry:\n    # Plot validation F1 Score\n    plt.figure()\n    for idx, epochs in enumerate(\n        data[\"epoch_settings\"][:5]\n    ):  # Plot only first 5 settings\n        plt.plot(data[\"metrics\"][\"val\"][:epochs], label=f\"Epochs: {epochs}\")\n    plt.title(\"Validation F1 Score over Epochs\")\n    plt.xlabel(\"Epoch\")\n    plt.ylabel(\"F1 Score\")\n    plt.legend()\n    plt.savefig(os.path.join(working_dir, \"synthetic_dynamic_network_val_f1.png\"))\n    plt.close()\nexcept Exception as e:\n    print(f\"Error creating validation f1 score plot: {e}\")\n    plt.close()\n", "import matplotlib.pyplot as plt\nimport numpy as np\nimport os\n\nworking_dir = os.path.join(os.getcwd(), \"working\")\n\ntry:\n    experiment_data = np.load(\n        os.path.join(working_dir, \"experiment_data.npy\"), allow_pickle=True\n    ).item()\nexcept Exception as e:\n    print(f\"Error loading experiment data: {e}\")\n\ntry:\n    feature_counts = experiment_data[\"feature_count_ablation\"][\n        \"synthetic_dynamic_network\"\n    ][\"feature_counts\"]\n    epochs_list = experiment_data[\"feature_count_ablation\"][\n        \"synthetic_dynamic_network\"\n    ][\"epoch_settings\"]\n    losses = experiment_data[\"feature_count_ablation\"][\"synthetic_dynamic_network\"][\n        \"losses\"\n    ][\"train\"]\n    val_f1_scores = experiment_data[\"feature_count_ablation\"][\n        \"synthetic_dynamic_network\"\n    ][\"metrics\"][\"val\"]\n\n    for i, feature_count in enumerate(set(feature_counts)):\n        plt.figure()\n        epoch_indices = [\n            idx for idx, fc in enumerate(feature_counts) if fc == feature_count\n        ]\n        interval = max(\n            1, len(epoch_indices) // 5\n        )  # Plot at most 5 figures per feature count\n        selected_epochs = epoch_indices[::interval]\n\n        plt.subplot(1, 2, 1)\n        plt.plot(\n            [epochs_list[idx] for idx in selected_epochs],\n            [losses[idx] for idx in selected_epochs],\n        )\n        plt.title(f\"Training Loss for Feature Count {feature_count}\")\n        plt.xlabel(\"Epochs\")\n        plt.ylabel(\"Loss\")\n\n        plt.subplot(1, 2, 2)\n        plt.plot(\n            [epochs_list[idx] for idx in selected_epochs],\n            [val_f1_scores[idx] for idx in selected_epochs],\n        )\n        plt.title(f\"Validation F1 Score for Feature Count {feature_count}\")\n        plt.xlabel(\"Epochs\")\n        plt.ylabel(\"F1 Score\")\n\n        plt.tight_layout()\n        plt.savefig(\n            os.path.join(\n                working_dir,\n                f\"synthetic_dynamic_network_feature_{feature_count}_plot.png\",\n            )\n        )\n        plt.close()\nexcept Exception as e:\n    print(f\"Error creating plots: {e}\")\n    plt.close()\n", null, "import matplotlib.pyplot as plt\nimport numpy as np\nimport os\n\n# Set up working directory\nworking_dir = os.path.join(os.getcwd(), \"working\")\nos.makedirs(working_dir, exist_ok=True)\n\ntry:\n    # Load experiment data\n    experiment_data = np.load(\n        os.path.join(working_dir, \"experiment_data.npy\"), allow_pickle=True\n    ).item()\nexcept Exception as e:\n    print(f\"Error loading experiment data: {e}\")\n\n# Extract data\ndata_dict = experiment_data[\"learning_rate_ablation\"][\"synthetic_dynamic_network\"]\ntrain_losses = data_dict[\"losses\"][\"train\"]\nval_metrics = data_dict[\"metrics\"][\"val\"]\nlearning_rates = data_dict[\"learning_rate_settings\"]\n\n# Plot training losses and validation F1 scores\ntry:\n    for lr_idx, lr in enumerate(set(learning_rates)):\n        plt.figure(figsize=(10, 5))\n\n        # Plot training loss\n        plt.subplot(1, 2, 1)\n        plt.plot(\n            range(1, 21),\n            train_losses[lr_idx * 20 : (lr_idx + 1) * 20],\n            label=f\"LR={lr}\",\n        )\n        plt.title(\"Training Loss\")\n        plt.xlabel(\"Epoch\")\n        plt.ylabel(\"Loss\")\n        plt.legend()\n\n        # Plot validation F1 score\n        plt.subplot(1, 2, 2)\n        plt.plot(\n            range(1, 21), val_metrics[lr_idx * 20 : (lr_idx + 1) * 20], label=f\"LR={lr}\"\n        )\n        plt.title(\"Validation F1 Score\")\n        plt.xlabel(\"Epoch\")\n        plt.ylabel(\"F1 Score\")\n        plt.legend()\n\n        # Save plot\n        plt.suptitle(f\"Learning Rate: {lr}\")\n        plt.savefig(os.path.join(working_dir, f\"plot_lr_{lr}.png\"))\n        plt.close()\nexcept Exception as e:\n    print(f\"Error creating plots: {e}\")\n    plt.close()  # Always close figures even if errors occur\n", "import matplotlib.pyplot as plt\nimport numpy as np\nimport os\n\nworking_dir = os.path.join(os.getcwd(), \"working\")\n\n# Load experiment data\ntry:\n    experiment_data = np.load(\n        os.path.join(working_dir, \"experiment_data.npy\"), allow_pickle=True\n    ).item()\nexcept Exception as e:\n    print(f\"Error loading experiment data: {e}\")\n\n# Plotting\nfor connectivity in [\"sparse\", \"dense\", \"random\"]:\n    try:\n        train_losses = experiment_data[connectivity][\"losses\"][\"train\"]\n        val_metrics = experiment_data[connectivity][\"metrics\"][\"val\"]\n\n        # Plot training losses\n        plt.figure()\n        plt.plot(train_losses, label=\"Training Loss\")\n        plt.title(f\"Training Loss for {connectivity.capitalize()} Connectivity\")\n        plt.xlabel(\"Epochs\")\n        plt.ylabel(\"Loss\")\n        plt.legend()\n        plt.savefig(os.path.join(working_dir, f\"{connectivity}_train_loss.png\"))\n        plt.close()\n\n        # Plot validation F1 scores\n        plt.figure()\n        plt.plot(val_metrics, label=\"Validation F1 Score\")\n        plt.title(f\"Validation F1 Score for {connectivity.capitalize()} Connectivity\")\n        plt.xlabel(\"Epochs\")\n        plt.ylabel(\"F1 Score\")\n        plt.legend()\n        plt.savefig(os.path.join(working_dir, f\"{connectivity}_val_f1.png\"))\n        plt.close()\n\n    except Exception as e:\n        print(f\"Error creating plots for {connectivity}: {e}\")\n        plt.close()\n", "import matplotlib.pyplot as plt\nimport numpy as np\nimport os\n\nworking_dir = os.path.join(os.getcwd(), \"working\")\n\ntry:\n    experiment_data = np.load(\n        os.path.join(working_dir, \"experiment_data.npy\"), allow_pickle=True\n    ).item()\nexcept Exception as e:\n    print(f\"Error loading experiment data: {e}\")\n\ndata = experiment_data[\"activation_function_ablation\"][\"synthetic_dynamic_network\"]\ntrain_losses = data[\"losses\"][\"train\"]\nval_metrics = data[\"metrics\"][\"val\"]\npredictions = data[\"predictions\"]\nground_truth = data[\"ground_truth\"]\nactivation_functions = data[\"activation_functions\"]\n\n# Plot training losses\ntry:\n    plt.figure()\n    plt.plot(train_losses, label=\"Train Loss\")\n    plt.title(\"Training Losses for Different Activation Functions\")\n    plt.xlabel(\"Epochs\")\n    plt.ylabel(\"Loss\")\n    plt.legend()\n    plt.savefig(os.path.join(working_dir, \"synthetic_dynamic_network_train_losses.png\"))\n    plt.close()\nexcept Exception as e:\n    print(f\"Error creating training loss plot: {e}\")\n    plt.close()\n\n# Plot validation F1 scores\ntry:\n    plt.figure()\n    plt.plot(val_metrics, label=\"Validation F1 Score\")\n    plt.title(\"Validation F1 Scores for Different Activation Functions\")\n    plt.xlabel(\"Epochs\")\n    plt.ylabel(\"F1 Score\")\n    plt.legend()\n    plt.savefig(\n        os.path.join(working_dir, \"synthetic_dynamic_network_val_f1_scores.png\")\n    )\n    plt.close()\nexcept Exception as e:\n    print(f\"Error creating validation F1 score plot: {e}\")\n    plt.close()\n\n# Plot predictions vs ground truth\ntry:\n    plt.figure()\n    plt.scatter(range(len(predictions)), predictions, label=\"Predictions\", alpha=0.5)\n    plt.scatter(range(len(ground_truth)), ground_truth, label=\"Ground Truth\", alpha=0.5)\n    plt.title(\"Predictions vs Ground Truth\")\n    plt.xlabel(\"Sample Index\")\n    plt.ylabel(\"Class Label\")\n    plt.legend()\n    plt.savefig(\n        os.path.join(\n            working_dir, \"synthetic_dynamic_network_predictions_vs_ground_truth.png\"\n        )\n    )\n    plt.close()\nexcept Exception as e:\n    print(f\"Error creating predictions vs ground truth plot: {e}\")\n    plt.close()\n", null, "import matplotlib.pyplot as plt\nimport numpy as np\nimport os\n\nworking_dir = os.path.join(os.getcwd(), \"working\")\n\n# Load experiment data\ntry:\n    experiment_data = np.load(\n        os.path.join(working_dir, \"experiment_data.npy\"), allow_pickle=True\n    ).item()\nexcept Exception as e:\n    print(f\"Error loading experiment data: {e}\")\n\n# Plot training loss\ntry:\n    train_losses = experiment_data[\"node_count_ablation\"][\"synthetic_dynamic_network\"][\n        \"losses\"\n    ][\"train\"]\n    plt.figure()\n    plt.plot(train_losses, label=\"Training Loss\")\n    plt.title(\"Training Loss Over Epochs\")\n    plt.xlabel(\"Epoch\")\n    plt.ylabel(\"Loss\")\n    plt.legend()\n    plt.savefig(os.path.join(working_dir, \"training_loss.png\"))\n    plt.close()\nexcept Exception as e:\n    print(f\"Error creating training loss plot: {e}\")\n    plt.close()\n\n# Plot validation F1 scores at node count intervals\ntry:\n    val_f1_scores = experiment_data[\"node_count_ablation\"][\"synthetic_dynamic_network\"][\n        \"metrics\"\n    ][\"val\"]\n    node_counts = experiment_data[\"node_count_ablation\"][\"synthetic_dynamic_network\"][\n        \"node_count_settings\"\n    ]\n    plt.figure()\n    epochs = len(val_f1_scores) // len(node_counts)\n    for i, node_count in enumerate(set(node_counts)):\n        plt.plot(\n            val_f1_scores[i * epochs : (i + 1) * epochs],\n            label=f\"Node Count {node_count}\",\n        )\n    plt.title(\"Validation F1 Scores Over Epochs\")\n    plt.xlabel(\"Epoch\")\n    plt.ylabel(\"F1 Score\")\n    plt.legend()\n    plt.savefig(os.path.join(working_dir, \"validation_f1_scores.png\"))\n    plt.close()\nexcept Exception as e:\n    print(f\"Error creating validation F1 scores plot: {e}\")\n    plt.close()\n\n# Plot Temporal Motif Coverage (TMC)\ntry:\n    tmc_values = experiment_data[\"node_count_ablation\"][\"synthetic_dynamic_network\"][\n        \"metrics\"\n    ][\"tmc\"]\n    plt.figure()\n    for i, node_count in enumerate(set(node_counts)):\n        plt.plot(\n            tmc_values[i * epochs : (i + 1) * epochs], label=f\"Node Count {node_count}\"\n        )\n    plt.title(\"Temporal Motif Coverage Over Epochs\")\n    plt.xlabel(\"Epoch\")\n    plt.ylabel(\"TMC\")\n    plt.legend()\n    plt.savefig(os.path.join(working_dir, \"tmc.png\"))\n    plt.close()\nexcept Exception as e:\n    print(f\"Error creating TMC plot: {e}\")\n    plt.close()\n\n# Plot predictions vs ground truth\ntry:\n    predictions = experiment_data[\"node_count_ablation\"][\"synthetic_dynamic_network\"][\n        \"predictions\"\n    ]\n    ground_truth = experiment_data[\"node_count_ablation\"][\"synthetic_dynamic_network\"][\n        \"ground_truth\"\n    ]\n    plt.figure()\n    plt.scatter(range(len(ground_truth)), ground_truth, label=\"Ground Truth\", alpha=0.5)\n    plt.scatter(range(len(predictions)), predictions, label=\"Predictions\", alpha=0.5)\n    plt.title(\"Predictions vs Ground Truth\")\n    plt.xlabel(\"Sample Index\")\n    plt.ylabel(\"Class Label\")\n    plt.legend()\n    plt.savefig(os.path.join(working_dir, \"predictions_vs_ground_truth.png\"))\n    plt.close()\nexcept Exception as e:\n    print(f\"Error creating predictions vs ground truth plot: {e}\")\n    plt.close()\n", "import matplotlib.pyplot as plt\nimport numpy as np\nimport os\n\nworking_dir = os.path.join(os.getcwd(), \"working\")\n\n# Load experiment data\ntry:\n    experiment_data = np.load(\n        os.path.join(working_dir, \"experiment_data.npy\"), allow_pickle=True\n    ).item()\nexcept Exception as e:\n    print(f\"Error loading experiment data: {e}\")\n\ntry:\n    # Extract data for plotting\n    node_counts = experiment_data[\"node_count_ablation\"][\"synthetic_dynamic_network\"][\n        \"node_count_settings\"\n    ]\n    losses = experiment_data[\"node_count_ablation\"][\"synthetic_dynamic_network\"][\n        \"losses\"\n    ]\n    metrics = experiment_data[\"node_count_ablation\"][\"synthetic_dynamic_network\"][\n        \"metrics\"\n    ]\n    tmc = experiment_data[\"node_count_ablation\"][\"synthetic_dynamic_network\"][\n        \"temporal_motif_coverage\"\n    ]\n\n    # Plot losses over epochs for each node count\n    for idx, num_nodes in enumerate(node_counts):\n        if idx >= 5:  # Limit to at most 5 plots\n            break\n        plt.figure()\n        plt.plot(losses[idx][\"train\"], label=\"Training Loss\")\n        plt.plot(losses[idx][\"val\"], label=\"Validation Loss\")\n        plt.title(f\"Loss Over Epochs (Node Count: {num_nodes})\")\n        plt.xlabel(\"Epochs\")\n        plt.ylabel(\"Loss\")\n        plt.legend()\n        plt.savefig(os.path.join(working_dir, f\"loss_plot_nodes_{num_nodes}.png\"))\n        plt.close()\nexcept Exception as e:\n    print(f\"Error creating loss plots: {e}\")\n\ntry:\n    # Plot validation metrics over epochs for each node count\n    for idx, num_nodes in enumerate(node_counts):\n        if idx >= 5:  # Limit to at most 5 plots\n            break\n        plt.figure()\n        plt.plot(metrics[idx][\"val\"], label=\"Validation F1 Score\")\n        plt.title(f\"Validation F1 Score Over Epochs (Node Count: {num_nodes})\")\n        plt.xlabel(\"Epochs\")\n        plt.ylabel(\"F1 Score\")\n        plt.legend()\n        plt.savefig(os.path.join(working_dir, f\"metrics_plot_nodes_{num_nodes}.png\"))\n        plt.close()\nexcept Exception as e:\n    print(f\"Error creating metrics plots: {e}\")\n\ntry:\n    # Plot Temporal Motif Coverage for each node count setting\n    for idx, num_nodes in enumerate(node_counts):\n        plt.figure()\n        plt.plot(tmc[idx], label=\"TMC\")\n        plt.title(f\"Temporal Motif Coverage (Node Count: {num_nodes})\")\n        plt.xlabel(\"Epochs\")\n        plt.ylabel(\"TMC\")\n        plt.legend()\n        plt.savefig(os.path.join(working_dir, f\"tmc_plot_nodes_{num_nodes}.png\"))\n        plt.close()\nexcept Exception as e:\n    print(f\"Error creating TMC plots: {e}\")\n", "import matplotlib.pyplot as plt\nimport numpy as np\nimport os\n\nworking_dir = os.path.join(os.getcwd(), \"working\")\n\ntry:\n    experiment_data = np.load(\n        os.path.join(working_dir, \"experiment_data.npy\"), allow_pickle=True\n    ).item()\nexcept Exception as e:\n    print(f\"Error loading experiment data: {e}\")\n\ntry:\n    feature_counts = experiment_data[\"feature_count_ablation\"][\n        \"synthetic_dynamic_network\"\n    ][\"feature_counts\"]\n    epochs_list = experiment_data[\"feature_count_ablation\"][\n        \"synthetic_dynamic_network\"\n    ][\"epoch_settings\"]\n    losses = experiment_data[\"feature_count_ablation\"][\"synthetic_dynamic_network\"][\n        \"losses\"\n    ][\"train\"]\n    val_f1_scores = experiment_data[\"feature_count_ablation\"][\n        \"synthetic_dynamic_network\"\n    ][\"metrics\"][\"val\"]\n\n    for i, feature_count in enumerate(set(feature_counts)):\n        plt.figure()\n        epoch_indices = [\n            idx for idx, fc in enumerate(feature_counts) if fc == feature_count\n        ]\n        interval = max(\n            1, len(epoch_indices) // 5\n        )  # Plot at most 5 figures per feature count\n        selected_epochs = epoch_indices[::interval]\n\n        plt.subplot(1, 2, 1)\n        plt.plot(\n            [epochs_list[idx] for idx in selected_epochs],\n            [losses[idx] for idx in selected_epochs],\n        )\n        plt.title(f\"Training Loss for Feature Count {feature_count}\")\n        plt.xlabel(\"Epochs\")\n        plt.ylabel(\"Loss\")\n\n        plt.subplot(1, 2, 2)\n        plt.plot(\n            [epochs_list[idx] for idx in selected_epochs],\n            [val_f1_scores[idx] for idx in selected_epochs],\n        )\n        plt.title(f\"Validation F1 Score for Feature Count {feature_count}\")\n        plt.xlabel(\"Epochs\")\n        plt.ylabel(\"F1 Score\")\n\n        plt.tight_layout()\n        plt.savefig(\n            os.path.join(\n                working_dir,\n                f\"synthetic_dynamic_network_feature_{feature_count}_plot.png\",\n            )\n        )\n        plt.close()\nexcept Exception as e:\n    print(f\"Error creating plots: {e}\")\n    plt.close()\n", "import matplotlib.pyplot as plt\nimport numpy as np\nimport os\n\nworking_dir = os.path.join(os.getcwd(), \"working\")\n\ntry:\n    experiment_data = np.load(\n        os.path.join(working_dir, \"experiment_data.npy\"), allow_pickle=True\n    ).item()\nexcept Exception as e:\n    print(f\"Error loading experiment data: {e}\")\n\ntry:\n    feature_counts = experiment_data[\"feature_count_ablation\"][\n        \"synthetic_dynamic_network\"\n    ][\"feature_counts\"]\n    epochs_list = experiment_data[\"feature_count_ablation\"][\n        \"synthetic_dynamic_network\"\n    ][\"epoch_settings\"]\n    losses = experiment_data[\"feature_count_ablation\"][\"synthetic_dynamic_network\"][\n        \"losses\"\n    ][\"train\"]\n    val_f1_scores = experiment_data[\"feature_count_ablation\"][\n        \"synthetic_dynamic_network\"\n    ][\"metrics\"][\"val\"]\n\n    for i, feature_count in enumerate(set(feature_counts)):\n        plt.figure()\n        epoch_indices = [\n            idx for idx, fc in enumerate(feature_counts) if fc == feature_count\n        ]\n        interval = max(\n            1, len(epoch_indices) // 5\n        )  # Plot at most 5 figures per feature count\n        selected_epochs = epoch_indices[::interval]\n\n        plt.subplot(1, 2, 1)\n        plt.plot(\n            [epochs_list[idx] for idx in selected_epochs],\n            [losses[idx] for idx in selected_epochs],\n        )\n        plt.title(f\"Training Loss for Feature Count {feature_count}\")\n        plt.xlabel(\"Epochs\")\n        plt.ylabel(\"Loss\")\n\n        plt.subplot(1, 2, 2)\n        plt.plot(\n            [epochs_list[idx] for idx in selected_epochs],\n            [val_f1_scores[idx] for idx in selected_epochs],\n        )\n        plt.title(f\"Validation F1 Score for Feature Count {feature_count}\")\n        plt.xlabel(\"Epochs\")\n        plt.ylabel(\"F1 Score\")\n\n        plt.tight_layout()\n        plt.savefig(\n            os.path.join(\n                working_dir,\n                f\"synthetic_dynamic_network_feature_{feature_count}_plot.png\",\n            )\n        )\n        plt.close()\nexcept Exception as e:\n    print(f\"Error creating plots: {e}\")\n    plt.close()\n", "import matplotlib.pyplot as plt\nimport numpy as np\nimport os\n\nworking_dir = os.path.join(os.getcwd(), \"working\")\n\ntry:\n    experiment_data = np.load(\n        os.path.join(working_dir, \"experiment_data.npy\"), allow_pickle=True\n    ).item()\nexcept Exception as e:\n    print(f\"Error loading experiment data: {e}\")\n\ntry:\n    feature_counts = experiment_data[\"feature_count_ablation\"][\n        \"synthetic_dynamic_network\"\n    ][\"feature_counts\"]\n    epochs_list = experiment_data[\"feature_count_ablation\"][\n        \"synthetic_dynamic_network\"\n    ][\"epoch_settings\"]\n    losses = experiment_data[\"feature_count_ablation\"][\"synthetic_dynamic_network\"][\n        \"losses\"\n    ][\"train\"]\n    val_f1_scores = experiment_data[\"feature_count_ablation\"][\n        \"synthetic_dynamic_network\"\n    ][\"metrics\"][\"val\"]\n\n    for i, feature_count in enumerate(set(feature_counts)):\n        plt.figure()\n        epoch_indices = [\n            idx for idx, fc in enumerate(feature_counts) if fc == feature_count\n        ]\n        interval = max(\n            1, len(epoch_indices) // 5\n        )  # Plot at most 5 figures per feature count\n        selected_epochs = epoch_indices[::interval]\n\n        plt.subplot(1, 2, 1)\n        plt.plot(\n            [epochs_list[idx] for idx in selected_epochs],\n            [losses[idx] for idx in selected_epochs],\n        )\n        plt.title(f\"Training Loss for Feature Count {feature_count}\")\n        plt.xlabel(\"Epochs\")\n        plt.ylabel(\"Loss\")\n\n        plt.subplot(1, 2, 2)\n        plt.plot(\n            [epochs_list[idx] for idx in selected_epochs],\n            [val_f1_scores[idx] for idx in selected_epochs],\n        )\n        plt.title(f\"Validation F1 Score for Feature Count {feature_count}\")\n        plt.xlabel(\"Epochs\")\n        plt.ylabel(\"F1 Score\")\n\n        plt.tight_layout()\n        plt.savefig(\n            os.path.join(\n                working_dir,\n                f\"synthetic_dynamic_network_feature_{feature_count}_plot.png\",\n            )\n        )\n        plt.close()\nexcept Exception as e:\n    print(f\"Error creating plots: {e}\")\n    plt.close()\n", "import matplotlib.pyplot as plt\nimport numpy as np\nimport os\n\nworking_dir = os.path.join(os.getcwd(), \"working\")\n\n# Load all experiment data\nexperiment_data_paths = [\n    \"experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_f58409f0f5ac4bf9be457b5cb8df4339_proc_5660/experiment_data.npy\",\n    \"experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_efef644de81f4f38a63ebe416507de69_proc_5657/experiment_data.npy\",\n    \"experiments/2025-09-14_13-56-51_temporal_motif_contrastive_anomaly_detection_attempt_0/logs/0-run/experiment_results/experiment_af46cdc8800c441e84b3bdaabfb80308_proc_5657/experiment_data.npy\",\n]\n\nall_losses = []\nall_val_f1_scores = []\nepochs_list = None\n\ntry:\n    for path in experiment_data_paths:\n        experiment_data = np.load(\n            os.path.join(os.getenv(\"AI_SCIENTIST_ROOT\"), path), allow_pickle=True\n        ).item()\n        if epochs_list is None:  # Initialize epochs_list if not done\n            epochs_list = experiment_data[\"feature_count_ablation\"][\n                \"synthetic_dynamic_network\"\n            ][\"epoch_settings\"]\n        all_losses.append(\n            experiment_data[\"feature_count_ablation\"][\"synthetic_dynamic_network\"][\n                \"losses\"\n            ][\"train\"]\n        )\n        all_val_f1_scores.append(\n            experiment_data[\"feature_count_ablation\"][\"synthetic_dynamic_network\"][\n                \"metrics\"\n            ][\"val\"]\n        )\nexcept Exception as e:\n    print(f\"Error loading experiment data: {e}\")\n\n# Calculate means and standard errors\ntry:\n    mean_losses = np.mean(all_losses, axis=0)\n    std_err_losses = np.std(all_losses, axis=0) / np.sqrt(len(all_losses))\n    mean_val_f1_scores = np.mean(all_val_f1_scores, axis=0)\n    std_err_val_f1_scores = np.std(all_val_f1_scores, axis=0) / np.sqrt(\n        len(all_val_f1_scores)\n    )\n\n    # Plot Training Loss with Error Bars\n    plt.figure()\n    plt.errorbar(\n        epochs_list,\n        mean_losses,\n        yerr=std_err_losses,\n        label=\"Mean Training Loss\",\n        fmt=\"-o\",\n        capsize=5,\n    )\n    plt.title(\"Aggregated Training Loss Over Epochs\")\n    plt.xlabel(\"Epochs\")\n    plt.ylabel(\"Loss\")\n    plt.legend()\n    plt.tight_layout()\n    plt.savefig(os.path.join(working_dir, \"aggregated_training_loss.png\"))\n    plt.close()\n\n    # Plot Validation F1 Score with Error Bars\n    plt.figure()\n    plt.errorbar(\n        epochs_list,\n        mean_val_f1_scores,\n        yerr=std_err_val_f1_scores,\n        label=\"Mean Validation F1 Score\",\n        fmt=\"-o\",\n        capsize=5,\n    )\n    plt.title(\"Aggregated Validation F1 Score Over Epochs\")\n    plt.xlabel(\"Epochs\")\n    plt.ylabel(\"F1 Score\")\n    plt.legend()\n    plt.tight_layout()\n    plt.savefig(os.path.join(working_dir, \"aggregated_validation_f1_score.png\"))\n    plt.close()\n\nexcept Exception as e:\n    print(f\"Error creating aggregated plots: {e}\")\n    plt.close()\n"], "plot_plan": ["To create the required visualizations, we first load the experiment data from the 'experiment_data.npy' file. We extract the relevant metrics and losses for training and validation from the 'synthetic_dynamic_network' dataset. We'll plot training loss and validation F1 score curves. For the validation F1 score, we plot against epochs to show how performance changes with training iterations. We generate a maximum of 5 plots for different epoch settings (i.e., 5, 10, 20, 30 epochs) to ensure clarity and manageability. We use a try-except block for each plot to handle potential errors gracefully. After plotting, we save each figure into the 'working' directory with descriptive names to ensure easy identification. Finally, all figures are closed after saving to manage resources efficiently.", "To create standard visualizations of the experiment results stored in 'experiment_data.npy', we will follow these steps:\n\n1. Load the experiment data from the 'experiment_data.npy' file.\n2. For each feature count, plot the training losses and validation F1 scores across different epochs.\n3. Use separate try-except blocks for each plot to handle potential errors gracefully.\n4. Save each plot in the 'working' directory with descriptive names, including details like the dataset name and plot type.\n5. Ensure that figures are closed after saving to manage resources effectively.\n6. Limit the number of plots for similar figures by selecting a suitable interval of epochs to plot, ensuring no more than 5 figures are created for each feature count.\n7. Include appropriate titles and subtitles in the plots for clarity.", null, "To visualize the experiment results from the data stored in `experiment_data.npy`, we will load the data and create plots for the training losses and validation F1 scores for each learning rate setting. We will iterate over each learning rate and plot the training loss and validation F1 score across epochs. For simplicity and clarity, we'll plot at most 5 figures by selecting a suitable interval of epochs. We'll handle any potential errors during data loading and plotting using try-except blocks, ensuring figures are closed after saving or an error occurs. Each plot will be saved with a descriptive name including the dataset and plot type.", "To create visualizations from the experiment data stored in \"experiment_data.npy\", we will start by importing the necessary libraries and setting up the working directory. We'll load the experiment data and iterate over each connectivity type ('sparse', 'dense', 'random') to generate plots for training losses and validation F1 scores. Each plot will be saved individually in the working directory. We'll also ensure that figures are closed after saving to avoid memory issues. Additionally, we'll handle any errors that occur during data loading or plotting in try-except blocks to ensure robustness. The plots will include titles that describe the type of data and metrics being displayed.", "First, we import the necessary libraries and set the working directory. We then load the experiment data from the 'experiment_data.npy' file. We extract relevant data such as training and validation losses, validation F1 scores, predictions, and ground truth values for each activation function used in the experiments. We then proceed to create plots for each type of data. The first plot will display training losses for different activation functions over epochs. The second plot will show validation F1 scores. The third plot will compare predictions versus ground truth. We use a try-except block for each plot to handle potential errors gracefully. We save each plot to the 'working_dir' directory with descriptive filenames that include the dataset name and the plot type. After each plot, we close the figure to free up resources.", null, "To create plots for the experiment data, we first import necessary libraries and set up the working directory. We then load the experiment data from the 'experiment_data.npy' file. The code attempts to generate several plots based on the available data in the experiment data dictionary. It plots training losses, validation F1 scores, Temporal Motif Coverage (TMC), and predictions versus ground truth, while ensuring that only existing data is plotted. Each plot is enclosed in a try-except block for robustness, and figures are closed after saving to manage resources efficiently. The code uses descriptive titles and filenames for each plot and ensures that plots are created at suitable intervals to avoid clutter.", "To create visualizations from the `experiment_data.npy`, we first load the data and extract the relevant information such as metrics, losses, predictions, ground truth, and temporal motif coverage for different node counts. We then create separate plots for each type of data, ensuring to plot at most 5 figures for metrics and losses over epochs. We use try-except blocks to handle potential errors during plotting, and we save each plot with descriptive filenames that include the dataset name and type of plot. After each plot is created, we make sure to close the figures to free up resources.", null, null, null, null], "ablation_name": [null, "Feature Count Ablation", "Edge Connectivity Ablation", "Learning Rate Ablation", null, "Activation Function Ablation", "Node Count Ablation", null, null, null, null, null, null], "hyperparam_name": ["epochs", null, null, null, null, null, null, null, null, null, null, null, null], "is_seed_node": [false, false, false, false, false, false, false, false, false, true, true, true, true], "is_seed_agg_node": [false, false, false, false, false, false, false, false, false, false, false, false, true], "parse_metrics_plan": ["To analyze the experimental results from the numpy file, we will load the file\nusing numpy, which contains a dictionary-like object. The data is structured\nwith multiple keys representing different datasets and metrics. We will extract\nthe metrics for each dataset, focusing on the final values for each metric. The\nscript will print the dataset name followed by the metric names and their final\nvalues. This will involve iterating through the dictionary and accessing the\nrelevant keys to get the desired values. The numpy file is located in the\n'working' directory, which we will handle using `os.path.join(os.getcwd(),\n'working')`.", "To analyze the experimental results stored in the numpy file, first, load the\ndata using `np.load()` with the appropriate file path. The data is structured\nwith nested dictionaries, so traverse the nested structure to extract metrics\nfor each dataset. Print the name of the dataset before printing its metrics, and\nclearly label each metric such as 'validation F1 score' before displaying the\nvalues. Focus on printing the final or best values for each metric. Ensure that\nthe code executes immediately when run, without any additional entry points or\nconditions.", "", "To analyze the experimental data stored in the numpy file, first, load the file\nfrom the specified working directory. The data is structured in a nested\ndictionary format, which includes various metrics and settings related to the\nexperiments. Extract relevant metrics such as the training loss and validation\nF1 score for the dataset named \"synthetic_dynamic_network\". For each metric,\nprint both the name of the dataset and the specific metrics (e.g., the best\nvalidation F1 score and final training loss) clearly. Ensure the code runs as\nsoon as the script is executed.", "To analyze the experimental results, first load the `experiment_data.npy` file\nusing numpy's `np.load` function, ensuring you specify `allow_pickle=True` since\nthe file contains a dictionary object. Iterate over each dataset ('sparse',\n'dense', 'random') in the data, and for each one, print the name of the dataset.\nExtract the final or best value of each metric ('train loss' and 'validation F1\nscore') from the corresponding lists, and print these values with clear labels.\nEnsure the code is executed immediately upon running the script by placing it in\nthe global scope.", "To analyze the experiment data stored in the numpy file, first, we'll set up the\nworking directory path and load the 'experiment_data.npy' file. After loading,\nwe'll extract the relevant metrics for the dataset, which in this case is\n\"synthetic_dynamic_network.\" We'll print out the name of the dataset before\niterating through the metrics. For each metric, we'll print its specific name\nand the corresponding best or final value. The metrics of interest include\ntraining loss and validation F1 score. We'll ensure that the printed information\nis clear and specific, avoiding ambiguous terms.", "To analyze the experiment data, first, the working directory is determined using\n`os.path.join(os.getcwd(), \"working\")`. The experiment data is then loaded from\nthe `experiment_data.npy` file located in this directory. By accessing the\n\"node_count_ablation\" and \"synthetic_dynamic_network\" keys, the metrics and\nlosses for training and validation are extracted. The script prints the dataset\nname \"synthetic_dynamic_network\" and the final values of \"train_loss\" and\n\"validation F1 score\" for each node count setting. The code is structured to\nexecute directly without any special entry point.", "To analyze the experimental results stored in the numpy file, we will first\ndetermine the working directory and load the data from the file\n'experiment_data.npy'. This data will be a dictionary containing metrics for\ndifferent node count settings. We will iterate over the node count settings and\nextract the final metrics for each dataset, ensuring that we clearly label each\ndataset and metric before printing the values. The metrics we are interested in\ninclude the final training loss, validation F1 score, and Temporal Motif\nCoverage (TMC) score. We will print these metrics in a clear format using\ndescriptive labels.", "To analyze the experimental results, we first need to load the data from the\n\"experiment_data.npy\" file, which is stored in the working directory. We will\nextract the data for each node count setting and print the metrics for each\ndataset. We will ensure that the dataset name is printed first, followed by the\nmetrics with clear labels such as 'validation F1 score' and 'validation loss.'\nWe will focus on printing the final value of each metric for clarity and\nconciseness. This approach does not involve any plots and directly executes the\ncode to display the results.", "To analyze the experimental results stored in the numpy file, first, load the\ndata using `np.load()` with the appropriate file path. The data is structured\nwith nested dictionaries, so traverse the nested structure to extract metrics\nfor each dataset. Print the name of the dataset before printing its metrics, and\nclearly label each metric such as 'validation F1 score' before displaying the\nvalues. Focus on printing the final or best values for each metric. Ensure that\nthe code executes immediately when run, without any additional entry points or\nconditions.", "To analyze the experimental results stored in the numpy file, first, load the\ndata using `np.load()` with the appropriate file path. The data is structured\nwith nested dictionaries, so traverse the nested structure to extract metrics\nfor each dataset. Print the name of the dataset before printing its metrics, and\nclearly label each metric such as 'validation F1 score' before displaying the\nvalues. Focus on printing the final or best values for each metric. Ensure that\nthe code executes immediately when run, without any additional entry points or\nconditions.", "To analyze the experimental results stored in the numpy file, first, load the\ndata using `np.load()` with the appropriate file path. The data is structured\nwith nested dictionaries, so traverse the nested structure to extract metrics\nfor each dataset. Print the name of the dataset before printing its metrics, and\nclearly label each metric such as 'validation F1 score' before displaying the\nvalues. Focus on printing the final or best values for each metric. Ensure that\nthe code executes immediately when run, without any additional entry points or\nconditions.", ""], "parse_metrics_code": ["import os\nimport numpy as np\n\n# Load the experiment data from the numpy file\nworking_dir = os.path.join(os.getcwd(), \"working\")\nexperiment_file_path = os.path.join(working_dir, \"experiment_data.npy\")\nexperiment_data = np.load(experiment_file_path, allow_pickle=True).item()\n\n# Extract and print metrics for each dataset\nfor dataset_name, dataset_data in experiment_data[\"hyperparam_tuning_epochs\"].items():\n    print(f\"Dataset: {dataset_name}\")\n\n    # Access metrics and losses\n    metrics = dataset_data[\"metrics\"]\n    losses = dataset_data[\"losses\"]\n\n    # Print the final values for each metric\n    for metric_name, values in metrics.items():\n        if values:  # Check if the list is not empty\n            final_value = values[-1]\n            print(f\"Final validation F1 score: {final_value}\")\n\n    for loss_name, values in losses.items():\n        if values:  # Check if the list is not empty\n            final_value = values[-1]\n            print(f\"Final training loss: {final_value}\")\n\n    # Print predictions and ground truth for completeness\n    predictions = dataset_data[\"predictions\"]\n    ground_truth = dataset_data[\"ground_truth\"]\n    print(f\"Predictions: {predictions[:5]}...\")  # Print first 5 predictions\n    print(f\"Ground Truth: {ground_truth[:5]}...\\n\")  # Print first 5 ground truth\n", "import os\nimport numpy as np\n\n# Get the working directory\nworking_dir = os.path.join(os.getcwd(), \"working\")\n\n# Load the experiment data\nexperiment_data = np.load(\n    os.path.join(working_dir, \"experiment_data.npy\"), allow_pickle=True\n).item()\n\n# Extract metrics for each dataset\nfor feature_ablation, datasets in experiment_data.items():\n    for dataset_name, metrics_dict in datasets.items():\n        print(f\"Dataset: {dataset_name}\")\n\n        # Extract and print the final validation F1 score\n        final_val_f1_score = metrics_dict[\"metrics\"][\"val\"][-1]\n        print(f\"Final validation F1 score: {final_val_f1_score:.4f}\")\n\n        # Extract and print the final training loss\n        final_train_loss = metrics_dict[\"losses\"][\"train\"][-1]\n        print(f\"Final training loss: {final_train_loss:.4f}\")\n\n        # Print the final predictions and ground truth (if needed)\n        # Here, we'll just print their lengths as an example\n        predictions = metrics_dict[\"predictions\"]\n        ground_truth = metrics_dict[\"ground_truth\"]\n        print(f\"Number of predictions: {len(predictions)}\")\n        print(f\"Number of ground truth labels: {len(ground_truth)}\")\n", "", "import os\nimport numpy as np\n\n# Load the experiment data\nworking_dir = os.path.join(os.getcwd(), \"working\")\nexperiment_data = np.load(\n    os.path.join(working_dir, \"experiment_data.npy\"), allow_pickle=True\n).item()\n\n\ndef analyze_experiment_data(data):\n    for experiment_name, experiment_details in data.items():\n        for dataset_name, dataset_details in experiment_details.items():\n            # Print dataset name\n            print(f\"Dataset: {dataset_name}\")\n\n            # Extract metrics\n            train_losses = dataset_details[\"losses\"][\"train\"]\n            val_metrics = dataset_details[\"metrics\"][\"val\"]\n\n            # Retrieve and print final training loss and best validation F1 score\n            final_train_loss = train_losses[-1]\n            best_val_f1_score = max(val_metrics)\n\n            print(f\"Final Training Loss: {final_train_loss}\")\n            print(f\"Best Validation F1 Score: {best_val_f1_score}\")\n            print()\n\n\n# Analyze the experiment data\nanalyze_experiment_data(experiment_data)\n", "import os\nimport numpy as np\n\n# Load the experiment data\nworking_dir = os.path.join(os.getcwd(), \"working\")\nfile_path = os.path.join(working_dir, \"experiment_data.npy\")\nexperiment_data = np.load(file_path, allow_pickle=True).item()\n\n# Iterate through each dataset and print the metrics\nfor connectivity, data in experiment_data.items():\n    print(f\"Dataset: {connectivity}\")\n\n    # Get the final train loss\n    train_loss = data[\"losses\"][\"train\"][-1]\n    print(f\"Final train loss: {train_loss:.4f}\")\n\n    # Get the best validation F1 score\n    best_val_f1 = max(data[\"metrics\"][\"val\"])\n    print(f\"Best validation F1 score: {best_val_f1:.4f}\")\n", "import os\nimport numpy as np\n\n# Set up working directory\nworking_dir = os.path.join(os.getcwd(), \"working\")\n\n\ndef load_and_analyze_experiment_data():\n    # Load the experiment data\n    experiment_data = np.load(\n        os.path.join(working_dir, \"experiment_data.npy\"), allow_pickle=True\n    ).item()\n\n    # Extract the relevant data\n    dataset_name = \"synthetic_dynamic_network\"\n    dataset_data = experiment_data[\"activation_function_ablation\"][dataset_name]\n\n    # Print dataset name\n    print(f\"Dataset: {dataset_name}\")\n\n    # Extract and print final training loss\n    final_train_loss = dataset_data[\"losses\"][\"train\"][-1]\n    print(f\"Final training loss: {final_train_loss}\")\n\n    # Extract and print final validation F1 score\n    final_val_f1 = dataset_data[\"metrics\"][\"val\"][-1]\n    print(f\"Final validation F1 score: {final_val_f1}\")\n\n\n# Execute the function to load and analyze the data\nload_and_analyze_experiment_data()\n", "import os\nimport numpy as np\n\n# Load the experiment data\nworking_dir = os.path.join(os.getcwd(), \"working\")\nexperiment_data = np.load(\n    os.path.join(working_dir, \"experiment_data.npy\"), allow_pickle=True\n).item()\n\n# Extract data for 'node_count_ablation' -> 'synthetic_dynamic_network'\nnode_count_data = experiment_data[\"node_count_ablation\"][\"synthetic_dynamic_network\"]\n\n# Extract metrics and losses\ntrain_losses = node_count_data[\"losses\"][\"train\"]\nval_f1_scores = node_count_data[\"metrics\"][\"val\"]\nnode_count_settings = node_count_data[\"node_count_settings\"]\n\n# Print the metrics for each node count setting\nprint(\"Dataset: synthetic_dynamic_network\")\nfor i, node_count in enumerate(node_count_settings):\n    print(f\"Node Count Setting: {node_count}\")\n    final_train_loss = train_losses[\n        (i + 1) * 20 - 1\n    ]  # Get the last training loss for this node count\n    final_val_f1 = val_f1_scores[\n        (i + 1) * 20 - 1\n    ]  # Get the last validation F1 score for this node count\n    print(f\"Final train loss: {final_train_loss:.4f}\")\n    print(f\"Final validation F1 score: {final_val_f1:.4f}\")\n", "import os\nimport numpy as np\n\n# Load experiment data from numpy file in the working directory\nworking_dir = os.path.join(os.getcwd(), \"working\")\nexperiment_data = np.load(\n    os.path.join(working_dir, \"experiment_data.npy\"), allow_pickle=True\n).item()\n\n# Extracting and printing metrics for each dataset\nfor node_count in experiment_data[\"node_count_ablation\"][\"synthetic_dynamic_network\"][\n    \"node_count_settings\"\n]:\n    # Access the metrics for the given node count\n    dataset_metrics = experiment_data[\"node_count_ablation\"][\n        \"synthetic_dynamic_network\"\n    ]\n\n    # Print the dataset name\n    print(f\"Dataset: Synthetic Dynamic Network with Node Count {node_count}\")\n\n    # Extract and print the final train loss\n    final_train_loss = dataset_metrics[\"losses\"][\"train\"][-1]\n    print(f\"Final Train Loss: {final_train_loss:.4f}\")\n\n    # Extract and print the final validation F1 score\n    final_val_f1 = dataset_metrics[\"metrics\"][\"val\"][-1]\n    print(f\"Final Validation F1 Score: {final_val_f1:.4f}\")\n\n    # Extract and print the final Temporal Motif Coverage (TMC)\n    final_tmc = dataset_metrics[\"metrics\"][\"tmc\"][-1]\n    print(f\"Final Temporal Motif Coverage (TMC): {final_tmc:.4f}\")\n\n    print()  # Add a newline for better readability between datasets\n", "import os\nimport numpy as np\n\n# Load the experiment data from the working directory\nworking_dir = os.path.join(os.getcwd(), \"working\")\nexperiment_file_path = os.path.join(working_dir, \"experiment_data.npy\")\nexperiment_data = np.load(experiment_file_path, allow_pickle=True).item()\n\n# Extracting and printing the metrics\nnode_count_ablation = experiment_data[\"node_count_ablation\"][\n    \"synthetic_dynamic_network\"\n]\n\nmetrics = node_count_ablation[\"metrics\"]\nlosses = node_count_ablation[\"losses\"]\nnode_count_settings = node_count_ablation[\"node_count_settings\"]\n\nfor i, node_count in enumerate(node_count_settings):\n    print(f\"Dataset with Node Count: {node_count}\")\n\n    # Get the metrics and losses for the current node count setting\n    node_metrics = metrics[i]\n    node_losses = losses[i]\n\n    # Print the final or best metrics with clear labels\n    final_val_f1 = node_metrics[\"val\"][-1]\n    final_train_loss = node_losses[\"train\"][-1]\n    final_val_loss = node_losses[\"val\"][-1]\n\n    print(f\"Final Validation F1 Score: {final_val_f1:.4f}\")\n    print(f\"Final Training Loss: {final_train_loss:.4f}\")\n    print(f\"Final Validation Loss: {final_val_loss:.4f}\")\n    print(\"\")  # Print a newline for separation between datasets\n", "import os\nimport numpy as np\n\n# Get the working directory\nworking_dir = os.path.join(os.getcwd(), \"working\")\n\n# Load the experiment data\nexperiment_data = np.load(\n    os.path.join(working_dir, \"experiment_data.npy\"), allow_pickle=True\n).item()\n\n# Extract metrics for each dataset\nfor feature_ablation, datasets in experiment_data.items():\n    for dataset_name, metrics_dict in datasets.items():\n        print(f\"Dataset: {dataset_name}\")\n\n        # Extract and print the final validation F1 score\n        final_val_f1_score = metrics_dict[\"metrics\"][\"val\"][-1]\n        print(f\"Final validation F1 score: {final_val_f1_score:.4f}\")\n\n        # Extract and print the final training loss\n        final_train_loss = metrics_dict[\"losses\"][\"train\"][-1]\n        print(f\"Final training loss: {final_train_loss:.4f}\")\n\n        # Print the final predictions and ground truth (if needed)\n        # Here, we'll just print their lengths as an example\n        predictions = metrics_dict[\"predictions\"]\n        ground_truth = metrics_dict[\"ground_truth\"]\n        print(f\"Number of predictions: {len(predictions)}\")\n        print(f\"Number of ground truth labels: {len(ground_truth)}\")\n", "import os\nimport numpy as np\n\n# Get the working directory\nworking_dir = os.path.join(os.getcwd(), \"working\")\n\n# Load the experiment data\nexperiment_data = np.load(\n    os.path.join(working_dir, \"experiment_data.npy\"), allow_pickle=True\n).item()\n\n# Extract metrics for each dataset\nfor feature_ablation, datasets in experiment_data.items():\n    for dataset_name, metrics_dict in datasets.items():\n        print(f\"Dataset: {dataset_name}\")\n\n        # Extract and print the final validation F1 score\n        final_val_f1_score = metrics_dict[\"metrics\"][\"val\"][-1]\n        print(f\"Final validation F1 score: {final_val_f1_score:.4f}\")\n\n        # Extract and print the final training loss\n        final_train_loss = metrics_dict[\"losses\"][\"train\"][-1]\n        print(f\"Final training loss: {final_train_loss:.4f}\")\n\n        # Print the final predictions and ground truth (if needed)\n        # Here, we'll just print their lengths as an example\n        predictions = metrics_dict[\"predictions\"]\n        ground_truth = metrics_dict[\"ground_truth\"]\n        print(f\"Number of predictions: {len(predictions)}\")\n        print(f\"Number of ground truth labels: {len(ground_truth)}\")\n", "import os\nimport numpy as np\n\n# Get the working directory\nworking_dir = os.path.join(os.getcwd(), \"working\")\n\n# Load the experiment data\nexperiment_data = np.load(\n    os.path.join(working_dir, \"experiment_data.npy\"), allow_pickle=True\n).item()\n\n# Extract metrics for each dataset\nfor feature_ablation, datasets in experiment_data.items():\n    for dataset_name, metrics_dict in datasets.items():\n        print(f\"Dataset: {dataset_name}\")\n\n        # Extract and print the final validation F1 score\n        final_val_f1_score = metrics_dict[\"metrics\"][\"val\"][-1]\n        print(f\"Final validation F1 score: {final_val_f1_score:.4f}\")\n\n        # Extract and print the final training loss\n        final_train_loss = metrics_dict[\"losses\"][\"train\"][-1]\n        print(f\"Final training loss: {final_train_loss:.4f}\")\n\n        # Print the final predictions and ground truth (if needed)\n        # Here, we'll just print their lengths as an example\n        predictions = metrics_dict[\"predictions\"]\n        ground_truth = metrics_dict[\"ground_truth\"]\n        print(f\"Number of predictions: {len(predictions)}\")\n        print(f\"Number of ground truth labels: {len(ground_truth)}\")\n", ""], "parse_term_out": ["['Dataset: synthetic_dynamic_network', '\\n', 'Final validation F1 score:\n0.8900330297267541', '\\n', 'Final training loss: 0.32455357909202576', '\\n',\n'Predictions: [0, 0, 1, 1, 1]...', '\\n', 'Ground Truth: [0, 0, 1, 1, 1]...\\n',\n'\\n', 'Execution time: a moment seconds (time limit is an hour).']", "['Dataset: synthetic_dynamic_network', '\\n', 'Final validation F1 score:\n1.0000', '\\n', 'Final training loss: 0.0809', '\\n', 'Number of predictions:\n100', '\\n', 'Number of ground truth labels: 100', '\\n', 'Execution time: a\nmoment seconds (time limit is an hour).']", "", "['Dataset: synthetic_dynamic_network', '\\n', 'Final Training Loss:\n0.3812828063964844', '\\n', 'Best Validation F1 Score: 0.9100270243218899', '\\n',\n'\\n', 'Execution time: a moment seconds (time limit is an hour).']", "['Dataset: sparse', '\\n', 'Final train loss: 0.3604', '\\n', 'Best validation F1\nscore: 0.8495', '\\n', 'Dataset: dense', '\\n', 'Final train loss: 0.4413', '\\n',\n'Best validation F1 score: 0.7792', '\\n', 'Dataset: random', '\\n', 'Final train\nloss: 0.2274', '\\n', 'Best validation F1 score: 0.9190', '\\n', 'Execution time:\na moment seconds (time limit is an hour).']", "['Dataset: synthetic_dynamic_network', '\\n', 'Final training loss:\n0.49043452739715576', '\\n', 'Final validation F1 score: 0.8', '\\n', 'Execution\ntime: a moment seconds (time limit is an hour).']", "['Dataset: synthetic_dynamic_network', '\\n', 'Node Count Setting: 50', '\\n',\n'Final train loss: 0.3301', '\\n', 'Final validation F1 score: 0.8604', '\\n',\n'Node Count Setting: 50', '\\n', 'Final train loss: 0.5346', '\\n', 'Final\nvalidation F1 score: 0.7194', '\\n', 'Node Count Setting: 50', '\\n', 'Final train\nloss: 0.5178', '\\n', 'Final validation F1 score: 0.7604', '\\n', 'Node Count\nSetting: 50', '\\n', 'Traceback (most recent call last):\\n  File \"runfile.py\",\nline 22, in <module>\\n    final_train_loss = train_losses[\\n\n^^^^^^^^^^^^^\\nIndexError: list index out of range\\n', 'Execution time: a moment\nseconds (time limit is an hour).']", "['Dataset: Synthetic Dynamic Network with Node Count 50', '\\n', 'Final Train\nLoss: 0.5027', '\\n', 'Final Validation F1 Score: 0.7498', '\\n', 'Final Temporal\nMotif Coverage (TMC): 0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic Network\nwith Node Count 50', '\\n', 'Final Train Loss: 0.5027', '\\n', 'Final Validation\nF1 Score: 0.7498', '\\n', 'Final Temporal Motif Coverage (TMC): 0.2339', '\\n',\n'\\n', 'Dataset: Synthetic Dynamic Network with Node Count 50', '\\n', 'Final\nTrain Loss: 0.5027', '\\n', 'Final Validation F1 Score: 0.7498', '\\n', 'Final\nTemporal Motif Coverage (TMC): 0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic\nNetwork with Node Count 50', '\\n', 'Final Train Loss: 0.5027', '\\n', 'Final\nValidation F1 Score: 0.7498', '\\n', 'Final Temporal Motif Coverage (TMC):\n0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic Network with Node Count 50',\n'\\n', 'Final Train Loss: 0.5027', '\\n', 'Final Validation F1 Score: 0.7498',\n'\\n', 'Final Temporal Motif Coverage (TMC): 0.2339', '\\n', '\\n', 'Dataset:\nSynthetic Dynamic Network with Node Count 50', '\\n', 'Final Train Loss: 0.5027',\n'\\n', 'Final Validation F1 Score: 0.7498', '\\n', 'Final Temporal Motif Coverage\n(TMC): 0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic Network with Node Count\n50', '\\n', 'Final Train Loss: 0.5027', '\\n', 'Final Validation F1 Score:\n0.7498', '\\n', 'Final Temporal Motif Coverage (TMC): 0.2339', '\\n', '\\n',\n'Dataset: Synthetic Dynamic Network with Node Count 50', '\\n', 'Final Train\nLoss: 0.5027', '\\n', 'Final Validation F1 Score: 0.7498', '\\n', 'Final Temporal\nMotif Coverage (TMC): 0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic Network\nwith Node Count 50', '\\n', 'Final Train Loss: 0.5027', '\\n', 'Final Validation\nF1 Score: 0.7498', '\\n', 'Final Temporal Motif Coverage (TMC): 0.2339', '\\n',\n'\\n', 'Dataset: Synthetic Dynamic Network with Node Count 50', '\\n', 'Final\nTrain Loss: 0.5027', '\\n', 'Final Validation F1 Score: 0.7498', '\\n', 'Final\nTemporal Motif Coverage (TMC): 0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic\nNetwork with Node Count 50', '\\n', 'Final Train Loss: 0.5027', '\\n', 'Final\nValidation F1 Score: 0.7498', '\\n', 'Final Temporal Motif Coverage (TMC):\n0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic Network with Node Count 50',\n'\\n', 'Final Train Loss: 0.5027', '\\n', 'Final Validation F1 Score: 0.7498',\n'\\n', 'Final Temporal Motif Coverage (TMC): 0.2339', '\\n', '\\n', 'Dataset:\nSynthetic Dynamic Network with Node Count 50', '\\n', 'Final Train Loss: 0.5027',\n'\\n', 'Final Validation F1 Score: 0.7498', '\\n', 'Final Temporal Motif Coverage\n(TMC): 0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic Network with Node Count\n50', '\\n', 'Final Train Loss: 0.5027', '\\n', 'Final Validation F1 Score:\n0.7498', '\\n', 'Final Temporal Motif Coverage (TMC): 0.2339', '\\n', '\\n',\n'Dataset: Synthetic Dynamic Network with Node Count 50', '\\n', 'Final Train\nLoss: 0.5027', '\\n', 'Final Validation F1 Score: 0.7498', '\\n', 'Final Temporal\nMotif Coverage (TMC): 0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic Network\nwith Node Count 50', '\\n', 'Final Train Loss: 0.5027', '\\n', 'Final Validation\nF1 Score: 0.7498', '\\n', 'Final Temporal Motif Coverage (TMC): 0.2339', '\\n',\n'\\n', 'Dataset: Synthetic Dynamic Network with Node Count 50', '\\n', 'Final\nTrain Loss: 0.5027', '\\n', 'Final Validation F1 Score: 0.7498', '\\n', 'Final\nTemporal Motif Coverage (TMC): 0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic\nNetwork with Node Count 50', '\\n', 'Final Train Loss: 0.5027', '\\n', 'Final\nValidation F1 Score: 0.7498', '\\n', 'Final Temporal Motif Coverage (TMC):\n0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic Network with Node Count 50',\n'\\n', 'Final Train Loss: 0.5027', '\\n', 'Final Validation F1 Score: 0.7498',\n'\\n', 'Final Temporal Motif Coverage (TMC): 0.2339', '\\n', '\\n', 'Dataset:\nSynthetic Dynamic Network with Node Count 50', '\\n', 'Final Train Loss: 0.5027',\n'\\n', 'Final Validation F1 Score: 0.7498', '\\n', 'Final Temporal Motif Coverage\n(TMC): 0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic Network with Node Count\n150', '\\n', 'Final Train Loss: 0.5027', '\\n', 'Final Validation F1 Score:\n0.7498', '\\n', 'Final Temporal Motif Coverage (TMC): 0.2339', '\\n', '\\n',\n'Dataset: Synthetic Dynamic Network with Node Count 150', '\\n', 'Final Train\nLoss: 0.5027', '\\n', 'Final Validation F1 Score: 0.7498', '\\n', 'Final Temporal\nMotif Coverage (TMC): 0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic Network\nwith Node Count 150', '\\n', 'Final Train Loss: 0.5027', '\\n', 'Final Validation\nF1 Score: 0.7498', '\\n', 'Final Temporal Motif Coverage (TMC): 0.2339', '\\n',\n'\\n', 'Dataset: Synthetic Dynamic Network with Node Count 150', '\\n', 'Final\nTrain Loss: 0.5027', '\\n', 'Final Validation F1 Score: 0.7498', '\\n', 'Final\nTemporal Motif Coverage (TMC): 0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic\nNetwork with Node Count 150', '\\n', 'Final Train Loss: 0.5027', '\\n', 'Final\nValidation F1 Score: 0.7498', '\\n', 'Final Temporal Motif Coverage (TMC):\n0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic Network with Node Count 150',\n'\\n', 'Final Train Loss: 0.5027', '\\n', 'Final Validation F1 Score: 0.7498',\n'\\n', 'Final Temporal Motif Coverage (TMC): 0.2339', '\\n', '\\n', 'Dataset:\nSynthetic Dynamic Network with Node Count 150', '\\n', 'Final Train Loss:\n0.5027', '\\n', 'Final Validation F1 Score: 0.7498', '\\n', 'Final Temporal Motif\nCoverage (TMC): 0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic Network with\nNode Count 150', '\\n', 'Final Train Loss: 0.5027', '\\n', 'Final Validation F1\nScore: 0.7498', '\\n', 'Final Temporal Motif Coverage (TMC): 0.2339', '\\n', '\\n',\n'Dataset: Synthetic Dynamic Network with Node Count 150', '\\n', 'Final Train\nLoss: 0.5027', '\\n', 'Final Validation F1 Score: 0.7498', '\\n', 'Final Temporal\nMotif Coverage (TMC): 0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic Network\nwith Node Count 150', '\\n', 'Final Train Loss: 0.5027', '\\n', 'Final Validation\nF1 Score: 0.7498', '\\n', 'Final Temporal Motif Coverage (TMC): 0.2339', '\\n',\n'\\n', 'Dataset: Synthetic Dynamic Network with Node Count 150', '\\n', 'Final\nTrain Loss: 0.5027', '\\n', 'Final Validation F1 Score: 0.7498', '\\n', 'Final\nTemporal Motif Coverage (TMC): 0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic\nNetwork with Node Count 150', '\\n', 'Final Train Loss: 0.5027', '\\n', 'Final\nValidation F1 Score: 0.7498', '\\n', 'Final Temporal Motif Coverage (TMC):\n0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic Network with Node Count 150',\n'\\n', 'Final Train Loss: 0.5027', '\\n', 'Final Validation F1 Score: 0.7498',\n'\\n', 'Final Temporal Motif Coverage (TMC): 0.2339', '\\n', '\\n', 'Dataset:\nSynthetic Dynamic Network with Node Count 150', '\\n', 'Final Train Loss:\n0.5027', '\\n', 'Final Validation F1 Score: 0.7498', '\\n', 'Final Temporal Motif\nCoverage (TMC): 0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic Network with\nNode Count 150', '\\n', 'Final Train Loss: 0.5027', '\\n', 'Final Validation F1\nScore: 0.7498', '\\n', 'Final Temporal Motif Coverage (TMC): 0.2339', '\\n', '\\n',\n'Dataset: Synthetic Dynamic Network with Node Count 150', '\\n', 'Final Train\nLoss: 0.5027', '\\n', 'Final Validation F1 Score: 0.7498', '\\n', 'Final Temporal\nMotif Coverage (TMC): 0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic Network\nwith Node Count 150', '\\n', 'Final Train Loss: 0.5027', '\\n', 'Final Validation\nF1 Score: 0.7498', '\\n', 'Final Temporal Motif Coverage (TMC): 0.2339', '\\n',\n'\\n', 'Dataset: Synthetic Dynamic Network with Node Count 150', '\\n', 'Final\nTrain Loss: 0.5027', '\\n', 'Final Validation F1 Score: 0.7498', '\\n', 'Final\nTemporal Motif Coverage (TMC): 0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic\nNetwork with Node Count 150', '\\n', 'Final Train Loss: 0.5027', '\\n', 'Final\nValidation F1 Score: 0.7498', '\\n', 'Final Temporal Motif Coverage (TMC):\n0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic Network with Node Count 150',\n'\\n', 'Final Train Loss: 0.5027', '\\n', 'Final Validation F1 Score: 0.7498',\n'\\n', 'Final Temporal Motif Coverage (TMC): 0.2339', '\\n', '\\n', 'Dataset:\nSynthetic Dynamic Network with Node Count 200', '\\n', 'Final Train Loss:\n0.5027', '\\n', 'Final Validation F1 Score: 0.7498', '\\n', 'Final Temporal Motif\nCoverage (TMC): 0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic Network with\nNode Count 200', '\\n', 'Final Train Loss: 0.5027', '\\n', 'Final Validation F1\nScore: 0.7498', '\\n', 'Final Temporal Motif Coverage (TMC): 0.2339', '\\n', '\\n',\n'Dataset: Synthetic Dynamic Network with Node Count 200', '\\n', 'Final Train\nLoss: 0.5027', '\\n', 'Final Validation F1 Score: 0.7498', '\\n', 'Final Temporal\nMotif Coverage (TMC): 0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic Network\nwith Node Count 200', '\\n', 'Final Train Loss: 0.5027', '\\n', 'Final Validation\nF1 Score: 0.7498', '\\n', 'Final Temporal Motif Coverage (TMC): 0.2339', '\\n',\n'\\n', 'Dataset: Synthetic Dynamic Network with Node Count 200', '\\n', 'Final\nTrain Loss: 0.5027', '\\n', 'Final Validation F1 Score: 0.7498', '\\n', 'Final\nTemporal Motif Coverage (TMC): 0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic\nNetwork with Node Count 200', '\\n', 'Final Train Loss: 0.5027', '\\n', 'Final\nValidation F1 Score: 0.7498', '\\n', 'Final Temporal Motif Coverage (TMC):\n0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic Network with Node Count 200',\n'\\n', 'Final Train Loss: 0.5027', '\\n', 'Final Validation F1 Score: 0.7498',\n'\\n', 'Final Temporal Motif Coverage (TMC): 0.2339', '\\n', '\\n', 'Dataset:\nSynthetic Dynamic Network with Node Count 200', '\\n', 'Final Train Loss:\n0.5027', '\\n', 'Final Validation F1 Score: 0.7498', '\\n', 'Final Temporal Motif\nCoverage (TMC): 0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic Network with\nNode Count 200', '\\n', 'Final Train Loss: 0.5027', '\\n', 'Final Validation F1\nScore: 0.7498', '\\n', 'Final Temporal Motif Coverage (TMC): 0.2339', '\\n', '\\n',\n'Dataset: Synthetic Dynamic Network with Node Count 200', '\\n', 'Final Train\nLoss: 0.5027', '\\n', 'Final Validation F1 Score: 0.7498', '\\n', 'Final Temporal\nMotif Coverage (TMC): 0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic Network\nwith Node Count 200', '\\n', 'Final Train Loss: 0.5027', '\\n', 'Final Validation\nF1 Score: 0.7498', '\\n', 'Final Temporal Motif Coverage (TMC): 0.2339', '\\n',\n'\\n', 'Dataset: Synthetic Dynamic Network with Node Count 200', '\\n', 'Final\nTrain Loss: 0.5027', '\\n', 'Final Validation F1 Score: 0.7498', '\\n', 'Final\nTemporal Motif Coverage (TMC): 0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic\nNetwork with Node Count 200', '\\n', 'Final Train Loss: 0.5027', '\\n', 'Final\nValidation F1 Score: 0.7498', '\\n', 'Final Temporal Motif Coverage (TMC):\n0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic Network with Node Count 200',\n'\\n', 'Final Train Loss: 0.5027', '\\n', 'Final Validation F1 Score: 0.7498',\n'\\n', 'Final Temporal Motif Coverage (TMC): 0.2339', '\\n', '\\n', 'Dataset:\nSynthetic Dynamic Network with Node Count 200', '\\n', 'Final Train Loss:\n0.5027', '\\n', 'Final Validation F1 Score: 0.7498', '\\n', 'Final Temporal Motif\nCoverage (TMC): 0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic Network with\nNode Count 200', '\\n', 'Final Train Loss: 0.5027', '\\n', 'Final Validation F1\nScore: 0.7498', '\\n', 'Final Temporal Motif Coverage (TMC): 0.2339', '\\n', '\\n',\n'Dataset: Synthetic Dynamic Network with Node Count 200', '\\n', 'Final Train\nLoss: 0.5027', '\\n', 'Final Validation F1 Score: 0.7498', '\\n', 'Final Temporal\nMotif Coverage (TMC): 0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic Network\nwith Node Count 200', '\\n', 'Final Train Loss: 0.5027', '\\n', 'Final Validation\nF1 Score: 0.7498', '\\n', 'Final Temporal Motif Coverage (TMC): 0.2339', '\\n',\n'\\n', 'Dataset: Synthetic Dynamic Network with Node Count 200', '\\n', 'Final\nTrain Loss: 0.5027', '\\n', 'Final Validation F1 Score: 0.7498', '\\n', 'Final\nTemporal Motif Coverage (TMC): 0.2339', '\\n', '\\n', 'Dataset: Synthetic Dynamic\nNetwork with Node Count 200', '\\n', 'Final Train Loss: 0.5027', '\\n', 'Final\nValidation F1 Score: 0.7498', '\\n', 'Final Temporal Motif Coverage (TMC):\n0.2339', '\\n', '\\n', 'Execution time: a moment seconds (time limit is an\nhour).']", "['Dataset with Node Count: 50', '\\n', 'Final Validation F1 Score: 0.8347', '\\n',\n'Final Training Loss: 0.3625', '\\n', 'Final Validation Loss: 0.3530', '\\n', '',\n'\\n', 'Dataset with Node Count: 150', '\\n', 'Final Validation F1 Score: 0.7796',\n'\\n', 'Final Training Loss: 0.5141', '\\n', 'Final Validation Loss: 0.5051',\n'\\n', '', '\\n', 'Dataset with Node Count: 200', '\\n', 'Final Validation F1\nScore: 0.7149', '\\n', 'Final Training Loss: 0.5822', '\\n', 'Final Validation\nLoss: 0.5776', '\\n', '', '\\n', 'Execution time: a moment seconds (time limit is\nan hour).']", "['Dataset: synthetic_dynamic_network', '\\n', 'Final validation F1 score:\n1.0000', '\\n', 'Final training loss: 0.0641', '\\n', 'Number of predictions:\n100', '\\n', 'Number of ground truth labels: 100', '\\n', 'Execution time: a\nmoment seconds (time limit is an hour).']", "['Dataset: synthetic_dynamic_network', '\\n', 'Final validation F1 score:\n1.0000', '\\n', 'Final training loss: 0.0641', '\\n', 'Number of predictions:\n100', '\\n', 'Number of ground truth labels: 100', '\\n', 'Execution time: a\nmoment seconds (time limit is an hour).']", "['Dataset: synthetic_dynamic_network', '\\n', 'Final validation F1 score:\n1.0000', '\\n', 'Final training loss: 0.0641', '\\n', 'Number of predictions:\n100', '\\n', 'Number of ground truth labels: 100', '\\n', 'Execution time: a\nmoment seconds (time limit is an hour).']", ""], "parse_exc_type": [null, null, null, null, null, null, "IndexError", null, null, null, null, null, null], "parse_exc_info": [null, null, null, null, null, null, {"args": ["list index out of range"]}, null, null, null, null, null, null], "parse_exc_stack": [null, null, null, null, null, null, [["/Users/fourzeroo/repos/ai_scientist/ai_scientists/AI-Scientist-V2/ai_scientist/treesearch/interpreter.py", 144, "_run_session", "exec(compile(code, self.agent_file_name, \"exec\"), global_scope)"], ["runfile.py", 22, "<module>", "final_train_loss = train_losses["]], null, null, null, null, null, null], "completed_stages": ["Stage_1", "Stage_2", "Stage_3", "Stage_4"], "current_stage": "Stage_4"};

// Add log directory path and stage info to the tree data
treeStructData.log_dir_path = window.location.pathname.split('/').slice(0, -1).join('/');
treeStructData.current_stage = window.location.pathname.includes('stage_')
  ? window.location.pathname.split('stage_')[1].split('/')[0]
  : 'Stage_1';

// Initialize background color
window.bgColCurrent = bgCol;

// Function to set background color that can be called from the console
function setBackgroundColor(color) {
  // Update the global color
  updateBackgroundColor(color);

  // Refresh the current sketch to apply the new background color
  if (currentStage) {
    startSketch(currentStage);
  }
}

// Load all stage data and initialize the visualization
loadAllStageData(treeStructData);

    </script>
    <title>AI Scientist-v2 Visualization</title>
    <style>
      body,
      * {
        margin: 0;
        padding: 0;
        box-sizing: border-box;
      }
      body {
        background-color: #ffffff;
        font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
      }
      #canvas-container {
        position: absolute;
        left: 0;
        top: 0;
        width: 40vw;
        height: 100vh;
        background-color: inherit;
        padding-top: 40px;
      }
      canvas {
        float: left;
        height: 100vh;
        width: 100vw;
      }
      #text-container {
        float: right;
        height: 100vh;
        width: 50vw;
        background-color: #282c34;
        overflow: auto;
      }
      #plan {
        /* border-left: 2px solid #282c34; */
        background-color: #282c34;
        color: #f2f0e7;
        min-height: 5rem;
        padding: 1em 0 1em 1em;
      }
      #plot_plan {
        background-color: #282c34;
        color: #f2f0e7;
        min-height: 5rem;
        padding: 1em 0 1em 1em;
        white-space: pre-wrap;
      }
      #exec_time_feedback {
        margin-top: 20px;
        padding: 10px;
        background-color: #282c34;
        border-left: 3px solid #ff5555;
        color: #f2f0e7;
      }
      #exec_time {
        margin-top: 20px;
        padding: 10px;
        background-color: #282c34;
        border-left: 3px solid #ff5555;
        color: #f2f0e7;
      }
      #exc_info {
        margin-top: 20px;
        padding: 10px;
        background-color: #2c1f1f;
        border-left: 3px solid #ff5555;
        color: #f2f0e7;
      }
      #metrics {
        margin-top: 20px;
        padding: 10px;
        background-color: #282c34;
        color: #f2f0e7;
      }
      #vlm_feedback {
        margin-top: 20px;
        padding: 10px;
        background-color: #1f2c2f;
        color: #f2f0e7;
        border-left: 3px solid #55ff55;
      }
      #vlm_feedback p {
        margin: 0.5em 0;
        white-space: pre-wrap;
      }
      .datasets_successfully_tested {
        margin-top: 20px;
        padding: 10px;
        background-color: #282c34;
        color: #f2f0e7;
        border-left: 3px solid #55ff55;
      }
      .plots-container {
        float: right;
        width: 50vw;
        padding: 1rem;
        background-color: #282c34;
        margin-top: 1rem;
      }

      .plot-item {
        flex: 1 1 300px;
        max-width: 100%;
        margin-bottom: 1rem;
        white-space: pre-wrap;
      }

      .plot-item img {
        width: 100%;
        height: auto;
        border-radius: 4px;
        box-shadow: 0 2px 4px rgba(0,0,0,0.1);
        display: block;
      }

      .metric-group {
        margin-bottom: 20px;
        padding: 10px;
        border: 1px solid #ddd;
        border-radius: 4px;
      }

      .metric-table {
        width: 100%;
        border-collapse: collapse;
        margin-top: 10px;
      }

      .metric-table th,
      .metric-table td {
        padding: 8px;
        text-align: left;
        border: 1px solid #ddd;
      }

      .metric-table th {
        background-color: #363b44;
      }

      /* Styles for tabs */
      .tabs-container {
        position: fixed;
        top: 0;
        left: 0;
        width: 49vw;
        background-color: #000000;
        z-index: 10;
        display: flex;
        padding: 0;
      }

      .tab {
        cursor: pointer;
        padding: 10px 15px;
        background-color: #333;
        color: #f2f0e7;
        border: none;
        outline: none;
        transition: background-color 0.3s;
        flex: 1;
        text-align: center;
      }

      .tab:hover {
        background-color: #444;
      }

      .tab.active {
        background-color: #4c76af;
        font-weight: bold;
      }

      .tab.disabled {
        opacity: 0.5;
        cursor: not-allowed;
        background-color: #282c34;
      }

      .tab-content {
        display: none;
        padding-top: 40px; /* Space for tabs */
      }

      .tab-content.active {
        display: block;
      }

      .stage-info {
        padding: 10px;
        background-color: #282c34;
        color: #f2f0e7;
        margin-bottom: 10px;
        font-size: 0.9em;
      }

      .stage-status {
        display: inline-block;
        padding: 3px 6px;
        border-radius: 3px;
        margin-left: 8px;
        font-size: 0.8em;
      }

      .stage-status.completed {
        background-color: #4caf50;
      }

      .stage-status.in-progress {
        background-color: #2196f3;
      }

      .stage-status.not-started {
        background-color: #9e9e9e;
      }
    </style>
  </head>
  <body>
    <div class="tabs-container" id="stage-tabs">
      <button class="tab" data-stage="Stage_1" onclick="selectStage('Stage_1')">Stage 1</button>
      <button class="tab" data-stage="Stage_2" onclick="selectStage('Stage_2')">Stage 2</button>
      <button class="tab" data-stage="Stage_3" onclick="selectStage('Stage_3')">Stage 3</button>
      <button class="tab" data-stage="Stage_4" onclick="selectStage('Stage_4')">Stage 4</button>
    </div>

    <div id="canvas-container"></div>

    <pre id="text-container">
        <div id="stage-info" class="stage-info"></div>
        <div id="plan"></div>
        <hr>
        <div id="exc_info"></div>
        <hr>
        <div id="exec_time"></div>
        <hr>
        <div id="exec_time_feedback"></div>
        <hr>
        <div id="metrics"></div>
        <hr>
        <div id="plot_plan"></div>
        <hr>
        <div class="plots-container" id="plots"></div>
        <hr>
        <div id="vlm_feedback"></div>
        <hr>
        <div id="datasets_successfully_tested"></div>
        <hr>
        <code id="code" class="language-python"></code>
        <hr>
        <code id="plot_code" class="language-python"></code>
    </pre>
  </body>
</html>
