{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saved data_val.npy with shape (36, 1, 70, 70) at datasets/CurveFault-B/CurveFault_val/data_val.npy\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import glob\n",
    "import numpy as np\n",
    "\n",
    "data_dir = \"datasets/CurveFault-B/CurveFault_val\"\n",
    "pattern = os.path.join(data_dir, \"vel*.npy\")\n",
    "file_list = glob.glob(pattern)\n",
    "\n",
    "selected_arrays = []\n",
    "\n",
    "for file_path in file_list:\n",
    "    data = np.load(file_path)  # data shape: [x, :, :, :]\n",
    "    if data.shape[0] < 3:\n",
    "        continue\n",
    "    indices = np.random.choice(data.shape[0], size=3, replace=False)\n",
    "    for idx in indices:\n",
    "        selected_arrays.append(data[idx])\n",
    "\n",
    "dataset = np.stack(selected_arrays, axis=0)\n",
    "save_path = os.path.join(data_dir, \"data_val.npy\")\n",
    "np.save(save_path, dataset)\n",
    "print(f\"Saved data_val.npy with shape {dataset.shape} at {save_path}\")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "cudass",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.21"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
