{"nbformat":4,"nbformat_minor":0,"metadata":{"accelerator":"GPU","colab":{"name":"5j0n_fullcvg_uniformS2_noise0_DE","provenance":[{"file_id":"https://github.com/anonymous/protein-reconstruction/blob/master/notebooks/2-phase2/colab_distance_estimation_5a1a.ipynb","timestamp":1592746023862}],"collapsed_sections":[],"toc_visible":true},"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"}},"cells":[{"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","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1614365652062,"user_tz":-60,"elapsed":695,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"f3f5e18d-9b5d-4173-ce68-e3bcadb54652"},"source":["# create directories\n","!mkdir --parents data/5a1a\n","!mkdir training"],"execution_count":3,"outputs":[{"output_type":"stream","text":["mkdir: cannot create directory ‘training’: File exists\n"],"name":"stdout"}]},{"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":1614365667386,"user_tz":-60,"elapsed":16007,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"39ac5289-22f0-4455-f57a-c4ab63347b2d"},"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":4,"outputs":[{"output_type":"stream","text":["--2021-02-26 18:54:11--  https://repo.anaconda.com/miniconda/Miniconda3-latest-Linux-x86_64.sh\n","Resolving repo.anaconda.com (repo.anaconda.com)... 104.16.130.3, 104.16.131.3, 2606:4700::6810:8203, ...\n","Connecting to repo.anaconda.com (repo.anaconda.com)|104.16.130.3|:443... connected.\n","HTTP request sent, awaiting response... 416 Requested Range Not Satisfiable\n","\n","    The file is already fully retrieved; nothing to do.\n","\n","PREFIX=/usr/local\n","Unpacking payload ...\n","Collecting package metadata (current_repodata.json): - \b\b\\ \b\bdone\n","Solving environment: / \b\b- \b\b\\ \b\bdone\n","\n","# All requested packages already installed.\n","\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":1614365694064,"user_tz":-60,"elapsed":42677,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"cdabf52f-deaa-417b-8754-2ac8bdbdebbe"},"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":5,"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":1614365727081,"user_tz":-60,"elapsed":33751,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"06f41b87-beb1-4589-8f97-cf03f7496338"},"source":["# clone repo\n","!rm -r protein-reconstruction\n","!git clone https://github.com/anonymous/protein-reconstruction.git\n","!cd protein-reconstruction"],"execution_count":6,"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 | 35.54 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":1614365837817,"user_tz":-60,"elapsed":143570,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"5c1292f0-4e1e-4ccf-db20-3293dacf893f"},"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":7,"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.22             |     pyhd8ed1ab_0         1.0 MB  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.2.0         |     pyhd8ed1ab_0         681 KB  conda-forge\n","    decorator-4.4.2            |             py_0          11 KB  conda-forge\n","    defusedxml-0.6.0           |             py_0          22 KB  conda-forge\n","    entrypoints-0.3            |  pyhd8ed1ab_1003           8 KB  conda-forge\n","    freetype-2.10.4            |       h7ca028e_0         912 KB  conda-forge\n","    icu-67.1                   |       he1b5a44_0        12.9 MB  conda-forge\n","    imageio-2.9.0              |             py_0         3.1 MB  conda-forge\n","    importlib-metadata-3.7.0   |   py38h578d9bd_0          24 KB  conda-forge\n","    importlib_metadata-3.7.0   |       hd8ed1ab_0           3 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.20.0             |   py38h81c977d_2         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           |             py_2          45 KB  conda-forge\n","    jupyter_client-6.1.11      |     pyhd8ed1ab_1          76 KB  conda-forge\n","    jupyter_core-4.7.1         |   py38h578d9bd_0          72 KB  conda-forge\n","    jupyterlab_pygments-0.1.2  |     pyh9f0ad1d_0           8 KB  conda-forge\n","    jupyterlab_widgets-1.0.0   |     pyhd8ed1ab_1         130 KB  conda-forge\n","    kiwisolver-1.3.1           |   py38h82cb98a_0          86 KB  conda-forge\n","    libblas-3.9.0              |       8_openblas          11 KB  conda-forge\n","    libcblas-3.9.0             |       8_openblas          11 KB  conda-forge\n","    libgfortran-ng-7.5.0       |      h14aa051_18          22 KB  conda-forge\n","    libgfortran4-7.5.0         |      h14aa051_18         1.3 MB  conda-forge\n","    liblapack-3.9.0            |       8_openblas          11 KB  conda-forge\n","    libopenblas-0.3.12         |pthreads_hb3c22a3_1         8.2 MB  conda-forge\n","    libpng-1.6.37              |       h21135ba_2         306 KB  conda-forge\n","    libsodium-1.0.18           |       h36c2ea0_1         366 KB  conda-forge\n","    libtiff-4.0.10             |    hc3755c2_1005         602 KB  conda-forge\n","    lz4-c-1.9.2                |       he1b5a44_3         203 KB  conda-forge\n","    markupsafe-1.1.1           |   py38h8df0ef7_2          27 KB  conda-forge\n","    matplotlib-base-3.2.2      |   py38h5d868c9_1         7.1 MB  conda-forge\n","    mistune-0.8.4              |py38h25fe258_1002          54 KB  conda-forge\n","    nbclient-0.5.3             |     pyhd8ed1ab_0          67 KB  conda-forge\n","    nbconvert-6.0.7            |   py38h578d9bd_3         546 KB  conda-forge\n","    nbformat-5.1.2             |     pyhd8ed1ab_1          66 KB  conda-forge\n","    nest-asyncio-1.4.3         |     pyhd8ed1ab_0           9 KB  conda-forge\n","    networkx-2.5               |             py_0         1.2 MB  conda-forge\n","    notebook-6.2.0             |   py38h578d9bd_0         6.3 MB  conda-forge\n","    numpy-1.18.1               |   py38h8854b6b_1         5.3 MB  conda-forge\n","    olefile-0.46               |     pyh9f0ad1d_1          32 KB  conda-forge\n","    openssl-1.1.1j             |       h27cfd23_0         2.5 MB\n","    packaging-20.9             |     pyh44b312d_0          35 KB  conda-forge\n","    pandas-1.1.4               |   py38h0ef3d22_0        10.9 MB  conda-forge\n","    pandoc-2.11.4              |       h7f98852_0        17.9 MB  conda-forge\n","    pandocfilters-1.4.2        |             py_1           9 KB  conda-forge\n","    parso-0.8.1                |     pyhd8ed1ab_0          67 KB  conda-forge\n","    pexpect-4.8.0              |     pyh9f0ad1d_2          47 KB  conda-forge\n","    pickleshare-0.7.5          |          py_1003           9 KB  conda-forge\n","    pillow-6.2.1               |   py38h6b7be26_0         637 KB  conda-forge\n","    prometheus_client-0.9.0    |     pyhd3deb0d_0          44 KB  conda-forge\n","    prompt-toolkit-3.0.16      |     pyha770c72_0         244 KB  conda-forge\n","    ptyprocess-0.7.0           |     pyhd3deb0d_0          16 KB  conda-forge\n","    pygments-2.8.0             |     pyhd8ed1ab_0         736 KB  conda-forge\n","    pyparsing-2.4.7            |     pyh9f0ad1d_0          60 KB  conda-forge\n","    pyrsistent-0.17.3          |   py38h25fe258_1          89 KB  conda-forge\n","    python-dateutil-2.8.1      |             py_0         220 KB  conda-forge\n","    python_abi-3.8             |           1_cp38           4 KB  conda-forge\n","    pythreejs-2.2.1            |     pyh9f0ad1d_0         2.7 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.0                 |             py_0          11 KB  conda-forge\n","    zstd-1.4.5                 |       h9ceee32_0         619 KB\n","    ------------------------------------------------------------\n","                                           Total:       152.5 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.22-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.2.0-pyhd8ed1ab_0\n","  decorator          conda-forge/noarch::decorator-4.4.2-py_0\n","  defusedxml         conda-forge/noarch::defusedxml-0.6.0-py_0\n","  entrypoints        conda-forge/noarch::entrypoints-0.3-pyhd8ed1ab_1003\n","  freetype           conda-forge/linux-64::freetype-2.10.4-h7ca028e_0\n","  icu                conda-forge/linux-64::icu-67.1-he1b5a44_0\n","  imageio            conda-forge/noarch::imageio-2.9.0-py_0\n","  importlib-metadata conda-forge/linux-64::importlib-metadata-3.7.0-py38h578d9bd_0\n","  importlib_metadata conda-forge/noarch::importlib_metadata-3.7.0-hd8ed1ab_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.20.0-py38h81c977d_2\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-py_2\n","  jupyter_client     conda-forge/noarch::jupyter_client-6.1.11-pyhd8ed1ab_1\n","  jupyter_core       conda-forge/linux-64::jupyter_core-4.7.1-py38h578d9bd_0\n","  jupyterlab_pygmen~ conda-forge/noarch::jupyterlab_pygments-0.1.2-pyh9f0ad1d_0\n","  jupyterlab_widgets conda-forge/noarch::jupyterlab_widgets-1.0.0-pyhd8ed1ab_1\n","  kiwisolver         conda-forge/linux-64::kiwisolver-1.3.1-py38h82cb98a_0\n","  libblas            conda-forge/linux-64::libblas-3.9.0-8_openblas\n","  libcblas           conda-forge/linux-64::libcblas-3.9.0-8_openblas\n","  libgfortran-ng     conda-forge/linux-64::libgfortran-ng-7.5.0-h14aa051_18\n","  libgfortran4       conda-forge/linux-64::libgfortran4-7.5.0-h14aa051_18\n","  liblapack          conda-forge/linux-64::liblapack-3.9.0-8_openblas\n","  libopenblas        conda-forge/linux-64::libopenblas-0.3.12-pthreads_hb3c22a3_1\n","  libpng             conda-forge/linux-64::libpng-1.6.37-h21135ba_2\n","  libsodium          conda-forge/linux-64::libsodium-1.0.18-h36c2ea0_1\n","  libtiff            conda-forge/linux-64::libtiff-4.0.10-hc3755c2_1005\n","  lz4-c              conda-forge/linux-64::lz4-c-1.9.2-he1b5a44_3\n","  markupsafe         conda-forge/linux-64::markupsafe-1.1.1-py38h8df0ef7_2\n","  matplotlib-base    conda-forge/linux-64::matplotlib-base-3.2.2-py38h5d868c9_1\n","  mistune            conda-forge/linux-64::mistune-0.8.4-py38h25fe258_1002\n","  nbclient           conda-forge/noarch::nbclient-0.5.3-pyhd8ed1ab_0\n","  nbconvert          conda-forge/linux-64::nbconvert-6.0.7-py38h578d9bd_3\n","  nbformat           conda-forge/noarch::nbformat-5.1.2-pyhd8ed1ab_1\n","  nest-asyncio       conda-forge/noarch::nest-asyncio-1.4.3-pyhd8ed1ab_0\n","  networkx           conda-forge/noarch::networkx-2.5-py_0\n","  notebook           conda-forge/linux-64::notebook-6.2.0-py38h578d9bd_0\n","  numpy              conda-forge/linux-64::numpy-1.18.1-py38h8854b6b_1\n","  olefile            conda-forge/noarch::olefile-0.46-pyh9f0ad1d_1\n","  packaging          conda-forge/noarch::packaging-20.9-pyh44b312d_0\n","  pandas             conda-forge/linux-64::pandas-1.1.4-py38h0ef3d22_0\n","  pandoc             conda-forge/linux-64::pandoc-2.11.4-h7f98852_0\n","  pandocfilters      conda-forge/noarch::pandocfilters-1.4.2-py_1\n","  parso              conda-forge/noarch::parso-0.8.1-pyhd8ed1ab_0\n","  pexpect            conda-forge/noarch::pexpect-4.8.0-pyh9f0ad1d_2\n","  pickleshare        conda-forge/noarch::pickleshare-0.7.5-py_1003\n","  pillow             conda-forge/linux-64::pillow-6.2.1-py38h6b7be26_0\n","  prometheus_client  conda-forge/noarch::prometheus_client-0.9.0-pyhd3deb0d_0\n","  prompt-toolkit     conda-forge/noarch::prompt-toolkit-3.0.16-pyha770c72_0\n","  ptyprocess         conda-forge/noarch::ptyprocess-0.7.0-pyhd3deb0d_0\n","  pygments           conda-forge/noarch::pygments-2.8.0-pyhd8ed1ab_0\n","  pyparsing          conda-forge/noarch::pyparsing-2.4.7-pyh9f0ad1d_0\n","  pyrsistent         conda-forge/linux-64::pyrsistent-0.17.3-py38h25fe258_1\n","  python-dateutil    conda-forge/noarch::python-dateutil-2.8.1-py_0\n","  python_abi         conda-forge/linux-64::python_abi-3.8-1_cp38\n","  pythreejs          conda-forge/noarch::pythreejs-2.2.1-pyh9f0ad1d_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.0-py_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.3 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 20 kB/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","Collecting absl-py>=0.6.1\n","  Downloading absl_py-0.11.0-py3-none-any.whl (127 kB)\n","\u001b[K     |████████████████████████████████| 127 kB 75.0 MB/s \n","\u001b[?25hRequirement already satisfied: six>=1.11.0 in /usr/local/lib/python3.8/site-packages (from tensorflow-graphics-gpu) (1.15.0)\n","Requirement already satisfied: scipy>=1.1.0 in /usr/local/lib/python3.8/site-packages (from tensorflow-graphics-gpu) (1.5.3)\n","Collecting tensorflow-estimator<2.5.0,>=2.4.0\n","  Downloading tensorflow_estimator-2.4.0-py2.py3-none-any.whl (462 kB)\n","\u001b[K     |████████████████████████████████| 462 kB 59.2 MB/s \n","\u001b[?25hCollecting keras-preprocessing~=1.1.2\n","  Downloading Keras_Preprocessing-1.1.2-py2.py3-none-any.whl (42 kB)\n","\u001b[K     |████████████████████████████████| 42 kB 1.1 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 4.5 MB/s \n","\u001b[?25hRequirement already satisfied: wheel~=0.35 in /usr/local/lib/python3.8/site-packages (from tensorflow-gpu>=1.13.1->tensorflow-graphics-gpu) (0.35.1)\n","Collecting wrapt~=1.12.1\n","  Downloading wrapt-1.12.1.tar.gz (27 kB)\n","Collecting grpcio~=1.32.0\n","  Downloading grpcio-1.32.0-cp38-cp38-manylinux2014_x86_64.whl (3.8 MB)\n","\u001b[K     |████████████████████████████████| 3.8 MB 55.1 MB/s \n","\u001b[?25hCollecting opt-einsum~=3.3.0\n","  Downloading opt_einsum-3.3.0-py3-none-any.whl (65 kB)\n","\u001b[K     |████████████████████████████████| 65 kB 4.3 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 termcolor~=1.1.0\n","  Downloading termcolor-1.1.0.tar.gz (3.9 kB)\n","Collecting gast==0.3.3\n","  Downloading gast-0.3.3-py2.py3-none-any.whl (9.7 kB)\n","Collecting h5py~=2.10.0\n","  Downloading h5py-2.10.0-cp38-cp38-manylinux1_x86_64.whl (2.9 MB)\n","\u001b[K     |████████████████████████████████| 2.9 MB 51.9 MB/s \n","\u001b[?25hCollecting 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.3-cp38-cp38-manylinux1_x86_64.whl (1.0 MB)\n","\u001b[K     |████████████████████████████████| 1.0 MB 57.1 MB/s \n","\u001b[?25hCollecting astunparse~=1.6.3\n","  Downloading astunparse-1.6.3-py2.py3-none-any.whl (12 kB)\n","Collecting tensorboard~=2.4\n","  Downloading tensorboard-2.4.1-py3-none-any.whl (10.6 MB)\n","\u001b[K     |████████████████████████████████| 10.6 MB 49.5 MB/s \n","\u001b[?25hCollecting google-auth<2,>=1.6.3\n","  Downloading google_auth-1.27.0-py2.py3-none-any.whl (135 kB)\n","\u001b[K     |████████████████████████████████| 135 kB 78.6 MB/s \n","\u001b[?25hRequirement already satisfied: setuptools>=41.0.0 in /usr/local/lib/python3.8/site-packages (from tensorboard~=2.4->tensorflow-gpu>=1.13.1->tensorflow-graphics-gpu) (50.3.1.post20201107)\n","Collecting tensorboard-plugin-wit>=1.6.0\n","  Downloading tensorboard_plugin_wit-1.8.0-py3-none-any.whl (781 kB)\n","\u001b[K     |████████████████████████████████| 781 kB 72.6 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 68.8 MB/s \n","\u001b[?25hRequirement already satisfied: requests<3,>=2.21.0 in /usr/local/lib/python3.8/site-packages (from tensorboard~=2.4->tensorflow-gpu>=1.13.1->tensorflow-graphics-gpu) (2.24.0)\n","Collecting markdown>=2.6.8\n","  Downloading Markdown-3.3.4-py3-none-any.whl (97 kB)\n","\u001b[K     |████████████████████████████████| 97 kB 6.6 MB/s \n","\u001b[?25hCollecting google-auth-oauthlib<0.5,>=0.4.1\n","  Downloading google_auth_oauthlib-0.4.2-py2.py3-none-any.whl (18 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 67.9 MB/s \n","\u001b[?25hCollecting cachetools<5.0,>=2.0.0\n","  Downloading cachetools-4.2.1-py3-none-any.whl (12 kB)\n","Collecting 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: 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: urllib3!=1.25.0,!=1.25.1,<1.26,>=1.21.1 in /usr/local/lib/python3.8/site-packages (from requests<3,>=2.21.0->tensorboard~=2.4->tensorflow-gpu>=1.13.1->tensorflow-graphics-gpu) (1.25.11)\n","Requirement already satisfied: 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: 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","Collecting requests-oauthlib>=0.7.0\n","  Downloading requests_oauthlib-1.3.0-py2.py3-none-any.whl (23 kB)\n","Collecting pyasn1<0.5.0,>=0.4.6\n","  Downloading pyasn1-0.4.8-py2.py3-none-any.whl (77 kB)\n","\u001b[K     |████████████████████████████████| 77 kB 6.3 MB/s \n","\u001b[?25hCollecting oauthlib>=3.0.0\n","  Downloading oauthlib-3.1.0-py2.py3-none-any.whl (147 kB)\n","\u001b[K     |████████████████████████████████| 147 kB 70.7 MB/s \n","\u001b[?25hBuilding wheels for collected packages: wrapt, termcolor\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=78015 sha256=d1ee261e3791e2ed17915c71a77138f6ef1f7919b3e7d37d811329ea92f2bfac\n","  Stored in directory: /root/.cache/pip/wheels/5f/fd/9e/b6cf5890494cb8ef0b5eaff72e5d55a70fb56316007d6dfe73\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=7ccb75d4ed9a8a0e9264434504bd38ffc4f930e2b950a3c1bdf7399a90a09914\n","  Stored in directory: /root/.cache/pip/wheels/a0/16/9c/5473df82468f958445479c59e784896fa24f4a5fc024b0f501\n","Successfully built wrapt termcolor\n","Installing collected packages: tensorflow-estimator, keras-preprocessing, google-pasta, wrapt, grpcio, opt-einsum, absl-py, typing-extensions, termcolor, gast, h5py, flatbuffers, protobuf, astunparse, pyasn1, pyasn1-modules, cachetools, rsa, google-auth, tensorboard-plugin-wit, werkzeug, markdown, oauthlib, requests-oauthlib, google-auth-oauthlib, 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.11.0 astunparse-1.6.3 cachetools-4.2.1 flatbuffers-1.12 gast-0.3.3 google-auth-1.27.0 google-auth-oauthlib-0.4.2 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.3 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":1614365837818,"user_tz":-60,"elapsed":142799,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["import sys\n","sys.path.append('/usr/local/lib/python3.8/site-packages')\n","sys.path.append(\"protein-reconstruction\") "],"execution_count":8,"outputs":[]},{"cell_type":"code","metadata":{"id":"Zro6bM3VK4KR","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1614365838006,"user_tz":-60,"elapsed":133274,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"69a78e07-853f-46e0-f841-86a600752b41"},"source":["!python --version"],"execution_count":9,"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":1614365861714,"user_tz":-60,"elapsed":155715,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"ebc6e41c-4d12-4544-f1a1-faca761eef1b"},"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":10,"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":1614365861718,"user_tz":-60,"elapsed":155083,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"21a0bf14-3a07-4af9-952a-81199ae905ff"},"source":["tf.__version__"],"execution_count":11,"outputs":[{"output_type":"execute_result","data":{"application/vnd.google.colaboratory.intrinsic+json":{"type":"string"},"text/plain":["'2.4.1'"]},"metadata":{"tags":[]},"execution_count":11}]},{"cell_type":"code","metadata":{"id":"ShUD7yqTK4Kb","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1614365861719,"user_tz":-60,"elapsed":154133,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"d489987a-829e-47fe-cff2-fa2be44df68e"},"source":["from tensorflow.python.client import device_lib \n","print(device_lib.list_local_devices())"],"execution_count":12,"outputs":[{"output_type":"stream","text":["[name: \"/device:CPU:0\"\n","device_type: \"CPU\"\n","memory_limit: 268435456\n","locality {\n","}\n","incarnation: 8407547113348774867\n","]\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"kZFVlYW4K4Ke","executionInfo":{"status":"ok","timestamp":1614365861720,"user_tz":-60,"elapsed":148928,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["PROTEIN=\"5j0n\"\n","NUM_PROJECTIONS = 5000\n","\n","NOISY_VAR = 0 # vary from 1 to 10\n","path_logs_training = \"/content/drive/My Drive/ModelsProtein\"\n","training_description = f\"5j0n_fullcvg_uniformS2_noisy{NOISY_VAR}\""],"execution_count":13,"outputs":[]},{"cell_type":"code","metadata":{"id":"-q8GWm2EK4Kh","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1614365861923,"user_tz":-60,"elapsed":82902,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"c97e4355-2590-48f9-bd49-16973cde1de9"},"source":["# TODO: dataset name\n","projections_filename = f\"5j0n_uniform_ProjectionsAngles_ProjNber5000_AngCoverage2.0,1.0,2.0_AngShift0.0,0.0,0.0.h5\"\n","\n","# load structures\n","data = h5py.File(os.path.join(path_logs_training, projections_filename), 'r')\n","\n","print(f\"{data['Projections'].shape[0]} projections of images with dimension {data['Projections'].shape[1:]} pixels\")\n","print(f\"{data['Angles'].shape[0]} sets of {data['Angles'].shape[1]} ground truth angles of corresponding projection images\")"],"execution_count":14,"outputs":[{"output_type":"stream","text":["5000 projections of images with dimension (116, 116) pixels\n","5000 sets of 3 ground truth angles of corresponding projection images\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"2zARA9L2K4Kj","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1614365862110,"user_tz":-60,"elapsed":82404,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"e5c04592-7b1c-4b4f-a4d6-b2ff87ad1907"},"source":["projections = data['Projections']\n","projections.shape"],"execution_count":15,"outputs":[{"output_type":"execute_result","data":{"text/plain":["(5000, 116, 116)"]},"metadata":{"tags":[]},"execution_count":15}]},{"cell_type":"code","metadata":{"id":"bIQzyIQnxgts","colab":{"base_uri":"https://localhost:8080/","height":271},"executionInfo":{"status":"ok","timestamp":1614365862494,"user_tz":-60,"elapsed":82386,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"3c6c06f4-c0ac-44de-e842-428ec4dc9452"},"source":["sampleProj = projections[1,:,:]\n","plt.imshow(sampleProj,cmap='gray')\n","plt.show()"],"execution_count":16,"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":1614365862690,"user_tz":-60,"elapsed":81996,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["def addGaussianNoise(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":17,"outputs":[]},{"cell_type":"code","metadata":{"id":"oCD6IwpOr3_A","executionInfo":{"status":"ok","timestamp":1614365870856,"user_tz":-60,"elapsed":89597,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["# Add zero-mean Gaussian noise on the projections \n","projections = addGaussianNoise(projections, NOISY_VAR)"],"execution_count":18,"outputs":[]},{"cell_type":"code","metadata":{"id":"qR8J0QCmxG-y","colab":{"base_uri":"https://localhost:8080/","height":271},"executionInfo":{"status":"ok","timestamp":1614365871091,"user_tz":-60,"elapsed":89187,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"5ae7a89e-0357-461f-e8ec-08555be6e002"},"source":["# Display projections with/out noise (for comparison)\n","sampleProj = projections[1,:,:]\n","plt.imshow(sampleProj,cmap='gray')\n","plt.show()"],"execution_count":19,"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":"X_voGDMSK4Kn","scrolled":true,"colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1614365871093,"user_tz":-60,"elapsed":88399,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"f9374adb-20c1-4235-be07-be280d46213b"},"source":["angles_true = np.array(data['Angles'])\n","angles_true.shape"],"execution_count":20,"outputs":[{"output_type":"execute_result","data":{"text/plain":["(5000, 3)"]},"metadata":{"tags":[]},"execution_count":20}]},{"cell_type":"code","metadata":{"id":"SXcS0FO4jqDl","executionInfo":{"status":"ok","timestamp":1614365871094,"user_tz":-60,"elapsed":81938,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["from skimage.transform import resize\n","\n","def rescale_image(image):\n","    c = image.shape[-1]/117\n","    image_resized = resize(image, (image.shape[0] // c, image.shape[1] // c), anti_aliasing=True)\n","    return image_resized"],"execution_count":21,"outputs":[]},{"cell_type":"code","metadata":{"id":"urRechgFjm2o","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1614365880713,"user_tz":-60,"elapsed":89536,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"2109f491-9276-470d-8228-bdfe1942ec0c"},"source":["projections_new = []\n","for p in projections:\n","    projections_new.append(rescale_image(p))\n","projections_new = np.array(projections_new)\n","projections_new.shape"],"execution_count":22,"outputs":[{"output_type":"execute_result","data":{"text/plain":["(5000, 116, 116)"]},"metadata":{"tags":[]},"execution_count":22}]},{"cell_type":"code","metadata":{"id":"WJvZ8_XPK4Kp","executionInfo":{"status":"ok","timestamp":1614365880714,"user_tz":-60,"elapsed":88518,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["#plot_images(angles_true, projections, range(100), img_size_scale=0.05)"],"execution_count":23,"outputs":[]},{"cell_type":"code","metadata":{"id":"Z-CMl6nMK4Ks","executionInfo":{"status":"ok","timestamp":1614365880714,"user_tz":-60,"elapsed":87999,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["#ipv.screenshot()"],"execution_count":24,"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":1614365880925,"user_tz":-60,"elapsed":86269,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["from sklearn.model_selection import train_test_split"],"execution_count":25,"outputs":[]},{"cell_type":"code","metadata":{"id":"O_lxJ3huK4K0","executionInfo":{"status":"ok","timestamp":1614365880927,"user_tz":-60,"elapsed":71940,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["X, y = np.array(projections_new, dtype=np.float32), np.array(angles_true, dtype=np.float32)"],"execution_count":26,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"4f-dUZ4kK4K3"},"source":["#### Global standardization of projections"]},{"cell_type":"code","metadata":{"id":"X6A3wHMVK4K3","executionInfo":{"status":"ok","timestamp":1614365881194,"user_tz":-60,"elapsed":16218,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["from cryoem.preprocessing import global_standardization"],"execution_count":27,"outputs":[]},{"cell_type":"code","metadata":{"id":"3pRAKWKmK4K6","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1614365881965,"user_tz":-60,"elapsed":16555,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"3f22e4e5-c1a1-4328-c74e-281df391267e"},"source":["X = global_standardization(X)"],"execution_count":28,"outputs":[{"output_type":"stream","text":["Global standardization\n","\tImage shape: (116, 116)\n","\tData Type: float32\n","\tMean: 0.262 | Std: 1.020\n","\tMin:  0.000 | Max: 15.280\n","\tMean: 0.000 | Std: 1.000\n","\tMin:  -0.257 | Max: 14.719\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"lVRXjdE3K4K9","executionInfo":{"status":"ok","timestamp":1614365881966,"user_tz":-60,"elapsed":15949,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["test_size = 0.33\n","val_size = 0.25"],"execution_count":29,"outputs":[]},{"cell_type":"code","metadata":{"id":"fRyiZcWPK4LC","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1614365881966,"user_tz":-60,"elapsed":15274,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"dc0852c2-b061-4417-8f9e-f0a4f74bbcea"},"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":30,"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":1614365888865,"user_tz":-60,"elapsed":807,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["data = np.load(f\"{path_logs_training}/5j0n_siamese_idx.npz\")\n","train_idx, val_idx, test_idx = data[\"arr_0\"], data[\"arr_1\"], data[\"arr_2\"]"],"execution_count":31,"outputs":[]},{"cell_type":"code","metadata":{"id":"KNkQKrfJK4LH","executionInfo":{"status":"ok","timestamp":1614365888866,"user_tz":-60,"elapsed":320,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["channels = \"gray\"\n","if channels == \"rgb\":\n","    X = np.stack((X,)*3, axis=-1)\n","elif channels == \"gray\":\n","    X = X[:,:,:,np.newaxis]"],"execution_count":32,"outputs":[]},{"cell_type":"code","metadata":{"id":"WCOYGoQRK4LK","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1614365889725,"user_tz":-60,"elapsed":543,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"8ae0bf9a-5ef2-4b12-dfe2-5bad5e7a81b4"},"source":["X.shape"],"execution_count":33,"outputs":[{"output_type":"execute_result","data":{"text/plain":["(5000, 116, 116, 1)"]},"metadata":{"tags":[]},"execution_count":33}]},{"cell_type":"markdown","metadata":{"id":"YZ71Z1DWK4LM"},"source":["# 1. Distance Estimation"]},{"cell_type":"markdown","metadata":{"id":"0ZRKoKicK4LN"},"source":["### Train the model"]},{"cell_type":"code","metadata":{"id":"HceKfhOaK4LN","executionInfo":{"status":"ok","timestamp":1614366125020,"user_tz":-60,"elapsed":550,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["from time import time"],"execution_count":34,"outputs":[]},{"cell_type":"code","metadata":{"id":"hqkn_ZVBK4LQ","executionInfo":{"status":"ok","timestamp":1614366125603,"user_tz":-60,"elapsed":627,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["# UNIFORM\n","from tensorflow.keras.utils import Sequence\n","\n","num_dec = 1\n","num_bins = 32\n","\n","# # for weights\n","# dQ_values = np.load(\"data/5j0n/dQ_values_100K.npy\")\n","# distribution = np.histogram(dQ_values, bins=32, range=(0.0, np.pi), density=True)\n","# probabilities = distribution[0]\n","# weights = 1/probabilities\n","# weights_norm = weights/sum(weights)\n","\n","class DataGenerator(Sequence):\n","    \n","    def __init__(self, X, y, list_ids, limit_num_pairs=None, limit_style=\"random\", batch_size=256, shuffle=True):\n","        start_time = time()\n","        if batch_size > limit_num_pairs:\n","            raise Exception(\"Please specify limit_num_pairs that is much higher than batch_size\")\n","        self.X = X  \n","        self.y = y  \n","        self.limit_num_pairs = limit_num_pairs\n","        self.list_ids = list_ids\n","        self.batch_size = batch_size  \n","        # all the possible combinations of 2 image id pairs\n","        self.pair_ids = np.array(list(zip(*list(map(lambda x: x.flatten(), np.meshgrid(list_ids, list_ids))))))  # e.g. train_idx\n","        \n","        # Don't use all possible combination of pairs, limit them here\n","        if self.limit_num_pairs:\n","            limited_pair_indices = np.random.choice(np.arange(len(self.pair_ids)), size=self.limit_num_pairs)\n","            self.pair_ids = self.pair_ids[limited_pair_indices]\n","        \n","        if limit_style==\"uniform\":\n","            self.pair_ids = self._generate_uniform()\n","      \n","        self.shuffle = shuffle \n","        self._on_epoch_start()\n","        print(f\"Data created in {time()-start_time} sec\")\n","        \n","        \n","    def _generate_uniform(self):\n","        if os.path.exists(f\"data/{PROTEIN}/{len(self.list_ids)}_{self.limit_num_pairs}_{self.batch_size}.npy\"):\n","            return np.load(f\"data/{PROTEIN}/{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/{PROTEIN}/{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":35,"outputs":[]},{"cell_type":"code","metadata":{"id":"Ui3KmgarK4LT","executionInfo":{"status":"ok","timestamp":1614366129321,"user_tz":-60,"elapsed":3804,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["import tensorflow_probability as tfp\n","import os\n","import h5py\n","from time import time, strftime\n","from datetime import datetime\n","import matplotlib.pyplot as plt\n","import numpy as np\n","from sklearn.model_selection import train_test_split\n","import pathlib\n","\n","from cryoem.rotation_matrices import RotationMatrix\n","from cryoem.conversions import euler2quaternion, d_q\n","from cryoem.knn import get_knn_projections\n","\n","import random\n","import tensorflow as tf\n","from tensorflow.keras.datasets import mnist\n","from tensorflow.keras.models import Model\n","from tensorflow.python.keras.applications.mobilenet import MobileNet\n","from tensorflow.keras.layers import Input, Conv2D, MaxPooling2D, AvgPool2D, Lambda, ZeroPadding2D, Dropout, Concatenate, Dense, GlobalAveragePooling2D, Flatten\n","from tensorflow.keras.optimizers import RMSprop, Adam, SGD\n","from tensorflow.keras import backend as K\n","from tensorflow.keras.callbacks import ModelCheckpoint,ReduceLROnPlateau\n","from tensorflow.keras.callbacks import TensorBoard\n","from tensorflow.keras.utils import plot_model#, multi_gpu_model\n","#from tensorflow.python.keras.applications.resnet50 import ResNet50\n","from tensorflow.python.keras.applications.inception_v3 import InceptionV3\n","from tensorflow.keras.losses import KLD, MAE, MSE\n","\n","_idx1 = list(np.random.choice(val_idx, size=1000))\n","_idx2 = list(np.random.choice(val_idx, size=1000))\n","\n","q1_true = euler2quaternion([angles_true[i] for i in _idx1])\n","q2_true = euler2quaternion([angles_true[i] for i in _idx2])\n","\n","p1 = [X[i] for i in _idx1]\n","p2 = [X[i] for i in _idx2]\n","\n","model = None\n","\n","def cosine_distance(vests):\n","    x, y = vests\n","    xy_sum_square = K.sum(x * y, axis=1, keepdims=True) \n","    xx_sum_square = K.sum(x * x, axis=1, keepdims=True)\n","    xx_sum_square = K.maximum(xx_sum_square,  1e-08) \n","    yy_sum_square = K.sum(y * y, axis=1, keepdims=True)\n","    yy_sum_square = K.maximum(yy_sum_square, 1e-08) \n","    \n","    cos_theta = tf.divide(xy_sum_square, K.sqrt(xx_sum_square)*K.sqrt(yy_sum_square))\n","    eps = K.epsilon()\n","    return 2*tf.acos(tf.clip_by_value(cos_theta, 0.0+eps, 1.0-eps)) \n","\n","def cos_dist_output_shape(shapes):\n","    shape1, shape2 = shapes\n","    return (shape1[0], 1)\n","\n","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","        distance = Lambda(cosine_distance, output_shape=cos_dist_output_shape)([processed_a, processed_b])\n","\n","        global model\n","        model = Model([input_a, input_b], distance)  # was m\n","\n","        # train\n","        #model = multi_gpu_model(m, gpus=gpus)\n","        model.summary()\n","        #plot_model(model, to_file=\"figures/model_plot.png\", expand_nested=True, show_shapes=True, show_layer_names=True)\n","\n","        # training only top layers\n","        optimizer1 = RMSprop(learning_rate=learning_rate)\n","        model.compile(loss=mae, optimizer=optimizer1, metrics=[mse], sample_weight_mode=None)\n","\n","        # Setup callbacks\n","        # Callback that saves the model\n","        training_description = training_description or strftime('%Y%m%d_%H%M%S')\n","        CHECKPOINT_PATH = os.path.join(f\"{path_logs_training}/training\", f\"{training_description}.h5\")\n","        pathlib.Path(f\"{path_logs_training}/training\").mkdir(parents=True, exist_ok=True)\n","        backup_callback = tf.keras.callbacks.ModelCheckpoint(filepath=CHECKPOINT_PATH, monitor='val_loss', verbose=0, save_best_only=False, save_weights_only=False, mode='auto', period=1)\n","        print(f\"Model will be saved to: {CHECKPOINT_PATH}\")\n","        # Callback that will show tensorboard data\n","        LOGS_PATH = os.path.join(f\"{path_logs_training}/logs\", f\"{training_description}\")\n","        pathlib.Path(LOGS_PATH).mkdir(parents=True, exist_ok=True)\n","        logs_callback = TensorBoard(LOGS_PATH, histogram_freq=1) #, profile_batch=300)#100000000)\n","        # Callback for the dP/dQ plot\n","        file_writer_plot = tf.summary.create_file_writer(os.path.join(LOGS_PATH, \"image\"))\n","        plot_callback = tf.keras.callbacks.LambdaCallback(on_epoch_end=generate_dPdQ_plot(file_writer_plot))\n","        # Callback that will decrease LR if it gets plateau in val_loss\n","        #reduce_on_plateau_callback = ReduceLROnPlateau(monitor=\"loss\", mode=\"min\", factor=0.1, patience=20, min_lr=1e-4, verbose=1)\n","\n","\n","\n","        history1 = model.fit(training_generator, \n","                            epochs=epochs,\n","                            validation_data=validation_generator, \n","                            callbacks=[plot_callback, logs_callback, backup_callback])\n","        \n","        # Get training and test loss histories\n","        training_loss = history1.history['loss']\n","        val_loss = history1.history['val_loss']\n","        mses = history1.history['mse']\n","        val_mses = history1.history['val_mse']\n","        pathlib.Path(f\"{path_logs_training}/losses\").mkdir(parents=True, exist_ok=True)\n","        np.savez(f\"{path_logs_training}/losses/{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":36,"outputs":[]},{"cell_type":"code","metadata":{"id":"qOYwbjOzK4LV","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1614366129322,"user_tz":-60,"elapsed":2642,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"20ad64a3-978e-4025-b431-499314891629"},"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":37,"outputs":[{"output_type":"execute_result","data":{"text/plain":["(63101, 7022)"]},"metadata":{"tags":[]},"execution_count":37}]},{"cell_type":"code","metadata":{"id":"8HWI9cfqK4LY","scrolled":true,"colab":{"base_uri":"https://localhost:8080/"},"outputId":"0c4cb79b-0abe-42c0-fab5-02c7f4b5d80d"},"source":["model, history1 = train_siamese(X=X, y=y, \n","                               train_idx=train_idx, \n","                               val_idx=val_idx,\n","                               epochs=150,  #500\n","                               batch_size=256,  #512 latest \n","                               learning_rate=1e-3,  #0.01 \n","                                limit_style=\"random\", \n","                                path_logs_training=path_logs_training, \n","                                training_description=training_description,\n","                               training_steps=int(train_percent*np.power(len(train_idx), 2)),  # None\n","                               validation_steps=int(val_percent*np.power(len(val_idx), 2)),  # None\n","                               plot=True,\n","                               gpus=None)"],"execution_count":null,"outputs":[{"output_type":"stream","text":["INFO:tensorflow:Using MirroredStrategy with devices ('/job:localhost/replica:0/task:0/device:GPU:0',)\n","Data created in 6.9606897830963135 sec\n","Data created in 0.7626266479492188 sec\n","Input images shape (116, 116, 1)\n","Model: \"model_1\"\n","__________________________________________________________________________________________________\n","Layer (type)                    Output Shape         Param #     Connected to                     \n","==================================================================================================\n","input_1 (InputLayer)            [(None, 116, 116, 1) 0                                            \n","__________________________________________________________________________________________________\n","input_2 (InputLayer)            [(None, 116, 116, 1) 0                                            \n","__________________________________________________________________________________________________\n","model (Functional)              (None, 512)          4551936     input_1[0][0]                    \n","                                                                 input_2[0][0]                    \n","__________________________________________________________________________________________________\n","lambda (Lambda)                 (None, 1)            0           model[0][0]                      \n","                                                                 model[1][0]                      \n","==================================================================================================\n","Total params: 4,551,936\n","Trainable params: 4,551,936\n","Non-trainable params: 0\n","__________________________________________________________________________________________________\n","INFO:tensorflow:Reduce to /job:localhost/replica:0/task:0/device:CPU:0 then broadcast to ('/job:localhost/replica:0/task:0/device:CPU:0',).\n","INFO:tensorflow:Reduce to /job:localhost/replica:0/task:0/device:CPU:0 then broadcast to ('/job:localhost/replica:0/task:0/device:CPU:0',).\n","INFO:tensorflow:Reduce to /job:localhost/replica:0/task:0/device:CPU:0 then broadcast to ('/job:localhost/replica:0/task:0/device:CPU:0',).\n","INFO:tensorflow:Reduce to /job:localhost/replica:0/task:0/device:CPU:0 then broadcast to ('/job:localhost/replica:0/task:0/device:CPU:0',).\n","WARNING:tensorflow:`period` argument is deprecated. Please use `save_freq` to specify the frequency in number of batches seen.\n","Model will be saved to: /content/drive/My Drive/ModelsProtein/training/5j0n_fullcvg_uniformS2_noisy0.h5\n","Epoch 1/150\n","INFO:tensorflow:Reduce to /job:localhost/replica:0/task:0/device:CPU:0 then broadcast to ('/job:localhost/replica:0/task:0/device:CPU:0',).\n","INFO:tensorflow:Reduce to /job:localhost/replica:0/task:0/device:CPU:0 then broadcast to ('/job:localhost/replica:0/task:0/device:CPU:0',).\n","INFO:tensorflow:Reduce to /job:localhost/replica:0/task:0/device:CPU:0 then broadcast to ('/job:localhost/replica:0/task:0/device:CPU:0',).\n","INFO:tensorflow:Reduce to /job:localhost/replica:0/task:0/device:CPU:0 then broadcast to ('/job:localhost/replica:0/task:0/device:CPU:0',).\n","INFO:tensorflow:Reduce to /job:localhost/replica:0/task:0/device:CPU:0 then broadcast to ('/job:localhost/replica:0/task:0/device:CPU:0',).\n","INFO:tensorflow:Reduce to /job:localhost/replica:0/task:0/device:CPU:0 then broadcast to ('/job:localhost/replica:0/task:0/device:CPU:0',).\n","247/247 [==============================] - 90s 320ms/step - loss: 0.8109 - mse: 1.1475 - val_loss: 0.5411 - val_mse: 0.4805\n","Epoch 2/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.5181 - mse: 0.4303 - val_loss: 0.4979 - val_mse: 0.3989\n","Epoch 3/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.4633 - mse: 0.3418 - val_loss: 0.4263 - val_mse: 0.2894\n","Epoch 4/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.4082 - mse: 0.2680 - val_loss: 0.3887 - val_mse: 0.2419\n","Epoch 5/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.3547 - mse: 0.2029 - val_loss: 0.3307 - val_mse: 0.1765\n","Epoch 6/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.2916 - mse: 0.1343 - val_loss: 0.2824 - val_mse: 0.1274\n","Epoch 7/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.2419 - mse: 0.0883 - val_loss: 0.2547 - val_mse: 0.1036\n","Epoch 8/150\n","247/247 [==============================] - 80s 325ms/step - loss: 0.2183 - mse: 0.0702 - val_loss: 0.2373 - val_mse: 0.0864\n","Epoch 9/150\n","247/247 [==============================] - 80s 325ms/step - loss: 0.2086 - mse: 0.0637 - val_loss: 0.2264 - val_mse: 0.0769\n","Epoch 10/150\n","247/247 [==============================] - 80s 325ms/step - loss: 0.2012 - mse: 0.0591 - val_loss: 0.2289 - val_mse: 0.0804\n","Epoch 11/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1965 - mse: 0.0565 - val_loss: 0.2240 - val_mse: 0.0759\n","Epoch 12/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1940 - mse: 0.0551 - val_loss: 0.2225 - val_mse: 0.0742\n","Epoch 13/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1921 - mse: 0.0541 - val_loss: 0.2191 - val_mse: 0.0713\n","Epoch 14/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1902 - mse: 0.0533 - val_loss: 0.2153 - val_mse: 0.0695\n","Epoch 15/150\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1871 - mse: 0.0518 - val_loss: 0.2188 - val_mse: 0.0728\n","Epoch 16/150\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1871 - mse: 0.0517 - val_loss: 0.2133 - val_mse: 0.0671\n","Epoch 17/150\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1842 - mse: 0.0504 - val_loss: 0.2134 - val_mse: 0.0674\n","Epoch 18/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1844 - mse: 0.0505 - val_loss: 0.2142 - val_mse: 0.0688\n","Epoch 19/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1828 - mse: 0.0497 - val_loss: 0.2131 - val_mse: 0.0668\n","Epoch 20/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1829 - mse: 0.0496 - val_loss: 0.2139 - val_mse: 0.0679\n","Epoch 21/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1811 - mse: 0.0489 - val_loss: 0.2122 - val_mse: 0.0658\n","Epoch 22/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1800 - mse: 0.0489 - val_loss: 0.2132 - val_mse: 0.0667\n","Epoch 23/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1796 - mse: 0.0482 - val_loss: 0.2126 - val_mse: 0.0670\n","Epoch 24/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1793 - mse: 0.0484 - val_loss: 0.2129 - val_mse: 0.0664\n","Epoch 25/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1788 - mse: 0.0481 - val_loss: 0.2180 - val_mse: 0.0726\n","Epoch 26/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1782 - mse: 0.0478 - val_loss: 0.2145 - val_mse: 0.0685\n","Epoch 27/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1770 - mse: 0.0474 - val_loss: 0.2103 - val_mse: 0.0650\n","Epoch 28/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1761 - mse: 0.0470 - val_loss: 0.2124 - val_mse: 0.0663\n","Epoch 29/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1760 - mse: 0.0468 - val_loss: 0.2122 - val_mse: 0.0664\n","Epoch 30/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1746 - mse: 0.0463 - val_loss: 0.2107 - val_mse: 0.0649\n","Epoch 31/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1744 - mse: 0.0464 - val_loss: 0.2174 - val_mse: 0.0706\n","Epoch 32/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1737 - mse: 0.0460 - val_loss: 0.2118 - val_mse: 0.0663\n","Epoch 33/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1746 - mse: 0.0464 - val_loss: 0.2100 - val_mse: 0.0646\n","Epoch 34/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1741 - mse: 0.0462 - val_loss: 0.2128 - val_mse: 0.0676\n","Epoch 35/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1738 - mse: 0.0460 - val_loss: 0.2108 - val_mse: 0.0651\n","Epoch 36/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1736 - mse: 0.0462 - val_loss: 0.2133 - val_mse: 0.0683\n","Epoch 37/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1728 - mse: 0.0458 - val_loss: 0.2129 - val_mse: 0.0666\n","Epoch 38/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1718 - mse: 0.0452 - val_loss: 0.2121 - val_mse: 0.0663\n","Epoch 39/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1713 - mse: 0.0452 - val_loss: 0.2097 - val_mse: 0.0647\n","Epoch 40/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1712 - mse: 0.0450 - val_loss: 0.2119 - val_mse: 0.0659\n","Epoch 41/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1719 - mse: 0.0457 - val_loss: 0.2105 - val_mse: 0.0644\n","Epoch 42/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1707 - mse: 0.0450 - val_loss: 0.2110 - val_mse: 0.0653\n","Epoch 43/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1696 - mse: 0.0447 - val_loss: 0.2124 - val_mse: 0.0673\n","Epoch 44/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1705 - mse: 0.0452 - val_loss: 0.2107 - val_mse: 0.0651\n","Epoch 45/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1694 - mse: 0.0445 - val_loss: 0.2113 - val_mse: 0.0658\n","Epoch 46/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1696 - mse: 0.0446 - val_loss: 0.2110 - val_mse: 0.0653\n","Epoch 47/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1696 - mse: 0.0447 - val_loss: 0.2123 - val_mse: 0.0671\n","Epoch 48/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1692 - mse: 0.0447 - val_loss: 0.2119 - val_mse: 0.0663\n","Epoch 49/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1683 - mse: 0.0443 - val_loss: 0.2127 - val_mse: 0.0671\n","Epoch 50/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1684 - mse: 0.0443 - val_loss: 0.2111 - val_mse: 0.0656\n","Epoch 51/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1678 - mse: 0.0441 - val_loss: 0.2134 - val_mse: 0.0676\n","Epoch 52/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1689 - mse: 0.0446 - val_loss: 0.2127 - val_mse: 0.0665\n","Epoch 53/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1673 - mse: 0.0438 - val_loss: 0.2113 - val_mse: 0.0655\n","Epoch 54/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1676 - mse: 0.0439 - val_loss: 0.2128 - val_mse: 0.0668\n","Epoch 55/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1665 - mse: 0.0436 - val_loss: 0.2123 - val_mse: 0.0667\n","Epoch 56/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1667 - mse: 0.0438 - val_loss: 0.2114 - val_mse: 0.0659\n","Epoch 57/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1666 - mse: 0.0437 - val_loss: 0.2131 - val_mse: 0.0665\n","Epoch 58/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1661 - mse: 0.0436 - val_loss: 0.2130 - val_mse: 0.0672\n","Epoch 59/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1665 - mse: 0.0437 - val_loss: 0.2130 - val_mse: 0.0673\n","Epoch 60/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1677 - mse: 0.0442 - val_loss: 0.2132 - val_mse: 0.0677\n","Epoch 61/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1657 - mse: 0.0434 - val_loss: 0.2105 - val_mse: 0.0651\n","Epoch 62/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1656 - mse: 0.0434 - val_loss: 0.2111 - val_mse: 0.0648\n","Epoch 63/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1662 - mse: 0.0436 - val_loss: 0.2131 - val_mse: 0.0679\n","Epoch 64/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1646 - mse: 0.0432 - val_loss: 0.2135 - val_mse: 0.0675\n","Epoch 65/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1654 - mse: 0.0434 - val_loss: 0.2107 - val_mse: 0.0651\n","Epoch 66/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1649 - mse: 0.0431 - val_loss: 0.2139 - val_mse: 0.0678\n","Epoch 67/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1650 - mse: 0.0434 - val_loss: 0.2106 - val_mse: 0.0647\n","Epoch 68/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1646 - mse: 0.0430 - val_loss: 0.2121 - val_mse: 0.0659\n","Epoch 69/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1650 - mse: 0.0434 - val_loss: 0.2117 - val_mse: 0.0663\n","Epoch 70/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1647 - mse: 0.0431 - val_loss: 0.2132 - val_mse: 0.0671\n","Epoch 71/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1648 - mse: 0.0433 - val_loss: 0.2121 - val_mse: 0.0662\n","Epoch 72/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1635 - mse: 0.0428 - val_loss: 0.2116 - val_mse: 0.0655\n","Epoch 73/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1634 - mse: 0.0427 - val_loss: 0.2134 - val_mse: 0.0672\n","Epoch 74/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1645 - mse: 0.0432 - val_loss: 0.2132 - val_mse: 0.0666\n","Epoch 75/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1647 - mse: 0.0431 - val_loss: 0.2116 - val_mse: 0.0659\n","Epoch 76/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1636 - mse: 0.0429 - val_loss: 0.2125 - val_mse: 0.0670\n","Epoch 77/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1640 - mse: 0.0430 - val_loss: 0.2134 - val_mse: 0.0667\n","Epoch 78/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1633 - mse: 0.0427 - val_loss: 0.2120 - val_mse: 0.0663\n","Epoch 79/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1620 - mse: 0.0425 - val_loss: 0.2126 - val_mse: 0.0665\n","Epoch 80/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1640 - mse: 0.0431 - val_loss: 0.2121 - val_mse: 0.0662\n","Epoch 81/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1646 - mse: 0.0434 - val_loss: 0.2128 - val_mse: 0.0667\n","Epoch 82/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1634 - mse: 0.0431 - val_loss: 0.2136 - val_mse: 0.0673\n","Epoch 83/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1629 - mse: 0.0428 - val_loss: 0.2161 - val_mse: 0.0695\n","Epoch 84/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1629 - mse: 0.0427 - val_loss: 0.2128 - val_mse: 0.0665\n","Epoch 85/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1630 - mse: 0.0428 - val_loss: 0.2131 - val_mse: 0.0671\n","Epoch 86/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1629 - mse: 0.0427 - val_loss: 0.2125 - val_mse: 0.0662\n","Epoch 87/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1619 - mse: 0.0424 - val_loss: 0.2128 - val_mse: 0.0668\n","Epoch 88/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1629 - mse: 0.0428 - val_loss: 0.2138 - val_mse: 0.0675\n","Epoch 89/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1622 - mse: 0.0424 - val_loss: 0.2124 - val_mse: 0.0661\n","Epoch 90/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1617 - mse: 0.0423 - val_loss: 0.2127 - val_mse: 0.0668\n","Epoch 91/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1618 - mse: 0.0424 - val_loss: 0.2134 - val_mse: 0.0668\n","Epoch 92/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1624 - mse: 0.0428 - val_loss: 0.2132 - val_mse: 0.0669\n","Epoch 93/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1621 - mse: 0.0425 - val_loss: 0.2137 - val_mse: 0.0673\n","Epoch 94/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1620 - mse: 0.0425 - val_loss: 0.2134 - val_mse: 0.0671\n","Epoch 95/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1615 - mse: 0.0425 - val_loss: 0.2140 - val_mse: 0.0675\n","Epoch 96/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1612 - mse: 0.0423 - val_loss: 0.2151 - val_mse: 0.0683\n","Epoch 97/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1611 - mse: 0.0422 - val_loss: 0.2134 - val_mse: 0.0671\n","Epoch 98/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1615 - mse: 0.0425 - val_loss: 0.2127 - val_mse: 0.0668\n","Epoch 99/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1609 - mse: 0.0420 - val_loss: 0.2134 - val_mse: 0.0669\n","Epoch 100/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1599 - mse: 0.0419 - val_loss: 0.2136 - val_mse: 0.0672\n","Epoch 101/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1616 - mse: 0.0424 - val_loss: 0.2132 - val_mse: 0.0676\n","Epoch 102/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1601 - mse: 0.0418 - val_loss: 0.2137 - val_mse: 0.0675\n","Epoch 103/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1613 - mse: 0.0424 - val_loss: 0.2129 - val_mse: 0.0666\n","Epoch 104/150\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1607 - mse: 0.0422 - val_loss: 0.2132 - val_mse: 0.0666\n","Epoch 105/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1607 - mse: 0.0424 - val_loss: 0.2128 - val_mse: 0.0661\n","Epoch 106/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1608 - mse: 0.0422 - val_loss: 0.2136 - val_mse: 0.0673\n","Epoch 107/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1601 - mse: 0.0420 - val_loss: 0.2135 - val_mse: 0.0669\n","Epoch 108/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1611 - mse: 0.0423 - val_loss: 0.2133 - val_mse: 0.0672\n","Epoch 109/150\n","247/247 [==============================] - 80s 325ms/step - loss: 0.1613 - mse: 0.0425 - val_loss: 0.2135 - val_mse: 0.0668\n","Epoch 110/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1598 - mse: 0.0420 - val_loss: 0.2146 - val_mse: 0.0684\n","Epoch 111/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1599 - mse: 0.0421 - val_loss: 0.2129 - val_mse: 0.0671\n","Epoch 112/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1606 - mse: 0.0423 - val_loss: 0.2140 - val_mse: 0.0674\n","Epoch 113/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1594 - mse: 0.0417 - val_loss: 0.2135 - val_mse: 0.0672\n","Epoch 114/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1599 - mse: 0.0418 - val_loss: 0.2138 - val_mse: 0.0673\n","Epoch 115/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1592 - mse: 0.0417 - val_loss: 0.2133 - val_mse: 0.0670\n","Epoch 116/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1597 - mse: 0.0421 - val_loss: 0.2117 - val_mse: 0.0658\n","Epoch 117/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1608 - mse: 0.0424 - val_loss: 0.2138 - val_mse: 0.0671\n","Epoch 118/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1600 - mse: 0.0422 - val_loss: 0.2124 - val_mse: 0.0665\n","Epoch 119/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1597 - mse: 0.0421 - val_loss: 0.2156 - val_mse: 0.0687\n","Epoch 120/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1595 - mse: 0.0418 - val_loss: 0.2132 - val_mse: 0.0669\n","Epoch 121/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1590 - mse: 0.0418 - val_loss: 0.2148 - val_mse: 0.0682\n","Epoch 122/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1600 - mse: 0.0421 - val_loss: 0.2123 - val_mse: 0.0660\n","Epoch 123/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1589 - mse: 0.0418 - val_loss: 0.2131 - val_mse: 0.0671\n","Epoch 124/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1592 - mse: 0.0420 - val_loss: 0.2134 - val_mse: 0.0667\n","Epoch 125/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1600 - mse: 0.0423 - val_loss: 0.2128 - val_mse: 0.0664\n","Epoch 126/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1595 - mse: 0.0420 - val_loss: 0.2137 - val_mse: 0.0676\n","Epoch 127/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1594 - mse: 0.0420 - val_loss: 0.2135 - val_mse: 0.0668\n","Epoch 128/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1588 - mse: 0.0417 - val_loss: 0.2129 - val_mse: 0.0668\n","Epoch 129/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1586 - mse: 0.0417 - val_loss: 0.2143 - val_mse: 0.0672\n","Epoch 130/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1590 - mse: 0.0418 - val_loss: 0.2141 - val_mse: 0.0676\n","Epoch 131/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1584 - mse: 0.0416 - val_loss: 0.2123 - val_mse: 0.0661\n","Epoch 132/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1591 - mse: 0.0417 - val_loss: 0.2139 - val_mse: 0.0675\n","Epoch 133/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1581 - mse: 0.0416 - val_loss: 0.2136 - val_mse: 0.0669\n","Epoch 134/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1585 - mse: 0.0416 - val_loss: 0.2133 - val_mse: 0.0673\n","Epoch 135/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1592 - mse: 0.0418 - val_loss: 0.2121 - val_mse: 0.0657\n","Epoch 136/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1587 - mse: 0.0418 - val_loss: 0.2158 - val_mse: 0.0691\n","Epoch 137/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1587 - mse: 0.0419 - val_loss: 0.2133 - val_mse: 0.0671\n","Epoch 138/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1578 - mse: 0.0413 - val_loss: 0.2135 - val_mse: 0.0671\n","Epoch 139/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1579 - mse: 0.0417 - val_loss: 0.2143 - val_mse: 0.0673\n","Epoch 140/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1595 - mse: 0.0422 - val_loss: 0.2125 - val_mse: 0.0666\n","Epoch 141/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1578 - mse: 0.0414 - val_loss: 0.2139 - val_mse: 0.0673\n","Epoch 142/150\n","247/247 [==============================] - 80s 324ms/step - loss: 0.1573 - mse: 0.0414 - val_loss: 0.2131 - val_mse: 0.0665\n","Epoch 143/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1575 - mse: 0.0412 - val_loss: 0.2142 - val_mse: 0.0672\n","Epoch 144/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1578 - mse: 0.0414 - val_loss: 0.2145 - val_mse: 0.0677\n","Epoch 145/150\n","247/247 [==============================] - 80s 323ms/step - loss: 0.1586 - mse: 0.0418 - val_loss: 0.2149 - val_mse: 0.0684\n","Epoch 146/150\n","  1/247 [..............................] - ETA: 1:21 - loss: 0.1364 - mse: 0.0337"],"name":"stdout"}]},{"cell_type":"markdown","metadata":{"id":"fJJKUgcJK4La"},"source":["---"]},{"cell_type":"code","metadata":{"id":"MAsi4iHUPjLi"},"source":[""],"execution_count":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"gi9CsCZAK4Ld"},"source":["data = np.load(f\"{path_logs_training}/losses/{training_description}.npz\")\n","training_loss, val_loss, mses, val_mses = data[\"arr_0\"], data[\"arr_1\"], data[\"arr_2\"], data[\"arr_3\"]"],"execution_count":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"IIKP9TtBK4Lg"},"source":["# Get training and test loss histories\n","fig, (ax1, ax2) = plt.subplots(1, 2, figsize=(15,7))\n","\n","# Create count of the number of epochs\n","epoch_count = range(1, len(training_loss) + 1)\n","\n","# Visualize loss history\n","ax1.plot(epoch_count, training_loss, 'r--', label='MAE Training Loss')\n","ax1.plot(epoch_count, val_loss, 'b-', label='MAE Validation Loss')\n","ax1.legend()\n","ax1.set_xlabel('Epoch')\n","ax1.set_ylabel('Loss')\n","\n","ax2.plot(epoch_count, mses, 'r-', label='MSE Training')\n","ax2.plot(epoch_count, val_mses, 'b-', label='MSE Validation')\n","ax2.legend()\n","ax2.set_xlabel('Epoch')\n","ax2.set_ylabel('Loss')\n","plt.show();"],"execution_count":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"4_py9DG4K4Lj"},"source":["training_loss[-1], val_loss[-1], mses[-1], val_mses[-1]"],"execution_count":null,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"M-kSlYfqK4Lt"},"source":["### (Or) Read model checkpoint"]},{"cell_type":"code","metadata":{"id":"9z7haF6NK4Lu","executionInfo":{"status":"ok","timestamp":1614366133411,"user_tz":-60,"elapsed":560,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["# put correct filename\n","model_filename = f\"{path_logs_training}/training/{training_description}.h5\""],"execution_count":38,"outputs":[]},{"cell_type":"code","metadata":{"id":"Dr9eFsJKK4Lw","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1614366136468,"user_tz":-60,"elapsed":2127,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"eeded3bb-5fe2-4c07-f96b-d60918374066"},"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":39,"outputs":[{"output_type":"stream","text":["Model: \"model_1\"\n","__________________________________________________________________________________________________\n","Layer (type)                    Output Shape         Param #     Connected to                     \n","==================================================================================================\n","input_1 (InputLayer)            [(None, 116, 116, 1) 0                                            \n","__________________________________________________________________________________________________\n","input_2 (InputLayer)            [(None, 116, 116, 1) 0                                            \n","__________________________________________________________________________________________________\n","model (Functional)              (None, 512)          4551936     input_1[0][0]                    \n","                                                                 input_2[0][0]                    \n","__________________________________________________________________________________________________\n","lambda (Lambda)                 (None, 1)            0           model[0][0]                      \n","                                                                 model[1][0]                      \n","==================================================================================================\n","Total params: 4,551,936\n","Trainable params: 4,551,936\n","Non-trainable params: 0\n","__________________________________________________________________________________________________\n"],"name":"stdout"}]},{"cell_type":"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":1614366138433,"user_tz":-60,"elapsed":528,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["from cryoem.conversions import d_q, euler2quaternion\n","from cryoem.plots import plot_dP_dQ"],"execution_count":40,"outputs":[]},{"cell_type":"code","metadata":{"id":"RJMjW2KHK4L5","executionInfo":{"status":"ok","timestamp":1614366140795,"user_tz":-60,"elapsed":519,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["def d_p(p1, p2):\n","    p1 = tf.cast(p1, dtype=tf.float32)\n","    p2 = tf.cast(p2, dtype=tf.float32)\n","    return model.predict([p1, p2], batch_size=256)"],"execution_count":41,"outputs":[]},{"cell_type":"code","metadata":{"id":"0YTh5UvmK4L7","executionInfo":{"status":"ok","timestamp":1614366215460,"user_tz":-60,"elapsed":73980,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["# 5:41 with 1024\n","# 5:43     with 256\n","idx1 = list(np.random.choice(test_idx, size=1000))\n","idx2 = list(np.random.choice(test_idx, size=1000))\n","\n","q1_true = euler2quaternion([angles_true[i] for i in idx1])\n","q2_true = euler2quaternion([angles_true[i] for i in idx2])\n","\n","p1 = [X[i] for i in idx1]\n","p2 = [X[i] for i in idx2]\n","\n","dP_values = d_p(p1, p2).T[0]\n","dQ_values = d_q(q1_true, q2_true).numpy()"],"execution_count":42,"outputs":[]},{"cell_type":"code","metadata":{"id":"NjmjpoN0K4L9","colab":{"base_uri":"https://localhost:8080/","height":882},"executionInfo":{"status":"ok","timestamp":1614366220289,"user_tz":-60,"elapsed":77772,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"196738ce-1d53-4c7a-f6cb-219083f4bd73"},"source":["plot_dP_dQ(dP_values, dQ_values)"],"execution_count":43,"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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mhr27t3L5MmTu/S9Mi0ZFBX+hokTJ/ZY/UII0V9FbArsY489Rn5+PuvWrcNsNlNUVARAXl4e999/P2PGjGHatGkcPHiQSZMmAbB48WKGDu3asNGLL66Trb+FEKKHRCwkRo4cybZt29p9fP369cG3tVotv/71ryNVkhBCiIvoc41rIYQQPUdCQgghREgSEkIIIUKSkBBCCBGShIQQQoiQJCSEEEKEJCEhhBAiJAkJIYQQIfWZk+la9oXq6q6xQgjRn7U8Z7Y8h16oz4REVVUVAHPmzIlyJUIIEXuqqqoYPnx4u48rqqqqUainx7lcLj799FPS09OD51YIIYTonN/vp6qqitGjR3d4kmefCQkhhBA9TxrXQgghQpKQEEIIEZKEhBBCiJAkJIQQQoQkISGEECIkCQkhhBAhSUgIIYQIKeZWXB8/fpz8/Hzq6upITk6mqKiIrKysNtf4/X5WrFjB/v37URSFBQsWMGPGjOgU3Ilw7mXNmjX8/ve/JyMjA4Bx48ZRUFAQhWpDKyoq4t133+XMmTPs3LmTUaNGtbsmVh6TcO4lFh6T2tpaHnroIcrKyoiLi2P48OE8/vjjpKamtrnO6XTy8MMP89lnn6HValm6dCnf//73o1R1x8K9l/z8fD788ENSUlIAmDJlCvfee280Su7UokWLOH36NBqNBpPJxPLly8nOzm5zTa/6eVFjzB133KG++eabqqqq6ptvvqnecccd7a75wx/+oN59992q3+9Xq6ur1Ztuukk9depUpEu9qHDuZfXq1WphYWGkS+uS//7v/1bPnj2rfv/731ePHj3a4TWx8piEcy+x8JjU1taqH330UfD9wsJC9eGHH2533Zo1a9Rly5apqqqqx48fV8ePH682NTVFrM5whHsvS5cuVV999dVIlnZJGhoagm+/99576vTp09td05t+XmJquKm6uprDhw8zdepUAKZOncrhw4epqalpc93u3buZMWMGGo2G1NRUbrnlFt55551olBxSuPcSC6699lqsVmun18TCYwLh3UssSE5O5jvf+U7w/bFjx3L27Nl217399tvMnDkTgKysLEaPHs0HH3wQsTrDEe69xIqkpKTg201NTSiK0u6a3vTzElPDTTabDYvFEtybSavVkpGRgc1ma/PS02azMWjQoOD7Vqu11+0OG+69ALz11lv8+c9/Jj09nfvuu49rrrkmGiV3Syw8Jl0RS49JIBBgy5YtTJw4sd3fnT17lsGDBwff7+2PS2f3ArBx40a2bt3K0KFDefDBBxk5cmSEKwzPsmXLOHDgAKqqsmHDhnZ/35t+XmIqJPqjWbNmsXDhQvR6PQcOHGDRokXs3r07OO4qIi/WHpMnnngCk8lEbm5utEvpts7uZcmSJaSnp6PRaHjzzTe555572Lt3b6/c8HPlypUAvPnmmzz11FOsX78+yhWFFlPDTVarlYqKiuC+536/n8rKynbDA1artc3LUZvNRmZmZkRrvZhw7yU9PR29Xg/AjTfeiNVq5Ysvvoh4vd0VC49JuGLpMSkqKuLkyZOsWrUKjab9j/ugQYM4c+ZM8P3e/Lhc7F4sFkvw49OnT8fhcPTqV0XQXOfHH39MbW1tm4/3pp+XmAqJtLQ0srOz2bVrFwC7du0iOzu73fDMlClT2LZtG4FAgJqaGvbu3cvkyZOjUXJI4d5LRUVF8O0jR45w5swZRowYEdFae0IsPCbhipXH5Nlnn+XTTz9l7dq1xMXFdXjNlClT2Lp1KwAnTpzg0KFD3HTTTZEsMyzh3Evrx2X//v1oNBosFkukSgyL3W7HZrMF3//Tn/7EgAEDSE5ObnNdb/p5ibmtwr/66ivy8/NpaGjAbDZTVFTEN77xDfLy8rj//vsZM2YMfr+fxx9/nAMHDgCQl5cXbM71JuHcy9KlS/nss8/QaDTo9Xruv/9+vve970W79DZWrFjBnj17OHfuHCkpKSQnJ/PWW2/F5GMSzr3EwmPyxRdfMHXqVLKysoJnBAwZMoS1a9cybdo0/v3f/x2LxYLD4SA/P58jR46g0Wj45S9/yS233BLl6tsK917mzp1LdXU1iqKQmJjIQw89xNixY6NcfVvnzp1j0aJFOJ1ONBoNAwYMYOnSpXzrW9/qtT8vMRcSQgghIiemhpuEEEJEloSEEEKIkCQkhBBChCQhIYQQIiQJCSGEECFJSAghhAhJQkKIHpafn89zzz0X7TKE6BESEkJEQUNDAwUFBdx4441cffXV3HbbbfzhD3+IdllCtCMb/AkRYR6Ph7lz55KWlkZxcTGZmZn813/9F/n5+TQ2NnLnnXdGu0QhguSVhBDddPjwYW6//XauueYaHnjgAdxud6fX79ixA5vNxvPPP8/QoUPR6/VMmDCBX/3qV6xatQq73R6hyoW4OAkJIbrB4/GwePFipk2bxl/+8hemTJnCnj17Ov2cDz/8kAkTJmAymdp8fNKkSbhcLv7+979fzpKF6BIJCSG64eDBg3i9Xu666y70ej1TpkxhzJgxnX5ObW0t6enp7T6u0+lISUmJydMJRd8lISFEN1RWVmKxWNocQdn6RLGOpKSkUFVV1e7jPp+P2traXnt4keifJCSE6Ib09HQqKipovZnyxc5fHj9+PB988AEOh6PNx/fs2YNer+fqq6++LLUKcSkkJITohrFjx6LT6di8eTNer5c9e/Zw6NChTj9n2rRpZGZm8rOf/YzTp0/j9XrZv38/K1asYP78+SQlJUWoeiEuTs6TEKKbDh06xPLlyzl58mTw8KHhw4ezZMmSkJ9TV1fHs88+y969e6mrq8Pv9/Pzn/+cvLy8Do/mFCJaJCSEiDKv10teXh4Wi4XCwsI2/Q0hok1+ZREiyvR6PWvWrGHo0KEcO3Ys2uUI0Ya8khDiMnjxxRd56aWX2n38X/7lX9iwYUMUKhLi0khICCGECEmGm4QQQoQkISGEECIkCQkhhBAhSUgIIYQISUJCCCFESP8fA1Cdv7aXY1gAAAAASUVORK5CYII=\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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CCGEdAUKSIQQQrqCeqsXsFl4ngcARCKRLV4JIYSsz8jICNTqvvkxfNn65isRj8cBAO9///u3eCWEELI+//7v/w6Px7PVy+gaClEUxa1exGYol8t444034HQ6oVKptno5hBCypvXskDiOQyQS2Ra7qb4JSIQQQnobJTUQQgjpChSQCCGEdAUKSIQQQroCBSRCCCFdgQISIYSQrkABiRBCSFeggEQIIaQr9G2VValUwmc/+1mcOnUKKpUKhw8fxo033tj0uNdffx2f+MQnMDk5CQDQarU4fvz4ZT33wsICjhw5gkwmA5vNhqNHj8qfv47neTz88MN49dVXoVAo8IlPfAJ33HHHZT3vpa7l2LFj+MEPfoDh4WEAwHXXXYcHHnhgU9dx9OhRvPTSSwgGg3j22Wexe/fupsd06muynrV04muSTqfxmc98Bj6fD1qtFhMTE3jooYfgcDgaHrfe13In1nLkyBH8/Oc/h91uBwDs378ff/Znf7apa7n33nsRCASgVCphNBrx+c9/HjMzMw2P6dRrZT1r6cRrZdsQ+9SxY8fEz33uc6IoiuLCwoL49re/XSwUCk2P++Uvfynefvvtm/rcH/zgB8Wnn35aFEVRfPrpp8UPfvCDTY956qmnxI9+9KMiz/NiMpkU3/GOd4h+v39T17HetXzjG98Qv/zlL2/6cy/3n//5n2IoFBJvvPFG8dy5cy0f06mvyXrW0omvSTqdFn/5y1/K73/5y18WP/vZzzY9br2v5U6s5fDhw+K//uu/bupzr5TL5eS3f/zjH4u33XZb02M69VpZz1o68VrZLvr2yO5HP/oR7rzzTgDA5OQkrr76arzyyitX/HmTySROnz6NAwcOAAAOHDiA06dPI5VKNTzuhRdewB133AGlUgmHw4F9+/bhxRdf3JK1dML1118Pt9u96mM68TVZ71o6wWaz4W1ve5v8/rXXXotQKNT0uE68lte7lk4wm83y24VCAQqFoukxnXqtrGctZPP07ZFdKBTC2NiY/L7b7W7bCXxxcRG333471Go17r77btx+++2X/LzhcBgul0vup6dSqTA8PIxwONxw/BEOhzE6Orqu9V3ptQDA888/j5/97GdwOp34i7/4C7zlLW/Z1LWsd71X+muyEZ38mgiCgCeeeAI33XRT059t5LV8pdcCAP/8z/+MJ598El6vF3/913+N6enp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\n","text/plain":["<Figure size 432x432 with 3 Axes>"]},"metadata":{"tags":[]}},{"output_type":"stream","text":["Variance = 0.2615634120003712\n","Min. angle recovery loss possible = 0.06834700307877864\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"lA75WQYrK4L_","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1614366220290,"user_tz":-60,"elapsed":77370,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}},"outputId":"c41bbd90-494c-4a45-831f-8c98aa525859"},"source":["MAE(dQ_values, dP_values)"],"execution_count":44,"outputs":[{"output_type":"execute_result","data":{"text/plain":["<tf.Tensor: shape=(), dtype=float32, numpy=0.21106979>"]},"metadata":{"tags":[]},"execution_count":44}]},{"cell_type":"code","metadata":{"id":"rGC2BjfxVYqF","executionInfo":{"status":"ok","timestamp":1614366220291,"user_tz":-60,"elapsed":71274,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["np.savez(f'{path_logs_training}/dPdQ_d{training_description}.npz', dP_values, dQ_values)"],"execution_count":45,"outputs":[]},{"cell_type":"code","metadata":{"id":"vKKst7k_2JLJ","executionInfo":{"status":"ok","timestamp":1614366227421,"user_tz":-60,"elapsed":442,"user":{"displayName":"Test Test","photoUrl":"","userId":"07602665060461436385"}}},"source":["model.save_weights(f\"{path_logs_training}/training/{training_description}_weights.h5\")"],"execution_count":46,"outputs":[]},{"cell_type":"code","metadata":{"id":"Rh0Q5W0JubnW"},"source":[""],"execution_count":null,"outputs":[]}]}