{"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":"5a1a_quartercvg_uniformS2_noise0_DE_LAST","provenance":[{"file_id":"1CqUehBRgFnpMnV1QNU8kFN88eGrXRqq8","timestamp":1614969730136},{"file_id":"15BvMspad3_FkfTTyzCIlJJjyRNTen9ev","timestamp":1614376558129},{"file_id":"1nnOFyHuLQU50H4TX8we118vefLfbKgVH","timestamp":1613399169853},{"file_id":"https://github.com/anonymous/protein-reconstruction/blob/master/notebooks/1-phase1/colab_distance_estimation_translated.ipynb","timestamp":1593207886361}],"collapsed_sections":[],"toc_visible":true},"accelerator":"GPU"},"cells":[{"cell_type":"markdown","metadata":{"id":"I-hskHNCK4Jy"},"source":["<a href=\"https://colab.research.google.com/github/anonymous/protein-reconstruction/blob/master/notebooks/2-phase2/colab_distance_estimation_and_angle_recovery-test5j0nhalf-cov_noisy.ipynb\" target=\"_parent\"><img src=\"https://colab.research.google.com/assets/colab-badge.svg\" alt=\"Open In Colab\"/></a>"]},{"cell_type":"markdown","metadata":{"id":"ny3JKImAK4Jz"},"source":["# Distance Estimation and Angle Recovery"]},{"cell_type":"markdown","metadata":{"id":"4W1rATe0K4J1"},"source":["<div class=\"alert alert-danger\" role=\"alert\">\n","  <p><strong>Important:</strong> This notebook is used to run the distance estimation on noisy data only (no angle recovery).</p>\n","  <hr>\n","    - <b>To enable GPU</b>: Navigate to Edit→Notebook Settings<br/>\n","    - <b>To save the latest version of code from this notebook</b>: Navigate to File→Save a copy to Github.\n","</div>"]},{"cell_type":"markdown","metadata":{"id":"EkRUrVFpCrFT"},"source":["## Content"]},{"cell_type":"markdown","metadata":{"id":"Zwit5GAFCrFU"},"source":["1. [Data Preparation](#1.-Data-Preparation)\n","2. [Distance Estimation](#2.-Distance-Estimation)\n","3. [Angle Recovery](#3.-Angle-Recovery)\n","4. [Angle Alignment](#4.-Angle-Alignment)"]},{"cell_type":"code","metadata":{"id":"P43631FkK4J5"},"source":["# create directories\n","!mkdir --parents data/5j0n\n","!mkdir training"],"execution_count":null,"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":1615132909431,"user_tz":-60,"elapsed":32082,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"251943b1-a8e8-4cd3-88c5-357eaa703f08"},"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":null,"outputs":[{"output_type":"stream","text":["--2021-03-07 16:01:17--  https://repo.anaconda.com/miniconda/Miniconda3-latest-Linux-x86_64.sh\n","Resolving repo.anaconda.com (repo.anaconda.com)... 104.16.130.3, 104.16.131.3, 2606:4700::6810:8203, ...\n","Connecting to repo.anaconda.com (repo.anaconda.com)|104.16.130.3|:443... connected.\n","HTTP request sent, awaiting response... 200 OK\n","Length: 94235922 (90M) [application/x-sh]\n","Saving to: ‘Miniconda3-latest-Linux-x86_64.sh’\n","\n","Miniconda3-latest-L 100%[===================>]  89.87M   130MB/s    in 0.7s    \n","\n","2021-03-07 16:01:18 (130 MB/s) - ‘Miniconda3-latest-Linux-x86_64.sh’ saved [94235922/94235922]\n","\n","PREFIX=/usr/local\n","Unpacking payload ...\n","Collecting package metadata (current_repodata.json): - \b\b\\ \b\b| \b\bdone\n","Solving environment: - \b\b\\ \b\bdone\n","\n","## Package Plan ##\n","\n","  environment location: /usr/local\n","\n","  added / updated specs:\n","    - _libgcc_mutex==0.1=main\n","    - brotlipy==0.7.0=py38h27cfd23_1003\n","    - ca-certificates==2020.10.14=0\n","    - certifi==2020.6.20=pyhd3eb1b0_3\n","    - cffi==1.14.3=py38h261ae71_2\n","    - chardet==3.0.4=py38h06a4308_1003\n","    - conda-package-handling==1.7.2=py38h03888b9_0\n","    - conda==4.9.2=py38h06a4308_0\n","    - cryptography==3.2.1=py38h3c74f83_1\n","    - idna==2.10=py_0\n","    - ld_impl_linux-64==2.33.1=h53a641e_7\n","    - libedit==3.1.20191231=h14c3975_1\n","    - libffi==3.3=he6710b0_2\n","    - libgcc-ng==9.1.0=hdf63c60_0\n","    - libstdcxx-ng==9.1.0=hdf63c60_0\n","    - ncurses==6.2=he6710b0_1\n","    - openssl==1.1.1h=h7b6447c_0\n","    - pip==20.2.4=py38h06a4308_0\n","    - pycosat==0.6.3=py38h7b6447c_1\n","    - pycparser==2.20=py_2\n","    - pyopenssl==19.1.0=pyhd3eb1b0_1\n","    - pysocks==1.7.1=py38h06a4308_0\n","    - python==3.8.5=h7579374_1\n","    - readline==8.0=h7b6447c_0\n","    - requests==2.24.0=py_0\n","    - ruamel_yaml==0.15.87=py38h7b6447c_1\n","    - setuptools==50.3.1=py38h06a4308_1\n","    - six==1.15.0=py38h06a4308_0\n","    - sqlite==3.33.0=h62c20be_0\n","    - tk==8.6.10=hbc83047_0\n","    - tqdm==4.51.0=pyhd3eb1b0_0\n","    - urllib3==1.25.11=py_0\n","    - wheel==0.35.1=pyhd3eb1b0_0\n","    - xz==5.2.5=h7b6447c_0\n","    - yaml==0.2.5=h7b6447c_0\n","    - zlib==1.2.11=h7b6447c_3\n","\n","\n","The following NEW packages will be INSTALLED:\n","\n","  _libgcc_mutex      pkgs/main/linux-64::_libgcc_mutex-0.1-main\n","  brotlipy           pkgs/main/linux-64::brotlipy-0.7.0-py38h27cfd23_1003\n","  ca-certificates    pkgs/main/linux-64::ca-certificates-2020.10.14-0\n","  certifi            pkgs/main/noarch::certifi-2020.6.20-pyhd3eb1b0_3\n","  cffi               pkgs/main/linux-64::cffi-1.14.3-py38h261ae71_2\n","  chardet            pkgs/main/linux-64::chardet-3.0.4-py38h06a4308_1003\n","  conda              pkgs/main/linux-64::conda-4.9.2-py38h06a4308_0\n","  conda-package-han~ pkgs/main/linux-64::conda-package-handling-1.7.2-py38h03888b9_0\n","  cryptography       pkgs/main/linux-64::cryptography-3.2.1-py38h3c74f83_1\n","  idna               pkgs/main/noarch::idna-2.10-py_0\n","  ld_impl_linux-64   pkgs/main/linux-64::ld_impl_linux-64-2.33.1-h53a641e_7\n","  libedit            pkgs/main/linux-64::libedit-3.1.20191231-h14c3975_1\n","  libffi             pkgs/main/linux-64::libffi-3.3-he6710b0_2\n","  libgcc-ng          pkgs/main/linux-64::libgcc-ng-9.1.0-hdf63c60_0\n","  libstdcxx-ng       pkgs/main/linux-64::libstdcxx-ng-9.1.0-hdf63c60_0\n","  ncurses            pkgs/main/linux-64::ncurses-6.2-he6710b0_1\n","  openssl            pkgs/main/linux-64::openssl-1.1.1h-h7b6447c_0\n","  pip                pkgs/main/linux-64::pip-20.2.4-py38h06a4308_0\n","  pycosat            pkgs/main/linux-64::pycosat-0.6.3-py38h7b6447c_1\n","  pycparser          pkgs/main/noarch::pycparser-2.20-py_2\n","  pyopenssl          pkgs/main/noarch::pyopenssl-19.1.0-pyhd3eb1b0_1\n","  pysocks            pkgs/main/linux-64::pysocks-1.7.1-py38h06a4308_0\n","  python             pkgs/main/linux-64::python-3.8.5-h7579374_1\n","  readline           pkgs/main/linux-64::readline-8.0-h7b6447c_0\n","  requests           pkgs/main/noarch::requests-2.24.0-py_0\n","  ruamel_yaml        pkgs/main/linux-64::ruamel_yaml-0.15.87-py38h7b6447c_1\n","  setuptools         pkgs/main/linux-64::setuptools-50.3.1-py38h06a4308_1\n","  six                pkgs/main/linux-64::six-1.15.0-py38h06a4308_0\n","  sqlite             pkgs/main/linux-64::sqlite-3.33.0-h62c20be_0\n","  tk                 pkgs/main/linux-64::tk-8.6.10-hbc83047_0\n","  tqdm               pkgs/main/noarch::tqdm-4.51.0-pyhd3eb1b0_0\n","  urllib3            pkgs/main/noarch::urllib3-1.25.11-py_0\n","  wheel              pkgs/main/noarch::wheel-0.35.1-pyhd3eb1b0_0\n","  xz                 pkgs/main/linux-64::xz-5.2.5-h7b6447c_0\n","  yaml               pkgs/main/linux-64::yaml-0.2.5-h7b6447c_0\n","  zlib               pkgs/main/linux-64::zlib-1.2.11-h7b6447c_3\n","\n","\n","Preparing transaction: / \b\b- \b\b\\ \b\bdone\n","Executing transaction: / \b\b- \b\b\\ \b\b| \b\b/ \b\b- \b\b\\ \b\b| \b\b/ \b\b- \b\b\\ \b\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":1615133034782,"user_tz":-60,"elapsed":157425,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"61f9b790-8885-4acf-8e9f-a6013a3038af"},"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":null,"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":1615133066963,"user_tz":-60,"elapsed":189598,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"3969ca0c-ba4d-4c07-a4ec-6fd748e2b305"},"source":["# clone repo\n","!rm -r protein-reconstruction\n","!git clone https://github.com/anonymous/protein-reconstruction.git\n","!cd protein-reconstruction"],"execution_count":null,"outputs":[{"output_type":"stream","text":["rm: cannot remove 'protein-reconstruction': No such file or directory\n","Cloning into 'protein-reconstruction'...\n","remote: Enumerating objects: 17, done.\u001b[K\n","remote: Counting objects: 100% (17/17), done.\u001b[K\n","remote: Compressing objects: 100% (14/14), done.\u001b[K\n","remote: Total 2972 (delta 3), reused 9 (delta 3), pack-reused 2955\u001b[K\n","Receiving objects: 100% (2972/2972), 746.34 MiB | 37.11 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/"},"executionInfo":{"status":"ok","timestamp":1615133167421,"user_tz":-60,"elapsed":290048,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"fee9063c-24f8-4bfc-d171-192dce232c7f"},"source":["#!conda env create -f environment.yml \n","!conda install -q -y --prefix /usr/local -c conda-forge ipyvolume\n","!pip3 install tensorflow-graphics-gpu"],"execution_count":null,"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.0           |     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.0   |   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.11      |     pyhd8ed1ab_1          76 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.11.4              |       h7f98852_0        17.9 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.16      |     pyha770c72_0         244 KB  conda-forge\n","    ptyprocess-0.7.0           |     pyhd3deb0d_0          16 KB  conda-forge\n","    pygments-2.8.0             |     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:       152.9 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.0-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.0-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.11-pyhd8ed1ab_1\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.11.4-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.16-pyha770c72_0\n","  ptyprocess         conda-forge/noarch::ptyprocess-0.7.0-pyhd3deb0d_0\n","  pygments           conda-forge/noarch::pygments-2.8.0-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-gpu\n","  Downloading tensorflow_graphics_gpu-1.0.0-py2.py3-none-any.whl (243 kB)\n","\u001b[K     |████████████████████████████████| 243 kB 6.6 MB/s \n","\u001b[?25hCollecting absl-py>=0.6.1\n","  Downloading absl_py-0.11.0-py3-none-any.whl (127 kB)\n","\u001b[K     |████████████████████████████████| 127 kB 8.9 MB/s \n","\u001b[?25hRequirement already satisfied: six>=1.11.0 in /usr/local/lib/python3.8/site-packages (from tensorflow-graphics-gpu) (1.15.0)\n","Requirement already satisfied: numpy>=1.15.4 in /usr/local/lib/python3.8/site-packages (from tensorflow-graphics-gpu) (1.18.1)\n","Collecting tensorflow-gpu>=1.13.1\n","  Downloading tensorflow_gpu-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: scipy>=1.1.0 in /usr/local/lib/python3.8/site-packages (from tensorflow-graphics-gpu) (1.5.3)\n","Collecting tensorboard~=2.4\n","  Downloading tensorboard-2.4.1-py3-none-any.whl (10.6 MB)\n","\u001b[K     |████████████████████████████████| 10.6 MB 76.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 termcolor~=1.1.0\n","  Downloading termcolor-1.1.0.tar.gz (3.9 kB)\n","Collecting h5py~=2.10.0\n","  Downloading h5py-2.10.0-cp38-cp38-manylinux1_x86_64.whl (2.9 MB)\n","\u001b[K     |████████████████████████████████| 2.9 MB 61.1 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.2 MB/s \n","\u001b[?25hCollecting typing-extensions~=3.7.4\n","  Downloading typing_extensions-3.7.4.3-py3-none-any.whl (22 kB)\n","Collecting protobuf>=3.9.2\n","  Downloading protobuf-3.15.5-cp38-cp38-manylinux1_x86_64.whl (1.0 MB)\n","\u001b[K     |████████████████████████████████| 1.0 MB 83.1 MB/s \n","\u001b[?25hRequirement already satisfied: wheel~=0.35 in /usr/local/lib/python3.8/site-packages (from tensorflow-gpu>=1.13.1->tensorflow-graphics-gpu) (0.35.1)\n","Collecting wrapt~=1.12.1\n","  Downloading wrapt-1.12.1.tar.gz (27 kB)\n","Collecting gast==0.3.3\n","  Downloading gast-0.3.3-py2.py3-none-any.whl (9.7 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 69.4 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 61.3 MB/s \n","\u001b[?25hCollecting astunparse~=1.6.3\n","  Downloading astunparse-1.6.3-py2.py3-none-any.whl (12 kB)\n","Collecting flatbuffers~=1.12.0\n","  Downloading flatbuffers-1.12-py2.py3-none-any.whl (15 kB)\n","Collecting google-pasta~=0.2\n","  Downloading google_pasta-0.2.0-py3-none-any.whl (57 kB)\n","\u001b[K     |████████████████████████████████| 57 kB 7.0 MB/s \n","\u001b[?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 68.5 MB/s \n","\u001b[?25hCollecting google-auth<2,>=1.6.3\n","  Downloading google_auth-1.27.1-py2.py3-none-any.whl (136 kB)\n","\u001b[K     |████████████████████████████████| 136 kB 84.3 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 9.4 MB/s \n","\u001b[?25hRequirement already satisfied: setuptools>=41.0.0 in /usr/local/lib/python3.8/site-packages (from tensorboard~=2.4->tensorflow-gpu>=1.13.1->tensorflow-graphics-gpu) (50.3.1.post20201107)\n","Collecting google-auth-oauthlib<0.5,>=0.4.1\n","  Downloading google_auth_oauthlib-0.4.3-py2.py3-none-any.whl (18 kB)\n","Collecting werkzeug>=0.11.15\n","  Downloading Werkzeug-1.0.1-py2.py3-none-any.whl (298 kB)\n","\u001b[K     |████████████████████████████████| 298 kB 64.9 MB/s \n","\u001b[?25hRequirement already satisfied: requests<3,>=2.21.0 in /usr/local/lib/python3.8/site-packages (from tensorboard~=2.4->tensorflow-gpu>=1.13.1->tensorflow-graphics-gpu) (2.24.0)\n","Collecting cachetools<5.0,>=2.0.0\n","  Downloading cachetools-4.2.1-py3-none-any.whl (12 kB)\n","Collecting pyasn1-modules>=0.2.1\n","  Downloading pyasn1_modules-0.2.8-py2.py3-none-any.whl (155 kB)\n","\u001b[K     |████████████████████████████████| 155 kB 84.5 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","Requirement already satisfied: chardet<4,>=3.0.2 in /usr/local/lib/python3.8/site-packages (from requests<3,>=2.21.0->tensorboard~=2.4->tensorflow-gpu>=1.13.1->tensorflow-graphics-gpu) (3.0.4)\n","Requirement already satisfied: certifi>=2017.4.17 in /usr/local/lib/python3.8/site-packages (from requests<3,>=2.21.0->tensorboard~=2.4->tensorflow-gpu>=1.13.1->tensorflow-graphics-gpu) (2020.12.5)\n","Requirement already satisfied: urllib3!=1.25.0,!=1.25.1,<1.26,>=1.21.1 in /usr/local/lib/python3.8/site-packages (from requests<3,>=2.21.0->tensorboard~=2.4->tensorflow-gpu>=1.13.1->tensorflow-graphics-gpu) (1.25.11)\n","Requirement already satisfied: idna<3,>=2.5 in /usr/local/lib/python3.8/site-packages (from requests<3,>=2.21.0->tensorboard~=2.4->tensorflow-gpu>=1.13.1->tensorflow-graphics-gpu) (2.10)\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 67.0 MB/s \n","\u001b[?25hBuilding wheels for collected packages: termcolor, wrapt\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=f88fa0c9d0982b77a0aec53fbd2f79e71e711d73dd6ba7b43382827662cd3804\n","  Stored in directory: /root/.cache/pip/wheels/a0/16/9c/5473df82468f958445479c59e784896fa24f4a5fc024b0f501\n","  Building wheel for wrapt (setup.py) ... \u001b[?25l\u001b[?25hdone\n","  Created wheel for wrapt: filename=wrapt-1.12.1-cp38-cp38-linux_x86_64.whl size=78017 sha256=86950374c991fd1dcf9984ae0404bb528216b734f04bda94365e45c7a5a9aa47\n","  Stored in directory: /root/.cache/pip/wheels/5f/fd/9e/b6cf5890494cb8ef0b5eaff72e5d55a70fb56316007d6dfe73\n","Successfully built termcolor wrapt\n","Installing collected packages: absl-py, tensorboard-plugin-wit, cachetools, pyasn1, pyasn1-modules, rsa, google-auth, markdown, oauthlib, requests-oauthlib, google-auth-oauthlib, werkzeug, grpcio, protobuf, tensorboard, keras-preprocessing, termcolor, h5py, opt-einsum, typing-extensions, wrapt, gast, tensorflow-estimator, astunparse, flatbuffers, google-pasta, tensorflow-gpu, tensorflow-graphics-gpu\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-gpu 2.4.1 requires numpy~=1.19.2, but you'll have numpy 1.18.1 which is incompatible.\u001b[0m\n","Successfully installed absl-py-0.11.0 astunparse-1.6.3 cachetools-4.2.1 flatbuffers-1.12 gast-0.3.3 google-auth-1.27.1 google-auth-oauthlib-0.4.3 google-pasta-0.2.0 grpcio-1.32.0 h5py-2.10.0 keras-preprocessing-1.1.2 markdown-3.3.4 oauthlib-3.1.0 opt-einsum-3.3.0 protobuf-3.15.5 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-estimator-2.4.0 tensorflow-gpu-2.4.1 tensorflow-graphics-gpu-1.0.0 termcolor-1.1.0 typing-extensions-3.7.4.3 werkzeug-1.0.1 wrapt-1.12.1\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"VZDmNWzdK4KO"},"source":["import sys\n","sys.path.append('/usr/local/lib/python3.8/site-packages')\n","sys.path.append(\"protein-reconstruction\") "],"execution_count":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"Zro6bM3VK4KR","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615133167424,"user_tz":-60,"elapsed":290017,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"c12c105f-f3f8-4790-ec17-430556f16b57"},"source":["!python --version"],"execution_count":null,"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","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615133236923,"user_tz":-60,"elapsed":21462,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"c432e399-d708-436a-813c-b03543d8e705"},"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":null,"outputs":[{"output_type":"stream","text":["Warning: To use the exr data format, please install the OpenEXR package following the instructions detailed in the README at github.com/tensorflow/graphics.\n"],"name":"stderr"}]},{"cell_type":"code","metadata":{"id":"m9Os8XDOK4KY","colab":{"base_uri":"https://localhost:8080/","height":35},"executionInfo":{"status":"ok","timestamp":1615133236936,"user_tz":-60,"elapsed":21077,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"fee35d59-1312-4b10-84c6-dd7e0990929d"},"source":["tf.__version__"],"execution_count":null,"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":1615133241998,"user_tz":-60,"elapsed":25733,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"27c6e290-ad96-4d73-e4a4-fd6c1db121e8"},"source":["from tensorflow.python.client import device_lib \n","print(device_lib.list_local_devices())"],"execution_count":null,"outputs":[{"output_type":"stream","text":["[name: \"/device:CPU:0\"\n","device_type: \"CPU\"\n","memory_limit: 268435456\n","locality {\n","}\n","incarnation: 11800895739504513334\n",", name: \"/device:GPU:0\"\n","device_type: \"GPU\"\n","memory_limit: 14674281152\n","locality {\n","  bus_id: 1\n","  links {\n","  }\n","}\n","incarnation: 17506218437728711050\n","physical_device_desc: \"device: 0, name: Tesla T4, pci bus id: 0000:00:04.0, compute capability: 7.5\"\n","]\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"kZFVlYW4K4Ke"},"source":["PROTEIN=\"5a1a\"\n","NUM_PROJECTIONS = 5000\n","\n","NOISY_VAR = 0 # vary from 1 to 10\n","TRANSLATION = 0.1\n","path_logs_training = \"/content/drive/My Drive/ModelsProtein\"\n","training_description = f\"5a1a_quartercvg_uniformS2_noise0\""],"execution_count":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"-q8GWm2EK4Kh","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615133242290,"user_tz":-60,"elapsed":24226,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"139a0ab9-f0a3-448b-82cc-b512fbd1448e"},"source":["# TODO: dataset name\n","#projections_filename = f\"{PROTEIN}_ProjectionsAngles_ProjNber5000_AngCoverage2.0,0.4,2.0_AngShift0.0,0.0,0.0.h5\"\n","projections_filename = f\"{PROTEIN}_uniform_ProjectionsAngles_ProjNber5000_AngCoverage2.0,1.0,0.4_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":null,"outputs":[{"output_type":"stream","text":["5000 projections of images with dimension (275, 275) 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":1615133256233,"user_tz":-60,"elapsed":38018,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"06a5c8f1-bee0-4aeb-b066-067eaadef241"},"source":["projections = np.array(data['Projections'], dtype=np.float32)\n","projections.shape"],"execution_count":null,"outputs":[{"output_type":"execute_result","data":{"text/plain":["(5000, 275, 275)"]},"metadata":{"tags":[]},"execution_count":13}]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"bu0vfR_1cKIv","executionInfo":{"status":"ok","timestamp":1615133256234,"user_tz":-60,"elapsed":37695,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"99305999-0d72-4230-f6e4-59365325facb"},"source":["type(projections[0][0][0])"],"execution_count":null,"outputs":[{"output_type":"execute_result","data":{"text/plain":["numpy.float32"]},"metadata":{"tags":[]},"execution_count":14}]},{"cell_type":"code","metadata":{"id":"bIQzyIQnxgts","colab":{"base_uri":"https://localhost:8080/","height":271},"executionInfo":{"status":"ok","timestamp":1615133256622,"user_tz":-60,"elapsed":35716,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"17202832-0a81-41b4-aa99-fdce51826c37"},"source":["sampleProj = projections[1,:,:]\n","plt.imshow(sampleProj,cmap='gray')\n","plt.show()"],"execution_count":null,"outputs":[{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[]}}]},{"cell_type":"code","metadata":{"id":"PpprtZ8vwc39"},"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":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"ydwWD-IkD0P3"},"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":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"oCD6IwpOr3_A"},"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)\n"],"execution_count":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"5FsWg8C4m9S3"},"source":["\n","from skimage.transform import resize\n","\n","dim = 116\n","\n","projections_new = np.zeros((len(projections), dim, dim))\n","for i in range(5000):\n","    p = projections[i]\n","    p = resize(p, (dim, dim))\n","    projections_new[i] = p\n","\n","projections = projections_new.copy()"],"execution_count":null,"outputs":[]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"dqYmKvjHnOop","executionInfo":{"status":"ok","timestamp":1615133295611,"user_tz":-60,"elapsed":71965,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"1d5ec269-1417-4bd0-a463-4a1466d100a9"},"source":["projections.shape"],"execution_count":null,"outputs":[{"output_type":"execute_result","data":{"text/plain":["(5000, 116, 116)"]},"metadata":{"tags":[]},"execution_count":20}]},{"cell_type":"code","metadata":{"id":"qR8J0QCmxG-y","colab":{"base_uri":"https://localhost:8080/","height":271},"executionInfo":{"status":"ok","timestamp":1615133295935,"user_tz":-60,"elapsed":67374,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"04e4f34f-50f4-465d-e3ac-2a02218746ee"},"source":["# Display projections with/out noise (for comparison)\n","sampleProj = projections[1,:,:]\n","plt.imshow(sampleProj,cmap='gray')\n","plt.show()"],"execution_count":null,"outputs":[{"output_type":"display_data","data":{"image/png":"iVBORw0KGgoAAAANSUhEUgAAAQYAAAD+CAYAAADYg6v8AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nO2da4yc51n+rzmfZ2dmZ3e9thObNLjaKlKj2iISAqHaURyBG/OhwsHUIJESoaqQfGiLqYQdaihsEqpGxCYpQpWKqkZUQi4xUh2piZCoIDjQVDIJburjJnue3dk5n9//B/+ve++Z14md7Nqz9tw/yUq8MzvvO+N5ruc+Px7HcRwYhmEovP2+AcMwNh4mDIZhuDBhMAzDhQmDYRguTBgMw3BhwmAYhoubKgwXL17EgQMHsHfvXhw4cACXLl26mZczDGOduKnCcPToURw8eBCnT5/GwYMHceTIkZt5OcMw1gnPzSpwyuVy2Lt3L15//XX4fD6022088MADeOWVV5DJZD7wd2u1Gs6ePYuRkRH4fL6bcXuGMdC0220sLCzgvvvuQzgcdj3uv1kXnpmZwdjYmCxsn8+H0dFRzMzMXFcYzp49i9/5nd+5WbdmGMb/57vf/S527drl+vlNE4a1MDIyAgC4cuUKWq1Wn+/GMO48/H4/7r77bllrrsdv1oXHx8cxNzeHdrstrsT8/DzGx8ev+7u0MlqtlgmDYdxE3s9Vv2nBx+HhYUxMTODUqVMAgFOnTmFiYuK6boRhGP3nproSTz31FA4fPowTJ04gmUxicnLyZl7OMIx14qYKw8c+9jF8//vfv5mXMAzjJmCVj4ZhuDBhMAzDhQmDYRguTBgMw3BhwmAYhgsTBsMwXJgwGIbhwoTBMAwXJgyGYbgwYTAMw4UJg2EYLkwYDMNwYcJgGIYLEwbDMFyYMBiG4cKEwTAMFyYMhmG4MGEwDMOFCYNhGC5MGAzDcGHCYBiGCxMGwzBcmDAYhuHChMEwDBcmDIZhuDBhMAzDhQmDYRguTBgMw3BhwmAYhos1nXa9vLyMr3zlK7hy5QqCwSC2bduGr33ta8hkMnjzzTdx5MgR1Ot1bNmyBc888wyGh4fX674Nw7iJrMli8Hg8+PznP4/Tp0/j5Zdfxl133YVnn30WnU4HX/7yl3HkyBGcPn0au3btwrPPPrte92wYxk1mTcKQSqXwwAMPyN/vv/9+TE9P4+zZswiFQti1axcA4NFHH8UPf/jDtd2pYRi3jHWLMXQ6HXzve9/D7t27MTMzg82bN8tjmUwGnU4H+Xx+vS5nGMZNZN2E4dixY4hGo/jc5z63Xi9pGEafWFPwkUxOTuLy5ct44YUX4PV6MT4+junpaXl8aWkJXq8XqVRqPS5nGMZNZs0Wwze+8Q2cPXsWx48fRzAYBADcd999qNVqeOONNwAAL730Eh5++OG1XsowjFvEmiyGd955By+++CK2b9+ORx99FACwdetWHD9+HE8//TSOHj3ala40DOP2YE3C8Iu/+Is4d+7cNR/71Kc+hZdffnktL28YRp+wykfDMFyYMBiG4cKEwTAMFyYMhmG4MGEwDMOFCYNhGC5MGAzDcGHCYBiGCxMGwzBcmDAYhuHChMEwDBcmDIZhuDBhMAzDhQmDYRguTBgMw3BhwmAYhgsTBsMwXKzLMFhjY+DxeAAAjuOs62t6PB54vV50Oh04jrOur29sTEwY7iB8Ph8AoN1uux77KItZiwJfm+Jg3NmYMNwBcAGHQiF4PB7U63VZvLQiOp3ONQXj/V5P/9fv9yMUCqHZbKLVaqHVaqHT6dyEd/L+96OtIROmm48Jwx2G4ziykPSCAq6Kw/UWmNfrFSuBz/X5fPD5fGi3267XvBnwGrxHbbEAuOXCNIiYMNzG6AXqOA5arRY8Hg98Pp8sJj6n2WzCcRx5rNFouCwI/q7P50MoFJLX9fv9CAQCslBv1PK43r3rxU+8Xq/ce7vdRrvdRiAQQCQSkedWq1V5P8bNwYThNoSLh3+azSYAyE7v9/vh9XrlACAuoOstJI/HA7/fj2AwiEQi4RKB9TLjeR2Px4N2u93l9gQCARGGVqslFoMOft4oXq9XXtdiIx8OE4bbEL/fLwvY6/WiUqmg3W537fZ+vx+RSASdTgetVktcg1ardc0dn6ISCoUQiUQwPDyMdruNZrOJer2Oer0OYO3BR1oKgUAAPp8PjUZDXs/n8yEcDosw0KrRlg/F6UZEjr/3Qe/buDYmDLcR2iIIBAIIhUJdJjf/zl2XO2W9XofH40E4HJYFHgqF4DiO+OoUk3A4jEAgIM/jwgyFQmi1Wmg2m/I7H1UkeF0dMOV1kskkAoEAYrEY6vU6SqWSBD/r9boICRf79WINFJkPE3w1TBhuKygKWhj8fr8IQyQScQUPO50OarUaIpEIwuGwLMpgMCiLy+PxIJFIwOfziftB9wSAiEqz2USj0ZDF+FFcCy5qBjJjsRh8Ph/q9ToCgQCGhoYQjUaRTqfRaDSwsrICn88Hv9+PcrmMarUqLsb16ip4LX5G/D3j+pgw3AbQLA6Hw2Jq66xBKBRCp9OR3Vzv8p1OB6FQCKFQCOFwWF4vm80iHo+jUqmg1WqJIPh8PglkAletAl6r2WzKgqaZzwDi+9F7rzTtI5EIAoEA4vG47Op+vx/JZBLhcFgsGloUPp8P6XQa6XQaiUQCtVoNuVwO1WoV1Wq1K1ahxZHB1o8apxhUTBhuA2gpBIPBrug8ANn9HcdBvV6XmIDf75cUXyAQQCAQQDAYlIWRzWaRTqdRLBbRaDTktfhfLQyEr0ETXrsV7wd3bP4/F20oFJL3QzGiCxEMBsUqCgQC8nuxWAyRSATxeBz1eh2tVkuClLSOAHTFFrQw3ew0653EugnD888/j7/927/Fyy+/jB07duDNN9/EkSNHuk67Hh4eXq/LDQzcLWn6N5tNBINBBAKBrl1SBx11upILg9ZGp9MR96JUKsmCpMVQq9UAAPF4HI1GA4VCQYSi0Wig2WwiEokgGo0iGAyi2WxK8JNZAPryFLBOpyMLnffHrARdlvHxccRiMWzevFnuIxAIyHVCoZAIRbFYRLVaxcrKimRf6Cq0Wi1UKhUAEEGi1RMMBsXSMavhg1mXJqr//d//xZtvvoktW7YAuPoP8eUvfxlHjhzB6dOnsWvXLjz77LPrcamBQRco0WKg2c6/Ey5+Lj4Kh/65/sNgHAOMDFgyU6CDkMBqsJA7cjAYRDQalbiFFiL+f2+NhdfrlXsLBoPyPFowiUQCQ0NDiMfjiEajEkPhzzOZDFKpFJLJpFgOFLtoNIp4PC4/67UUGGvgNY3rs2aLodFo4Gtf+xr+5m/+Br/7u78LADh79ixCoRB27doFAHj00UexZ88e/NVf/dVaL3fHQzFgLQL/CwCxWEzqC/hcALJoKRZMY/L3o9GovAb9d4qDtiw6nQ5KpVKX9TE0NCRiwaxAOByG3+/H3NycxCharZbEBRiLoInv9XrFyqD46HLrcDiMRCKBaDQqBVWjo6PymfB9RyIRhEIhvPfee/K50JWi0LXbbREbFkeFw2EJ0OqaDwoGsL6NZ3cCaxaG5557Do888gi2bt0qP5uZmRGTEAAymQw6nQ7y+TxSqdRaL3nHonc6LQxaLMLhsCxEpiqB7iAhFx4tAboJ3PG1v613+t5CKO7yfA3GOSgszFQwDkALw+v1SgCU8HX4vihUOjDK12UNBu+F8Qg+l+LSG1Tk+/N6vV3l1NeyrvRnDsDcix7WJAw/+clPcPbsWXzpS19ar/sZWLg4GYxjapG+u85KNJtNKWxqNBqy0JmxoMvA1woEAqjVahJobDQayGQyiEaj4jJEIhERH8YTuKNqi4SLn3g8HnENKGJMfdLKqFarXW6MLr0eHR1FPB7H3XffLelWvi5jK81mE6VSCY1GA4FAAIVCAZVKRWIQbO5iEJXWBsUzEAiImPJ+eQ1+zvl8Xp5jrFEYzpw5g/Pnz2PPnj0AgNnZWTz22GM4dOgQpqen5XlLS0vwer1mLbwP2lLgrsrehF4rgj8HILtmr9tBv793d6b7wKyCfn39u8w28A/viQKki4V0QRVfJxaLicjQEtE7PK2LYDCIeDwucQMuUqZL+XkAq1aM7vDshWIzNDSEdruNWq3W9f5pydCiAK66MrS2emMj+v0OmjWxJmF4/PHH8fjjj8vfd+/ejRdeeAH33nsv/umf/glvvPEGdu3ahZdeegkPP/zwmm/2TqPX7Gc8gGY3gK54Ai0GpicDgQCazSai0ajszl6vF0NDQ3AcB7VaTXxvr9eLeDwuvj+zCSwwikajci8MEPK5DPCxNJpFTmy08vv9XYVTIyMjACBlyPF4vMvv73Q6XZZCPB7H8PAw/H4/Go0G6vU6yuWyfC60bJaXl1EsFqXQiiJBtyWdTiMWi2H79u2oVCrI5XJdlgQARKPRrnhEvV4X8dPBSmA1TczrDZI43JQ6Bq/Xi6effhpHjx7tSlcaq+i4AUWBJr3Ow+tIfyKRQCwWAwDZhVmcxJ2NablOpyNfZv2FZpyAFoIOAjKGwYWmU426CAmAlE3zHrU/z5gDxYWNXu12WywPLXJ0RXT6kvUMOlPCz4oZC6ZfdcCRP6MrRcuDVoauqaDw8fm93Z7X6v4cFNZVGF599VX5/0996lN4+eWX1/Pl7zhYAaiDb8PDw/B4PCiXy/D7/UgkEgiHw0gmk0gkEpKVcBwHjUZD8vY0rbVlwJ2Si6DdbkscgkE8LjZeP5FIoNPpoFqtio/P+AQXaigUEhEol8tynUQiIdcKBoMYGhpCvV5HsVhEqVRCuVxGMpmU9CKvSSFpt9solUqIRCL4hV/4BQDd06goXENDQ1LHUavVZHGz5LlYLCIQCCCbzYrFsLy8jHw+j3g8LtYYhYGuhc7ssLqzUqmYK2HcWvhl5JdfxxO4KGOxmETl6WLo33McB9FoVHZELnqKAL/QfC5TirQWKCDcYePxOBzHQaVSEWuA19dNVwDEdOfioaVSq9UkbcnFyvcTjUaRSCSQzWbFRdA7eqlUQqvVQrlcls+In0upVEKpVAIAsTJ0fwfvj0Vg0WhUFnckEkGj0UAikUAoFEK5XO5yh/h58jPhvetsxyBhwtAn9K7PxQ1AfF12FA4PD3cJBc1zXbYcj8e7fGNaDPyya+HhYmT59OzsLGq1GkKhEJLJJO666y54PB6pZtT9F7znQqGAarWKVCoFj8cjfj+zJPTfy+Wy3AddglQqhXQ6jXvvvRepVAoLCwvyO9VqFfPz84hEIojFYl1B00AggIWFBeRyOWSzWQmw8jV1vYd2JSqVClZWVuR1hoeHEY1GMTU1hUajIT0bwGoWg12ddH8GEROGPqFjCLp0l0G3Wq0mMwloLTA+wIXKBcjX42JhsI8LW3dKAlcj+3Qh+FydrWAakNZLPp/H/Py8CBTNf50haLVa4hJEIhERJMYOeJ8MLOZyObkvFmR1Oh1xrejzM2tAd0XXJLDhKhqNSqcoxatWq0mDFQVKZ2kYS2HvR7PZlFgJ73fQ3AeNCUOf0GlCPc2oUCgAWN29mHJjtkKb9KVSqSvtGIvFpHWZO3Wj0UC1Wu1KAzYaDQnu9T6X1YLxeByhUEgallZWViQmwN/N5XKSpWDbN+sgaEHoHgVeo1gsYm5uDsViEZs3bxZ3AkBXExWFsFKpSPk2xcdxHAwNDQFYTUPy82DsYXl5uaupTAcwY7FY171Wq1XUajU0m82u2o1BxYShT3BxM3jGHS2RSMDv90vPACP3wGqV3srKCkqlEgKBABKJhOyCNKkpKuPj47JAaZmwwIlikMlkJAbAHbLVamF5eVkKg+hW0ELRHZGdTkesAgYlY7EYqtWq7OIUI8YN6H6wYElXZrLgiv4+F+3KyooUKFHkONSFqUtOx+Y1dUyEj9MKowun5zTQ0qCImcVg3HJ0jIG+LNuOaSGw6If+OSmVSlhYWMDmzZsRi8XEzB4aGoLH45GpRyMjI2g2myiXy5L5qFarYgHUajUx47lTAlcDlSsrK7LQq9WqBPXobtD0ZzpSl0/HYjGUy2XZ6enO8Hp+v1/iEYwfUGDS6bS4D1ywtVoN5XJZrqNjKaFQCKVSqasmRAc9ie68pHDSStODZ/jvYcJg9BWOOOOXkDsoF2WlUkEqlUI2m4XjOGIpsNuQ7dEej0eEgdkJtlXzOu12G5VKBaVSCcPDw4jH42KhVKtVeL1ejI+PSzCw2Wxibm4OrVYLIyMjslgKhQKWl5dRKBQkAEpB8nq9WFlZkaIg4GoMgRWVwNU4Ayc19Y52YxyA9RkUPrpDACRLUiqVUK1W0Wg0UKvVsLCwgHq9jkqlIpaGthR09SXQnRXS/09rhc8ZREwYNgC6iIaLgzs5fWumBekW6LZnftl1JSIAKUDSC4E7dywWw8jIiOzQTE+mUilUKhVxO2h9xGIxWTTFYlFEgRWYwOp5D71VgrodnO+V6URaQkyh6jSqbtXmNCp2X/p8PhEfplxZU8EhLnQZ2FuiW8J7i5d0ZeagioHGhGGDoCv4WOUIrPrGxWIRtVpNZiPSvWBvgMfjwfLyslgO7XZbmpfYJk1BYbZiZWVFFu3S0pKY7+12W1wa/p3ZhEqlIk1MdHOYRdCTpIDVse2tVktSkDTTk8kk4vG4lFNXq1V5v1y0OlsQi8XEwsjlciiVShJTqVarCIVCUgo9OzuLQqEg1hVdMs5q0A1nACTwSAvDGqlMGDYMepdimg6ALCQdMGQ2g8LQayFQKPRrXasRSzcj8QAXBg31Lq/7Ehi5Z9SegUtWTwKrbc90a3rbr5naZHwBWJ0poTMB+u8UuFgshnw+L6/F7ksdY2Bql/egW7b169GK0I1hfE+DWgpNTBg2CHq2ANA9joxdkdzxU6mUDC8JBAKy09VqNVkQrDfgrq+vE4/HpSQZuCpKo6OjEsMAVkfFDQ0NyXAW7v4MJuZyObTbbWzbtk2GujD1ymIlxgfojrCAq9lsolgsYnR0FJFIRK4zOzsr5jzLkvXMiXa7jWw2i0wmg2w2K6PearUaZmZmpO2b4sD3TNeL6VW6PQzG8nNgIHiQRQEwYdgQ0LzVLb8MgOlRbLqZqDeAxseZ0yd8XDdt6TZrLgC6Afwd7sA0v1mdqbMTxWJR/q77Duha0Drg6zEzEgwGUS6XxfcHVgfGaN6vZJwBS7oyFEJej4IXi8W6Uqp8TX6++o+OxRgmDH2HpiwFgP4/W6JTqRS8Xi/K5TKGhoYk9lCr1bpOnwoEAkgmkwCAYrHY1TrMIB4bkOLxuOTr9XwEPl+b4Ew9FgoFpNNpBINBXL58GUtLS/D5fCiVSigWi6hUKqhWq4hGo9iyZQu8Xi+y2SyKxSJarRYSiQSSySTS6bRkUprNJpaWliQVqXsXKEx0jwDI/VDkaBVks1mJxXCAC1OjutGMQkY3gXGYRqMhB+roBqtBxoShj/S2XVMYtHXA0l3uytyhAUjkXk9f4hefrgiwes5Cb84eQFcEX7syOhvAnZ3dlzzXgeXUPNeBi1jPjeQCpiVDVwRYzcDoRch75WN8Df5h7YNu0WYpOPtIOGOCnxXfI2cv0Epg3YI+RKfXchtUTBj6BE1XdvvpYB0Hq8ZiMaTTaVQqFSwtLUl2QndSer1ejIyMSDWiXiCsptSZCEb/uWuurKyIKc0mLVZesv6AAcRkMonR0VFpmmq320gmk3j33XclY0Jrh+df8j22Wi0UCgWpdmS8IRKJSLOTnmXJ4bGZTEbe1+LiIubm5qTxifMmWTnJeAyzHyywohXhOA6Wl5flPnlPDF5SaE0YTBj6Br98vZF4LgI+xkXLQam0BtgazdJgms0AujIYekIUYwVcnNyRdZGVrkHgbspeA5ZwA5DDb7krM5tBt4Z1GAAkA6JTrbowiilOWg76HtnXQZeGvSM6c0LLgQILQISK96yzO7rWgSXpvZ/boGPC0EeYMdCdllywNLtZtZdKpboapgAgn8+jVquJ718sFgFAfGlg1TSmNUBfe3h4uOvsCIpOqVSSWYw8Bo41CI1GA4uLi3AcRwqe2PewtLQktQyMddANqdVqqFQqKJfL0milTXi2aAOQzkw+xlbxdDotMRWKVyKRkPfk8XiQTCZFjIrFohxMs7i4iFKphHq9LuXVzEYwo6P7LUwYTBj6ig6CMSbAlKMubOLurHdKx3GQSqVkKAmblygiHHqiD77lQqnX610zHoFVAWGqj7s6U4sMEHo8HqysrHQVBXEBM3DJgB8AERU9Hp7WAQfHsItUD43Rp3HXajXk83lpFNNzEnR8gPdSqVTEYtDVmPy5rsug0PIz1ZmaQcaEoU9oUQBWi5O4kGmeLy0tyXg3ZheYsuSkJu7CQ0NDiMViyGazqNVqePfdd+V3CoUC8vm85PEpNAwMAlcDjsPDw+IK6HmNWhhYWci8P9OFfB0uSs57SKVSKJfLsouzPRpYDRxy0fJnY2Nj8jmx52NsbAzZbFaEZ2lpSYSBi79er2N+fr6rDoLiwgEzupYBwDWzMr0FToMmFiYMfYS+t86lsyGI49G4GGkRsNxZWxosSwYgC6Ner6NQKHRlAvSwE1YCcsI0axsoQLQC9OlSejCLbvyiUBFaKLOzs9K/wPtgkRYDkfl8XgKGoVBIzp3U50ak02kMDw8jm81iaGhICqsY1NTnZei5Cvwc9QxKZnEYQGUmCIAMcKHQ8J5pTfHfahAwYegT3JF0bwCFgXl4oPssCGYGdGEOG5K4gFutFvL5vAxE4ZgyLnzGGphx0NWIen4ir68DhRQtigZhapHvhfMUFhYWUK1WpT6A16E1wsAf51Dw82AKlMfWpdNpjI+PSzcpuyo5n5LXoItAF4cH8nIeJd8j35ueGUFXjsIArPapUBh0sdWdjglDn+k1WfnF5mLWJjV98FQqhUQigVQqJVV+/F0+x3GuTjjqdDpIpVJdsx8BiLUwNDQkgUtd/MPAZ7VaRalUwsrKSleNBOdH6PSoTvXR/eDuzfQjF2qhUEC9Xkcmk0EkEpGBM/F4HAAknpBKpeS4ulwuh/n5eRGc8fFxmeikA7MsBWc8g2Kmy8xpYdEq0y3kALqEQg9+GRRMGDYQXPwsFmJ5L1OCXLDBYBCJRALj4+NIJBJiGdDn1iY7F6pO0XFRM6jJ2Qa6+ElnRRjJp8uhFxmFgSlDXXLMWYv8O3DtgSmsytRnUjIQypF2wNVMQ7lcxsrKisygoDAAqwFU3aDFszd4b7rRqtPpiNujU8MUGlpZWjAHBROGDYJuB2ZTEZul9GGwwGppMPP/egpUp9ORuoNmsymLn5WV7FHQo97YBu33+5FKpVCtVjE3Nye/z1Qfd9tkMgnHccQioNVCq4KmuXZbCoUC5ubmJJZAkdJmPKsldT0FKxwpfrpqktWaDKQyq0PXJR6PY3l5uaurlDGVc+fOdcVxaM0wVsG4CAVy0FKYJgwbCB0HYHqPgULWEeiKRwbGdLqzt6SXuyOtAD3FiP41G6QoIgxWsnKSOygXB3dpBvB433qGAusyeL1Go4FCodDVPcr7081LevYk4T32mvM6oKmHvTL9GI1GJYipy6VZ3amhZUCXCFh183Rz2aBgwrBB0JmHeDwuX2AKAacaUxyKxSIWFxfR6XSQTqcRCoWQzWYBQNqI+eXnzhsIBMRv9/v9smvrWYra+uB1y+WyND7lcjkZ/LKwsCAnVHU6V0ff0/UIBoNIpVLiz7Oak/5+KpVCNBrFvffei1gshqWlJbRaLSmjZnnz8vKyWFE6QKutCF6XDVlsv75y5YoEJXWRlB7+SguHpeb8fHunO1mMwegretcDIDuwDvzpyHu73ZZj13TakZYD4xXcDbmLa5eDZrledLweLQI2c9Hy4GM02/WgE2YaKAaMa2hfPRgMSnyDWQwdY6GFQquI1wDQ1YWqS8S16Q+snr5FdIs6hVg3mFEYesvUBy2+AJgwbCj4ZWXUnotSlw7zC1wsFmXxsSaAC3h4eFjckZWVFbz77rtS4BSLxRCJRORAG45XY3BRVwWWSiW88847iMfj2LRpkxQnsc2a8QYdKPV6vdITEY1GUS6X8d5770kdBK/PeZMseuL7unDhgixE1lUkEokuNyiTycDv92N6ehqNRgOjo6PSNh0MBiUewgKwVquFmZkZ/PznP0cmk5ExbzyXwu/3S/CVIqqthUHsnzBh2CDopirt09JC0Ee50yrQJzbp4So6e6CLdBhr0ANSdbs2f1dnI+ij8zV6T9bmfWvTHIDUKbDgqHfH1f0hACR7wHMwWbjFOAffKy0en88nsxT4Hvh6PO5PZ1D0cFhmUqLRqJxFQYuI96Xfz6CJArAOwlCv1/H1r38d//Ef/4FQKIT7778fx44dw8WLF3H48GHk83mkUilMTk5i+/bt63DLdzYsutFTlgDIZGdOd85kMhJhZwPS0NCQmOfNZhOLi4vSMBSLxbBp0ybMzs5ieXnZNeGZXYu5XE4yAdVqVQ6bqVarMiimWCx2CQIXD6scaR3wgNp6vS7BVN2NGQ6HZbdfXl6Wegm6Hkw5sr+B7hJrI9hXwecxLjIyMoJarSYH8ywtLYmFxEpIDsDhhGyv9+rYewZUGWsYtNgCWbMwPPPMMwiFQjh9+jQ8Hg8WFxcBAEePHsXBgwexf/9+/OAHP8CRI0fwne98Z803PGhocWAKj+a7Lm7i49x5PR6PlABXKhU5i4FBPfYM0AKo1WqSaWDGQ2dBmOpkpSEXJXdlWixMH+q6AABiGejYCV+bNRXtdlvOn6D7xGnUfC09Wo7XYFk1u0sZtNXxB8YVdPMVAOnRYI0D4xe9GZ5BE4c1CUO5XMbJkyfxb//2b/IBZrNZ5HI5vPXWW/j2t78NANi3bx+OHTuGpaUlZDKZtd/1HYr+cupeBZq27GrkYmSPAcnn87ITJxIJ3H333VhaWurqIOQhsPPz88jn89JlyTJhHfnvnYnIgiW2Ko+NjckMR7ocrF6kK0EznlYAxUPPcOBRe6FQSMquS6USCoUClpaWEA6HpWajNxDYarVw7tw5CYbqz0THCfh3ig47MWdnZ2XgC60Upl75u4PUI0HWJAxTU1NIpVJ4/vnn8frrryMWi+GJJ56Q7jjtP46OjoZDYoMAABxoSURBVGJmZsaE4X3ggmTQMJFIyPmVhDski3W4o+nagGazKVOK6GZwcfNIeHZZciGwj0DPeuCuq5/Da9Dq0H/nf9vttgQCddMWxYzCREHhqVX8XQ6cYaCzUqkgl8sBgJyErTMuukOV6Vntjuksg3Z76IIMDQ11VWDys+PnoKsiB4k1CUO73cbU1BQ+8YlP4E/+5E/w05/+FH/4h3+I5557br3ub2DgDhUOhxGPx5HNZhGLxWToiV60jKrrYh5gteCHGYZcLicWCI+mm52dxeLiopQk61kPjuNIdyMDc5wPwSGsLKemFdNsNqV1mu5ANBqV+QdacOjeJBIJyU7Mz89LTwhdCp7NyZhDsVjEe++9h02bNiGbzXalQmnBeDweOaCXC5vTnXS6lC4G06S6F6VcLsvwGz2glqnRQWJNwjA+Pg6/3499+/YBAD75yU8inU4jHA5jbm5Odpt2u435+XmMj4+vy03fiXDX52LUXZb0d2lGc0cFIEfVswQagHQycmdnnQLHwfM0ahYJNZtN6W7kuDgWDXGh0B1otVpSfMX0JAVJ10/oMmNd8kxRYbyENRh8HQZLubB1vIIpRb4Wi75oRTAoSqHkAmdAU89fYG8GU6VsFmOauLeDVbeZDwJrEoZMJoMHHngAP/7xj/Erv/IruHjxInK5HLZv346JiQmcOnUK+/fvx6lTpzAxMWFuxAfABcXhpVzIPKyF5jqHjjDiz8cAdBUjaWFgfQKFIR6PI5fLicBwcAuDkHomxMrKigToKFC0Mmi15PN58e91IxPHtOm2a30mZ7PZRDablWYv1mfo98xDYlhXoQ/EGRkZkUpRAJibm4PH45Hp1RQ+Bid1OThdmXw+j0qlguXlZRmTz1iP7kgdtCDkmrMSf/7nf46vfvWrmJychN/vx9NPP41kMomnnnoKhw8fxokTJ5BMJjE5Obke93vHomsOWHrMZiMuEnZUxuPxrhJh/i5N93A4LENQ9MBTHlLLWgE9P5F+Nl+L1x0fHxf3hFYCT5Pm8fO949m5u/I16WpQENh4pbMfwGqVJwOErC/ozQ4wWzI7OyvugtfrlQnYTE3S3eg9eIaZGloU2iLStQycZk3XRI+Uu9NZszDcdddd+Md//EfXzz/2sY/h+9///lpffmCgm0BxKJVKEjij751IJJBOpyUIpweXcjHTL9YTjPL5vJj3HKkOrBYV6eCa7h8IBALIZDJYWVlBoVDoOiOTIkN06bYu1tKBS4oI3SRmAvRJVvoPeyZ0sZFu46bbw91fl1KziYoVkPo1KVC0vpiB6c14MJahy61NGIy+wCIe7rpcxNwZeWYDzXm9mw4PD4sFUalUcOnSJVSrVaysrCAajSIej4t/ziDg1NQUyuUyLl++3CUUtFJYcQhcjWckk0kpYgJWZzcwoMdCJ54NUa1WJavgOE5XAZbH48GFCxfktXXHJxe1Hoyry7WZ4eDC5bwJCgwHw1AIOKWaFgOtA74m3TfWhuhJ3boadVAwYdhg9JrNeuHpzkCauixhZhUjFwkXZLValQAjgK4hsBQfxhr0cFimRHkNfZgNd16d6+f16QrwMbocunmJi67ZbEpgMJFIiNvBPgk9bIVWjD50lrEUWk1c7PocDG296FOsaDHokmltUTAYqkuiB0kcTBg2CDSVq9UqHMeRhcLFCay6Cyx1Hh0dRSwWc5Ukz87OSukvg4U8nZqpQi4Y+tHA6ji1YDAoZ1Uw8s/FvLKyIqlUujuMZegqSMYldHxDl0avrKzIYBW+N4/HIxkJ4GpaNpPJSNUm4yMs5KpUKhIk1JOfHMdBrVbDhQsXROB0FSQzGGy68ng8Ul7O+2Uqlq4G3Y1BwYRhg6GLcbRVoMuB+f+sMQC6T3sqlUpiIehiINYt6GIlne+nT88iJH12JesaONuA8yR7W6J1wZW2fNjgxMe4+CgIOpXI+9BNXpy9SDdHixAXrB74whSknu3Az0qLV+/ZGjqWoeMdvS3cdzomDBsEPT+RX+RIJIKxsTFpB261WlLGHAqFMDU1JYVFfv/VU58DgYBMTeZuqoehsimKC4JfdvYHsCpRuw6hUEjOnIjFYvJfv98vg1p4jkWz2cTQ0JC0XTMdyJgGFy/TpBQpjmBj4VMikUCz2cSVK1fkM9KzG2hBUBS0tUWRYY8FG9BYgAVAyp4ZwwEgv8c0p575MEiiAJgwbBh0YRD/AJAFrMuQic4oUEg4nZmBPh3156JgxkG3Teu0JYuIgNXJ0wxG6tFoFA4eLsMdmfdLK4MWCE/J1gNWgNWj+nQjFrDa29DbCs3f0c/jf3sDhdz5dbGSnm1BwdTZh97HBxEThj7Dxanz7vw5AOkuTKfTXQVG+gSpXC7XddDM1NQUAoEANm3a1HVWI0uluciZBvV6vSiVSvD7r55ynclkMDY2hkajgenpadd5FIwfMAbChTg6Oip+eSgUkoExALqyIMvLy10NSzrImEgkukbYscFLHySjy8eB1TMwdM8Ig416BiUtgk6n05UOprvBGM61pjgNGiYMfUYHzehO9KYKKRisE2AUnbGH3l0egMQgdJ4eWHVZdK8DsGpGM1Coj6XXaUTGNXSDHF9T9xPomRIcAa+fS0uFr6VjEAweMmaiZzzo+Qi6X+Ja719PlOb1aGnoTASfz/fOz3mQMWHoI7pmnzMUaHaz54QZBPq9hUJBdnuOltepSL/fj0gkgkajgbm5OfmysyKSMQSa3OVyuatwiGc8Tk1NiXXB1GapVJITqxmkpBXhOI5E+gkbrjgXgn9nFkS7Tly87Ihkz4I+ml4HAmn+AxAR42uxQ7NUKiESiSAej8vrs82cZ3Cw+5QBXbphgxZT6MWEoc/wS8hJyrpugIuJz9MDRACIK9D7RebvctfTOyaDgnrGAEWC5ztGo1Ekk8muLAgzD7pDEUDXTsxsAYOXOruiU5DXinFQ3FiXQTeA71mPe6flQHhdxhDoCvC1gdUDb1gdqgWGnxPvd9BFATBh6Ctc7OwU1H48FzaDgvzS6vMTotGoWBR6YhEj93rYC4Np4XBYJkC121cnTHPhhkIhbNmyRYShUqlgdnZWpjLRnOdOzqlPvB8eJReNRsVf17l/Dp+lJaTbxXO5nFQz0g3ioo1EIlKYxeItCgPvzXGcroGuwKpg0NWiqLF+Qh/Sc63A5SBjwtBn9A6l/eJ8Pi8t1YQ7G+cx1Ot16VLkQmSfBQWC2QF+6dnmzF2X7gdNcF0CzYXEjk+Kgjb7mfKjiOn6AsdxxE3Q2RaWRFP02M3I5wUCASSTya4YAGMlzWZTRJFuhj7Vm3EQwnsi2v3QwUyzFLoxYegzvTsVF7rjOJJ7547O54XDYaRSKczPz6NcLovJzPZnBggjkYjUHRCmGjmQhX0XvQFPXYLNuIMukuJgV2D1EBmmLfUO3DttiqKytLQk52IAkG5LCgMnKzEQyqpOViuyM5Rl1Xr2B2dVULgoUDq9ydcbxHLnG8GEoU/owBsAmRgEQPxlmuKRSESmGvt8PuTzeZmHWK1WJeUIQOYgMF6RyWSwfft213mM9OVZIJXJZEQ06JowWAdAmoyazSZSqZTs6hwmo311r9fbNTlJuyBDQ0Pi/ujAI60UZgR4L4yJpNNpuQaHx2hXTA9o0dWSuqyZQUZgtfLSBOHamDD0CS4KflE5S0A38DAFyGPvaW7z1Od8Pi8lyqxB4GGuNMuTySTGx8dlQlGlUpFSYS6gQCAgvRF6gCsAGdDKqdI8NIYFVHRFmCVgOzSwWoDF98dp1ewKpSBot0RnHPQsBz0dioudIsfPTDdO+Xw+ObuSLpYeNjPIxUs3gglDn+Bi4C6oR4hx9BmfQ1+YKUIuOOb6KQwMXDJmwJ17YWHB1UXIVGM2m0UikcDY2Bg8Hg8uX77cVS+h4xHA6iEu+uxIdkhSGFiqzHgJr+vxeOTULN4j3y93cM5OYNxED3XReL1Xp1HzJG1d0KTrLgBIRoU/G7S+h4+CCUOf0GW+OgWom54AdPnIoVBIdlDGHPSu1xvko7/PqkaW/bJFmr0RPMimt1xYo0uR+TzuxOVyWYKCDH7yubq1mULV6XSkSYuvTTNfV1Lyc9H3ou+D8RfObOgtdNLpWloTg9QhuRZMGPqE/sJrX/dafi/Ne45sSyQSiEQiyGQyXdF8DnjlQtCdlzxnMhAISOszg4J6lHw8HkepVML8/LwE/yhMvQ1WNM03bdrUNdikUqmIOc/sgz4Wj4JB1wRAl6XDwCmtB4pauVyW8ytSqZTMkGCGojfmwPdOMdLuilkMH4wJQ5/4MIEvnQpkuo3BNe6weqiLThfqtmT+DnP/rLhk85SO3lMUqtVqV08Dd3m+BwYK2UPBjAaFgaXQtIT04JRei0c/RwdHdas2PwfGHPi+mAHRVti1PmcLON4YJgy3AfwycyGxqUo3IOkqSboipVJJ+iVYbRiPx2VuJFu0m80mLl++LLEDnszE06IIz5fQE528Xi8KhQIAyEAZXZ/Aa7ILs1AoSPDT5/OJtcHzN2nFMAtSqVTkeowf8DPhRGlOk+agFX16NtOfdI90q7nx/pgw3CZoV0MPM6HLwJgDsNplqOsG9DASmuzAalsyawp00I6P0+rQ8xYZD9DX5T1qK0THQnTBlB5DR9HTJcz6feu4AQOcvVBodDm4dhl4fROFG8OE4TZBBwZpUmezWcTjcdn1WbDDZqlNmzaJaxCPx2WASqfTwfLyMprNZteZEBQbAF2BOo585xg0Bhv52kx18nFaLKyYrFar0jbNVCvLvi9fvgwA2LJlS1eRUzwel/oDHTPpdDrSNMX0rB7Y6vf7MTo6KgfmME2payqM62PCcJug/W/6/sViUeIPFAz9fO7oRDdhMSVIAWB6VFdY6lZoXod9CrqGgMFRuhJ6t2aWglkDBiIBSACTvwN0D2DRqUw2P3m9XmnFZkxEu1n6+rRQ9Ps0i+HGMGG4DdCzGgKBAAqFAiqVChYXFyWgyKPa2HEJrB7ySmuiWCxK/YIuL/Z4PLh06RJarRbGxsZECNhYReHhcBOOlqPLkM/nZYCsjjmw9Dqfz8tQW56hyRkN7N6kEEWjUem/4CJeWVnBwsKCZCo4Fk5XMVIUKEQsbNI9GcaNY8Jwm6DrHfSgEWC1ZZmBQR0T0C3L/DsXHlOLNPlppuvBMLpJi92NvAYtBz6fMQW6NDp9yOIstpUzyMlAJBc3d/darSYuDF9Xd5DqNmsArvgEYylWt/DRMGG4DWCEn81VXOxcJBQGfc4CD1FhmzXLiJlS5IKfmZnpOkhW+/P6bEteX9cEUDDY7ckMBs+xqFariEajSKVSUkjF+MDi4qLEHmg5cLgKy6ppbbTbbTl5i8/nMFjeiy4KAyDl1LoN26yGG8eE4Tahd9IRFz+Daz6fD3NzcxIEZKcjj5Wnr63Hx/fWL+h6Be64TAOyWYqLUxcOUUjoFuimKgYPWYrN7lBg9Vi7druNxcXFrpOgaBHR5aHVwGpHYHXmIzs9l5aWutqv9VmTJgofDhOG24DenRxYPdxV++PM6afTaalRYKUjFwzHs7MDkyY8C5H0kBjWLfB3aXUUi0VpYtJBvytXrog1Q1GiJRIOhyUbwaPjdGXl9PQ0yuVyV4yDokeXhhWfuqza7/fLqPlcLtclCvpMSuPDsWZheO211/Dcc8+JufvFL34RDz30EC5evIjDhw8jn88jlUphcnIS27dvX4dbHmzow1MM9K5PseDiZLOUz+cTf52xB1oZHMACdA+m5evypGe/349CoYBCoSCpQN1spTMYFDHOeGQco1gsIpVKSds1BYTDVhqNhpyhyXiHPvaebgHfH10bnWWh0FF0TBg+GmsSBsdx8JWvfAXf/e53sWPHDvzf//0ffvu3fxsPPvggjh49ioMHD2L//v34wQ9+gCNHjuA73/nOet33QNN7PqQufebC1seyxWIx1Go18ckZZ2AwsfdnOj1ZLBZlxkOpVJJqQz3fgRkFpkdZbchUJl0LHY/g8+gW0Ap57733ulyXSqXSddBMvV7vOk6OQU5aCroJzKY9f3TWbDF4vV6ZmFMsFjE6Oorl5WW89dZb+Pa3vw0A2LdvH44dO4alpSVkMpm1XnLg0FaBHmLKx/TzeguhKpWKTIummNCq0JF8/j8XFAuTlpeX5XE9jv5a7cu6ypA1C5VKxeX753I55HI5aYriNdk6rgfW6LoKpiv5p1AoSCMX3Y5KpSITpk0UPjprEgaPx4NvfvOb+MIXvoBoNIpyuYxvfetbmJmZwdjYWNfZA6Ojo5iZmTFh+IhQFK73HGC1/FcXGenGIh29Z8yC/+WC56LlSDe+lhan3mvzDxczxYEj2nkf5XJZZjmwFJsxjWKxKK4M4yOEtRB0V7T7QNeBr2misDbWJAytVgsvvvgiTpw4gZ07d+K///u/8eSTT+Lpp59er/szPiR6TgIAKYoinKSkR67rSsd8Pg/HccQyqFQqXaLCa1wLLRZaGNiUFQgEZIAt06C0YmixMLXY6XSkupOxCAZfp6enEQgEJNvCtGQul7O4wjqxJmF4++23MT8/j507dwIAdu7cKebe3Nxc14DO+fl5jI+Pr8tNG++PbrPuHf7CXD8XTm+MQdcC6HTfjbYq6+foxalHr/XOgeT1eou2+PudzuqYN74HDrvV5222220p1zZRWDtrEoZNmzZhdnYWFy5cwD333IPz588jl8th27ZtmJiYwKlTp7B//36cOnUKExMT5kbcIrhYdLagd1ozR75rdwOA1B3QylhLm7IuwNILtzfNCawe9sL2695uUh0PYQpUuy7aZTLWzpqEYWRkBE899RSeeOIJ+Yf7+te/jlQqhaeeegqHDx/GiRMnkEwmMTk5uS43bNw4OkDZ24JNy4ELsnewCSsr14JubtLxjfcrU9bWTu/Pe//eK1g2gGV98Tgb8NN89913sWfPHly4cOG6ATfjxuCZEVykjNpfa0GxxoALe62LTu/2G/DrNpD4/X7cc889+NGPfoStW7e6H+/DPRl9oHf37g0o9tI7Hm6t1zZuL0wYBgRmCG5EFN7PpDcGB+/1n2LcCayXW2AMBmYxDAhmBRgfBrMYDMNwYcJgGIYLEwbDMFyYMBiG4cKEwTAMFyYMhmG4MGEwDMOFCYNhGC5MGAzDcGHCYBiGCxMGwzBcmDAYhuHChMEwDBcmDIZhuDBhMAzDhQmDYRguTBgMw3BhwmAYhgsTBsMwXJgwGIbhwoTBMAwXJgyGYbgwYTAMw4UJg2EYLkwYDMNwcV1hmJycxO7du/Hxj38cP/vZz+TnFy9exIEDB7B3714cOHAAly5duqHHDMO4DXCuw5kzZ5zp6Wnn05/+tHPu3Dn5+aFDh5yTJ086juM4J0+edA4dOnRDj90IU1NTzo4dOxy/3+8AsD/2x/6s8x+/3+/s2LHDmZqauuYavK7FsGvXLoyPj3f9LJfL4a233sK+ffsAAPv27cNbb72FpaWlD3zMMIzbg490qO3MzAzGxsbg8/kAAD6fD6Ojo5iZmYHjOO/7WCaTWb87NwzjpmHBR8MwXHwki2F8fBxzc3Not9vw+Xxot9uYn5/H+Pg4HMd538cMw7g9+EgWw/DwMCYmJnDq1CkAwKlTpzAxMYFMJvOBjxmGcZtwvQzBsWPHnF/91V91JiYmnF/+5V92fv3Xf91xHMf5+c9/7nz2s591HnroIeezn/2sc/78efmdD3rMshL2x/70/8/1shIex3EcbDDeffdd7NmzBxcuXECr1er37RjGHYff78c999yDH/3oR9i6davrcQs+GobhwoTBMAwXJgyGYbgwYTAMw4UJg2EYLkwYDMNwYcJgGIYLEwbDMFyYMBiG4cKEwTAMFyYMhmG4MGEwDMOFCYNhGC5MGAzDcGHCYBiGCxMGwzBcmDAYhuHChMEwDBcmDIZhuDBhMAzDhQmDYRguTBgMw3DxkU6iutm0220AV0dcG4ax/nBtca25Hr+VN3OjLCwsAADuvvvuPt+JYdzZLCwsYNu2ba6fb8gDZ2q1Gs6ePYuRkRE5NdswjPWj3W5jYWEB9913H8LhsOvxDSkMhmH0Fws+GobhwoTBMAwXJgyGYbgwYTAMw4UJg2EYLkwYDMNwYcJgGIaLDSkMFy9exIEDB7B3714cOHAAly5duuX3sLy8jD/4gz/A3r178ZnPfAZf/OIXsbS0BAB488038cgjj2Dv3r34/d//feRyuVt+f88//zw+/vGP42c/+9mGuKd6vY6jR4/ioYcewmc+8xn82Z/9GYD+/lu+9tpr+M3f/E3s378fjzzyCF555ZW+3NPk5CR2797d9e91vfvo+xpwNiCHDh1yTp486TiO45w8edI5dOjQLb+H5eVl5z//8z/l73/913/t/Omf/qnTbredBx980Dlz5ozjOI5z/Phx5/Dhw7f03s6ePes89thjzqc//Wnn3LlzG+Kejh075vzlX/6l0+l0HMdxnIWFBcdx+vdv2el0nF27djnnzp1zHMdx3n77bef+++932u32Lb+nM2fOONPT0/LvRT7oPvq9BjacMCwuLjo7d+50Wq2W4ziO02q1nJ07dzq5XK6v9/XDH/7Q+b3f+z3npz/9qfMbv/Eb8vNcLufcf//9t+w+6vW681u/9VvO1NSUfNH6fU+lUsnZuXOnUyqVun7ez3/LTqfj/NIv/ZLzxhtvOI7jOP/1X//lPPTQQ329Jy0MH3QfG2ENbLgmqpmZGYyNjUmPhM/nw+joKGZmZpDJZPpyT51OB9/73vewe/duzMzMYPPmzfJYJpNBp9NBPp9HKpW66ffy3HPP4ZFHHsHWrVvlZ/2+p6mpKaRSKTz//PN4/fXXEYvF8MQTTyAcDvft39Lj8eCb3/wmvvCFLyAajaJcLuNb3/rWhvl+fdB9OI7T93vckDGGjcaxY8cQjUbxuc99rq/38ZOf/ARnz57FwYMH+3ofvbTbbUxNTeETn/gE/vmf/xlf+tKX8Ed/9EeoVCp9u6dWq4UXX3wRJ06cwGuvvYa/+7u/w5NPPtnXe7qd2HAWw/j4OObm5tBut+Hz+dButzE/P4/x8fG+3M/k5CQuX76MF154AV6vF+Pj45ienpbHl5aW4PV6b8nOfObMGZw/fx579uwBAMzOzuKxxx7DoUOH+nZPwNV/M7/fj3379gEAPvnJTyKdTiMcDvft3/Ltt9/G/Pw8du7cCQDYuXMnIpEIQqHQhvh+fdD33HGcvt/jhrMYhoeHMTExgVOnTgEATp06hYmJib64Ed/4xjdw9uxZHD9+HMFgEABw3333oVar4Y033gAAvPTSS3j44Ydvyf08/vjj+Pd//3e8+uqrePXVV7Fp0yb8wz/8Az7/+c/37Z6Aq67LAw88gB//+McArkbUc7kctm/f3rd/y02bNmF2dhYXLlwAAJw/fx65XA7btm3bEN+vD/qeb4Q1sCHbrs+fP4/Dhw+jUCggmUxicnIS99xzzy29h3feeQf79u3D9u3bpV9969atOH78OP7nf/4HR48eRb1ex5YtW/DMM88gm83e0vsDgN27d+OFF17Ajh07+n5PU1NT+OpXv4p8Pg+/348nn3wSv/Zrv9bXf8t/+Zd/wd///d/D4/EAAP74j/8YDz744C2/p7/4i7/AK6+8gsXFRaTTaaRSKfzrv/7rB95Hv9fAhhQGwzD6y4ZzJQzD6D8mDIZhuDBhMAzDhQmDYRguTBgMw3BhwmAYhgsTBsMwXJgwGIbh4v8BkKcnEyXbfP8AAAAASUVORK5CYII=\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":1615133295936,"user_tz":-60,"elapsed":66569,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"46e053a9-76f1-4572-ce14-eaf603ce18c5"},"source":["angles_true = np.array(data['Angles'])\n","angles_true.shape"],"execution_count":null,"outputs":[{"output_type":"execute_result","data":{"text/plain":["(5000, 3)"]},"metadata":{"tags":[]},"execution_count":22}]},{"cell_type":"code","metadata":{"id":"WJvZ8_XPK4Kp"},"source":["#plot_images(angles_true, projections, range(100), img_size_scale=0.05)"],"execution_count":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"Z-CMl6nMK4Ks"},"source":["#ipv.screenshot()"],"execution_count":null,"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"},"source":["from sklearn.model_selection import train_test_split"],"execution_count":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"O_lxJ3huK4K0"},"source":["X, y = np.array(projections, dtype=np.float32), np.array(angles_true, dtype=np.float32)"],"execution_count":null,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"4f-dUZ4kK4K3"},"source":["#### Global standardization of projections"]},{"cell_type":"code","metadata":{"id":"X6A3wHMVK4K3"},"source":["from cryoem.preprocessing import global_standardization"],"execution_count":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"3pRAKWKmK4K6","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615133296788,"user_tz":-60,"elapsed":63148,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"76c8b171-f837-4cad-cbe2-c1af5e82aff9"},"source":["X = global_standardization(X)"],"execution_count":null,"outputs":[{"output_type":"stream","text":["Global standardization\n","\tImage shape: (116, 116)\n","\tData Type: float32\n","\tMean: 2.955 | Std: 7.814\n","\tMin:  0.000 | Max: 75.557\n","\tMean: 0.000 | Std: 1.000\n","\tMin:  -0.378 | Max: 9.291\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"lVRXjdE3K4K9"},"source":["test_size = 0.33\n","val_size = 0.25"],"execution_count":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"fRyiZcWPK4LC","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615133296791,"user_tz":-60,"elapsed":62211,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"cba1e9a2-6126-4d47-db7e-605ba01d22b0"},"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":null,"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"},"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":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"KNkQKrfJK4LH"},"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":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"WCOYGoQRK4LK","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615133297030,"user_tz":-60,"elapsed":61202,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"cd76e1c9-2087-4a4c-aa93-9f7fe909499b"},"source":["X.shape"],"execution_count":null,"outputs":[{"output_type":"execute_result","data":{"text/plain":["(5000, 116, 116, 1)"]},"metadata":{"tags":[]},"execution_count":33}]},{"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"},"source":["from time import time"],"execution_count":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"hqkn_ZVBK4LQ"},"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":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"Ui3KmgarK4LT"},"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","\n","    x = tf.squeeze(x, axis=[1,2])\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=f\"{path_logs_training}/model_plot_256d.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/{training_description}.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":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"qOYwbjOzK4LV","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615133299113,"user_tz":-60,"elapsed":54844,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"0fb176a8-0bf2-4f49-9bc4-b4f6822ce92f"},"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":null,"outputs":[{"output_type":"execute_result","data":{"text/plain":["(63101, 7022)"]},"metadata":{"tags":[]},"execution_count":37}]},{"cell_type":"code","metadata":{"scrolled":true,"id":"8HWI9cfqK4LY","colab":{"base_uri":"https://localhost:8080/"},"outputId":"ed26dad3-a7e9-4748-889b-ee2e70d8d5ab"},"source":["model, history1 = train_siamese(X=X, y=y, \n","                               train_idx=train_idx, \n","                               val_idx=val_idx,\n","                               epochs=150,  #500\n","                               batch_size=256,  #512 latest \n","                               learning_rate=1e-3,  #0.01 \n","                                limit_style=\"random\", \n","                                path_logs_training=path_logs_training, \n","                                training_description=training_description,\n","                               training_steps=int(train_percent*np.power(len(train_idx), 2)),  # None\n","                               validation_steps=int(val_percent*np.power(len(val_idx), 2)),  # None\n","                               plot=True,\n","                               gpus=None)"],"execution_count":null,"outputs":[{"output_type":"stream","text":["INFO:tensorflow:Using MirroredStrategy with devices ('/job:localhost/replica:0/task:0/device:GPU:0',)\n","Data created in 7.348897695541382 sec\n","Data created in 0.7839450836181641 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, 512)          4551936     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,551,936\n","Trainable params: 4,551,936\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/5a1a_quartercvg_uniformS2_noise0.h5\n","Epoch 1/150\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 [==============================] - 122s 340ms/step - loss: 0.7734 - mse: 1.0380 - val_loss: 0.3470 - val_mse: 0.2214\n","Epoch 2/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.2825 - mse: 0.1435 - val_loss: 0.2292 - val_mse: 0.1146\n","Epoch 3/150\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1876 - mse: 0.0649 - val_loss: 0.2120 - val_mse: 0.1019\n","Epoch 4/150\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1611 - mse: 0.0460 - val_loss: 0.1996 - val_mse: 0.0974\n","Epoch 5/150\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1488 - mse: 0.0387 - val_loss: 0.1897 - val_mse: 0.0872\n","Epoch 6/150\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1418 - mse: 0.0349 - val_loss: 0.1924 - val_mse: 0.0938\n","Epoch 7/150\n","247/247 [==============================] - 82s 332ms/step - loss: 0.1381 - mse: 0.0335 - val_loss: 0.1828 - val_mse: 0.0867\n","Epoch 8/150\n","247/247 [==============================] - 81s 328ms/step - loss: 0.1355 - mse: 0.0328 - val_loss: 0.1855 - val_mse: 0.0910\n","Epoch 9/150\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1327 - mse: 0.0313 - val_loss: 0.1840 - val_mse: 0.0907\n","Epoch 10/150\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1308 - mse: 0.0307 - val_loss: 0.1763 - val_mse: 0.0810\n","Epoch 11/150\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1294 - mse: 0.0302 - val_loss: 0.1819 - val_mse: 0.0874\n","Epoch 12/150\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1278 - mse: 0.0294 - val_loss: 0.1734 - val_mse: 0.0784\n","Epoch 13/150\n","247/247 [==============================] - 82s 332ms/step - loss: 0.1271 - mse: 0.0293 - val_loss: 0.1748 - val_mse: 0.0790\n","Epoch 14/150\n","247/247 [==============================] - 82s 332ms/step - loss: 0.1268 - mse: 0.0294 - val_loss: 0.1777 - val_mse: 0.0838\n","Epoch 15/150\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1260 - mse: 0.0291 - val_loss: 0.1813 - val_mse: 0.0887\n","Epoch 16/150\n","247/247 [==============================] - 81s 328ms/step - loss: 0.1259 - mse: 0.0291 - val_loss: 0.1762 - val_mse: 0.0833\n","Epoch 17/150\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1244 - mse: 0.0292 - val_loss: 0.1749 - val_mse: 0.0833\n","Epoch 18/150\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1238 - mse: 0.0286 - val_loss: 0.1727 - val_mse: 0.0843\n","Epoch 19/150\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1232 - mse: 0.0284 - val_loss: 0.1747 - val_mse: 0.0819\n","Epoch 20/150\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1230 - mse: 0.0284 - val_loss: 0.1696 - val_mse: 0.0767\n","Epoch 21/150\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1232 - mse: 0.0285 - val_loss: 0.1703 - val_mse: 0.0763\n","Epoch 22/150\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1230 - mse: 0.0285 - val_loss: 0.1733 - val_mse: 0.0834\n","Epoch 23/150\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1225 - mse: 0.0282 - val_loss: 0.1759 - val_mse: 0.0846\n","Epoch 24/150\n","247/247 [==============================] - 81s 327ms/step - loss: 0.1225 - mse: 0.0282 - val_loss: 0.1776 - val_mse: 0.0844\n","Epoch 25/150\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1214 - mse: 0.0281 - val_loss: 0.1751 - val_mse: 0.0850\n","Epoch 26/150\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1209 - mse: 0.0279 - val_loss: 0.1734 - val_mse: 0.0820\n","Epoch 27/150\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1211 - mse: 0.0278 - val_loss: 0.1726 - val_mse: 0.0825\n","Epoch 28/150\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1213 - mse: 0.0281 - val_loss: 0.1737 - val_mse: 0.0794\n","Epoch 29/150\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1199 - mse: 0.0276 - val_loss: 0.1766 - val_mse: 0.0854\n","Epoch 30/150\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1197 - mse: 0.0275 - val_loss: 0.1751 - val_mse: 0.0870\n","Epoch 31/150\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1191 - mse: 0.0274 - val_loss: 0.1766 - val_mse: 0.0858\n","Epoch 32/150\n","247/247 [==============================] - 81s 327ms/step - loss: 0.1202 - mse: 0.0279 - val_loss: 0.1752 - val_mse: 0.0843\n","Epoch 33/150\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1192 - mse: 0.0273 - val_loss: 0.1733 - val_mse: 0.0848\n","Epoch 34/150\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1190 - mse: 0.0275 - val_loss: 0.1742 - val_mse: 0.0836\n","Epoch 35/150\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1196 - mse: 0.0277 - val_loss: 0.1754 - val_mse: 0.0858\n","Epoch 36/150\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1197 - mse: 0.0278 - val_loss: 0.1780 - val_mse: 0.0891\n","Epoch 37/150\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1181 - mse: 0.0274 - val_loss: 0.1756 - val_mse: 0.0864\n","Epoch 38/150\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1181 - mse: 0.0273 - val_loss: 0.1731 - val_mse: 0.0837\n","Epoch 39/150\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1176 - mse: 0.0271 - val_loss: 0.1742 - val_mse: 0.0856\n","Epoch 40/150\n","247/247 [==============================] - 81s 326ms/step - loss: 0.1179 - mse: 0.0272 - val_loss: 0.1759 - val_mse: 0.0860\n","Epoch 41/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1182 - mse: 0.0276 - val_loss: 0.1729 - val_mse: 0.0814\n","Epoch 42/150\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1171 - mse: 0.0271 - val_loss: 0.1743 - val_mse: 0.0834\n","Epoch 43/150\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1178 - mse: 0.0273 - val_loss: 0.1729 - val_mse: 0.0838\n","Epoch 44/150\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1177 - mse: 0.0272 - val_loss: 0.1730 - val_mse: 0.0821\n","Epoch 45/150\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1174 - mse: 0.0268 - val_loss: 0.1723 - val_mse: 0.0806\n","Epoch 46/150\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1174 - mse: 0.0271 - val_loss: 0.1714 - val_mse: 0.0813\n","Epoch 47/150\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1172 - mse: 0.0270 - val_loss: 0.1745 - val_mse: 0.0831\n","Epoch 48/150\n","247/247 [==============================] - 81s 327ms/step - loss: 0.1177 - mse: 0.0270 - val_loss: 0.1729 - val_mse: 0.0824\n","Epoch 49/150\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1165 - mse: 0.0268 - val_loss: 0.1739 - val_mse: 0.0833\n","Epoch 50/150\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1164 - mse: 0.0270 - val_loss: 0.1744 - val_mse: 0.0838\n","Epoch 51/150\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1163 - mse: 0.0270 - val_loss: 0.1718 - val_mse: 0.0809\n","Epoch 52/150\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1171 - mse: 0.0268 - val_loss: 0.1748 - val_mse: 0.0849\n","Epoch 53/150\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1175 - mse: 0.0273 - val_loss: 0.1768 - val_mse: 0.0862\n","Epoch 54/150\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1155 - mse: 0.0264 - val_loss: 0.1764 - val_mse: 0.0871\n","Epoch 55/150\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1162 - mse: 0.0270 - val_loss: 0.1734 - val_mse: 0.0829\n","Epoch 56/150\n","247/247 [==============================] - 81s 327ms/step - loss: 0.1154 - mse: 0.0265 - val_loss: 0.1733 - val_mse: 0.0832\n","Epoch 57/150\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1165 - mse: 0.0270 - val_loss: 0.1729 - val_mse: 0.0817\n","Epoch 58/150\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1166 - mse: 0.0269 - val_loss: 0.1727 - val_mse: 0.0834\n","Epoch 59/150\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1156 - mse: 0.0266 - val_loss: 0.1715 - val_mse: 0.0813\n","Epoch 60/150\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1159 - mse: 0.0268 - val_loss: 0.1728 - val_mse: 0.0820\n","Epoch 61/150\n","247/247 [==============================] - 82s 332ms/step - loss: 0.1156 - mse: 0.0267 - val_loss: 0.1756 - val_mse: 0.0862\n","Epoch 62/150\n","247/247 [==============================] - 82s 332ms/step - loss: 0.1159 - mse: 0.0269 - val_loss: 0.1741 - val_mse: 0.0841\n","Epoch 63/150\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1155 - mse: 0.0266 - val_loss: 0.1771 - val_mse: 0.0886\n","Epoch 64/150\n","247/247 [==============================] - 81s 326ms/step - loss: 0.1156 - mse: 0.0269 - val_loss: 0.1745 - val_mse: 0.0827\n","Epoch 65/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1149 - mse: 0.0264 - val_loss: 0.1749 - val_mse: 0.0840\n","Epoch 66/150\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1145 - mse: 0.0262 - val_loss: 0.1742 - val_mse: 0.0833\n","Epoch 67/150\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1153 - mse: 0.0264 - val_loss: 0.1730 - val_mse: 0.0828\n","Epoch 68/150\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1152 - mse: 0.0267 - val_loss: 0.1741 - val_mse: 0.0832\n","Epoch 69/150\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1142 - mse: 0.0263 - val_loss: 0.1765 - val_mse: 0.0874\n","Epoch 70/150\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1148 - mse: 0.0263 - val_loss: 0.1776 - val_mse: 0.0892\n","Epoch 71/150\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1147 - mse: 0.0264 - val_loss: 0.1756 - val_mse: 0.0845\n","Epoch 72/150\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1144 - mse: 0.0264 - val_loss: 0.1754 - val_mse: 0.0841\n","Epoch 73/150\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1145 - mse: 0.0264 - val_loss: 0.1770 - val_mse: 0.0876\n","Epoch 74/150\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1144 - mse: 0.0264 - val_loss: 0.1738 - val_mse: 0.0821\n","Epoch 75/150\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1150 - mse: 0.0265 - val_loss: 0.1755 - val_mse: 0.0878\n","Epoch 76/150\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1151 - mse: 0.0265 - val_loss: 0.1754 - val_mse: 0.0861\n","Epoch 77/150\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1138 - mse: 0.0262 - val_loss: 0.1742 - val_mse: 0.0849\n","Epoch 78/150\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1145 - mse: 0.0265 - val_loss: 0.1767 - val_mse: 0.0866\n","Epoch 79/150\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1145 - mse: 0.0264 - val_loss: 0.1759 - val_mse: 0.0871\n","Epoch 80/150\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1144 - mse: 0.0265 - val_loss: 0.1757 - val_mse: 0.0850\n","Epoch 81/150\n","247/247 [==============================] - 81s 329ms/step - loss: 0.1145 - mse: 0.0266 - val_loss: 0.1764 - val_mse: 0.0876\n","Epoch 82/150\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1143 - mse: 0.0264 - val_loss: 0.1773 - val_mse: 0.0887\n","Epoch 83/150\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1140 - mse: 0.0263 - val_loss: 0.1748 - val_mse: 0.0850\n","Epoch 84/150\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1143 - mse: 0.0266 - val_loss: 0.1780 - val_mse: 0.0898\n","Epoch 85/150\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1137 - mse: 0.0262 - val_loss: 0.1767 - val_mse: 0.0861\n","Epoch 86/150\n","247/247 [==============================] - 81s 330ms/step - loss: 0.1139 - mse: 0.0262 - val_loss: 0.1748 - val_mse: 0.0850\n","Epoch 87/150\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1140 - mse: 0.0264 - val_loss: 0.1765 - val_mse: 0.0867\n","Epoch 88/150\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1144 - mse: 0.0265 - val_loss: 0.1787 - val_mse: 0.0900\n","Epoch 89/150\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1139 - mse: 0.0263 - val_loss: 0.1761 - val_mse: 0.0870\n","Epoch 90/150\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1143 - mse: 0.0266 - val_loss: 0.1791 - val_mse: 0.0915\n","Epoch 91/150\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1138 - mse: 0.0265 - val_loss: 0.1739 - val_mse: 0.0852\n","Epoch 92/150\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1132 - mse: 0.0262 - val_loss: 0.1783 - val_mse: 0.0910\n","Epoch 93/150\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1133 - mse: 0.0261 - val_loss: 0.1759 - val_mse: 0.0851\n","Epoch 94/150\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1138 - mse: 0.0264 - val_loss: 0.1740 - val_mse: 0.0839\n","Epoch 95/150\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1127 - mse: 0.0260 - val_loss: 0.1741 - val_mse: 0.0834\n","Epoch 96/150\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1135 - mse: 0.0263 - val_loss: 0.1758 - val_mse: 0.0870\n","Epoch 97/150\n","247/247 [==============================] - 82s 330ms/step - loss: 0.1133 - mse: 0.0264 - val_loss: 0.1758 - val_mse: 0.0849\n","Epoch 98/150\n","247/247 [==============================] - 82s 331ms/step - loss: 0.1135 - mse: 0.0264 - val_loss: 0.1725 - val_mse: 0.0818\n","Epoch 99/150\n","247/247 [==============================] - 83s 336ms/step - loss: 0.1134 - mse: 0.0263 - val_loss: 0.1751 - val_mse: 0.0851\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"sZ4ydSfdMbLa","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615133299693,"user_tz":-60,"elapsed":566,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"0810649e-ed4b-41eb-8161-25d30afc3e7c"},"source":["from tensorflow.python.client import device_lib\n","device_lib.list_local_devices()"],"execution_count":null,"outputs":[{"output_type":"execute_result","data":{"text/plain":["[name: \"/device:CPU:0\"\n"," device_type: \"CPU\"\n"," memory_limit: 268435456\n"," locality {\n"," }\n"," incarnation: 6299730584023050894, name: \"/device:GPU:0\"\n"," device_type: \"GPU\"\n"," memory_limit: 14674281152\n"," locality {\n","   bus_id: 1\n","   links {\n","   }\n"," }\n"," incarnation: 3940036478313418680\n"," physical_device_desc: \"device: 0, name: Tesla T4, pci bus id: 0000:00:04.0, compute capability: 7.5\"]"]},"metadata":{"tags":[]},"execution_count":38}]},{"cell_type":"markdown","metadata":{"id":"fJJKUgcJK4La"},"source":["---"]},{"cell_type":"code","metadata":{"id":"gi9CsCZAK4Ld"},"source":["# data = np.load(f\"{path_logs_training}/losses/{training_description}.npz\")\n","# training_loss, val_loss, mses, val_mses = data[\"arr_0\"], data[\"arr_1\"], data[\"arr_2\"], data[\"arr_3\"]"],"execution_count":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"IIKP9TtBK4Lg"},"source":["# # Get training and test loss histories\n","# fig, (ax1, ax2) = plt.subplots(1, 2, figsize=(15,7))\n","\n","# # Create count of the number of epochs\n","# epoch_count = range(1, len(training_loss) + 1)\n","\n","# # Visualize loss history\n","# ax1.plot(epoch_count, training_loss, 'r--', label='MAE Training Loss')\n","# ax1.plot(epoch_count, val_loss, 'b-', label='MAE Validation Loss')\n","# ax1.legend()\n","# ax1.set_xlabel('Epoch')\n","# ax1.set_ylabel('Loss')\n","\n","# ax2.plot(epoch_count, mses, 'r-', label='MSE Training')\n","# ax2.plot(epoch_count, val_mses, 'b-', label='MSE Validation')\n","# ax2.legend()\n","# ax2.set_xlabel('Epoch')\n","# ax2.set_ylabel('Loss')\n","# plt.show();"],"execution_count":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"4_py9DG4K4Lj"},"source":["# training_loss[-1], val_loss[-1], mses[-1], val_mses[-1]"],"execution_count":null,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"M-kSlYfqK4Lt"},"source":["### (Or) Read model checkpoint"]},{"cell_type":"code","metadata":{"id":"9z7haF6NK4Lu"},"source":["# put correct filename\n","model_filename = f\"{path_logs_training}/training/{training_description}.h5\""],"execution_count":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"Dr9eFsJKK4Lw","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615133301474,"user_tz":-60,"elapsed":2325,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"1e2b2ab6-e711-4aab-ac61-55f487e46583"},"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":null,"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, 512)          4551936     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,551,936\n","Trainable params: 4,551,936\n","Non-trainable params: 0\n","__________________________________________________________________________________________________\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"z8jtcgWOZu2j"},"source":["# plot_model(model, to_file=f\"{path_logs_training}/model_plot_256d.png\", expand_nested=True, show_shapes=True, show_layer_names=True)\n"],"execution_count":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"6-eOzKnG-Hdo"},"source":["model.save_weights(f\"{path_logs_training}/training/{training_description}_weights.h5\")"],"execution_count":null,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"KpIqU8r6K4L2"},"source":["---"]},{"cell_type":"markdown","metadata":{"id":"_KlxFl_eK4L2"},"source":["## dP/dQ plot"]},{"cell_type":"code","metadata":{"id":"Z766GBdvK4L3"},"source":["from cryoem.conversions import d_q, euler2quaternion\n","from cryoem.plots import plot_dP_dQ"],"execution_count":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"RJMjW2KHK4L5"},"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":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"0YTh5UvmK4L7"},"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":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"OqwZcuEFBMJp"},"source":["np.savez(os.path.join(path_logs_training, f\"dPdQ_data_{training_description}\"), dP_values, dQ_values)"],"execution_count":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"NjmjpoN0K4L9","colab":{"base_uri":"https://localhost:8080/","height":882},"executionInfo":{"status":"ok","timestamp":1615133369492,"user_tz":-60,"elapsed":70329,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"9f2d18bb-11d1-4497-c53b-fd7e9333c491"},"source":["plot_dP_dQ(dP_values, dQ_values)"],"execution_count":null,"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.3131353700352579\n","Min. angle recovery loss possible = 0.09795570620715074\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"lA75WQYrK4L_","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615133369495,"user_tz":-60,"elapsed":70330,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"e3507e3a-76e0-4f33-f018-5dd7f19f2511"},"source":["MAE(dQ_values, dP_values)"],"execution_count":null,"outputs":[{"output_type":"execute_result","data":{"text/plain":["<tf.Tensor: shape=(), dtype=float32, numpy=0.17817941>"]},"metadata":{"tags":[]},"execution_count":51}]},{"cell_type":"code","metadata":{"id":"rGC2BjfxVYqF"},"source":["model.save_weights(f\"{path_logs_training}/training/{training_description}_weights.h5\")"],"execution_count":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"zkQn2kkjZb6U"},"source":[""],"execution_count":null,"outputs":[]}]}