{"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_dim128.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":1615718420229,"user_tz":-60,"elapsed":1165,"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":1615718452258,"user_tz":-60,"elapsed":33182,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"c06a6fdb-4211-4ead-87ec-83e7e5ffbfd7"},"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:40:20--  https://repo.anaconda.com/miniconda/Miniconda3-latest-Linux-x86_64.sh\n","Resolving repo.anaconda.com (repo.anaconda.com)... 104.16.130.3, 104.16.131.3, 2606:4700::6810:8203, ...\n","Connecting to repo.anaconda.com (repo.anaconda.com)|104.16.130.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   171MB/s    in 0.5s    \n","\n","2021-03-14 10:40:20 (171 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\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":1615718478276,"user_tz":-60,"elapsed":59193,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"826b4986-9082-4399-ce62-c267c27cc452"},"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":1615718510497,"user_tz":-60,"elapsed":91406,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"e3852dbb-003d-492e-df6f-e32d97f2c11c"},"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 | 36.04 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":1615718624420,"user_tz":-60,"elapsed":205322,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"dfe2da46-f319-437f-de0d-ea0e0a1b447d"},"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 7.3 MB/s \n","\u001b[?25hCollecting OpenEXR>=1.3.2\n","  Downloading OpenEXR-1.3.2.tar.gz (10 kB)\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 16.8 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","Collecting trimesh>=2.37.22\n","  Downloading trimesh-3.9.8-py3-none-any.whl (629 kB)\n","\u001b[K     |████████████████████████████████| 629 kB 18.2 MB/s \n","\u001b[?25hRequirement already satisfied: matplotlib>=2.2.5 in /usr/local/lib/python3.8/site-packages (from tensorflow-graphics) (3.2.2)\n","Requirement already satisfied: numpy>=1.15.4 in /usr/local/lib/python3.8/site-packages (from tensorflow-graphics) (1.18.1)\n","Requirement already satisfied: scipy>=1.1.0 in /usr/local/lib/python3.8/site-packages (from tensorflow-graphics) (1.5.3)\n","Collecting absl-py>=0.6.1\n","  Downloading absl_py-0.12.0-py3-none-any.whl (129 kB)\n","\u001b[K     |████████████████████████████████| 129 kB 34.1 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 29.5 MB/s \n","\u001b[?25hCollecting termcolor>=1.1.0\n","  Downloading termcolor-1.1.0.tar.gz (3.9 kB)\n","Collecting 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 55.7 MB/s \n","\u001b[?25hRequirement already satisfied: networkx in /usr/local/lib/python3.8/site-packages (from tensorflow-graphics) (2.5)\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 21 kB/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: kiwisolver>=1.0.1 in /usr/local/lib/python3.8/site-packages (from matplotlib>=2.2.5->tensorflow-graphics) (1.3.1)\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: 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: 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: six in /usr/local/lib/python3.8/site-packages (from absl-py>=0.6.1->tensorflow-graphics) (1.15.0)\n","Collecting importlib-resources; python_version < \"3.9\"\n","  Downloading importlib_resources-5.1.2-py3-none-any.whl (25 kB)\n","Collecting dill\n","  Downloading dill-0.3.3-py2.py3-none-any.whl (81 kB)\n","\u001b[K     |████████████████████████████████| 81 kB 10.9 MB/s \n","\u001b[?25hCollecting protobuf>=3.12.2\n","  Downloading protobuf-3.15.6-cp38-cp38-manylinux1_x86_64.whl (1.0 MB)\n","\u001b[K     |████████████████████████████████| 1.0 MB 65.8 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.2 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","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 future\n","  Downloading future-0.18.2.tar.gz (829 kB)\n","\u001b[K     |████████████████████████████████| 829 kB 63.6 MB/s \n","\u001b[?25hCollecting promise\n","  Downloading promise-2.3.tar.gz (19 kB)\n","Requirement already satisfied: decorator>=4.3.0 in /usr/local/lib/python3.8/site-packages (from networkx->tensorflow-graphics) (4.4.2)\n","Requirement already satisfied: wheel~=0.35 in /usr/local/lib/python3.8/site-packages (from tensorflow>=2.2.0->tensorflow-graphics) (0.35.1)\n","Collecting flatbuffers~=1.12.0\n","  Downloading flatbuffers-1.12-py2.py3-none-any.whl (15 kB)\n","Collecting tensorboard~=2.4\n","  Downloading tensorboard-2.4.1-py3-none-any.whl (10.6 MB)\n","\u001b[K     |████████████████████████████████| 10.6 MB 59.6 MB/s \n","\u001b[?25hCollecting google-pasta~=0.2\n","  Downloading google_pasta-0.2.0-py3-none-any.whl (57 kB)\n","\u001b[K     |████████████████████████████████| 57 kB 6.0 MB/s \n","\u001b[?25hCollecting astunparse~=1.6.3\n","  Downloading astunparse-1.6.3-py2.py3-none-any.whl (12 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 55.9 MB/s \n","\u001b[?25hCollecting opt-einsum~=3.3.0\n","  Downloading opt_einsum-3.3.0-py3-none-any.whl (65 kB)\n","\u001b[K     |████████████████████████████████| 65 kB 5.0 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 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 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 69.0 MB/s \n","\u001b[?25hCollecting wrapt~=1.12.1\n","  Downloading wrapt-1.12.1.tar.gz (27 kB)\n","Collecting typing-extensions~=3.7.4\n","  Downloading typing_extensions-3.7.4.3-py3-none-any.whl (22 kB)\n","Collecting googleapis-common-protos<2,>=1.52.0\n","  Downloading googleapis_common_protos-1.53.0-py2.py3-none-any.whl (198 kB)\n","\u001b[K     |████████████████████████████████| 198 kB 69.2 MB/s \n","\u001b[?25hRequirement 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","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: 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","Collecting 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 66.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 72.5 MB/s \n","\u001b[?25hCollecting markdown>=2.6.8\n","  Downloading Markdown-3.3.4-py3-none-any.whl (97 kB)\n","\u001b[K     |████████████████████████████████| 97 kB 7.8 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 62.6 MB/s \n","\u001b[?25hCollecting 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 61.1 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 68.3 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 6.0 MB/s \n","\u001b[?25hBuilding wheels for collected packages: OpenEXR, termcolor, future, promise, wrapt\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=209625 sha256=0b05f5471ab12693f6be206e40ae2c0e60f8e3c0f44ef3a0a7b3b868f2cff0fd\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=343a17346ab240215a536e677204303cd7b06244014e3735beae8dafd32338ab\n","  Stored in directory: /root/.cache/pip/wheels/a0/16/9c/5473df82468f958445479c59e784896fa24f4a5fc024b0f501\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=af202687240213b2b94bbd3a7ada73fb1f0c95968693ccbfa5303555bf6b4d91\n","  Stored in directory: /root/.cache/pip/wheels/8e/70/28/3d6ccd6e315f65f245da085482a2e1c7d14b90b30f239e2cf4\n","  Building wheel for promise (setup.py) ... \u001b[?25l\u001b[?25hdone\n","  Created wheel for promise: filename=promise-2.3-py3-none-any.whl size=21494 sha256=a1c0738be3559cb91af28e25de07d54eed1a2684fe8441553e25e5f2a53818a0\n","  Stored in directory: /root/.cache/pip/wheels/54/aa/01/724885182f93150035a2a91bce34a12877e8067a97baaf5dc8\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=78013 sha256=5431b63fa4dca7e48e99a275ebd869e9034898d72439eabb3d49a7853aab17f4\n","  Stored in directory: /root/.cache/pip/wheels/5f/fd/9e/b6cf5890494cb8ef0b5eaff72e5d55a70fb56316007d6dfe73\n","Successfully built OpenEXR termcolor future promise wrapt\n","Installing collected packages: OpenEXR, psutil, trimesh, absl-py, h5py, termcolor, importlib-resources, dill, protobuf, googleapis-common-protos, tensorflow-metadata, future, promise, tensorflow-datasets, flatbuffers, grpcio, cachetools, pyasn1, pyasn1-modules, rsa, google-auth, oauthlib, requests-oauthlib, google-auth-oauthlib, werkzeug, markdown, tensorboard-plugin-wit, tensorboard, google-pasta, astunparse, opt-einsum, gast, keras-preprocessing, tensorflow-estimator, wrapt, typing-extensions, tensorflow, 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-metadata 0.28.0 requires absl-py<0.11,>=0.9, but you'll have absl-py 0.12.0 which is incompatible.\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.\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":1615718624422,"user_tz":-60,"elapsed":205321,"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":1615718624628,"user_tz":-60,"elapsed":205520,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"b64053f7-06c5-4dde-a427-2c8d7bed6a2d"},"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":1615718629694,"user_tz":-60,"elapsed":210584,"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":1615718629703,"user_tz":-60,"elapsed":210584,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"7ea60eaa-4035-4d01-82d1-75fe2499e2a1"},"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":1615718634866,"user_tz":-60,"elapsed":215739,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"806717d2-edbc-4109-8961-5543cad7dc3e"},"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: 11440849026103552623\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: 14393292071485622353\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":1615718634867,"user_tz":-60,"elapsed":215738,"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 = 128\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":1615718635086,"user_tz":-60,"elapsed":215951,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"754e50a0-1f64-4fef-f60b-a2e6ca8e71ab"},"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":1615718635088,"user_tz":-60,"elapsed":215946,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"b17f2178-0901-4255-ea87-f32f650ac1a6"},"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":1615718635541,"user_tz":-60,"elapsed":216391,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"3e69ff17-f1ac-46db-978f-1bd73a1403e9"},"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":1615718635543,"user_tz":-60,"elapsed":216391,"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":1615718635546,"user_tz":-60,"elapsed":216391,"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":1615718640544,"user_tz":-60,"elapsed":221388,"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":1615718640859,"user_tz":-60,"elapsed":221619,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"6a09eb33-c7ec-4b41-d480-9c7d7b992038"},"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":1615718640860,"user_tz":-60,"elapsed":221467,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"a9850353-e640-45a4-f29c-0e91650a11f2"},"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":1615718640861,"user_tz":-60,"elapsed":220982,"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":1615718640862,"user_tz":-60,"elapsed":220830,"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":1615718640863,"user_tz":-60,"elapsed":220329,"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":1615718641114,"user_tz":-60,"elapsed":220419,"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":1615718641116,"user_tz":-60,"elapsed":220038,"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":1615718641878,"user_tz":-60,"elapsed":220634,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"a1da04d7-4e9f-4c1b-f167-8005d05e7122"},"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":1615718641881,"user_tz":-60,"elapsed":220456,"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":1615718641883,"user_tz":-60,"elapsed":220253,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"6f6ae767-579b-4e25-86ee-85e8cab14831"},"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":1615718642109,"user_tz":-60,"elapsed":220260,"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":1615718642110,"user_tz":-60,"elapsed":219973,"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":1615718642111,"user_tz":-60,"elapsed":219520,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"7b6da390-c2f3-41e3-dcff-7b341da4fe3f"},"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":1615718642113,"user_tz":-60,"elapsed":218442,"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":1615718642387,"user_tz":-60,"elapsed":218336,"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":1615718644199,"user_tz":-60,"elapsed":219410,"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":1615718644201,"user_tz":-60,"elapsed":218727,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"f9d8a545-e23a-4c7f-af43-b2ea4aedb434"},"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":"10f59efc-9dba-4de2-879c-d94f2ee98b19"},"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.941774368286133 sec\n","Data created in 0.7750816345214844 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, 128)          4617600     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,617,600\n","Trainable params: 4,617,600\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_dim128_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 [==============================] - 126s 352ms/step - loss: 0.9231 - mse: 1.3903 - val_loss: 0.5850 - val_mse: 0.5771\n","Epoch 2/100\n","247/247 [==============================] - 81s 328ms/step - loss: 0.5559 - mse: 0.5062 - val_loss: 0.4452 - val_mse: 0.3317\n","Epoch 3/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.4246 - mse: 0.3024 - val_loss: 0.4088 - val_mse: 0.2788\n","Epoch 4/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.3459 - mse: 0.2053 - val_loss: 0.3321 - val_mse: 0.1967\n","Epoch 5/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.2888 - mse: 0.1426 - val_loss: 0.3071 - val_mse: 0.1651\n","Epoch 6/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.2500 - mse: 0.1024 - val_loss: 0.2548 - val_mse: 0.1086\n","Epoch 7/100\n","247/247 [==============================] - 81s 329ms/step - loss: 0.2185 - mse: 0.0749 - val_loss: 0.2318 - val_mse: 0.0901\n","Epoch 8/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.2015 - mse: 0.0619 - val_loss: 0.2190 - val_mse: 0.0796\n","Epoch 9/100\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1945 - mse: 0.0575 - val_loss: 0.2203 - val_mse: 0.0782\n","Epoch 10/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1895 - mse: 0.0544 - val_loss: 0.2158 - val_mse: 0.0744\n","Epoch 11/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1878 - mse: 0.0533 - val_loss: 0.2102 - val_mse: 0.0704\n","Epoch 12/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1833 - mse: 0.0510 - val_loss: 0.2070 - val_mse: 0.0673\n","Epoch 13/100\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1819 - mse: 0.0503 - val_loss: 0.2100 - val_mse: 0.0712\n","Epoch 14/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1802 - mse: 0.0495 - val_loss: 0.2118 - val_mse: 0.0724\n","Epoch 15/100\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1779 - mse: 0.0483 - val_loss: 0.2079 - val_mse: 0.0685\n","Epoch 16/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1773 - mse: 0.0481 - val_loss: 0.2055 - val_mse: 0.0673\n","Epoch 17/100\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1764 - mse: 0.0475 - val_loss: 0.2071 - val_mse: 0.0687\n","Epoch 18/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1731 - mse: 0.0462 - val_loss: 0.2079 - val_mse: 0.0685\n","Epoch 19/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1731 - mse: 0.0461 - val_loss: 0.2083 - val_mse: 0.0704\n","Epoch 20/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1727 - mse: 0.0458 - val_loss: 0.2063 - val_mse: 0.0669\n","Epoch 21/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1718 - mse: 0.0456 - val_loss: 0.2030 - val_mse: 0.0649\n","Epoch 22/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1703 - mse: 0.0448 - val_loss: 0.2040 - val_mse: 0.0658\n","Epoch 23/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1710 - mse: 0.0450 - val_loss: 0.2041 - val_mse: 0.0646\n","Epoch 24/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1704 - mse: 0.0450 - val_loss: 0.2040 - val_mse: 0.0662\n","Epoch 25/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1690 - mse: 0.0444 - val_loss: 0.2064 - val_mse: 0.0675\n","Epoch 26/100\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1688 - mse: 0.0443 - val_loss: 0.2049 - val_mse: 0.0664\n","Epoch 27/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1675 - mse: 0.0437 - val_loss: 0.2045 - val_mse: 0.0659\n","Epoch 28/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1667 - mse: 0.0435 - val_loss: 0.2043 - val_mse: 0.0646\n","Epoch 29/100\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1659 - mse: 0.0432 - val_loss: 0.2054 - val_mse: 0.0653\n","Epoch 30/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1662 - mse: 0.0433 - val_loss: 0.2058 - val_mse: 0.0675\n","Epoch 31/100\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1659 - mse: 0.0432 - val_loss: 0.2032 - val_mse: 0.0651\n","Epoch 32/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1666 - mse: 0.0436 - val_loss: 0.2058 - val_mse: 0.0683\n","Epoch 33/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1646 - mse: 0.0425 - val_loss: 0.2066 - val_mse: 0.0668\n","Epoch 34/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1651 - mse: 0.0429 - val_loss: 0.2058 - val_mse: 0.0671\n","Epoch 35/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1635 - mse: 0.0422 - val_loss: 0.2051 - val_mse: 0.0665\n","Epoch 36/100\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1640 - mse: 0.0425 - val_loss: 0.2059 - val_mse: 0.0665\n","Epoch 37/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1629 - mse: 0.0420 - val_loss: 0.2092 - val_mse: 0.0697\n","Epoch 38/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1621 - mse: 0.0418 - val_loss: 0.2045 - val_mse: 0.0664\n","Epoch 39/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1622 - mse: 0.0417 - val_loss: 0.2033 - val_mse: 0.0660\n","Epoch 40/100\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1612 - mse: 0.0414 - val_loss: 0.2058 - val_mse: 0.0675\n","Epoch 41/100\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1610 - mse: 0.0413 - val_loss: 0.2075 - val_mse: 0.0666\n","Epoch 42/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1616 - mse: 0.0415 - val_loss: 0.2055 - val_mse: 0.0667\n","Epoch 43/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1614 - mse: 0.0413 - val_loss: 0.2063 - val_mse: 0.0682\n","Epoch 44/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1605 - mse: 0.0413 - val_loss: 0.2064 - val_mse: 0.0681\n","Epoch 45/100\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1600 - mse: 0.0411 - val_loss: 0.2083 - val_mse: 0.0678\n","Epoch 46/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1598 - mse: 0.0410 - val_loss: 0.2092 - val_mse: 0.0693\n","Epoch 47/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1597 - mse: 0.0411 - val_loss: 0.2066 - val_mse: 0.0674\n","Epoch 48/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1593 - mse: 0.0410 - val_loss: 0.2056 - val_mse: 0.0670\n","Epoch 49/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1590 - mse: 0.0408 - val_loss: 0.2047 - val_mse: 0.0653\n","Epoch 50/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1568 - mse: 0.0397 - val_loss: 0.2080 - val_mse: 0.0695\n","Epoch 51/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1590 - mse: 0.0409 - val_loss: 0.2046 - val_mse: 0.0663\n","Epoch 52/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1582 - mse: 0.0406 - val_loss: 0.2079 - val_mse: 0.0686\n","Epoch 53/100\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1573 - mse: 0.0400 - val_loss: 0.2064 - val_mse: 0.0668\n","Epoch 54/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1584 - mse: 0.0407 - val_loss: 0.2064 - val_mse: 0.0674\n","Epoch 55/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1576 - mse: 0.0405 - val_loss: 0.2060 - val_mse: 0.0667\n","Epoch 56/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1575 - mse: 0.0405 - val_loss: 0.2075 - val_mse: 0.0683\n","Epoch 57/100\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1564 - mse: 0.0400 - val_loss: 0.2066 - val_mse: 0.0668\n","Epoch 58/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1573 - mse: 0.0402 - val_loss: 0.2072 - val_mse: 0.0680\n","Epoch 59/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1567 - mse: 0.0400 - val_loss: 0.2081 - val_mse: 0.0685\n","Epoch 60/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1564 - mse: 0.0400 - val_loss: 0.2068 - val_mse: 0.0673\n","Epoch 61/100\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1563 - mse: 0.0399 - val_loss: 0.2071 - val_mse: 0.0669\n","Epoch 62/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1561 - mse: 0.0399 - val_loss: 0.2080 - val_mse: 0.0675\n","Epoch 63/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1555 - mse: 0.0397 - val_loss: 0.2049 - val_mse: 0.0662\n","Epoch 64/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1552 - mse: 0.0395 - val_loss: 0.2078 - val_mse: 0.0676\n","Epoch 65/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1552 - mse: 0.0396 - val_loss: 0.2074 - val_mse: 0.0662\n","Epoch 66/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1546 - mse: 0.0395 - val_loss: 0.2090 - val_mse: 0.0683\n","Epoch 67/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1551 - mse: 0.0398 - val_loss: 0.2078 - val_mse: 0.0681\n","Epoch 68/100\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1554 - mse: 0.0397 - val_loss: 0.2073 - val_mse: 0.0672\n","Epoch 69/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1550 - mse: 0.0398 - val_loss: 0.2063 - val_mse: 0.0664\n","Epoch 70/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1551 - mse: 0.0396 - val_loss: 0.2069 - val_mse: 0.0672\n","Epoch 71/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1541 - mse: 0.0394 - val_loss: 0.2084 - val_mse: 0.0686\n","Epoch 72/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1557 - mse: 0.0401 - val_loss: 0.2077 - val_mse: 0.0685\n","Epoch 73/100\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1544 - mse: 0.0396 - val_loss: 0.2084 - val_mse: 0.0681\n","Epoch 74/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1539 - mse: 0.0392 - val_loss: 0.2080 - val_mse: 0.0675\n","Epoch 75/100\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1542 - mse: 0.0395 - val_loss: 0.2082 - val_mse: 0.0674\n","Epoch 76/100\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1528 - mse: 0.0389 - val_loss: 0.2074 - val_mse: 0.0667\n","Epoch 77/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1534 - mse: 0.0393 - val_loss: 0.2095 - val_mse: 0.0693\n","Epoch 78/100\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1535 - mse: 0.0393 - val_loss: 0.2095 - val_mse: 0.0690\n","Epoch 79/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1526 - mse: 0.0389 - val_loss: 0.2094 - val_mse: 0.0695\n","Epoch 80/100\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1518 - mse: 0.0388 - val_loss: 0.2088 - val_mse: 0.0687\n","Epoch 81/100\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1527 - mse: 0.0388 - val_loss: 0.2067 - val_mse: 0.0671\n","Epoch 82/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1531 - mse: 0.0391 - val_loss: 0.2086 - val_mse: 0.0678\n","Epoch 83/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1527 - mse: 0.0390 - val_loss: 0.2072 - val_mse: 0.0669\n","Epoch 84/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1532 - mse: 0.0391 - val_loss: 0.2090 - val_mse: 0.0686\n","Epoch 85/100\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1516 - mse: 0.0387 - val_loss: 0.2074 - val_mse: 0.0680\n","Epoch 86/100\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1519 - mse: 0.0389 - val_loss: 0.2081 - val_mse: 0.0682\n","Epoch 87/100\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1529 - mse: 0.0392 - val_loss: 0.2092 - val_mse: 0.0692\n","Epoch 88/100\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1514 - mse: 0.0387 - val_loss: 0.2082 - val_mse: 0.0679\n","Epoch 89/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1510 - mse: 0.0383 - val_loss: 0.2088 - val_mse: 0.0686\n","Epoch 90/100\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1511 - mse: 0.0386 - val_loss: 0.2101 - val_mse: 0.0682\n","Epoch 91/100\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1519 - mse: 0.0388 - val_loss: 0.2100 - val_mse: 0.0685\n","Epoch 92/100\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1516 - mse: 0.0386 - val_loss: 0.2065 - val_mse: 0.0664\n","Epoch 93/100\n","247/247 [==============================] - 83s 335ms/step - loss: 0.1504 - mse: 0.0382 - val_loss: 0.2092 - val_mse: 0.0673\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":1615718644811,"user_tz":-60,"elapsed":596,"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":1615718646039,"user_tz":-60,"elapsed":1820,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"12a26e65-81f1-402d-abe8-6ec5b374b168"},"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, 128)          4617600     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,617,600\n","Trainable params: 4,617,600\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":1615718646041,"user_tz":-60,"elapsed":1820,"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":1615718646042,"user_tz":-60,"elapsed":1819,"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":1615718718548,"user_tz":-60,"elapsed":74323,"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":1615718718548,"user_tz":-60,"elapsed":74321,"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":1615718721137,"user_tz":-60,"elapsed":76908,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"e9b59a40-8d12-4c4a-ce1b-cfcac46d0511"},"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.25381557545850003\n","Min. angle recovery loss possible = 0.0643579239989842\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"lA75WQYrK4L_","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615718721138,"user_tz":-60,"elapsed":76907,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"d963b4d4-35bd-401c-8f9a-4119f79a371f"},"source":["MAE(dQ_values, dP_values)"],"execution_count":42,"outputs":[{"output_type":"execute_result","data":{"text/plain":["<tf.Tensor: shape=(), dtype=float32, numpy=0.20261306>"]},"metadata":{"tags":[]},"execution_count":42}]},{"cell_type":"code","metadata":{"id":"rGC2BjfxVYqF","executionInfo":{"status":"ok","timestamp":1615718721139,"user_tz":-60,"elapsed":76906,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":[""],"execution_count":42,"outputs":[]}]}