{"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_dim32.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":1615719489152,"user_tz":-60,"elapsed":985,"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":1615719520186,"user_tz":-60,"elapsed":32003,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"aac463b7-0598-4e90-8a83-8033569fadd2"},"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:58:09--  https://repo.anaconda.com/miniconda/Miniconda3-latest-Linux-x86_64.sh\n","Resolving repo.anaconda.com (repo.anaconda.com)... 104.16.131.3, 104.16.130.3, 2606:4700::6810:8303, ...\n","Connecting to repo.anaconda.com (repo.anaconda.com)|104.16.131.3|:443... connected.\n","HTTP request sent, awaiting response... 200 OK\n","Length: 94235922 (90M) [application/x-sh]\n","Saving to: ‘Miniconda3-latest-Linux-x86_64.sh’\n","\n","Miniconda3-latest-L 100%[===================>]  89.87M   220MB/s    in 0.4s    \n","\n","2021-03-14 10:58:09 (220 MB/s) - ‘Miniconda3-latest-Linux-x86_64.sh’ saved [94235922/94235922]\n","\n","PREFIX=/usr/local\n","Unpacking payload ...\n","Collecting package metadata (current_repodata.json): - \b\b\\ \b\b| \b\bdone\n","Solving environment: - \b\b\\ \b\bdone\n","\n","## Package Plan ##\n","\n","  environment location: /usr/local\n","\n","  added / updated specs:\n","    - _libgcc_mutex==0.1=main\n","    - brotlipy==0.7.0=py38h27cfd23_1003\n","    - ca-certificates==2020.10.14=0\n","    - certifi==2020.6.20=pyhd3eb1b0_3\n","    - cffi==1.14.3=py38h261ae71_2\n","    - chardet==3.0.4=py38h06a4308_1003\n","    - conda-package-handling==1.7.2=py38h03888b9_0\n","    - conda==4.9.2=py38h06a4308_0\n","    - cryptography==3.2.1=py38h3c74f83_1\n","    - idna==2.10=py_0\n","    - ld_impl_linux-64==2.33.1=h53a641e_7\n","    - libedit==3.1.20191231=h14c3975_1\n","    - libffi==3.3=he6710b0_2\n","    - libgcc-ng==9.1.0=hdf63c60_0\n","    - libstdcxx-ng==9.1.0=hdf63c60_0\n","    - ncurses==6.2=he6710b0_1\n","    - openssl==1.1.1h=h7b6447c_0\n","    - pip==20.2.4=py38h06a4308_0\n","    - pycosat==0.6.3=py38h7b6447c_1\n","    - pycparser==2.20=py_2\n","    - pyopenssl==19.1.0=pyhd3eb1b0_1\n","    - pysocks==1.7.1=py38h06a4308_0\n","    - python==3.8.5=h7579374_1\n","    - readline==8.0=h7b6447c_0\n","    - requests==2.24.0=py_0\n","    - ruamel_yaml==0.15.87=py38h7b6447c_1\n","    - setuptools==50.3.1=py38h06a4308_1\n","    - six==1.15.0=py38h06a4308_0\n","    - sqlite==3.33.0=h62c20be_0\n","    - tk==8.6.10=hbc83047_0\n","    - tqdm==4.51.0=pyhd3eb1b0_0\n","    - urllib3==1.25.11=py_0\n","    - wheel==0.35.1=pyhd3eb1b0_0\n","    - xz==5.2.5=h7b6447c_0\n","    - yaml==0.2.5=h7b6447c_0\n","    - zlib==1.2.11=h7b6447c_3\n","\n","\n","The following NEW packages will be INSTALLED:\n","\n","  _libgcc_mutex      pkgs/main/linux-64::_libgcc_mutex-0.1-main\n","  brotlipy           pkgs/main/linux-64::brotlipy-0.7.0-py38h27cfd23_1003\n","  ca-certificates    pkgs/main/linux-64::ca-certificates-2020.10.14-0\n","  certifi            pkgs/main/noarch::certifi-2020.6.20-pyhd3eb1b0_3\n","  cffi               pkgs/main/linux-64::cffi-1.14.3-py38h261ae71_2\n","  chardet            pkgs/main/linux-64::chardet-3.0.4-py38h06a4308_1003\n","  conda              pkgs/main/linux-64::conda-4.9.2-py38h06a4308_0\n","  conda-package-han~ pkgs/main/linux-64::conda-package-handling-1.7.2-py38h03888b9_0\n","  cryptography       pkgs/main/linux-64::cryptography-3.2.1-py38h3c74f83_1\n","  idna               pkgs/main/noarch::idna-2.10-py_0\n","  ld_impl_linux-64   pkgs/main/linux-64::ld_impl_linux-64-2.33.1-h53a641e_7\n","  libedit            pkgs/main/linux-64::libedit-3.1.20191231-h14c3975_1\n","  libffi             pkgs/main/linux-64::libffi-3.3-he6710b0_2\n","  libgcc-ng          pkgs/main/linux-64::libgcc-ng-9.1.0-hdf63c60_0\n","  libstdcxx-ng       pkgs/main/linux-64::libstdcxx-ng-9.1.0-hdf63c60_0\n","  ncurses            pkgs/main/linux-64::ncurses-6.2-he6710b0_1\n","  openssl            pkgs/main/linux-64::openssl-1.1.1h-h7b6447c_0\n","  pip                pkgs/main/linux-64::pip-20.2.4-py38h06a4308_0\n","  pycosat            pkgs/main/linux-64::pycosat-0.6.3-py38h7b6447c_1\n","  pycparser          pkgs/main/noarch::pycparser-2.20-py_2\n","  pyopenssl          pkgs/main/noarch::pyopenssl-19.1.0-pyhd3eb1b0_1\n","  pysocks            pkgs/main/linux-64::pysocks-1.7.1-py38h06a4308_0\n","  python             pkgs/main/linux-64::python-3.8.5-h7579374_1\n","  readline           pkgs/main/linux-64::readline-8.0-h7b6447c_0\n","  requests           pkgs/main/noarch::requests-2.24.0-py_0\n","  ruamel_yaml        pkgs/main/linux-64::ruamel_yaml-0.15.87-py38h7b6447c_1\n","  setuptools         pkgs/main/linux-64::setuptools-50.3.1-py38h06a4308_1\n","  six                pkgs/main/linux-64::six-1.15.0-py38h06a4308_0\n","  sqlite             pkgs/main/linux-64::sqlite-3.33.0-h62c20be_0\n","  tk                 pkgs/main/linux-64::tk-8.6.10-hbc83047_0\n","  tqdm               pkgs/main/noarch::tqdm-4.51.0-pyhd3eb1b0_0\n","  urllib3            pkgs/main/noarch::urllib3-1.25.11-py_0\n","  wheel              pkgs/main/noarch::wheel-0.35.1-pyhd3eb1b0_0\n","  xz                 pkgs/main/linux-64::xz-5.2.5-h7b6447c_0\n","  yaml               pkgs/main/linux-64::yaml-0.2.5-h7b6447c_0\n","  zlib               pkgs/main/linux-64::zlib-1.2.11-h7b6447c_3\n","\n","\n","Preparing transaction: / \b\b- \b\b\\ \b\bdone\n","Executing transaction: / \b\b- \b\b\\ \b\b| \b\b/ \b\b- \b\b\\ \b\b| \b\b/ \b\b- \b\b\\ \b\bdone\n","installation finished.\n","WARNING:\n","    You currently have a PYTHONPATH environment variable set. This may cause\n","    unexpected behavior when running the Python interpreter in Miniconda3.\n","    For best results, please verify that your PYTHONPATH only points to\n","    directories of packages that are compatible with the Python interpreter\n","    in Miniconda3: /usr/local\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"HeNudKnGpFCJ","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615719662703,"user_tz":-60,"elapsed":174513,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"e8e12aa0-3e26-4297-d763-c5432ff34df6"},"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":1615719703824,"user_tz":-60,"elapsed":215626,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"2fe6cfa3-00cd-492b-d5c5-48106dd7f6bc"},"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 | 25.00 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":1615719811549,"user_tz":-60,"elapsed":323344,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"81b7de9d-fa52-4a61-f596-d10f47b587ce"},"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 15.0 MB/s \n","\u001b[?25hRequirement already satisfied: tqdm>=4.45.0 in /usr/local/lib/python3.8/site-packages (from tensorflow-graphics) (4.51.0)\n","Requirement already satisfied: 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 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 19 kB/s \n","\u001b[?25hCollecting absl-py>=0.6.1\n","  Downloading absl_py-0.12.0-py3-none-any.whl (129 kB)\n","\u001b[K     |████████████████████████████████| 129 kB 70.5 MB/s \n","\u001b[?25hCollecting trimesh>=2.37.22\n","  Downloading trimesh-3.9.8-py3-none-any.whl (629 kB)\n","\u001b[K     |████████████████████████████████| 629 kB 70.3 MB/s \n","\u001b[?25hCollecting psutil>=5.7.0\n","  Downloading psutil-5.8.0-cp38-cp38-manylinux2010_x86_64.whl (296 kB)\n","\u001b[K     |████████████████████████████████| 296 kB 83.4 MB/s \n","\u001b[?25hCollecting termcolor>=1.1.0\n","  Downloading termcolor-1.1.0.tar.gz (3.9 kB)\n","Requirement already satisfied: matplotlib>=2.2.5 in /usr/local/lib/python3.8/site-packages (from tensorflow-graphics) (3.2.2)\n","Requirement already satisfied: networkx in /usr/local/lib/python3.8/site-packages (from tensorflow-graphics) (2.5)\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 52.1 MB/s \n","\u001b[?25hCollecting OpenEXR>=1.3.2\n","  Downloading OpenEXR-1.3.2.tar.gz (10 kB)\n","Collecting 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 57.9 MB/s \n","\u001b[?25hCollecting protobuf>=3.9.2\n","  Downloading protobuf-3.15.6-cp38-cp38-manylinux1_x86_64.whl (1.0 MB)\n","\u001b[K     |████████████████████████████████| 1.0 MB 71.5 MB/s \n","\u001b[?25hRequirement already satisfied: six~=1.15.0 in /usr/local/lib/python3.8/site-packages (from tensorflow>=2.2.0->tensorflow-graphics) (1.15.0)\n","Collecting typing-extensions~=3.7.4\n","  Downloading typing_extensions-3.7.4.3-py3-none-any.whl (22 kB)\n","Collecting google-pasta~=0.2\n","  Downloading google_pasta-0.2.0-py3-none-any.whl (57 kB)\n","\u001b[K     |████████████████████████████████| 57 kB 6.7 MB/s \n","\u001b[?25hRequirement already satisfied: wheel~=0.35 in /usr/local/lib/python3.8/site-packages (from tensorflow>=2.2.0->tensorflow-graphics) (0.35.1)\n","Collecting 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 81.3 MB/s \n","\u001b[?25hCollecting wrapt~=1.12.1\n","  Downloading wrapt-1.12.1.tar.gz (27 kB)\n","Collecting opt-einsum~=3.3.0\n","  Downloading opt_einsum-3.3.0-py3-none-any.whl (65 kB)\n","\u001b[K     |████████████████████████████████| 65 kB 5.2 MB/s \n","\u001b[?25hCollecting astunparse~=1.6.3\n","  Downloading astunparse-1.6.3-py2.py3-none-any.whl (12 kB)\n","Collecting flatbuffers~=1.12.0\n","  Downloading flatbuffers-1.12-py2.py3-none-any.whl (15 kB)\n","Collecting 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.6 MB/s \n","\u001b[?25hCollecting grpcio~=1.32.0\n","  Downloading grpcio-1.32.0-cp38-cp38-manylinux2014_x86_64.whl (3.8 MB)\n","\u001b[K     |████████████████████████████████| 3.8 MB 60.5 MB/s \n","\u001b[?25hCollecting tensorboard~=2.4\n","  Downloading tensorboard-2.4.1-py3-none-any.whl (10.6 MB)\n","\u001b[K     |████████████████████████████████| 10.6 MB 19.5 MB/s \n","\u001b[?25hRequirement already satisfied: setuptools in /usr/local/lib/python3.8/site-packages (from trimesh>=2.37.22->tensorflow-graphics) (50.3.1.post20201107)\n","Requirement already satisfied: pyparsing!=2.0.4,!=2.1.2,!=2.1.6,>=2.0.1 in /usr/local/lib/python3.8/site-packages (from matplotlib>=2.2.5->tensorflow-graphics) (2.4.7)\n","Requirement already satisfied: kiwisolver>=1.0.1 in /usr/local/lib/python3.8/site-packages (from matplotlib>=2.2.5->tensorflow-graphics) (1.3.1)\n","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: decorator>=4.3.0 in /usr/local/lib/python3.8/site-packages (from networkx->tensorflow-graphics) (4.4.2)\n","Collecting importlib-resources; python_version < \"3.9\"\n","  Downloading importlib_resources-5.1.2-py3-none-any.whl (25 kB)\n","Requirement already satisfied: requests>=2.19.0 in /usr/local/lib/python3.8/site-packages (from tensorflow-datasets>=2.0.0->tensorflow-graphics) (2.24.0)\n","Collecting tensorflow-metadata\n","  Downloading tensorflow_metadata-0.28.0-py3-none-any.whl (47 kB)\n","\u001b[K     |████████████████████████████████| 47 kB 6.1 MB/s \n","\u001b[?25hCollecting dill\n","  Downloading dill-0.3.3-py2.py3-none-any.whl (81 kB)\n","\u001b[K     |████████████████████████████████| 81 kB 13.1 MB/s \n","\u001b[?25hCollecting promise\n","  Downloading promise-2.3.tar.gz (19 kB)\n","Collecting future\n","  Downloading future-0.18.2.tar.gz (829 kB)\n","\u001b[K     |████████████████████████████████| 829 kB 63.0 MB/s \n","\u001b[?25hRequirement 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 werkzeug>=0.11.15\n","  Downloading Werkzeug-1.0.1-py2.py3-none-any.whl (298 kB)\n","\u001b[K     |████████████████████████████████| 298 kB 70.1 MB/s \n","\u001b[?25hCollecting google-auth<2,>=1.6.3\n","  Downloading google_auth-1.27.1-py2.py3-none-any.whl (136 kB)\n","\u001b[K     |████████████████████████████████| 136 kB 85.4 MB/s \n","\u001b[?25hCollecting google-auth-oauthlib<0.5,>=0.4.1\n","  Downloading google_auth_oauthlib-0.4.3-py2.py3-none-any.whl (18 kB)\n","Collecting 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 84.0 MB/s \n","\u001b[?25hCollecting markdown>=2.6.8\n","  Downloading Markdown-3.3.4-py3-none-any.whl (97 kB)\n","\u001b[K     |████████████████████████████████| 97 kB 8.6 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: 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","Requirement already satisfied: urllib3!=1.25.0,!=1.25.1,<1.26,>=1.21.1 in /usr/local/lib/python3.8/site-packages (from requests>=2.19.0->tensorflow-datasets>=2.0.0->tensorflow-graphics) (1.25.11)\n","Collecting 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 66.2 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 pyasn1-modules>=0.2.1\n","  Downloading pyasn1_modules-0.2.8-py2.py3-none-any.whl (155 kB)\n","\u001b[K     |████████████████████████████████| 155 kB 86.8 MB/s \n","\u001b[?25hCollecting cachetools<5.0,>=2.0.0\n","  Downloading cachetools-4.2.1-py3-none-any.whl (12 kB)\n","Collecting requests-oauthlib>=0.7.0\n","  Downloading requests_oauthlib-1.3.0-py2.py3-none-any.whl (23 kB)\n","Collecting pyasn1>=0.1.3\n","  Downloading pyasn1-0.4.8-py2.py3-none-any.whl (77 kB)\n","\u001b[K     |████████████████████████████████| 77 kB 7.5 MB/s \n","\u001b[?25hCollecting oauthlib>=3.0.0\n","  Downloading oauthlib-3.1.0-py2.py3-none-any.whl (147 kB)\n","\u001b[K     |████████████████████████████████| 147 kB 76.3 MB/s \n","\u001b[?25hBuilding wheels for collected packages: termcolor, OpenEXR, wrapt, promise, future\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=5bb0cc3d0d83b3ec019d2418fcb47473a379d550dd9add532f4f57b1e7875e6a\n","  Stored in directory: /root/.cache/pip/wheels/a0/16/9c/5473df82468f958445479c59e784896fa24f4a5fc024b0f501\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=209608 sha256=fcb0775aa78454bdf11c51b598f7a81d8b7d7952bb2e957d776e422059c5343d\n","  Stored in directory: /root/.cache/pip/wheels/0a/10/25/9e32a4b1313a410a3210aea47a0fe60c8a738da2ef55419cd7\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=78017 sha256=fda050e6d6519aa45ce0834d19818e37b1f7ed47e8a820895d417df6b6dcb3a7\n","  Stored in directory: /root/.cache/pip/wheels/5f/fd/9e/b6cf5890494cb8ef0b5eaff72e5d55a70fb56316007d6dfe73\n","  Building wheel for promise (setup.py) ... \u001b[?25l\u001b[?25hdone\n","  Created wheel for promise: filename=promise-2.3-py3-none-any.whl size=21494 sha256=2e77d6c8a3da3dd2566016a20129b17b2f6cf189c3107259c1b74c6870a8894b\n","  Stored in directory: /root/.cache/pip/wheels/54/aa/01/724885182f93150035a2a91bce34a12877e8067a97baaf5dc8\n","  Building wheel for future (setup.py) ... \u001b[?25l\u001b[?25hdone\n","  Created wheel for future: filename=future-0.18.2-py3-none-any.whl size=491059 sha256=b3fe63a8fd6c25bc4ba680f7849371918e1744602a1d0e903ff6d7d94d2837f1\n","  Stored in directory: /root/.cache/pip/wheels/8e/70/28/3d6ccd6e315f65f245da085482a2e1c7d14b90b30f239e2cf4\n","Successfully built termcolor OpenEXR wrapt promise future\n","Installing collected packages: h5py, absl-py, protobuf, termcolor, typing-extensions, google-pasta, tensorflow-estimator, wrapt, opt-einsum, astunparse, flatbuffers, gast, keras-preprocessing, grpcio, werkzeug, pyasn1, rsa, pyasn1-modules, cachetools, google-auth, oauthlib, requests-oauthlib, google-auth-oauthlib, tensorboard-plugin-wit, markdown, tensorboard, tensorflow, trimesh, psutil, importlib-resources, googleapis-common-protos, tensorflow-metadata, dill, promise, future, tensorflow-datasets, OpenEXR, tensorflow-graphics\n","\u001b[31mERROR: After October 2020 you may experience errors when installing or updating packages. This is because pip will change the way that it resolves dependency conflicts.\n","\n","We recommend you use --use-feature=2020-resolver to test your packages with the new resolver before it becomes the default.\n","\n","tensorflow 2.4.1 requires h5py~=2.10.0, but you'll have h5py 3.2.1 which is incompatible.\n","tensorflow 2.4.1 requires numpy~=1.19.2, but you'll have numpy 1.18.1 which is incompatible.\n","tensorflow-metadata 0.28.0 requires absl-py<0.11,>=0.9, but you'll have absl-py 0.12.0 which is incompatible.\u001b[0m\n","Successfully installed OpenEXR-1.3.2 absl-py-0.12.0 astunparse-1.6.3 cachetools-4.2.1 dill-0.3.3 flatbuffers-1.12 future-0.18.2 gast-0.3.3 google-auth-1.27.1 google-auth-oauthlib-0.4.3 google-pasta-0.2.0 googleapis-common-protos-1.53.0 grpcio-1.32.0 h5py-3.2.1 importlib-resources-5.1.2 keras-preprocessing-1.1.2 markdown-3.3.4 oauthlib-3.1.0 opt-einsum-3.3.0 promise-2.3 protobuf-3.15.6 psutil-5.8.0 pyasn1-0.4.8 pyasn1-modules-0.2.8 requests-oauthlib-1.3.0 rsa-4.7.2 tensorboard-2.4.1 tensorboard-plugin-wit-1.8.0 tensorflow-2.4.1 tensorflow-datasets-4.2.0 tensorflow-estimator-2.4.0 tensorflow-graphics-2020.5.20 tensorflow-metadata-0.28.0 termcolor-1.1.0 trimesh-3.9.8 typing-extensions-3.7.4.3 werkzeug-1.0.1 wrapt-1.12.1\n"],"name":"stdout"},{"output_type":"display_data","data":{"application/vnd.colab-display-data+json":{"pip_warning":{"packages":["google"]}}},"metadata":{"tags":[]}}]},{"cell_type":"code","metadata":{"id":"VZDmNWzdK4KO","executionInfo":{"status":"ok","timestamp":1615719811550,"user_tz":-60,"elapsed":323343,"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":1615719811550,"user_tz":-60,"elapsed":323335,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"6da50f3f-f9de-4162-9add-3cc77323e28e"},"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":1615719816426,"user_tz":-60,"elapsed":328209,"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":1615719816431,"user_tz":-60,"elapsed":328206,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"f7af2b28-dcfc-44be-b931-884fd6ee207e"},"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":1615719821977,"user_tz":-60,"elapsed":333744,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"42341079-d828-4332-86e4-5516d08f7676"},"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: 16622658890659471297\n",", name: \"/device:GPU:0\"\n","device_type: \"GPU\"\n","memory_limit: 15703311680\n","locality {\n","  bus_id: 1\n","  links {\n","  }\n","}\n","incarnation: 1375662785843576141\n","physical_device_desc: \"device: 0, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:04.0, compute capability: 6.0\"\n","]\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"kZFVlYW4K4Ke","executionInfo":{"status":"ok","timestamp":1615719821979,"user_tz":-60,"elapsed":333744,"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 = 32\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":1615719822350,"user_tz":-60,"elapsed":334110,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"74ca30eb-3e75-48e0-c620-de6194aeab2f"},"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":1615719822355,"user_tz":-60,"elapsed":334109,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"3d082eae-d1b1-4ef9-df10-ce357cc1834e"},"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":1615719822812,"user_tz":-60,"elapsed":334560,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"432e2320-fac9-472b-cacd-263003b91b3a"},"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":1615719822813,"user_tz":-60,"elapsed":334558,"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":1615719822814,"user_tz":-60,"elapsed":334558,"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":1615719827404,"user_tz":-60,"elapsed":339146,"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":1615719827405,"user_tz":-60,"elapsed":339140,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"6c0ec8c1-4805-4fd6-b8b5-8ccac3b99b52"},"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":1615719827406,"user_tz":-60,"elapsed":339135,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"a23396cb-d6fa-483c-e750-442c90e140c8"},"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":1615719827407,"user_tz":-60,"elapsed":339134,"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":1615719827407,"user_tz":-60,"elapsed":339132,"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":1615719827683,"user_tz":-60,"elapsed":339407,"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":1615719827685,"user_tz":-60,"elapsed":339407,"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":1615719827687,"user_tz":-60,"elapsed":339407,"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":1615719828654,"user_tz":-60,"elapsed":340369,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"b2b54cc8-88f2-487a-8a18-c73821511364"},"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":1615719828655,"user_tz":-60,"elapsed":340369,"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":1615719828656,"user_tz":-60,"elapsed":340364,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"4e8f9d66-5fba-4334-d1cf-66857711f35a"},"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":1615719829160,"user_tz":-60,"elapsed":340866,"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":1615719829161,"user_tz":-60,"elapsed":340865,"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":1615719829161,"user_tz":-60,"elapsed":340860,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"71440843-186c-4332-d023-5bb71d94cc12"},"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":1615719829162,"user_tz":-60,"elapsed":340859,"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":1615719829163,"user_tz":-60,"elapsed":340859,"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":1615719830984,"user_tz":-60,"elapsed":342678,"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":1615719830986,"user_tz":-60,"elapsed":342674,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"46bb7160-1d19-4d3d-8aa3-0c7b773cbafb"},"source":["# 0.1 -> 34 min/epoch\n","# 0.01 -> 3.3 min/epoch\n","train_percent = 0.01\n","val_percent = 0.01\n","int(train_percent*np.power(len(train_idx), 2)), int(val_percent*np.power(len(val_idx), 2))"],"execution_count":34,"outputs":[{"output_type":"execute_result","data":{"text/plain":["(63101, 7022)"]},"metadata":{"tags":[]},"execution_count":34}]},{"cell_type":"code","metadata":{"scrolled":true,"id":"8HWI9cfqK4LY","colab":{"base_uri":"https://localhost:8080/","height":1000},"executionInfo":{"status":"ok","timestamp":1615727027116,"user_tz":-60,"elapsed":1173384,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"88513ea3-3469-40b4-f48a-d6f0d612008d"},"source":["model, history1 = train_siamese(X=X, y=y, \n","                               train_idx=train_idx, \n","                               val_idx=val_idx,\n","                               epochs=100,  #500\n","                               batch_size=256,  #512 latest \n","                               learning_rate=1e-3,  #0.01 \n","                                limit_style=\"random\", \n","                                path_logs_training=path_logs_training, \n","                                training_description=training_description,\n","                               training_steps=int(train_percent*np.power(len(train_idx), 2)),  # None\n","                               validation_steps=int(val_percent*np.power(len(val_idx), 2)),  # None\n","                               plot=True,\n","                               gpus=None)"],"execution_count":35,"outputs":[{"output_type":"stream","text":["INFO:tensorflow:Using MirroredStrategy with devices ('/job:localhost/replica:0/task:0/device:GPU:0',)\n","Data created in 6.890359401702881 sec\n","Data created in 0.7540848255157471 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, 32)           4568352     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,568,352\n","Trainable params: 4,568,352\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_dim32_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 [==============================] - 81s 190ms/step - loss: 0.9516 - mse: 1.4712 - val_loss: 0.6136 - val_mse: 0.6351\n","Epoch 2/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.5656 - mse: 0.5384 - val_loss: 0.4352 - val_mse: 0.3149\n","Epoch 3/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.4162 - mse: 0.2916 - val_loss: 0.3738 - val_mse: 0.2381\n","Epoch 4/100\n","247/247 [==============================] - 43s 174ms/step - loss: 0.3257 - mse: 0.1835 - val_loss: 0.3026 - val_mse: 0.1611\n","Epoch 5/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.2716 - mse: 0.1258 - val_loss: 0.2875 - val_mse: 0.1402\n","Epoch 6/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.2427 - mse: 0.0978 - val_loss: 0.2560 - val_mse: 0.1106\n","Epoch 7/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.2140 - mse: 0.0729 - val_loss: 0.2334 - val_mse: 0.0887\n","Epoch 8/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1991 - mse: 0.0605 - val_loss: 0.2346 - val_mse: 0.0913\n","Epoch 9/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1925 - mse: 0.0567 - val_loss: 0.2255 - val_mse: 0.0811\n","Epoch 10/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1889 - mse: 0.0545 - val_loss: 0.2304 - val_mse: 0.0893\n","Epoch 11/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1862 - mse: 0.0530 - val_loss: 0.2268 - val_mse: 0.0861\n","Epoch 12/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1837 - mse: 0.0516 - val_loss: 0.2160 - val_mse: 0.0743\n","Epoch 13/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1806 - mse: 0.0499 - val_loss: 0.2110 - val_mse: 0.0715\n","Epoch 14/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1790 - mse: 0.0493 - val_loss: 0.2141 - val_mse: 0.0735\n","Epoch 15/100\n","247/247 [==============================] - 43s 174ms/step - loss: 0.1786 - mse: 0.0487 - val_loss: 0.2161 - val_mse: 0.0767\n","Epoch 16/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1764 - mse: 0.0477 - val_loss: 0.2122 - val_mse: 0.0718\n","Epoch 17/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1757 - mse: 0.0473 - val_loss: 0.2146 - val_mse: 0.0748\n","Epoch 18/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1738 - mse: 0.0467 - val_loss: 0.2125 - val_mse: 0.0714\n","Epoch 19/100\n","247/247 [==============================] - 43s 172ms/step - loss: 0.1740 - mse: 0.0465 - val_loss: 0.2125 - val_mse: 0.0688\n","Epoch 20/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1725 - mse: 0.0458 - val_loss: 0.2105 - val_mse: 0.0703\n","Epoch 21/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1716 - mse: 0.0457 - val_loss: 0.2103 - val_mse: 0.0710\n","Epoch 22/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1721 - mse: 0.0458 - val_loss: 0.2126 - val_mse: 0.0720\n","Epoch 23/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1700 - mse: 0.0448 - val_loss: 0.2120 - val_mse: 0.0693\n","Epoch 24/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1693 - mse: 0.0447 - val_loss: 0.2097 - val_mse: 0.0702\n","Epoch 25/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1691 - mse: 0.0445 - val_loss: 0.2084 - val_mse: 0.0679\n","Epoch 26/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1696 - mse: 0.0446 - val_loss: 0.2065 - val_mse: 0.0663\n","Epoch 27/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1673 - mse: 0.0437 - val_loss: 0.2077 - val_mse: 0.0666\n","Epoch 28/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1671 - mse: 0.0438 - val_loss: 0.2081 - val_mse: 0.0693\n","Epoch 29/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1666 - mse: 0.0435 - val_loss: 0.2107 - val_mse: 0.0708\n","Epoch 30/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1666 - mse: 0.0436 - val_loss: 0.2084 - val_mse: 0.0681\n","Epoch 31/100\n","247/247 [==============================] - 43s 174ms/step - loss: 0.1651 - mse: 0.0429 - val_loss: 0.2106 - val_mse: 0.0699\n","Epoch 32/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1652 - mse: 0.0432 - val_loss: 0.2069 - val_mse: 0.0669\n","Epoch 33/100\n","247/247 [==============================] - 43s 174ms/step - loss: 0.1647 - mse: 0.0428 - val_loss: 0.2086 - val_mse: 0.0692\n","Epoch 34/100\n","247/247 [==============================] - 43s 174ms/step - loss: 0.1637 - mse: 0.0425 - val_loss: 0.2085 - val_mse: 0.0675\n","Epoch 35/100\n","247/247 [==============================] - 43s 174ms/step - loss: 0.1641 - mse: 0.0427 - val_loss: 0.2102 - val_mse: 0.0692\n","Epoch 36/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1638 - mse: 0.0425 - val_loss: 0.2081 - val_mse: 0.0683\n","Epoch 37/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1637 - mse: 0.0426 - val_loss: 0.2097 - val_mse: 0.0671\n","Epoch 38/100\n","247/247 [==============================] - 43s 174ms/step - loss: 0.1628 - mse: 0.0420 - val_loss: 0.2111 - val_mse: 0.0709\n","Epoch 39/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1625 - mse: 0.0422 - val_loss: 0.2101 - val_mse: 0.0687\n","Epoch 40/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1610 - mse: 0.0415 - val_loss: 0.2095 - val_mse: 0.0680\n","Epoch 41/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1612 - mse: 0.0419 - val_loss: 0.2100 - val_mse: 0.0702\n","Epoch 42/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1608 - mse: 0.0414 - val_loss: 0.2083 - val_mse: 0.0680\n","Epoch 43/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1606 - mse: 0.0413 - val_loss: 0.2098 - val_mse: 0.0698\n","Epoch 44/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1604 - mse: 0.0415 - val_loss: 0.2099 - val_mse: 0.0683\n","Epoch 45/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1607 - mse: 0.0415 - val_loss: 0.2088 - val_mse: 0.0683\n","Epoch 46/100\n","247/247 [==============================] - 43s 172ms/step - loss: 0.1596 - mse: 0.0411 - val_loss: 0.2092 - val_mse: 0.0673\n","Epoch 47/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1602 - mse: 0.0414 - val_loss: 0.2101 - val_mse: 0.0692\n","Epoch 48/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1602 - mse: 0.0413 - val_loss: 0.2098 - val_mse: 0.0691\n","Epoch 49/100\n","247/247 [==============================] - 43s 172ms/step - loss: 0.1599 - mse: 0.0414 - val_loss: 0.2095 - val_mse: 0.0687\n","Epoch 50/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1583 - mse: 0.0407 - val_loss: 0.2106 - val_mse: 0.0706\n","Epoch 51/100\n","247/247 [==============================] - 43s 174ms/step - loss: 0.1579 - mse: 0.0406 - val_loss: 0.2086 - val_mse: 0.0668\n","Epoch 52/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1585 - mse: 0.0408 - val_loss: 0.2086 - val_mse: 0.0689\n","Epoch 53/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1584 - mse: 0.0409 - val_loss: 0.2102 - val_mse: 0.0690\n","Epoch 54/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1580 - mse: 0.0408 - val_loss: 0.2103 - val_mse: 0.0697\n","Epoch 55/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1572 - mse: 0.0404 - val_loss: 0.2118 - val_mse: 0.0704\n","Epoch 56/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1571 - mse: 0.0403 - val_loss: 0.2081 - val_mse: 0.0679\n","Epoch 57/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1585 - mse: 0.0409 - val_loss: 0.2099 - val_mse: 0.0693\n","Epoch 58/100\n","247/247 [==============================] - 43s 172ms/step - loss: 0.1566 - mse: 0.0402 - val_loss: 0.2092 - val_mse: 0.0694\n","Epoch 59/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1569 - mse: 0.0404 - val_loss: 0.2099 - val_mse: 0.0703\n","Epoch 60/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1560 - mse: 0.0398 - val_loss: 0.2094 - val_mse: 0.0683\n","Epoch 61/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1569 - mse: 0.0404 - val_loss: 0.2114 - val_mse: 0.0710\n","Epoch 62/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1558 - mse: 0.0400 - val_loss: 0.2107 - val_mse: 0.0698\n","Epoch 63/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1557 - mse: 0.0398 - val_loss: 0.2076 - val_mse: 0.0669\n","Epoch 64/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1560 - mse: 0.0400 - val_loss: 0.2103 - val_mse: 0.0688\n","Epoch 65/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1559 - mse: 0.0401 - val_loss: 0.2086 - val_mse: 0.0681\n","Epoch 66/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1553 - mse: 0.0399 - val_loss: 0.2104 - val_mse: 0.0701\n","Epoch 67/100\n","247/247 [==============================] - 43s 174ms/step - loss: 0.1559 - mse: 0.0401 - val_loss: 0.2085 - val_mse: 0.0673\n","Epoch 68/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1548 - mse: 0.0395 - val_loss: 0.2091 - val_mse: 0.0685\n","Epoch 69/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1553 - mse: 0.0401 - val_loss: 0.2102 - val_mse: 0.0694\n","Epoch 70/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1548 - mse: 0.0398 - val_loss: 0.2117 - val_mse: 0.0704\n","Epoch 71/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1544 - mse: 0.0396 - val_loss: 0.2085 - val_mse: 0.0669\n","Epoch 72/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1545 - mse: 0.0397 - val_loss: 0.2090 - val_mse: 0.0683\n","Epoch 73/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1543 - mse: 0.0396 - val_loss: 0.2091 - val_mse: 0.0687\n","Epoch 74/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1543 - mse: 0.0396 - val_loss: 0.2098 - val_mse: 0.0687\n","Epoch 75/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1537 - mse: 0.0394 - val_loss: 0.2099 - val_mse: 0.0684\n","Epoch 76/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1536 - mse: 0.0393 - val_loss: 0.2104 - val_mse: 0.0694\n","Epoch 77/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1529 - mse: 0.0389 - val_loss: 0.2117 - val_mse: 0.0706\n","Epoch 78/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1544 - mse: 0.0397 - val_loss: 0.2105 - val_mse: 0.0705\n","Epoch 79/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1531 - mse: 0.0394 - val_loss: 0.2087 - val_mse: 0.0678\n","Epoch 80/100\n","247/247 [==============================] - 43s 174ms/step - loss: 0.1523 - mse: 0.0389 - val_loss: 0.2105 - val_mse: 0.0693\n","Epoch 81/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1530 - mse: 0.0393 - val_loss: 0.2103 - val_mse: 0.0690\n","Epoch 82/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1533 - mse: 0.0393 - val_loss: 0.2095 - val_mse: 0.0688\n","Epoch 83/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1535 - mse: 0.0394 - val_loss: 0.2103 - val_mse: 0.0697\n","Epoch 84/100\n","247/247 [==============================] - 43s 172ms/step - loss: 0.1529 - mse: 0.0394 - val_loss: 0.2118 - val_mse: 0.0714\n","Epoch 85/100\n","247/247 [==============================] - 43s 174ms/step - loss: 0.1530 - mse: 0.0393 - val_loss: 0.2130 - val_mse: 0.0725\n","Epoch 86/100\n","247/247 [==============================] - 43s 174ms/step - loss: 0.1528 - mse: 0.0394 - val_loss: 0.2135 - val_mse: 0.0723\n","Epoch 87/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1523 - mse: 0.0392 - val_loss: 0.2099 - val_mse: 0.0693\n","Epoch 88/100\n","247/247 [==============================] - 43s 174ms/step - loss: 0.1515 - mse: 0.0388 - val_loss: 0.2101 - val_mse: 0.0686\n","Epoch 89/100\n","247/247 [==============================] - 43s 174ms/step - loss: 0.1519 - mse: 0.0389 - val_loss: 0.2100 - val_mse: 0.0692\n","Epoch 90/100\n","247/247 [==============================] - 43s 174ms/step - loss: 0.1525 - mse: 0.0392 - val_loss: 0.2097 - val_mse: 0.0692\n","Epoch 91/100\n","247/247 [==============================] - 43s 174ms/step - loss: 0.1525 - mse: 0.0393 - val_loss: 0.2100 - val_mse: 0.0693\n","Epoch 92/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1521 - mse: 0.0392 - val_loss: 0.2110 - val_mse: 0.0693\n","Epoch 93/100\n","247/247 [==============================] - 43s 174ms/step - loss: 0.1506 - mse: 0.0383 - val_loss: 0.2086 - val_mse: 0.0686\n","Epoch 94/100\n","247/247 [==============================] - 43s 174ms/step - loss: 0.1515 - mse: 0.0388 - val_loss: 0.2114 - val_mse: 0.0708\n","Epoch 95/100\n","247/247 [==============================] - 43s 174ms/step - loss: 0.1515 - mse: 0.0389 - val_loss: 0.2094 - val_mse: 0.0688\n","Epoch 96/100\n","247/247 [==============================] - 43s 174ms/step - loss: 0.1513 - mse: 0.0388 - val_loss: 0.2098 - val_mse: 0.0692\n","Epoch 97/100\n","247/247 [==============================] - 43s 174ms/step - loss: 0.1507 - mse: 0.0385 - val_loss: 0.2101 - val_mse: 0.0694\n","Epoch 98/100\n","247/247 [==============================] - 43s 173ms/step - loss: 0.1515 - mse: 0.0390 - val_loss: 0.2105 - val_mse: 0.0703\n","Epoch 99/100\n","247/247 [==============================] - 43s 174ms/step - loss: 0.1525 - mse: 0.0393 - val_loss: 0.2097 - val_mse: 0.0682\n","Epoch 100/100\n","247/247 [==============================] - 43s 174ms/step - loss: 0.1504 - mse: 0.0385 - val_loss: 0.2101 - val_mse: 0.0692\n"],"name":"stdout"},{"output_type":"display_data","data":{"image/png":"iVBORw0KGgoAAAANSUhEUgAAA38AAAGvCAYAAADrFmyJAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nOzdeXyU9bn///c999wzAyQhISYxiBSkglEQSxWVoiipBWlCWFRa3HqweL56TrEuVUBlUXss7kfcftI+pDS1KhKNBovnKLYUWTwuRWoUXFAMhgBhS8g22++PyQzZkARh7rmT1/Px8GGSuTNzTeCRD9d9fT7XZYTD4bAAAAAAAJ2ay+4AAAAAAADHHskfAAAAAHQBJH8AAAAA0AWQ/AEAAABAF0DyBwAAAABdgNvuAI6Wuro6/etf/1JGRoZM07Q7HADAMRQMBrVz504NHjxYPp/P7nASHmskAHQNh1sfO03y969//UuXX3653WEAAOLoz3/+s84880y7w0h4rJEA0LUcan3sNMlfRkaGpMgbPf74422OBgBwLG3fvl2XX3557Hc/vh1rJAB0DYdbHztN8hfdxnL88cerT58+NkcDAIgHtjC2D2skAHQth1ofafgCAAAAAF0AyR8AAAAAdAGdZtsngMTg9/tVVlamuro6u0NBJ+Dz+dSnTx9ZlmV3KADgKKFQSLt27dLevXsVDAbtDgdHmWmaSk1N1XHHHSeXq/31PJI/AEdVWVmZkpOT1a9fPxmGYXc4cLBwOKzKykqVlZWpf//+docDAI5SVlYmwzDUr18/WZbFmtyJhMNh+f1+VVRUqKysTH379m3397LtE8BRVVdXp/T0dBYZfGeGYSg9PZ0qMgAcgQMHDuiEE06Qx+NhTe5kDMOQx+PRCSecoAMHDnToe0n+ABx1LDI4Wvi7BABHriPbAeE8R/Lny98IAAAAAOgCSP4AdGqjR4/WyJEjmx12Lyoq0qBBg1RYWNjs2vvvv1+DBw9WZWVlq+cYO3asCgoKYv+VlZU1u2bZsmWxx4YPH67zzz8/9vmGDRvaHW9BQUG7tjlOnz5dW7dubffzHk5ZWZnOPvvso/Z8AAC01J41ed++fbrpppuUl5en/Px8FRQUaO3atbFrzzzzzGbr8QMPPNDqdS699FIVFBRo3LhxOvXUU2PXzpo1q92x/uUvf9HixYsPe92bb76pBQsWtPt57UbDFwCdXmZmplavXq1Ro0ZJkl566SWddtppza4JBoMqLi7WsGHDVFxcrGnTpjV7/NFHH9XAgQMP+RqTJ0/W5MmTJUkzZ87U4MGDdcUVV7S6LhgMfutg8uLi4na9p0WLFrXrOgAAEsnh1uRHHnlEWVlZevDBB2UYhvbs2aPa2trY4yNGjNCjjz76ra+xdOlSSZEbm5MnT25zbQ0EAnK7D50K/fznP2/X+8nNzVVubm67rk0EJH8AOr2JEyeqqKhIo0aN0tdff62amppWidzf//539e3bVzNmzNC8efNaJX9HqqioSK+88op69Oihr776Svfff7/Wrl2r5cuXKxgMyuv1at68ecrJyZEkDRo0SO+//7569Oih0aNHq6CgQGvWrNHOnTs1bdq0WEI5evRoPfXUUxo4cKCuvPJKDR48WP/85z+1Y8cOXXzxxbrlllskSZ999plmzZql2tpanXLKKdq6dauuu+46XXjhhe2KPxgM6oEHHtA//vEPSdJ5552nW265RaZp6vnnn9fixYvl8XgUCoX0yCOPqH///rrrrru0bt06eTwede/eXc8999xR+VkCAJzvcGvy9u3bdfbZZ8fOfKelpSktLe2ovPbo0aM1btw4rVu3TgMHDtSNN96om266SQcOHFB9fb1GjRqlW2+9VZK0cOFC1dTU6LbbblNRUZFKSkqUkpKiTz/9VMnJyVq4cKEyMjJUVFSkv/3tb3r00Ue1fv16/dd//ZeGDh2qDz74QIZh6OGHH9aAAQMkSQ8//LBee+01paamavjw4Vq7dq2KioqOyntrL5I/AMfUxtvntPracT8aoexxYxWsr1fpXb9t9Xjm6AuUlTta/v379cmC1ts5jh87Rhnn/ajdMQwfPlzPPvus9u3bp5deekkTJkzQRx991OyaZcuWadKkSTrzzDPl9/u1YcMGDR06NPb4jBkz5PV6JUVm63Tkl/WGDRtUXFwca8WclZUVSy7XrFmjuXPn6oUXXmjze+vq6vT888+rrKxM+fn5mjhxonr06NHquvLycv35z3/WgQMH9OMf/1iXXHKJ+vXrp1tvvVVXX321CgoKtHHjRl122WXtjluSnn/+eX388cex9zt9+nQ9//zzmjp1qu677z799a9/VWZmphoaGhQMBvXJJ59o/fr1eu211+RyubRv374OvR4A4NjYsfJvqnhz5TF57qzc0cocfUG7rj3cmnzVVVdpxowZKikp0Q9+8AONHj1a5557buzxNWvWqKCgIPb5FVdcoUsvvbTdsVZXV+vFF1+UJNXX1+upp55Sjx495Pf7dc0112jVqlU6//zzW33fxo0b9corryg7O1t33HGHCgsLdeONN7a67rPPPtO9996ru+66S08++aSeeOIJPfjgg1q5cqXeeustFRcXy+fzacaMGe2O+WjizB+ATs8wDF188cVavny5li9frry8vGaPV1ZW6p133tHYsWMlSRMmTNCyZcuaXfPoo4+quLhYxcXFHb5LN2zYsGYzeP71r3/p8ssvV15enu699159/PHHh/zecePGSZL69OmjlJQUbd++vc3rxo4dK5fLpeTkZA0YMEBbt25VdXW1Nm/erPz8fEnSkCFDNGjQoA7FvnbtWk2cOFEej0cej0eTJk2Knb0455xzNHPmTP3pT39SRUWFunXrphNPPFGBQEC33367Xn755Q69FgCg8zvcmnzuuefqrbfe0nXXXSfLsvTrX/9aTz/9dOzxESNGxNbj4uLiDiV+UmSNjwoGg7rvvvs0fvx4TZo0SZ9++qk++eSTNr9v2LBhys7OliQNHTr0kOfu+/fvr1NPPVWSdMYZZ+jrr7+WJK1fv14XX3yxunfvLpfL1SyOeKLyB+CYGvLbuw75mOn1fuvjVkrKtz7eERMnTtSll16qs846q9X2keLiYgUCAY0fP15S5BxAbW2tZs+eLZ/P951fu2mlrqGhQTfccIMKCwt12mmnqaKios07jFHRaqMUqTg2PSTf3uuO1biExx57TBs3btS6det01VVXad68eRo1apSWL1+u9evXa82aNXrggQf00ksvKSMj45jEAABon8zRF7S7OnesfduaLElJSUmxs3SDBw/Wk08+qWuvvfaovHb37t1jHz/zzDPav3+/li5dKq/XqzvvvFP19fVtfl9712OPxxP72OVyKRAIHJW4jxYqfwC6hBNPPFE33nijrr/++laPFRUV6fHHH9fKlSu1cuVKrVq1SqeffrpWrFhx1ONoaGhQIBCI3T189tlnj/prRCUlJenkk09WSUmJJOmjjz7S5s2bO/Qc5557rl5++WX5/X75/X69/PLLGjFihAKBgL7++mudfvrpuvbaa/WjH/1IH3/8sXbv3q3a2trY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\n","text/plain":["<Figure size 1080x504 with 2 Axes>"]},"metadata":{"tags":[]}}]},{"cell_type":"markdown","metadata":{"id":"fJJKUgcJK4La"},"source":["---"]},{"cell_type":"code","metadata":{"id":"gi9CsCZAK4Ld","executionInfo":{"status":"ok","timestamp":1615727027117,"user_tz":-60,"elapsed":57,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["# data = np.load(f\"{path_logs_training}/losses/{training_description}.npz\")\n","# training_loss, val_loss, mses, val_mses = data[\"arr_0\"], data[\"arr_1\"], data[\"arr_2\"], data[\"arr_3\"]"],"execution_count":36,"outputs":[]},{"cell_type":"code","metadata":{"id":"IIKP9TtBK4Lg","executionInfo":{"status":"ok","timestamp":1615727027117,"user_tz":-60,"elapsed":51,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["# # Get training and test loss histories\n","# fig, (ax1, ax2) = plt.subplots(1, 2, figsize=(15,7))\n","\n","# # Create count of the number of epochs\n","# epoch_count = range(1, len(training_loss) + 1)\n","\n","# # Visualize loss history\n","# ax1.plot(epoch_count, training_loss, 'r--', label='MAE Training Loss')\n","# ax1.plot(epoch_count, val_loss, 'b-', label='MAE Validation Loss')\n","# ax1.legend()\n","# ax1.set_xlabel('Epoch')\n","# ax1.set_ylabel('Loss')\n","\n","# ax2.plot(epoch_count, mses, 'r-', label='MSE Training')\n","# ax2.plot(epoch_count, val_mses, 'b-', label='MSE Validation')\n","# ax2.legend()\n","# ax2.set_xlabel('Epoch')\n","# ax2.set_ylabel('Loss')\n","# plt.show();"],"execution_count":37,"outputs":[]},{"cell_type":"code","metadata":{"id":"4_py9DG4K4Lj","executionInfo":{"status":"ok","timestamp":1615727027118,"user_tz":-60,"elapsed":46,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["# training_loss[-1], val_loss[-1], mses[-1], val_mses[-1]"],"execution_count":38,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"M-kSlYfqK4Lt"},"source":["### (Or) Read model checkpoint"]},{"cell_type":"code","metadata":{"id":"9z7haF6NK4Lu","executionInfo":{"status":"ok","timestamp":1615727142969,"user_tz":-60,"elapsed":707,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["# put correct filename\n","model_filename = f\"{path_logs_training}/training/{training_description}.h5\""],"execution_count":47,"outputs":[]},{"cell_type":"code","metadata":{"id":"Dr9eFsJKK4Lw","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615727153012,"user_tz":-60,"elapsed":3727,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"5e7c0ea9-2905-4935-82f8-fd331a173462"},"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":48,"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, 32)           4568352     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,568,352\n","Trainable params: 4,568,352\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":1615727158130,"user_tz":-60,"elapsed":687,"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":49,"outputs":[]},{"cell_type":"code","metadata":{"id":"RJMjW2KHK4L5","executionInfo":{"status":"ok","timestamp":1615727158930,"user_tz":-60,"elapsed":647,"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":50,"outputs":[]},{"cell_type":"code","metadata":{"id":"0YTh5UvmK4L7","executionInfo":{"status":"ok","timestamp":1615727188361,"user_tz":-60,"elapsed":27654,"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":51,"outputs":[]},{"cell_type":"code","metadata":{"id":"Nq2fufgT2OOd","executionInfo":{"status":"ok","timestamp":1615727228882,"user_tz":-60,"elapsed":995,"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":52,"outputs":[]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/","height":882},"id":"X0j06XvD2RLf","executionInfo":{"status":"ok","timestamp":1615727249244,"user_tz":-60,"elapsed":2535,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"5f41a7e2-4dca-4874-9ca6-8611a7958a2f"},"source":["plot_dP_dQ(dP_values, dQ_values)"],"execution_count":53,"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.2479660893184668\n","Min. angle recovery loss possible = 0.06142569427044198\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"jgBIiGLw2XD9","executionInfo":{"status":"ok","timestamp":1615727265348,"user_tz":-60,"elapsed":718,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"ca4cd7ef-ad41-4ef8-9871-11e456f9a606"},"source":["MAE(dQ_values, dP_values)"],"execution_count":54,"outputs":[{"output_type":"execute_result","data":{"text/plain":["<tf.Tensor: shape=(), dtype=float32, numpy=0.20065233>"]},"metadata":{"tags":[]},"execution_count":54}]},{"cell_type":"code","metadata":{"id":"rGC2BjfxVYqF","executionInfo":{"status":"ok","timestamp":1615727055624,"user_tz":-60,"elapsed":14,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":[""],"execution_count":46,"outputs":[]}]}