{"nbformat":4,"nbformat_minor":0,"metadata":{"kernelspec":{"display_name":"Python 3","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.6.9"},"colab":{"name":"5j0n_DE_dim8ipynb","provenance":[{"file_id":"1tFfaLiF3kDn8bJaTGDyTAdpzbZsXaeEh","timestamp":1615670015225},{"file_id":"1nnOFyHuLQU50H4TX8we118vefLfbKgVH","timestamp":1613260362702},{"file_id":"https://github.com/anonymous/protein-reconstruction/blob/master/notebooks/1-phase1/colab_distance_estimation_translated.ipynb","timestamp":1593207886361}],"collapsed_sections":["M-kSlYfqK4Lt"],"toc_visible":true},"accelerator":"GPU"},"cells":[{"cell_type":"markdown","metadata":{"id":"I-hskHNCK4Jy"},"source":["<a href=\"https://colab.research.google.com/github/anonymous/protein-reconstruction/blob/master/notebooks/2-phase2/colab_distance_estimation_and_angle_recovery-test5j0nhalf-cov_noisy.ipynb\" target=\"_parent\"><img src=\"https://colab.research.google.com/assets/colab-badge.svg\" alt=\"Open In Colab\"/></a>"]},{"cell_type":"markdown","metadata":{"id":"ny3JKImAK4Jz"},"source":["# Distance Estimation and Angle Recovery"]},{"cell_type":"markdown","metadata":{"id":"4W1rATe0K4J1"},"source":["<div class=\"alert alert-danger\" role=\"alert\">\n","  <p><strong>Important:</strong> This notebook is used to run the distance estimation on noisy data only (no angle recovery).</p>\n","  <hr>\n","    - <b>To enable GPU</b>: Navigate to Edit→Notebook Settings<br/>\n","    - <b>To save the latest version of code from this notebook</b>: Navigate to File→Save a copy to Github.\n","</div>"]},{"cell_type":"markdown","metadata":{"id":"EkRUrVFpCrFT"},"source":["## Content"]},{"cell_type":"markdown","metadata":{"id":"Zwit5GAFCrFU"},"source":["1. [Data Preparation](#1.-Data-Preparation)\n","2. [Distance Estimation](#2.-Distance-Estimation)\n","3. [Angle Recovery](#3.-Angle-Recovery)\n","4. [Angle Alignment](#4.-Angle-Alignment)"]},{"cell_type":"markdown","metadata":{"id":"TDsOdNomK4J4"},"source":["Data used:\n","- Protein: 5j0n (symmetric protein)\n","- Projections: 5K\n","- Coverage: Half-sphere\n","\n","![](https://github.com/anonymous/protein-reconstruction/blob/master/notebooks/2-phase2/figures/5j0n.pdb1-500.jpg?raw=1)"]},{"cell_type":"code","metadata":{"id":"P43631FkK4J5","executionInfo":{"status":"ok","timestamp":1615719626830,"user_tz":-60,"elapsed":1062,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["# create directories\n","!mkdir --parents data/5j0n\n","!mkdir training"],"execution_count":1,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"A-xIo-OjK4J_"},"source":["## Setup Environment (Colab)"]},{"cell_type":"markdown","metadata":{"id":"kOyAAhtiK4J_"},"source":["Link to MiniConda Linux installer [here](https://docs.conda.io/en/latest/miniconda.html)."]},{"cell_type":"code","metadata":{"id":"6mMUWEYfK4KA","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615719657748,"user_tz":-60,"elapsed":31968,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"340cf692-c20e-4c6e-ef35-7e1ef8963b7c"},"source":["!wget -c https://repo.anaconda.com/miniconda/Miniconda3-latest-Linux-x86_64.sh\n","!chmod +x Miniconda3-latest-Linux-x86_64.sh\n","!bash ./Miniconda3-latest-Linux-x86_64.sh -b -f -p /usr/local"],"execution_count":2,"outputs":[{"output_type":"stream","text":["--2021-03-14 11:00:26--  https://repo.anaconda.com/miniconda/Miniconda3-latest-Linux-x86_64.sh\n","Resolving repo.anaconda.com (repo.anaconda.com)... 104.16.131.3, 104.16.130.3, 2606:4700::6810:8303, ...\n","Connecting to repo.anaconda.com (repo.anaconda.com)|104.16.131.3|:443... connected.\n","HTTP request sent, awaiting response... 200 OK\n","Length: 94235922 (90M) [application/x-sh]\n","Saving to: ‘Miniconda3-latest-Linux-x86_64.sh’\n","\n","Miniconda3-latest-L 100%[===================>]  89.87M   231MB/s    in 0.4s    \n","\n","2021-03-14 11:00:27 (231 MB/s) - ‘Miniconda3-latest-Linux-x86_64.sh’ saved [94235922/94235922]\n","\n","PREFIX=/usr/local\n","Unpacking payload ...\n","Collecting package metadata (current_repodata.json): - \b\b\\ \b\b| \b\bdone\n","Solving environment: - \b\b\\ \b\bdone\n","\n","## Package Plan ##\n","\n","  environment location: /usr/local\n","\n","  added / updated specs:\n","    - _libgcc_mutex==0.1=main\n","    - brotlipy==0.7.0=py38h27cfd23_1003\n","    - ca-certificates==2020.10.14=0\n","    - certifi==2020.6.20=pyhd3eb1b0_3\n","    - cffi==1.14.3=py38h261ae71_2\n","    - chardet==3.0.4=py38h06a4308_1003\n","    - conda-package-handling==1.7.2=py38h03888b9_0\n","    - conda==4.9.2=py38h06a4308_0\n","    - cryptography==3.2.1=py38h3c74f83_1\n","    - idna==2.10=py_0\n","    - ld_impl_linux-64==2.33.1=h53a641e_7\n","    - libedit==3.1.20191231=h14c3975_1\n","    - libffi==3.3=he6710b0_2\n","    - libgcc-ng==9.1.0=hdf63c60_0\n","    - libstdcxx-ng==9.1.0=hdf63c60_0\n","    - ncurses==6.2=he6710b0_1\n","    - openssl==1.1.1h=h7b6447c_0\n","    - pip==20.2.4=py38h06a4308_0\n","    - pycosat==0.6.3=py38h7b6447c_1\n","    - pycparser==2.20=py_2\n","    - pyopenssl==19.1.0=pyhd3eb1b0_1\n","    - pysocks==1.7.1=py38h06a4308_0\n","    - python==3.8.5=h7579374_1\n","    - readline==8.0=h7b6447c_0\n","    - requests==2.24.0=py_0\n","    - ruamel_yaml==0.15.87=py38h7b6447c_1\n","    - setuptools==50.3.1=py38h06a4308_1\n","    - six==1.15.0=py38h06a4308_0\n","    - sqlite==3.33.0=h62c20be_0\n","    - tk==8.6.10=hbc83047_0\n","    - tqdm==4.51.0=pyhd3eb1b0_0\n","    - urllib3==1.25.11=py_0\n","    - wheel==0.35.1=pyhd3eb1b0_0\n","    - xz==5.2.5=h7b6447c_0\n","    - yaml==0.2.5=h7b6447c_0\n","    - zlib==1.2.11=h7b6447c_3\n","\n","\n","The following NEW packages will be INSTALLED:\n","\n","  _libgcc_mutex      pkgs/main/linux-64::_libgcc_mutex-0.1-main\n","  brotlipy           pkgs/main/linux-64::brotlipy-0.7.0-py38h27cfd23_1003\n","  ca-certificates    pkgs/main/linux-64::ca-certificates-2020.10.14-0\n","  certifi            pkgs/main/noarch::certifi-2020.6.20-pyhd3eb1b0_3\n","  cffi               pkgs/main/linux-64::cffi-1.14.3-py38h261ae71_2\n","  chardet            pkgs/main/linux-64::chardet-3.0.4-py38h06a4308_1003\n","  conda              pkgs/main/linux-64::conda-4.9.2-py38h06a4308_0\n","  conda-package-han~ pkgs/main/linux-64::conda-package-handling-1.7.2-py38h03888b9_0\n","  cryptography       pkgs/main/linux-64::cryptography-3.2.1-py38h3c74f83_1\n","  idna               pkgs/main/noarch::idna-2.10-py_0\n","  ld_impl_linux-64   pkgs/main/linux-64::ld_impl_linux-64-2.33.1-h53a641e_7\n","  libedit            pkgs/main/linux-64::libedit-3.1.20191231-h14c3975_1\n","  libffi             pkgs/main/linux-64::libffi-3.3-he6710b0_2\n","  libgcc-ng          pkgs/main/linux-64::libgcc-ng-9.1.0-hdf63c60_0\n","  libstdcxx-ng       pkgs/main/linux-64::libstdcxx-ng-9.1.0-hdf63c60_0\n","  ncurses            pkgs/main/linux-64::ncurses-6.2-he6710b0_1\n","  openssl            pkgs/main/linux-64::openssl-1.1.1h-h7b6447c_0\n","  pip                pkgs/main/linux-64::pip-20.2.4-py38h06a4308_0\n","  pycosat            pkgs/main/linux-64::pycosat-0.6.3-py38h7b6447c_1\n","  pycparser          pkgs/main/noarch::pycparser-2.20-py_2\n","  pyopenssl          pkgs/main/noarch::pyopenssl-19.1.0-pyhd3eb1b0_1\n","  pysocks            pkgs/main/linux-64::pysocks-1.7.1-py38h06a4308_0\n","  python             pkgs/main/linux-64::python-3.8.5-h7579374_1\n","  readline           pkgs/main/linux-64::readline-8.0-h7b6447c_0\n","  requests           pkgs/main/noarch::requests-2.24.0-py_0\n","  ruamel_yaml        pkgs/main/linux-64::ruamel_yaml-0.15.87-py38h7b6447c_1\n","  setuptools         pkgs/main/linux-64::setuptools-50.3.1-py38h06a4308_1\n","  six                pkgs/main/linux-64::six-1.15.0-py38h06a4308_0\n","  sqlite             pkgs/main/linux-64::sqlite-3.33.0-h62c20be_0\n","  tk                 pkgs/main/linux-64::tk-8.6.10-hbc83047_0\n","  tqdm               pkgs/main/noarch::tqdm-4.51.0-pyhd3eb1b0_0\n","  urllib3            pkgs/main/noarch::urllib3-1.25.11-py_0\n","  wheel              pkgs/main/noarch::wheel-0.35.1-pyhd3eb1b0_0\n","  xz                 pkgs/main/linux-64::xz-5.2.5-h7b6447c_0\n","  yaml               pkgs/main/linux-64::yaml-0.2.5-h7b6447c_0\n","  zlib               pkgs/main/linux-64::zlib-1.2.11-h7b6447c_3\n","\n","\n","Preparing transaction: / \b\b- \b\b\\ \b\bdone\n","Executing transaction: / \b\b- \b\b\\ \b\b| \b\b/ \b\b- \b\b\\ \b\b| \b\b/ \b\b- \b\b\\ \b\bdone\n","installation finished.\n","WARNING:\n","    You currently have a PYTHONPATH environment variable set. This may cause\n","    unexpected behavior when running the Python interpreter in Miniconda3.\n","    For best results, please verify that your PYTHONPATH only points to\n","    directories of packages that are compatible with the Python interpreter\n","    in Miniconda3: /usr/local\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"HeNudKnGpFCJ","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615719683760,"user_tz":-60,"elapsed":57974,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"67499f6b-7f10-4990-c470-6e156102538b"},"source":["# save the model on the drive\n","from google.colab import drive\n","drive.mount(\"/content/drive\")\n","#!cd 'drive/My Drive'\n","!mkdir --parents 'drive/My Drive/ModelsProtein'"],"execution_count":3,"outputs":[{"output_type":"stream","text":["Mounted at /content/drive\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"6ghrKBx2K4KE","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615719728867,"user_tz":-60,"elapsed":103073,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"74a485a0-b870-4a17-bc09-68698d90ad88"},"source":["# clone repo\n","!rm -r protein-reconstruction\n","!git clone https://github.com/anonymous/protein-reconstruction.git\n","!cd protein-reconstruction"],"execution_count":4,"outputs":[{"output_type":"stream","text":["rm: cannot remove 'protein-reconstruction': No such file or directory\n","Cloning into 'protein-reconstruction'...\n","remote: Enumerating objects: 17, done.\u001b[K\n","remote: Counting objects: 100% (17/17), done.\u001b[K\n","remote: Compressing objects: 100% (14/14), done.\u001b[K\n","remote: Total 2972 (delta 3), reused 9 (delta 3), pack-reused 2955\u001b[K\n","Receiving objects: 100% (2972/2972), 746.34 MiB | 22.22 MiB/s, done.\n","Resolving deltas: 100% (1786/1786), done.\n","Checking out files: 100% (161/161), done.\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"LGvnGT0xK4KL","colab":{"base_uri":"https://localhost:8080/","height":1000},"executionInfo":{"status":"ok","timestamp":1615719853860,"user_tz":-60,"elapsed":228059,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"c31f302b-0d90-4727-e01e-e86d6e77294b"},"source":["#!conda env create -f environment.yml \n","!conda install -q -y --prefix /usr/local -c conda-forge ipyvolume\n","#!pip3 install tensorflow-gpu==2.2.0\n","!pip install tensorflow-graphics"],"execution_count":5,"outputs":[{"output_type":"stream","text":["Collecting package metadata (current_repodata.json): ...working... done\n","Solving environment: ...working... done\n","\n","## Package Plan ##\n","\n","  environment location: /usr/local\n","\n","  added / updated specs:\n","    - ipyvolume\n","\n","\n","The following packages will be downloaded:\n","\n","    package                    |            build\n","    ---------------------------|-----------------\n","    argon2-cffi-20.1.0         |   py38h25fe258_2          47 KB  conda-forge\n","    async_generator-1.10       |             py_0          18 KB  conda-forge\n","    attrs-20.3.0               |     pyhd3deb0d_0          41 KB  conda-forge\n","    backcall-0.2.0             |     pyh9f0ad1d_0          13 KB  conda-forge\n","    backports-1.0              |             py_2           4 KB  conda-forge\n","    backports.functools_lru_cache-1.6.1|             py_0           8 KB  conda-forge\n","    bleach-3.3.0               |     pyh44b312d_0         111 KB  conda-forge\n","    bqplot-0.12.23             |     pyhd8ed1ab_0        1013 KB  conda-forge\n","    ca-certificates-2020.12.5  |       ha878542_0         137 KB  conda-forge\n","    certifi-2020.12.5          |   py38h578d9bd_1         143 KB  conda-forge\n","    cloudpickle-1.6.0          |             py_0          22 KB  conda-forge\n","    conda-4.9.2                |   py38h578d9bd_0         3.0 MB  conda-forge\n","    cycler-0.10.0              |             py_2           9 KB  conda-forge\n","    cytoolz-0.11.0             |   py38h25fe258_1         396 KB  conda-forge\n","    dask-core-2021.3.0         |     pyhd8ed1ab_0         702 KB  conda-forge\n","    decorator-4.4.2            |             py_0          11 KB  conda-forge\n","    defusedxml-0.7.1           |     pyhd8ed1ab_0          23 KB  conda-forge\n","    entrypoints-0.3            |  pyhd8ed1ab_1003           8 KB  conda-forge\n","    freetype-2.10.4            |       h7ca028e_0         912 KB  conda-forge\n","    icu-67.1                   |       he1b5a44_0        12.9 MB  conda-forge\n","    imageio-2.9.0              |             py_0         3.1 MB  conda-forge\n","    importlib-metadata-3.7.2   |   py38h578d9bd_0          24 KB  conda-forge\n","    ipydatawidgets-4.2.0       |     pyhd3deb0d_0         171 KB  conda-forge\n","    ipykernel-5.5.0            |   py38h81c977d_1         167 KB  conda-forge\n","    ipython-7.21.0             |   py38h81c977d_0         1.1 MB  conda-forge\n","    ipython_genutils-0.2.0     |             py_1          21 KB  conda-forge\n","    ipyvolume-0.6.0a6          |     pyh9f0ad1d_0         5.1 MB  conda-forge\n","    ipywebrtc-0.5.0            |   py38h32f6830_1         878 KB  conda-forge\n","    ipywidgets-7.6.3           |     pyhd3deb0d_0         101 KB  conda-forge\n","    jedi-0.18.0                |   py38h578d9bd_2         937 KB  conda-forge\n","    jinja2-2.11.3              |     pyh44b312d_0          93 KB  conda-forge\n","    jpeg-9d                    |       h36c2ea0_0         264 KB  conda-forge\n","    jsonschema-3.2.0           |     pyhd8ed1ab_3          45 KB  conda-forge\n","    jupyter_client-6.1.12      |     pyhd8ed1ab_0          79 KB  conda-forge\n","    jupyter_core-4.7.1         |   py38h578d9bd_0          72 KB  conda-forge\n","    jupyterlab_pygments-0.1.2  |     pyh9f0ad1d_0           8 KB  conda-forge\n","    jupyterlab_widgets-1.0.0   |     pyhd8ed1ab_1         130 KB  conda-forge\n","    kiwisolver-1.3.1           |   py38h82cb98a_0          86 KB  conda-forge\n","    libblas-3.9.0              |       8_openblas          11 KB  conda-forge\n","    libcblas-3.9.0             |       8_openblas          11 KB  conda-forge\n","    libgfortran-ng-7.5.0       |      h14aa051_18          22 KB  conda-forge\n","    libgfortran4-7.5.0         |      h14aa051_18         1.3 MB  conda-forge\n","    liblapack-3.9.0            |       8_openblas          11 KB  conda-forge\n","    libopenblas-0.3.12         |pthreads_hb3c22a3_1         8.2 MB  conda-forge\n","    libpng-1.6.37              |       h21135ba_2         306 KB  conda-forge\n","    libsodium-1.0.18           |       h36c2ea0_1         366 KB  conda-forge\n","    libtiff-4.0.10             |    hc3755c2_1005         602 KB  conda-forge\n","    lz4-c-1.9.2                |       he1b5a44_3         203 KB  conda-forge\n","    markupsafe-1.1.1           |   py38h8df0ef7_2          27 KB  conda-forge\n","    matplotlib-base-3.2.2      |   py38h5d868c9_1         7.1 MB  conda-forge\n","    mistune-0.8.4              |py38h25fe258_1002          54 KB  conda-forge\n","    nbclient-0.5.3             |     pyhd8ed1ab_0          67 KB  conda-forge\n","    nbconvert-6.0.7            |   py38h578d9bd_3         546 KB  conda-forge\n","    nbformat-5.1.2             |     pyhd8ed1ab_1          66 KB  conda-forge\n","    nest-asyncio-1.4.3         |     pyhd8ed1ab_0           9 KB  conda-forge\n","    networkx-2.5               |             py_0         1.2 MB  conda-forge\n","    notebook-6.2.0             |   py38h578d9bd_0         6.3 MB  conda-forge\n","    numpy-1.18.1               |   py38h8854b6b_1         5.3 MB  conda-forge\n","    olefile-0.46               |     pyh9f0ad1d_1          32 KB  conda-forge\n","    openssl-1.1.1j             |       h27cfd23_0         2.5 MB\n","    packaging-20.9             |     pyh44b312d_0          35 KB  conda-forge\n","    pandas-1.0.1               |   py38hb3f55d8_0        11.4 MB  conda-forge\n","    pandoc-2.12                |       h7f98852_0        12.4 MB  conda-forge\n","    pandocfilters-1.4.2        |             py_1           9 KB  conda-forge\n","    parso-0.8.1                |     pyhd8ed1ab_0          67 KB  conda-forge\n","    pexpect-4.8.0              |     pyh9f0ad1d_2          47 KB  conda-forge\n","    pickleshare-0.7.5          |          py_1003           9 KB  conda-forge\n","    pillow-6.2.1               |   py38h6b7be26_0         637 KB  conda-forge\n","    prometheus_client-0.9.0    |     pyhd3deb0d_0          44 KB  conda-forge\n","    prompt-toolkit-3.0.17      |     pyha770c72_0         244 KB  conda-forge\n","    ptyprocess-0.7.0           |     pyhd3deb0d_0          16 KB  conda-forge\n","    pygments-2.8.1             |     pyhd8ed1ab_0         736 KB  conda-forge\n","    pyparsing-2.4.7            |     pyh9f0ad1d_0          60 KB  conda-forge\n","    pyrsistent-0.17.3          |   py38h25fe258_1          89 KB  conda-forge\n","    python-dateutil-2.8.1      |             py_0         220 KB  conda-forge\n","    python_abi-3.8             |           1_cp38           4 KB  conda-forge\n","    pythreejs-2.3.0            |     pyhd8ed1ab_0         2.6 MB  conda-forge\n","    pytz-2021.1                |     pyhd8ed1ab_0         239 KB  conda-forge\n","    pywavelets-1.1.1           |   py38hab2c0dc_3         4.3 MB  conda-forge\n","    pyyaml-5.3.1               |   py38h8df0ef7_1         190 KB  conda-forge\n","    pyzmq-19.0.2               |   py38ha71036d_2         511 KB  conda-forge\n","    scikit-image-0.16.2        |   py38hb3f55d8_0        25.1 MB  conda-forge\n","    scipy-1.5.3                |   py38h828c644_0        18.7 MB  conda-forge\n","    send2trash-1.5.0           |             py_0          12 KB  conda-forge\n","    terminado-0.9.2            |   py38h578d9bd_0          26 KB  conda-forge\n","    testpath-0.4.4             |             py_0          85 KB  conda-forge\n","    toolz-0.11.1               |             py_0          46 KB  conda-forge\n","    tornado-6.1                |   py38h25fe258_0         646 KB  conda-forge\n","    traitlets-5.0.5            |             py_0          81 KB  conda-forge\n","    traittypes-0.2.1           |     pyh9f0ad1d_2          10 KB  conda-forge\n","    wcwidth-0.2.5              |     pyh9f0ad1d_2          33 KB  conda-forge\n","    webencodings-0.5.1         |             py_1          12 KB  conda-forge\n","    widgetsnbextension-3.5.1   |   py38h578d9bd_4         1.8 MB  conda-forge\n","    zeromq-4.3.3               |       he6710b0_3         500 KB\n","    zipp-3.4.1                 |     pyhd8ed1ab_0          11 KB  conda-forge\n","    zstd-1.4.5                 |       h9ceee32_0         619 KB\n","    ------------------------------------------------------------\n","                                           Total:       147.4 MB\n","\n","The following NEW packages will be INSTALLED:\n","\n","  argon2-cffi        conda-forge/linux-64::argon2-cffi-20.1.0-py38h25fe258_2\n","  async_generator    conda-forge/noarch::async_generator-1.10-py_0\n","  attrs              conda-forge/noarch::attrs-20.3.0-pyhd3deb0d_0\n","  backcall           conda-forge/noarch::backcall-0.2.0-pyh9f0ad1d_0\n","  backports          conda-forge/noarch::backports-1.0-py_2\n","  backports.functoo~ conda-forge/noarch::backports.functools_lru_cache-1.6.1-py_0\n","  bleach             conda-forge/noarch::bleach-3.3.0-pyh44b312d_0\n","  bqplot             conda-forge/noarch::bqplot-0.12.23-pyhd8ed1ab_0\n","  cloudpickle        conda-forge/noarch::cloudpickle-1.6.0-py_0\n","  cycler             conda-forge/noarch::cycler-0.10.0-py_2\n","  cytoolz            conda-forge/linux-64::cytoolz-0.11.0-py38h25fe258_1\n","  dask-core          conda-forge/noarch::dask-core-2021.3.0-pyhd8ed1ab_0\n","  decorator          conda-forge/noarch::decorator-4.4.2-py_0\n","  defusedxml         conda-forge/noarch::defusedxml-0.7.1-pyhd8ed1ab_0\n","  entrypoints        conda-forge/noarch::entrypoints-0.3-pyhd8ed1ab_1003\n","  freetype           conda-forge/linux-64::freetype-2.10.4-h7ca028e_0\n","  icu                conda-forge/linux-64::icu-67.1-he1b5a44_0\n","  imageio            conda-forge/noarch::imageio-2.9.0-py_0\n","  importlib-metadata conda-forge/linux-64::importlib-metadata-3.7.2-py38h578d9bd_0\n","  ipydatawidgets     conda-forge/noarch::ipydatawidgets-4.2.0-pyhd3deb0d_0\n","  ipykernel          conda-forge/linux-64::ipykernel-5.5.0-py38h81c977d_1\n","  ipython            conda-forge/linux-64::ipython-7.21.0-py38h81c977d_0\n","  ipython_genutils   conda-forge/noarch::ipython_genutils-0.2.0-py_1\n","  ipyvolume          conda-forge/noarch::ipyvolume-0.6.0a6-pyh9f0ad1d_0\n","  ipywebrtc          conda-forge/linux-64::ipywebrtc-0.5.0-py38h32f6830_1\n","  ipywidgets         conda-forge/noarch::ipywidgets-7.6.3-pyhd3deb0d_0\n","  jedi               conda-forge/linux-64::jedi-0.18.0-py38h578d9bd_2\n","  jinja2             conda-forge/noarch::jinja2-2.11.3-pyh44b312d_0\n","  jpeg               conda-forge/linux-64::jpeg-9d-h36c2ea0_0\n","  jsonschema         conda-forge/noarch::jsonschema-3.2.0-pyhd8ed1ab_3\n","  jupyter_client     conda-forge/noarch::jupyter_client-6.1.12-pyhd8ed1ab_0\n","  jupyter_core       conda-forge/linux-64::jupyter_core-4.7.1-py38h578d9bd_0\n","  jupyterlab_pygmen~ conda-forge/noarch::jupyterlab_pygments-0.1.2-pyh9f0ad1d_0\n","  jupyterlab_widgets conda-forge/noarch::jupyterlab_widgets-1.0.0-pyhd8ed1ab_1\n","  kiwisolver         conda-forge/linux-64::kiwisolver-1.3.1-py38h82cb98a_0\n","  libblas            conda-forge/linux-64::libblas-3.9.0-8_openblas\n","  libcblas           conda-forge/linux-64::libcblas-3.9.0-8_openblas\n","  libgfortran-ng     conda-forge/linux-64::libgfortran-ng-7.5.0-h14aa051_18\n","  libgfortran4       conda-forge/linux-64::libgfortran4-7.5.0-h14aa051_18\n","  liblapack          conda-forge/linux-64::liblapack-3.9.0-8_openblas\n","  libopenblas        conda-forge/linux-64::libopenblas-0.3.12-pthreads_hb3c22a3_1\n","  libpng             conda-forge/linux-64::libpng-1.6.37-h21135ba_2\n","  libsodium          conda-forge/linux-64::libsodium-1.0.18-h36c2ea0_1\n","  libtiff            conda-forge/linux-64::libtiff-4.0.10-hc3755c2_1005\n","  lz4-c              conda-forge/linux-64::lz4-c-1.9.2-he1b5a44_3\n","  markupsafe         conda-forge/linux-64::markupsafe-1.1.1-py38h8df0ef7_2\n","  matplotlib-base    conda-forge/linux-64::matplotlib-base-3.2.2-py38h5d868c9_1\n","  mistune            conda-forge/linux-64::mistune-0.8.4-py38h25fe258_1002\n","  nbclient           conda-forge/noarch::nbclient-0.5.3-pyhd8ed1ab_0\n","  nbconvert          conda-forge/linux-64::nbconvert-6.0.7-py38h578d9bd_3\n","  nbformat           conda-forge/noarch::nbformat-5.1.2-pyhd8ed1ab_1\n","  nest-asyncio       conda-forge/noarch::nest-asyncio-1.4.3-pyhd8ed1ab_0\n","  networkx           conda-forge/noarch::networkx-2.5-py_0\n","  notebook           conda-forge/linux-64::notebook-6.2.0-py38h578d9bd_0\n","  numpy              conda-forge/linux-64::numpy-1.18.1-py38h8854b6b_1\n","  olefile            conda-forge/noarch::olefile-0.46-pyh9f0ad1d_1\n","  packaging          conda-forge/noarch::packaging-20.9-pyh44b312d_0\n","  pandas             conda-forge/linux-64::pandas-1.0.1-py38hb3f55d8_0\n","  pandoc             conda-forge/linux-64::pandoc-2.12-h7f98852_0\n","  pandocfilters      conda-forge/noarch::pandocfilters-1.4.2-py_1\n","  parso              conda-forge/noarch::parso-0.8.1-pyhd8ed1ab_0\n","  pexpect            conda-forge/noarch::pexpect-4.8.0-pyh9f0ad1d_2\n","  pickleshare        conda-forge/noarch::pickleshare-0.7.5-py_1003\n","  pillow             conda-forge/linux-64::pillow-6.2.1-py38h6b7be26_0\n","  prometheus_client  conda-forge/noarch::prometheus_client-0.9.0-pyhd3deb0d_0\n","  prompt-toolkit     conda-forge/noarch::prompt-toolkit-3.0.17-pyha770c72_0\n","  ptyprocess         conda-forge/noarch::ptyprocess-0.7.0-pyhd3deb0d_0\n","  pygments           conda-forge/noarch::pygments-2.8.1-pyhd8ed1ab_0\n","  pyparsing          conda-forge/noarch::pyparsing-2.4.7-pyh9f0ad1d_0\n","  pyrsistent         conda-forge/linux-64::pyrsistent-0.17.3-py38h25fe258_1\n","  python-dateutil    conda-forge/noarch::python-dateutil-2.8.1-py_0\n","  python_abi         conda-forge/linux-64::python_abi-3.8-1_cp38\n","  pythreejs          conda-forge/noarch::pythreejs-2.3.0-pyhd8ed1ab_0\n","  pytz               conda-forge/noarch::pytz-2021.1-pyhd8ed1ab_0\n","  pywavelets         conda-forge/linux-64::pywavelets-1.1.1-py38hab2c0dc_3\n","  pyyaml             conda-forge/linux-64::pyyaml-5.3.1-py38h8df0ef7_1\n","  pyzmq              conda-forge/linux-64::pyzmq-19.0.2-py38ha71036d_2\n","  scikit-image       conda-forge/linux-64::scikit-image-0.16.2-py38hb3f55d8_0\n","  scipy              conda-forge/linux-64::scipy-1.5.3-py38h828c644_0\n","  send2trash         conda-forge/noarch::send2trash-1.5.0-py_0\n","  terminado          conda-forge/linux-64::terminado-0.9.2-py38h578d9bd_0\n","  testpath           conda-forge/noarch::testpath-0.4.4-py_0\n","  toolz              conda-forge/noarch::toolz-0.11.1-py_0\n","  tornado            conda-forge/linux-64::tornado-6.1-py38h25fe258_0\n","  traitlets          conda-forge/noarch::traitlets-5.0.5-py_0\n","  traittypes         conda-forge/noarch::traittypes-0.2.1-pyh9f0ad1d_2\n","  wcwidth            conda-forge/noarch::wcwidth-0.2.5-pyh9f0ad1d_2\n","  webencodings       conda-forge/noarch::webencodings-0.5.1-py_1\n","  widgetsnbextension conda-forge/linux-64::widgetsnbextension-3.5.1-py38h578d9bd_4\n","  zeromq             pkgs/main/linux-64::zeromq-4.3.3-he6710b0_3\n","  zipp               conda-forge/noarch::zipp-3.4.1-pyhd8ed1ab_0\n","  zstd               pkgs/main/linux-64::zstd-1.4.5-h9ceee32_0\n","\n","The following packages will be UPDATED:\n","\n","  ca-certificates    pkgs/main::ca-certificates-2020.10.14~ --> conda-forge::ca-certificates-2020.12.5-ha878542_0\n","  certifi            pkgs/main/noarch::certifi-2020.6.20-p~ --> conda-forge/linux-64::certifi-2020.12.5-py38h578d9bd_1\n","  openssl                                 1.1.1h-h7b6447c_0 --> 1.1.1j-h27cfd23_0\n","\n","The following packages will be SUPERSEDED by a higher-priority channel:\n","\n","  conda               pkgs/main::conda-4.9.2-py38h06a4308_0 --> conda-forge::conda-4.9.2-py38h578d9bd_0\n","\n","\n","Preparing transaction: ...working... done\n","Verifying transaction: ...working... done\n","Executing transaction: ...working... Enabling notebook extension jupyter-js-widgets/extension...\n","Paths used for configuration of notebook: \n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/bqplot.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/ipyvolume.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/ipywebrtc.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/jupyter-datawidgets.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/jupyter-threejs.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/plotlywidget.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/widgetsnbextension.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.json\n","Paths used for configuration of notebook: \n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/bqplot.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/ipyvolume.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/ipywebrtc.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/jupyter-datawidgets.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/jupyter-threejs.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/plotlywidget.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/widgetsnbextension.json\n","      - Validating: \u001b[32mOK\u001b[0m\n","Paths used for configuration of notebook: \n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/bqplot.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/ipyvolume.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/ipywebrtc.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/jupyter-datawidgets.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/jupyter-threejs.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/plotlywidget.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/widgetsnbextension.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.json\n","\n","done\n","Collecting tensorflow-graphics\n","  Downloading tensorflow_graphics-2020.5.20-py2.py3-none-any.whl (342 kB)\n","\u001b[K     |████████████████████████████████| 342 kB 4.0 MB/s \n","\u001b[?25hCollecting h5py>=2.10.0\n","  Downloading h5py-3.2.1-cp38-cp38-manylinux1_x86_64.whl (4.5 MB)\n","\u001b[K     |████████████████████████████████| 4.5 MB 5.9 MB/s \n","\u001b[?25hCollecting psutil>=5.7.0\n","  Downloading psutil-5.8.0-cp38-cp38-manylinux2010_x86_64.whl (296 kB)\n","\u001b[K     |████████████████████████████████| 296 kB 34.8 MB/s \n","\u001b[?25hCollecting tensorflow>=2.2.0\n","  Downloading tensorflow-2.4.1-cp38-cp38-manylinux2010_x86_64.whl (394.4 MB)\n","\u001b[K     |████████████████████████████████| 394.4 MB 20 kB/s \n","\u001b[?25hRequirement already satisfied: networkx in /usr/local/lib/python3.8/site-packages (from tensorflow-graphics) (2.5)\n","Collecting trimesh>=2.37.22\n","  Downloading trimesh-3.9.8-py3-none-any.whl (629 kB)\n","\u001b[K     |████████████████████████████████| 629 kB 77.4 MB/s \n","\u001b[?25hCollecting tensorflow-datasets>=2.0.0\n","  Downloading tensorflow_datasets-4.2.0-py3-none-any.whl (3.7 MB)\n","\u001b[K     |████████████████████████████████| 3.7 MB 79.1 MB/s \n","\u001b[?25hRequirement already satisfied: tqdm>=4.45.0 in /usr/local/lib/python3.8/site-packages (from tensorflow-graphics) (4.51.0)\n","Requirement already satisfied: scipy>=1.1.0 in /usr/local/lib/python3.8/site-packages (from tensorflow-graphics) (1.5.3)\n","Requirement already satisfied: numpy>=1.15.4 in /usr/local/lib/python3.8/site-packages (from tensorflow-graphics) (1.18.1)\n","Collecting absl-py>=0.6.1\n","  Downloading absl_py-0.12.0-py3-none-any.whl (129 kB)\n","\u001b[K     |████████████████████████████████| 129 kB 83.2 MB/s \n","\u001b[?25hCollecting OpenEXR>=1.3.2\n","  Downloading OpenEXR-1.3.2.tar.gz (10 kB)\n","Collecting termcolor>=1.1.0\n","  Downloading termcolor-1.1.0.tar.gz (3.9 kB)\n","Requirement already satisfied: matplotlib>=2.2.5 in /usr/local/lib/python3.8/site-packages (from tensorflow-graphics) (3.2.2)\n","Collecting typing-extensions~=3.7.4\n","  Downloading typing_extensions-3.7.4.3-py3-none-any.whl (22 kB)\n","Requirement already satisfied: six~=1.15.0 in /usr/local/lib/python3.8/site-packages (from tensorflow>=2.2.0->tensorflow-graphics) (1.15.0)\n","Collecting wrapt~=1.12.1\n","  Downloading wrapt-1.12.1.tar.gz (27 kB)\n","Collecting protobuf>=3.9.2\n","  Downloading protobuf-3.15.6-cp38-cp38-manylinux1_x86_64.whl (1.0 MB)\n","\u001b[K     |████████████████████████████████| 1.0 MB 70.2 MB/s \n","\u001b[?25hCollecting tensorflow-estimator<2.5.0,>=2.4.0\n","  Downloading tensorflow_estimator-2.4.0-py2.py3-none-any.whl (462 kB)\n","\u001b[K     |████████████████████████████████| 462 kB 65.2 MB/s \n","\u001b[?25hCollecting gast==0.3.3\n","  Downloading gast-0.3.3-py2.py3-none-any.whl (9.7 kB)\n","Collecting tensorboard~=2.4\n","  Downloading tensorboard-2.4.1-py3-none-any.whl (10.6 MB)\n","\u001b[K     |████████████████████████████████| 10.6 MB 65.0 MB/s \n","\u001b[?25hCollecting grpcio~=1.32.0\n","  Downloading grpcio-1.32.0-cp38-cp38-manylinux2014_x86_64.whl (3.8 MB)\n","\u001b[K     |████████████████████████████████| 3.8 MB 65.9 MB/s \n","\u001b[?25hCollecting opt-einsum~=3.3.0\n","  Downloading opt_einsum-3.3.0-py3-none-any.whl (65 kB)\n","\u001b[K     |████████████████████████████████| 65 kB 4.8 MB/s \n","\u001b[?25hCollecting keras-preprocessing~=1.1.2\n","  Downloading Keras_Preprocessing-1.1.2-py2.py3-none-any.whl (42 kB)\n","\u001b[K     |████████████████████████████████| 42 kB 1.6 MB/s \n","\u001b[?25hCollecting google-pasta~=0.2\n","  Downloading google_pasta-0.2.0-py3-none-any.whl (57 kB)\n","\u001b[K     |████████████████████████████████| 57 kB 7.0 MB/s \n","\u001b[?25hRequirement already satisfied: wheel~=0.35 in /usr/local/lib/python3.8/site-packages (from tensorflow>=2.2.0->tensorflow-graphics) (0.35.1)\n","Collecting flatbuffers~=1.12.0\n","  Downloading flatbuffers-1.12-py2.py3-none-any.whl (15 kB)\n","Collecting astunparse~=1.6.3\n","  Downloading astunparse-1.6.3-py2.py3-none-any.whl (12 kB)\n","Requirement already satisfied: decorator>=4.3.0 in /usr/local/lib/python3.8/site-packages (from networkx->tensorflow-graphics) (4.4.2)\n","Requirement already satisfied: setuptools in /usr/local/lib/python3.8/site-packages (from trimesh>=2.37.22->tensorflow-graphics) (50.3.1.post20201107)\n","Collecting future\n","  Downloading future-0.18.2.tar.gz (829 kB)\n","\u001b[K     |████████████████████████████████| 829 kB 69.5 MB/s \n","\u001b[?25hCollecting dill\n","  Downloading dill-0.3.3-py2.py3-none-any.whl (81 kB)\n","\u001b[K     |████████████████████████████████| 81 kB 11.7 MB/s \n","\u001b[?25hCollecting tensorflow-metadata\n","  Downloading tensorflow_metadata-0.28.0-py3-none-any.whl (47 kB)\n","\u001b[K     |████████████████████████████████| 47 kB 6.0 MB/s \n","\u001b[?25hCollecting importlib-resources; python_version < \"3.9\"\n","  Downloading importlib_resources-5.1.2-py3-none-any.whl (25 kB)\n","Requirement already satisfied: requests>=2.19.0 in /usr/local/lib/python3.8/site-packages (from tensorflow-datasets>=2.0.0->tensorflow-graphics) (2.24.0)\n","Collecting promise\n","  Downloading promise-2.3.tar.gz (19 kB)\n","Requirement already satisfied: attrs>=18.1.0 in /usr/local/lib/python3.8/site-packages (from tensorflow-datasets>=2.0.0->tensorflow-graphics) (20.3.0)\n","Requirement already satisfied: pyparsing!=2.0.4,!=2.1.2,!=2.1.6,>=2.0.1 in /usr/local/lib/python3.8/site-packages (from matplotlib>=2.2.5->tensorflow-graphics) (2.4.7)\n","Requirement already satisfied: python-dateutil>=2.1 in /usr/local/lib/python3.8/site-packages (from matplotlib>=2.2.5->tensorflow-graphics) (2.8.1)\n","Requirement already satisfied: cycler>=0.10 in /usr/local/lib/python3.8/site-packages (from matplotlib>=2.2.5->tensorflow-graphics) (0.10.0)\n","Requirement already satisfied: kiwisolver>=1.0.1 in /usr/local/lib/python3.8/site-packages (from matplotlib>=2.2.5->tensorflow-graphics) (1.3.1)\n","Collecting werkzeug>=0.11.15\n","  Downloading Werkzeug-1.0.1-py2.py3-none-any.whl (298 kB)\n","\u001b[K     |████████████████████████████████| 298 kB 59.0 MB/s \n","\u001b[?25hCollecting google-auth<2,>=1.6.3\n","  Downloading google_auth-1.27.1-py2.py3-none-any.whl (136 kB)\n","\u001b[K     |████████████████████████████████| 136 kB 87.6 MB/s \n","\u001b[?25hCollecting markdown>=2.6.8\n","  Downloading Markdown-3.3.4-py3-none-any.whl (97 kB)\n","\u001b[K     |████████████████████████████████| 97 kB 8.7 MB/s \n","\u001b[?25hCollecting tensorboard-plugin-wit>=1.6.0\n","  Downloading tensorboard_plugin_wit-1.8.0-py3-none-any.whl (781 kB)\n","\u001b[K     |████████████████████████████████| 781 kB 69.5 MB/s \n","\u001b[?25hCollecting google-auth-oauthlib<0.5,>=0.4.1\n","  Downloading google_auth_oauthlib-0.4.3-py2.py3-none-any.whl (18 kB)\n","Collecting googleapis-common-protos<2,>=1.52.0\n","  Downloading googleapis_common_protos-1.53.0-py2.py3-none-any.whl (198 kB)\n","\u001b[K     |████████████████████████████████| 198 kB 83.1 MB/s \n","\u001b[?25hRequirement already satisfied: chardet<4,>=3.0.2 in /usr/local/lib/python3.8/site-packages (from requests>=2.19.0->tensorflow-datasets>=2.0.0->tensorflow-graphics) (3.0.4)\n","Requirement already satisfied: urllib3!=1.25.0,!=1.25.1,<1.26,>=1.21.1 in /usr/local/lib/python3.8/site-packages (from requests>=2.19.0->tensorflow-datasets>=2.0.0->tensorflow-graphics) (1.25.11)\n","Requirement already satisfied: idna<3,>=2.5 in /usr/local/lib/python3.8/site-packages (from requests>=2.19.0->tensorflow-datasets>=2.0.0->tensorflow-graphics) (2.10)\n","Requirement already satisfied: certifi>=2017.4.17 in /usr/local/lib/python3.8/site-packages (from requests>=2.19.0->tensorflow-datasets>=2.0.0->tensorflow-graphics) (2020.12.5)\n","Collecting pyasn1-modules>=0.2.1\n","  Downloading pyasn1_modules-0.2.8-py2.py3-none-any.whl (155 kB)\n","\u001b[K     |████████████████████████████████| 155 kB 89.2 MB/s \n","\u001b[?25hCollecting cachetools<5.0,>=2.0.0\n","  Downloading cachetools-4.2.1-py3-none-any.whl (12 kB)\n","Collecting rsa<5,>=3.1.4; python_version >= \"3.6\"\n","  Downloading rsa-4.7.2-py3-none-any.whl (34 kB)\n","Collecting requests-oauthlib>=0.7.0\n","  Downloading requests_oauthlib-1.3.0-py2.py3-none-any.whl (23 kB)\n","Collecting pyasn1<0.5.0,>=0.4.6\n","  Downloading pyasn1-0.4.8-py2.py3-none-any.whl (77 kB)\n","\u001b[K     |████████████████████████████████| 77 kB 7.1 MB/s \n","\u001b[?25hCollecting oauthlib>=3.0.0\n","  Downloading oauthlib-3.1.0-py2.py3-none-any.whl (147 kB)\n","\u001b[K     |████████████████████████████████| 147 kB 89.1 MB/s \n","\u001b[?25hBuilding wheels for collected packages: OpenEXR, termcolor, wrapt, future, promise\n","  Building wheel for OpenEXR (setup.py) ... \u001b[?25l\u001b[?25hdone\n","  Created wheel for OpenEXR: filename=OpenEXR-1.3.2-cp38-cp38-linux_x86_64.whl size=209621 sha256=25573cf1a9bc9747af0321211b3cb6b90905c2c69a00d198505f495b899d6c6a\n","  Stored in directory: /root/.cache/pip/wheels/0a/10/25/9e32a4b1313a410a3210aea47a0fe60c8a738da2ef55419cd7\n","  Building wheel for termcolor (setup.py) ... \u001b[?25l\u001b[?25hdone\n","  Created wheel for termcolor: filename=termcolor-1.1.0-py3-none-any.whl size=4830 sha256=16096b0c2bdac8045fd37595bac5fd5b400ca5a4a867ba238ade83a1b625f317\n","  Stored in directory: /root/.cache/pip/wheels/a0/16/9c/5473df82468f958445479c59e784896fa24f4a5fc024b0f501\n","  Building wheel for wrapt (setup.py) ... \u001b[?25l\u001b[?25hdone\n","  Created wheel for wrapt: filename=wrapt-1.12.1-cp38-cp38-linux_x86_64.whl size=78018 sha256=457b9b77deec667f589e19a992b190e26572ddac8fbfd60ace753b2f98022adf\n","  Stored in directory: /root/.cache/pip/wheels/5f/fd/9e/b6cf5890494cb8ef0b5eaff72e5d55a70fb56316007d6dfe73\n","  Building wheel for future (setup.py) ... \u001b[?25l\u001b[?25hdone\n","  Created wheel for future: filename=future-0.18.2-py3-none-any.whl size=491059 sha256=93ed1bfedb844b987afe8d0cb36a3d937b740ecb4d1b1a78bd9f4496dfa70340\n","  Stored in directory: /root/.cache/pip/wheels/8e/70/28/3d6ccd6e315f65f245da085482a2e1c7d14b90b30f239e2cf4\n","  Building wheel for promise (setup.py) ... \u001b[?25l\u001b[?25hdone\n","  Created wheel for promise: filename=promise-2.3-py3-none-any.whl size=21494 sha256=594eb2927060391a8d6cd6665f7548dbafa533bdcb487566c51e2b0660a99eb5\n","  Stored in directory: /root/.cache/pip/wheels/54/aa/01/724885182f93150035a2a91bce34a12877e8067a97baaf5dc8\n","Successfully built OpenEXR termcolor wrapt future promise\n","Installing collected packages: h5py, psutil, typing-extensions, termcolor, wrapt, protobuf, tensorflow-estimator, gast, absl-py, werkzeug, pyasn1, pyasn1-modules, cachetools, rsa, google-auth, grpcio, markdown, tensorboard-plugin-wit, oauthlib, requests-oauthlib, google-auth-oauthlib, tensorboard, opt-einsum, keras-preprocessing, google-pasta, flatbuffers, astunparse, tensorflow, trimesh, future, dill, googleapis-common-protos, tensorflow-metadata, importlib-resources, promise, tensorflow-datasets, OpenEXR, tensorflow-graphics\n","\u001b[31mERROR: After October 2020 you may experience errors when installing or updating packages. This is because pip will change the way that it resolves dependency conflicts.\n","\n","We recommend you use --use-feature=2020-resolver to test your packages with the new resolver before it becomes the default.\n","\n","tensorflow 2.4.1 requires h5py~=2.10.0, but you'll have h5py 3.2.1 which is incompatible.\n","tensorflow 2.4.1 requires numpy~=1.19.2, but you'll have numpy 1.18.1 which is incompatible.\n","tensorflow-metadata 0.28.0 requires absl-py<0.11,>=0.9, but you'll have absl-py 0.12.0 which is incompatible.\u001b[0m\n","Successfully installed OpenEXR-1.3.2 absl-py-0.12.0 astunparse-1.6.3 cachetools-4.2.1 dill-0.3.3 flatbuffers-1.12 future-0.18.2 gast-0.3.3 google-auth-1.27.1 google-auth-oauthlib-0.4.3 google-pasta-0.2.0 googleapis-common-protos-1.53.0 grpcio-1.32.0 h5py-3.2.1 importlib-resources-5.1.2 keras-preprocessing-1.1.2 markdown-3.3.4 oauthlib-3.1.0 opt-einsum-3.3.0 promise-2.3 protobuf-3.15.6 psutil-5.8.0 pyasn1-0.4.8 pyasn1-modules-0.2.8 requests-oauthlib-1.3.0 rsa-4.7.2 tensorboard-2.4.1 tensorboard-plugin-wit-1.8.0 tensorflow-2.4.1 tensorflow-datasets-4.2.0 tensorflow-estimator-2.4.0 tensorflow-graphics-2020.5.20 tensorflow-metadata-0.28.0 termcolor-1.1.0 trimesh-3.9.8 typing-extensions-3.7.4.3 werkzeug-1.0.1 wrapt-1.12.1\n"],"name":"stdout"},{"output_type":"display_data","data":{"application/vnd.colab-display-data+json":{"pip_warning":{"packages":["google"]}}},"metadata":{"tags":[]}}]},{"cell_type":"code","metadata":{"id":"VZDmNWzdK4KO","executionInfo":{"status":"ok","timestamp":1615719853862,"user_tz":-60,"elapsed":228059,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["import sys\n","sys.path.append('/usr/local/lib/python3.8/site-packages')\n","sys.path.append(\"protein-reconstruction\") "],"execution_count":6,"outputs":[]},{"cell_type":"code","metadata":{"id":"Zro6bM3VK4KR","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615719853862,"user_tz":-60,"elapsed":228052,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"98822a6c-21a9-4bb7-bfcb-e0e86333a2e7"},"source":["!python --version"],"execution_count":7,"outputs":[{"output_type":"stream","text":["Python 3.8.5\n"],"name":"stdout"}]},{"cell_type":"markdown","metadata":{"id":"787rPWn8K4KU"},"source":["## Start the Pipeline"]},{"cell_type":"code","metadata":{"id":"06JQ1KmQK4KV","executionInfo":{"status":"ok","timestamp":1615719858519,"user_tz":-60,"elapsed":232707,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["import os\n","import h5py\n","import numpy as np\n","import time\n","import pandas as pd\n","\n","\n","from cryoem.plots import plot_angles_count, plot_images\n","from IPython.display import Image\n","import matplotlib.pyplot as plt\n","\n","import tensorflow as tf\n","from cryoem.conversions import d_q, euler2quaternion\n","#import ipyvolume as ipv\n","from collections import Counter\n","import itertools\n","import seaborn as sns; sns.set(style=\"white\", color_codes=True)\n","import io"],"execution_count":8,"outputs":[]},{"cell_type":"code","metadata":{"id":"m9Os8XDOK4KY","colab":{"base_uri":"https://localhost:8080/","height":35},"executionInfo":{"status":"ok","timestamp":1615719858520,"user_tz":-60,"elapsed":232701,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"da7a13a4-0a77-4996-bfa5-382d4dd4d1fc"},"source":["tf.__version__"],"execution_count":9,"outputs":[{"output_type":"execute_result","data":{"application/vnd.google.colaboratory.intrinsic+json":{"type":"string"},"text/plain":["'2.4.1'"]},"metadata":{"tags":[]},"execution_count":9}]},{"cell_type":"code","metadata":{"id":"ShUD7yqTK4Kb","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615719864190,"user_tz":-60,"elapsed":238363,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"6c4f7f23-7536-4eb9-b7a3-85a6f13d80e0"},"source":["from tensorflow.python.client import device_lib \n","print(device_lib.list_local_devices())"],"execution_count":10,"outputs":[{"output_type":"stream","text":["[name: \"/device:CPU:0\"\n","device_type: \"CPU\"\n","memory_limit: 268435456\n","locality {\n","}\n","incarnation: 6404653418234959023\n",", name: \"/device:GPU:0\"\n","device_type: \"GPU\"\n","memory_limit: 15703311680\n","locality {\n","  bus_id: 1\n","  links {\n","  }\n","}\n","incarnation: 15342113253344037820\n","physical_device_desc: \"device: 0, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:04.0, compute capability: 6.0\"\n","]\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"kZFVlYW4K4Ke","executionInfo":{"status":"ok","timestamp":1615719864193,"user_tz":-60,"elapsed":238364,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["PROTEIN=\"5j0n\"\n","NUM_PROJECTIONS = 5000\n","\n","NOISY_VAR = 0 # vary from 1 to 10\n","TRANSLATION = 0.1\n","FEATURE_DIM = 8\n","path_logs_training = \"/content/drive/My Drive/ModelsProtein\"\n","training_description = f\"5j0n_dim{FEATURE_DIM}_de\""],"execution_count":11,"outputs":[]},{"cell_type":"code","metadata":{"id":"-q8GWm2EK4Kh","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615719864704,"user_tz":-60,"elapsed":238870,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"87ef4263-fe60-46f7-e0fe-6056bdfaf8a3"},"source":["# TODO: dataset name\n","projections_filename = f\"{PROTEIN}_ProjectionsAngles_ProjNber5000_AngCoverage2.0,1.0,2.0_AngShift0.0,0.0,0.0.h5\"\n","\n","# load structures\n","data = h5py.File(os.path.join(path_logs_training, projections_filename), 'r')\n","\n","print(f\"{data['Projections'].shape[0]} projections of images with dimension {data['Projections'].shape[1:]} pixels\")\n","print(f\"{data['Angles'].shape[0]} sets of {data['Angles'].shape[1]} ground truth angles of corresponding projection images\")"],"execution_count":12,"outputs":[{"output_type":"stream","text":["5000 projections of images with dimension (116, 116) pixels\n","5000 sets of 3 ground truth angles of corresponding projection images\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"2zARA9L2K4Kj","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615719864705,"user_tz":-60,"elapsed":238865,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"17ea5e54-8742-4847-8382-a4ee36fad135"},"source":["projections = data['Projections']\n","projections.shape"],"execution_count":13,"outputs":[{"output_type":"execute_result","data":{"text/plain":["(5000, 116, 116)"]},"metadata":{"tags":[]},"execution_count":13}]},{"cell_type":"code","metadata":{"id":"bIQzyIQnxgts","colab":{"base_uri":"https://localhost:8080/","height":271},"executionInfo":{"status":"ok","timestamp":1615719864706,"user_tz":-60,"elapsed":238860,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"f77bd881-304b-4188-cce9-705c2756fb3f"},"source":["sampleProj = projections[1,:,:]\n","plt.imshow(sampleProj,cmap='gray')\n","plt.show()"],"execution_count":14,"outputs":[{"output_type":"display_data","data":{"image/png":"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DMD0/i3379+Pb33rW7jrrruwbt06vP3229Oypt7eXqxataru73WxdUz7HnBnIBs3bnT37t3ruq7r7t271924ceMVX8Po6Kj7j3/8w/z861//2v3pT3/qOo7j3n777e6BAwdc13XdXbt2uZs2bbqia+vv73fvv/9+97bbbnOPHDkyI9a0bds295e//KVbq9Vc13Xd4eFh13Wn729Zq9Xc7u5u98iRI67ruu6HH37oLl++3HUc54qv6cCBA+7x48fN34tcaB3TvQdmnDCcOnXKXbFihVutVl3Xdd1qtequWLHCTafT07qut956y/3+97/vfvDBB+43v/lNc386nXaXL19+xdZRLpfdb3/72+7AwID5R5vuNeVyOXfFihVuLperu386/5a1Ws39yle+4h48eNB1Xdf95z//6a5Zs2Za12QLw4XWMRP2wIxrohocHERHR4fpkQgEAliwYAEGBweRSqWmZU21Wg2vvvoqVq1ahcHBQVx77bXmsVQqhVqthkwmg2QyOeVr2bFjB9atW4dFixaZ+6Z7TQMDA0gmk9i5cyfee+89JBIJPPLII4hGo9P2t/T5fHj++efx0EMPIR6PI5/P46WXXpox/18XWofrutO+xhkZY5hpbNu2DfF4HPfee++0ruP9999Hf38/NmzYMK3raMRxHAwMDODmm2/GH//4Rzz22GP40Y9+hEKhMG1rqlarePHFF7F7927s378fL7zwAh599NFpXdPVxIyzGDo7O3Hy5Ek4joNAIADHcTA0NITOzs5pWU9vby8+++wz7NmzB36/H52dnTh+/Lh5fGRkBH6//4pcmQ8cOICjR49i9erVAIATJ07g/vvvx8aNG6dtTcCZv1kwGERPTw8A4JZbbsGcOXMQjUan7W/54YcfYmhoCCtWrAAArFixArFYDJFIZEb8f13o/9x13Wlf44yzGObOnYuuri709fUBAPr6+tDV1TUtbsRzzz2H/v5+7Nq1C+FwGACwbNkylEolHDx4EADw2muv4Y477rgi63nwwQfxt7/9De+88w7eeecdXHPNNfjd736HBx54YNrWBJxxXVauXIl3330XwJmIejqdxpIlS6btb3nNNdfgxIkT+OSTTwAAR48eRTqdxuLFi2fE/9eF/s9nwh6YkW3XR48exaZNmzA2Noa2tjb09vbihhtuuKJr+Pjjj9HT04MlS5aYfvVFixZh165d+Ne//oUtW7agXC5j4cKF2L59O+bNm3dF1wcAq1atwp49e7B06dJpX9PAwACefPJJZDIZBINBPProo/j6178+rX/LP/3pT/jtb38Ln88HAPjxj3+M22+//Yqv6Re/+AXefvttnDp1CnPmzEEymcSf//znC65juvfAjBQGIcT0MuNcCSHE9CNhEEJ4kDAIITxIGIQQHiQMQggPEgYhhAcJgxDCg4RBCOHh/wFH0aU6H+DxMAAAAABJRU5ErkJggg==\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[]}}]},{"cell_type":"code","metadata":{"id":"PpprtZ8vwc39","executionInfo":{"status":"ok","timestamp":1615719864708,"user_tz":-60,"elapsed":238860,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["def add_gaussian_noise(projections, noise_var):\n","    noise_sigma   = noise_var**0.5\n","    nproj,row,col = projections.shape\n","    gauss_noise   = np.random.normal(0,noise_sigma,(nproj,row,col))\n","    gauss_noise   = gauss_noise.reshape(nproj,row,col) \n","    projections   = projections + gauss_noise\n","    return projections"],"execution_count":15,"outputs":[]},{"cell_type":"code","metadata":{"id":"ydwWD-IkD0P3","executionInfo":{"status":"ok","timestamp":1615719864709,"user_tz":-60,"elapsed":238859,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["def add_triangle_translation(projections, left_limit, peak_limit, right_limit):\n","    horizontal_shift = np.random.triangular(left_limit, peak_limit, right_limit, len(projections))\n","    vertical_shift   = np.random.triangular(left_limit, peak_limit, right_limit, len(projections))\n","    for i, (hs, vs) in enumerate(zip(horizontal_shift, vertical_shift)):\n","        projections[i]      = np.roll(projections[i], int(hs), axis=0) # shift 1 place in horizontal axis\n","        projections[i]      = np.roll(projections[i], int(vs), axis=1) # shift 1 place in vertical axis\n","    return projections"],"execution_count":16,"outputs":[]},{"cell_type":"code","metadata":{"id":"oCD6IwpOr3_A","executionInfo":{"status":"ok","timestamp":1615719870102,"user_tz":-60,"elapsed":244251,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["# Add zero-mean Gaussian noise on the projections \n","projections = add_gaussian_noise(projections, NOISY_VAR)\n","projections = add_triangle_translation(projections, left_limit=-TRANSLATION, peak_limit=0, right_limit=TRANSLATION)"],"execution_count":17,"outputs":[]},{"cell_type":"code","metadata":{"id":"qR8J0QCmxG-y","colab":{"base_uri":"https://localhost:8080/","height":271},"executionInfo":{"status":"ok","timestamp":1615719870104,"user_tz":-60,"elapsed":244246,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"ae54bcf5-cfb0-40f4-b3f6-83d39253f2f0"},"source":["# Display projections with/out noise (for comparison)\n","sampleProj = projections[1,:,:]\n","plt.imshow(sampleProj,cmap='gray')\n","plt.show()"],"execution_count":18,"outputs":[{"output_type":"display_data","data":{"image/png":"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DMD0/i3379+Pb33rW7jrrruwbt06vP3229Oypt7eXqxataru73WxdUz7HnBnIBs3bnT37t3ruq7r7t271924ceMVX8Po6Kj7j3/8w/z861//2v3pT3/qOo7j3n777e6BAwdc13XdXbt2uZs2bbqia+vv73fvv/9+97bbbnOPHDkyI9a0bds295e//KVbq9Vc13Xd4eFh13Wn729Zq9Xc7u5u98iRI67ruu6HH37oLl++3HUc54qv6cCBA+7x48fN34tcaB3TvQdmnDCcOnXKXbFihVutVl3Xdd1qtequWLHCTafT07qut956y/3+97/vfvDBB+43v/lNc386nXaXL19+xdZRLpfdb3/72+7AwID5R5vuNeVyOXfFihVuLperu386/5a1Ws39yle+4h48eNB1Xdf95z//6a5Zs2Za12QLw4XWMRP2wIxrohocHERHR4fpkQgEAliwYAEGBweRSqWmZU21Wg2vvvoqVq1ahcHBQVx77bXmsVQqhVqthkwmg2QyOeVr2bFjB9atW4dFixaZ+6Z7TQMDA0gmk9i5cyfee+89JBIJPPLII4hGo9P2t/T5fHj++efx0EMPIR6PI5/P46WXXpox/18XWofrutO+xhkZY5hpbNu2DfF4HPfee++0ruP9999Hf38/NmzYMK3raMRxHAwMDODmm2/GH//4Rzz22GP40Y9+hEKhMG1rqlarePHFF7F7927s378fL7zwAh599NFpXdPVxIyzGDo7O3Hy5Ek4joNAIADHcTA0NITOzs5pWU9vby8+++wz7NmzB36/H52dnTh+/Lh5fGRkBH6//4pcmQ8cOICjR49i9erVAIATJ07g/vvvx8aNG6dtTcCZv1kwGERPTw8A4JZbbsGcOXMQjUan7W/54YcfYmhoCCtWrAAArFixArFYDJFIZEb8f13o/9x13Wlf44yzGObOnYuuri709fUBAPr6+tDV1TUtbsRzzz2H/v5+7Nq1C+FwGACwbNkylEolHDx4EADw2muv4Y477rgi63nwwQfxt7/9De+88w7eeecdXHPNNfjd736HBx54YNrWBJxxXVauXIl3330XwJmIejqdxpIlS6btb3nNNdfgxIkT+OSTTwAAR48eRTqdxuLFi2fE/9eF/s9nwh6YkW3XR48exaZNmzA2Noa2tjb09vbihhtuuKJr+Pjjj9HT04MlS5aYfvVFixZh165d+Ne//oUtW7agXC5j4cKF2L59O+bNm3dF1wcAq1atwp49e7B06dJpX9PAwACefPJJZDIZBINBPProo/j6178+rX/LP/3pT/jtb38Ln88HAPjxj3+M22+//Yqv6Re/+AXefvttnDp1CnPmzEEymcSf//znC65juvfAjBQGIcT0MuNcCSHE9CNhEEJ4kDAIITxIGIQQHiQMQggPEgYhhAcJgxDCg4RBCOHh/wFH0aU6H+DxMAAAAABJRU5ErkJggg==\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[]}}]},{"cell_type":"code","metadata":{"scrolled":true,"id":"X_voGDMSK4Kn","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615719870105,"user_tz":-60,"elapsed":244241,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"b5c063b9-ca8c-4eec-b12e-842202c37dd6"},"source":["angles_true = np.array(data['Angles'])\n","angles_true.shape"],"execution_count":19,"outputs":[{"output_type":"execute_result","data":{"text/plain":["(5000, 3)"]},"metadata":{"tags":[]},"execution_count":19}]},{"cell_type":"code","metadata":{"id":"WJvZ8_XPK4Kp","executionInfo":{"status":"ok","timestamp":1615719870105,"user_tz":-60,"elapsed":244240,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["#plot_images(angles_true, projections, range(100), img_size_scale=0.05)"],"execution_count":20,"outputs":[]},{"cell_type":"code","metadata":{"id":"Z-CMl6nMK4Ks","executionInfo":{"status":"ok","timestamp":1615719870106,"user_tz":-60,"elapsed":244240,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["#ipv.screenshot()"],"execution_count":21,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"xJhOqdOnK4Kv"},"source":["---"]},{"cell_type":"markdown","metadata":{"id":"5-mkqsaEK4Kw"},"source":["## Prepare for training"]},{"cell_type":"code","metadata":{"id":"r_RDAMqvK4Kw","executionInfo":{"status":"ok","timestamp":1615719870427,"user_tz":-60,"elapsed":244559,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["from sklearn.model_selection import train_test_split"],"execution_count":22,"outputs":[]},{"cell_type":"code","metadata":{"id":"O_lxJ3huK4K0","executionInfo":{"status":"ok","timestamp":1615719870429,"user_tz":-60,"elapsed":244560,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["X, y = np.array(projections, dtype=np.float32), np.array(angles_true, dtype=np.float32)"],"execution_count":23,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"4f-dUZ4kK4K3"},"source":["#### Global standardization of projections"]},{"cell_type":"code","metadata":{"id":"X6A3wHMVK4K3","executionInfo":{"status":"ok","timestamp":1615719870431,"user_tz":-60,"elapsed":244560,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["from cryoem.preprocessing import global_standardization"],"execution_count":24,"outputs":[]},{"cell_type":"code","metadata":{"id":"3pRAKWKmK4K6","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615719871607,"user_tz":-60,"elapsed":245730,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"0050a592-8a20-42ad-ab9c-5e90dcbc4e8c"},"source":["X = global_standardization(X)"],"execution_count":25,"outputs":[{"output_type":"stream","text":["Global standardization\n","\tImage shape: (116, 116)\n","\tData Type: float32\n","\tMean: 0.262 | Std: 1.039\n","\tMin:  0.000 | Max: 15.421\n","\tMean: 0.000 | Std: 1.000\n","\tMin:  -0.252 | Max: 14.591\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"lVRXjdE3K4K9","executionInfo":{"status":"ok","timestamp":1615719871608,"user_tz":-60,"elapsed":245730,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["test_size = 0.33\n","val_size = 0.25"],"execution_count":26,"outputs":[]},{"cell_type":"code","metadata":{"id":"fRyiZcWPK4LC","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615719871609,"user_tz":-60,"elapsed":245726,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"c742b234-a394-4040-c437-e26f753b9275"},"source":["print(f\"TRAIN: {1-test_size:.2f} x {1-val_size:.2f} = {(1-test_size)*(1-val_size):.2f} => {str(int((1-test_size)*(1-val_size)*5000)).rjust(5)} imgs => max pairs: {str(int(np.power((1-test_size)*(1-val_size)*5000, 2))).rjust(10)}\")\n","print(f\"TEST : {str(test_size).rjust(18)} => {str(int(test_size*5000)).rjust(5)} imgs => max pairs: {str(int(np.power(test_size*5000, 2))).rjust(10)}\")\n","print(f\"VAL  : {1-test_size:.2f} x {val_size:.2f} = {(1-test_size)*val_size:.2f} => {str(int((1-test_size)*val_size*5000)).rjust(5)} imgs => max pairs: {str(int(np.power((1-test_size)*val_size*5000, 2))).rjust(10)}\")"],"execution_count":27,"outputs":[{"output_type":"stream","text":["TRAIN: 0.67 x 0.75 = 0.50 =>  2512 imgs => max pairs:    6312656\n","TEST :               0.33 =>  1650 imgs => max pairs:    2722500\n","VAL  : 0.67 x 0.25 = 0.17 =>   837 imgs => max pairs:     701406\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"dmtJEGv1K4LF","executionInfo":{"status":"ok","timestamp":1615719872237,"user_tz":-60,"elapsed":246352,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["data = np.load(f\"{path_logs_training}/5j0n_siamese_idx.npz\")\n","train_idx, val_idx, test_idx = data[\"arr_0\"], data[\"arr_1\"], data[\"arr_2\"]"],"execution_count":28,"outputs":[]},{"cell_type":"code","metadata":{"id":"KNkQKrfJK4LH","executionInfo":{"status":"ok","timestamp":1615719872238,"user_tz":-60,"elapsed":246352,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["channels = \"gray\"\n","if channels == \"rgb\":\n","    X = np.stack((X,)*3, axis=-1)\n","elif channels == \"gray\":\n","    X = X[:,:,:,np.newaxis]"],"execution_count":29,"outputs":[]},{"cell_type":"code","metadata":{"id":"WCOYGoQRK4LK","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615719872239,"user_tz":-60,"elapsed":246347,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"7ba83dd5-c0ba-48dd-a592-5a1a9fe51536"},"source":["X.shape"],"execution_count":30,"outputs":[{"output_type":"execute_result","data":{"text/plain":["(5000, 116, 116, 1)"]},"metadata":{"tags":[]},"execution_count":30}]},{"cell_type":"markdown","metadata":{"id":"YZ71Z1DWK4LM"},"source":["# 1. Distance Estimation"]},{"cell_type":"markdown","metadata":{"id":"0ZRKoKicK4LN"},"source":["### Train the model"]},{"cell_type":"code","metadata":{"id":"HceKfhOaK4LN","executionInfo":{"status":"ok","timestamp":1615719872240,"user_tz":-60,"elapsed":246347,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["from time import time"],"execution_count":31,"outputs":[]},{"cell_type":"code","metadata":{"id":"hqkn_ZVBK4LQ","executionInfo":{"status":"ok","timestamp":1615719872242,"user_tz":-60,"elapsed":246347,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["# UNIFORM\n","from tensorflow.keras.utils import Sequence\n","\n","num_dec = 1\n","num_bins = 32\n","\n","# # for weights\n","# dQ_values = np.load(\"data/5j0n/dQ_values_100K.npy\")\n","# distribution = np.histogram(dQ_values, bins=32, range=(0.0, np.pi), density=True)\n","# probabilities = distribution[0]\n","# weights = 1/probabilities\n","# weights_norm = weights/sum(weights)\n","\n","class DataGenerator(Sequence):\n","    \n","    def __init__(self, X, y, list_ids, limit_num_pairs=None, limit_style=\"random\", batch_size=256, shuffle=True):\n","        start_time = time()\n","        if batch_size > limit_num_pairs:\n","            raise Exception(\"Please specify limit_num_pairs that is much higher than batch_size\")\n","        self.X = X  \n","        self.y = y  \n","        self.limit_num_pairs = limit_num_pairs\n","        self.list_ids = list_ids\n","        self.batch_size = batch_size  \n","        # all the possible combinations of 2 image id pairs\n","        self.pair_ids = np.array(list(zip(*list(map(lambda x: x.flatten(), np.meshgrid(list_ids, list_ids))))))  # e.g. train_idx\n","        \n","        # Don't use all possible combination of pairs, limit them here\n","        if self.limit_num_pairs:\n","            limited_pair_indices = np.random.choice(np.arange(len(self.pair_ids)), size=self.limit_num_pairs)\n","            self.pair_ids = self.pair_ids[limited_pair_indices]\n","        \n","        if limit_style==\"uniform\":\n","            self.pair_ids = self._generate_uniform()\n","      \n","        self.shuffle = shuffle \n","        self._on_epoch_start()\n","        print(f\"Data created in {time()-start_time} sec\")\n","        \n","        \n","    def _generate_uniform(self):\n","        if os.path.exists(f\"data/5j0n/{len(self.list_ids)}_{self.limit_num_pairs}_{self.batch_size}.npy\"):\n","            return np.load(f\"data/5j0n/{len(self.list_ids)}_{self.limit_num_pairs}_{self.batch_size}.npy\")\n","        else:\n","            bins = {}\n","            for i in np.arange(0.0, 3.14, step=0.1): # so we have 32 bins\n","                bins[np.around(i, num_dec)] = []\n","\n","\n","            for idx1, idx2 in self.pair_ids:\n","                label = d_q(euler2quaternion(self.y[idx1]), euler2quaternion(self.y[idx2]))\n","                bins[np.around(label, num_dec)].append([idx1, idx2])\n","\n","            min_bin_size = len(bins[min(bins.keys(), key=lambda x: len(bins[x]))])\n","            print(\"min=\", min_bin_size)\n","            if min_bin_size == 0:\n","                raise Exception(\"It haven't yet managed to fill all the bins, please increase limit_num_pairs\")\n","\n","\n","            # cut the top of histogram to make it uniform\n","            for i in np.arange(0.0, 3.14, step=0.1): # so we have 32 bins\n","                b = np.around(i, num_dec)\n","                bins[b] = np.take(bins[b], np.arange(min_bin_size), axis=0)  \n","\n","            l = np.array(list(itertools.chain(*list(bins.values()))))\n","            np.save(f\"data/5j0n/{len(self.list_ids)}_{self.limit_num_pairs}_{self.batch_size}.npy\", l)\n","            print(\"total number of data = \", 31*min_bin_size)\n","            return l\n","    \n","    def __len__(self):\n","        # Denotes the number of batches per epoch\n","        if len(self.pair_ids)%self.batch_size == 0:\n","            return len(self.pair_ids) // self.batch_size\n","        else:\n","            return len(self.pair_ids) // self.batch_size + 1\n","        \n","    def __getitem__(self, index):\n","        # Generate one batch of data\n","        indices = self.indices[index*self.batch_size:(index+1)*self.batch_size]\n","        \n","        # Find list of ids\n","        list_ids_batch = np.take(self.pair_ids, indices, axis=0)\n","\n","        # Generate data\n","        idx1, idx2 = list_ids_batch[:,0], list_ids_batch[:,1]\n","        pairs = np.stack((self.X[idx1], self.X[idx2]), axis=1)  # shape: (len(idx1), 2, x.shape[1], x.shape[2], x.shape[3])\n","        labels = d_q(euler2quaternion(self.y[idx1]), euler2quaternion(self.y[idx2]))  # shape: len(idx1)\n","\n","        #weights = np.array(self._get_weights(labels))\n","        #labels_and_weights = np.stack((labels, weights), axis=1)\n","        \n","        # [training_pairs[:, 0], training_pairs[:, 1]], labels\n","        return [pairs[:, 0], pairs[:, 1]], labels \n","        \n","    #def _get_weights(self, labels):\n","    #    l = labels.numpy()\n","    #    return np.array(list(map(lambda x: probabilities[np.where(x >= distribution[1])[0][-1]], l)))    \n","    \n","    def _on_epoch_start(self):\n","        # Updates indices after each epoch\n","        self.indices = np.arange(len(self.pair_ids))\n","        if self.shuffle:\n","            np.random.shuffle(self.indices)     "],"execution_count":32,"outputs":[]},{"cell_type":"code","metadata":{"id":"Ui3KmgarK4LT","executionInfo":{"status":"ok","timestamp":1615719873667,"user_tz":-60,"elapsed":247771,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["import tensorflow_probability as tfp\n","import os\n","import h5py\n","from time import time, strftime\n","from datetime import datetime\n","import matplotlib.pyplot as plt\n","import numpy as np\n","from sklearn.model_selection import train_test_split\n","import pathlib\n","\n","from cryoem.rotation_matrices import RotationMatrix\n","from cryoem.conversions import euler2quaternion, d_q\n","from cryoem.knn import get_knn_projections\n","\n","import random\n","import tensorflow as tf\n","from tensorflow.keras.datasets import mnist\n","from tensorflow.keras.models import Model\n","from tensorflow.python.keras.applications.mobilenet import MobileNet\n","from tensorflow.keras.layers import Input, Conv2D, MaxPooling2D, AvgPool2D, Lambda, ZeroPadding2D, Dropout, Concatenate, Dense, GlobalAveragePooling2D, Flatten\n","from tensorflow.keras.optimizers import RMSprop, Adam, SGD\n","from tensorflow.keras import backend as K\n","from tensorflow.keras.callbacks import ModelCheckpoint,ReduceLROnPlateau\n","from tensorflow.keras.callbacks import TensorBoard\n","from tensorflow.keras.utils import plot_model#, multi_gpu_model\n","#from tensorflow.python.keras.applications.resnet50 import ResNet50\n","from tensorflow.python.keras.applications.inception_v3 import InceptionV3\n","from tensorflow.keras.losses import KLD, MAE, MSE\n","\n","_idx1 = list(np.random.choice(val_idx, size=1000))\n","_idx2 = list(np.random.choice(val_idx, size=1000))\n","\n","q1_true = euler2quaternion([angles_true[i] for i in _idx1])\n","q2_true = euler2quaternion([angles_true[i] for i in _idx2])\n","\n","p1 = [X[i] for i in _idx1]\n","p2 = [X[i] for i in _idx2]\n","\n","model = None\n","\n","def cosine_distance(vests):\n","    x, y = vests\n","    xy_sum_square = K.sum(x * y, axis=1, keepdims=True) \n","    xx_sum_square = K.sum(x * x, axis=1, keepdims=True)\n","    xx_sum_square = K.maximum(xx_sum_square,  1e-08) \n","    yy_sum_square = K.sum(y * y, axis=1, keepdims=True)\n","    yy_sum_square = K.maximum(yy_sum_square, 1e-08) \n","    \n","    cos_theta = tf.divide(xy_sum_square, K.sqrt(xx_sum_square)*K.sqrt(yy_sum_square))\n","    eps = K.epsilon()\n","    return 2*tf.acos(tf.clip_by_value(cos_theta, 0.0+eps, 1.0-eps)) \n","\n","def cos_dist_output_shape(shapes):\n","    shape1, shape2 = shapes\n","    return (shape1[0], 1)\n","\n","\n","def mae(y_true, y_pred):\n","    return MAE(y_true, y_pred) \n","\n","def mse(y_true, y_pred):\n","    return MSE(y_true, y_pred) \n","\n","\n","def create_siamese_network(input_shape):\n","    '''Base network to be shared (eq. to feature extraction).\n","    '''\n","    input_x = Input(shape=input_shape)\n","    #print(input_shape)\n","\n","    # add Convolution, MaxPool, Conv2D, remove Dropout and Dense\n","    \n","    x = Conv2D(filters=32, kernel_size=[7, 7], activation='relu', padding='same', kernel_initializer='glorot_uniform')(input_x)\n","    x = MaxPooling2D([2, 2], padding='same')(x)\n","\n","    x = Conv2D(64, [5, 5], activation='relu', padding='same', kernel_initializer='glorot_uniform')(x)\n","    x = MaxPooling2D([2, 2], padding='same')(x)\n","\n","    x = Conv2D(128, [3, 3], activation='relu', padding='same', kernel_initializer='glorot_uniform')(x)\n","    x = MaxPooling2D([2, 2], padding='same')(x)\n","\n","    x = Conv2D(256, [3, 3], activation='relu', padding='same', kernel_initializer='glorot_uniform')(x)\n","    x = MaxPooling2D([2, 2], padding='same')(x)\n","    \n","    x = Conv2D(256, [3, 3], activation='relu', padding='same', kernel_initializer='glorot_uniform')(x)\n","    x = MaxPooling2D([2, 2], padding='same')(x)\n","    \n","    x = Conv2D(512, [3, 3], activation='relu', padding='same', kernel_initializer='glorot_uniform')(x)\n","    x = MaxPooling2D([2, 2], padding='same')(x)\n","    \n","    x = Conv2D(512, [3, 3], activation='relu', padding='same', kernel_initializer='glorot_uniform')(x)\n","    x = MaxPooling2D([2, 2], padding='same')(x)\n","\n","    #x = AvgPool2D(pool_size=[8, 8], padding='same')(x)\n","    #x = tf.squeeze(x, axis=[1,2])\n","    x = Flatten()(x)\n","    x = Dense(FEATURE_DIM)(x)\n","    \n","    return Model(input_x, x)\n","\n","\n","def train_siamese(X, y, train_idx, val_idx, epochs, batch_size, learning_rate, limit_style, path_logs_training, training_description=\"\", training_steps=None, validation_steps=None, plot=True, gpus=None):\n","    \n","    \n","    def d_p(p1, p2):\n","        global model\n","        p1 = tf.cast(p1, dtype=tf.float32)\n","        p2 = tf.cast(p2, dtype=tf.float32)\n","        return model.predict([p1, p2], batch_size=256)\n","\n","    def plot_to_image(figure):\n","        \"\"\"Converts the matplotlib plot specified by 'figure' to a PNG image and\n","        returns it. The supplied figure is closed and inaccessible after this call.\"\"\"\n","        # Save the plot to a PNG in memory.\n","        buf = io.BytesIO()\n","        plt.savefig(buf, format='png')\n","        # Closing the figure prevents it from being displayed directly inside\n","        # the notebook.\n","        plt.close(figure)\n","        buf.seek(0)\n","        # Convert PNG buffer to TF image\n","        image = tf.image.decode_png(buf.getvalue(), channels=4)\n","        # Add the batch dimension\n","        image = tf.expand_dims(image, 0)\n","        return image\n","\n","    def generate_dPdQ_plot(file_writer_plot):\n","        \"\"\"Source: https://www.tensorflow.org/tensorboard/image_summaries#logging_arbitrary_image_data\"\"\"\n","\n","        \n","        def _inner_plot(epoch, logs):\n","            \"\"\"Generate dP/dQ plot for tensorboard\"\"\"\n","            dP_values = d_p(p1, p2).T[0]\n","            dQ_values = d_q(q1_true, q2_true).numpy()\n","\n","            # Creating the dataframe for SNS plot\n","            data = {\"d_Q\" : dQ_values, \"d_P\" : dP_values }\n","            df1 = pd.DataFrame(data=data)\n","\n","            fig, ax = plt.subplots(figsize=(6,6));\n","            sns.scatterplot(x=\"d_Q\", y=\"d_P\", data=df1, color=\"b\", alpha=0.3, label=\"projection pair\", ax=ax);  # \"reg\", \"kde\"\n","            x = np.arange(0, np.pi);\n","            sns.regplot(x=x, y=x, color=\"k\", ax=ax)\n","            #g = sns.jointplot(x=\"d_Q\", y=\"d_P\", data=df1, color=\"b\", alpha=0.3, label=\"projection pair\", kind=\"kde\");  # \"reg\", \"kde\"\n","            #plt.show()\n","            \n","            # Log the confusion matrix as an image summary.\n","            with file_writer_plot.as_default():\n","                tf.summary.image(\"dP/dQ plot\", plot_to_image(fig), step=epoch)\n","        \n","        return _inner_plot\n","\n","    mirrored_strategy = tf.distribute.MirroredStrategy()\n","    \n","    with mirrored_strategy.scope():\n","        # Prepare data generators\n","        training_generator = DataGenerator(X, y, train_idx, limit_num_pairs=training_steps, limit_style=limit_style, shuffle=True)\n","        validation_generator = DataGenerator(X, y, val_idx, limit_num_pairs=validation_steps, limit_style=limit_style, shuffle=True)\n","        \n","        input_shape = tuple(list(X.shape[1:])) #training_pairs[:, 0].shape[1:]\n","        print(f\"Input images shape {input_shape}\")\n","\n","        # network definition\n","        input_a = Input(shape=input_shape)\n","        input_b = Input(shape=input_shape)\n","        cnn_network = create_siamese_network(input_shape)\n","        \n","        # because we re-use the same instance `cnn_network`,\n","        # the weights of the network will be shared across the two branches\n","        processed_a = cnn_network(input_a)\n","        processed_b = cnn_network(input_b)\n","\n","        \n","        distance = Lambda(cosine_distance, output_shape=cos_dist_output_shape)([processed_a, processed_b])\n","\n","        global model\n","        model = Model([input_a, input_b], distance)  # was m\n","\n","        # train\n","        #model = multi_gpu_model(m, gpus=gpus)\n","        model.summary()\n","        #plot_model(model, to_file=\"figures/model_plot.png\", expand_nested=True, show_shapes=True, show_layer_names=True)\n","\n","        # training only top layers\n","        optimizer1 = RMSprop(learning_rate=learning_rate)\n","        model.compile(loss=mae, optimizer=optimizer1, metrics=[mse], sample_weight_mode=None)\n","\n","        # Setup callbacks\n","        # Callback that saves the model\n","        training_description = training_description or strftime('%Y%m%d_%H%M%S')\n","        CHECKPOINT_PATH = os.path.join(f\"{path_logs_training}/training\", f\"{training_description}.h5\")\n","        pathlib.Path(f\"{path_logs_training}/training\").mkdir(parents=True, exist_ok=True)\n","        backup_callback = tf.keras.callbacks.ModelCheckpoint(filepath=CHECKPOINT_PATH, monitor='val_loss', verbose=0, save_best_only=False, save_weights_only=False, mode='auto', period=1)\n","        print(f\"Model will be saved to: {CHECKPOINT_PATH}\")\n","        # Callback that will show tensorboard data\n","        LOGS_PATH = os.path.join(f\"{path_logs_training}/logs\", f\"{training_description}\")\n","        pathlib.Path(LOGS_PATH).mkdir(parents=True, exist_ok=True)\n","        logs_callback = TensorBoard(LOGS_PATH, histogram_freq=1) #, profile_batch=300)#100000000)\n","        # Callback for the dP/dQ plot\n","        file_writer_plot = tf.summary.create_file_writer(os.path.join(LOGS_PATH, \"image\"))\n","        plot_callback = tf.keras.callbacks.LambdaCallback(on_epoch_end=generate_dPdQ_plot(file_writer_plot))\n","        # Callback that will decrease LR if it gets plateau in val_loss\n","        #reduce_on_plateau_callback = ReduceLROnPlateau(monitor=\"loss\", mode=\"min\", factor=0.1, patience=20, min_lr=1e-4, verbose=1)\n","\n","\n","\n","        history1 = model.fit(training_generator, \n","                            epochs=epochs,\n","                            validation_data=validation_generator, \n","                            callbacks=[plot_callback, logs_callback, backup_callback])\n","        \n","        # Get training and test loss histories\n","        training_loss = history1.history['loss']\n","        val_loss = history1.history['val_loss']\n","        mses = history1.history['mse']\n","        val_mses = history1.history['val_mse']\n","        pathlib.Path(f\"{path_logs_training}/losses\").mkdir(parents=True, exist_ok=True)\n","        np.savez(f\"{path_logs_training}/losses/noisy_var{NOISY_VAR}.npz\", training_loss, val_loss, mses, val_mses)\n","\n","        if plot:\n","            fig, (ax1, ax2) = plt.subplots(1, 2, figsize=(15,7))\n","\n","            # Create count of the number of epochs\n","            epoch_count = range(1, len(training_loss) + 1)\n","\n","            # Visualize loss history\n","            ax1.plot(epoch_count, training_loss, 'r--', label='MAE Training Loss')\n","            ax1.plot(epoch_count, val_loss, 'b-', label='MAE Validation Loss')\n","            ax1.legend()\n","            ax1.set_xlabel('Epoch')\n","            ax1.set_ylabel('Loss')\n","\n","            ax2.plot(epoch_count, mses, 'r-', label='MSE Training')\n","            ax2.plot(epoch_count, val_mses, 'b-', label='MSE Validation')\n","            ax2.legend()\n","            ax2.set_xlabel('Epoch')\n","            ax2.set_ylabel('Loss')\n","            plt.show();\n","\n","        return model, history1\n","\n","def plot_results(projections, y_pred, y, strtype):\n","    if projections.shape[-1] == 1:\n","        projections = projections.reshape(list(projections.shape[:-2]) +[-1])\n","\n","    def _inner(i):\n","        \n","        plt.imfig, (ax1, ax2) = plt.subplots(1, 2)\n","        ax1.imshow(projections[i, 0])\n","        ax2.imshow(projections[i, 1])\n","\n","        print(f\"--- {strtype} Set ---\")\n","        print(f\"predicted: {y_pred[i][0]}\")\n","        print(f\"true:      {y[i].numpy()}\")\n","        print(f\"mse:       {mse(y_pred[i], y[i].numpy())}\")\n","        print(f\"mae:       {mae(y_pred[i], y[i].numpy())}\")\n","        \n","    return _inner"],"execution_count":33,"outputs":[]},{"cell_type":"code","metadata":{"id":"qOYwbjOzK4LV","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615719873669,"user_tz":-60,"elapsed":247767,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"01040341-9e2e-47aa-d64a-bed90732dce1"},"source":["# 0.1 -> 34 min/epoch\n","# 0.01 -> 3.3 min/epoch\n","train_percent = 0.01\n","val_percent = 0.01\n","int(train_percent*np.power(len(train_idx), 2)), int(val_percent*np.power(len(val_idx), 2))"],"execution_count":34,"outputs":[{"output_type":"execute_result","data":{"text/plain":["(63101, 7022)"]},"metadata":{"tags":[]},"execution_count":34}]},{"cell_type":"code","metadata":{"scrolled":true,"id":"8HWI9cfqK4LY","colab":{"base_uri":"https://localhost:8080/","height":1000},"executionInfo":{"status":"ok","timestamp":1615727051901,"user_tz":-60,"elapsed":1198167,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"ed97e1aa-286d-400b-dc4d-ff7a186c51e3"},"source":["model, history1 = train_siamese(X=X, y=y, \n","                               train_idx=train_idx, \n","                               val_idx=val_idx,\n","                               epochs=100,  #500\n","                               batch_size=256,  #512 latest \n","                               learning_rate=1e-3,  #0.01 \n","                                limit_style=\"random\", \n","                                path_logs_training=path_logs_training, \n","                                training_description=training_description,\n","                               training_steps=int(train_percent*np.power(len(train_idx), 2)),  # None\n","                               validation_steps=int(val_percent*np.power(len(val_idx), 2)),  # None\n","                               plot=True,\n","                               gpus=None)"],"execution_count":35,"outputs":[{"output_type":"stream","text":["INFO:tensorflow:Using MirroredStrategy with devices ('/job:localhost/replica:0/task:0/device:GPU:0',)\n","Data created in 6.8153321743011475 sec\n","Data created in 0.7494244575500488 sec\n","Input images shape (116, 116, 1)\n","Model: \"model_1\"\n","__________________________________________________________________________________________________\n","Layer (type)                    Output Shape         Param #     Connected to                     \n","==================================================================================================\n","input_1 (InputLayer)            [(None, 116, 116, 1) 0                                            \n","__________________________________________________________________________________________________\n","input_2 (InputLayer)            [(None, 116, 116, 1) 0                                            \n","__________________________________________________________________________________________________\n","model (Functional)              (None, 8)            4556040     input_1[0][0]                    \n","                                                                 input_2[0][0]                    \n","__________________________________________________________________________________________________\n","lambda (Lambda)                 (None, 1)            0           model[0][0]                      \n","                                                                 model[1][0]                      \n","==================================================================================================\n","Total params: 4,556,040\n","Trainable params: 4,556,040\n","Non-trainable params: 0\n","__________________________________________________________________________________________________\n","INFO:tensorflow:Reduce to /job:localhost/replica:0/task:0/device:CPU:0 then broadcast to ('/job:localhost/replica:0/task:0/device:CPU:0',).\n","INFO:tensorflow:Reduce to /job:localhost/replica:0/task:0/device:CPU:0 then broadcast to ('/job:localhost/replica:0/task:0/device:CPU:0',).\n","INFO:tensorflow:Reduce to /job:localhost/replica:0/task:0/device:CPU:0 then broadcast to ('/job:localhost/replica:0/task:0/device:CPU:0',).\n","INFO:tensorflow:Reduce to /job:localhost/replica:0/task:0/device:CPU:0 then broadcast to ('/job:localhost/replica:0/task:0/device:CPU:0',).\n","WARNING:tensorflow:`period` argument is deprecated. Please use `save_freq` to specify the frequency in number of batches seen.\n","Model will be saved to: /content/drive/My Drive/ModelsProtein/training/5j0n_dim8_de.h5\n","Epoch 1/100\n","INFO:tensorflow:Reduce to /job:localhost/replica:0/task:0/device:CPU:0 then broadcast to ('/job:localhost/replica:0/task:0/device:CPU:0',).\n","INFO:tensorflow:Reduce to /job:localhost/replica:0/task:0/device:CPU:0 then broadcast to ('/job:localhost/replica:0/task:0/device:CPU:0',).\n","INFO:tensorflow:Reduce to /job:localhost/replica:0/task:0/device:CPU:0 then broadcast to ('/job:localhost/replica:0/task:0/device:CPU:0',).\n","INFO:tensorflow:Reduce to /job:localhost/replica:0/task:0/device:CPU:0 then broadcast to ('/job:localhost/replica:0/task:0/device:CPU:0',).\n","INFO:tensorflow:Reduce to /job:localhost/replica:0/task:0/device:CPU:0 then broadcast to ('/job:localhost/replica:0/task:0/device:CPU:0',).\n","INFO:tensorflow:Reduce to /job:localhost/replica:0/task:0/device:CPU:0 then broadcast to ('/job:localhost/replica:0/task:0/device:CPU:0',).\n","247/247 [==============================] - 79s 181ms/step - loss: 1.0132 - mse: 1.6504 - val_loss: 0.6337 - val_mse: 0.6966\n","Epoch 2/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.5939 - mse: 0.6054 - val_loss: 0.5155 - val_mse: 0.4400\n","Epoch 3/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.4431 - mse: 0.3360 - val_loss: 0.3649 - val_mse: 0.2319\n","Epoch 4/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.3535 - mse: 0.2202 - val_loss: 0.3254 - val_mse: 0.1902\n","Epoch 5/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.2994 - mse: 0.1606 - val_loss: 0.3089 - val_mse: 0.1714\n","Epoch 6/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.2696 - mse: 0.1300 - val_loss: 0.2689 - val_mse: 0.1301\n","Epoch 7/100\n","247/247 [==============================] - 41s 166ms/step - loss: 0.2437 - mse: 0.1031 - val_loss: 0.2553 - val_mse: 0.1188\n","Epoch 8/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.2298 - mse: 0.0911 - val_loss: 0.2499 - val_mse: 0.1109\n","Epoch 9/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.2218 - mse: 0.0852 - val_loss: 0.2350 - val_mse: 0.0969\n","Epoch 10/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.2169 - mse: 0.0812 - val_loss: 0.2351 - val_mse: 0.0991\n","Epoch 11/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.2133 - mse: 0.0791 - val_loss: 0.2314 - val_mse: 0.0949\n","Epoch 12/100\n","247/247 [==============================] - 41s 166ms/step - loss: 0.2105 - mse: 0.0771 - val_loss: 0.2336 - val_mse: 0.0978\n","Epoch 13/100\n","247/247 [==============================] - 41s 166ms/step - loss: 0.2076 - mse: 0.0759 - val_loss: 0.2354 - val_mse: 0.0988\n","Epoch 14/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.2069 - mse: 0.0753 - val_loss: 0.2291 - val_mse: 0.0937\n","Epoch 15/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.2060 - mse: 0.0748 - val_loss: 0.2298 - val_mse: 0.0923\n","Epoch 16/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.2033 - mse: 0.0726 - val_loss: 0.2236 - val_mse: 0.0872\n","Epoch 17/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.2031 - mse: 0.0728 - val_loss: 0.2241 - val_mse: 0.0905\n","Epoch 18/100\n","247/247 [==============================] - 41s 166ms/step - loss: 0.2004 - mse: 0.0708 - val_loss: 0.2227 - val_mse: 0.0873\n","Epoch 19/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1997 - mse: 0.0709 - val_loss: 0.2269 - val_mse: 0.0916\n","Epoch 20/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1983 - mse: 0.0695 - val_loss: 0.2234 - val_mse: 0.0876\n","Epoch 21/100\n","247/247 [==============================] - 41s 166ms/step - loss: 0.1974 - mse: 0.0695 - val_loss: 0.2267 - val_mse: 0.0907\n","Epoch 22/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1960 - mse: 0.0683 - val_loss: 0.2260 - val_mse: 0.0902\n","Epoch 23/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1960 - mse: 0.0685 - val_loss: 0.2235 - val_mse: 0.0872\n","Epoch 24/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1949 - mse: 0.0683 - val_loss: 0.2274 - val_mse: 0.0912\n","Epoch 25/100\n","247/247 [==============================] - 41s 166ms/step - loss: 0.1945 - mse: 0.0675 - val_loss: 0.2287 - val_mse: 0.0920\n","Epoch 26/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1944 - mse: 0.0678 - val_loss: 0.2231 - val_mse: 0.0879\n","Epoch 27/100\n","247/247 [==============================] - 41s 166ms/step - loss: 0.1937 - mse: 0.0676 - val_loss: 0.2275 - val_mse: 0.0895\n","Epoch 28/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1931 - mse: 0.0674 - val_loss: 0.2254 - val_mse: 0.0894\n","Epoch 29/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1916 - mse: 0.0662 - val_loss: 0.2241 - val_mse: 0.0871\n","Epoch 30/100\n","247/247 [==============================] - 41s 166ms/step - loss: 0.1912 - mse: 0.0656 - val_loss: 0.2265 - val_mse: 0.0889\n","Epoch 31/100\n","247/247 [==============================] - 41s 166ms/step - loss: 0.1896 - mse: 0.0653 - val_loss: 0.2248 - val_mse: 0.0884\n","Epoch 32/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1899 - mse: 0.0656 - val_loss: 0.2264 - val_mse: 0.0902\n","Epoch 33/100\n","247/247 [==============================] - 41s 166ms/step - loss: 0.1903 - mse: 0.0657 - val_loss: 0.2309 - val_mse: 0.0934\n","Epoch 34/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1900 - mse: 0.0655 - val_loss: 0.2235 - val_mse: 0.0880\n","Epoch 35/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1883 - mse: 0.0649 - val_loss: 0.2268 - val_mse: 0.0905\n","Epoch 36/100\n","247/247 [==============================] - 41s 166ms/step - loss: 0.1882 - mse: 0.0652 - val_loss: 0.2236 - val_mse: 0.0869\n","Epoch 37/100\n","247/247 [==============================] - 41s 166ms/step - loss: 0.1891 - mse: 0.0654 - val_loss: 0.2278 - val_mse: 0.0905\n","Epoch 38/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1878 - mse: 0.0649 - val_loss: 0.2228 - val_mse: 0.0861\n","Epoch 39/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1874 - mse: 0.0647 - val_loss: 0.2233 - val_mse: 0.0858\n","Epoch 40/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1856 - mse: 0.0632 - val_loss: 0.2236 - val_mse: 0.0871\n","Epoch 41/100\n","247/247 [==============================] - 41s 166ms/step - loss: 0.1859 - mse: 0.0637 - val_loss: 0.2273 - val_mse: 0.0907\n","Epoch 42/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1862 - mse: 0.0635 - val_loss: 0.2242 - val_mse: 0.0873\n","Epoch 43/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1854 - mse: 0.0638 - val_loss: 0.2245 - val_mse: 0.0877\n","Epoch 44/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1862 - mse: 0.0642 - val_loss: 0.2251 - val_mse: 0.0885\n","Epoch 45/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1860 - mse: 0.0641 - val_loss: 0.2232 - val_mse: 0.0882\n","Epoch 46/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1846 - mse: 0.0632 - val_loss: 0.2252 - val_mse: 0.0884\n","Epoch 47/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1848 - mse: 0.0637 - val_loss: 0.2230 - val_mse: 0.0876\n","Epoch 48/100\n","247/247 [==============================] - 41s 166ms/step - loss: 0.1828 - mse: 0.0621 - val_loss: 0.2277 - val_mse: 0.0915\n","Epoch 49/100\n","247/247 [==============================] - 41s 166ms/step - loss: 0.1833 - mse: 0.0630 - val_loss: 0.2230 - val_mse: 0.0857\n","Epoch 50/100\n","247/247 [==============================] - 41s 166ms/step - loss: 0.1837 - mse: 0.0628 - val_loss: 0.2241 - val_mse: 0.0873\n","Epoch 51/100\n","247/247 [==============================] - 41s 166ms/step - loss: 0.1837 - mse: 0.0627 - val_loss: 0.2248 - val_mse: 0.0890\n","Epoch 52/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1836 - mse: 0.0632 - val_loss: 0.2251 - val_mse: 0.0882\n","Epoch 53/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1828 - mse: 0.0629 - val_loss: 0.2261 - val_mse: 0.0892\n","Epoch 54/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1824 - mse: 0.0625 - val_loss: 0.2269 - val_mse: 0.0913\n","Epoch 55/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1808 - mse: 0.0622 - val_loss: 0.2255 - val_mse: 0.0887\n","Epoch 56/100\n","247/247 [==============================] - 41s 166ms/step - loss: 0.1824 - mse: 0.0631 - val_loss: 0.2252 - val_mse: 0.0875\n","Epoch 57/100\n","247/247 [==============================] - 41s 166ms/step - loss: 0.1817 - mse: 0.0625 - val_loss: 0.2276 - val_mse: 0.0906\n","Epoch 58/100\n","247/247 [==============================] - 41s 166ms/step - loss: 0.1811 - mse: 0.0622 - val_loss: 0.2241 - val_mse: 0.0876\n","Epoch 59/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1813 - mse: 0.0622 - val_loss: 0.2246 - val_mse: 0.0870\n","Epoch 60/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1805 - mse: 0.0621 - val_loss: 0.2247 - val_mse: 0.0879\n","Epoch 61/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1814 - mse: 0.0625 - val_loss: 0.2255 - val_mse: 0.0884\n","Epoch 62/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1794 - mse: 0.0614 - val_loss: 0.2241 - val_mse: 0.0884\n","Epoch 63/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1808 - mse: 0.0623 - val_loss: 0.2245 - val_mse: 0.0882\n","Epoch 64/100\n","247/247 [==============================] - 41s 166ms/step - loss: 0.1801 - mse: 0.0619 - val_loss: 0.2250 - val_mse: 0.0887\n","Epoch 65/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1804 - mse: 0.0617 - val_loss: 0.2268 - val_mse: 0.0903\n","Epoch 66/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1800 - mse: 0.0616 - val_loss: 0.2242 - val_mse: 0.0879\n","Epoch 67/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1788 - mse: 0.0612 - val_loss: 0.2255 - val_mse: 0.0890\n","Epoch 68/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1803 - mse: 0.0618 - val_loss: 0.2254 - val_mse: 0.0876\n","Epoch 69/100\n","247/247 [==============================] - 41s 166ms/step - loss: 0.1792 - mse: 0.0617 - val_loss: 0.2253 - val_mse: 0.0885\n","Epoch 70/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1786 - mse: 0.0608 - val_loss: 0.2252 - val_mse: 0.0883\n","Epoch 71/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1778 - mse: 0.0606 - val_loss: 0.2254 - val_mse: 0.0882\n","Epoch 72/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1769 - mse: 0.0602 - val_loss: 0.2271 - val_mse: 0.0887\n","Epoch 73/100\n","247/247 [==============================] - 41s 166ms/step - loss: 0.1787 - mse: 0.0608 - val_loss: 0.2266 - val_mse: 0.0895\n","Epoch 74/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1778 - mse: 0.0608 - val_loss: 0.2253 - val_mse: 0.0878\n","Epoch 75/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1783 - mse: 0.0611 - val_loss: 0.2254 - val_mse: 0.0881\n","Epoch 76/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1785 - mse: 0.0615 - val_loss: 0.2253 - val_mse: 0.0886\n","Epoch 77/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1767 - mse: 0.0600 - val_loss: 0.2251 - val_mse: 0.0872\n","Epoch 78/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1776 - mse: 0.0606 - val_loss: 0.2258 - val_mse: 0.0880\n","Epoch 79/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1769 - mse: 0.0606 - val_loss: 0.2261 - val_mse: 0.0890\n","Epoch 80/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1780 - mse: 0.0612 - val_loss: 0.2279 - val_mse: 0.0910\n","Epoch 81/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1775 - mse: 0.0607 - val_loss: 0.2274 - val_mse: 0.0897\n","Epoch 82/100\n","247/247 [==============================] - 41s 166ms/step - loss: 0.1756 - mse: 0.0597 - val_loss: 0.2252 - val_mse: 0.0884\n","Epoch 83/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1773 - mse: 0.0611 - val_loss: 0.2285 - val_mse: 0.0911\n","Epoch 84/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1760 - mse: 0.0600 - val_loss: 0.2280 - val_mse: 0.0908\n","Epoch 85/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1766 - mse: 0.0602 - val_loss: 0.2253 - val_mse: 0.0884\n","Epoch 86/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1782 - mse: 0.0618 - val_loss: 0.2242 - val_mse: 0.0871\n","Epoch 87/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1761 - mse: 0.0601 - val_loss: 0.2255 - val_mse: 0.0877\n","Epoch 88/100\n","247/247 [==============================] - 41s 168ms/step - loss: 0.1774 - mse: 0.0609 - val_loss: 0.2258 - val_mse: 0.0894\n","Epoch 89/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1755 - mse: 0.0599 - val_loss: 0.2253 - val_mse: 0.0880\n","Epoch 90/100\n","247/247 [==============================] - 41s 168ms/step - loss: 0.1759 - mse: 0.0605 - val_loss: 0.2253 - val_mse: 0.0883\n","Epoch 91/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1760 - mse: 0.0602 - val_loss: 0.2262 - val_mse: 0.0881\n","Epoch 92/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1758 - mse: 0.0608 - val_loss: 0.2247 - val_mse: 0.0877\n","Epoch 93/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1754 - mse: 0.0599 - val_loss: 0.2248 - val_mse: 0.0880\n","Epoch 94/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1761 - mse: 0.0606 - val_loss: 0.2250 - val_mse: 0.0887\n","Epoch 95/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1761 - mse: 0.0604 - val_loss: 0.2241 - val_mse: 0.0866\n","Epoch 96/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1760 - mse: 0.0600 - val_loss: 0.2258 - val_mse: 0.0882\n","Epoch 97/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1756 - mse: 0.0603 - val_loss: 0.2258 - val_mse: 0.0891\n","Epoch 98/100\n","247/247 [==============================] - 41s 168ms/step - loss: 0.1756 - mse: 0.0604 - val_loss: 0.2283 - val_mse: 0.0912\n","Epoch 99/100\n","247/247 [==============================] - 41s 168ms/step - loss: 0.1751 - mse: 0.0600 - val_loss: 0.2250 - val_mse: 0.0879\n","Epoch 100/100\n","247/247 [==============================] - 41s 167ms/step - loss: 0.1758 - mse: 0.0607 - val_loss: 0.2264 - val_mse: 0.0888\n"],"name":"stdout"},{"output_type":"display_data","data":{"image/png":"iVBORw0KGgoAAAANSUhEUgAAA38AAAGvCAYAAADrFmyJAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nOzdeXhU9d3//9eZc2YJhN0khK0gCqIg1qoIRVBiC2JCWFRaXNqicN/au1iXW8CFTVuLe8HtJ+0ltXFFotFAab+KlSKLt0sRRcAFC8GwCLIEktl/f0xmTEICA8KcOcnzcV1eV5I5mXlP4sUnr/NZ3kY0Go0KAAAAANCouewuAAAAAABw4hH+AAAAAKAJIPwBAAAAQBNA+AMAAACAJoDwBwAAAABNgGV3AcdLVVWVPv74Y2VlZck0TbvLAQCcQOFwWDt37lTv3r3l8/nsLiftMUYCQNNwpPGx0YS/jz/+WFdeeaXdZQAAUujZZ5/VOeecY3cZaY8xEgCalobGx0YT/rKysiTF3mj79u1trgYAcCJt27ZNV155ZeLffhweYyQANA1HGh8bTfiLL2Np3769OnXqZHM1AIBUYAljchgjAaBpaWh85MAXAAAAAGgCCH8AAAAA0AQ0mmWfANJDMBhUWVmZqqqq7C4FjYDP51OnTp3kdrvtLgUAHCUSieibb77Rnj17FA6H7S4Hx5lpmmrdurVOOukkuVzJz+cR/gAcV2VlZWrRooW6du0qwzDsLgcOFo1GtWvXLpWVlalbt252lwMAjlJWVibDMNS1a1e53W7G5EYkGo0qGAxq+/btKisrU5cuXZL+XpZ9Ajiuqqqq1K5dOwYZfG+GYahdu3bMIgPAMThw4IA6duwoj8fDmNzIGIYhj8ejjh076sCBA0f1vYQ/AMcdgwyOF/5fAoBjdzTLAeE8x/L75f8IAAAAAGgCCH8AGrUhQ4Zo4MCBtTa7FxcXq2fPnioqKqp17f3336/evXtr165dhzzHsGHDVFhYmPivrKys1jULFy5MPHbeeedp0KBBic/XrFmTdL2FhYVJLXOcMGGCNm/enPTzHklZWZn69et33J4PAIC6khmT9+7dq5tvvln5+fkqKChQYWGhVq5cmbj2nHPOqTUeP/DAA4e8zuWXX67CwkINHz5cp59+euLaqVOnJl3r888/r/nz5x/xujfffFOzZ89O+nntxoEvABq97OxsLV++XIMHD5YkvfLKKzrjjDNqXRMOh1VSUqKzzz5bJSUlGj9+fK3H58yZox49ejT4GmPGjNGYMWMkSVOmTFHv3r111VVXHXJdOBw+bGPykpKSpN7TvHnzkroOAIB0cqQx+ZFHHlFOTo4efPBBGYahb7/9VpWVlYnHBwwYoDlz5hz2NRYsWCApdmNzzJgx9Y6toVBIltVwFPr5z3+e1PvJy8tTXl5eUtemA8IfgEZv1KhRKi4u1uDBg7VlyxYdPHjwkCD39ttvq0uXLpo0aZJmzJhxSPg7VsXFxXrttdfUvHlz/ec//9H999+vlStXatGiRQqHw/J6vZoxY4Z69eolSerZs6c++OADNW/eXEOGDFFhYaFWrFihnTt3avz48YlAOWTIED355JPq0aOHrr76avXu3Vv//ve/tWPHDl1yySW69dZbJUmff/65pk6dqsrKSp122mnavHmzrr/+el100UVJ1R8Oh/XAAw/oX//6lyTpggsu0K233irTNPXiiy9q/vz58ng8ikQieuSRR9StWzfNmjVLq1atksfjUbNmzfTCCy8cl58lAMD5jjQmb9u2Tf369Uvs+W7Tpo3atGlzXF57yJAhGj58uFatWqUePXropptu0s0336wDBw7I7/dr8ODBuu222yRJc+fO1cGDBzV58mQVFxertLRULVu21GeffaYWLVpo7ty5ysrKUnFxsf75z39qzpw5Wr16tX7/+9+rb9+++vDDD2UYhh5++GF1795dkvTwww9r8eLFat26tc477zytXLlSxcXFx+W9JYvwB+CEWnvHtEO+dtKPByh3+DCF/X6tm/W7Qx7PHnKhcvKGKLhvn9bPPnQ5R/thQ5V1wY+TruG8887Tc889p7179+qVV17RyJEj9cknn9S6ZuHChRo9erTOOeccBYNBrVmzRn379k08PmnSJHm9Xkmx3jpH84/1mjVrVFJSkjiKOScnJxEuV6xYoenTp+ull16q93urqqr04osvqqysTAUFBRo1apSaN29+yHXl5eV69tlndeDAAV188cW67LLL1LVrV9122236xS9+ocLCQq1du1ZXXHFF0nVL0osvvqhPP/008X4nTJigF198UePGjdN9992nv/3tb8rOzlYgEFA4HNb69eu1evVqLV68WC6XS3v37j2q1wMAnBg7lv5T299cekKeOydviLKHXJjUtUcak6+55hpNmjRJpaWl+uEPf6ghQ4aof//+icdXrFihwsLCxOdXXXWVLr/88qRrraio0MsvvyxJ8vv9evLJJ9W8eXMFg0Fde+21WrZsmQYNGnTI961du1avvfaacnNzdeedd6qoqEg33XTTIdd9/vnnuvfeezVr1iw98cQTevzxx/Xggw9q6dKleuutt1RSUiKfz6dJkyYlXfPxxJ4/AI2eYRi65JJLtGjRIi1atEj5+fm1Ht+1a5feffddDRs2TJI0cuRILVy4sNY1c+bMUUlJiUpKSo76Lt3ZZ59dqwfPxx9/rCuvvFL5+fm699579emnnzb4vcOHD5ckderUSS1bttS2bdvqvW7YsGFyuVxq0aKFunfvrs2bN6uiokIbN25UQUGBJKlPnz7q2bPnUdW+cuVKjRo1Sh6PRx6PR6NHj07svTj//PM1ZcoU/fWvf9X27duVkZGhzp07KxQK6Y477tCrr756VK8FAGj8jjQm9+/fX2+99Zauv/56ud1u/fa3v9VTTz2VeHzAgAGJ8bikpOSogp8UG+PjwuGw7rvvPo0YMUKjR4/WZ599pvXr19f7fWeffbZyc3MlSX379m1w3323bt10+umnS5LOOussbdmyRZK0evVqXXLJJWrWrJlcLletOlKJmT8AJ1Sf381q8DHT6z3s4+6WLQ/7+NEYNWqULr/8cp177rmHLB8pKSlRKBTSiBEjJMX2AVRWVur222+Xz+f73q9dc6YuEAjoxhtvVFFRkc444wxt37693juMcfHZRik241hzk3yy152odgmPPvqo1q5dq1WrVumaa67RjBkzNHjwYC1atEirV6/WihUr9MADD+iVV15RVlbWCakBAJCc7CEXJj07d6IdbkyWpMzMzMReut69e+uJJ57QxIkTj8trN2vWLPHx008/rX379mnBggXyer2666675Pf76/2+ZMdjj8eT+NjlcikUCh2Xuo8XZv4ANAmdO3fWTTfdpBtuuOGQx4qLi/XYY49p6dKlWrp0qZYtW6YzzzxTS5YsOe51BAIBhUKhxN3D55577ri/RlxmZqZOPfVUlZaWSpI++eQTbdy48aieo3///nr11VcVDAYVDAb16quvasCAAQqFQtqyZYvOPPNMTZw4UT/+8Y/16aefavfu3aqsrEzsDWzRokXirifqN3v2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erQ2btyomTNnqrKyUn6/X1dccYV++ctfHvIcc+fO1cGDBzV58mQFAgHdc889WrVqldq0aaNevXolrtuwYUO9z/evf/1LS5cu1YoVK7RgwQL96le/Um5urmbPnq3i4mJJ0quvvqo///nPkqQuXbpo1qxZateunYqLi1VaWqqWLVvqs88+U4sWLTR37lxlZWUd1c+hPoS/GuIzf/T5AxqX8847T88995z27t2rV155RSNHjtQnn3xS65qFCxdq9OjROueccxQMBrVmzRr17ds38fikSZPk9XolxQ7fiP/DXVNhYaHmzp2rvXv3qlWrViouLtbw4cPl8/k0YcIETZ48WZK0YMECPfDAA3r44YcbrDkQCOimm27SAw88oH79+mnx4sV69tlnE4839HzTpk3TmDFjGpxBvOeee3Tqqafqscce044dOzR69GidfvrpiYG3qqpKL774osrKylRQUKBRo0apefPmyfyY9fjjjysSiej111/XgQMHNHbsWPXo0UN9+/bV/PnztXz5cvl8PlVUVMjn8+mtt97SgQMHtHjxYkmxpT5IX7Fln4Q/AN/Pkcbka665RpMmTVJpaal++MMfasiQIerfv3/i8RUrVqiwsDDx+VVXXaXLL7+81mt4PB4VFBRo4cKFuu2221RRUaE33nhDixcvVmZmpubPny+Px6MDBw7o8ssv1wUXXJAIifWJj4uLFi1SKBTSlVdeqU6dOkmSOnbsWO/zXXDBBRoyZIh69+6duJG6evXqxHNu3LhRDzzwgIqLi5Wdna1HHnlEd999tx555BFJsSWir732mnJzc3XnnXeqqKhIN9100/f4yccQ/mowLEvthw9T5ikN//IBJG/IOcnfCTyRDMPQJZdcokWLFmnRokV64YUXag00u3bt0rvvvqvZs2dLkkaOHKmFCxfWCn9HWvYpSe3atdOAAQNUWlqqn//853r11VcTM1nLli3Tc889p4MHDyqUxNK5L7/8UhkZGYn9gMOHD9e0adMSjx/t88WtXLlSU6ZMkRRbejN48GCtXr068d6GDx8uSerUqZNatmypbdu2HXZArPvct99+uwzDUGZmpi699FKtXLlSAwcOVJcuXXTbbbdp4MCBuvDCC5WZmanTTjtNX3zxhWbOnKnzzjtPF154YdLvA6lnmOz5A5zMKWNy//799dZbb2n16tV6//339dvf/lbXXnutJk6cKCm5ZZ+SdNlll+m6667TLbfcor/97W86++yz1b59e33zzTeaMWOGNmzYIMMwtGPHDq1fv/6wY93q1as1cuRIud1uud1ujRgxQh988IGk2E3To32++HMOHjxY2dnZkqSf/exntULt2WefrdzcXEmxrSUrVqw44ntOBuGvBsMw1P2/Jhz5QgCOM2rUKF1++eU699xzD1k+UlJSolAopBEjRkiSQqGQKisrdfvtt8vn8x3V64wZM0aPPvqounbtqszMTPXt21dbt27Vvffeq5dfflmdO3fWBx98oFtvvfWo30N8Cczxer76xGc3pdgMZ90DbI6FaZp66aWX9MEHH2jVqlUaPXq0/vSnP+m0005TaWmpVq1apWXLlunhhx/W66+/XqsGpA/DshQNEv4AfH+HG5MlKTMzU3l5ecrLy1Pv3r31xBNPJMJfsk477TRlZ2dr2bJlWrhwoX7xi19Ikh566CFlZWXpD3/4gyzL0vjx4+X3+4/5vRzv54s7EeOxxGmfh4gEgyz7BBqhzp0766abbtINN9xwyGPFxcV67LHHtHTpUi1dulTLli3TmWeeqSVLlhz16wwaNEg7duzQQw89lDgRs6KiQm63W1lZWYpEInrhhReO+Dwnn3yyqqqqEqd0LlmyRPv27Tvi82VmZqqqqqrB2cD+/fvrpZdekiTt3LlTb7/9ts4///yjfp8NPffChQsVjUZVUVGhxYsXa8CAAaqoqNDu3bt13nnnadKkSerRo4c+++wzbdu2TaZp6uKLL9bUqVO1e/du7dmz57jUguPPZVks+wRwXBxuTH7nnXdUUVEhKXZC57p16xJLLI/WmDFjNHfuXH311VfKy8uTJO3fv1/t27eXZVnauHFjUqdhn3/++YkbxVVVVSotLU08drjny8zM1P79++t9zn79+untt9/Wzp07JUkvvfSSBgwYcEzv82gw81fHe9f9t9r2O1en3PDfdpcC4DgbO3bsIV9bs2aN9uzZc0gAiu8ViB+GUnPPnxTbO9enT59Dns+yLBUWFuovf/mLnnrqKUmxQ1yGDRum4cOHq02bNho8ePARBxuPx6OHHnqo1oEvHTp0OOLztW7dWgUFBSooKFCrVq0OCZp33nmnpk2bpoKCAknSrbfeqlNPPfWwtdRn48aNtU41HTBggO666y7dfffdieceMWKEBg0apG3btuk3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\n","text/plain":["<Figure size 1080x504 with 2 Axes>"]},"metadata":{"tags":[]}}]},{"cell_type":"markdown","metadata":{"id":"fJJKUgcJK4La"},"source":["---"]},{"cell_type":"code","metadata":{"id":"gi9CsCZAK4Ld","executionInfo":{"status":"ok","timestamp":1615727051908,"user_tz":-60,"elapsed":63,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["# data = np.load(f\"{path_logs_training}/losses/{training_description}.npz\")\n","# training_loss, val_loss, mses, val_mses = data[\"arr_0\"], data[\"arr_1\"], data[\"arr_2\"], data[\"arr_3\"]"],"execution_count":36,"outputs":[]},{"cell_type":"code","metadata":{"id":"IIKP9TtBK4Lg","executionInfo":{"status":"ok","timestamp":1615727051909,"user_tz":-60,"elapsed":56,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["# # Get training and test loss histories\n","# fig, (ax1, ax2) = plt.subplots(1, 2, figsize=(15,7))\n","\n","# # Create count of the number of epochs\n","# epoch_count = range(1, len(training_loss) + 1)\n","\n","# # Visualize loss history\n","# ax1.plot(epoch_count, training_loss, 'r--', label='MAE Training Loss')\n","# ax1.plot(epoch_count, val_loss, 'b-', label='MAE Validation Loss')\n","# ax1.legend()\n","# ax1.set_xlabel('Epoch')\n","# ax1.set_ylabel('Loss')\n","\n","# ax2.plot(epoch_count, mses, 'r-', label='MSE Training')\n","# ax2.plot(epoch_count, val_mses, 'b-', label='MSE Validation')\n","# ax2.legend()\n","# ax2.set_xlabel('Epoch')\n","# ax2.set_ylabel('Loss')\n","# plt.show();"],"execution_count":37,"outputs":[]},{"cell_type":"code","metadata":{"id":"4_py9DG4K4Lj","executionInfo":{"status":"ok","timestamp":1615727051909,"user_tz":-60,"elapsed":50,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["# training_loss[-1], val_loss[-1], mses[-1], val_mses[-1]"],"execution_count":38,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"M-kSlYfqK4Lt"},"source":["### (Or) Read model checkpoint"]},{"cell_type":"code","metadata":{"id":"9z7haF6NK4Lu","executionInfo":{"status":"ok","timestamp":1615727051910,"user_tz":-60,"elapsed":47,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["# put correct filename\n","model_filename = f\"{path_logs_training}/training/{training_description}.h5\""],"execution_count":39,"outputs":[]},{"cell_type":"code","metadata":{"id":"Dr9eFsJKK4Lw","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615727051911,"user_tz":-60,"elapsed":43,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"69c867c8-1d42-4a4e-8fdb-f515330523da"},"source":["# Recreate the exact same model, including its weights and the optimizer\n","model = tf.keras.models.load_model(model_filename)\n","\n","# Show the model architecture\n","model.summary()"],"execution_count":40,"outputs":[{"output_type":"stream","text":["Model: \"model_1\"\n","__________________________________________________________________________________________________\n","Layer (type)                    Output Shape         Param #     Connected to                     \n","==================================================================================================\n","input_1 (InputLayer)            [(None, 116, 116, 1) 0                                            \n","__________________________________________________________________________________________________\n","input_2 (InputLayer)            [(None, 116, 116, 1) 0                                            \n","__________________________________________________________________________________________________\n","model (Functional)              (None, 8)            4556040     input_1[0][0]                    \n","                                                                 input_2[0][0]                    \n","__________________________________________________________________________________________________\n","lambda (Lambda)                 (None, 1)            0           model[0][0]                      \n","                                                                 model[1][0]                      \n","==================================================================================================\n","Total params: 4,556,040\n","Trainable params: 4,556,040\n","Non-trainable params: 0\n","__________________________________________________________________________________________________\n"],"name":"stdout"}]},{"cell_type":"markdown","metadata":{"id":"KpIqU8r6K4L2"},"source":["---"]},{"cell_type":"markdown","metadata":{"id":"_KlxFl_eK4L2"},"source":["## dP/dQ plot"]},{"cell_type":"code","metadata":{"id":"Z766GBdvK4L3","executionInfo":{"status":"ok","timestamp":1615727051912,"user_tz":-60,"elapsed":39,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["from cryoem.conversions import d_q, euler2quaternion\n","from cryoem.plots import plot_dP_dQ"],"execution_count":41,"outputs":[]},{"cell_type":"code","metadata":{"id":"RJMjW2KHK4L5","executionInfo":{"status":"ok","timestamp":1615727051912,"user_tz":-60,"elapsed":34,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["def d_p(p1, p2):\n","    p1 = tf.cast(p1, dtype=tf.float32)\n","    p2 = tf.cast(p2, dtype=tf.float32)\n","    return model.predict([p1, p2], batch_size=256)"],"execution_count":42,"outputs":[]},{"cell_type":"code","metadata":{"id":"0YTh5UvmK4L7","executionInfo":{"status":"ok","timestamp":1615727080502,"user_tz":-60,"elapsed":28620,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["# 5:41 with 1024\n","# 5:43     with 256\n","idx1 = list(np.random.choice(test_idx, size=1000))\n","idx2 = list(np.random.choice(test_idx, size=1000))\n","\n","q1_true = euler2quaternion([angles_true[i] for i in idx1])\n","q2_true = euler2quaternion([angles_true[i] for i in idx2])\n","\n","p1 = [X[i] for i in idx1]\n","p2 = [X[i] for i in idx2]\n","\n","dP_values = d_p(p1, p2).T[0]\n","dQ_values = d_q(q1_true, q2_true).numpy()"],"execution_count":43,"outputs":[]},{"cell_type":"code","metadata":{"id":"DBDpCwIZ2foL","executionInfo":{"status":"ok","timestamp":1615727301438,"user_tz":-60,"elapsed":849,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["np.savez(os.path.join(path_logs_training, f\"dPdQ_data_{FEATURE_DIM}d_5j0n\"), dP_values, dQ_values)"],"execution_count":47,"outputs":[]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/","height":882},"id":"k2DXGL622fDq","executionInfo":{"status":"ok","timestamp":1615727307843,"user_tz":-60,"elapsed":3502,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"918f963a-a7c2-4cbd-e05c-b7f69d6cbb91"},"source":["plot_dP_dQ(dP_values, dQ_values)"],"execution_count":48,"outputs":[{"output_type":"display_data","data":{"text/plain":["<Figure size 432x288 with 0 Axes>"]},"metadata":{"tags":[]}},{"output_type":"display_data","data":{"image/png":"iVBORw0KGgoAAAANSUhEUgAAAYkAAAF5CAYAAABqT9akAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nOy9eZxkZ1n3/T37UntVr9PT3ZNJMhNCEsJmBEEg4REUAxFf0EheXx4ISIKyGCBI4EUR4htkU2Qx4IP6qEFBAsSP8GpAEAUDQoKM2SaTmenp6aW6a6+zb88fp7vSPdOdZJKenmRyvv9kuurUWeqk7t+57+v6XZeQJElCRkZGRkbGBoin+gQyMjIyMh67ZCKRkZGRkbEpmUhkZGRkZGxKJhIZGRkZGZuSiURGRkZGxqbIp/oEtgrXddm3bx/Dw8NIknSqTycjIyPjcUEURSwtLXHeeeeh6/px7582IrFv3z5e9apXnerTyMjIyHhc8td//dc84xnPOO7100YkhoeHgfRCx8bGTvHZZGRkZDw+WFhY4FWvetVgDD2W00YkVpeYxsbG2Llz5yk+m4yMjIzHF5st02eB64yMjIyMTclEIiMjIyNjUzKRyMjIyMjYlNMmJvFgBEHA7Owsruue6lPJ2EIkSaJcLjM0NIQoZs87GRkngyeESMzOzlIoFNi1axeCIJzq08nYApIkIQgCFhcXmZ2dZWpq6lSfUkbGackT4vHLdV1qtVomEKcRgiCgqioTExNYlnWqTycj47TlCSESQCYQpynZMlNGxskl+4U9jnnd617HzMzMI/78l770JQ4ePDj4+xvf+AY33HDDVpzao+InP/kJ11xzzak+jYyMDJ4gMYnHK2EYIsub36LPfOYzj2r/N998M5VKhTPOOAOASy65hEsuueRR7XMrOP/88/nwhz+84XsP9Z1kZGRsLdmvbROSJKFnBTh+gKEqFHLKli1Z7d27lze+8Y184xvfwHVdfvu3f5sXvehFg/d+8zd/k29961s897nP5YorruC9733vYMbw2te+lssuuwyAiy++mE9/+tPs2bOHer3O+9//fubm5vA8j5e85CW84Q1vAODAgQN84AMfYGlpCYDXvOY1xHHMvn37eP/738/HPvYxrr32WhYWFvjWt77FH//xHwNw44038tWvfhVIB+53v/vd5HI5Pv7xj3Pw4EF6vR5HjhxhamqKP/qjP8IwjBO61muuuYaDBw8SBAFTU1Ncf/31lEolbrvtNm644Qa+9KUvMTs7yy//8i/z8pe/nP/4j//gla98JZdffvmW3IeMjFVO9Pe+dntdkUEA1w8f9ViRJAndvk+r75LEUC3pFHPqcfs7mePTsWQisQFJknB4vku95QxeG6kYTI8Xt+xGiKLIV77yFe6//34uv/xynvGMZ1Cr1QDQNI2///u/B+Atb3kLZ599Np/4xCeo1+u8/OUv59xzz2XPnj3r9nfttddy9dVX88xnPhPf93n1q1/N+eefz0UXXcTVV1/NW97yFn7+538egFarRaVS4ctf/jKvec1reMELXgCky0+rfPvb3+arX/0qn//858nlclx77bV88pOf5O1vfzuQFlT84he/SKFQ4LWvfS233HILr3zlK0/oWq+77jqq1SoAH/3oR/nMZz7D2972tuM+3263Of/887n22msfzVeekbEhJ/p7X799QtfycbyQkYqJIAgP+dnNBvckSTg81+G+ox0WGzYJUMqrnL+7xvSO0vrtTvL4tJZMJDagZwXrbgBAveVQLRoU8+qWHOMVr3gFALt37+bcc8/ljjvuGCz1/NIv/dJgu+9973u8853vBGBkZITnPe953HbbbetEwrZtvv/979NsNgevWZbFgQMHGBkZIQzDgUAAVCqVhzy/733ve/zCL/wC+XwegFe+8pVcf/31g/ef85znUCwWAbjgggseNDay2bV+5Stf4ZZbbiEIAmzbZteuXRt+XtO0deefkbGVnOjvfe32ccxgQC+YKqaubPrZhxrce1bAQtMZ7A+g0/c5tNCjWjIH+9uO8WktmUhsgOMHm75eZOtvwrGYpnlC28dxjCAIfPGLX0RRlHXv7d+/fytPbYCmaYN/S5KE53kn9Pn//M//5KabbuLzn/881WqVW265hb/7u7/bcFvDMLLstIyTxon+3tdu7wXRYED3gghTVzb97EMN7o4frNvf2mOs3d92j09ZdtMGGKpyQq8/ElaXkw4dOsSdd97JhRdeuOF2z3rWswaD59LSEt/+9rf56Z/+6XXb5PN5nv70p3PjjTcOXpufn2dpaYkzzjgDWZb52te+Nniv1WoBkMvl6PV6mx73a1/7Gv1+nyRJ+OIXv8izn/3sLbvWbrdLPp+nXC7j+/5gm4yM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SLz++uvMmjWLtrY2SktL+d3vfsfUqVOHullCCDGijMog8Yc//IGLL76YSCTChAkTWLduHZMnTx7qZgkhxIiTtzWJrVu3snDhQnw+H4WFhVRXVzNx4sSca1KpFEuWLOGtt95CURQuv/xyzjnnnAH9nHPPPZft27djGAZHHHEEa9asoby8fBDvRAghDhx5G0ksXryY2bNn8/LLLzN79mxuu+22Ltc8//zz1NTUsGHDBn7729+yfPlydu7cOaCfkwkQhx56KM8884wECCGE2Ad5CRLNzc1s2rSJGTNmADBjxgw2bdpES0tLznXr16/nnHPOQVVVioqKmDZtGi+99NKAf57X66W0tBSv1zso7RdCiANVXoJEXV0dZWVl2dxIJpOJ0tJS6urqulw3duzY7OcVFRXU19cP6GeNGTOGyspKampq9r3hQghxgBt1C9clJSVEIhHGjx8/1E0RQogRLy9BoqKigoaGBlKpFJBeoG5sbKSioqLLdbt27cp+XldXN+A1hXA4TDwe58orr9z3hgshxAEuL0GiuLiYyZMn88ILLwDwwgsvMHnyZIqKinKumz59OmvXrkXXdVpaWnj11Vc5/fTTB/SzxowZw913383JJ588aO0XQogDVd62wN5+++0sXLiQFStW4PF4qK6uBmDOnDnMmzePKVOmMHPmTD788ENOO+00AK666qoBTxs98sgjVFZWDnr7hRDiQJS3IHHwwQezdu3aLl9fuXJl9mOTycQdd9yRryYJIYTow6hbuBZCCDF4JEgIIYTokQQJIYQQPZIgIYQQokcSJIQQQvRIgoQQQogeSZAQQgjRIwkSQgghepS3w3T7WyYv1ECzxgohxIEs02dm+tDORk2QaGpqAuD8888f4pYIIcTI09TURFVVVZevK4ZhGEPQnkEXjUb517/+RUlJSbZuhRBCiN6lUimampo48sgjsdlsXb4/aoKEEEKIwScL10IIIXokQUIIIUSPJEgIIYTokQQJIYQQPZIgIYQQokcSJIQQQvRIgoQQQogejbgT11u3bmXhwoX4fD4KCwuprq5m4sSJOdekUimWLFnCW2+9haIoXH755ZxzzjlD0+Be9Odeli9fzpNPPklpaSkAxx57LIsXLx6C1vasurqal19+mdraWp5//nkOO+ywLteMlN9Jf+5lJPxOWltbuemmm6ipqcFisVBVVcWdd95JUVFRznWRSISbb76ZjRs3YjKZWLBgASeddNIQtbp7/b2XhQsX8u677+L1egGYPn06V1555VA0uVdz585l586dqKqKw+Hg1ltvZfLkyTnXDKu/F2OEufDCC41169YZhmEY69atMy688MIu1zz33HPG97//fSOVShnNzc3GCSecYOzYsSPfTe1Tf+7loYceMu699958N21A3n//fWPXrl3GSSedZGzevLnba0bK76Q/9zISfietra3GX/7yl+zn9957r3HzzTd3uW758uXGokWLDMMwjK1btxrHHXecEQwG89bO/ujvvSxYsMD49a9/nc+m7RW/35/9+JVXXjHOPPPMLtcMp7+XETXd1NzczKZNm5gxYwYAM2bMYNOmTbS0tORct379es455xxUVaWoqIhp06bx0ksvDUWTe9TfexkJpk6dSkVFRa/XjITfCfTvXkaCwsJCvvKVr2Q/P/roo9m1a1eX6/74xz9y7rnnAjBx4kSOPPJI3nzzzby1sz/6ey8jhdvtzn4cDAZRFKXLNcPp72VETTfV1dVRVlaWzc1kMpkoLS2lrq4uZ+hZV1fH2LFjs59XVFQMu+yw/b0XgBdffJG3336bkpISrrnmGo455pihaPI+GQm/k4EYSb8TXdd56qmnOPnkk7t8b9euXYwbNy77+XD/vfR2LwC//OUv+e1vf8v48eOZP38+Bx98cJ5b2D+LFi3inXfewTAMVq1a1eX7w+nvZUQFiQPReeedxxVXXIGmabzzzjvMnTuX9evXZ+ddRf6NtN/JXXfdhcPh4IILLhjqpuyz3u7l+uuvp6SkBFVVWbduHZdddhmvvvrqsEz4effddwOwbt06li5dysqVK4e4RT0bUdNNFRUVNDQ0ZPOep1IpGhsbu0wPVFRU5AxH6+rqKC8vz2tb+9LfeykpKUHTNACOP/54Kioq2LJlS97bu69Gwu+kv0bS76S6uprt27fzwAMPoKpd/9zHjh1LbW1t9vPh/Hvp617KysqyXz/zzDMJh8PDelQE6Xb+9a9/pbW1Nefrw+nvZUQFieLiYiZPnswLL7wAwAsvvMDkyZO7TM9Mnz6dtWvXous6LS0tvPrqq5x++ulD0eQe9fdeGhoash9/8skn1NbWctBBB+W1rYNhJPxO+muk/E6WLVvGv/71Lx555BEsFku310yfPp3f/va3AGzbto2PP/6YE044IZ/N7Jf+3EvH38tbb72FqqqUlZXlq4n9EgqFqKury37+2muvUVBQQGFhYc51w+nvZcSlCv/ss89YuHAhfr8fj8dDdXU1kyZNYs6cOcybN48pU6aQSqW48847eeeddwCYM2dOdnFuOOnPvSxYsICNGzeiqiqapjFv3jy+/vWvD3XTcyxZsoQNGzawe/duvF4vhYWFvPjiiyPyd9KfexkJv5MtW7YwY8YMJk6cmK0RUFlZySOPPMLMmTP5xS9+QVlZGeFwmIULF/LJJ5+gqio33ngj06ZNG+LW5+rvvVx88cU0NzejKAoul4ubbrqJo48+eohbn2v37t3MnTuXSCSCqqoUFBSwYMEC/uu//mvY/r2MuCAhhBAif0bUdJMQQoj8kiAhhBCiRxIkhBBC9EiChBBCiB5JkBBCCNEjCRJCCCF6JEFCiEG2cOFC7r///qFuhhCDQoKEEEPA7/ezePFijj/+eI466ijOOOMMnnvuuaFulhBdSII/IfIsHo9z8cUXU1xczNNPP015eTl//vOfWbhwIYFAgIsuumiomyhElowkhNhHmzZt4jvf+Q7HHHMM1113HbFYrNfrf//731NXV8eDDz7I+PHj0TSNE088kR/96Ec88MADhEKhPLVciL5JkBBiH8Tjca666ipmzpzJe++9x/Tp09mwYUOvr3n33Xc58cQTcTgcOV8/7bTTiEaj/POf/9yfTRZiQCRICLEPPvzwQxKJBN/73vfQNI3p06czZcqUXl/T2tpKSUlJl6+bzWa8Xu+IrE4oRi8JEkLsg8bGRsrKynJKUHasKNYdr9dLU1NTl68nk0laW1uHbfEicWCSICHEPigpKaGhoYGOyZT7qr983HHH8eabbxIOh3O+vmHDBjRN46ijjtovbRVib0iQEGIfHH300ZjNZp544gkSiQQbNmzg448/7vU1M2fOpLy8nGuvvZadO3eSSCR46623WLJkCZdeeilutztPrReib1JPQoh99PHHH3Prrbeyffv2bPGhqqoqrr/++h5f4/P5WLZsGa+++io+n49UKsUNN9zAnDlzui3NKcRQkSAhxBBLJBLMmTOHsrIy7r333pz1DSGGmjyyCDHENE1j+fLljB8/ns8//3yomyNEDhlJCLEfPProo/z85z/v8vUvfelLrFq1aghaJMTekSAhhBCiRzLdJIQQokcSJIQQQvRIgoQQQogeSZAQQgjRIwkSQgghevT/AfLKVpr99VW5AAAAAElFTkSuQmCC\n","text/plain":["<Figure size 432x432 with 1 Axes>"]},"metadata":{"tags":[]}},{"output_type":"display_data","data":{"text/plain":["<Figure size 432x288 with 0 Axes>"]},"metadata":{"tags":[]}},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x432 with 3 Axes>"]},"metadata":{"tags":[]}},{"output_type":"stream","text":["Variance = 0.2985644842881027\n","Min. angle recovery loss possible = 0.08905161052694253\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"0OitAYxm2eaD","executionInfo":{"status":"ok","timestamp":1615727309878,"user_tz":-60,"elapsed":785,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"8bd8ae87-49d6-42fc-96fe-47ddf05b799f"},"source":["MAE(dQ_values, dP_values)"],"execution_count":49,"outputs":[{"output_type":"execute_result","data":{"text/plain":["<tf.Tensor: shape=(), dtype=float32, numpy=0.22804998>"]},"metadata":{"tags":[]},"execution_count":49}]},{"cell_type":"code","metadata":{"id":"rGC2BjfxVYqF","executionInfo":{"status":"ok","timestamp":1615727082642,"user_tz":-60,"elapsed":21,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":[""],"execution_count":46,"outputs":[]}]}