{"cells":[{"cell_type":"code","execution_count":null,"id":"df433cba","metadata":{"id":"df433cba"},"outputs":[],"source":["import numpy as np\n","import pandas as pd"]},{"cell_type":"code","execution_count":null,"id":"214149af","metadata":{"id":"214149af"},"outputs":[],"source":["# From https://github.com/google-deepmind/mathematics_conjectures/blob/main/knot_theory.ipynb\n","# We quantize the predicted signature values to even integers,\n","# between min_signature and max_signature.\n","def quantize(x, min_signature, max_signature):\n","    return min(max(2 * round(x / 2), min_signature), max_signature)"]},{"cell_type":"code","execution_count":null,"id":"ce5330a5","metadata":{"id":"ce5330a5"},"outputs":[],"source":["# Download data: https://colab.research.google.com/github/deepmind/mathematics_conjectures/blob/main/knot_theory.ipynb#scrollTo=l10N2ZbHu6Ob\n","data_path = '../../data/knot_theory_invariants.csv'\n","df = pd.read_csv(data_path)\n","X = df[df.keys()[1:-1]].to_numpy()\n","Y = df['signature'].to_numpy()"]},{"cell_type":"code","execution_count":null,"id":"2d0b0c92","metadata":{"id":"2d0b0c92"},"outputs":[],"source":["X_labels = [\n","    'Adjoint torsion degree',\n","    'Torsion degree',\n","    'Re(short geodesic)',\n","    'Im(short geodesic)',\n","    'Injectivity radius',\n","    'Chern-Simons',\n","    'Cusp volume',\n","    'Longitudinal translation',\n","    'Im(meridional translation)',\n","    'Re(meridional translation)',\n","    'Volume',\n","    'Symmetry: $0$',\n","    'Symmetry: $D_3$',\n","    'Symmetry: $D_4$',\n","    'Symmetry: $D_6$',\n","    'Symmetry: $D_8$',\n","    r'Symmetry: $\\frac{Z}{2} + \\frac{Z}{2}$'\n","]"]},{"cell_type":"code","execution_count":null,"id":"78d0053e","metadata":{"id":"78d0053e"},"outputs":[],"source":["# From https://github.com/KindXiaoming/pykan/blob/master/tutorials/Example/Example_14_knot_supervised.ipynb\n","# Normalize X\n","X_mean = np.mean(X, axis=0)\n","X_std = np.std(X, axis=0)\n","X = (X - X_mean[np.newaxis,:])/X_std[np.newaxis,:]\n","\n","# Normalize Y\n","max_signature = np.max(Y)\n","min_signature = np.min(Y)\n","Y = ((Y-min_signature)/2).astype(int)"]},{"cell_type":"code","execution_count":null,"id":"fea47f7d","metadata":{"id":"fea47f7d"},"outputs":[],"source":["# Unnormalized data\n","x7 = df['cusp_volume'].to_numpy()\n","x8 = df['longitudinal_translation'].to_numpy()\n","x9 = df['meridinal_translation_imag'].to_numpy()\n","x10 = df['meridinal_translation_real'].to_numpy()\n","y = df['signature'].to_numpy()"]},{"cell_type":"code","execution_count":null,"id":"d623fd1c","metadata":{"id":"d623fd1c","outputId":"96d30e93-6e2b-44fe-f9f2-7c3f5689ef5d"},"outputs":[{"name":"stdout","output_type":"stream","text":["Total accuracy: 73.8%\n"]}],"source":["# Formula A\n","A = (\n","    x8 * x10 / (x10**2 + x9**2)\n",") / 2\n","quantized_A = [quantize(x, min_signature, max_signature) for x in A]\n","print(f'Total accuracy: {np.mean(y - quantized_A == 0) * 100:.1f}%')"]},{"cell_type":"code","execution_count":null,"id":"f16d8717","metadata":{"id":"f16d8717","outputId":"3fb051b0-a541-4b7d-9f52-3441e098c7be"},"outputs":[{"name":"stdout","output_type":"stream","text":["Total accuracy: 26.8%\n"]}],"source":["# Formula B\n","B = (\n","    -0.02 * np.sin(4.98 * x9 + 0.85) + 0.08 * np.abs(4.02 * x10 + 6.28) - 0.52 -\n","    0.04 * np.exp(-0.88 * (1. - 0.45 * x8)**2)\n",")\n","quantized_B = [quantize(x, min_signature, max_signature) for x in B]\n","print(f'Total accuracy: {np.mean(y - quantized_B == 0) * 100:.1f}%')"]},{"cell_type":"code","execution_count":null,"id":"55ee4d68","metadata":{"id":"55ee4d68","outputId":"fe6523cf-06be-41e1-cd89-76bbc1882951"},"outputs":[{"name":"stdout","output_type":"stream","text":["Total accuracy: 41.5%\n"]}],"source":["# Formula C\n","C = (\n","    0.17 * np.tan(-1.51 + 0.1 * np.exp(-1.43 * (1. - 0.4 * x9)**2 + 0.09 * np.exp(-0.06 * (1. - 0.21 * x8)**2)) +\n","    1.32 * np.exp(-3.18 * (1. - 0.43 * x10)**2))\n",")\n","quantized_C = [quantize(x, min_signature, max_signature) for x in C]\n","print(f'Total accuracy: {np.mean(y - quantized_C == 0) * 100:.1f}%')"]},{"cell_type":"code","execution_count":null,"id":"1acdb637","metadata":{"id":"1acdb637","outputId":"6fb08c1d-0522-4216-c9ad-dc05240a6874"},"outputs":[{"name":"stdout","output_type":"stream","text":["Total accuracy: 0.0%\n"]}],"source":["# Formula D\n","D = (\n","    -0.09 + 1.04 * np.exp(-9.59 * (-0.62 * np.sin(0.61 * x10 + 7.26)) -\n","    0.32 * np.tan(0.03 * x8 - 6.59) + 1. - 0.11 * np.exp(-1.77 * (0.31 - x9)**2)**2) -\n","    1.09 * np.exp(-7.6 * (0.65 * (1. - 0.01 * x8)**3) + 0.27 * np.arctan(0.53 * x9 - 0.6) +\n","    0.09 + np.exp(-2.58 * (1. - 0.36 * x10)**2))\n",")\n","quantized_D = [quantize(x, min_signature, max_signature) for x in D]\n","print(f'Total accuracy: {np.mean(y - quantized_D == 0) * 100:.1f}%')"]},{"cell_type":"code","execution_count":null,"id":"b39a1aff","metadata":{"id":"b39a1aff","outputId":"89c95d8d-30a9-4e07-8f1f-d5472fa27efd"},"outputs":[{"name":"stdout","output_type":"stream","text":["Total accuracy: 79.3%\n"]}],"source":["# Formula E\n","E = (\n","    4.76 * x8 * x10 / (3.09 * x9 + 6.05 * x10**2 + 3.54 * x9**2)\n",") / 2\n","quantized_E = [quantize(x, min_signature, max_signature) for x in E]\n","print(f'Total accuracy: {np.mean(y - quantized_E == 0) * 100:.1f}%')"]},{"cell_type":"code","execution_count":null,"id":"0b1b196f","metadata":{"id":"0b1b196f","outputId":"1845098a-003d-44bd-d712-d6fc6e3e1df4"},"outputs":[{"name":"stdout","output_type":"stream","text":["Total accuracy: 26.8%\n"]}],"source":["# Formula F\n","F = (\n","    (2.94 - 2.92 * (1. - 0.10 * x10)**2) / (0.32 * (0.18 - x10)**2 + 5.36 * (1. - 0.04 * x8)**2 + 0.50)\n",")\n","quantized_F = [quantize(x, min_signature, max_signature) for x in F]\n","print(f'Total accuracy: {np.mean(y - quantized_F == 0) * 100:.1f}%')"]},{"cell_type":"code","execution_count":null,"id":"45bef9d7","metadata":{"id":"45bef9d7","outputId":"3d0b97b2-78ca-4a61-af45-e121d8fce5e1"},"outputs":[{"name":"stdout","output_type":"stream","text":["Total accuracy: 75.7%\n"]}],"source":["# Formula G\n","G = (\n","    12.766 * (0.132 * (-x10 + 0.035 * x8 + 0.157)**2 +\n","    0.592 * (-0.23 * x10 + 0.008 * x8 + 1.)**2 * (0.162 * x10 - 0.006 * x8 +\n","    0.076) - 1.)**4 + 7.202 * (0.871 * x10 + 0.029 * x8 - (0.229 * x10 +\n","    0.008 * x8 - 0.103) * (0.229 * x10 + 0.008 * x8 + 0.159 * (x10 +\n","    0.033 * x8 - 0.449)**2 + 0.625) - 0.173)**2 - 10.643\n",")\n","quantized_G = [quantize(x, min_signature, max_signature) for x in G]\n","print(f'Total accuracy: {np.mean(y - quantized_G == 0) * 100:.1f}%')"]},{"cell_type":"code","execution_count":null,"id":"107e982e","metadata":{"id":"107e982e","outputId":"9c269a7b-1943-4a4f-ac99-c1185d272489"},"outputs":[{"name":"stdout","output_type":"stream","text":["Total accuracy: 80.9%\n"]}],"source":["# Formula H\n","H = (\n","    26. * ((0.096 * x10 - 0.002 * x7 + 0.004 * x8 - 0.237) * (0.267 * x10 -\n","    0.004 * x7 + 0.011 * x8 + 0.119 * (x10 - 0.016 * x7 + 0.04 * x8 -\n","    0.316)**2 - 1.)**2 + 0.133) * (0.734 * x10 - 0.012 * x7 + 0.029 * x8 +\n","    0.418) + 2.054 * (0.589 * x10 + 0.018 * x7 - 0.027 * x8 + 1.)**2 -\n","    4.056 * (x10 + 0.031 * x7 - 0.046 * x8 + 0.195)**2 * (0.107 * x10 +\n","    0.003 * x7 - 0.005 * x8 - 0.064 * (x10 + 0.031 * x7 - 0.046 * x8 +\n","    0.087 * (x10 + 0.031 * x7 - 0.046 * x8 - 0.165 * (x10 + 0.031 * x7 -\n","    0.046 * x8 + 0.195)**2 + 0.195)**2 + 0.195)**2 + 1.)**2 - 0.895\n",")\n","quantized_H = [quantize(x, min_signature, max_signature) for x in H]\n","print(f'Total accuracy: {np.mean(y - quantized_H == 0) * 100:.1f}%')"]},{"cell_type":"code","execution_count":null,"id":"bdfa5e0c","metadata":{"id":"bdfa5e0c","outputId":"55ddac27-0536-49be-e572-75511b8b7708"},"outputs":[{"name":"stdout","output_type":"stream","text":["Total accuracy: 81.0%\n"]}],"source":["# Formula I\n","I = (\n","    2.574 * x10 + 0.078 * x7 - 0.13 * x8 + 26. * (0.233 * (-x10 +\n","    0.016 * x7 - 0.04 * x8 - 0.597)**2 * np.sin(0.367 * x10 - 0.006 * x7 +\n","    0.015 * x8 - 0.719)**2 + np.sin(0.777 * x10 - 0.013 * x7 + 0.031 * x8 +\n","    0.262)) * (0.168 * x10 - 0.003 * x7 + 0.007 * x8 - 0.053) +\n","    15.626 * (-np.sin(0.54 * x10 + 0.017 * x7 - 0.025 * x8 + 0.105) -\n","    0.049)**2 * (-0.165 * x10 - 0.005 * x7 + 0.008 * x8 - 0.645) + 0.509\n",")\n","quantized_I = [quantize(x, min_signature, max_signature) for x in I]\n","print(f'Total accuracy: {np.mean(y - quantized_I == 0) * 100:.1f}%')"]},{"cell_type":"code","execution_count":null,"id":"9e2023f8","metadata":{"id":"9e2023f8","outputId":"d8840bf5-5ae9-44a2-b4f8-f97222d5c6a7"},"outputs":[{"name":"stdout","output_type":"stream","text":["Total accuracy: 20.8%\n"]}],"source":["# Formula A without a factor of 1/2\n","A = (\n","    x8 * x10 / (x10**2 + x9**2)\n",")\n","quantized_A = [quantize(x, min_signature, max_signature) for x in A]\n","print(f'Total accuracy: {np.mean(y - quantized_A == 0) * 100:.1f}%')"]},{"cell_type":"code","execution_count":null,"id":"5cc7bfe8","metadata":{"id":"5cc7bfe8","outputId":"4670103c-4142-4a1b-80ff-2642d59378b4"},"outputs":[{"name":"stdout","output_type":"stream","text":["Total accuracy: 32.4%\n"]}],"source":["# Formula E without a factor of 1/2\n","E = (\n","    4.76 * x8 * x10 / (3.09 * x9 + 6.05 * x10**2 + 3.54 * x9**2)\n",")\n","quantized_E = [quantize(x, min_signature, max_signature) for x in E]\n","print(f'Total accuracy: {np.mean(y - quantized_E == 0) * 100:.1f}%')"]},{"cell_type":"code","execution_count":null,"id":"a5feba1b","metadata":{"id":"a5feba1b","outputId":"cd5702cc-a347-424b-e1e2-44013300fcaa"},"outputs":[{"name":"stdout","output_type":"stream","text":["Total accuracy: 26.8%\n"]}],"source":["# Formula B with a factor of 1/2\n","B = (\n","    -0.02 * np.sin(4.98 * x9 + 0.85) + 0.08 * np.abs(4.02 * x10 + 6.28) - 0.52 -\n","    0.04 * np.exp(-0.88 * (1. - 0.45 * x8)**2)\n",") / 2\n","quantized_B = [quantize(x, min_signature, max_signature) for x in B]\n","print(f'Total accuracy: {np.mean(y - quantized_B == 0) * 100:.1f}%')"]},{"cell_type":"code","execution_count":null,"id":"ac47d91e","metadata":{"id":"ac47d91e","outputId":"758e7c11-c1db-4371-c02e-fc7bb5f7ba46"},"outputs":[{"name":"stdout","output_type":"stream","text":["Total accuracy: 26.8%\n","Total accuracy: 0.0%\n"]}],"source":["# Formula B with normalized data\n","B = (\n","    -0.02 * np.sin(4.98 * X[:, 8] + 0.85) + 0.08 * np.abs(4.02 * X[:, 9] + 6.28) - 0.52 -\n","    0.04 * np.exp(-0.88 * (1. - 0.45 * X[:, 7])**2)\n",")\n","quantized_B = [quantize(x, min_signature, max_signature) for x in B]\n","print(f'Total accuracy: {np.mean(y - quantized_B == 0) * 100:.1f}%')\n","print(f'Total accuracy: {np.mean(Y - quantized_B == 0) * 100:.1f}%')"]}],"metadata":{"kernelspec":{"display_name":"base","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.8.18"},"colab":{"provenance":[]}},"nbformat":4,"nbformat_minor":5}