{"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_dim16.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":["M-kSlYfqK4Lt"],"toc_visible":true},"accelerator":"GPU"},"cells":[{"cell_type":"markdown","metadata":{"id":"I-hskHNCK4Jy"},"source":["<a href=\"https://colab.research.google.com/github/anonymous/protein-reconstruction/blob/master/notebooks/2-phase2/colab_distance_estimation_and_angle_recovery-test5j0nhalf-cov_noisy.ipynb\" target=\"_parent\"><img src=\"https://colab.research.google.com/assets/colab-badge.svg\" alt=\"Open In Colab\"/></a>"]},{"cell_type":"markdown","metadata":{"id":"ny3JKImAK4Jz"},"source":["# Distance Estimation and Angle Recovery"]},{"cell_type":"markdown","metadata":{"id":"4W1rATe0K4J1"},"source":["<div class=\"alert alert-danger\" role=\"alert\">\n","  <p><strong>Important:</strong> This notebook is used to run the distance estimation on noisy data only (no angle recovery).</p>\n","  <hr>\n","    - <b>To enable GPU</b>: Navigate to Edit→Notebook Settings<br/>\n","    - <b>To save the latest version of code from this notebook</b>: Navigate to File→Save a copy to Github.\n","</div>"]},{"cell_type":"markdown","metadata":{"id":"EkRUrVFpCrFT"},"source":["## Content"]},{"cell_type":"markdown","metadata":{"id":"Zwit5GAFCrFU"},"source":["1. [Data Preparation](#1.-Data-Preparation)\n","2. [Distance Estimation](#2.-Distance-Estimation)\n","3. [Angle Recovery](#3.-Angle-Recovery)\n","4. [Angle Alignment](#4.-Angle-Alignment)"]},{"cell_type":"markdown","metadata":{"id":"TDsOdNomK4J4"},"source":["Data used:\n","- Protein: 5j0n (symmetric protein)\n","- Projections: 5K\n","- Coverage: Half-sphere\n","\n","![](https://github.com/anonymous/protein-reconstruction/blob/master/notebooks/2-phase2/figures/5j0n.pdb1-500.jpg?raw=1)"]},{"cell_type":"code","metadata":{"id":"P43631FkK4J5","executionInfo":{"status":"ok","timestamp":1615719433203,"user_tz":-60,"elapsed":746,"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":1615719463465,"user_tz":-60,"elapsed":30994,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"e7005e87-0802-489c-edf3-02fbb77e80d8"},"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:57:13--  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:8203, ...\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   238MB/s    in 0.4s    \n","\n","2021-03-14 10:57:13 (238 MB/s) - ‘Miniconda3-latest-Linux-x86_64.sh’ saved [94235922/94235922]\n","\n","PREFIX=/usr/local\n","Unpacking payload ...\n","Collecting package metadata (current_repodata.json): - \b\b\\ \b\b| \b\b/ \b\bdone\n","Solving environment: \\ \b\b| \b\bdone\n","\n","## Package Plan ##\n","\n","  environment location: /usr/local\n","\n","  added / updated specs:\n","    - _libgcc_mutex==0.1=main\n","    - brotlipy==0.7.0=py38h27cfd23_1003\n","    - ca-certificates==2020.10.14=0\n","    - certifi==2020.6.20=pyhd3eb1b0_3\n","    - cffi==1.14.3=py38h261ae71_2\n","    - chardet==3.0.4=py38h06a4308_1003\n","    - conda-package-handling==1.7.2=py38h03888b9_0\n","    - conda==4.9.2=py38h06a4308_0\n","    - cryptography==3.2.1=py38h3c74f83_1\n","    - idna==2.10=py_0\n","    - ld_impl_linux-64==2.33.1=h53a641e_7\n","    - libedit==3.1.20191231=h14c3975_1\n","    - libffi==3.3=he6710b0_2\n","    - libgcc-ng==9.1.0=hdf63c60_0\n","    - libstdcxx-ng==9.1.0=hdf63c60_0\n","    - ncurses==6.2=he6710b0_1\n","    - openssl==1.1.1h=h7b6447c_0\n","    - pip==20.2.4=py38h06a4308_0\n","    - pycosat==0.6.3=py38h7b6447c_1\n","    - pycparser==2.20=py_2\n","    - pyopenssl==19.1.0=pyhd3eb1b0_1\n","    - pysocks==1.7.1=py38h06a4308_0\n","    - python==3.8.5=h7579374_1\n","    - readline==8.0=h7b6447c_0\n","    - requests==2.24.0=py_0\n","    - ruamel_yaml==0.15.87=py38h7b6447c_1\n","    - setuptools==50.3.1=py38h06a4308_1\n","    - six==1.15.0=py38h06a4308_0\n","    - sqlite==3.33.0=h62c20be_0\n","    - tk==8.6.10=hbc83047_0\n","    - tqdm==4.51.0=pyhd3eb1b0_0\n","    - urllib3==1.25.11=py_0\n","    - wheel==0.35.1=pyhd3eb1b0_0\n","    - xz==5.2.5=h7b6447c_0\n","    - yaml==0.2.5=h7b6447c_0\n","    - zlib==1.2.11=h7b6447c_3\n","\n","\n","The following NEW packages will be INSTALLED:\n","\n","  _libgcc_mutex      pkgs/main/linux-64::_libgcc_mutex-0.1-main\n","  brotlipy           pkgs/main/linux-64::brotlipy-0.7.0-py38h27cfd23_1003\n","  ca-certificates    pkgs/main/linux-64::ca-certificates-2020.10.14-0\n","  certifi            pkgs/main/noarch::certifi-2020.6.20-pyhd3eb1b0_3\n","  cffi               pkgs/main/linux-64::cffi-1.14.3-py38h261ae71_2\n","  chardet            pkgs/main/linux-64::chardet-3.0.4-py38h06a4308_1003\n","  conda              pkgs/main/linux-64::conda-4.9.2-py38h06a4308_0\n","  conda-package-han~ pkgs/main/linux-64::conda-package-handling-1.7.2-py38h03888b9_0\n","  cryptography       pkgs/main/linux-64::cryptography-3.2.1-py38h3c74f83_1\n","  idna               pkgs/main/noarch::idna-2.10-py_0\n","  ld_impl_linux-64   pkgs/main/linux-64::ld_impl_linux-64-2.33.1-h53a641e_7\n","  libedit            pkgs/main/linux-64::libedit-3.1.20191231-h14c3975_1\n","  libffi             pkgs/main/linux-64::libffi-3.3-he6710b0_2\n","  libgcc-ng          pkgs/main/linux-64::libgcc-ng-9.1.0-hdf63c60_0\n","  libstdcxx-ng       pkgs/main/linux-64::libstdcxx-ng-9.1.0-hdf63c60_0\n","  ncurses            pkgs/main/linux-64::ncurses-6.2-he6710b0_1\n","  openssl            pkgs/main/linux-64::openssl-1.1.1h-h7b6447c_0\n","  pip                pkgs/main/linux-64::pip-20.2.4-py38h06a4308_0\n","  pycosat            pkgs/main/linux-64::pycosat-0.6.3-py38h7b6447c_1\n","  pycparser          pkgs/main/noarch::pycparser-2.20-py_2\n","  pyopenssl          pkgs/main/noarch::pyopenssl-19.1.0-pyhd3eb1b0_1\n","  pysocks            pkgs/main/linux-64::pysocks-1.7.1-py38h06a4308_0\n","  python             pkgs/main/linux-64::python-3.8.5-h7579374_1\n","  readline           pkgs/main/linux-64::readline-8.0-h7b6447c_0\n","  requests           pkgs/main/noarch::requests-2.24.0-py_0\n","  ruamel_yaml        pkgs/main/linux-64::ruamel_yaml-0.15.87-py38h7b6447c_1\n","  setuptools         pkgs/main/linux-64::setuptools-50.3.1-py38h06a4308_1\n","  six                pkgs/main/linux-64::six-1.15.0-py38h06a4308_0\n","  sqlite             pkgs/main/linux-64::sqlite-3.33.0-h62c20be_0\n","  tk                 pkgs/main/linux-64::tk-8.6.10-hbc83047_0\n","  tqdm               pkgs/main/noarch::tqdm-4.51.0-pyhd3eb1b0_0\n","  urllib3            pkgs/main/noarch::urllib3-1.25.11-py_0\n","  wheel              pkgs/main/noarch::wheel-0.35.1-pyhd3eb1b0_0\n","  xz                 pkgs/main/linux-64::xz-5.2.5-h7b6447c_0\n","  yaml               pkgs/main/linux-64::yaml-0.2.5-h7b6447c_0\n","  zlib               pkgs/main/linux-64::zlib-1.2.11-h7b6447c_3\n","\n","\n","Preparing transaction: - \b\b\\ \b\b| \b\bdone\n","Executing transaction: - \b\b\\ \b\b| \b\b/ \b\b- \b\b\\ \b\b| \b\b/ \b\b- \b\b\\ \b\b| \b\bdone\n","installation finished.\n","WARNING:\n","    You currently have a PYTHONPATH environment variable set. This may cause\n","    unexpected behavior when running the Python interpreter in Miniconda3.\n","    For best results, please verify that your PYTHONPATH only points to\n","    directories of packages that are compatible with the Python interpreter\n","    in Miniconda3: /usr/local\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"HeNudKnGpFCJ","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615719503182,"user_tz":-60,"elapsed":70704,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"236c477d-aa63-4fe1-b818-5c0c78e86bcb"},"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":1615719535015,"user_tz":-60,"elapsed":102530,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"ba292b01-9d53-43e8-ff51-8ea06e917018"},"source":["# clone repo\n","!rm -r protein-reconstruction\n","!git clone https://github.com/anonymous/protein-reconstruction.git\n","!cd protein-reconstruction"],"execution_count":4,"outputs":[{"output_type":"stream","text":["rm: cannot remove 'protein-reconstruction': No such file or directory\n","Cloning into 'protein-reconstruction'...\n","remote: Enumerating objects: 17, done.\u001b[K\n","remote: Counting objects: 100% (17/17), done.\u001b[K\n","remote: Compressing objects: 100% (14/14), done.\u001b[K\n","remote: Total 2972 (delta 3), reused 9 (delta 3), pack-reused 2955\u001b[K\n","Receiving objects: 100% (2972/2972), 746.34 MiB | 36.40 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":1615719639483,"user_tz":-60,"elapsed":206991,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"1e1a060d-6fd3-408f-a760-a030714a7cfd"},"source":["#!conda env create -f environment.yml \n","!conda install -q -y --prefix /usr/local -c conda-forge ipyvolume\n","#!pip3 install tensorflow-gpu==2.2.0\n","!pip install tensorflow-graphics"],"execution_count":5,"outputs":[{"output_type":"stream","text":["Collecting package metadata (current_repodata.json): ...working... done\n","Solving environment: ...working... done\n","\n","## Package Plan ##\n","\n","  environment location: /usr/local\n","\n","  added / updated specs:\n","    - ipyvolume\n","\n","\n","The following packages will be downloaded:\n","\n","    package                    |            build\n","    ---------------------------|-----------------\n","    argon2-cffi-20.1.0         |   py38h25fe258_2          47 KB  conda-forge\n","    async_generator-1.10       |             py_0          18 KB  conda-forge\n","    attrs-20.3.0               |     pyhd3deb0d_0          41 KB  conda-forge\n","    backcall-0.2.0             |     pyh9f0ad1d_0          13 KB  conda-forge\n","    backports-1.0              |             py_2           4 KB  conda-forge\n","    backports.functools_lru_cache-1.6.1|             py_0           8 KB  conda-forge\n","    bleach-3.3.0               |     pyh44b312d_0         111 KB  conda-forge\n","    bqplot-0.12.23             |     pyhd8ed1ab_0        1013 KB  conda-forge\n","    ca-certificates-2020.12.5  |       ha878542_0         137 KB  conda-forge\n","    certifi-2020.12.5          |   py38h578d9bd_1         143 KB  conda-forge\n","    cloudpickle-1.6.0          |             py_0          22 KB  conda-forge\n","    conda-4.9.2                |   py38h578d9bd_0         3.0 MB  conda-forge\n","    cycler-0.10.0              |             py_2           9 KB  conda-forge\n","    cytoolz-0.11.0             |   py38h25fe258_1         396 KB  conda-forge\n","    dask-core-2021.3.0         |     pyhd8ed1ab_0         702 KB  conda-forge\n","    decorator-4.4.2            |             py_0          11 KB  conda-forge\n","    defusedxml-0.7.1           |     pyhd8ed1ab_0          23 KB  conda-forge\n","    entrypoints-0.3            |  pyhd8ed1ab_1003           8 KB  conda-forge\n","    freetype-2.10.4            |       h7ca028e_0         912 KB  conda-forge\n","    icu-67.1                   |       he1b5a44_0        12.9 MB  conda-forge\n","    imageio-2.9.0              |             py_0         3.1 MB  conda-forge\n","    importlib-metadata-3.7.2   |   py38h578d9bd_0          24 KB  conda-forge\n","    ipydatawidgets-4.2.0       |     pyhd3deb0d_0         171 KB  conda-forge\n","    ipykernel-5.5.0            |   py38h81c977d_1         167 KB  conda-forge\n","    ipython-7.21.0             |   py38h81c977d_0         1.1 MB  conda-forge\n","    ipython_genutils-0.2.0     |             py_1          21 KB  conda-forge\n","    ipyvolume-0.6.0a6          |     pyh9f0ad1d_0         5.1 MB  conda-forge\n","    ipywebrtc-0.5.0            |   py38h32f6830_1         878 KB  conda-forge\n","    ipywidgets-7.6.3           |     pyhd3deb0d_0         101 KB  conda-forge\n","    jedi-0.18.0                |   py38h578d9bd_2         937 KB  conda-forge\n","    jinja2-2.11.3              |     pyh44b312d_0          93 KB  conda-forge\n","    jpeg-9d                    |       h36c2ea0_0         264 KB  conda-forge\n","    jsonschema-3.2.0           |     pyhd8ed1ab_3          45 KB  conda-forge\n","    jupyter_client-6.1.12      |     pyhd8ed1ab_0          79 KB  conda-forge\n","    jupyter_core-4.7.1         |   py38h578d9bd_0          72 KB  conda-forge\n","    jupyterlab_pygments-0.1.2  |     pyh9f0ad1d_0           8 KB  conda-forge\n","    jupyterlab_widgets-1.0.0   |     pyhd8ed1ab_1         130 KB  conda-forge\n","    kiwisolver-1.3.1           |   py38h82cb98a_0          86 KB  conda-forge\n","    libblas-3.9.0              |       8_openblas          11 KB  conda-forge\n","    libcblas-3.9.0             |       8_openblas          11 KB  conda-forge\n","    libgfortran-ng-7.5.0       |      h14aa051_18          22 KB  conda-forge\n","    libgfortran4-7.5.0         |      h14aa051_18         1.3 MB  conda-forge\n","    liblapack-3.9.0            |       8_openblas          11 KB  conda-forge\n","    libopenblas-0.3.12         |pthreads_hb3c22a3_1         8.2 MB  conda-forge\n","    libpng-1.6.37              |       h21135ba_2         306 KB  conda-forge\n","    libsodium-1.0.18           |       h36c2ea0_1         366 KB  conda-forge\n","    libtiff-4.0.10             |    hc3755c2_1005         602 KB  conda-forge\n","    lz4-c-1.9.2                |       he1b5a44_3         203 KB  conda-forge\n","    markupsafe-1.1.1           |   py38h8df0ef7_2          27 KB  conda-forge\n","    matplotlib-base-3.2.2      |   py38h5d868c9_1         7.1 MB  conda-forge\n","    mistune-0.8.4              |py38h25fe258_1002          54 KB  conda-forge\n","    nbclient-0.5.3             |     pyhd8ed1ab_0          67 KB  conda-forge\n","    nbconvert-6.0.7            |   py38h578d9bd_3         546 KB  conda-forge\n","    nbformat-5.1.2             |     pyhd8ed1ab_1          66 KB  conda-forge\n","    nest-asyncio-1.4.3         |     pyhd8ed1ab_0           9 KB  conda-forge\n","    networkx-2.5               |             py_0         1.2 MB  conda-forge\n","    notebook-6.2.0             |   py38h578d9bd_0         6.3 MB  conda-forge\n","    numpy-1.18.1               |   py38h8854b6b_1         5.3 MB  conda-forge\n","    olefile-0.46               |     pyh9f0ad1d_1          32 KB  conda-forge\n","    openssl-1.1.1j             |       h27cfd23_0         2.5 MB\n","    packaging-20.9             |     pyh44b312d_0          35 KB  conda-forge\n","    pandas-1.0.1               |   py38hb3f55d8_0        11.4 MB  conda-forge\n","    pandoc-2.12                |       h7f98852_0        12.4 MB  conda-forge\n","    pandocfilters-1.4.2        |             py_1           9 KB  conda-forge\n","    parso-0.8.1                |     pyhd8ed1ab_0          67 KB  conda-forge\n","    pexpect-4.8.0              |     pyh9f0ad1d_2          47 KB  conda-forge\n","    pickleshare-0.7.5          |          py_1003           9 KB  conda-forge\n","    pillow-6.2.1               |   py38h6b7be26_0         637 KB  conda-forge\n","    prometheus_client-0.9.0    |     pyhd3deb0d_0          44 KB  conda-forge\n","    prompt-toolkit-3.0.17      |     pyha770c72_0         244 KB  conda-forge\n","    ptyprocess-0.7.0           |     pyhd3deb0d_0          16 KB  conda-forge\n","    pygments-2.8.1             |     pyhd8ed1ab_0         736 KB  conda-forge\n","    pyparsing-2.4.7            |     pyh9f0ad1d_0          60 KB  conda-forge\n","    pyrsistent-0.17.3          |   py38h25fe258_1          89 KB  conda-forge\n","    python-dateutil-2.8.1      |             py_0         220 KB  conda-forge\n","    python_abi-3.8             |           1_cp38           4 KB  conda-forge\n","    pythreejs-2.3.0            |     pyhd8ed1ab_0         2.6 MB  conda-forge\n","    pytz-2021.1                |     pyhd8ed1ab_0         239 KB  conda-forge\n","    pywavelets-1.1.1           |   py38hab2c0dc_3         4.3 MB  conda-forge\n","    pyyaml-5.3.1               |   py38h8df0ef7_1         190 KB  conda-forge\n","    pyzmq-19.0.2               |   py38ha71036d_2         511 KB  conda-forge\n","    scikit-image-0.16.2        |   py38hb3f55d8_0        25.1 MB  conda-forge\n","    scipy-1.5.3                |   py38h828c644_0        18.7 MB  conda-forge\n","    send2trash-1.5.0           |             py_0          12 KB  conda-forge\n","    terminado-0.9.2            |   py38h578d9bd_0          26 KB  conda-forge\n","    testpath-0.4.4             |             py_0          85 KB  conda-forge\n","    toolz-0.11.1               |             py_0          46 KB  conda-forge\n","    tornado-6.1                |   py38h25fe258_0         646 KB  conda-forge\n","    traitlets-5.0.5            |             py_0          81 KB  conda-forge\n","    traittypes-0.2.1           |     pyh9f0ad1d_2          10 KB  conda-forge\n","    wcwidth-0.2.5              |     pyh9f0ad1d_2          33 KB  conda-forge\n","    webencodings-0.5.1         |             py_1          12 KB  conda-forge\n","    widgetsnbextension-3.5.1   |   py38h578d9bd_4         1.8 MB  conda-forge\n","    zeromq-4.3.3               |       he6710b0_3         500 KB\n","    zipp-3.4.1                 |     pyhd8ed1ab_0          11 KB  conda-forge\n","    zstd-1.4.5                 |       h9ceee32_0         619 KB\n","    ------------------------------------------------------------\n","                                           Total:       147.4 MB\n","\n","The following NEW packages will be INSTALLED:\n","\n","  argon2-cffi        conda-forge/linux-64::argon2-cffi-20.1.0-py38h25fe258_2\n","  async_generator    conda-forge/noarch::async_generator-1.10-py_0\n","  attrs              conda-forge/noarch::attrs-20.3.0-pyhd3deb0d_0\n","  backcall           conda-forge/noarch::backcall-0.2.0-pyh9f0ad1d_0\n","  backports          conda-forge/noarch::backports-1.0-py_2\n","  backports.functoo~ conda-forge/noarch::backports.functools_lru_cache-1.6.1-py_0\n","  bleach             conda-forge/noarch::bleach-3.3.0-pyh44b312d_0\n","  bqplot             conda-forge/noarch::bqplot-0.12.23-pyhd8ed1ab_0\n","  cloudpickle        conda-forge/noarch::cloudpickle-1.6.0-py_0\n","  cycler             conda-forge/noarch::cycler-0.10.0-py_2\n","  cytoolz            conda-forge/linux-64::cytoolz-0.11.0-py38h25fe258_1\n","  dask-core          conda-forge/noarch::dask-core-2021.3.0-pyhd8ed1ab_0\n","  decorator          conda-forge/noarch::decorator-4.4.2-py_0\n","  defusedxml         conda-forge/noarch::defusedxml-0.7.1-pyhd8ed1ab_0\n","  entrypoints        conda-forge/noarch::entrypoints-0.3-pyhd8ed1ab_1003\n","  freetype           conda-forge/linux-64::freetype-2.10.4-h7ca028e_0\n","  icu                conda-forge/linux-64::icu-67.1-he1b5a44_0\n","  imageio            conda-forge/noarch::imageio-2.9.0-py_0\n","  importlib-metadata conda-forge/linux-64::importlib-metadata-3.7.2-py38h578d9bd_0\n","  ipydatawidgets     conda-forge/noarch::ipydatawidgets-4.2.0-pyhd3deb0d_0\n","  ipykernel          conda-forge/linux-64::ipykernel-5.5.0-py38h81c977d_1\n","  ipython            conda-forge/linux-64::ipython-7.21.0-py38h81c977d_0\n","  ipython_genutils   conda-forge/noarch::ipython_genutils-0.2.0-py_1\n","  ipyvolume          conda-forge/noarch::ipyvolume-0.6.0a6-pyh9f0ad1d_0\n","  ipywebrtc          conda-forge/linux-64::ipywebrtc-0.5.0-py38h32f6830_1\n","  ipywidgets         conda-forge/noarch::ipywidgets-7.6.3-pyhd3deb0d_0\n","  jedi               conda-forge/linux-64::jedi-0.18.0-py38h578d9bd_2\n","  jinja2             conda-forge/noarch::jinja2-2.11.3-pyh44b312d_0\n","  jpeg               conda-forge/linux-64::jpeg-9d-h36c2ea0_0\n","  jsonschema         conda-forge/noarch::jsonschema-3.2.0-pyhd8ed1ab_3\n","  jupyter_client     conda-forge/noarch::jupyter_client-6.1.12-pyhd8ed1ab_0\n","  jupyter_core       conda-forge/linux-64::jupyter_core-4.7.1-py38h578d9bd_0\n","  jupyterlab_pygmen~ conda-forge/noarch::jupyterlab_pygments-0.1.2-pyh9f0ad1d_0\n","  jupyterlab_widgets conda-forge/noarch::jupyterlab_widgets-1.0.0-pyhd8ed1ab_1\n","  kiwisolver         conda-forge/linux-64::kiwisolver-1.3.1-py38h82cb98a_0\n","  libblas            conda-forge/linux-64::libblas-3.9.0-8_openblas\n","  libcblas           conda-forge/linux-64::libcblas-3.9.0-8_openblas\n","  libgfortran-ng     conda-forge/linux-64::libgfortran-ng-7.5.0-h14aa051_18\n","  libgfortran4       conda-forge/linux-64::libgfortran4-7.5.0-h14aa051_18\n","  liblapack          conda-forge/linux-64::liblapack-3.9.0-8_openblas\n","  libopenblas        conda-forge/linux-64::libopenblas-0.3.12-pthreads_hb3c22a3_1\n","  libpng             conda-forge/linux-64::libpng-1.6.37-h21135ba_2\n","  libsodium          conda-forge/linux-64::libsodium-1.0.18-h36c2ea0_1\n","  libtiff            conda-forge/linux-64::libtiff-4.0.10-hc3755c2_1005\n","  lz4-c              conda-forge/linux-64::lz4-c-1.9.2-he1b5a44_3\n","  markupsafe         conda-forge/linux-64::markupsafe-1.1.1-py38h8df0ef7_2\n","  matplotlib-base    conda-forge/linux-64::matplotlib-base-3.2.2-py38h5d868c9_1\n","  mistune            conda-forge/linux-64::mistune-0.8.4-py38h25fe258_1002\n","  nbclient           conda-forge/noarch::nbclient-0.5.3-pyhd8ed1ab_0\n","  nbconvert          conda-forge/linux-64::nbconvert-6.0.7-py38h578d9bd_3\n","  nbformat           conda-forge/noarch::nbformat-5.1.2-pyhd8ed1ab_1\n","  nest-asyncio       conda-forge/noarch::nest-asyncio-1.4.3-pyhd8ed1ab_0\n","  networkx           conda-forge/noarch::networkx-2.5-py_0\n","  notebook           conda-forge/linux-64::notebook-6.2.0-py38h578d9bd_0\n","  numpy              conda-forge/linux-64::numpy-1.18.1-py38h8854b6b_1\n","  olefile            conda-forge/noarch::olefile-0.46-pyh9f0ad1d_1\n","  packaging          conda-forge/noarch::packaging-20.9-pyh44b312d_0\n","  pandas             conda-forge/linux-64::pandas-1.0.1-py38hb3f55d8_0\n","  pandoc             conda-forge/linux-64::pandoc-2.12-h7f98852_0\n","  pandocfilters      conda-forge/noarch::pandocfilters-1.4.2-py_1\n","  parso              conda-forge/noarch::parso-0.8.1-pyhd8ed1ab_0\n","  pexpect            conda-forge/noarch::pexpect-4.8.0-pyh9f0ad1d_2\n","  pickleshare        conda-forge/noarch::pickleshare-0.7.5-py_1003\n","  pillow             conda-forge/linux-64::pillow-6.2.1-py38h6b7be26_0\n","  prometheus_client  conda-forge/noarch::prometheus_client-0.9.0-pyhd3deb0d_0\n","  prompt-toolkit     conda-forge/noarch::prompt-toolkit-3.0.17-pyha770c72_0\n","  ptyprocess         conda-forge/noarch::ptyprocess-0.7.0-pyhd3deb0d_0\n","  pygments           conda-forge/noarch::pygments-2.8.1-pyhd8ed1ab_0\n","  pyparsing          conda-forge/noarch::pyparsing-2.4.7-pyh9f0ad1d_0\n","  pyrsistent         conda-forge/linux-64::pyrsistent-0.17.3-py38h25fe258_1\n","  python-dateutil    conda-forge/noarch::python-dateutil-2.8.1-py_0\n","  python_abi         conda-forge/linux-64::python_abi-3.8-1_cp38\n","  pythreejs          conda-forge/noarch::pythreejs-2.3.0-pyhd8ed1ab_0\n","  pytz               conda-forge/noarch::pytz-2021.1-pyhd8ed1ab_0\n","  pywavelets         conda-forge/linux-64::pywavelets-1.1.1-py38hab2c0dc_3\n","  pyyaml             conda-forge/linux-64::pyyaml-5.3.1-py38h8df0ef7_1\n","  pyzmq              conda-forge/linux-64::pyzmq-19.0.2-py38ha71036d_2\n","  scikit-image       conda-forge/linux-64::scikit-image-0.16.2-py38hb3f55d8_0\n","  scipy              conda-forge/linux-64::scipy-1.5.3-py38h828c644_0\n","  send2trash         conda-forge/noarch::send2trash-1.5.0-py_0\n","  terminado          conda-forge/linux-64::terminado-0.9.2-py38h578d9bd_0\n","  testpath           conda-forge/noarch::testpath-0.4.4-py_0\n","  toolz              conda-forge/noarch::toolz-0.11.1-py_0\n","  tornado            conda-forge/linux-64::tornado-6.1-py38h25fe258_0\n","  traitlets          conda-forge/noarch::traitlets-5.0.5-py_0\n","  traittypes         conda-forge/noarch::traittypes-0.2.1-pyh9f0ad1d_2\n","  wcwidth            conda-forge/noarch::wcwidth-0.2.5-pyh9f0ad1d_2\n","  webencodings       conda-forge/noarch::webencodings-0.5.1-py_1\n","  widgetsnbextension conda-forge/linux-64::widgetsnbextension-3.5.1-py38h578d9bd_4\n","  zeromq             pkgs/main/linux-64::zeromq-4.3.3-he6710b0_3\n","  zipp               conda-forge/noarch::zipp-3.4.1-pyhd8ed1ab_0\n","  zstd               pkgs/main/linux-64::zstd-1.4.5-h9ceee32_0\n","\n","The following packages will be UPDATED:\n","\n","  ca-certificates    pkgs/main::ca-certificates-2020.10.14~ --> conda-forge::ca-certificates-2020.12.5-ha878542_0\n","  certifi            pkgs/main/noarch::certifi-2020.6.20-p~ --> conda-forge/linux-64::certifi-2020.12.5-py38h578d9bd_1\n","  openssl                                 1.1.1h-h7b6447c_0 --> 1.1.1j-h27cfd23_0\n","\n","The following packages will be SUPERSEDED by a higher-priority channel:\n","\n","  conda               pkgs/main::conda-4.9.2-py38h06a4308_0 --> conda-forge::conda-4.9.2-py38h578d9bd_0\n","\n","\n","Preparing transaction: ...working... done\n","Verifying transaction: ...working... done\n","Executing transaction: ...working... Enabling notebook extension jupyter-js-widgets/extension...\n","Paths used for configuration of notebook: \n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/bqplot.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/ipyvolume.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/ipywebrtc.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/jupyter-datawidgets.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/jupyter-threejs.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/plotlywidget.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/widgetsnbextension.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.json\n","Paths used for configuration of notebook: \n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/bqplot.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/ipyvolume.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/ipywebrtc.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/jupyter-datawidgets.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/jupyter-threejs.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/plotlywidget.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/widgetsnbextension.json\n","      - Validating: \u001b[32mOK\u001b[0m\n","Paths used for configuration of notebook: \n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/bqplot.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/ipyvolume.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/ipywebrtc.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/jupyter-datawidgets.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/jupyter-threejs.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/plotlywidget.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/widgetsnbextension.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.json\n","\n","done\n","Collecting tensorflow-graphics\n","  Downloading tensorflow_graphics-2020.5.20-py2.py3-none-any.whl (342 kB)\n","\u001b[K     |████████████████████████████████| 342 kB 7.4 MB/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 14.7 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 15.0 MB/s \n","\u001b[?25hCollecting h5py>=2.10.0\n","  Downloading h5py-3.2.1-cp38-cp38-manylinux1_x86_64.whl (4.5 MB)\n","\u001b[K     |████████████████████████████████| 4.5 MB 26.8 MB/s \n","\u001b[?25hRequirement already satisfied: networkx in /usr/local/lib/python3.8/site-packages (from tensorflow-graphics) (2.5)\n","Collecting termcolor>=1.1.0\n","  Downloading termcolor-1.1.0.tar.gz (3.9 kB)\n","Requirement already satisfied: numpy>=1.15.4 in /usr/local/lib/python3.8/site-packages (from tensorflow-graphics) (1.18.1)\n","Collecting psutil>=5.7.0\n","  Downloading psutil-5.8.0-cp38-cp38-manylinux2010_x86_64.whl (296 kB)\n","\u001b[K     |████████████████████████████████| 296 kB 56.3 MB/s \n","\u001b[?25hCollecting tensorflow>=2.2.0\n","  Downloading tensorflow-2.4.1-cp38-cp38-manylinux2010_x86_64.whl (394.4 MB)\n","\u001b[K     |████████████████████████████████| 394.4 MB 19 kB/s \n","\u001b[?25hRequirement already satisfied: tqdm>=4.45.0 in /usr/local/lib/python3.8/site-packages (from tensorflow-graphics) (4.51.0)\n","Requirement already satisfied: scipy>=1.1.0 in /usr/local/lib/python3.8/site-packages (from tensorflow-graphics) (1.5.3)\n","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 77.2 MB/s \n","\u001b[?25hRequirement already satisfied: matplotlib>=2.2.5 in /usr/local/lib/python3.8/site-packages (from tensorflow-graphics) (3.2.2)\n","Collecting OpenEXR>=1.3.2\n","  Downloading OpenEXR-1.3.2.tar.gz (10 kB)\n","Requirement already satisfied: six in /usr/local/lib/python3.8/site-packages (from absl-py>=0.6.1->tensorflow-graphics) (1.15.0)\n","Requirement already satisfied: setuptools in /usr/local/lib/python3.8/site-packages (from trimesh>=2.37.22->tensorflow-graphics) (50.3.1.post20201107)\n","Requirement already satisfied: decorator>=4.3.0 in /usr/local/lib/python3.8/site-packages (from networkx->tensorflow-graphics) (4.4.2)\n","Collecting gast==0.3.3\n","  Downloading gast-0.3.3-py2.py3-none-any.whl (9.7 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.1 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 wrapt~=1.12.1\n","  Downloading wrapt-1.12.1.tar.gz (27 kB)\n","Collecting typing-extensions~=3.7.4\n","  Downloading typing_extensions-3.7.4.3-py3-none-any.whl (22 kB)\n","Collecting tensorboard~=2.4\n","  Downloading tensorboard-2.4.1-py3-none-any.whl (10.6 MB)\n","\u001b[K     |████████████████████████████████| 10.6 MB 56.4 MB/s \n","\u001b[?25hCollecting flatbuffers~=1.12.0\n","  Downloading flatbuffers-1.12-py2.py3-none-any.whl (15 kB)\n","Collecting tensorflow-estimator<2.5.0,>=2.4.0\n","  Downloading tensorflow_estimator-2.4.0-py2.py3-none-any.whl (462 kB)\n","\u001b[K     |████████████████████████████████| 462 kB 76.3 MB/s \n","\u001b[?25hCollecting grpcio~=1.32.0\n","  Downloading grpcio-1.32.0-cp38-cp38-manylinux2014_x86_64.whl (3.8 MB)\n","\u001b[K     |████████████████████████████████| 3.8 MB 65.9 MB/s \n","\u001b[?25hCollecting keras-preprocessing~=1.1.2\n","  Downloading Keras_Preprocessing-1.1.2-py2.py3-none-any.whl (42 kB)\n","\u001b[K     |████████████████████████████████| 42 kB 1.5 MB/s \n","\u001b[?25hCollecting astunparse~=1.6.3\n","  Downloading astunparse-1.6.3-py2.py3-none-any.whl (12 kB)\n","Collecting protobuf>=3.9.2\n","  Downloading protobuf-3.15.6-cp38-cp38-manylinux1_x86_64.whl (1.0 MB)\n","\u001b[K     |████████████████████████████████| 1.0 MB 74.2 MB/s \n","\u001b[?25hCollecting opt-einsum~=3.3.0\n","  Downloading opt_einsum-3.3.0-py3-none-any.whl (65 kB)\n","\u001b[K     |████████████████████████████████| 65 kB 5.5 MB/s \n","\u001b[?25hCollecting future\n","  Downloading future-0.18.2.tar.gz (829 kB)\n","\u001b[K     |████████████████████████████████| 829 kB 75.2 MB/s \n","\u001b[?25hCollecting dill\n","  Downloading dill-0.3.3-py2.py3-none-any.whl (81 kB)\n","\u001b[K     |████████████████████████████████| 81 kB 12.1 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","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 5.4 MB/s \n","\u001b[?25hCollecting importlib-resources; python_version < \"3.9\"\n","  Downloading importlib_resources-5.1.2-py3-none-any.whl (25 kB)\n","Collecting promise\n","  Downloading promise-2.3.tar.gz (19 kB)\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: 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: pyparsing!=2.0.4,!=2.1.2,!=2.1.6,>=2.0.1 in /usr/local/lib/python3.8/site-packages (from matplotlib>=2.2.5->tensorflow-graphics) (2.4.7)\n","Requirement already satisfied: cycler>=0.10 in /usr/local/lib/python3.8/site-packages (from matplotlib>=2.2.5->tensorflow-graphics) (0.10.0)\n","Collecting google-auth<2,>=1.6.3\n","  Downloading google_auth-1.27.1-py2.py3-none-any.whl (136 kB)\n","\u001b[K     |████████████████████████████████| 136 kB 78.8 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 werkzeug>=0.11.15\n","  Downloading Werkzeug-1.0.1-py2.py3-none-any.whl (298 kB)\n","\u001b[K     |████████████████████████████████| 298 kB 76.6 MB/s \n","\u001b[?25hCollecting tensorboard-plugin-wit>=1.6.0\n","  Downloading tensorboard_plugin_wit-1.8.0-py3-none-any.whl (781 kB)\n","\u001b[K     |████████████████████████████████| 781 kB 72.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: urllib3!=1.25.0,!=1.25.1,<1.26,>=1.21.1 in /usr/local/lib/python3.8/site-packages (from requests>=2.19.0->tensorflow-datasets>=2.0.0->tensorflow-graphics) (1.25.11)\n","Requirement already satisfied: 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: chardet<4,>=3.0.2 in /usr/local/lib/python3.8/site-packages (from requests>=2.19.0->tensorflow-datasets>=2.0.0->tensorflow-graphics) (3.0.4)\n","Requirement already satisfied: idna<3,>=2.5 in /usr/local/lib/python3.8/site-packages (from requests>=2.19.0->tensorflow-datasets>=2.0.0->tensorflow-graphics) (2.10)\n","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 71.3 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 pyasn1-modules>=0.2.1\n","  Downloading pyasn1_modules-0.2.8-py2.py3-none-any.whl (155 kB)\n","\u001b[K     |████████████████████████████████| 155 kB 73.9 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 requests-oauthlib>=0.7.0\n","  Downloading requests_oauthlib-1.3.0-py2.py3-none-any.whl (23 kB)\n","Collecting pyasn1<0.5.0,>=0.4.6\n","  Downloading pyasn1-0.4.8-py2.py3-none-any.whl (77 kB)\n","\u001b[K     |████████████████████████████████| 77 kB 7.2 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 85.9 MB/s \n","\u001b[?25hBuilding wheels for collected packages: termcolor, OpenEXR, wrapt, future, promise\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=7ebc2cfa43ec987ee7959db2f75612ee07a3bccca938cb96938125ce8dc34a4d\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=209582 sha256=5d11b4a55e2b4cbe4a187929ec866920556350b8538aa64212933f7942345f47\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=78008 sha256=299a37b95858c0938872188495e84b4b57240e0ef122d6ab72fcb575474eab16\n","  Stored in directory: /root/.cache/pip/wheels/5f/fd/9e/b6cf5890494cb8ef0b5eaff72e5d55a70fb56316007d6dfe73\n","  Building wheel for future (setup.py) ... \u001b[?25l\u001b[?25hdone\n","  Created wheel for future: filename=future-0.18.2-py3-none-any.whl size=491059 sha256=e5b2f33b2217e65a20d39399c7d09eda06db1a05191e7776ec860a842d1aa5bc\n","  Stored in directory: /root/.cache/pip/wheels/8e/70/28/3d6ccd6e315f65f245da085482a2e1c7d14b90b30f239e2cf4\n","  Building wheel for promise (setup.py) ... \u001b[?25l\u001b[?25hdone\n","  Created wheel for promise: filename=promise-2.3-py3-none-any.whl size=21494 sha256=d62e7862a32cf8ac447875e9fa2164d9b212de1b981c758601c60d360242aefa\n","  Stored in directory: /root/.cache/pip/wheels/54/aa/01/724885182f93150035a2a91bce34a12877e8067a97baaf5dc8\n","Successfully built termcolor OpenEXR wrapt future promise\n","Installing collected packages: absl-py, trimesh, h5py, termcolor, psutil, gast, google-pasta, wrapt, typing-extensions, cachetools, pyasn1, pyasn1-modules, rsa, google-auth, oauthlib, requests-oauthlib, google-auth-oauthlib, protobuf, werkzeug, tensorboard-plugin-wit, markdown, grpcio, tensorboard, flatbuffers, tensorflow-estimator, keras-preprocessing, astunparse, opt-einsum, tensorflow, future, dill, googleapis-common-protos, tensorflow-metadata, importlib-resources, promise, tensorflow-datasets, OpenEXR, tensorflow-graphics\n","\u001b[31mERROR: After October 2020 you may experience errors when installing or updating packages. This is because pip will change the way that it resolves dependency conflicts.\n","\n","We recommend you use --use-feature=2020-resolver to test your packages with the new resolver before it becomes the default.\n","\n","tensorflow 2.4.1 requires h5py~=2.10.0, but you'll have h5py 3.2.1 which is incompatible.\n","tensorflow 2.4.1 requires numpy~=1.19.2, but you'll have numpy 1.18.1 which is incompatible.\n","tensorflow-metadata 0.28.0 requires absl-py<0.11,>=0.9, but you'll have absl-py 0.12.0 which is incompatible.\u001b[0m\n","Successfully installed OpenEXR-1.3.2 absl-py-0.12.0 astunparse-1.6.3 cachetools-4.2.1 dill-0.3.3 flatbuffers-1.12 future-0.18.2 gast-0.3.3 google-auth-1.27.1 google-auth-oauthlib-0.4.3 google-pasta-0.2.0 googleapis-common-protos-1.53.0 grpcio-1.32.0 h5py-3.2.1 importlib-resources-5.1.2 keras-preprocessing-1.1.2 markdown-3.3.4 oauthlib-3.1.0 opt-einsum-3.3.0 promise-2.3 protobuf-3.15.6 psutil-5.8.0 pyasn1-0.4.8 pyasn1-modules-0.2.8 requests-oauthlib-1.3.0 rsa-4.7.2 tensorboard-2.4.1 tensorboard-plugin-wit-1.8.0 tensorflow-2.4.1 tensorflow-datasets-4.2.0 tensorflow-estimator-2.4.0 tensorflow-graphics-2020.5.20 tensorflow-metadata-0.28.0 termcolor-1.1.0 trimesh-3.9.8 typing-extensions-3.7.4.3 werkzeug-1.0.1 wrapt-1.12.1\n"],"name":"stdout"},{"output_type":"display_data","data":{"application/vnd.colab-display-data+json":{"pip_warning":{"packages":["google"]}}},"metadata":{"tags":[]}}]},{"cell_type":"code","metadata":{"id":"VZDmNWzdK4KO","executionInfo":{"status":"ok","timestamp":1615719639485,"user_tz":-60,"elapsed":206991,"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":1615719639685,"user_tz":-60,"elapsed":207185,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"9e4703aa-548d-4b59-e2ca-8ad6c653e516"},"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":1615719644549,"user_tz":-60,"elapsed":212047,"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":1615719644551,"user_tz":-60,"elapsed":212043,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"7eb6600c-71d3-4f92-f5cd-4ce08856cdd4"},"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":1615719649860,"user_tz":-60,"elapsed":217344,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"9ff76f62-62dd-409d-c75a-a02bbf2ea876"},"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: 10076590452824651843\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: 16226616021479529496\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":1615719649861,"user_tz":-60,"elapsed":217343,"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 = 16\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":1615719650144,"user_tz":-60,"elapsed":217620,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"fc38cdb9-0811-43a9-cc68-584afb2792f7"},"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":1615719650145,"user_tz":-60,"elapsed":217615,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"4fed3727-24dc-4352-f26d-569a4ead75d9"},"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":1615719650429,"user_tz":-60,"elapsed":217892,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"453e4e84-7622-46e0-f853-7b1ec02597ba"},"source":["sampleProj = projections[1,:,:]\n","plt.imshow(sampleProj,cmap='gray')\n","plt.show()"],"execution_count":14,"outputs":[{"output_type":"display_data","data":{"image/png":"iVBORw0KGgoAAAANSUhEUgAAAQYAAAD+CAYAAADYg6v8AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nO2de2jd9f3/n+d+y+X09BJjqy26VSIFiw0rDMawlVa2WPeHrK6zG6iTIW76h7pOWNvZzS3WiYW2Vsf4gkOUCaPODKwwy2CyuZZZIaurrlbNaNqkJznNuZ+cz/n8/ujv+e77nE+vJmnSk+cDDknO9R2S9/Pzur99ruu6EEIIC/90L0AIMfOQMAghPEgYhBAeJAxCCA8SBiGEBwmDEMLDlArDsWPHsH79eqxduxbr16/Hp59+OpUfJ4SYJKZUGLZs2YINGzZg37592LBhAzZv3jyVHyeEmCR8U1XglE6nsXbtWrz33nsIBAJwHAcrV67E22+/jVQqdcHXlkol9Pf3Y/78+QgEAlOxPCFmNY7jYHh4GMuWLUM0GvU8HpyqDx4cHERHR4fZ2IFAAAsWLMDg4OBFhaG/vx/f/e53p2ppQoj/zyuvvILu7m7P/VMmDBNh/vz5AIDPP/8c1Wp1mlcjRPMRDAZx/fXXm73meXyqPrizsxMnT56E4zjGlRgaGkJnZ+dFX0sro1qtShiEmELO56pPWfBx7ty56OrqQl9fHwCgr68PXV1dF3UjhBDTz5S6Elu3bsWmTZuwe/dutLW1obe3dyo/TggxSUypMNx44414/fXXp/IjhBBTgCofhRAeJAxCCA8SBiGEBwmDEMKDhEEI4UHCIITwIGEQQniQMAghPEgYhBAeJAxCCA8SBiGEBwmDEMKDhEEI4UHCIITwIGEQQniQMAghPEgYhBAeJAxCCA8SBiGEBwmDEMKDhEEI4UHCIITwIGEQQniQMAghPEgYhBAeJAxCCA8SBiGEBwmDEMKDhEEI4WFCp12Pjo7iiSeewOeff45wOIzFixfjqaeeQiqVwqFDh7B582aUy2UsXLgQ27dvx9y5cydr3UKIKWRCFoPP58MDDzyAffv24c0338R1112HZ599FrVaDY8//jg2b96Mffv2obu7G88+++xkrVkIMcVMSBiSySRWrlxpfl6+fDmOHz+O/v5+RCIRdHd3AwDuuecevPXWWxNbqRDiijFpMYZarYZXX30Vq1atwuDgIK699lrzWCqVQq1WQyaTmayPE0JMIZMmDNu2bUM8Hse99947WW8phJgmJhR8JL29vfjss8+wZ88e+P1+dHZ24vjx4+bxkZER+P1+JJPJyfg4IcQUM2GL4bnnnkN/fz927dqFcDgMAFi2bBlKpRIOHjwIAHjttddwxx13TPSjhBBXiAlZDB9//DFefPFFLFmyBPfccw8AYNGiRdi1axeeeeYZbNmypS5dKYS4OpiQMHz5y1/GkSNHzvnYrbfeijfffHMiby+EmCZU+SiE8CBhEEJ4kDAIITxIGIQQHiQMQggPEgYhhAcJgxDCg4RBCOFBwiCE8CBhEEJ4kDAIITxIGIQQHiQMQggPEgYhhAcJgxDCg4RBCOFBwiCE8CBhEEJ4kDAIITxIGIQQHiQMQggPEgYhhAcJgxDCg4RBCOFBwiCE8CBhEEJ4mJTTrsXswefz1d0AwHVd85U3cXUjYRCXDIXA7/fD5/OZr7VaDa7rolarmedKHK5uJs2V2LlzJ2666SZ89NFHAIBDhw5h3bp1WLt2Le677z6k0+nJ+ihxhaEIBINBRCIRJBIJtLe3I5VKYe7cuZg7dy5SqRRaW1uRSCQQDocRCoWMcIirj0kRhn//+984dOgQFi5cCACo1Wp4/PHHsXnzZuzbtw/d3d149tlnJ+OjxDTh8/kQCASMOMRiMSQSCbS0tCCRSCCRSCAWiyEajSIUCiEYDBphkDhcfUzYlahUKnjqqafwm9/8Bt/73vcAAP39/YhEIuju7gYA3HPPPVi9ejV+9atfTfTjxASwN6nff+aaQJOfbkCjC+D3+xEIBBAKhczGnzNnjrEawuEwHMdBrVbD6dOnUSqVkMlkUKlUkMvlUK1WUalUUKvV6lwNMbOZsDDs2LED69atw6JFi8x9g4ODuPbaa83PqVQKtVoNmUwGyWRyoh8pvgAUhcb4gB0sbPzK19BSCIfDdZZCMplENBqF67qoVqvw+/0olUqoVqsolUoYHx+Hz+eD4zjmfRV7uDqYkDC8//776O/vx2OPPTZZ6xGTDEUgEAggEAggEokY/9/v95ugITd0pVIx99mWAi2EtrY2dHR0IJlMYuHChUgkEggEAqjVakin08jlcmhtbUU+n8fw8DDy+TxGR0dRqVRQLpeNdSFmNhMShgMHDuDo0aNYvXo1AODEiRO4//77sXHjRhw/ftw8b2RkBH6/X9bCNGAHDsPhMKLRKCKRCILBoLEYeEWvVqt1Jj8FhXGFaDRaZzEwvhAOh1Gr1eA4DoLBIHK5HAKBAPL5PGq1GorFIgCYzwFkPcx0JiQMDz74IB588EHz86pVq7Bnzx586Utfwh/+8AccPHgQ3d3deO2113DHHXdMeLHi8qAbEI1GkUgk0NbWhng8bjZ2OBxGuVzG+Pi4iQ+cOnXKXN1pYcTjcSSTSSSTSZONYEaipaUFkUgEPp8PLS0tKBaLCIfDyGQyAIBsNmvEgp8xPj5uRGiqBKIx4CkRujympI7B7/fjmWeewZYtW1Aul7Fw4UJs3759Kj5KXAAKQygUQjQaRUtLC9rb29He3o6WlhaEQiGMj49jfHwcfr8f+XwehULBuAa2C8L3A85e7WldMBYRCoXgOA6i0agRILoptVoN1Wq17n1oZUxmYZRdfEVXqfEmLs6kCsM777xjvr/11lvx5ptvTubbi8uAohAOh9HS0oJUKoXOzk5cd9116OjoMC7A+Pg4KpUKBgYGcPr0aQBALpczG4guBzc24xDlchnFYrHO3aAItbS0wOfzoVKpIB6PIxgMIhaLIRaLIZPJIJ/PG8vBjjucKxD6RX5vxlCCwaARL8dxJl2EmhlVPjYpdkaBAcTW1la0tbWZIGIkEkG5XEalUkGhUDAuQDAYNFd5AHXxCFsYSqWSER/HceD3+z1By1qtVpeuHB8fN2ukJeI4DqrVal28o7HM+lycK7VKQWBMhYJGYaAIUSTEuZEwNDHcJLFYDG1tbViwYAHmz59vbvF4HPl8HpVKBaFQCGNjYygUCjh9+rSxDkqlkrEGuMmLxSICgQDi8bhxOUKhECKRCFzXNWLR1taGcDhsbix64vflchnBYBCO46BcLhvhsK/q54pD2K6IfT9/XxZZxeNxIzq80UKx31t4kTA0Kbafbd9o9gNnrrj8PpFIAADmzp1rgoWVSgWRSMRYALwSszahXC7D5/MZi8F13bq6hXA4bNbDYCPjDABMdqRarRqBsNOldg+G67qeSsrx8fG6LArXaZdk8zX2783gp1yK8yNhaGLsYqZAIFC3QbjhaA20tLQgGAyio6MDkUgE2WzWuAt8PaslGdQrFotwHAfhcNhsNG5aCgY3K1/HlGYwGESlUjGvZZVkKBTyBCXtVCg3OwDz+fzsYDBoLBd+BgDz+9qFW3RvxLmRMDQxvJrSRC+VSqhUKuZKC5z185mlaG1tRa1WQ1tbG0qlEgDUCYPdUVkul1GtVs3mZ5zBDnwCZzYiNyqrJWOxGMrlMkKhEMrlsllvpVIx6+dGZlyALghjEXbJtb1OCgjfo9EqUADy4kgYmhT7n9/2s5mepHluBygDgQASiQSq1SpaWlrg9/tRqVTqrI5QKIRKpWJcCQoBTXdaJnQ5bFHhxo7H46aGghseOGPi83vb3aHVEIlEjIXBFGulUjECBsDjKvG16vS8PCQMTQx9+lKphHw+j0wmg3Q6bfxwe5PaV2VWSNqWheM4xlJwHAfj4+N15j5jEBQP3seNSb+eJdnc4LQYGChkf0U0GgUAk+lwXde4JtlsFsVisc664HO5+SmGjHfwPUqlUl0AUpwbCUOTYlsLdCMKhQJyuRyy2Wxdk1MgEDDBPV5xaUHwvSgIfr/fbDhmEPg+lUrFWArA2eCgXWpNF4OxBNd1UalUzPvSEohGo8bS4O9i11TwZ2YigPr0J7/yuUxVKvB4aUgYmhheqQuFAsbGxow1AMBUJfp8PsRiMZOOBM6Y8YlEwmz0YrGIfD5vTHmKBF0GpgcBGJ/f7/ejUCgAQF1QMhqNwufzmTqKzs5O07LNtZ4rNQmcbRWntXK+OILtMlEQKGaVSsUIlTg/EoYmxfavWd1YLBaN1ZDL5UwPBf13wniAbTWwrdreqLyi22XT/Dyfz4dqtepJmwIwrgLdGF71maXgRuZzG38v223he9qPNxY0Mb5iFzjJWrgwEoYmxo4x0CT3+XymqvHUqVMYGxtDS0sL5s2bh1gshng8Dr/fj0QigfHxccyZMwcAkM/nTY1CYxqU1gO/z+fzAGAyEXZXZltbG1paWszX9vZ2+P1+tLS0oFwuI5PJmHJru0aBLgcFih2fdi0DLRlmXkqlUp042M8TF0bC0OTQamDVX6FQQDAYRDabBQC0trYCANrb242vbrdqh0Ihc4VubFCym6oaS5oJYwq0ENj2TWuENwYq6eo0XuH51XYDGA9hT0SjVWPHRuyCKXFxJAxNDjcRU4Ou65q6gXw+j2g0CsdxkEqlTFzA3kCBQACxWAxz5swxPjs3MzcpLQRuSpr5kUgE7e3t6OjoMH0advERaxH8fr+piWAQlC4F4w75fN5kIgqFgmkLj0aj5rnFYtGsyefzoVgsGrGSpXB5SBhmAfaVkyY2eyAYWOTmtmMFjAUwzcjMA2sVmCFgdoKC0Dg1ig1NtqXQeFVnHICi1JhhaEyT2s1a/J4ZEmYeKD7i8pEwzAJ41WRAcnx8HKFQCNVqFcPDw6ZLMh6PY/78+Wa2YygUwrx58xAOh+G6LvL5vKkrsK++9OWj0ajx/dlYZZclx2KxOjfEbobi1Z6BSzvwaW962yrgvEneYrEYxsfHjRixzsEeDCMuDQnDLMFuTLKrFjOZjBGKeDwOAMZ1aIwBsCiJ2Qa6G0xhNmYK7Ks8X0ehsC0KVibaAVLGDewshF2STYHie9FiobVBd8W2TsSlI2GYRTBIWKvVTPVguVxGOBzGyMgI4vE4MpkM2traUKvVEI/H0draimAwaHoo6ErYG5g/06RnoJJuS7FYNDfWTNgzE1zXNelSvi/vDwQCpjKSLhD7MpiRoGhQBJitYNm1HTRV8PHSkDDMQuzuxWKxWFe5GA6HUalUzCEyjCPwqs4ZDK7rGguDPj9bpu0OS34esyJ2hoPi4LquqXS005N8X7ol7Jyk62PXRdjf2xZCo+siYbg0JAyzDG4MigFLkGk51Go1M+W5vb3d+Pu88TkA6jaz4zgYGxszdRM2DFCWy2WTlbAbt1g3wXQj38OusORns/qS9QoA6kSCwcZGoZA4XB4ShlkMN0hjcRCbrmjSJxIJtLa21s1SZCcmS6Ftq4HvyS7MYrFohIVuRyKRMAFJvh8rNBs3Lq2LeDxeV2TFgCR/l3ONcLMtEHHpSBhmOfbMA7/fX1c+DZzNCHCoq9/vN1d9jqBnxSMrLO0ybAoDi6XoRthuRSQSMXEBnkXBjQ/Uj6hjtoECwXoKuwDKzkLYmQiJw6UjYZjl0MRmb0QsFqubecDYAN0Du/6A5c50L5LJpAkOlsvluolJdnUi39d+LBKJGIuFKUlmP+zCKb6GwlUoFExmhYVPvNmzHs81O1KcHwnDLKex/NmekmQHAFkf0JhitIfAMuZg92Twe/s4PF7F+ZUxBFoFLI224wHMUDAYyrmU3PRMwXLqtW1F6Fi8y0fCIACcHb1uVx7aY9LsGwWkcYoTr+gsZLJ9fvuIu2g0aoSiVCp5Jj7FYjF0dHR4aiCYXmWpc6VSMTeevWl3U1IgNMrt8pEwiDrskW/nape2p03bAT/7+axPsPsd7IYsBjEBGEuE2RHez3Zwe7NzfY2TpGxXgV9ti0GCcPlIGGY53DisZ2C60M4gcAPy9CrGI/hYJpPxXJHZSk3XgcKQSCQQj8dNNmN0dBQ+nw/5fB7hcBjt7e2IRCLmNKtAIGDaqCkqQ0NDKBaLGBsbw9jYmAly8rNoWdhDWSQOl4eEQdT5/nbq0m5a4lcAdfUAja3Q3Mx0OSgY9sg4+2QruxbBvuLb78OYh32uRWMg0z63ojHGIDfi8pEwzHK4Cbl5Gg90sU+lss+m4M0OUDJ9yLqExq92zIIdmWwBZ3yiUCgY18Se78BiLODswTLMYoyNjZlZE+Vy2RyWY7eai8tDwiDqsEfC0bdngM+O+jM2YD+3sYvTPl+C39sl1raVYYsRgLp6CK6LE55ti8BOpxYKhbq2a1kKX5wJC0O5XMbTTz+Nv//974hEIli+fDm2bduGY8eOYdOmTchkMkgmk+jt7cWSJUsmYcliKuAmYu1A4xmP9kg3uyYhFArV9UTQGuB7smKR79Po93NGA10MzocYHh42Lgw3Pt2ZdDpt5lYWCgWMjo6aWZZ8PtcsvhgTFobt27cjEolg37598Pl8OHXqFABgy5Yt2LBhA+666y688cYb2Lx5M15++eUJL1hMPraVwOg/S5PtA1z4XLuy0TbVeYycXbYcDAaNUNjWAjMYdqk0cNZiaBxHl8/nUS6XjXvDiU52oNEOQspSmBgTEoZ8Po+9e/fir3/9q7lqzJs3D+l0GocPH8b//d//AQB6enqwbds2jIyMIJVKTXzVYtKxi4BoEdAFsE+qBs6OZ2c/BeMFdgemXT3JmQq8j0NdOAPCbt22x7sxwzA2NoaRkREjBrQQhoeHcfr0aeRyOePmaITb5DAhYRgYGEAymcTOnTvx3nvvIZFI4JFHHkE0GkVHR0fdBJ4FCxZgcHBQwjBDsRuq7KGq9gxF1i80mun2wTKMI/A97FQl5zWwQ5KWCDMgAOpGw9GtsbszOYYul8shn88bF0NpycllQsLgOA4GBgZw88034yc/+Qk++OAD/PCHP8SOHTsma33iCmLHGHjlZfTfzioAZ6c4M7Ngi0W5XDYuBNORnB05Z84cUw9hfw6FhGXV9iG5XBfjD6Ojozh9+jQymYxxJTS6bXKZkDB0dnYiGAyip6cHAHDLLbdgzpw5iEajOHnypPmHchwHQ0ND6OzsnJRFiytD49ATlkAzlsCru52utJuseJVnd2VjlgJA3fuxZ4L3c/oTA5b2MXu5XK7uHEqJwuTiv/hTzk8qlcLKlSvx7rvvAgCOHTuGdDqNJUuWoKurC319fQCAvr4+dHV1yY24irDHoXET2/MauCntY+Bsl4DFSwwe2kNe2aoNwGx+e1QcG7Ds9CRFKZ/PI5vNYmxsDMVi0QyilQsxuUw4K/Hzn/8cTz75JHp7exEMBvHMM8+gra0NW7duxaZNm7B79260tbWht7d3MtYrphC7eCkWi5nSZE5/ZiVirVYzE5aAsydh87WMRXCKs50poBVRKBRMcRLFxJ7lyKDiyMgIRkdHMTo6ipGREaTT6bqAo+oVpoYJC8N1112H3//+9577b7zxRrz++usTfXtxhaBlwDiC3Q1pj2Njw5M9iIWvZ8v0uU6DspucmNFgzIBt1vbBs5lMBvl8HmNjY8ZC4NdCoVDXTSlRmHxU+SgMPAEqEomgtbUV0WgUra2taG1tRTKZNL0KrF9gRuBcB80AMDURAEx8gNOgubk5ZGVsbKzuLMxCoYBsNotTp04hnU5jeHgYIyMjOH36tLE2JApTh4RBADg7manRYuAgFh4iQ2uALkLjeZH298xwsJ6BtQbMWHC8vD0himnKSqWCbDaLTCaD0dFRZDIZM/Ke6VGJwtQhYRAG2/zn1ZidjZVKpW7cO3D2wFoWNNmxCPsMC8dxTDNWrVarK3Gm5WBPheaJ2blcDqdOncLp06cxOjqKUqlUV90opg4Jg6jDvgo3lkrb5zewnJnuh905ab/eboUOBAIoFAqmn4KWhH30HIOP2WwWuVwO2WzWdE3a51aKqUXCIOqgm0DTP5fLmawDB7RwdHwikfC83jbxbWFhsLFUKiESiZiYBFummWXIZrMm+FgqlcwgFsY1JApXBgmDAIC6QiYAdTEEZiDsxic7NdmYMrSnQzcOgAVQd2I2m6NYyETxoJWgKUzTg4RB1M1rbDyUlr5/rVYzx9OxRqGlpQWhUMicBcGp0PaMSHvCEk+rsg+EoQtRKBRQrVbNkJV8Pl/XhCVRuLJIGGYp9vmSdnESA4zMLtij3uyNysYqVjPafQ12/4P9lYFHuin2UXSc3MT6BLtGQaJw5ZEwzDLsMufGkfD2aU921WJjStI+5xIAIpGIZ+ITN7ld+UgBYMaB2Qn75Go7kwHo9KjpQsIwi2gc/86vTDty7DtTjvbm5LQmO6DIqdL2z3amwR7kYp9taZ8WRRGxG7FkJUw/EoZZRuO0ZooALYVYLOYpUuLGDYfDdSdUcePzKs+rPzc8LQbb8mBwkUHHxilQEoSZgYRhltBoLVAU7NoDWgb2mDW7ItHupKQQ+Hw+c9VnBoFfi8Vi3QEw7JE413AVCcLMQsIwSzhfkLExC2FfvWn28/XhcBixWMyIA+dCsq2a9zOwaNcesBaBaUkVK81sJAyzBDsdaU9lpttgT3oGzhYn2dkLlkYXCoW6uAEzCXQlisWiCSja8QfebKtDzEwkDLMAOxNxPjfCFgSgfg4jX8s4AQXAtgZYi8DyZj7XHktvC4Jch5mNhKHJscWALdWRSASJRMIMaLXHxnPsmn0MXOP78MoPoM5iyOfzJi5hv9bOZCiecHUgYWhybBfCthZCoRCi0agJIHKz0oqwj59rLJdmAVLjz+eKLQDexiwx85EwNDGN1gLbou1Jz3ars13oFA6HAaBOUFibUCwWAcBMaGY587lcCHF1ImFoYuzhKfaN2OY9n08hYEu1LSy0LphqtCsdaTVQECQKVzcShiancQS8PR+BlgNnKtgl0fzZtjKi0aixGjh5iQVLFApA7kIzIGFoYi529eaRchzbbt/so+5pNdDC4HvbbogyDc2FhKHJoYXA8yhpHdgj3u1eCVoIfI5d58BUJa2Gc5U0i+ZAwjALsIuV7AAjYwn218ahrvZhM4wpnEsIJAzNhYShybFnJ/BsyJaWFhNL4P38HjhbGs3UJVuo7SPhANQFM+2Up7j6kTA0IY3zFli3wJRlPB43LgPgrTOwg5Vsq2ZjFd/fjj3wORKG5kHC0GTYgmDXJMTjccTjcSSTSaRSKTOQlb0L9gg3Vj02jmmjVUGh4YAWtler96F5kDA0Gdy4DCzy8JhYLIZEInHO4+bsK71tLfC9CFOc9gj5xgClrIbmQMLQRHBz8ooej8dNpqGlpQWtra2IxWJ1nZUAzusG+P1+RCIRY4WUSqW6WAQzG421EuLqZ8LCsH//fuzYscP8cz388MNYs2YNjh07hk2bNiGTySCZTKK3txdLliyZhCWLC3G+gSyMEdh1Bz6fz/Q30A3gfIbGKkng7CCXYrGIXC5nRryrhbr5mJAwuK6LJ554Aq+88gqWLl2K//znP/jOd76D22+/HVu2bMGGDRtw11134Y033sDmzZvx8ssvT9a6xQWwG6coDPbxc3bXI2MMjCfYsyAbhYE1EXbFo324rNyI5sF/8adc5A38fmSzWQBANpvFggULMDo6isOHD6OnpwcA0NPTg8OHD2NkZGSiHycuQKMghMNhU7hEceDkpWKxiEKhYG6NqUi77Zo3WgUcwmIPXpHF0FxMyGLw+Xx4/vnn8dBDDyEejyOfz+Oll17C4OAgOjo6jPkaCASwYMECDA4OIpVKTcrChZfGg2MYR7CPqWcZMxuhKAZss7bfC4DpugRQl6WwRUPWQvMxIYuhWq3ixRdfxO7du7F//3688MILePTRR1EoFCZrfeISsQUhGo0iFoshHo+bMyaZnmQGgY1ULFyybxQLW0B4tgSHvbCUWkHH5mRCFsOHH36IoaEhrFixAgCwYsUKxGIxRCIRnDx50lyJHMfB0NAQOjs7J2XR4tzYVYyNDVF2WhGob4KypzRREDigxY4/0F2wR8WJ5mRCFsM111yDEydO4JNPPgEAHD16FOl0GosXL0ZXVxf6+voAAH19fejq6pIbMcU0bn7bHWBFI10AWgIA6twOWgk8+2FsbAzDw8MYGBjA8ePHcfLkSYyNjZm5j3IjmpMJWQzz58/H1q1b8cgjj5h/wqeffhrJZBJbt27Fpk2bsHv3brS1taG3t3dSFiwujn36E6E1QezH7boE+z0AmDhEoVAwI+AbU5yi+ZhwHcO6deuwbt06z/033ngjXn/99Ym+vbgMaA3wau44Tl12Ih6PG7eCU5eAs4Na2H7N57BUOpvNGiuBR9TzbAiJQ3Oiyscmwj7Dga4DB6z4/f66qzyFIRAImDkNjYNZgLPuiT35SSdRNz8ShibBnt9YKBTg8/lQLBYRCoXM6VG0AhhHcBwH8Xi8biYDbxzjxiPo+FoeY880pWhOJAxNhH0FtwOQDDYWCgVP/YF9GlUjdC3O11shYWheJAxNROM5DrQg7LFstihwroI999F+PV2KUqmEWCyGXC5XJw6ieZEwNCH2kfJ0G+zBraxRYPqy0YpoPJqO/RAKNM4eJAxNTOORcJyXUKvVjKVAQaCAMJ7AI+gAmOPsAVkKswUJQ5NjT1ayB6lQMCgGTEHaLgafWygUkM1mzaG1mgrd/EgYZgG2GNj32VWQhUIBwWDQU/RUq9VQKBSQz+dNjEIuRfMjYZilUCR4LgQrI7npGYis1Wool8ue2QuiuZEwzFK4uW3XgK6Gz+dDKBTyuBsqapo9SBhmMZzmxA5LWxjK5bJ5HjMaEoXZg4RhlmOPiyeNLdUqaJp9SBiEjpsTHiY881EI0XxIGIQQHiQMQggPEgYhhAcJgxDCg4RBCOFBwiCE8CBhEEJ4kDAIITxIGIQQHiQMQggPEgYhhAcJgxDCg4RBCOFBwiCE8CBhEEJ4uKgw9Pb2YtWqVbjpppvw0UcfmfuPHTuG9evXY+3atVi/fj0+/fTTS3pMCHEV4F6EAwcOuMePH3dvu+0298iRI+b+jU1/XpUAAAbCSURBVBs3unv37nVd13X37t3rbty48ZIeuxQGBgbcpUuXusFg0AWgm266TfItGAy6S5cudQcGBs65By9qMXR3d6Ozs7PuvnQ6jcOHD6OnpwcA0NPTg8OHD2NkZOSCjwkhrg6+0MzHwcFBdHR0IBAIADhz+OmCBQswODgI13XP+1gqlZq8lQshpgwFH4UQHr6QxdDZ2YmTJ0/CcRwEAgE4joOhoSF0dnbCdd3zPiaEuDr4QhbD3Llz0dXVhb6+PgBAX18furq6kEqlLviYEOIq4WIZgm3btrlf+9rX3K6uLverX/2q+41vfMN1Xdf973//6959993umjVr3Lvvvts9evSoec2FHlNWQjfdpv92sayEz3Vn3uki//vf/7B69Wp88sknqFar070cIZqOYDCIG264AX/5y1+waNEiz+MKPgohPEgYhBAeJAxCCA8SBiGEBwmDEMKDhEEI4UHCIITwIGEQQniQMAghPEgYhBAeJAxCCA8SBiGEBwmDEMKDhEEI4UHCIITwIGEQQniQMAghPEgYhBAeJAxCCA8SBiGEBwmDEMKDhEEI4eELnUQ11TiOA+DMiGshxOTDvcW95nn8Si7mUhkeHgYAXH/99dO8EiGam+HhYSxevNhz/4w8cKZUKqG/vx/z5883p2YLISYPx3EwPDyMZcuWIRqNeh6fkcIghJheFHwUQniQMAghPEgYhBAeJAxCCA8SBiGEBwmDEMKDhEEI4WFGCsOxY8ewfv16rF27FuvXr8enn356xdcwOjqKH/zgB1i7di3uvPNOPPzwwxgZGQEAHDp0COvWrcPatWtx3333IZ1OX/H17dy5EzfddBM++uijGbGmcrmMLVu2YM2aNbjzzjvxs5/9DMD0/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":1615719650431,"user_tz":-60,"elapsed":217892,"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":1615719650433,"user_tz":-60,"elapsed":217893,"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":1615719655793,"user_tz":-60,"elapsed":223251,"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":1615719655796,"user_tz":-60,"elapsed":223248,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"e3e7e766-6ae3-458d-f4be-91d37be53774"},"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":"iVBORw0KGgoAAAANSUhEUgAAAQYAAAD+CAYAAADYg6v8AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nO2de2jd9f3/n+d+y+X09BJjqy26VSIFiw0rDMawlVa2WPeHrK6zG6iTIW76h7pOWNvZzS3WiYW2Vsf4gkOUCaPODKwwy2CyuZZZIaurrlbNaNqkJznNuZ+cz/n8/ujv+e77nE+vJmnSk+cDDknO9R2S9/Pzur99ruu6EEIIC/90L0AIMfOQMAghPEgYhBAeJAxCCA8SBiGEBwmDEMLDlArDsWPHsH79eqxduxbr16/Hp59+OpUfJ4SYJKZUGLZs2YINGzZg37592LBhAzZv3jyVHyeEmCR8U1XglE6nsXbtWrz33nsIBAJwHAcrV67E22+/jVQqdcHXlkol9Pf3Y/78+QgEAlOxPCFmNY7jYHh4GMuWLUM0GvU8HpyqDx4cHERHR4fZ2IFAAAsWLMDg4OBFhaG/vx/f/e53p2ppQoj/zyuvvILu7m7P/VMmDBNh/vz5AIDPP/8c1Wp1mlcjRPMRDAZx/fXXm73meXyqPrizsxMnT56E4zjGlRgaGkJnZ+dFX0sro1qtShiEmELO56pPWfBx7ty56OrqQl9fHwCgr68PXV1dF3UjhBDTz5S6Elu3bsWmTZuwe/dutLW1obe3dyo/TggxSUypMNx44414/fXXp/IjhBBTgCofhRAeJAxCCA8SBiGEBwmDEMKDhEEI4UHCIITwIGEQQniQMAghPEgYhBAeJAxCCA8SBiGEBwmDEMKDhEEI4UHCIITwIGEQQniQMAghPEgYhBAeJAxCCA8SBiGEBwmDEMKDhEEI4UHCIITwIGEQQniQMAghPEgYhBAeJAxCCA8SBiGEBwmDEMKDhEEI4WFCp12Pjo7iiSeewOeff45wOIzFixfjqaeeQiqVwqFDh7B582aUy2UsXLgQ27dvx9y5cydr3UKIKWRCFoPP58MDDzyAffv24c0338R1112HZ599FrVaDY8//jg2b96Mffv2obu7G88+++xkrVkIMcVMSBiSySRWrlxpfl6+fDmOHz+O/v5+RCIRdHd3AwDuuecevPXWWxNbqRDiijFpMYZarYZXX30Vq1atwuDgIK699lrzWCqVQq1WQyaTmayPE0JMIZMmDNu2bUM8Hse99947WW8phJgmJhR8JL29vfjss8+wZ88e+P1+dHZ24vjx4+bxkZER+P1+JJPJyfg4IcQUM2GL4bnnnkN/fz927dqFcDgMAFi2bBlKpRIOHjwIAHjttddwxx13TPSjhBBXiAlZDB9//DFefPFFLFmyBPfccw8AYNGiRdi1axeeeeYZbNmypS5dKYS4OpiQMHz5y1/GkSNHzvnYrbfeijfffHMiby+EmCZU+SiE8CBhEEJ4kDAIITxIGIQQHiQMQggPEgYhhAcJgxDCg4RBCOFBwiCE8CBhEEJ4kDAIITxIGIQQHiQMQggPEgYhhAcJgxDCg4RBCOFBwiCE8CBhEEJ4kDAIITxIGIQQHiQMQggPEgYhhAcJgxDCg4RBCOFBwiCE8CBhEEJ4mJTTrsXswefz1d0AwHVd85U3cXUjYRCXDIXA7/fD5/OZr7VaDa7rolarmedKHK5uJs2V2LlzJ2666SZ89NFHAIBDhw5h3bp1WLt2Le677z6k0+nJ+ihxhaEIBINBRCIRJBIJtLe3I5VKYe7cuZg7dy5SqRRaW1uRSCQQDocRCoWMcIirj0kRhn//+984dOgQFi5cCACo1Wp4/PHHsXnzZuzbtw/d3d149tlnJ+OjxDTh8/kQCASMOMRiMSQSCbS0tCCRSCCRSCAWiyEajSIUCiEYDBphkDhcfUzYlahUKnjqqafwm9/8Bt/73vcAAP39/YhEIuju7gYA3HPPPVi9ejV+9atfTfTjxASwN6nff+aaQJOfbkCjC+D3+xEIBBAKhczGnzNnjrEawuEwHMdBrVbD6dOnUSqVkMlkUKlUkMvlUK1WUalUUKvV6lwNMbOZsDDs2LED69atw6JFi8x9g4ODuPbaa83PqVQKtVoNmUwGyWRyoh8pvgAUhcb4gB0sbPzK19BSCIfDdZZCMplENBqF67qoVqvw+/0olUqoVqsolUoYHx+Hz+eD4zjmfRV7uDqYkDC8//776O/vx2OPPTZZ6xGTDEUgEAggEAggEokY/9/v95ugITd0pVIx99mWAi2EtrY2dHR0IJlMYuHChUgkEggEAqjVakin08jlcmhtbUU+n8fw8DDy+TxGR0dRqVRQLpeNdSFmNhMShgMHDuDo0aNYvXo1AODEiRO4//77sXHjRhw/ftw8b2RkBH6/X9bCNGAHDsPhMKLRKCKRCILBoLEYeEWvVqt1Jj8FhXGFaDRaZzEwvhAOh1Gr1eA4DoLBIHK5HAKBAPL5PGq1GorFIgCYzwFkPcx0JiQMDz74IB588EHz86pVq7Bnzx586Utfwh/+8AccPHgQ3d3deO2113DHHXdMeLHi8qAbEI1GkUgk0NbWhng8bjZ2OBxGuVzG+Pi4iQ+cOnXKXN1pYcTjcSSTSSSTSZONYEaipaUFkUgEPp8PLS0tKBaLCIfDyGQyAIBsNmvEgp8xPj5uRGiqBKIx4CkRujympI7B7/fjmWeewZYtW1Aul7Fw4UJs3759Kj5KXAAKQygUQjQaRUtLC9rb29He3o6WlhaEQiGMj49jfHwcfr8f+XwehULBuAa2C8L3A85e7WldMBYRCoXgOA6i0agRILoptVoN1Wq17n1oZUxmYZRdfEVXqfEmLs6kCsM777xjvr/11lvx5ptvTubbi8uAohAOh9HS0oJUKoXOzk5cd9116OjoMC7A+Pg4KpUKBgYGcPr0aQBALpczG4guBzc24xDlchnFYrHO3aAItbS0wOfzoVKpIB6PIxgMIhaLIRaLIZPJIJ/PG8vBjjucKxD6RX5vxlCCwaARL8dxJl2EmhlVPjYpdkaBAcTW1la0tbWZIGIkEkG5XEalUkGhUDAuQDAYNFd5AHXxCFsYSqWSER/HceD3+z1By1qtVpeuHB8fN2ukJeI4DqrVal28o7HM+lycK7VKQWBMhYJGYaAIUSTEuZEwNDHcJLFYDG1tbViwYAHmz59vbvF4HPl8HpVKBaFQCGNjYygUCjh9+rSxDkqlkrEGuMmLxSICgQDi8bhxOUKhECKRCFzXNWLR1taGcDhsbix64vflchnBYBCO46BcLhvhsK/q54pD2K6IfT9/XxZZxeNxIzq80UKx31t4kTA0Kbafbd9o9gNnrrj8PpFIAADmzp1rgoWVSgWRSMRYALwSszahXC7D5/MZi8F13bq6hXA4bNbDYCPjDABMdqRarRqBsNOldg+G67qeSsrx8fG6LArXaZdk8zX2783gp1yK8yNhaGLsYqZAIFC3QbjhaA20tLQgGAyio6MDkUgE2WzWuAt8PaslGdQrFotwHAfhcNhsNG5aCgY3K1/HlGYwGESlUjGvZZVkKBTyBCXtVCg3OwDz+fzsYDBoLBd+BgDz+9qFW3RvxLmRMDQxvJrSRC+VSqhUKuZKC5z185mlaG1tRa1WQ1tbG0qlEgDUCYPdUVkul1GtVs3mZ5zBDnwCZzYiNyqrJWOxGMrlMkKhEMrlsllvpVIx6+dGZlyALghjEXbJtb1OCgjfo9EqUADy4kgYmhT7n9/2s5mepHluBygDgQASiQSq1SpaWlrg9/tRqVTqrI5QKIRKpWJcCQoBTXdaJnQ5bFHhxo7H46aGghseOGPi83vb3aHVEIlEjIXBFGulUjECBsDjKvG16vS8PCQMTQx9+lKphHw+j0wmg3Q6bfxwe5PaV2VWSNqWheM4xlJwHAfj4+N15j5jEBQP3seNSb+eJdnc4LQYGChkf0U0GgUAk+lwXde4JtlsFsVisc664HO5+SmGjHfwPUqlUl0AUpwbCUOTYlsLdCMKhQJyuRyy2Wxdk1MgEDDBPV5xaUHwvSgIfr/fbDhmEPg+lUrFWArA2eCgXWpNF4OxBNd1UalUzPvSEohGo8bS4O9i11TwZ2YigPr0J7/yuUxVKvB4aUgYmhheqQuFAsbGxow1AMBUJfp8PsRiMZOOBM6Y8YlEwmz0YrGIfD5vTHmKBF0GpgcBGJ/f7/ejUCgAQF1QMhqNwufzmTqKzs5O07LNtZ4rNQmcbRWntXK+OILtMlEQKGaVSsUIlTg/EoYmxfavWd1YLBaN1ZDL5UwPBf13wniAbTWwrdreqLyi22XT/Dyfz4dqtepJmwIwrgLdGF71maXgRuZzG38v223he9qPNxY0Mb5iFzjJWrgwEoYmxo4x0CT3+XymqvHUqVMYGxtDS0sL5s2bh1gshng8Dr/fj0QigfHxccyZMwcAkM/nTY1CYxqU1gO/z+fzAGAyEXZXZltbG1paWszX9vZ2+P1+tLS0oFwuI5PJmHJru0aBLgcFih2fdi0DLRlmXkqlUp042M8TF0bC0OTQamDVX6FQQDAYRDabBQC0trYCANrb242vbrdqh0Ihc4VubFCym6oaS5oJYwq0ENj2TWuENwYq6eo0XuH51XYDGA9hT0SjVWPHRuyCKXFxJAxNDjcRU4Ou65q6gXw+j2g0CsdxkEqlTFzA3kCBQACxWAxz5swxPjs3MzcpLQRuSpr5kUgE7e3t6OjoMH0advERaxH8fr+piWAQlC4F4w75fN5kIgqFgmkLj0aj5rnFYtGsyefzoVgsGrGSpXB5SBhmAfaVkyY2eyAYWOTmtmMFjAUwzcjMA2sVmCFgdoKC0Dg1ig1NtqXQeFVnHICi1JhhaEyT2s1a/J4ZEmYeKD7i8pEwzAJ41WRAcnx8HKFQCNVqFcPDw6ZLMh6PY/78+Wa2YygUwrx58xAOh+G6LvL5vKkrsK++9OWj0ajx/dlYZZclx2KxOjfEbobi1Z6BSzvwaW962yrgvEneYrEYxsfHjRixzsEeDCMuDQnDLMFuTLKrFjOZjBGKeDwOAMZ1aIwBsCiJ2Qa6G0xhNmYK7Ks8X0ehsC0KVibaAVLGDewshF2STYHie9FiobVBd8W2TsSlI2GYRTBIWKvVTPVguVxGOBzGyMgI4vE4MpkM2traUKvVEI/H0draimAwaHoo6ErYG5g/06RnoJJuS7FYNDfWTNgzE1zXNelSvi/vDwQCpjKSLhD7MpiRoGhQBJitYNm1HTRV8PHSkDDMQuzuxWKxWFe5GA6HUalUzCEyjCPwqs4ZDK7rGguDPj9bpu0OS34esyJ2hoPi4LquqXS005N8X7ol7Jyk62PXRdjf2xZCo+siYbg0JAyzDG4MigFLkGk51Go1M+W5vb3d+Pu88TkA6jaz4zgYGxszdRM2DFCWy2WTlbAbt1g3wXQj38OusORns/qS9QoA6kSCwcZGoZA4XB4ShlkMN0hjcRCbrmjSJxIJtLa21s1SZCcmS6Ftq4HvyS7MYrFohIVuRyKRMAFJvh8rNBs3Lq2LeDxeV2TFgCR/l3ONcLMtEHHpSBhmOfbMA7/fX1c+DZzNCHCoq9/vN1d9jqBnxSMrLO0ybAoDi6XoRthuRSQSMXEBnkXBjQ/Uj6hjtoECwXoKuwDKzkLYmQiJw6UjYZjl0MRmb0QsFqubecDYAN0Du/6A5c50L5LJpAkOlsvluolJdnUi39d+LBKJGIuFKUlmP+zCKb6GwlUoFExmhYVPvNmzHs81O1KcHwnDLKex/NmekmQHAFkf0JhitIfAMuZg92Twe/s4PF7F+ZUxBFoFLI224wHMUDAYyrmU3PRMwXLqtW1F6Fi8y0fCIACcHb1uVx7aY9LsGwWkcYoTr+gsZLJ9fvuIu2g0aoSiVCp5Jj7FYjF0dHR4aiCYXmWpc6VSMTeevWl3U1IgNMrt8pEwiDrskW/nape2p03bAT/7+axPsPsd7IYsBjEBGEuE2RHez3Zwe7NzfY2TpGxXgV9ti0GCcPlIGGY53DisZ2C60M4gcAPy9CrGI/hYJpPxXJHZSk3XgcKQSCQQj8dNNmN0dBQ+nw/5fB7hcBjt7e2IRCLmNKtAIGDaqCkqQ0NDKBaLGBsbw9jYmAly8rNoWdhDWSQOl4eEQdT5/nbq0m5a4lcAdfUAja3Q3Mx0OSgY9sg4+2QruxbBvuLb78OYh32uRWMg0z63ojHGIDfi8pEwzHK4Cbl5Gg90sU+lss+m4M0OUDJ9yLqExq92zIIdmWwBZ3yiUCgY18Se78BiLODswTLMYoyNjZlZE+Vy2RyWY7eai8tDwiDqsEfC0bdngM+O+jM2YD+3sYvTPl+C39sl1raVYYsRgLp6CK6LE55ti8BOpxYKhbq2a1kKX5wJC0O5XMbTTz+Nv//974hEIli+fDm2bduGY8eOYdOmTchkMkgmk+jt7cWSJUsmYcliKuAmYu1A4xmP9kg3uyYhFArV9UTQGuB7smKR79Po93NGA10MzocYHh42Lgw3Pt2ZdDpt5lYWCgWMjo6aWZZ8PtcsvhgTFobt27cjEolg37598Pl8OHXqFABgy5Yt2LBhA+666y688cYb2Lx5M15++eUJL1hMPraVwOg/S5PtA1z4XLuy0TbVeYycXbYcDAaNUNjWAjMYdqk0cNZiaBxHl8/nUS6XjXvDiU52oNEOQspSmBgTEoZ8Po+9e/fir3/9q7lqzJs3D+l0GocPH8b//d//AQB6enqwbds2jIyMIJVKTXzVYtKxi4BoEdAFsE+qBs6OZ2c/BeMFdgemXT3JmQq8j0NdOAPCbt22x7sxwzA2NoaRkREjBrQQhoeHcfr0aeRyOePmaITb5DAhYRgYGEAymcTOnTvx3nvvIZFI4JFHHkE0GkVHR0fdBJ4FCxZgcHBQwjBDsRuq7KGq9gxF1i80mun2wTKMI/A97FQl5zWwQ5KWCDMgAOpGw9GtsbszOYYul8shn88bF0NpycllQsLgOA4GBgZw88034yc/+Qk++OAD/PCHP8SOHTsma33iCmLHGHjlZfTfzioAZ6c4M7Ngi0W5XDYuBNORnB05Z84cUw9hfw6FhGXV9iG5XBfjD6Ojozh9+jQymYxxJTS6bXKZkDB0dnYiGAyip6cHAHDLLbdgzpw5iEajOHnypPmHchwHQ0ND6OzsnJRFiytD49ATlkAzlsCru52utJuseJVnd2VjlgJA3fuxZ4L3c/oTA5b2MXu5XK7uHEqJwuTiv/hTzk8qlcLKlSvx7rvvAgCOHTuGdDqNJUuWoKurC319fQCAvr4+dHV1yY24irDHoXET2/MauCntY+Bsl4DFSwwe2kNe2aoNwGx+e1QcG7Ds9CRFKZ/PI5vNYmxsDMVi0QyilQsxuUw4K/Hzn/8cTz75JHp7exEMBvHMM8+gra0NW7duxaZNm7B79260tbWht7d3MtYrphC7eCkWi5nSZE5/ZiVirVYzE5aAsydh87WMRXCKs50poBVRKBRMcRLFxJ7lyKDiyMgIRkdHMTo6ipGREaTT6bqAo+oVpoYJC8N1112H3//+9577b7zxRrz++usTfXtxhaBlwDiC3Q1pj2Njw5M9iIWvZ8v0uU6DspucmNFgzIBt1vbBs5lMBvl8HmNjY8ZC4NdCoVDXTSlRmHxU+SgMPAEqEomgtbUV0WgUra2taG1tRTKZNL0KrF9gRuBcB80AMDURAEx8gNOgubk5ZGVsbKzuLMxCoYBsNotTp04hnU5jeHgYIyMjOH36tLE2JApTh4RBADg7manRYuAgFh4iQ2uALkLjeZH298xwsJ6BtQbMWHC8vD0himnKSqWCbDaLTCaD0dFRZDIZM/Ke6VGJwtQhYRAG2/zn1ZidjZVKpW7cO3D2wFoWNNmxCPsMC8dxTDNWrVarK3Gm5WBPheaJ2blcDqdOncLp06cxOjqKUqlUV90opg4Jg6jDvgo3lkrb5zewnJnuh905ab/eboUOBAIoFAqmn4KWhH30HIOP2WwWuVwO2WzWdE3a51aKqUXCIOqgm0DTP5fLmawDB7RwdHwikfC83jbxbWFhsLFUKiESiZiYBFummWXIZrMm+FgqlcwgFsY1JApXBgmDAIC6QiYAdTEEZiDsxic7NdmYMrSnQzcOgAVQd2I2m6NYyETxoJWgKUzTg4RB1M1rbDyUlr5/rVYzx9OxRqGlpQWhUMicBcGp0PaMSHvCEk+rsg+EoQtRKBRQrVbNkJV8Pl/XhCVRuLJIGGYp9vmSdnESA4zMLtij3uyNysYqVjPafQ12/4P9lYFHuin2UXSc3MT6BLtGQaJw5ZEwzDLsMufGkfD2aU921WJjStI+5xIAIpGIZ+ITN7ld+UgBYMaB2Qn75Go7kwHo9KjpQsIwi2gc/86vTDty7DtTjvbm5LQmO6DIqdL2z3amwR7kYp9taZ8WRRGxG7FkJUw/EoZZRuO0ZooALYVYLOYpUuLGDYfDdSdUcePzKs+rPzc8LQbb8mBwkUHHxilQEoSZgYRhltBoLVAU7NoDWgb2mDW7ItHupKQQ+Hw+c9VnBoFfi8Vi3QEw7JE413AVCcLMQsIwSzhfkLExC2FfvWn28/XhcBixWMyIA+dCsq2a9zOwaNcesBaBaUkVK81sJAyzBDsdaU9lpttgT3oGzhYn2dkLlkYXCoW6uAEzCXQlisWiCSja8QfebKtDzEwkDLMAOxNxPjfCFgSgfg4jX8s4AQXAtgZYi8DyZj7XHktvC4Jch5mNhKHJscWALdWRSASJRMIMaLXHxnPsmn0MXOP78MoPoM5iyOfzJi5hv9bOZCiecHUgYWhybBfCthZCoRCi0agJIHKz0oqwj59rLJdmAVLjz+eKLQDexiwx85EwNDGN1gLbou1Jz3ars13oFA6HAaBOUFibUCwWAcBMaGY587lcCHF1ImFoYuzhKfaN2OY9n08hYEu1LSy0LphqtCsdaTVQECQKVzcShiancQS8PR+BlgNnKtgl0fzZtjKi0aixGjh5iQVLFApA7kIzIGFoYi529eaRchzbbt/so+5pNdDC4HvbbogyDc2FhKHJoYXA8yhpHdgj3u1eCVoIfI5d58BUJa2Gc5U0i+ZAwjALsIuV7AAjYwn218ahrvZhM4wpnEsIJAzNhYShybFnJ/BsyJaWFhNL4P38HjhbGs3UJVuo7SPhANQFM+2Up7j6kTA0IY3zFli3wJRlPB43LgPgrTOwg5Vsq2ZjFd/fjj3wORKG5kHC0GTYgmDXJMTjccTjcSSTSaRSKTOQlb0L9gg3Vj02jmmjVUGh4YAWtler96F5kDA0Gdy4DCzy8JhYLIZEInHO4+bsK71tLfC9CFOc9gj5xgClrIbmQMLQRHBz8ooej8dNpqGlpQWtra2IxWJ1nZUAzusG+P1+RCIRY4WUSqW6WAQzG421EuLqZ8LCsH//fuzYscP8cz388MNYs2YNjh07hk2bNiGTySCZTKK3txdLliyZhCWLC3G+gSyMEdh1Bz6fz/Q30A3gfIbGKkng7CCXYrGIXC5nRryrhbr5mJAwuK6LJ554Aq+88gqWLl2K//znP/jOd76D22+/HVu2bMGGDRtw11134Y033sDmzZvx8ssvT9a6xQWwG6coDPbxc3bXI2MMjCfYsyAbhYE1EXbFo324rNyI5sF/8adc5A38fmSzWQBANpvFggULMDo6isOHD6OnpwcA0NPTg8OHD2NkZGSiHycuQKMghMNhU7hEceDkpWKxiEKhYG6NqUi77Zo3WgUcwmIPXpHF0FxMyGLw+Xx4/vnn8dBDDyEejyOfz+Oll17C4OAgOjo6jPkaCASwYMECDA4OIpVKTcrChZfGg2MYR7CPqWcZMxuhKAZss7bfC4DpugRQl6WwRUPWQvMxIYuhWq3ixRdfxO7du7F//3688MILePTRR1EoFCZrfeISsQUhGo0iFoshHo+bMyaZnmQGgY1ULFyybxQLW0B4tgSHvbCUWkHH5mRCFsOHH36IoaEhrFixAgCwYsUKxGIxRCIRnDx50lyJHMfB0NAQOjs7J2XR4tzYVYyNDVF2WhGob4KypzRREDigxY4/0F2wR8WJ5mRCFsM111yDEydO4JNPPgEAHD16FOl0GosXL0ZXVxf6+voAAH19fejq6pIbMcU0bn7bHWBFI10AWgIA6twOWgk8+2FsbAzDw8MYGBjA8ePHcfLkSYyNjZm5j3IjmpMJWQzz58/H1q1b8cgjj5h/wqeffhrJZBJbt27Fpk2bsHv3brS1taG3t3dSFiwujn36E6E1QezH7boE+z0AmDhEoVAwI+AbU5yi+ZhwHcO6deuwbt06z/033ngjXn/99Ym+vbgMaA3wau44Tl12Ih6PG7eCU5eAs4Na2H7N57BUOpvNGiuBR9TzbAiJQ3Oiyscmwj7Dga4DB6z4/f66qzyFIRAImDkNjYNZgLPuiT35SSdRNz8ShibBnt9YKBTg8/lQLBYRCoXM6VG0AhhHcBwH8Xi8biYDbxzjxiPo+FoeY880pWhOJAxNhH0FtwOQDDYWCgVP/YF9GlUjdC3O11shYWheJAxNROM5DrQg7LFstihwroI999F+PV2KUqmEWCyGXC5XJw6ieZEwNCH2kfJ0G+zBraxRYPqy0YpoPJqO/RAKNM4eJAxNTOORcJyXUKvVjKVAQaCAMJ7AI+gAmOPsAVkKswUJQ5NjT1ayB6lQMCgGTEHaLgafWygUkM1mzaG1mgrd/EgYZgG2GNj32VWQhUIBwWDQU/RUq9VQKBSQz+dNjEIuRfMjYZilUCR4LgQrI7npGYis1Wool8ue2QuiuZEwzFK4uW3XgK6Gz+dDKBTyuBsqapo9SBhmMZzmxA5LWxjK5bJ5HjMaEoXZg4RhlmOPiyeNLdUqaJp9SBiEjpsTHiY881EI0XxIGIQQHiQMQggPEgYhhAcJgxDCg4RBCOFBwiCE8CBhEEJ4kDAIITxIGIQQHiQMQggPEgYhhAcJgxDCg4RBCOFBwiCE8CBhEEJ4uKgw9Pb2YtWqVbjpppvw0UcfmfuPHTuG9evXY+3atVi/fj0+/fTTS3pMCHEV4F6EAwcOuMePH3dvu+0298iRI+b+jU1/XpUAAAbCSURBVBs3unv37nVd13X37t3rbty48ZIeuxQGBgbcpUuXusFg0AWgm266TfItGAy6S5cudQcGBs65By9qMXR3d6Ozs7PuvnQ6jcOHD6OnpwcA0NPTg8OHD2NkZOSCjwkhrg6+0MzHwcFBdHR0IBAIADhz+OmCBQswODgI13XP+1gqlZq8lQshpgwFH4UQHr6QxdDZ2YmTJ0/CcRwEAgE4joOhoSF0dnbCdd3zPiaEuDr4QhbD3Llz0dXVhb6+PgBAX18furq6kEqlLviYEOIq4WIZgm3btrlf+9rX3K6uLverX/2q+41vfMN1Xdf973//6959993umjVr3Lvvvts9evSoec2FHlNWQjfdpv92sayEz3Vn3uki//vf/7B69Wp88sknqFar070cIZqOYDCIG264AX/5y1+waNEiz+MKPgohPEgYhBAeJAxCCA8SBiGEBwmDEMKDhEEI4UHCIITwIGEQQniQMAghPEgYhBAeJAxCCA8SBiGEBwmDEMKDhEEI4UHCIITwIGEQQniQMAghPEgYhBAeJAxCCA8SBiGEBwmDEMKDhEEI4eELnUQ11TiOA+DMiGshxOTDvcW95nn8Si7mUhkeHgYAXH/99dO8EiGam+HhYSxevNhz/4w8cKZUKqG/vx/z5883p2YLISYPx3EwPDyMZcuWIRqNeh6fkcIghJheFHwUQniQMAghPEgYhBAeJAxCCA8SBiGEBwmDEMKDhEEI4WFGCsOxY8ewfv16rF27FuvXr8enn356xdcwOjqKH/zgB1i7di3uvPNOPPzwwxgZGQEAHDp0COvWrcPatWtx3333IZ1OX/H17dy5EzfddBM++uijGbGmcrmMLVu2YM2aNbjzzjvxs5/9DMD0/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":1615719655796,"user_tz":-60,"elapsed":223242,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"13ebd653-10b3-4cb7-8e60-5afb67a43bec"},"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":1615719655797,"user_tz":-60,"elapsed":223242,"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":1615719655797,"user_tz":-60,"elapsed":223240,"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":1615719656152,"user_tz":-60,"elapsed":223594,"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":1615719656153,"user_tz":-60,"elapsed":223594,"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":1615719656153,"user_tz":-60,"elapsed":223592,"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":1615719656918,"user_tz":-60,"elapsed":224352,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"bb428d39-db1d-46f9-b390-533e71d52b16"},"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":1615719656918,"user_tz":-60,"elapsed":224350,"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":1615719656919,"user_tz":-60,"elapsed":224346,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"bd5ec951-7f13-4586-833f-746999f97a88"},"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":1615719657267,"user_tz":-60,"elapsed":224693,"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":1615719657268,"user_tz":-60,"elapsed":224692,"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":1615719657269,"user_tz":-60,"elapsed":224688,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"91b4a7bc-258d-41a9-a2fc-4d8ecea05a28"},"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":1615719657614,"user_tz":-60,"elapsed":225031,"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":1615719657616,"user_tz":-60,"elapsed":225032,"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":1615719659261,"user_tz":-60,"elapsed":226675,"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":1615719659263,"user_tz":-60,"elapsed":226672,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"4bca0dcb-e545-45b3-b502-6ed3f1e07b30"},"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":1615726809271,"user_tz":-60,"elapsed":7376674,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"05e844f6-4762-4d85-ee02-68577fec7f52"},"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.875372648239136 sec\n","Data created in 0.7527220249176025 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, 16)           4560144     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,560,144\n","Trainable params: 4,560,144\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_dim16_de.h5\n","Epoch 1/100\n","INFO:tensorflow:Reduce to /job:localhost/replica:0/task:0/device:CPU:0 then broadcast to ('/job:localhost/replica:0/task:0/device:CPU:0',).\n","INFO:tensorflow:Reduce to /job:localhost/replica:0/task:0/device:CPU:0 then broadcast to ('/job:localhost/replica:0/task:0/device:CPU:0',).\n","INFO:tensorflow:Reduce to /job:localhost/replica:0/task:0/device:CPU:0 then broadcast to ('/job:localhost/replica:0/task:0/device:CPU:0',).\n","INFO:tensorflow:Reduce to /job:localhost/replica:0/task:0/device:CPU:0 then broadcast to ('/job:localhost/replica:0/task:0/device:CPU:0',).\n","INFO:tensorflow:Reduce to /job:localhost/replica:0/task:0/device:CPU:0 then broadcast to ('/job:localhost/replica:0/task:0/device:CPU:0',).\n","INFO:tensorflow:Reduce to /job:localhost/replica:0/task:0/device:CPU:0 then broadcast to ('/job:localhost/replica:0/task:0/device:CPU:0',).\n","247/247 [==============================] - 79s 181ms/step - loss: 1.0163 - mse: 1.6365 - val_loss: 0.6351 - val_mse: 0.6712\n","Epoch 2/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.5797 - mse: 0.5638 - val_loss: 0.4737 - val_mse: 0.3744\n","Epoch 3/100\n","247/247 [==============================] - 42s 169ms/step - loss: 0.4107 - mse: 0.2868 - val_loss: 0.3470 - val_mse: 0.2087\n","Epoch 4/100\n","247/247 [==============================] - 42s 169ms/step - loss: 0.3244 - mse: 0.1832 - val_loss: 0.3010 - val_mse: 0.1600\n","Epoch 5/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.2745 - mse: 0.1297 - val_loss: 0.2758 - val_mse: 0.1329\n","Epoch 6/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.2474 - mse: 0.1024 - val_loss: 0.2510 - val_mse: 0.1086\n","Epoch 7/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.2233 - mse: 0.0809 - val_loss: 0.2415 - val_mse: 0.0967\n","Epoch 8/100\n","247/247 [==============================] - 41s 168ms/step - loss: 0.2043 - mse: 0.0649 - val_loss: 0.2289 - val_mse: 0.0862\n","Epoch 9/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1960 - mse: 0.0587 - val_loss: 0.2283 - val_mse: 0.0844\n","Epoch 10/100\n","247/247 [==============================] - 42s 169ms/step - loss: 0.1892 - mse: 0.0547 - val_loss: 0.2191 - val_mse: 0.0763\n","Epoch 11/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1872 - mse: 0.0535 - val_loss: 0.2186 - val_mse: 0.0783\n","Epoch 12/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1839 - mse: 0.0517 - val_loss: 0.2136 - val_mse: 0.0743\n","Epoch 13/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1811 - mse: 0.0504 - val_loss: 0.2110 - val_mse: 0.0705\n","Epoch 14/100\n","247/247 [==============================] - 42s 169ms/step - loss: 0.1807 - mse: 0.0497 - val_loss: 0.2116 - val_mse: 0.0720\n","Epoch 15/100\n","247/247 [==============================] - 41s 168ms/step - loss: 0.1781 - mse: 0.0487 - val_loss: 0.2102 - val_mse: 0.0705\n","Epoch 16/100\n","247/247 [==============================] - 42s 169ms/step - loss: 0.1770 - mse: 0.0483 - val_loss: 0.2129 - val_mse: 0.0734\n","Epoch 17/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1770 - mse: 0.0483 - val_loss: 0.2082 - val_mse: 0.0701\n","Epoch 18/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1756 - mse: 0.0476 - val_loss: 0.2180 - val_mse: 0.0779\n","Epoch 19/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1738 - mse: 0.0466 - val_loss: 0.2054 - val_mse: 0.0673\n","Epoch 20/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1726 - mse: 0.0460 - val_loss: 0.2044 - val_mse: 0.0643\n","Epoch 21/100\n","247/247 [==============================] - 42s 169ms/step - loss: 0.1712 - mse: 0.0456 - val_loss: 0.2058 - val_mse: 0.0668\n","Epoch 22/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1715 - mse: 0.0458 - val_loss: 0.2101 - val_mse: 0.0712\n","Epoch 23/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1712 - mse: 0.0454 - val_loss: 0.2050 - val_mse: 0.0659\n","Epoch 24/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1699 - mse: 0.0449 - val_loss: 0.2054 - val_mse: 0.0675\n","Epoch 25/100\n","247/247 [==============================] - 41s 168ms/step - loss: 0.1683 - mse: 0.0444 - val_loss: 0.2066 - val_mse: 0.0663\n","Epoch 26/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1684 - mse: 0.0445 - val_loss: 0.2083 - val_mse: 0.0688\n","Epoch 27/100\n","247/247 [==============================] - 42s 169ms/step - loss: 0.1673 - mse: 0.0441 - val_loss: 0.2111 - val_mse: 0.0717\n","Epoch 28/100\n","247/247 [==============================] - 41s 168ms/step - loss: 0.1678 - mse: 0.0442 - val_loss: 0.2037 - val_mse: 0.0655\n","Epoch 29/100\n","247/247 [==============================] - 41s 168ms/step - loss: 0.1663 - mse: 0.0436 - val_loss: 0.2054 - val_mse: 0.0660\n","Epoch 30/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1678 - mse: 0.0441 - val_loss: 0.2066 - val_mse: 0.0671\n","Epoch 31/100\n","247/247 [==============================] - 41s 168ms/step - loss: 0.1654 - mse: 0.0431 - val_loss: 0.2032 - val_mse: 0.0647\n","Epoch 32/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1650 - mse: 0.0430 - val_loss: 0.2026 - val_mse: 0.0632\n","Epoch 33/100\n","247/247 [==============================] - 41s 168ms/step - loss: 0.1642 - mse: 0.0428 - val_loss: 0.2046 - val_mse: 0.0653\n","Epoch 34/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1648 - mse: 0.0430 - val_loss: 0.2038 - val_mse: 0.0639\n","Epoch 35/100\n","247/247 [==============================] - 41s 168ms/step - loss: 0.1647 - mse: 0.0431 - val_loss: 0.2024 - val_mse: 0.0624\n","Epoch 36/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1645 - mse: 0.0429 - val_loss: 0.2068 - val_mse: 0.0664\n","Epoch 37/100\n","247/247 [==============================] - 41s 168ms/step - loss: 0.1628 - mse: 0.0423 - val_loss: 0.2066 - val_mse: 0.0669\n","Epoch 38/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1635 - mse: 0.0427 - val_loss: 0.2048 - val_mse: 0.0664\n","Epoch 39/100\n","247/247 [==============================] - 41s 168ms/step - loss: 0.1628 - mse: 0.0423 - val_loss: 0.2053 - val_mse: 0.0663\n","Epoch 40/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1618 - mse: 0.0418 - val_loss: 0.2055 - val_mse: 0.0668\n","Epoch 41/100\n","247/247 [==============================] - 41s 168ms/step - loss: 0.1619 - mse: 0.0421 - val_loss: 0.2078 - val_mse: 0.0691\n","Epoch 42/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1616 - mse: 0.0420 - val_loss: 0.2081 - val_mse: 0.0680\n","Epoch 43/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1608 - mse: 0.0417 - val_loss: 0.2029 - val_mse: 0.0639\n","Epoch 44/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1595 - mse: 0.0410 - val_loss: 0.2071 - val_mse: 0.0678\n","Epoch 45/100\n","247/247 [==============================] - 41s 168ms/step - loss: 0.1614 - mse: 0.0420 - val_loss: 0.2049 - val_mse: 0.0651\n","Epoch 46/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1606 - mse: 0.0414 - val_loss: 0.2054 - val_mse: 0.0660\n","Epoch 47/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1599 - mse: 0.0414 - val_loss: 0.2057 - val_mse: 0.0663\n","Epoch 48/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1600 - mse: 0.0415 - val_loss: 0.2056 - val_mse: 0.0659\n","Epoch 49/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1595 - mse: 0.0412 - val_loss: 0.2067 - val_mse: 0.0671\n","Epoch 50/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1593 - mse: 0.0412 - val_loss: 0.2080 - val_mse: 0.0692\n","Epoch 51/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1591 - mse: 0.0412 - val_loss: 0.2081 - val_mse: 0.0680\n","Epoch 52/100\n","247/247 [==============================] - 41s 168ms/step - loss: 0.1586 - mse: 0.0410 - val_loss: 0.2078 - val_mse: 0.0673\n","Epoch 53/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1583 - mse: 0.0409 - val_loss: 0.2086 - val_mse: 0.0684\n","Epoch 54/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1581 - mse: 0.0409 - val_loss: 0.2061 - val_mse: 0.0661\n","Epoch 55/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1584 - mse: 0.0410 - val_loss: 0.2065 - val_mse: 0.0661\n","Epoch 56/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1571 - mse: 0.0404 - val_loss: 0.2059 - val_mse: 0.0666\n","Epoch 57/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1575 - mse: 0.0407 - val_loss: 0.2093 - val_mse: 0.0689\n","Epoch 58/100\n","247/247 [==============================] - 41s 168ms/step - loss: 0.1575 - mse: 0.0407 - val_loss: 0.2056 - val_mse: 0.0660\n","Epoch 59/100\n","247/247 [==============================] - 42s 169ms/step - loss: 0.1565 - mse: 0.0403 - val_loss: 0.2062 - val_mse: 0.0654\n","Epoch 60/100\n","247/247 [==============================] - 41s 168ms/step - loss: 0.1570 - mse: 0.0403 - val_loss: 0.2044 - val_mse: 0.0656\n","Epoch 61/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1573 - mse: 0.0406 - val_loss: 0.2075 - val_mse: 0.0682\n","Epoch 62/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1567 - mse: 0.0403 - val_loss: 0.2077 - val_mse: 0.0682\n","Epoch 63/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1563 - mse: 0.0403 - val_loss: 0.2074 - val_mse: 0.0673\n","Epoch 64/100\n","247/247 [==============================] - 41s 168ms/step - loss: 0.1552 - mse: 0.0398 - val_loss: 0.2061 - val_mse: 0.0671\n","Epoch 65/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1559 - mse: 0.0403 - val_loss: 0.2076 - val_mse: 0.0676\n","Epoch 66/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1549 - mse: 0.0398 - val_loss: 0.2055 - val_mse: 0.0661\n","Epoch 67/100\n","247/247 [==============================] - 42s 169ms/step - loss: 0.1553 - mse: 0.0398 - val_loss: 0.2044 - val_mse: 0.0656\n","Epoch 68/100\n","247/247 [==============================] - 41s 168ms/step - loss: 0.1540 - mse: 0.0396 - val_loss: 0.2067 - val_mse: 0.0669\n","Epoch 69/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1548 - mse: 0.0398 - val_loss: 0.2055 - val_mse: 0.0665\n","Epoch 70/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1545 - mse: 0.0398 - val_loss: 0.2071 - val_mse: 0.0672\n","Epoch 71/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1542 - mse: 0.0394 - val_loss: 0.2060 - val_mse: 0.0663\n","Epoch 72/100\n","247/247 [==============================] - 41s 168ms/step - loss: 0.1548 - mse: 0.0399 - val_loss: 0.2078 - val_mse: 0.0676\n","Epoch 73/100\n","247/247 [==============================] - 42s 169ms/step - loss: 0.1542 - mse: 0.0396 - val_loss: 0.2064 - val_mse: 0.0676\n","Epoch 74/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1546 - mse: 0.0398 - val_loss: 0.2074 - val_mse: 0.0668\n","Epoch 75/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1545 - mse: 0.0400 - val_loss: 0.2077 - val_mse: 0.0671\n","Epoch 76/100\n","247/247 [==============================] - 41s 168ms/step - loss: 0.1539 - mse: 0.0396 - val_loss: 0.2077 - val_mse: 0.0678\n","Epoch 77/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1536 - mse: 0.0394 - val_loss: 0.2092 - val_mse: 0.0689\n","Epoch 78/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1543 - mse: 0.0399 - val_loss: 0.2082 - val_mse: 0.0681\n","Epoch 79/100\n","247/247 [==============================] - 41s 168ms/step - loss: 0.1541 - mse: 0.0397 - val_loss: 0.2064 - val_mse: 0.0666\n","Epoch 80/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1532 - mse: 0.0393 - val_loss: 0.2108 - val_mse: 0.0699\n","Epoch 81/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1536 - mse: 0.0395 - val_loss: 0.2077 - val_mse: 0.0677\n","Epoch 82/100\n","247/247 [==============================] - 42s 169ms/step - loss: 0.1544 - mse: 0.0399 - val_loss: 0.2069 - val_mse: 0.0669\n","Epoch 83/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1530 - mse: 0.0396 - val_loss: 0.2087 - val_mse: 0.0685\n","Epoch 84/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1524 - mse: 0.0393 - val_loss: 0.2076 - val_mse: 0.0683\n","Epoch 85/100\n","247/247 [==============================] - 42s 169ms/step - loss: 0.1531 - mse: 0.0394 - val_loss: 0.2071 - val_mse: 0.0670\n","Epoch 86/100\n","247/247 [==============================] - ETA: 0s - loss: 0.1529 - mse: 0.0394Epoch 87/100\n","247/247 [==============================] - 41s 168ms/step - loss: 0.1518 - mse: 0.0390 - val_loss: 0.2088 - val_mse: 0.0692\n","Epoch 88/100\n","247/247 [==============================] - 41s 168ms/step - loss: 0.1533 - mse: 0.0397 - val_loss: 0.2077 - val_mse: 0.0682\n","Epoch 89/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1522 - mse: 0.0394 - val_loss: 0.2102 - val_mse: 0.0694\n","Epoch 90/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1522 - mse: 0.0394 - val_loss: 0.2086 - val_mse: 0.0683\n","Epoch 91/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1511 - mse: 0.0388 - val_loss: 0.2085 - val_mse: 0.0688\n","Epoch 92/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1523 - mse: 0.0394 - val_loss: 0.2095 - val_mse: 0.0692\n","Epoch 93/100\n","247/247 [==============================] - 41s 168ms/step - loss: 0.1516 - mse: 0.0392 - val_loss: 0.2084 - val_mse: 0.0674\n","Epoch 94/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1514 - mse: 0.0391 - val_loss: 0.2086 - val_mse: 0.0677\n","Epoch 95/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1523 - mse: 0.0394 - val_loss: 0.2082 - val_mse: 0.0677\n","Epoch 96/100\n","247/247 [==============================] - 42s 169ms/step - loss: 0.1513 - mse: 0.0390 - val_loss: 0.2070 - val_mse: 0.0669\n","Epoch 97/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1518 - mse: 0.0394 - val_loss: 0.2070 - val_mse: 0.0668\n","Epoch 98/100\n","247/247 [==============================] - 42s 168ms/step - loss: 0.1511 - mse: 0.0388 - val_loss: 0.2077 - val_mse: 0.0672\n","Epoch 99/100\n","247/247 [==============================] - 42s 169ms/step - loss: 0.1523 - mse: 0.0395 - val_loss: 0.2076 - val_mse: 0.0677\n","Epoch 100/100\n","247/247 [==============================] - 42s 169ms/step - loss: 0.1506 - mse: 0.0388 - val_loss: 0.2074 - val_mse: 0.0669\n"],"name":"stdout"},{"output_type":"display_data","data":{"image/png":"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bZs2b96sUaNGacGCBXr//ffl8/nUuXNn/fnPf26009OvXz999NFHSkpK0gcffKB58+ZJks4555zoRe2Sjvh48+fP16FDh5STk6PExES9+OKLuuaaazR58mT98pe/1N69ezVnzhxt2xb+c/n973+vsWPHSgq/IpuTk6N169Zpz549mjx5sq6++uqYv//y8nLde++92rRpk6RwFzMSQh955BEVFBTI6/XKMAw9++yzcrvdmjFjhr766itZlqXevXvrv//7v5v8c28LiouL1b179+j7GRkZ2rVrV1xrMExLoQCnfQJO5ZQ5edeuXRo0aJAMw5Akde7cWZ07d25SPSNGjNDcuXP19ddfq0+fPpLCL8aOHz9eX3zxhebNm6eKigpVVVXpyiuv1HXXXdfgMRYvXqzDhw9rxowZqq6u1r333qsNGzaoc+fOyszMjI7bsmVLo4/3z3/+U6tXr9a6deu0dOlS/e53v1NGRoYWLFigvLw8SdKrr76qv/3tb5Kknj17av78+UpJSVFeXp4KCgrUoUMHffnll2rfvr0WL16s1NTUJv0cGkP4q+WHzh/hD2hNzj33XD3//PM6cOCAli9frrFjx+qzzz6rM2bZsmUaP368zj77bPl8Pm3cuFEDBw6Mfn7atGnyer2SJNM0o/9w15aTk6PFixfrwIED6tixo/Ly8jR69GglJCRoypQpmjFjhiRp6dKlWrhwof76178esebq6mrdcsstWrhwoQYNGqSVK1fqueeei37+SI83e/ZsTZgw4YgdxHvvvVennHKKHn30Ue3evVvjx4/XaaedFp14Kysr9dJLL2nHjh3Kzs7WuHHjlJSUFMuPWY899piCwaBef/11lZeXa+LEierbt68GDhyop59+WmvXrlVCQoLKysqUkJCgd955R+Xl5Vq5cqWk8FIftFzhPX/MjwB+mmPNyddee62mTZumgoIC/fznP9fw4cM1ePDg6OfXrVunnJyc6PtXX321rrjiijrP4fF4lJ2drWXLlmn69OkqKyvTW2+9pZUrVyo5OVlPP/20PB6PysvLdcUVV+iCCy6IhsTGRObFFStWyO/366qrrlKPHj0kSSeccEKjj3fBBRdo+PDh6t+/f/SF1MLCwuhjfvHFF1q4cKHy8vKUlpamhx9+WPfcc48efvhhSeEloq+99poyMjJ01113KTc3V7fccstP+MmH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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":1615726809273,"user_tz":-60,"elapsed":7376674,"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":1615726809274,"user_tz":-60,"elapsed":7376674,"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":1615726809275,"user_tz":-60,"elapsed":7376673,"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":1615726809276,"user_tz":-60,"elapsed":7376673,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["# put correct filename\n","model_filename = f\"{path_logs_training}/training/{training_description}.h5\""],"execution_count":39,"outputs":[]},{"cell_type":"code","metadata":{"id":"Dr9eFsJKK4Lw","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615726809276,"user_tz":-60,"elapsed":7376668,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"3fc52366-4321-49af-ee1c-8f03b4818181"},"source":["# Recreate the exact same model, including its weights and the optimizer\n","model = tf.keras.models.load_model(model_filename)\n","\n","# Show the model architecture\n","model.summary()"],"execution_count":40,"outputs":[{"output_type":"stream","text":["Model: \"model_1\"\n","__________________________________________________________________________________________________\n","Layer (type)                    Output Shape         Param #     Connected to                     \n","==================================================================================================\n","input_1 (InputLayer)            [(None, 116, 116, 1) 0                                            \n","__________________________________________________________________________________________________\n","input_2 (InputLayer)            [(None, 116, 116, 1) 0                                            \n","__________________________________________________________________________________________________\n","model (Functional)              (None, 16)           4560144     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,560,144\n","Trainable params: 4,560,144\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":1615726809277,"user_tz":-60,"elapsed":7376667,"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":41,"outputs":[]},{"cell_type":"code","metadata":{"id":"RJMjW2KHK4L5","executionInfo":{"status":"ok","timestamp":1615726809278,"user_tz":-60,"elapsed":7376666,"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":42,"outputs":[]},{"cell_type":"code","metadata":{"id":"0YTh5UvmK4L7","executionInfo":{"status":"ok","timestamp":1615726836920,"user_tz":-60,"elapsed":7404307,"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":43,"outputs":[]},{"cell_type":"code","metadata":{"id":"5iTuvVue-a9c","executionInfo":{"status":"ok","timestamp":1615726836921,"user_tz":-60,"elapsed":7404307,"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":44,"outputs":[]},{"cell_type":"code","metadata":{"id":"NjmjpoN0K4L9","colab":{"base_uri":"https://localhost:8080/","height":882},"executionInfo":{"status":"ok","timestamp":1615726839654,"user_tz":-60,"elapsed":7407036,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"8926cd5a-c5e1-4171-b228-72b74d5169b6"},"source":["plot_dP_dQ(dP_values, dQ_values)"],"execution_count":45,"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.2607098751473095\n","Min. angle recovery loss possible = 0.06790166936032636\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"lA75WQYrK4L_","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615726839655,"user_tz":-60,"elapsed":7407031,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"f686b706-8c0b-4a65-dc5d-608999281eb8"},"source":["MAE(dQ_values, dP_values)"],"execution_count":46,"outputs":[{"output_type":"execute_result","data":{"text/plain":["<tf.Tensor: shape=(), dtype=float32, numpy=0.20317902>"]},"metadata":{"tags":[]},"execution_count":46}]},{"cell_type":"code","metadata":{"id":"rGC2BjfxVYqF","executionInfo":{"status":"ok","timestamp":1615726839655,"user_tz":-60,"elapsed":7407029,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":[""],"execution_count":46,"outputs":[]}]}