{"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_dim256.ipynb","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":[],"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":1615718385367,"user_tz":-60,"elapsed":1064,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"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":1615718416169,"user_tz":-60,"elapsed":31854,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"d2ef1932-57ec-48ab-abbf-bd2fc4076432"},"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 10:39:45--  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   261MB/s    in 0.3s    \n","\n","2021-03-14 10:39:45 (261 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\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":1615718454922,"user_tz":-60,"elapsed":70600,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"f6bbdd20-c0d7-447a-b85a-9c2b1ba76571"},"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":1615718486555,"user_tz":-60,"elapsed":102225,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"5f2706de-3b55-41fd-9ec9-9b00ec577e54"},"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 | 37.78 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":1615718592692,"user_tz":-60,"elapsed":208354,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"efb71b6c-4af8-4e9d-acd0-2ac99b78f6c9"},"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 9.2 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 15.5 MB/s \n","\u001b[?25hRequirement already satisfied: numpy>=1.15.4 in /usr/local/lib/python3.8/site-packages (from tensorflow-graphics) (1.18.1)\n","Collecting 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 22 kB/s \n","\u001b[?25hCollecting absl-py>=0.6.1\n","  Downloading absl_py-0.12.0-py3-none-any.whl (129 kB)\n","\u001b[K     |████████████████████████████████| 129 kB 75.7 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 70.8 MB/s \n","\u001b[?25hCollecting trimesh>=2.37.22\n","  Downloading trimesh-3.9.8-py3-none-any.whl (629 kB)\n","\u001b[K     |████████████████████████████████| 629 kB 70.3 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: networkx in /usr/local/lib/python3.8/site-packages (from tensorflow-graphics) (2.5)\n","Collecting 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 psutil>=5.7.0\n","  Downloading psutil-5.8.0-cp38-cp38-manylinux2010_x86_64.whl (296 kB)\n","\u001b[K     |████████████████████████████████| 296 kB 82.1 MB/s \n","\u001b[?25hRequirement already satisfied: scipy>=1.1.0 in /usr/local/lib/python3.8/site-packages (from tensorflow-graphics) (1.5.3)\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 tensorboard~=2.4\n","  Downloading tensorboard-2.4.1-py3-none-any.whl (10.6 MB)\n","\u001b[K     |████████████████████████████████| 10.6 MB 61.0 MB/s \n","\u001b[?25hCollecting 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 64.2 MB/s \n","\u001b[?25hCollecting typing-extensions~=3.7.4\n","  Downloading typing_extensions-3.7.4.3-py3-none-any.whl (22 kB)\n","Collecting wrapt~=1.12.1\n","  Downloading wrapt-1.12.1.tar.gz (27 kB)\n","Requirement 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 opt-einsum~=3.3.0\n","  Downloading opt_einsum-3.3.0-py3-none-any.whl (65 kB)\n","\u001b[K     |████████████████████████████████| 65 kB 5.1 MB/s \n","\u001b[?25hCollecting astunparse~=1.6.3\n","  Downloading astunparse-1.6.3-py2.py3-none-any.whl (12 kB)\n","Collecting 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 74.5 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 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 61.0 MB/s \n","\u001b[?25hCollecting flatbuffers~=1.12.0\n","  Downloading flatbuffers-1.12-py2.py3-none-any.whl (15 kB)\n","Collecting 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.5 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.1 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 5.9 MB/s \n","\u001b[?25hRequirement 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 importlib-resources; python_version < \"3.9\"\n","  Downloading importlib_resources-5.1.2-py3-none-any.whl (25 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","Collecting dill\n","  Downloading dill-0.3.3-py2.py3-none-any.whl (81 kB)\n","\u001b[K     |████████████████████████████████| 81 kB 12.8 MB/s \n","\u001b[?25hCollecting promise\n","  Downloading promise-2.3.tar.gz (19 kB)\n","Collecting future\n","  Downloading future-0.18.2.tar.gz (829 kB)\n","\u001b[K     |████████████████████████████████| 829 kB 58.9 MB/s \n","\u001b[?25hRequirement already satisfied: setuptools in /usr/local/lib/python3.8/site-packages (from trimesh>=2.37.22->tensorflow-graphics) (50.3.1.post20201107)\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: 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: 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: kiwisolver>=1.0.1 in /usr/local/lib/python3.8/site-packages (from matplotlib>=2.2.5->tensorflow-graphics) (1.3.1)\n","Collecting markdown>=2.6.8\n","  Downloading Markdown-3.3.4-py3-none-any.whl (97 kB)\n","\u001b[K     |████████████████████████████████| 97 kB 7.4 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 61.2 MB/s \n","\u001b[?25hCollecting werkzeug>=0.11.15\n","  Downloading Werkzeug-1.0.1-py2.py3-none-any.whl (298 kB)\n","\u001b[K     |████████████████████████████████| 298 kB 83.3 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 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 78.1 MB/s \n","\u001b[?25hCollecting 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 80.8 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: 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","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","Collecting requests-oauthlib>=0.7.0\n","  Downloading requests_oauthlib-1.3.0-py2.py3-none-any.whl (23 kB)\n","Collecting cachetools<5.0,>=2.0.0\n","  Downloading cachetools-4.2.1-py3-none-any.whl (12 kB)\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 72.4 MB/s \n","\u001b[?25hCollecting rsa<5,>=3.1.4; python_version >= \"3.6\"\n","  Downloading rsa-4.7.2-py3-none-any.whl (34 kB)\n","Collecting oauthlib>=3.0.0\n","  Downloading oauthlib-3.1.0-py2.py3-none-any.whl (147 kB)\n","\u001b[K     |████████████████████████████████| 147 kB 84.4 MB/s \n","\u001b[?25hCollecting 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.6 MB/s \n","\u001b[?25hBuilding wheels for collected packages: OpenEXR, termcolor, wrapt, promise, future\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=209614 sha256=5e83bfc35d730557ff9323331d0baf0a550b59e8d9d63f1635460bb323bc67b8\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=07ed073078a5dd8967262458322e8292d0cc52e3a83cd0b8b216bf4cb89fa50f\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=78016 sha256=136d6bd44e911a2800a3d7f3c3a20b18bf41549235890ec102f0f66b15cb4243\n","  Stored in directory: /root/.cache/pip/wheels/5f/fd/9e/b6cf5890494cb8ef0b5eaff72e5d55a70fb56316007d6dfe73\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=1dfd3cab9b298670296ab765d3198d20a4b6bff7fa08a0e3fd721c25d8a2a604\n","  Stored in directory: /root/.cache/pip/wheels/54/aa/01/724885182f93150035a2a91bce34a12877e8067a97baaf5dc8\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=63dee89711ea95d27aba10dc910c7ea290c82c61b3cda7c72aa97ff7444e3b9b\n","  Stored in directory: /root/.cache/pip/wheels/8e/70/28/3d6ccd6e315f65f245da085482a2e1c7d14b90b30f239e2cf4\n","Successfully built OpenEXR termcolor wrapt promise future\n","Installing collected packages: h5py, markdown, grpcio, tensorboard-plugin-wit, werkzeug, cachetools, pyasn1, pyasn1-modules, rsa, google-auth, oauthlib, requests-oauthlib, google-auth-oauthlib, protobuf, absl-py, tensorboard, termcolor, typing-extensions, wrapt, opt-einsum, astunparse, tensorflow-estimator, gast, flatbuffers, keras-preprocessing, google-pasta, tensorflow, googleapis-common-protos, tensorflow-metadata, importlib-resources, dill, promise, future, tensorflow-datasets, trimesh, OpenEXR, psutil, 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":1615718592693,"user_tz":-60,"elapsed":208352,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"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":1615718592694,"user_tz":-60,"elapsed":208346,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"55c3181b-73ef-430f-c256-6522e39bdf81"},"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":1615718597379,"user_tz":-60,"elapsed":213029,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"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":1615718597383,"user_tz":-60,"elapsed":213025,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"566cc330-7f3c-4001-8128-ec43318e8fdc"},"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":1615718602350,"user_tz":-60,"elapsed":217984,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"0180acd5-f011-49ec-d075-e1e92d7689df"},"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: 6700211141866393905\n",", name: \"/device:GPU:0\"\n","device_type: \"GPU\"\n","memory_limit: 14674281152\n","locality {\n","  bus_id: 1\n","  links {\n","  }\n","}\n","incarnation: 16218470580965240779\n","physical_device_desc: \"device: 0, name: Tesla T4, pci bus id: 0000:00:04.0, compute capability: 7.5\"\n","]\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"kZFVlYW4K4Ke","executionInfo":{"status":"ok","timestamp":1615718602353,"user_tz":-60,"elapsed":217985,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["PROTEIN=\"5j0n\"\n","NUM_PROJECTIONS = 5000\n","\n","NOISY_VAR = 0 # vary from 1 to 10\n","TRANSLATION = 0.1\n","FEATURE_DIM = 256\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":1615718602760,"user_tz":-60,"elapsed":218385,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"e1b7ebef-3283-4574-e4a6-b8099e32f711"},"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":1615718602761,"user_tz":-60,"elapsed":218378,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"4420aacb-f6c9-4779-c0cc-55261b4c4f49"},"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":1615718603151,"user_tz":-60,"elapsed":218760,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"9d1e19fe-0cd5-42bd-a6f7-14cd112a5410"},"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":1615718603152,"user_tz":-60,"elapsed":218759,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"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":1615718603153,"user_tz":-60,"elapsed":218758,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"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":1615718608200,"user_tz":-60,"elapsed":223803,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"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":1615718608201,"user_tz":-60,"elapsed":223795,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"5aa9481c-7008-4b04-9667-513bb3137a97"},"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":1615718608202,"user_tz":-60,"elapsed":223764,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"62a29edd-5074-40e1-f9bd-996b43f0d0fc"},"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":1615718608203,"user_tz":-60,"elapsed":223636,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"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":1615718608204,"user_tz":-60,"elapsed":223210,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"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":1615718608204,"user_tz":-60,"elapsed":222558,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["from sklearn.model_selection import train_test_split"],"execution_count":22,"outputs":[]},{"cell_type":"code","metadata":{"id":"O_lxJ3huK4K0","executionInfo":{"status":"ok","timestamp":1615718608205,"user_tz":-60,"elapsed":222242,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"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":1615718608205,"user_tz":-60,"elapsed":221892,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"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":1615718608992,"user_tz":-60,"elapsed":222287,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"7c12eb70-8a6f-4c66-ad1a-473f84fc9404"},"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":1615718608994,"user_tz":-60,"elapsed":221989,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"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":1615718608995,"user_tz":-60,"elapsed":221687,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"f690f9bc-4f27-4395-8dae-6d82dc6fc76e"},"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":1615718609410,"user_tz":-60,"elapsed":221603,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"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":1615718609411,"user_tz":-60,"elapsed":221096,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"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":1615718609412,"user_tz":-60,"elapsed":220659,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"3ed1a64c-c8eb-45f4-e515-7627715cdf87"},"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":1615718609413,"user_tz":-60,"elapsed":219248,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["from time import time"],"execution_count":31,"outputs":[]},{"cell_type":"code","metadata":{"id":"hqkn_ZVBK4LQ","executionInfo":{"status":"ok","timestamp":1615718609413,"user_tz":-60,"elapsed":218575,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"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":1615718610826,"user_tz":-60,"elapsed":218713,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"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":1615718610827,"user_tz":-60,"elapsed":217936,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"d843dc40-2160-4322-eed3-9cb37172a8dd"},"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/"},"outputId":"9bc513a3-1ef6-4660-96bc-b5f5e5b1b6ae"},"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":null,"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.819724798202515 sec\n","Data created in 0.7608637809753418 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, 256)          4683264     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,683,264\n","Trainable params: 4,683,264\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_dim256_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 [==============================] - 123s 341ms/step - loss: 0.9018 - mse: 1.3373 - val_loss: 0.5750 - val_mse: 0.5525\n","Epoch 2/100\n","247/247 [==============================] - 79s 319ms/step - loss: 0.5366 - mse: 0.4698 - val_loss: 0.4843 - val_mse: 0.3840\n","Epoch 3/100\n","247/247 [==============================] - 80s 323ms/step - loss: 0.4205 - mse: 0.2974 - val_loss: 0.3845 - val_mse: 0.2507\n","Epoch 4/100\n","247/247 [==============================] - 80s 325ms/step - loss: 0.3473 - mse: 0.2065 - val_loss: 0.3237 - val_mse: 0.1810\n","Epoch 5/100\n","247/247 [==============================] - 80s 325ms/step - loss: 0.2857 - mse: 0.1388 - val_loss: 0.2844 - val_mse: 0.1356\n","Epoch 6/100\n","247/247 [==============================] - 80s 325ms/step - loss: 0.2490 - mse: 0.1022 - val_loss: 0.2549 - val_mse: 0.1093\n","Epoch 7/100\n","247/247 [==============================] - 80s 325ms/step - loss: 0.2182 - mse: 0.0749 - val_loss: 0.2315 - val_mse: 0.0860\n","Epoch 8/100\n","247/247 [==============================] - 80s 325ms/step - loss: 0.2029 - mse: 0.0629 - val_loss: 0.2302 - val_mse: 0.0882\n","Epoch 9/100\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1958 - mse: 0.0585 - val_loss: 0.2148 - val_mse: 0.0725\n","Epoch 10/100\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1907 - mse: 0.0553 - val_loss: 0.2174 - val_mse: 0.0756\n","Epoch 11/100\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1869 - mse: 0.0530 - val_loss: 0.2097 - val_mse: 0.0690\n","Epoch 12/100\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1841 - mse: 0.0516 - val_loss: 0.2114 - val_mse: 0.0720\n","Epoch 13/100\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1812 - mse: 0.0503 - val_loss: 0.2097 - val_mse: 0.0715\n","Epoch 14/100\n","247/247 [==============================] - 80s 326ms/step - loss: 0.1801 - mse: 0.0495 - val_loss: 0.2033 - val_mse: 0.0656\n","Epoch 15/100\n","247/247 [==============================] - 80s 326ms/step - loss: 0.1793 - mse: 0.0492 - val_loss: 0.2027 - val_mse: 0.0650\n","Epoch 16/100\n","247/247 [==============================] - 80s 326ms/step - loss: 0.1776 - mse: 0.0483 - val_loss: 0.2057 - val_mse: 0.0660\n","Epoch 17/100\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1763 - mse: 0.0476 - val_loss: 0.1996 - val_mse: 0.0633\n","Epoch 18/100\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1756 - mse: 0.0474 - val_loss: 0.2038 - val_mse: 0.0669\n","Epoch 19/100\n","247/247 [==============================] - 80s 326ms/step - loss: 0.1739 - mse: 0.0466 - val_loss: 0.2027 - val_mse: 0.0665\n","Epoch 20/100\n","247/247 [==============================] - 81s 326ms/step - loss: 0.1726 - mse: 0.0461 - val_loss: 0.2005 - val_mse: 0.0629\n","Epoch 21/100\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1738 - mse: 0.0465 - val_loss: 0.2000 - val_mse: 0.0624\n","Epoch 22/100\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1721 - mse: 0.0459 - val_loss: 0.2069 - val_mse: 0.0679\n","Epoch 23/100\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1712 - mse: 0.0455 - val_loss: 0.2038 - val_mse: 0.0668\n","Epoch 24/100\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1694 - mse: 0.0447 - val_loss: 0.2007 - val_mse: 0.0647\n","Epoch 25/100\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1687 - mse: 0.0444 - val_loss: 0.2006 - val_mse: 0.0632\n","Epoch 26/100\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1687 - mse: 0.0442 - val_loss: 0.1998 - val_mse: 0.0631\n","Epoch 27/100\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1680 - mse: 0.0441 - val_loss: 0.2016 - val_mse: 0.0636\n","Epoch 28/100\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1679 - mse: 0.0440 - val_loss: 0.2016 - val_mse: 0.0635\n","Epoch 29/100\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1683 - mse: 0.0442 - val_loss: 0.2023 - val_mse: 0.0650\n","Epoch 30/100\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1667 - mse: 0.0436 - val_loss: 0.1988 - val_mse: 0.0635\n","Epoch 31/100\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1664 - mse: 0.0434 - val_loss: 0.1985 - val_mse: 0.0614\n","Epoch 32/100\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1657 - mse: 0.0433 - val_loss: 0.2027 - val_mse: 0.0645\n","Epoch 33/100\n","247/247 [==============================] - 80s 326ms/step - loss: 0.1649 - mse: 0.0427 - val_loss: 0.1999 - val_mse: 0.0630\n","Epoch 34/100\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1639 - mse: 0.0426 - val_loss: 0.1977 - val_mse: 0.0605\n","Epoch 35/100\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1642 - mse: 0.0426 - val_loss: 0.1986 - val_mse: 0.0621\n","Epoch 36/100\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1628 - mse: 0.0422 - val_loss: 0.2001 - val_mse: 0.0621\n","Epoch 37/100\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1642 - mse: 0.0428 - val_loss: 0.1987 - val_mse: 0.0620\n","Epoch 38/100\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1621 - mse: 0.0418 - val_loss: 0.2014 - val_mse: 0.0642\n","Epoch 39/100\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1627 - mse: 0.0422 - val_loss: 0.1984 - val_mse: 0.0613\n","Epoch 40/100\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1627 - mse: 0.0419 - val_loss: 0.1984 - val_mse: 0.0613\n","Epoch 41/100\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1609 - mse: 0.0415 - val_loss: 0.2026 - val_mse: 0.0656\n","Epoch 42/100\n","247/247 [==============================] - 81s 326ms/step - loss: 0.1615 - mse: 0.0418 - val_loss: 0.2006 - val_mse: 0.0630\n","Epoch 43/100\n","247/247 [==============================] - 81s 328ms/step - loss: 0.1612 - mse: 0.0416 - val_loss: 0.2013 - val_mse: 0.0634\n","Epoch 44/100\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1613 - mse: 0.0417 - val_loss: 0.1991 - val_mse: 0.0611\n","Epoch 45/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1608 - mse: 0.0415 - val_loss: 0.1983 - val_mse: 0.0618\n","Epoch 46/100\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1605 - mse: 0.0414 - val_loss: 0.1995 - val_mse: 0.0620\n","Epoch 47/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1600 - mse: 0.0413 - val_loss: 0.2000 - val_mse: 0.0623\n","Epoch 48/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1597 - mse: 0.0412 - val_loss: 0.1996 - val_mse: 0.0627\n","Epoch 49/100\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1602 - mse: 0.0416 - val_loss: 0.1999 - val_mse: 0.0614\n","Epoch 50/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1587 - mse: 0.0406 - val_loss: 0.2002 - val_mse: 0.0621\n","Epoch 51/100\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1597 - mse: 0.0413 - val_loss: 0.2012 - val_mse: 0.0642\n","Epoch 52/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1589 - mse: 0.0411 - val_loss: 0.1995 - val_mse: 0.0610\n","Epoch 53/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1576 - mse: 0.0404 - val_loss: 0.2010 - val_mse: 0.0616\n","Epoch 54/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1583 - mse: 0.0405 - val_loss: 0.2004 - val_mse: 0.0622\n","Epoch 55/100\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1578 - mse: 0.0406 - val_loss: 0.2002 - val_mse: 0.0626\n","Epoch 56/100\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1577 - mse: 0.0404 - val_loss: 0.1995 - val_mse: 0.0622\n","Epoch 57/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1575 - mse: 0.0403 - val_loss: 0.1999 - val_mse: 0.0624\n","Epoch 58/100\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1573 - mse: 0.0405 - val_loss: 0.1987 - val_mse: 0.0613\n","Epoch 59/100\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1576 - mse: 0.0404 - val_loss: 0.2006 - val_mse: 0.0635\n","Epoch 60/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1573 - mse: 0.0407 - val_loss: 0.1992 - val_mse: 0.0627\n","Epoch 61/100\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1567 - mse: 0.0402 - val_loss: 0.2000 - val_mse: 0.0615\n","Epoch 62/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1561 - mse: 0.0399 - val_loss: 0.1993 - val_mse: 0.0625\n","Epoch 63/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1567 - mse: 0.0403 - val_loss: 0.2010 - val_mse: 0.0621\n","Epoch 64/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1568 - mse: 0.0404 - val_loss: 0.1993 - val_mse: 0.0618\n","Epoch 65/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1568 - mse: 0.0404 - val_loss: 0.2001 - val_mse: 0.0626\n","Epoch 66/100\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1560 - mse: 0.0403 - val_loss: 0.2001 - val_mse: 0.0630\n","Epoch 67/100\n","247/247 [==============================] - 82s 332ms/step - loss: 0.1560 - mse: 0.0400 - val_loss: 0.2003 - val_mse: 0.0627\n","Epoch 68/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1546 - mse: 0.0396 - val_loss: 0.2012 - val_mse: 0.0612\n","Epoch 69/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1553 - mse: 0.0398 - val_loss: 0.2001 - val_mse: 0.0619\n","Epoch 70/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1537 - mse: 0.0392 - val_loss: 0.1990 - val_mse: 0.0617\n","Epoch 71/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1542 - mse: 0.0392 - val_loss: 0.2003 - val_mse: 0.0625\n","Epoch 72/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1540 - mse: 0.0395 - val_loss: 0.2001 - val_mse: 0.0629\n","Epoch 73/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1546 - mse: 0.0395 - val_loss: 0.2011 - val_mse: 0.0632\n","Epoch 74/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1552 - mse: 0.0400 - val_loss: 0.2001 - val_mse: 0.0615\n","Epoch 75/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1533 - mse: 0.0392 - val_loss: 0.1990 - val_mse: 0.0613\n","Epoch 76/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1542 - mse: 0.0394 - val_loss: 0.2013 - val_mse: 0.0621\n","Epoch 77/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1547 - mse: 0.0397 - val_loss: 0.2012 - val_mse: 0.0622\n","Epoch 78/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1538 - mse: 0.0394 - val_loss: 0.2007 - val_mse: 0.0633\n","Epoch 79/100\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1533 - mse: 0.0392 - val_loss: 0.2011 - val_mse: 0.0620\n","Epoch 80/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1546 - mse: 0.0397 - val_loss: 0.1991 - val_mse: 0.0613\n","Epoch 81/100\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1533 - mse: 0.0394 - val_loss: 0.2027 - val_mse: 0.0642\n","Epoch 82/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1537 - mse: 0.0395 - val_loss: 0.1995 - val_mse: 0.0619\n","Epoch 83/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1533 - mse: 0.0394 - val_loss: 0.2002 - val_mse: 0.0626\n","Epoch 84/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1532 - mse: 0.0394 - val_loss: 0.2014 - val_mse: 0.0633\n","Epoch 85/100\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1520 - mse: 0.0389 - val_loss: 0.2016 - val_mse: 0.0635\n","Epoch 86/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1521 - mse: 0.0390 - val_loss: 0.1996 - val_mse: 0.0615\n","Epoch 87/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1530 - mse: 0.0392 - val_loss: 0.1998 - val_mse: 0.0619\n","Epoch 88/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1521 - mse: 0.0389 - val_loss: 0.2021 - val_mse: 0.0637\n","Epoch 89/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1524 - mse: 0.0389 - val_loss: 0.2006 - val_mse: 0.0633\n","Epoch 90/100\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1524 - mse: 0.0391 - val_loss: 0.2004 - val_mse: 0.0621\n","Epoch 91/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1522 - mse: 0.0388 - val_loss: 0.2008 - val_mse: 0.0619\n","Epoch 92/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1520 - mse: 0.0391 - val_loss: 0.2000 - val_mse: 0.0627\n","Epoch 93/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1523 - mse: 0.0389 - val_loss: 0.2013 - val_mse: 0.0636\n","Epoch 94/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1519 - mse: 0.0389 - val_loss: 0.2009 - val_mse: 0.0629\n","Epoch 95/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1514 - mse: 0.0387 - val_loss: 0.2013 - val_mse: 0.0624\n","Epoch 96/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1510 - mse: 0.0386 - val_loss: 0.1999 - val_mse: 0.0615\n","Epoch 97/100\n","247/247 [==============================] - 83s 334ms/step - loss: 0.1515 - mse: 0.0391 - val_loss: 0.2008 - val_mse: 0.0622\n"],"name":"stdout"}]},{"cell_type":"markdown","metadata":{"id":"fJJKUgcJK4La"},"source":["---"]},{"cell_type":"code","metadata":{"id":"gi9CsCZAK4Ld"},"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":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"IIKP9TtBK4Lg"},"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":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"4_py9DG4K4Lj"},"source":["# training_loss[-1], val_loss[-1], mses[-1], val_mses[-1]"],"execution_count":null,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"M-kSlYfqK4Lt"},"source":["### (Or) Read model checkpoint"]},{"cell_type":"code","metadata":{"id":"9z7haF6NK4Lu","executionInfo":{"status":"ok","timestamp":1615718610828,"user_tz":-60,"elapsed":212163,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["# put correct filename\n","model_filename = f\"{path_logs_training}/training/{training_description}.h5\""],"execution_count":35,"outputs":[]},{"cell_type":"code","metadata":{"id":"Dr9eFsJKK4Lw","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615718612179,"user_tz":-60,"elapsed":213269,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"a6ed3789-2692-4200-a857-ff251b468eb2"},"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":36,"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, 256)          4683264     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,683,264\n","Trainable params: 4,683,264\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":1615718612180,"user_tz":-60,"elapsed":212284,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["from cryoem.conversions import d_q, euler2quaternion\n","from cryoem.plots import plot_dP_dQ"],"execution_count":37,"outputs":[]},{"cell_type":"code","metadata":{"id":"RJMjW2KHK4L5","executionInfo":{"status":"ok","timestamp":1615718612181,"user_tz":-60,"elapsed":211937,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"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":38,"outputs":[]},{"cell_type":"code","metadata":{"id":"0YTh5UvmK4L7","executionInfo":{"status":"ok","timestamp":1615718678798,"user_tz":-60,"elapsed":278292,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"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":39,"outputs":[]},{"cell_type":"code","metadata":{"id":"5iTuvVue-a9c","executionInfo":{"status":"ok","timestamp":1615718678802,"user_tz":-60,"elapsed":278099,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["np.savez(os.path.join(path_logs_training, f\"dPdQ_data_{FEATURE_DIM}d_5j0n\"), dP_values, dQ_values)"],"execution_count":40,"outputs":[]},{"cell_type":"code","metadata":{"id":"NjmjpoN0K4L9","colab":{"base_uri":"https://localhost:8080/","height":882},"executionInfo":{"status":"ok","timestamp":1615718681509,"user_tz":-60,"elapsed":280633,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"bcb43fdf-52ac-41ca-995a-72b6d680a382"},"source":["plot_dP_dQ(dP_values, dQ_values)"],"execution_count":41,"outputs":[{"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 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.25481334792951094\n","Min. angle recovery loss possible = 0.06486491244076295\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"lA75WQYrK4L_","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615718681510,"user_tz":-60,"elapsed":280452,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"91ebd3da-f325-4dd1-a5ec-ab9c8d925f1a"},"source":["MAE(dQ_values, dP_values)"],"execution_count":42,"outputs":[{"output_type":"execute_result","data":{"text/plain":["<tf.Tensor: shape=(), dtype=float32, numpy=0.20969862>"]},"metadata":{"tags":[]},"execution_count":42}]},{"cell_type":"code","metadata":{"id":"rGC2BjfxVYqF","executionInfo":{"status":"ok","timestamp":1615718681510,"user_tz":-60,"elapsed":280287,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":[""],"execution_count":42,"outputs":[]}]}