{"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_noise16_DE_LAST","provenance":[{"file_id":"1L9WxU3C7orsJaDaAuDfpK8gJkSQDPlzx","timestamp":1615798816185},{"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","executionInfo":{"status":"ok","timestamp":1615798885287,"user_tz":-60,"elapsed":1015,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["# create directories\n","!mkdir --parents data/5j0n\n","!mkdir training"],"execution_count":1,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"A-xIo-OjK4J_"},"source":["## Setup Environment (Colab)"]},{"cell_type":"markdown","metadata":{"id":"kOyAAhtiK4J_"},"source":["Link to MiniConda Linux installer [here](https://docs.conda.io/en/latest/miniconda.html)."]},{"cell_type":"code","metadata":{"id":"6mMUWEYfK4KA","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615798918712,"user_tz":-60,"elapsed":34425,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"54a716ef-f9e4-4445-b057-ca2f0f2f3fb0"},"source":["!wget -c https://repo.anaconda.com/miniconda/Miniconda3-latest-Linux-x86_64.sh\n","!chmod +x Miniconda3-latest-Linux-x86_64.sh\n","!bash ./Miniconda3-latest-Linux-x86_64.sh -b -f -p /usr/local"],"execution_count":2,"outputs":[{"output_type":"stream","text":["--2021-03-15 09:01:25--  https://repo.anaconda.com/miniconda/Miniconda3-latest-Linux-x86_64.sh\n","Resolving repo.anaconda.com (repo.anaconda.com)... 104.16.131.3, 104.16.130.3, 2606:4700::6810:8203, ...\n","Connecting to repo.anaconda.com (repo.anaconda.com)|104.16.131.3|:443... connected.\n","HTTP request sent, awaiting response... 200 OK\n","Length: 94235922 (90M) [application/x-sh]\n","Saving to: ‘Miniconda3-latest-Linux-x86_64.sh’\n","\n","Miniconda3-latest-L 100%[===================>]  89.87M   134MB/s    in 0.7s    \n","\n","2021-03-15 09:01:26 (134 MB/s) - ‘Miniconda3-latest-Linux-x86_64.sh’ saved [94235922/94235922]\n","\n","PREFIX=/usr/local\n","Unpacking payload ...\n","Collecting package metadata (current_repodata.json): - \b\b\\ \b\b| \b\b/ \b\bdone\n","Solving environment: \\ \b\b| \b\bdone\n","\n","## Package Plan ##\n","\n","  environment location: /usr/local\n","\n","  added / updated specs:\n","    - _libgcc_mutex==0.1=main\n","    - brotlipy==0.7.0=py38h27cfd23_1003\n","    - ca-certificates==2020.10.14=0\n","    - certifi==2020.6.20=pyhd3eb1b0_3\n","    - cffi==1.14.3=py38h261ae71_2\n","    - chardet==3.0.4=py38h06a4308_1003\n","    - conda-package-handling==1.7.2=py38h03888b9_0\n","    - conda==4.9.2=py38h06a4308_0\n","    - cryptography==3.2.1=py38h3c74f83_1\n","    - idna==2.10=py_0\n","    - ld_impl_linux-64==2.33.1=h53a641e_7\n","    - libedit==3.1.20191231=h14c3975_1\n","    - libffi==3.3=he6710b0_2\n","    - libgcc-ng==9.1.0=hdf63c60_0\n","    - libstdcxx-ng==9.1.0=hdf63c60_0\n","    - ncurses==6.2=he6710b0_1\n","    - openssl==1.1.1h=h7b6447c_0\n","    - pip==20.2.4=py38h06a4308_0\n","    - pycosat==0.6.3=py38h7b6447c_1\n","    - pycparser==2.20=py_2\n","    - pyopenssl==19.1.0=pyhd3eb1b0_1\n","    - pysocks==1.7.1=py38h06a4308_0\n","    - python==3.8.5=h7579374_1\n","    - readline==8.0=h7b6447c_0\n","    - requests==2.24.0=py_0\n","    - ruamel_yaml==0.15.87=py38h7b6447c_1\n","    - setuptools==50.3.1=py38h06a4308_1\n","    - six==1.15.0=py38h06a4308_0\n","    - sqlite==3.33.0=h62c20be_0\n","    - tk==8.6.10=hbc83047_0\n","    - tqdm==4.51.0=pyhd3eb1b0_0\n","    - urllib3==1.25.11=py_0\n","    - wheel==0.35.1=pyhd3eb1b0_0\n","    - xz==5.2.5=h7b6447c_0\n","    - yaml==0.2.5=h7b6447c_0\n","    - zlib==1.2.11=h7b6447c_3\n","\n","\n","The following NEW packages will be INSTALLED:\n","\n","  _libgcc_mutex      pkgs/main/linux-64::_libgcc_mutex-0.1-main\n","  brotlipy           pkgs/main/linux-64::brotlipy-0.7.0-py38h27cfd23_1003\n","  ca-certificates    pkgs/main/linux-64::ca-certificates-2020.10.14-0\n","  certifi            pkgs/main/noarch::certifi-2020.6.20-pyhd3eb1b0_3\n","  cffi               pkgs/main/linux-64::cffi-1.14.3-py38h261ae71_2\n","  chardet            pkgs/main/linux-64::chardet-3.0.4-py38h06a4308_1003\n","  conda              pkgs/main/linux-64::conda-4.9.2-py38h06a4308_0\n","  conda-package-han~ pkgs/main/linux-64::conda-package-handling-1.7.2-py38h03888b9_0\n","  cryptography       pkgs/main/linux-64::cryptography-3.2.1-py38h3c74f83_1\n","  idna               pkgs/main/noarch::idna-2.10-py_0\n","  ld_impl_linux-64   pkgs/main/linux-64::ld_impl_linux-64-2.33.1-h53a641e_7\n","  libedit            pkgs/main/linux-64::libedit-3.1.20191231-h14c3975_1\n","  libffi             pkgs/main/linux-64::libffi-3.3-he6710b0_2\n","  libgcc-ng          pkgs/main/linux-64::libgcc-ng-9.1.0-hdf63c60_0\n","  libstdcxx-ng       pkgs/main/linux-64::libstdcxx-ng-9.1.0-hdf63c60_0\n","  ncurses            pkgs/main/linux-64::ncurses-6.2-he6710b0_1\n","  openssl            pkgs/main/linux-64::openssl-1.1.1h-h7b6447c_0\n","  pip                pkgs/main/linux-64::pip-20.2.4-py38h06a4308_0\n","  pycosat            pkgs/main/linux-64::pycosat-0.6.3-py38h7b6447c_1\n","  pycparser          pkgs/main/noarch::pycparser-2.20-py_2\n","  pyopenssl          pkgs/main/noarch::pyopenssl-19.1.0-pyhd3eb1b0_1\n","  pysocks            pkgs/main/linux-64::pysocks-1.7.1-py38h06a4308_0\n","  python             pkgs/main/linux-64::python-3.8.5-h7579374_1\n","  readline           pkgs/main/linux-64::readline-8.0-h7b6447c_0\n","  requests           pkgs/main/noarch::requests-2.24.0-py_0\n","  ruamel_yaml        pkgs/main/linux-64::ruamel_yaml-0.15.87-py38h7b6447c_1\n","  setuptools         pkgs/main/linux-64::setuptools-50.3.1-py38h06a4308_1\n","  six                pkgs/main/linux-64::six-1.15.0-py38h06a4308_0\n","  sqlite             pkgs/main/linux-64::sqlite-3.33.0-h62c20be_0\n","  tk                 pkgs/main/linux-64::tk-8.6.10-hbc83047_0\n","  tqdm               pkgs/main/noarch::tqdm-4.51.0-pyhd3eb1b0_0\n","  urllib3            pkgs/main/noarch::urllib3-1.25.11-py_0\n","  wheel              pkgs/main/noarch::wheel-0.35.1-pyhd3eb1b0_0\n","  xz                 pkgs/main/linux-64::xz-5.2.5-h7b6447c_0\n","  yaml               pkgs/main/linux-64::yaml-0.2.5-h7b6447c_0\n","  zlib               pkgs/main/linux-64::zlib-1.2.11-h7b6447c_3\n","\n","\n","Preparing transaction: - \b\b\\ \b\b| \b\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\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":1615798951054,"user_tz":-60,"elapsed":66759,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"7e0212ee-61e1-4aaf-c456-20d5880bdaba"},"source":["# save the model on the drive\n","from google.colab import drive\n","drive.mount(\"/content/drive\")\n","#!cd 'drive/My Drive'\n","!mkdir --parents 'drive/My Drive/ModelsProtein'"],"execution_count":3,"outputs":[{"output_type":"stream","text":["Mounted at /content/drive\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"6ghrKBx2K4KE","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615798992520,"user_tz":-60,"elapsed":108217,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"e616d3bf-cdad-413a-debd-d38ca3c76a18"},"source":["# clone repo\n","!rm -r protein-reconstruction\n","!git clone https://github.com/anonymous/protein-reconstruction.git\n","!cd protein-reconstruction"],"execution_count":4,"outputs":[{"output_type":"stream","text":["rm: cannot remove 'protein-reconstruction': No such file or directory\n","Cloning into 'protein-reconstruction'...\n","remote: Enumerating objects: 17, done.\u001b[K\n","remote: Counting objects: 100% (17/17), done.\u001b[K\n","remote: Compressing objects: 100% (14/14), done.\u001b[K\n","remote: Total 2972 (delta 3), reused 9 (delta 3), pack-reused 2955\u001b[K\n","Receiving objects: 100% (2972/2972), 746.34 MiB | 26.20 MiB/s, done.\n","Resolving deltas: 100% (1786/1786), done.\n","Checking out files: 100% (161/161), done.\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"LGvnGT0xK4KL","colab":{"base_uri":"https://localhost:8080/","height":1000},"executionInfo":{"status":"ok","timestamp":1615799109863,"user_tz":-60,"elapsed":225552,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"cc42d90e-c178-4491-edb9-eed1f0754ff4"},"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":5,"outputs":[{"output_type":"stream","text":["Collecting package metadata (current_repodata.json): ...working... done\n","Solving environment: ...working... done\n","\n","## Package Plan ##\n","\n","  environment location: /usr/local\n","\n","  added / updated specs:\n","    - ipyvolume\n","\n","\n","The following packages will be downloaded:\n","\n","    package                    |            build\n","    ---------------------------|-----------------\n","    argon2-cffi-20.1.0         |   py38h25fe258_2          47 KB  conda-forge\n","    async_generator-1.10       |             py_0          18 KB  conda-forge\n","    attrs-20.3.0               |     pyhd3deb0d_0          41 KB  conda-forge\n","    backcall-0.2.0             |     pyh9f0ad1d_0          13 KB  conda-forge\n","    backports-1.0              |             py_2           4 KB  conda-forge\n","    backports.functools_lru_cache-1.6.1|             py_0           8 KB  conda-forge\n","    bleach-3.3.0               |     pyh44b312d_0         111 KB  conda-forge\n","    bqplot-0.12.23             |     pyhd8ed1ab_0        1013 KB  conda-forge\n","    ca-certificates-2020.12.5  |       ha878542_0         137 KB  conda-forge\n","    certifi-2020.12.5          |   py38h578d9bd_1         143 KB  conda-forge\n","    cloudpickle-1.6.0          |             py_0          22 KB  conda-forge\n","    conda-4.9.2                |   py38h578d9bd_0         3.0 MB  conda-forge\n","    cycler-0.10.0              |             py_2           9 KB  conda-forge\n","    cytoolz-0.11.0             |   py38h25fe258_1         396 KB  conda-forge\n","    dask-core-2021.3.0         |     pyhd8ed1ab_0         702 KB  conda-forge\n","    decorator-4.4.2            |             py_0          11 KB  conda-forge\n","    defusedxml-0.7.1           |     pyhd8ed1ab_0          23 KB  conda-forge\n","    entrypoints-0.3            |  pyhd8ed1ab_1003           8 KB  conda-forge\n","    freetype-2.10.4            |       h7ca028e_0         912 KB  conda-forge\n","    icu-67.1                   |       he1b5a44_0        12.9 MB  conda-forge\n","    imageio-2.9.0              |             py_0         3.1 MB  conda-forge\n","    importlib-metadata-3.7.3   |   py38h578d9bd_0          24 KB  conda-forge\n","    ipydatawidgets-4.2.0       |     pyhd3deb0d_0         171 KB  conda-forge\n","    ipykernel-5.5.0            |   py38h81c977d_1         167 KB  conda-forge\n","    ipython-7.21.0             |   py38h81c977d_0         1.1 MB  conda-forge\n","    ipython_genutils-0.2.0     |             py_1          21 KB  conda-forge\n","    ipyvolume-0.6.0a6          |     pyh9f0ad1d_0         5.1 MB  conda-forge\n","    ipywebrtc-0.5.0            |   py38h32f6830_1         878 KB  conda-forge\n","    ipywidgets-7.6.3           |     pyhd3deb0d_0         101 KB  conda-forge\n","    jedi-0.18.0                |   py38h578d9bd_2         937 KB  conda-forge\n","    jinja2-2.11.3              |     pyh44b312d_0          93 KB  conda-forge\n","    jpeg-9d                    |       h36c2ea0_0         264 KB  conda-forge\n","    jsonschema-3.2.0           |     pyhd8ed1ab_3          45 KB  conda-forge\n","    jupyter_client-6.1.12      |     pyhd8ed1ab_0          79 KB  conda-forge\n","    jupyter_core-4.7.1         |   py38h578d9bd_0          72 KB  conda-forge\n","    jupyterlab_pygments-0.1.2  |     pyh9f0ad1d_0           8 KB  conda-forge\n","    jupyterlab_widgets-1.0.0   |     pyhd8ed1ab_1         130 KB  conda-forge\n","    kiwisolver-1.3.1           |   py38h82cb98a_0          86 KB  conda-forge\n","    libblas-3.9.0              |       8_openblas          11 KB  conda-forge\n","    libcblas-3.9.0             |       8_openblas          11 KB  conda-forge\n","    libgfortran-ng-7.5.0       |      h14aa051_18          22 KB  conda-forge\n","    libgfortran4-7.5.0         |      h14aa051_18         1.3 MB  conda-forge\n","    liblapack-3.9.0            |       8_openblas          11 KB  conda-forge\n","    libopenblas-0.3.12         |pthreads_hb3c22a3_1         8.2 MB  conda-forge\n","    libpng-1.6.37              |       h21135ba_2         306 KB  conda-forge\n","    libsodium-1.0.18           |       h36c2ea0_1         366 KB  conda-forge\n","    libtiff-4.0.10             |    hc3755c2_1005         602 KB  conda-forge\n","    lz4-c-1.9.2                |       he1b5a44_3         203 KB  conda-forge\n","    markupsafe-1.1.1           |   py38h8df0ef7_2          27 KB  conda-forge\n","    matplotlib-base-3.2.2      |   py38h5d868c9_1         7.1 MB  conda-forge\n","    mistune-0.8.4              |py38h25fe258_1002          54 KB  conda-forge\n","    nbclient-0.5.3             |     pyhd8ed1ab_0          67 KB  conda-forge\n","    nbconvert-6.0.7            |   py38h578d9bd_3         546 KB  conda-forge\n","    nbformat-5.1.2             |     pyhd8ed1ab_1          66 KB  conda-forge\n","    nest-asyncio-1.4.3         |     pyhd8ed1ab_0           9 KB  conda-forge\n","    networkx-2.5               |             py_0         1.2 MB  conda-forge\n","    notebook-6.2.0             |   py38h578d9bd_0         6.3 MB  conda-forge\n","    numpy-1.18.1               |   py38h8854b6b_1         5.3 MB  conda-forge\n","    olefile-0.46               |     pyh9f0ad1d_1          32 KB  conda-forge\n","    openssl-1.1.1j             |       h27cfd23_0         2.5 MB\n","    packaging-20.9             |     pyh44b312d_0          35 KB  conda-forge\n","    pandas-1.0.1               |   py38hb3f55d8_0        11.4 MB  conda-forge\n","    pandoc-2.12                |       h7f98852_0        12.4 MB  conda-forge\n","    pandocfilters-1.4.2        |             py_1           9 KB  conda-forge\n","    parso-0.8.1                |     pyhd8ed1ab_0          67 KB  conda-forge\n","    pexpect-4.8.0              |     pyh9f0ad1d_2          47 KB  conda-forge\n","    pickleshare-0.7.5          |          py_1003           9 KB  conda-forge\n","    pillow-6.2.1               |   py38h6b7be26_0         637 KB  conda-forge\n","    prometheus_client-0.9.0    |     pyhd3deb0d_0          44 KB  conda-forge\n","    prompt-toolkit-3.0.17      |     pyha770c72_0         244 KB  conda-forge\n","    ptyprocess-0.7.0           |     pyhd3deb0d_0          16 KB  conda-forge\n","    pygments-2.8.1             |     pyhd8ed1ab_0         736 KB  conda-forge\n","    pyparsing-2.4.7            |     pyh9f0ad1d_0          60 KB  conda-forge\n","    pyrsistent-0.17.3          |   py38h25fe258_1          89 KB  conda-forge\n","    python-dateutil-2.8.1      |             py_0         220 KB  conda-forge\n","    python_abi-3.8             |           1_cp38           4 KB  conda-forge\n","    pythreejs-2.3.0            |     pyhd8ed1ab_0         2.6 MB  conda-forge\n","    pytz-2021.1                |     pyhd8ed1ab_0         239 KB  conda-forge\n","    pywavelets-1.1.1           |   py38hab2c0dc_3         4.3 MB  conda-forge\n","    pyyaml-5.3.1               |   py38h8df0ef7_1         190 KB  conda-forge\n","    pyzmq-19.0.2               |   py38ha71036d_2         511 KB  conda-forge\n","    scikit-image-0.16.2        |   py38hb3f55d8_0        25.1 MB  conda-forge\n","    scipy-1.5.3                |   py38h828c644_0        18.7 MB  conda-forge\n","    send2trash-1.5.0           |             py_0          12 KB  conda-forge\n","    terminado-0.9.2            |   py38h578d9bd_0          26 KB  conda-forge\n","    testpath-0.4.4             |             py_0          85 KB  conda-forge\n","    toolz-0.11.1               |             py_0          46 KB  conda-forge\n","    tornado-6.1                |   py38h25fe258_0         646 KB  conda-forge\n","    traitlets-5.0.5            |             py_0          81 KB  conda-forge\n","    traittypes-0.2.1           |     pyh9f0ad1d_2          10 KB  conda-forge\n","    wcwidth-0.2.5              |     pyh9f0ad1d_2          33 KB  conda-forge\n","    webencodings-0.5.1         |             py_1          12 KB  conda-forge\n","    widgetsnbextension-3.5.1   |   py38h578d9bd_4         1.8 MB  conda-forge\n","    zeromq-4.3.3               |       he6710b0_3         500 KB\n","    zipp-3.4.1                 |     pyhd8ed1ab_0          11 KB  conda-forge\n","    zstd-1.4.5                 |       h9ceee32_0         619 KB\n","    ------------------------------------------------------------\n","                                           Total:       147.4 MB\n","\n","The following NEW packages will be INSTALLED:\n","\n","  argon2-cffi        conda-forge/linux-64::argon2-cffi-20.1.0-py38h25fe258_2\n","  async_generator    conda-forge/noarch::async_generator-1.10-py_0\n","  attrs              conda-forge/noarch::attrs-20.3.0-pyhd3deb0d_0\n","  backcall           conda-forge/noarch::backcall-0.2.0-pyh9f0ad1d_0\n","  backports          conda-forge/noarch::backports-1.0-py_2\n","  backports.functoo~ conda-forge/noarch::backports.functools_lru_cache-1.6.1-py_0\n","  bleach             conda-forge/noarch::bleach-3.3.0-pyh44b312d_0\n","  bqplot             conda-forge/noarch::bqplot-0.12.23-pyhd8ed1ab_0\n","  cloudpickle        conda-forge/noarch::cloudpickle-1.6.0-py_0\n","  cycler             conda-forge/noarch::cycler-0.10.0-py_2\n","  cytoolz            conda-forge/linux-64::cytoolz-0.11.0-py38h25fe258_1\n","  dask-core          conda-forge/noarch::dask-core-2021.3.0-pyhd8ed1ab_0\n","  decorator          conda-forge/noarch::decorator-4.4.2-py_0\n","  defusedxml         conda-forge/noarch::defusedxml-0.7.1-pyhd8ed1ab_0\n","  entrypoints        conda-forge/noarch::entrypoints-0.3-pyhd8ed1ab_1003\n","  freetype           conda-forge/linux-64::freetype-2.10.4-h7ca028e_0\n","  icu                conda-forge/linux-64::icu-67.1-he1b5a44_0\n","  imageio            conda-forge/noarch::imageio-2.9.0-py_0\n","  importlib-metadata conda-forge/linux-64::importlib-metadata-3.7.3-py38h578d9bd_0\n","  ipydatawidgets     conda-forge/noarch::ipydatawidgets-4.2.0-pyhd3deb0d_0\n","  ipykernel          conda-forge/linux-64::ipykernel-5.5.0-py38h81c977d_1\n","  ipython            conda-forge/linux-64::ipython-7.21.0-py38h81c977d_0\n","  ipython_genutils   conda-forge/noarch::ipython_genutils-0.2.0-py_1\n","  ipyvolume          conda-forge/noarch::ipyvolume-0.6.0a6-pyh9f0ad1d_0\n","  ipywebrtc          conda-forge/linux-64::ipywebrtc-0.5.0-py38h32f6830_1\n","  ipywidgets         conda-forge/noarch::ipywidgets-7.6.3-pyhd3deb0d_0\n","  jedi               conda-forge/linux-64::jedi-0.18.0-py38h578d9bd_2\n","  jinja2             conda-forge/noarch::jinja2-2.11.3-pyh44b312d_0\n","  jpeg               conda-forge/linux-64::jpeg-9d-h36c2ea0_0\n","  jsonschema         conda-forge/noarch::jsonschema-3.2.0-pyhd8ed1ab_3\n","  jupyter_client     conda-forge/noarch::jupyter_client-6.1.12-pyhd8ed1ab_0\n","  jupyter_core       conda-forge/linux-64::jupyter_core-4.7.1-py38h578d9bd_0\n","  jupyterlab_pygmen~ conda-forge/noarch::jupyterlab_pygments-0.1.2-pyh9f0ad1d_0\n","  jupyterlab_widgets conda-forge/noarch::jupyterlab_widgets-1.0.0-pyhd8ed1ab_1\n","  kiwisolver         conda-forge/linux-64::kiwisolver-1.3.1-py38h82cb98a_0\n","  libblas            conda-forge/linux-64::libblas-3.9.0-8_openblas\n","  libcblas           conda-forge/linux-64::libcblas-3.9.0-8_openblas\n","  libgfortran-ng     conda-forge/linux-64::libgfortran-ng-7.5.0-h14aa051_18\n","  libgfortran4       conda-forge/linux-64::libgfortran4-7.5.0-h14aa051_18\n","  liblapack          conda-forge/linux-64::liblapack-3.9.0-8_openblas\n","  libopenblas        conda-forge/linux-64::libopenblas-0.3.12-pthreads_hb3c22a3_1\n","  libpng             conda-forge/linux-64::libpng-1.6.37-h21135ba_2\n","  libsodium          conda-forge/linux-64::libsodium-1.0.18-h36c2ea0_1\n","  libtiff            conda-forge/linux-64::libtiff-4.0.10-hc3755c2_1005\n","  lz4-c              conda-forge/linux-64::lz4-c-1.9.2-he1b5a44_3\n","  markupsafe         conda-forge/linux-64::markupsafe-1.1.1-py38h8df0ef7_2\n","  matplotlib-base    conda-forge/linux-64::matplotlib-base-3.2.2-py38h5d868c9_1\n","  mistune            conda-forge/linux-64::mistune-0.8.4-py38h25fe258_1002\n","  nbclient           conda-forge/noarch::nbclient-0.5.3-pyhd8ed1ab_0\n","  nbconvert          conda-forge/linux-64::nbconvert-6.0.7-py38h578d9bd_3\n","  nbformat           conda-forge/noarch::nbformat-5.1.2-pyhd8ed1ab_1\n","  nest-asyncio       conda-forge/noarch::nest-asyncio-1.4.3-pyhd8ed1ab_0\n","  networkx           conda-forge/noarch::networkx-2.5-py_0\n","  notebook           conda-forge/linux-64::notebook-6.2.0-py38h578d9bd_0\n","  numpy              conda-forge/linux-64::numpy-1.18.1-py38h8854b6b_1\n","  olefile            conda-forge/noarch::olefile-0.46-pyh9f0ad1d_1\n","  packaging          conda-forge/noarch::packaging-20.9-pyh44b312d_0\n","  pandas             conda-forge/linux-64::pandas-1.0.1-py38hb3f55d8_0\n","  pandoc             conda-forge/linux-64::pandoc-2.12-h7f98852_0\n","  pandocfilters      conda-forge/noarch::pandocfilters-1.4.2-py_1\n","  parso              conda-forge/noarch::parso-0.8.1-pyhd8ed1ab_0\n","  pexpect            conda-forge/noarch::pexpect-4.8.0-pyh9f0ad1d_2\n","  pickleshare        conda-forge/noarch::pickleshare-0.7.5-py_1003\n","  pillow             conda-forge/linux-64::pillow-6.2.1-py38h6b7be26_0\n","  prometheus_client  conda-forge/noarch::prometheus_client-0.9.0-pyhd3deb0d_0\n","  prompt-toolkit     conda-forge/noarch::prompt-toolkit-3.0.17-pyha770c72_0\n","  ptyprocess         conda-forge/noarch::ptyprocess-0.7.0-pyhd3deb0d_0\n","  pygments           conda-forge/noarch::pygments-2.8.1-pyhd8ed1ab_0\n","  pyparsing          conda-forge/noarch::pyparsing-2.4.7-pyh9f0ad1d_0\n","  pyrsistent         conda-forge/linux-64::pyrsistent-0.17.3-py38h25fe258_1\n","  python-dateutil    conda-forge/noarch::python-dateutil-2.8.1-py_0\n","  python_abi         conda-forge/linux-64::python_abi-3.8-1_cp38\n","  pythreejs          conda-forge/noarch::pythreejs-2.3.0-pyhd8ed1ab_0\n","  pytz               conda-forge/noarch::pytz-2021.1-pyhd8ed1ab_0\n","  pywavelets         conda-forge/linux-64::pywavelets-1.1.1-py38hab2c0dc_3\n","  pyyaml             conda-forge/linux-64::pyyaml-5.3.1-py38h8df0ef7_1\n","  pyzmq              conda-forge/linux-64::pyzmq-19.0.2-py38ha71036d_2\n","  scikit-image       conda-forge/linux-64::scikit-image-0.16.2-py38hb3f55d8_0\n","  scipy              conda-forge/linux-64::scipy-1.5.3-py38h828c644_0\n","  send2trash         conda-forge/noarch::send2trash-1.5.0-py_0\n","  terminado          conda-forge/linux-64::terminado-0.9.2-py38h578d9bd_0\n","  testpath           conda-forge/noarch::testpath-0.4.4-py_0\n","  toolz              conda-forge/noarch::toolz-0.11.1-py_0\n","  tornado            conda-forge/linux-64::tornado-6.1-py38h25fe258_0\n","  traitlets          conda-forge/noarch::traitlets-5.0.5-py_0\n","  traittypes         conda-forge/noarch::traittypes-0.2.1-pyh9f0ad1d_2\n","  wcwidth            conda-forge/noarch::wcwidth-0.2.5-pyh9f0ad1d_2\n","  webencodings       conda-forge/noarch::webencodings-0.5.1-py_1\n","  widgetsnbextension conda-forge/linux-64::widgetsnbextension-3.5.1-py38h578d9bd_4\n","  zeromq             pkgs/main/linux-64::zeromq-4.3.3-he6710b0_3\n","  zipp               conda-forge/noarch::zipp-3.4.1-pyhd8ed1ab_0\n","  zstd               pkgs/main/linux-64::zstd-1.4.5-h9ceee32_0\n","\n","The following packages will be UPDATED:\n","\n","  ca-certificates    pkgs/main::ca-certificates-2020.10.14~ --> conda-forge::ca-certificates-2020.12.5-ha878542_0\n","  certifi            pkgs/main/noarch::certifi-2020.6.20-p~ --> conda-forge/linux-64::certifi-2020.12.5-py38h578d9bd_1\n","  openssl                                 1.1.1h-h7b6447c_0 --> 1.1.1j-h27cfd23_0\n","\n","The following packages will be SUPERSEDED by a higher-priority channel:\n","\n","  conda               pkgs/main::conda-4.9.2-py38h06a4308_0 --> conda-forge::conda-4.9.2-py38h578d9bd_0\n","\n","\n","Preparing transaction: ...working... done\n","Verifying transaction: ...working... done\n","Executing transaction: ...working... Enabling notebook extension jupyter-js-widgets/extension...\n","Paths used for configuration of notebook: \n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/bqplot.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/ipyvolume.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/ipywebrtc.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/jupyter-datawidgets.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/jupyter-threejs.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/plotlywidget.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/widgetsnbextension.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.json\n","Paths used for configuration of notebook: \n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/bqplot.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/ipyvolume.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/ipywebrtc.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/jupyter-datawidgets.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/jupyter-threejs.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/plotlywidget.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/widgetsnbextension.json\n","      - Validating: \u001b[32mOK\u001b[0m\n","Paths used for configuration of notebook: \n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/bqplot.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/ipyvolume.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/ipywebrtc.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/jupyter-datawidgets.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/jupyter-threejs.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/plotlywidget.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.d/widgetsnbextension.json\n","    \t/usr/local/etc/jupyter/nbconfig/notebook.json\n","\n","done\n","Collecting tensorflow-graphics-gpu\n","  Downloading tensorflow_graphics_gpu-1.0.0-py2.py3-none-any.whl (243 kB)\n","\u001b[K     |████████████████████████████████| 243 kB 4.0 MB/s \n","\u001b[?25hRequirement already satisfied: numpy>=1.15.4 in /usr/local/lib/python3.8/site-packages (from tensorflow-graphics-gpu) (1.18.1)\n","Requirement already satisfied: scipy>=1.1.0 in /usr/local/lib/python3.8/site-packages (from tensorflow-graphics-gpu) (1.5.3)\n","Requirement already satisfied: six>=1.11.0 in /usr/local/lib/python3.8/site-packages (from tensorflow-graphics-gpu) (1.15.0)\n","Collecting absl-py>=0.6.1\n","  Downloading absl_py-0.12.0-py3-none-any.whl (129 kB)\n","\u001b[K     |████████████████████████████████| 129 kB 6.5 MB/s \n","\u001b[?25hCollecting 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 22 kB/s \n","\u001b[?25hCollecting gast==0.3.3\n","  Downloading gast-0.3.3-py2.py3-none-any.whl (9.7 kB)\n","Collecting keras-preprocessing~=1.1.2\n","  Downloading Keras_Preprocessing-1.1.2-py2.py3-none-any.whl (42 kB)\n","\u001b[K     |████████████████████████████████| 42 kB 1.2 MB/s \n","\u001b[?25hCollecting 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 50.7 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 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 protobuf>=3.9.2\n","  Downloading protobuf-3.15.6-cp38-cp38-manylinux1_x86_64.whl (1.0 MB)\n","\u001b[K     |████████████████████████████████| 1.0 MB 54.2 MB/s \n","\u001b[?25hCollecting termcolor~=1.1.0\n","  Downloading termcolor-1.1.0.tar.gz (3.9 kB)\n","Collecting wrapt~=1.12.1\n","  Downloading wrapt-1.12.1.tar.gz (27 kB)\n","Collecting opt-einsum~=3.3.0\n","  Downloading opt_einsum-3.3.0-py3-none-any.whl (65 kB)\n","\u001b[K     |████████████████████████████████| 65 kB 3.8 MB/s \n","\u001b[?25hCollecting google-pasta~=0.2\n","  Downloading google_pasta-0.2.0-py3-none-any.whl (57 kB)\n","\u001b[K     |████████████████████████████████| 57 kB 5.3 MB/s \n","\u001b[?25hCollecting tensorflow-estimator<2.5.0,>=2.4.0\n","  Downloading tensorflow_estimator-2.4.0-py2.py3-none-any.whl (462 kB)\n","\u001b[K     |████████████████████████████████| 462 kB 46.7 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 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 42.3 MB/s \n","\u001b[?25hCollecting tensorboard~=2.4\n","  Downloading tensorboard-2.4.1-py3-none-any.whl (10.6 MB)\n","\u001b[K     |████████████████████████████████| 10.6 MB 53.7 MB/s \n","\u001b[?25hCollecting google-auth-oauthlib<0.5,>=0.4.1\n","  Downloading google_auth_oauthlib-0.4.3-py2.py3-none-any.whl (18 kB)\n","Collecting google-auth<2,>=1.6.3\n","  Downloading google_auth-1.27.1-py2.py3-none-any.whl (136 kB)\n","\u001b[K     |████████████████████████████████| 136 kB 53.9 MB/s \n","\u001b[?25hCollecting markdown>=2.6.8\n","  Downloading Markdown-3.3.4-py3-none-any.whl (97 kB)\n","\u001b[K     |████████████████████████████████| 97 kB 7.4 MB/s \n","\u001b[?25hCollecting werkzeug>=0.11.15\n","  Downloading Werkzeug-1.0.1-py2.py3-none-any.whl (298 kB)\n","\u001b[K     |████████████████████████████████| 298 kB 34.4 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","Requirement 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 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 46.1 MB/s \n","\u001b[?25hCollecting requests-oauthlib>=0.7.0\n","  Downloading requests_oauthlib-1.3.0-py2.py3-none-any.whl (23 kB)\n","Collecting cachetools<5.0,>=2.0.0\n","  Downloading cachetools-4.2.1-py3-none-any.whl (12 kB)\n","Collecting pyasn1-modules>=0.2.1\n","  Downloading pyasn1_modules-0.2.8-py2.py3-none-any.whl (155 kB)\n","\u001b[K     |████████████████████████████████| 155 kB 57.3 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","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: 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","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","Collecting oauthlib>=3.0.0\n","  Downloading oauthlib-3.1.0-py2.py3-none-any.whl (147 kB)\n","\u001b[K     |████████████████████████████████| 147 kB 58.9 MB/s \n","\u001b[?25hCollecting pyasn1<0.5.0,>=0.4.6\n","  Downloading pyasn1-0.4.8-py2.py3-none-any.whl (77 kB)\n","\u001b[K     |████████████████████████████████| 77 kB 5.8 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=6c15710a303393d92067fefd63038469f2d89a1e98817ad7763f5437b91e09aa\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=78011 sha256=82705ba529015d8961b67c00c67fbbb4e5d3e665271117864c020e5dad43c517\n","  Stored in directory: /root/.cache/pip/wheels/5f/fd/9e/b6cf5890494cb8ef0b5eaff72e5d55a70fb56316007d6dfe73\n","Successfully built termcolor wrapt\n","Installing collected packages: absl-py, gast, keras-preprocessing, h5py, typing-extensions, astunparse, flatbuffers, protobuf, termcolor, wrapt, opt-einsum, google-pasta, tensorflow-estimator, grpcio, cachetools, pyasn1, pyasn1-modules, rsa, google-auth, oauthlib, requests-oauthlib, google-auth-oauthlib, markdown, werkzeug, tensorboard-plugin-wit, tensorboard, 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.12.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.6 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"},{"output_type":"display_data","data":{"application/vnd.colab-display-data+json":{"pip_warning":{"packages":["google"]}}},"metadata":{"tags":[]}}]},{"cell_type":"code","metadata":{"id":"VZDmNWzdK4KO","executionInfo":{"status":"ok","timestamp":1615799109865,"user_tz":-60,"elapsed":225552,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["import sys\n","sys.path.append('/usr/local/lib/python3.8/site-packages')\n","sys.path.append(\"protein-reconstruction\") "],"execution_count":6,"outputs":[]},{"cell_type":"code","metadata":{"id":"Zro6bM3VK4KR","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615799109865,"user_tz":-60,"elapsed":225545,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"e4837b7c-e335-420e-e5ec-dd39b9c7d49c"},"source":["!python --version"],"execution_count":7,"outputs":[{"output_type":"stream","text":["Python 3.8.5\n"],"name":"stdout"}]},{"cell_type":"markdown","metadata":{"id":"787rPWn8K4KU"},"source":["## Start the Pipeline"]},{"cell_type":"code","metadata":{"id":"06JQ1KmQK4KV","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615799134283,"user_tz":-60,"elapsed":249956,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"cdccc5a5-8fe9-4488-fbe8-8c59574c3e1a"},"source":["import os\n","import h5py\n","import numpy as np\n","import time\n","import pandas as pd\n","\n","\n","from cryoem.plots import plot_angles_count, plot_images\n","from IPython.display import Image\n","import matplotlib.pyplot as plt\n","\n","import tensorflow as tf\n","from cryoem.conversions import d_q, euler2quaternion\n","#import ipyvolume as ipv\n","from collections import Counter\n","import itertools\n","import seaborn as sns; sns.set(style=\"white\", color_codes=True)\n","import io"],"execution_count":8,"outputs":[{"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":1615799134284,"user_tz":-60,"elapsed":249948,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"0bb98cfe-daaf-41ab-9c1f-deea78cb2b83"},"source":["tf.__version__"],"execution_count":9,"outputs":[{"output_type":"execute_result","data":{"application/vnd.google.colaboratory.intrinsic+json":{"type":"string"},"text/plain":["'2.4.1'"]},"metadata":{"tags":[]},"execution_count":9}]},{"cell_type":"code","metadata":{"id":"ShUD7yqTK4Kb","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615799139196,"user_tz":-60,"elapsed":254852,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"04b89c16-0587-4e2d-fe1e-7841203be40f"},"source":["from tensorflow.python.client import device_lib \n","print(device_lib.list_local_devices())"],"execution_count":10,"outputs":[{"output_type":"stream","text":["[name: \"/device:CPU:0\"\n","device_type: \"CPU\"\n","memory_limit: 268435456\n","locality {\n","}\n","incarnation: 16531145956419149120\n",", name: \"/device:GPU:0\"\n","device_type: \"GPU\"\n","memory_limit: 11154422528\n","locality {\n","  bus_id: 1\n","  links {\n","  }\n","}\n","incarnation: 641525767465021842\n","physical_device_desc: \"device: 0, name: Tesla K80, pci bus id: 0000:00:04.0, compute capability: 3.7\"\n","]\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"kZFVlYW4K4Ke","executionInfo":{"status":"ok","timestamp":1615799284576,"user_tz":-60,"elapsed":693,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["PROTEIN=\"5a1a\"\n","NUM_PROJECTIONS = 5000\n","\n","NOISY_VAR = 16 # 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_noise16\""],"execution_count":39,"outputs":[]},{"cell_type":"code","metadata":{"id":"-q8GWm2EK4Kh","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615799284909,"user_tz":-60,"elapsed":561,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"4b2af61e-ef47-495c-9a3d-b8ba762d518e"},"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":40,"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":1615799329123,"user_tz":-60,"elapsed":43794,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"28de2673-5b6d-44db-85ea-605f57d34132"},"source":["projections = np.array(data['Projections'], dtype=np.float32)\n","projections.shape"],"execution_count":41,"outputs":[{"output_type":"execute_result","data":{"text/plain":["(5000, 275, 275)"]},"metadata":{"tags":[]},"execution_count":41}]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"bu0vfR_1cKIv","executionInfo":{"status":"ok","timestamp":1615799329124,"user_tz":-60,"elapsed":43268,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"5422df88-8d25-4e92-fb5c-d1ca82907eec"},"source":["type(projections[0][0][0])"],"execution_count":42,"outputs":[{"output_type":"execute_result","data":{"text/plain":["numpy.float32"]},"metadata":{"tags":[]},"execution_count":42}]},{"cell_type":"code","metadata":{"id":"bIQzyIQnxgts","colab":{"base_uri":"https://localhost:8080/","height":271},"executionInfo":{"status":"ok","timestamp":1615799329135,"user_tz":-60,"elapsed":42774,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"77d617d7-52bb-45dd-a022-781738640567"},"source":["sampleProj = projections[1,:,:]\n","plt.imshow(sampleProj,cmap='gray')\n","plt.show()"],"execution_count":43,"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","executionInfo":{"status":"ok","timestamp":1615799329136,"user_tz":-60,"elapsed":41733,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"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":44,"outputs":[]},{"cell_type":"code","metadata":{"id":"ydwWD-IkD0P3","executionInfo":{"status":"ok","timestamp":1615799329137,"user_tz":-60,"elapsed":41156,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"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":45,"outputs":[]},{"cell_type":"code","metadata":{"id":"oCD6IwpOr3_A","executionInfo":{"status":"ok","timestamp":1615799329137,"user_tz":-60,"elapsed":40484,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":[""],"execution_count":45,"outputs":[]},{"cell_type":"code","metadata":{"id":"5FsWg8C4m9S3","executionInfo":{"status":"ok","timestamp":1615799351936,"user_tz":-60,"elapsed":62905,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"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":46,"outputs":[]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"dqYmKvjHnOop","executionInfo":{"status":"ok","timestamp":1615799351939,"user_tz":-60,"elapsed":61433,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"dd961a56-27ca-4d3b-b42e-a303dca938c1"},"source":["projections.shape"],"execution_count":47,"outputs":[{"output_type":"execute_result","data":{"text/plain":["(5000, 116, 116)"]},"metadata":{"tags":[]},"execution_count":47}]},{"cell_type":"code","metadata":{"id":"GSJYr5JLJF8H","executionInfo":{"status":"ok","timestamp":1615799355853,"user_tz":-60,"elapsed":64637,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"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":48,"outputs":[]},{"cell_type":"code","metadata":{"id":"qR8J0QCmxG-y","colab":{"base_uri":"https://localhost:8080/","height":271},"executionInfo":{"status":"ok","timestamp":1615799355854,"user_tz":-60,"elapsed":63252,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"055f4f1c-dc2a-49f6-ac9f-7fdd7cf7c0a2"},"source":["# Display projections with/out noise (for comparison)\n","sampleProj = projections[1,:,:]\n","plt.imshow(sampleProj,cmap='gray')\n","plt.show()"],"execution_count":49,"outputs":[{"output_type":"display_data","data":{"image/png":"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5WM6ceJENDg4GNYLWWwclT4DVacYRkZGor6+viibzUZRFEXZbDbq6+uLMplMRcf17bffRs8880x06tSp6NFHHw0/z2Qy0fr162/ZOObm5qInnngi6u/vDxut0mOanJyM+vr6osnJyZKfV3It8/l89MADD0QnT56MoiiKfv7552jz5s0VHZMrhsXGUQ1noOqqK4eGhtTT0xNqJJLJpNLptIaGhtTR0VGRMeXzeX3xxRfasGGDhoaGtHz58vBvHR0dobFKKpX6j4/lgw8+0Pbt20tKZSs9pv7+fqVSKR04cEA//fSTWlpa9Oqrr6qxsbFia1lTU6P3339fL774opqbmzU1NaVPPvmkavbXYuOIoqjiY6xKjKHaZN++fWpubtbTTz9d0XH8+uuvOn36tJ588smKjqNccrmc+vv7de+99+qrr77Sa6+9ppdffjm0OquEZLNZffzxx/rwww91/PhxffTRR9q9e3dFx/TfJFXnMSxbtkxXrlxRLpcLdfxXr17VsmXLKjKe/fv36+LFizp06JASiYSWLVumwcHB8O/cRn0rLPOJEyd0/vx5bdy4UVLhvsNdu3Zp586dFRuTVFiz2tpabd26VZJ03333qb29XY2NjRVbyzNnzujq1avq6+uTJPX19ampqUkNDQ1Vsb8W2+dRFFV8jFXnMXR2dmrt2rU6cuSIJOnIkSNau3ZtRcKI9957T6dPn9bBgwdD6/h169ZpdnZWJ0+elCR9+eWXeuSRR27JeF544QV9//33OnbsmI4dO6be3l599tlneu655yo2JqkQujz44IP64YcfJBUQ9UwmozVr1lRsLXt7e3X58mX9+eefkqTz588rk8lo9erVVbG/Ftvn1XAGqrLs+vz589qzZ48mJia0dOlS7d+/X7fffvstHcMff/yhrVu3as2aNaFefeXKlTp48KB++eUX7d27V3Nzc1qxYoXeffdddXV13dLxSdKGDRt06NAh3XXXXRUfU39/v954441wZ8fu3bv10EMPVXQtv/76a3366aeho9Err7yiTZs23fIxvfXWWzp69KhGRkbU3t6uVCqlb775ZtFxVPoMVKViiCWWWCorVRdKxBJLLJWXWDHEEkssCyRWDLHEEssCiRVDLLHEskBixRBLLLEskFgxxBJLLAskVgyxxBLLAokVQyyxxLJA/gX/Pqq1a0esyAAAAABJRU5ErkJggg==\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":1615799392682,"user_tz":-60,"elapsed":1061,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"cd21dfe8-4587-47f6-da74-6740fbe88837"},"source":["angles_true = np.array(data['Angles'])\n","angles_true.shape"],"execution_count":50,"outputs":[{"output_type":"execute_result","data":{"text/plain":["(5000, 3)"]},"metadata":{"tags":[]},"execution_count":50}]},{"cell_type":"code","metadata":{"id":"WJvZ8_XPK4Kp","executionInfo":{"status":"ok","timestamp":1615799393293,"user_tz":-60,"elapsed":1249,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["#plot_images(angles_true, projections, range(100), img_size_scale=0.05)"],"execution_count":51,"outputs":[]},{"cell_type":"code","metadata":{"id":"Z-CMl6nMK4Ks","executionInfo":{"status":"ok","timestamp":1615799393294,"user_tz":-60,"elapsed":962,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["#ipv.screenshot()"],"execution_count":52,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"xJhOqdOnK4Kv"},"source":["---"]},{"cell_type":"markdown","metadata":{"id":"5-mkqsaEK4Kw"},"source":["## Prepare for training"]},{"cell_type":"code","metadata":{"id":"r_RDAMqvK4Kw","executionInfo":{"status":"ok","timestamp":1615799394150,"user_tz":-60,"elapsed":934,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["from sklearn.model_selection import train_test_split"],"execution_count":53,"outputs":[]},{"cell_type":"code","metadata":{"id":"O_lxJ3huK4K0","executionInfo":{"status":"ok","timestamp":1615799394779,"user_tz":-60,"elapsed":1296,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["X, y = np.array(projections, dtype=np.float32), np.array(angles_true, dtype=np.float32)"],"execution_count":54,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"4f-dUZ4kK4K3"},"source":["#### Global standardization of projections"]},{"cell_type":"code","metadata":{"id":"X6A3wHMVK4K3","executionInfo":{"status":"ok","timestamp":1615799395042,"user_tz":-60,"elapsed":977,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["from cryoem.preprocessing import global_standardization"],"execution_count":55,"outputs":[]},{"cell_type":"code","metadata":{"id":"3pRAKWKmK4K6","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615799395782,"user_tz":-60,"elapsed":1389,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"216c4d35-cdb3-411a-db32-552ebce1d9a3"},"source":["X = global_standardization(X)"],"execution_count":56,"outputs":[{"output_type":"stream","text":["Global standardization\n","\tImage shape: (116, 116)\n","\tData Type: float32\n","\tMean: 2.956 | Std: 8.779\n","\tMin:  -21.112 | Max: 86.030\n","\tMean: -0.000 | Std: 1.000\n","\tMin:  -2.742 | Max: 9.463\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"lVRXjdE3K4K9","executionInfo":{"status":"ok","timestamp":1615799395782,"user_tz":-60,"elapsed":814,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["test_size = 0.33\n","val_size = 0.25"],"execution_count":57,"outputs":[]},{"cell_type":"code","metadata":{"id":"fRyiZcWPK4LC","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615799396754,"user_tz":-60,"elapsed":1210,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"3feb5db7-f6d2-4f96-bf59-bd5b8492f709"},"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":58,"outputs":[{"output_type":"stream","text":["TRAIN: 0.67 x 0.75 = 0.50 =>  2512 imgs => max pairs:    6312656\n","TEST :               0.33 =>  1650 imgs => max pairs:    2722500\n","VAL  : 0.67 x 0.25 = 0.17 =>   837 imgs => max pairs:     701406\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"dmtJEGv1K4LF","executionInfo":{"status":"ok","timestamp":1615799397106,"user_tz":-60,"elapsed":938,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"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":59,"outputs":[]},{"cell_type":"code","metadata":{"id":"KNkQKrfJK4LH","executionInfo":{"status":"ok","timestamp":1615799397107,"user_tz":-60,"elapsed":423,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"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":60,"outputs":[]},{"cell_type":"code","metadata":{"id":"WCOYGoQRK4LK","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615799397969,"user_tz":-60,"elapsed":1033,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"67d0fcb1-581e-49a9-becd-09051531a7c0"},"source":["X.shape"],"execution_count":61,"outputs":[{"output_type":"execute_result","data":{"text/plain":["(5000, 116, 116, 1)"]},"metadata":{"tags":[]},"execution_count":61}]},{"cell_type":"markdown","metadata":{"id":"YZ71Z1DWK4LM"},"source":["# 1. Distance Estimation"]},{"cell_type":"markdown","metadata":{"id":"0ZRKoKicK4LN"},"source":["### Train the model"]},{"cell_type":"code","metadata":{"id":"HceKfhOaK4LN","executionInfo":{"status":"ok","timestamp":1615799399265,"user_tz":-60,"elapsed":1199,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["from time import time"],"execution_count":62,"outputs":[]},{"cell_type":"code","metadata":{"id":"hqkn_ZVBK4LQ","executionInfo":{"status":"ok","timestamp":1615799399675,"user_tz":-60,"elapsed":1248,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"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":63,"outputs":[]},{"cell_type":"code","metadata":{"id":"Ui3KmgarK4LT","executionInfo":{"status":"ok","timestamp":1615799400663,"user_tz":-60,"elapsed":1897,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"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":64,"outputs":[]},{"cell_type":"code","metadata":{"id":"qOYwbjOzK4LV","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615799400667,"user_tz":-60,"elapsed":1448,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"655337aa-b4f8-408e-fa2d-bd295449752a"},"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":65,"outputs":[{"output_type":"execute_result","data":{"text/plain":["(63101, 7022)"]},"metadata":{"tags":[]},"execution_count":65}]},{"cell_type":"code","metadata":{"scrolled":true,"id":"8HWI9cfqK4LY","colab":{"base_uri":"https://localhost:8080/","height":1000},"executionInfo":{"status":"error","timestamp":1615818311549,"user_tz":-60,"elapsed":17196030,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"473b3ba4-ca92-4420-fd5b-37ffbf71f5c0"},"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":66,"outputs":[{"output_type":"stream","text":["INFO:tensorflow:Using MirroredStrategy with devices ('/job:localhost/replica:0/task:0/device:GPU:0',)\n","Data created in 8.768343925476074 sec\n","Data created in 0.9499454498291016 sec\n","Input images shape (116, 116, 1)\n","Model: \"model_3\"\n","__________________________________________________________________________________________________\n","Layer (type)                    Output Shape         Param #     Connected to                     \n","==================================================================================================\n","input_4 (InputLayer)            [(None, 116, 116, 1) 0                                            \n","__________________________________________________________________________________________________\n","input_5 (InputLayer)            [(None, 116, 116, 1) 0                                            \n","__________________________________________________________________________________________________\n","model_2 (Functional)            (None, 512)          4551936     input_4[0][0]                    \n","                                                                 input_5[0][0]                    \n","__________________________________________________________________________________________________\n","lambda_1 (Lambda)               (None, 1)            0           model_2[0][0]                    \n","                                                                 model_2[1][0]                    \n","==================================================================================================\n","Total params: 4,551,936\n","Trainable params: 4,551,936\n","Non-trainable params: 0\n","__________________________________________________________________________________________________\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_noise16.h5\n","Epoch 1/150\n","247/247 [==============================] - 153s 605ms/step - loss: 0.7481 - mse: 0.9813 - val_loss: 0.3497 - val_mse: 0.2198\n","Epoch 2/150\n","247/247 [==============================] - 144s 582ms/step - loss: 0.2898 - mse: 0.1502 - val_loss: 0.2504 - val_mse: 0.1296\n","Epoch 3/150\n","247/247 [==============================] - 144s 582ms/step - loss: 0.1982 - mse: 0.0705 - val_loss: 0.2329 - val_mse: 0.1310\n","Epoch 4/150\n","247/247 [==============================] - 144s 582ms/step - loss: 0.1646 - mse: 0.0466 - val_loss: 0.2146 - val_mse: 0.1150\n","Epoch 5/150\n","247/247 [==============================] - 143s 578ms/step - loss: 0.1505 - mse: 0.0384 - val_loss: 0.2080 - val_mse: 0.1113\n","Epoch 6/150\n","247/247 [==============================] - 144s 582ms/step - loss: 0.1434 - mse: 0.0348 - val_loss: 0.2018 - val_mse: 0.1039\n","Epoch 7/150\n","247/247 [==============================] - 144s 582ms/step - loss: 0.1394 - mse: 0.0332 - val_loss: 0.1987 - val_mse: 0.1058\n","Epoch 8/150\n","247/247 [==============================] - 143s 580ms/step - loss: 0.1357 - mse: 0.0322 - val_loss: 0.1978 - val_mse: 0.1048\n","Epoch 9/150\n","247/247 [==============================] - 144s 581ms/step - loss: 0.1348 - mse: 0.0318 - val_loss: 0.1982 - val_mse: 0.1049\n","Epoch 10/150\n","247/247 [==============================] - 144s 582ms/step - loss: 0.1320 - mse: 0.0307 - val_loss: 0.1896 - val_mse: 0.0939\n","Epoch 11/150\n","247/247 [==============================] - 144s 581ms/step - loss: 0.1306 - mse: 0.0303 - val_loss: 0.1948 - val_mse: 0.1018\n","Epoch 12/150\n","247/247 [==============================] - 143s 578ms/step - loss: 0.1299 - mse: 0.0301 - val_loss: 0.1938 - val_mse: 0.1026\n","Epoch 13/150\n","247/247 [==============================] - 144s 583ms/step - loss: 0.1282 - mse: 0.0297 - val_loss: 0.1919 - val_mse: 0.0990\n","Epoch 14/150\n","247/247 [==============================] - 144s 582ms/step - loss: 0.1266 - mse: 0.0294 - val_loss: 0.1888 - val_mse: 0.0964\n","Epoch 15/150\n","247/247 [==============================] - 144s 582ms/step - loss: 0.1266 - mse: 0.0293 - val_loss: 0.1938 - val_mse: 0.1039\n","Epoch 16/150\n","247/247 [==============================] - 144s 582ms/step - loss: 0.1262 - mse: 0.0292 - val_loss: 0.1936 - val_mse: 0.1024\n","Epoch 17/150\n","247/247 [==============================] - 144s 584ms/step - loss: 0.1260 - mse: 0.0294 - val_loss: 0.1976 - val_mse: 0.1041\n","Epoch 18/150\n","247/247 [==============================] - 144s 582ms/step - loss: 0.1254 - mse: 0.0290 - val_loss: 0.1886 - val_mse: 0.0948\n","Epoch 19/150\n","247/247 [==============================] - 144s 583ms/step - loss: 0.1246 - mse: 0.0289 - val_loss: 0.1901 - val_mse: 0.1001\n","Epoch 20/150\n","247/247 [==============================] - 144s 584ms/step - loss: 0.1235 - mse: 0.0285 - val_loss: 0.1860 - val_mse: 0.0922\n","Epoch 21/150\n","247/247 [==============================] - 144s 584ms/step - loss: 0.1229 - mse: 0.0285 - val_loss: 0.1898 - val_mse: 0.0973\n","Epoch 22/150\n","247/247 [==============================] - 143s 581ms/step - loss: 0.1231 - mse: 0.0285 - val_loss: 0.1873 - val_mse: 0.0931\n","Epoch 23/150\n","247/247 [==============================] - 144s 582ms/step - loss: 0.1227 - mse: 0.0283 - val_loss: 0.1928 - val_mse: 0.0988\n","Epoch 24/150\n","247/247 [==============================] - 143s 580ms/step - loss: 0.1217 - mse: 0.0282 - val_loss: 0.1891 - val_mse: 0.0961\n","Epoch 25/150\n","247/247 [==============================] - 144s 581ms/step - loss: 0.1219 - mse: 0.0281 - val_loss: 0.1920 - val_mse: 0.0989\n","Epoch 26/150\n","247/247 [==============================] - 144s 582ms/step - loss: 0.1213 - mse: 0.0281 - val_loss: 0.1853 - val_mse: 0.0924\n","Epoch 27/150\n","247/247 [==============================] - 144s 583ms/step - loss: 0.1207 - mse: 0.0277 - val_loss: 0.1880 - val_mse: 0.0958\n","Epoch 28/150\n","247/247 [==============================] - 144s 581ms/step - loss: 0.1211 - mse: 0.0279 - val_loss: 0.1904 - val_mse: 0.0997\n","Epoch 29/150\n","247/247 [==============================] - 144s 582ms/step - loss: 0.1205 - mse: 0.0279 - val_loss: 0.1843 - val_mse: 0.0932\n","Epoch 30/150\n","247/247 [==============================] - 144s 581ms/step - loss: 0.1198 - mse: 0.0275 - val_loss: 0.1905 - val_mse: 0.0978\n","Epoch 31/150\n","247/247 [==============================] - 143s 580ms/step - loss: 0.1200 - mse: 0.0278 - val_loss: 0.1896 - val_mse: 0.0982\n","Epoch 32/150\n","247/247 [==============================] - 143s 580ms/step - loss: 0.1203 - mse: 0.0278 - val_loss: 0.1945 - val_mse: 0.1024\n","Epoch 33/150\n","247/247 [==============================] - 142s 575ms/step - loss: 0.1187 - mse: 0.0273 - val_loss: 0.1884 - val_mse: 0.0968\n","Epoch 34/150\n","247/247 [==============================] - 142s 575ms/step - loss: 0.1184 - mse: 0.0273 - val_loss: 0.1925 - val_mse: 0.1032\n","Epoch 35/150\n","247/247 [==============================] - 142s 575ms/step - loss: 0.1185 - mse: 0.0273 - val_loss: 0.1933 - val_mse: 0.1008\n","Epoch 36/150\n","247/247 [==============================] - 142s 576ms/step - loss: 0.1179 - mse: 0.0270 - val_loss: 0.1922 - val_mse: 0.1007\n","Epoch 37/150\n","247/247 [==============================] - 142s 575ms/step - loss: 0.1193 - mse: 0.0278 - val_loss: 0.1871 - val_mse: 0.0971\n","Epoch 38/150\n","247/247 [==============================] - 142s 575ms/step - loss: 0.1194 - mse: 0.0277 - val_loss: 0.1928 - val_mse: 0.1017\n","Epoch 39/150\n","247/247 [==============================] - 142s 575ms/step - loss: 0.1178 - mse: 0.0270 - val_loss: 0.1900 - val_mse: 0.0971\n","Epoch 40/150\n","247/247 [==============================] - 142s 576ms/step - loss: 0.1178 - mse: 0.0271 - val_loss: 0.1888 - val_mse: 0.0944\n","Epoch 41/150\n","247/247 [==============================] - 142s 575ms/step - loss: 0.1184 - mse: 0.0273 - val_loss: 0.1946 - val_mse: 0.1023\n","Epoch 42/150\n","247/247 [==============================] - 142s 576ms/step - loss: 0.1176 - mse: 0.0271 - val_loss: 0.1946 - val_mse: 0.1002\n","Epoch 43/150\n","247/247 [==============================] - 142s 577ms/step - loss: 0.1180 - mse: 0.0271 - val_loss: 0.1936 - val_mse: 0.1037\n","Epoch 44/150\n","247/247 [==============================] - 142s 574ms/step - loss: 0.1174 - mse: 0.0272 - val_loss: 0.1882 - val_mse: 0.0954\n","Epoch 45/150\n","247/247 [==============================] - 142s 574ms/step - loss: 0.1172 - mse: 0.0269 - val_loss: 0.1922 - val_mse: 0.1024\n","Epoch 46/150\n","247/247 [==============================] - 142s 573ms/step - loss: 0.1164 - mse: 0.0268 - val_loss: 0.1921 - val_mse: 0.0990\n","Epoch 47/150\n","247/247 [==============================] - 141s 572ms/step - loss: 0.1165 - mse: 0.0267 - val_loss: 0.1928 - val_mse: 0.1013\n","Epoch 48/150\n","247/247 [==============================] - 141s 572ms/step - loss: 0.1160 - mse: 0.0268 - val_loss: 0.1938 - val_mse: 0.1034\n","Epoch 49/150\n","247/247 [==============================] - 142s 573ms/step - loss: 0.1158 - mse: 0.0268 - val_loss: 0.1961 - val_mse: 0.1048\n","Epoch 50/150\n","247/247 [==============================] - 142s 573ms/step - loss: 0.1161 - mse: 0.0268 - val_loss: 0.1946 - val_mse: 0.1022\n","Epoch 51/150\n","247/247 [==============================] - 142s 575ms/step - loss: 0.1162 - mse: 0.0268 - val_loss: 0.1959 - val_mse: 0.1045\n","Epoch 52/150\n","247/247 [==============================] - 142s 574ms/step - loss: 0.1169 - mse: 0.0271 - val_loss: 0.1934 - val_mse: 0.1014\n","Epoch 53/150\n","247/247 [==============================] - 142s 573ms/step - loss: 0.1160 - mse: 0.0268 - val_loss: 0.1924 - val_mse: 0.1007\n","Epoch 54/150\n","247/247 [==============================] - 142s 573ms/step - loss: 0.1157 - mse: 0.0268 - val_loss: 0.1931 - val_mse: 0.1006\n","Epoch 55/150\n","247/247 [==============================] - 141s 572ms/step - loss: 0.1155 - mse: 0.0266 - val_loss: 0.1969 - val_mse: 0.1054\n","Epoch 56/150\n","247/247 [==============================] - 142s 573ms/step - loss: 0.1159 - mse: 0.0269 - val_loss: 0.1951 - val_mse: 0.1007\n","Epoch 57/150\n","247/247 [==============================] - 141s 572ms/step - loss: 0.1152 - mse: 0.0264 - val_loss: 0.1947 - val_mse: 0.1015\n","Epoch 58/150\n","247/247 [==============================] - 142s 575ms/step - loss: 0.1153 - mse: 0.0265 - val_loss: 0.1939 - val_mse: 0.1003\n","Epoch 59/150\n","247/247 [==============================] - 142s 575ms/step - loss: 0.1158 - mse: 0.0267 - val_loss: 0.1928 - val_mse: 0.1008\n","Epoch 60/150\n","247/247 [==============================] - 142s 575ms/step - loss: 0.1153 - mse: 0.0265 - val_loss: 0.1939 - val_mse: 0.1018\n","Epoch 61/150\n","247/247 [==============================] - 141s 573ms/step - loss: 0.1147 - mse: 0.0264 - val_loss: 0.1968 - val_mse: 0.1051\n","Epoch 62/150\n","247/247 [==============================] - 142s 573ms/step - loss: 0.1153 - mse: 0.0266 - val_loss: 0.1935 - val_mse: 0.1008\n","Epoch 63/150\n","247/247 [==============================] - 142s 575ms/step - loss: 0.1145 - mse: 0.0263 - val_loss: 0.1927 - val_mse: 0.0993\n","Epoch 64/150\n","247/247 [==============================] - 142s 575ms/step - loss: 0.1144 - mse: 0.0264 - val_loss: 0.1944 - val_mse: 0.1009\n","Epoch 65/150\n","247/247 [==============================] - 143s 577ms/step - loss: 0.1144 - mse: 0.0262 - val_loss: 0.1948 - val_mse: 0.1014\n","Epoch 66/150\n","247/247 [==============================] - 142s 577ms/step - loss: 0.1145 - mse: 0.0263 - val_loss: 0.1948 - val_mse: 0.1023\n","Epoch 67/150\n","247/247 [==============================] - 143s 578ms/step - loss: 0.1146 - mse: 0.0264 - val_loss: 0.1956 - val_mse: 0.1030\n","Epoch 68/150\n","247/247 [==============================] - 142s 576ms/step - loss: 0.1139 - mse: 0.0263 - val_loss: 0.1957 - val_mse: 0.1032\n","Epoch 69/150\n","247/247 [==============================] - 142s 576ms/step - loss: 0.1150 - mse: 0.0267 - val_loss: 0.1976 - val_mse: 0.1055\n","Epoch 70/150\n","247/247 [==============================] - 142s 575ms/step - loss: 0.1143 - mse: 0.0264 - val_loss: 0.1992 - val_mse: 0.1076\n","Epoch 71/150\n","247/247 [==============================] - 142s 576ms/step - loss: 0.1142 - mse: 0.0264 - val_loss: 0.1982 - val_mse: 0.1062\n","Epoch 72/150\n","247/247 [==============================] - 142s 576ms/step - loss: 0.1140 - mse: 0.0262 - val_loss: 0.1947 - val_mse: 0.1022\n","Epoch 73/150\n","247/247 [==============================] - 142s 576ms/step - loss: 0.1134 - mse: 0.0262 - val_loss: 0.1969 - val_mse: 0.1055\n","Epoch 74/150\n","247/247 [==============================] - 142s 577ms/step - loss: 0.1132 - mse: 0.0260 - val_loss: 0.1963 - val_mse: 0.1021\n","Epoch 75/150\n","247/247 [==============================] - 143s 577ms/step - loss: 0.1135 - mse: 0.0261 - val_loss: 0.1946 - val_mse: 0.1034\n","Epoch 76/150\n","247/247 [==============================] - 142s 576ms/step - loss: 0.1136 - mse: 0.0261 - val_loss: 0.1956 - val_mse: 0.1025\n","Epoch 77/150\n","247/247 [==============================] - 142s 575ms/step - loss: 0.1135 - mse: 0.0263 - val_loss: 0.1939 - val_mse: 0.1015\n","Epoch 78/150\n","247/247 [==============================] - 142s 577ms/step - loss: 0.1135 - mse: 0.0263 - val_loss: 0.1986 - val_mse: 0.1068\n","Epoch 79/150\n","247/247 [==============================] - 143s 579ms/step - loss: 0.1140 - mse: 0.0264 - val_loss: 0.1955 - val_mse: 0.1022\n","Epoch 80/150\n","247/247 [==============================] - 143s 580ms/step - loss: 0.1142 - mse: 0.0265 - val_loss: 0.1965 - val_mse: 0.1042\n","Epoch 81/150\n","247/247 [==============================] - 143s 578ms/step - loss: 0.1135 - mse: 0.0263 - val_loss: 0.1966 - val_mse: 0.1040\n","Epoch 82/150\n","247/247 [==============================] - 143s 578ms/step - loss: 0.1125 - mse: 0.0258 - val_loss: 0.1963 - val_mse: 0.1042\n","Epoch 83/150\n","247/247 [==============================] - 143s 579ms/step - loss: 0.1140 - mse: 0.0265 - val_loss: 0.1961 - val_mse: 0.1043\n","Epoch 84/150\n","247/247 [==============================] - 143s 579ms/step - loss: 0.1133 - mse: 0.0260 - val_loss: 0.1959 - val_mse: 0.1045\n","Epoch 85/150\n","247/247 [==============================] - 142s 574ms/step - loss: 0.1139 - mse: 0.0265 - val_loss: 0.1973 - val_mse: 0.1058\n","Epoch 86/150\n","247/247 [==============================] - 142s 577ms/step - loss: 0.1131 - mse: 0.0262 - val_loss: 0.1987 - val_mse: 0.1072\n","Epoch 87/150\n","247/247 [==============================] - 142s 577ms/step - loss: 0.1135 - mse: 0.0262 - val_loss: 0.1982 - val_mse: 0.1047\n","Epoch 88/150\n","247/247 [==============================] - 142s 577ms/step - loss: 0.1128 - mse: 0.0259 - val_loss: 0.1959 - val_mse: 0.1024\n","Epoch 89/150\n","247/247 [==============================] - 142s 574ms/step - loss: 0.1131 - mse: 0.0259 - val_loss: 0.1973 - val_mse: 0.1048\n","Epoch 90/150\n","247/247 [==============================] - 143s 578ms/step - loss: 0.1131 - mse: 0.0262 - val_loss: 0.1948 - val_mse: 0.1016\n","Epoch 91/150\n","247/247 [==============================] - 143s 579ms/step - loss: 0.1139 - mse: 0.0265 - val_loss: 0.1957 - val_mse: 0.1023\n","Epoch 92/150\n","247/247 [==============================] - 142s 577ms/step - loss: 0.1138 - mse: 0.0263 - val_loss: 0.2001 - val_mse: 0.1083\n","Epoch 93/150\n","247/247 [==============================] - 143s 579ms/step - loss: 0.1131 - mse: 0.0262 - val_loss: 0.1960 - val_mse: 0.1030\n","Epoch 94/150\n","247/247 [==============================] - 143s 578ms/step - loss: 0.1127 - mse: 0.0259 - val_loss: 0.1950 - val_mse: 0.1007\n","Epoch 95/150\n","247/247 [==============================] - 143s 578ms/step - loss: 0.1129 - mse: 0.0261 - val_loss: 0.1968 - val_mse: 0.1044\n","Epoch 96/150\n","247/247 [==============================] - 143s 578ms/step - loss: 0.1120 - mse: 0.0259 - val_loss: 0.1938 - val_mse: 0.1010\n","Epoch 97/150\n","247/247 [==============================] - 143s 579ms/step - loss: 0.1128 - mse: 0.0260 - val_loss: 0.1969 - val_mse: 0.1039\n","Epoch 98/150\n","247/247 [==============================] - 143s 578ms/step - loss: 0.1127 - mse: 0.0260 - val_loss: 0.1980 - val_mse: 0.1055\n","Epoch 99/150\n","247/247 [==============================] - 143s 578ms/step - loss: 0.1124 - mse: 0.0261 - val_loss: 0.1979 - val_mse: 0.1059\n","Epoch 100/150\n","247/247 [==============================] - 142s 576ms/step - loss: 0.1122 - mse: 0.0262 - val_loss: 0.1981 - val_mse: 0.1062\n","Epoch 101/150\n","247/247 [==============================] - 143s 577ms/step - loss: 0.1124 - mse: 0.0260 - val_loss: 0.1993 - val_mse: 0.1083\n","Epoch 102/150\n","247/247 [==============================] - 143s 579ms/step - loss: 0.1131 - mse: 0.0263 - val_loss: 0.1987 - val_mse: 0.1071\n","Epoch 103/150\n","247/247 [==============================] - 143s 578ms/step - loss: 0.1120 - mse: 0.0258 - val_loss: 0.1970 - val_mse: 0.1053\n","Epoch 104/150\n","247/247 [==============================] - 142s 577ms/step - loss: 0.1124 - mse: 0.0261 - val_loss: 0.1992 - val_mse: 0.1070\n","Epoch 105/150\n","247/247 [==============================] - 142s 576ms/step - loss: 0.1127 - mse: 0.0262 - val_loss: 0.1960 - val_mse: 0.1010\n","Epoch 106/150\n","247/247 [==============================] - 143s 579ms/step - loss: 0.1116 - mse: 0.0257 - val_loss: 0.1968 - val_mse: 0.1038\n","Epoch 107/150\n"," 97/247 [==========>...................] - ETA: 1:22 - loss: 0.1105 - mse: 0.0255"],"name":"stdout"},{"output_type":"error","ename":"KeyboardInterrupt","evalue":"ignored","traceback":["\u001b[0;31m---------------------------------------------------------------------------\u001b[0m","\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)","\u001b[0;32m<ipython-input-66-a4372881b8b1>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m()\u001b[0m\n\u001b[1;32m     11\u001b[0m                                \u001b[0mvalidation_steps\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mval_percent\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mpower\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mlen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mval_idx\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m2\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m  \u001b[0;31m# None\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     12\u001b[0m                                \u001b[0mplot\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mTrue\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 13\u001b[0;31m                                gpus=None)\n\u001b[0m","\u001b[0;32m<ipython-input-64-987e1299a8f8>\u001b[0m in \u001b[0;36mtrain_siamese\u001b[0;34m(X, y, train_idx, val_idx, epochs, batch_size, learning_rate, limit_style, path_logs_training, training_description, training_steps, validation_steps, plot, gpus)\u001b[0m\n\u001b[1;32m    207\u001b[0m                             \u001b[0mepochs\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mepochs\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    208\u001b[0m                             \u001b[0mvalidation_data\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mvalidation_generator\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 209\u001b[0;31m                             callbacks=[plot_callback, logs_callback, backup_callback])\n\u001b[0m\u001b[1;32m    210\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    211\u001b[0m         \u001b[0;31m# Get training and test loss histories\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n","\u001b[0;32m/usr/local/lib/python3.7/dist-packages/tensorflow/python/keras/engine/training.py\u001b[0m in \u001b[0;36mfit\u001b[0;34m(self, x, y, batch_size, epochs, verbose, callbacks, validation_split, validation_data, shuffle, class_weight, sample_weight, initial_epoch, steps_per_epoch, validation_steps, validation_batch_size, validation_freq, max_queue_size, workers, use_multiprocessing)\u001b[0m\n\u001b[1;32m   1098\u001b[0m                 _r=1):\n\u001b[1;32m   1099\u001b[0m               \u001b[0mcallbacks\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mon_train_batch_begin\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mstep\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1100\u001b[0;31m               \u001b[0mtmp_logs\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtrain_function\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0miterator\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   1101\u001b[0m               \u001b[0;32mif\u001b[0m \u001b[0mdata_handler\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mshould_sync\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1102\u001b[0m                 \u001b[0mcontext\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0masync_wait\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n","\u001b[0;32m/usr/local/lib/python3.7/dist-packages/tensorflow/python/eager/def_function.py\u001b[0m in \u001b[0;36m__call__\u001b[0;34m(self, *args, **kwds)\u001b[0m\n\u001b[1;32m    826\u001b[0m     \u001b[0mtracing_count\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mexperimental_get_tracing_count\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    827\u001b[0m     \u001b[0;32mwith\u001b[0m \u001b[0mtrace\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mTrace\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_name\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0mtm\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 828\u001b[0;31m       \u001b[0mresult\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_call\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwds\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    829\u001b[0m       \u001b[0mcompiler\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m\"xla\"\u001b[0m \u001b[0;32mif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_experimental_compile\u001b[0m \u001b[0;32melse\u001b[0m \u001b[0;34m\"nonXla\"\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    830\u001b[0m       \u001b[0mnew_tracing_count\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mexperimental_get_tracing_count\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n","\u001b[0;32m/usr/local/lib/python3.7/dist-packages/tensorflow/python/eager/def_function.py\u001b[0m in \u001b[0;36m_call\u001b[0;34m(self, *args, **kwds)\u001b[0m\n\u001b[1;32m    853\u001b[0m       \u001b[0;31m# In this case we have created variables on the first call, so we run the\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    854\u001b[0m       \u001b[0;31m# defunned version which is guaranteed to never create variables.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 855\u001b[0;31m       \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_stateless_fn\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwds\u001b[0m\u001b[0;34m)\u001b[0m  \u001b[0;31m# pylint: disable=not-callable\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    856\u001b[0m     \u001b[0;32melif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_stateful_fn\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    857\u001b[0m       \u001b[0;31m# Release the lock early so that multiple threads can perform the call\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n","\u001b[0;32m/usr/local/lib/python3.7/dist-packages/tensorflow/python/eager/function.py\u001b[0m in \u001b[0;36m__call__\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m   2941\u001b[0m        filtered_flat_args) = self._maybe_define_function(args, kwargs)\n\u001b[1;32m   2942\u001b[0m     return graph_function._call_flat(\n\u001b[0;32m-> 2943\u001b[0;31m         filtered_flat_args, captured_inputs=graph_function.captured_inputs)  # pylint: disable=protected-access\n\u001b[0m\u001b[1;32m   2944\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   2945\u001b[0m   \u001b[0;34m@\u001b[0m\u001b[0mproperty\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n","\u001b[0;32m/usr/local/lib/python3.7/dist-packages/tensorflow/python/eager/function.py\u001b[0m in \u001b[0;36m_call_flat\u001b[0;34m(self, args, captured_inputs, cancellation_manager)\u001b[0m\n\u001b[1;32m   1917\u001b[0m       \u001b[0;31m# No tape is watching; skip to running the function.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1918\u001b[0m       return self._build_call_outputs(self._inference_function.call(\n\u001b[0;32m-> 1919\u001b[0;31m           ctx, args, cancellation_manager=cancellation_manager))\n\u001b[0m\u001b[1;32m   1920\u001b[0m     forward_backward = self._select_forward_and_backward_functions(\n\u001b[1;32m   1921\u001b[0m         \u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n","\u001b[0;32m/usr/local/lib/python3.7/dist-packages/tensorflow/python/eager/function.py\u001b[0m in \u001b[0;36mcall\u001b[0;34m(self, ctx, args, cancellation_manager)\u001b[0m\n\u001b[1;32m    558\u001b[0m               \u001b[0minputs\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    559\u001b[0m               \u001b[0mattrs\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mattrs\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 560\u001b[0;31m               ctx=ctx)\n\u001b[0m\u001b[1;32m    561\u001b[0m         \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    562\u001b[0m           outputs = execute.execute_with_cancellation(\n","\u001b[0;32m/usr/local/lib/python3.7/dist-packages/tensorflow/python/eager/execute.py\u001b[0m in \u001b[0;36mquick_execute\u001b[0;34m(op_name, num_outputs, inputs, attrs, ctx, name)\u001b[0m\n\u001b[1;32m     58\u001b[0m     \u001b[0mctx\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mensure_initialized\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     59\u001b[0m     tensors = pywrap_tfe.TFE_Py_Execute(ctx._handle, device_name, op_name,\n\u001b[0;32m---> 60\u001b[0;31m                                         inputs, attrs, num_outputs)\n\u001b[0m\u001b[1;32m     61\u001b[0m   \u001b[0;32mexcept\u001b[0m \u001b[0mcore\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_NotOkStatusException\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0me\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     62\u001b[0m     \u001b[0;32mif\u001b[0m \u001b[0mname\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n","\u001b[0;31mKeyboardInterrupt\u001b[0m: "]}]},{"cell_type":"code","metadata":{"id":"sZ4ydSfdMbLa","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615818317190,"user_tz":-60,"elapsed":894,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"94eebcbc-215d-49be-f16e-82042243f108"},"source":["from tensorflow.python.client import device_lib\r\n","device_lib.list_local_devices()"],"execution_count":67,"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: 5190501618644281940, name: \"/device:GPU:0\"\n"," device_type: \"GPU\"\n"," memory_limit: 11154422528\n"," locality {\n","   bus_id: 1\n","   links {\n","   }\n"," }\n"," incarnation: 8748409794886906791\n"," physical_device_desc: \"device: 0, name: Tesla K80, pci bus id: 0000:00:04.0, compute capability: 3.7\"]"]},"metadata":{"tags":[]},"execution_count":67}]},{"cell_type":"markdown","metadata":{"id":"fJJKUgcJK4La"},"source":["---"]},{"cell_type":"code","metadata":{"id":"gi9CsCZAK4Ld","executionInfo":{"status":"aborted","timestamp":1615818311552,"user_tz":-60,"elapsed":65,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"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","executionInfo":{"status":"aborted","timestamp":1615818311553,"user_tz":-60,"elapsed":62,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"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","executionInfo":{"status":"aborted","timestamp":1615818311553,"user_tz":-60,"elapsed":57,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["# training_loss[-1], val_loss[-1], mses[-1], val_mses[-1]"],"execution_count":null,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"M-kSlYfqK4Lt"},"source":["### (Or) Read model checkpoint"]},{"cell_type":"code","metadata":{"id":"9z7haF6NK4Lu","executionInfo":{"status":"ok","timestamp":1615818321142,"user_tz":-60,"elapsed":797,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["# put correct filename\n","model_filename = f\"{path_logs_training}/training/{training_description}.h5\""],"execution_count":68,"outputs":[]},{"cell_type":"code","metadata":{"id":"9BeTrg3xSLft","executionInfo":{"status":"ok","timestamp":1615818447405,"user_tz":-60,"elapsed":1045,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"6eff9347-dcb6-42d7-d6f5-209d1771f1c7","colab":{"base_uri":"https://localhost:8080/","height":35}},"source":["model_filename"],"execution_count":84,"outputs":[{"output_type":"execute_result","data":{"application/vnd.google.colaboratory.intrinsic+json":{"type":"string"},"text/plain":["'/content/drive/My Drive/ModelsProtein/training/5a1a_quartercvg_uniformS2_noise16.h5'"]},"metadata":{"tags":[]},"execution_count":84}]},{"cell_type":"code","metadata":{"id":"Dr9eFsJKK4Lw","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615818328210,"user_tz":-60,"elapsed":4153,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"270df6b0-7fa5-4e53-aedf-e3ed7add636e"},"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":69,"outputs":[{"output_type":"stream","text":["Model: \"model_3\"\n","__________________________________________________________________________________________________\n","Layer (type)                    Output Shape         Param #     Connected to                     \n","==================================================================================================\n","input_4 (InputLayer)            [(None, 116, 116, 1) 0                                            \n","__________________________________________________________________________________________________\n","input_5 (InputLayer)            [(None, 116, 116, 1) 0                                            \n","__________________________________________________________________________________________________\n","model_2 (Functional)            (None, 512)          4551936     input_4[0][0]                    \n","                                                                 input_5[0][0]                    \n","__________________________________________________________________________________________________\n","lambda_1 (Lambda)               (None, 1)            0           model_2[0][0]                    \n","                                                                 model_2[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","executionInfo":{"status":"ok","timestamp":1615818328211,"user_tz":-60,"elapsed":2705,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["# plot_model(model, to_file=f\"{path_logs_training}/model_plot_256d.png\", expand_nested=True, show_shapes=True, show_layer_names=True)\r\n"],"execution_count":70,"outputs":[]},{"cell_type":"code","metadata":{"id":"6-eOzKnG-Hdo","executionInfo":{"status":"ok","timestamp":1615818328212,"user_tz":-60,"elapsed":840,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["model.save_weights(f\"{path_logs_training}/training/{training_description}_weights.h5\")"],"execution_count":71,"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","executionInfo":{"status":"ok","timestamp":1615818407268,"user_tz":-60,"elapsed":923,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["from cryoem.conversions import d_q, euler2quaternion\n","from cryoem.plots import plot_dP_dQ"],"execution_count":79,"outputs":[]},{"cell_type":"code","metadata":{"id":"RJMjW2KHK4L5","executionInfo":{"status":"ok","timestamp":1615818407269,"user_tz":-60,"elapsed":625,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"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":80,"outputs":[]},{"cell_type":"code","metadata":{"id":"0YTh5UvmK4L7","executionInfo":{"status":"ok","timestamp":1615818442720,"user_tz":-60,"elapsed":35821,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"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":81,"outputs":[]},{"cell_type":"code","metadata":{"id":"OqwZcuEFBMJp","executionInfo":{"status":"ok","timestamp":1615818442721,"user_tz":-60,"elapsed":35081,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["np.savez(os.path.join(path_logs_training, f\"dPdQ_data_{training_description}\"), dP_values, dQ_values)"],"execution_count":82,"outputs":[]},{"cell_type":"code","metadata":{"id":"NjmjpoN0K4L9","colab":{"base_uri":"https://localhost:8080/","height":882},"executionInfo":{"status":"ok","timestamp":1615818445215,"user_tz":-60,"elapsed":37115,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"9aeb17ba-a01d-4f0e-c2f7-0c1fce7f5a37"},"source":["plot_dP_dQ(dP_values, dQ_values)"],"execution_count":83,"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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tHXrVu6//35OO+20RY979rOf3TOeMzMz3HnnnTzrWc9acEwul+MZz3gGN9xwQ++xyclJZmZmOOaYY1BVlR//+Me95+Z/79lstvflXOx1f/zjH9PpdEiShJtvvpnnPOc5S/ZeW60WuVyOUqmE7/u9YwSCJwtJkvDJT36y9zc4PDzcc786jsPKlSsP5fJ6LItIdLtdJicnez/fcccdFItFSqXSguPOOussvv3tbxPHMbVajdtuu60X5FxO8lmNwfLCIOxg2SKfXTqRiKKIc845h3e84x184hOf6MUj9uTDH/4wGzdu5Oyzz+bCCy/k8ssv57jjjus9P3+H/ZnPfIbNmzdz9tlnc/bZZ/Pe976XVquFqqp8+ctf5qabbuLss8/m5S9/OXfeeScAr3vd6/jSl77EK17xCn7+858veN0XvOAFnH322Zx33nmcffbZAFx88cVL9l6f//zns2rVKl7ykpdwwQUXcOKJJx7QtQWCI5E4jvnIRz7CV7/6VSCdh5PP54njGNu28X3/gP/elpxkGZiZmUle85rXJH/xF3+RvPzlL0/e+MY3Jhs2bEiSJEkuuuii5L//+7+TJEmSMAyTv/7rv07OPPPM5Mwzz0xuuummx/0a4+Pjyfr165Px8fFHPXf//ffv95rjOE6abS+ZmuskzbaXxHG839fYG+vXr086nc4TukYQBMnTn/70ZHp6eolWdXBYivf6WBzI5ysQHCqiKEre//73JytWrEhWrFiRvPe9701++tOfJueee25yxhlnJOeee25y++237/X8pbZN+7KdSZIkyxKT6O/v36u/efe4hKIofPzjH1+OJT0mkiRRyOnLEoPYX2ZnZzn//PN5+ctfvtdpUgKB4PAjiiIuu+wyvv3tbwPwxje+kWuuuQZZlnnxi1/8mOcny5B5uSeiKukQsGnTpid0fn9/Pz/96U+XaDUHlyf6XgWCo4UwDLn00kt79WFvfetb+fjHP75fxn05Mi/3RIiEQCAQHGSCIOBd73oXP/zhDwF45zvfyZVXXrnfBbuHIvPySSMSSZKINMqjkDiOD/USBIJ94nke73znO/nJT34CwHve8x4uv/xytk+199tttByZl3vypGjwZ5omc3NzJElyqJciWCKSJMH3fXbs2EE2mz3UyxEIFsVxHC666KKeQFx++eV84AMfoGOHi7qN2t3FdwrzLEfm5Z48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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.2706384212827074\n","Min. angle recovery loss possible = 0.07317190991932178\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"lA75WQYrK4L_","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1615818367907,"user_tz":-60,"elapsed":33824,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}},"outputId":"10c57e57-469e-4d7b-8c3a-09bcc5c31019"},"source":["MAE(dQ_values, dP_values)"],"execution_count":77,"outputs":[{"output_type":"execute_result","data":{"text/plain":["<tf.Tensor: shape=(), dtype=float32, numpy=0.17588636>"]},"metadata":{"tags":[]},"execution_count":77}]},{"cell_type":"code","metadata":{"id":"rGC2BjfxVYqF","executionInfo":{"status":"ok","timestamp":1615818367909,"user_tz":-60,"elapsed":31590,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":["model.save_weights(f\"{path_logs_training}/training/{training_description}_weights.h5\")"],"execution_count":78,"outputs":[]},{"cell_type":"code","metadata":{"id":"zkQn2kkjZb6U","executionInfo":{"status":"aborted","timestamp":1615818311558,"user_tz":-60,"elapsed":15,"user":{"displayName":"","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14Gi7QhNkRF916hxK9g21jI-G0gEPMgU_Y__ksZcr=s64","userId":"13001887981754116628"}}},"source":[""],"execution_count":null,"outputs":[]}]}