{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "d3f0aff4-c88f-456e-9c3b-9ff95d38e876",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "90821e97-a1a8-4d1b-b399-ade15c677aa5",
   "metadata": {},
   "outputs": [],
   "source": [
    "def genpc()-> numpy.ndarray:\n",
    "    e0=numpy.random.normal(0,1.0)\n",
    "    e1=numpy.random.normal(0,1.0)\n",
    "    e2=numpy.random.normal(0,1.0)\n",
    "    e3=numpy.random.normal(0,1.0)\n",
    "    x2=2*e3+e2\n",
    "    x0=2*e3+e0\n",
    "    x1=(9/38)*x0+3*x2+e1\n",
    "    return numpy.array([x0, x1, x2, e3])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f9184a9d-2763-44ae-a66a-f025f8dbcaed",
   "metadata": {},
   "outputs": [],
   "source": [
    "def cgensp()-> numpy.ndarray:\n",
    "    e1=scipy.stats.bernoulli.rvs(0.5)\n",
    "    e2=scipy.stats.bernoulli.rvs(0.5)\n",
    "    e3=scipy.stats.bernoulli.rvs(0.5)\n",
    "    e4=scipy.stats.bernoulli.rvs(0.5)\n",
    "    e5=scipy.stats.bernoulli.rvs(0.5)\n",
    "    e6=scipy.stats.bernoulli.rvs(0.5)\n",
    "    e7=scipy.stats.bernoulli.rvs(0.5)\n",
    "    e8=scipy.stats.bernoulli.rvs(0.5)\n",
    "    e9=scipy.stats.bernoulli.rvs(0.5)\n",
    "    x0=[e2,e8,e9]\n",
    "    x1=[e1,e2,e3]\n",
    "    x2=conv([e9, e6])+((e1+e4)*3+(e2+e5))*(2**2)\n",
    "    x3=[e4,e5,e7]\n",
    "    x0=conv(x0)\n",
    "    x1=conv(x1)\n",
    "    x3=conv(x3)\n",
    "    return numpy.array([x0,x1,x2,x3])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "83d35871-b9c0-45bd-b2dd-fc271132c7b9",
   "metadata": {},
   "outputs": [],
   "source": [
    "data=[]\n",
    "for i in range(100*10000):\n",
    "    data.append(genpc())\n",
    "data=numpy.stack(data, axis=0)\n",
    "data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "d8b2379e-0629-4dd2-9b6c-3b9ae50f2b36",
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'data1' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[1;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[1;32mIn[5], line 4\u001b[0m\n\u001b[0;32m      1\u001b[0m output_file_path \u001b[38;5;241m=\u001b[39m \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mpccounterexample1.txt\u001b[39m\u001b[38;5;124m'\u001b[39m\n\u001b[0;32m      3\u001b[0m \u001b[38;5;66;03m# Save the NumPy array to a text file\u001b[39;00m\n\u001b[1;32m----> 4\u001b[0m numpy\u001b[38;5;241m.\u001b[39msavetxt(output_file_path, \u001b[43mdata1\u001b[49m, fmt\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;132;01m%.8f\u001b[39;00m\u001b[38;5;124m'\u001b[39m, delimiter\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124m \u001b[39m\u001b[38;5;124m'\u001b[39m)\n\u001b[0;32m      6\u001b[0m \u001b[38;5;28mprint\u001b[39m(\u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mNumPy array has been saved to \u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;132;01m{\u001b[39;00moutput_file_path\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124m.\u001b[39m\u001b[38;5;124m\"\u001b[39m)\n",
      "\u001b[1;31mNameError\u001b[0m: name 'data1' is not defined"
     ]
    }
   ],
   "source": [
    "output_file_path = 'pccounterexample.txt'\n",
    "\n",
    "# Save the NumPy array to a text file\n",
    "numpy.savetxt(output_file_path, data, fmt='%.8f', delimiter=' ')\n",
    "\n",
    "print(f\"NumPy array has been saved to '{output_file_path}'.\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "6420b246-8a31-47ec-9ddc-ea171f4c84d6",
   "metadata": {},
   "outputs": [],
   "source": [
    "import scipy.stats"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "f34e3dfd-fd74-45fb-829d-2367d5e7f9d8",
   "metadata": {},
   "outputs": [],
   "source": [
    "def conv(x:tuple) -> int:\n",
    "    n=len(x)\n",
    "    y=0\n",
    "    for i in range(n):\n",
    "        y=y+x[i]*(2**i)\n",
    "    return y"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "f0fcb29e-f541-442e-ab44-eddd81f63752",
   "metadata": {},
   "outputs": [],
   "source": [
    "def gensp()-> numpy.ndarray:\n",
    "    e1=[scipy.stats.bernoulli.rvs(0.5), scipy.stats.bernoulli.rvs(0.5), scipy.stats.bernoulli.rvs(0.5)]\n",
    "    e0=[e1[0], scipy.stats.bernoulli.rvs(0.5), scipy.stats.bernoulli.rvs(0.5)]\n",
    "    I=(conv(e1)+conv(e0))%8\n",
    "    e3=inconv(I,3)\n",
    "    e2=[e1[1], e0[1], e3[2]]\n",
    "    e0=conv(e0)\n",
    "    e1=conv(e1)\n",
    "    e2=conv(e2)\n",
    "    e3=conv(e3)\n",
    "    return numpy.array([e0, e1, e2, e3])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "1330466b-0760-4ff2-b1a3-96e9c9e88cac",
   "metadata": {},
   "outputs": [],
   "source": [
    "def cgensp()-> numpy.ndarray:\n",
    "    e1=scipy.stats.bernoulli.rvs(0.5)\n",
    "    e2=scipy.stats.bernoulli.rvs(0.5)\n",
    "    e3=scipy.stats.bernoulli.rvs(0.5)\n",
    "    e4=scipy.stats.bernoulli.rvs(0.5)\n",
    "    e5=scipy.stats.bernoulli.rvs(0.5)\n",
    "    e6=scipy.stats.bernoulli.rvs(0.5)\n",
    "    e7=scipy.stats.bernoulli.rvs(0.5)\n",
    "    e8=scipy.stats.bernoulli.rvs(0.5)\n",
    "    e9=scipy.stats.bernoulli.rvs(0.5)\n",
    "    x0=[e2,e8,e9]\n",
    "    x1=[e1,e2,e3]\n",
    "    x2=conv([e9, e6])+((e1+e4)*3+(e2+e5))*(2**2)\n",
    "    x3=[e4,e5,e7]\n",
    "    x0=conv(x0)\n",
    "    x1=conv(x1)\n",
    "    x3=conv(x3)\n",
    "    return numpy.array([x0,x1,x2,x3])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "6d9a9f16-3a25-498d-9b9a-f66f774b8e8b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[ 7,  7, 35,  7],\n",
       "       [ 4,  1, 27,  5],\n",
       "       [ 0,  0,  4,  6],\n",
       "       ...,\n",
       "       [ 6,  4,  1,  4],\n",
       "       [ 6,  4, 15,  5],\n",
       "       [ 5,  2,  7,  0]])"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data=[]\n",
    "for i in range(100*10000):\n",
    "    data.append(cgensp())\n",
    "data=numpy.stack(data, axis=0)\n",
    "data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "ff4b68df-337e-4176-88a6-710bfcf54e38",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "NumPy array has been saved to 'spcounterexample1.txt'.\n"
     ]
    }
   ],
   "source": [
    "output_file_path = 'spcounterexample1.txt'\n",
    "\n",
    "# Save the NumPy array to a text file\n",
    "numpy.savetxt(output_file_path, data, fmt='%d', delimiter=' ')\n",
    "\n",
    "print(f\"NumPy array has been saved to '{output_file_path}'.\")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.10.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
