Skip to content

Commit

Permalink
Develop (#55)
Browse files Browse the repository at this point in the history
* Rework readme (#6)

* Renamed actions and added badges to readme

* Switched slash for dash

* Fix import structure (#10)

* Fixed import structure

* Removed pull_request target as push also seems to trigger on pull request?

* Fix visualization helpers (#13)

* Fixed bugs

* Added pull_request again as trigger for workflow

* Update build_deploy.yml

* Fix compressing core and installed pre-commit (#15)

* Pre-commit test

* Added local hook for zipping core

* Added .zip and .tar.gz autozips into core_archives folder

* Zip test

* tar.gz test

* Compressing works, only really ugly workaround for moving files

* Refered to the archives in the README

* Fix datasets (#17)

* Release v0.2a1 (#14)

* Rework readme (#6)

* Renamed actions and added badges to readme

* Switched slash for dash

* Fix import structure (#10)

* Fixed import structure

* Removed pull_request target as push also seems to trigger on pull request?

* Fix visualization helpers (#13)

* Fixed bugs

* Added pull_request again as trigger for workflow

* Deleted old log file and changed setup version

* Restructured dataset files and added package_data to setup.py, also changed max-line-length for black to 79

* New setup for loading datasets

* Added dataset inclusion

* Added archiving for datasets

* Test for matrix include (#18)

* Test for matrix include

* Added runOns variable

* Changed to a custom action

* Added inputFile

* Copied literal line

* Changed strategy order

* Check only ubuntu

* Extended matrix with all OS and extra CIBW_BUILD ENV flag

* Added default of only python 3.6 builds for 64-bit if push is not to master

* Added enter to README

* Release v0.2a2 (#20)

* Release v0.2a1 (#14)

* Rework readme (#6)

* Renamed actions and added badges to readme

* Switched slash for dash

* Fix import structure (#10)

* Fixed import structure

* Removed pull_request target as push also seems to trigger on pull request?

* Fix visualization helpers (#13)

* Fixed bugs

* Added pull_request again as trigger for workflow

* Deleted old log file and changed setup version

* Changed master trigger to release trigger

* Moved wildcard

* Moved wildcard of JMESPath

* Added dot

* Trying starts_with

* Switched arguments

* Excluded python 2.7 pypy

* New jmespath filter test

* Changed version number

* Add PyTest to repo and CI (#21)

* Added first pytest script for protein class and a script for performing local tests.

* Added pytest in CI

* Forgot -r for file

* Version of pytest with pytest at end of pipeline

* New pytest CI where pip installs local package

* Fixed tabs and added caching of python/pip environment

* Removed dot and added removal of build dirs to manage clean command

* Added cache ignores for env setup and ids for the caches

* Fixed cache IDs

* Renamed cache because GitHub does not allow for clearing caches...

* Moved python setup to be before cache loading

* Run that will install the dependencies

* Uncommented the cache-hit detection for installing dependencies

* Updated pre-commit version in hope that runner will create new cache

* Added more tests and added flake8 incompatability

* Other flake8 config try

* Reset to .flake8 file

* Downgrade of pre-commit to force dep. installation in CI

* Different pre-commit version

* Added depth_first tests

* Added depth_first_bnb tests

* Push to try and install all dependencies correctly

* Added back cache check for installing dependencies. New way of calling flake8, added class dependencies on tests

* Removed ls

* Core change test

* Core change test - new correctly

* Core archiving works

* Fixed pytest ordering and upgraded pandas version to trigger new cache

* Upgraded pandas

* Changed pandas version to 1.1.0

* Removed caching of CI and moved code to new PR

* Add CI caching for python environments (#23)

* Added first pytest script for protein class and a script for performing local tests.

* Added pytest in CI

* Forgot -r for file

* Version of pytest with pytest at end of pipeline

* New pytest CI where pip installs local package

* Fixed tabs and added caching of python/pip environment

* Removed dot and added removal of build dirs to manage clean command

* Added cache ignores for env setup and ids for the caches

* Fixed cache IDs

* Renamed cache because GitHub does not allow for clearing caches...

* Moved python setup to be before cache loading

* Run that will install the dependencies

* Uncommented the cache-hit detection for installing dependencies

* Updated pre-commit version in hope that runner will create new cache

* Added more tests and added flake8 incompatability

* Other flake8 config try

* Reset to .flake8 file

* Downgrade of pre-commit to force dep. installation in CI

* Different pre-commit version

* Added depth_first tests

* Added depth_first_bnb tests

* Push to try and install all dependencies correctly

* Added back cache check for installing dependencies. New way of calling flake8, added class dependencies on tests

* Removed ls

* Core change test

* Core change test - new correctly

* Core archiving works

* Fixed pytest ordering and upgraded pandas version to trigger new cache

* Upgraded pandas

* Changed pandas version to 1.1.0

* Dependency check

* new flake8 installation

* Flake8 action

* Added pip update flag

* Cleaned up the flake8 action usage

* Trying to install new deps

* Removed caching, only using dependencies during pytest

* Add documentation to project (#24)

* Ran the sphinx quickstart, ignored mypy on docs

* First version of docs

* Added installation instructions for python

* Finished installation page and added quickstart info (not done yet)

* Finished v1 of the quickstart guide

* Removed heterogeneous setup page and added todo for creating example

* Added manpages for the datasets and algorithms

* Added helpers and visualize documentation

* Added placeholders for the Protein properties

* Added methods of Protein to the documentation

* Small changes

* Reworked the README

* Added whitespace for enter

* Added github star and filler-logo

* Starting on logo

* Added logo

* Removed github fork banner

* Logo test

* Changed logo loading

* New test

* Trying image tag

* Trying image tag 2.0

* Trying image tag 2.0

* Trying relative link

* New size

* New logo test

* New logo try

* New logo

* Reworked logo

* Downgraded matplotlib to alllow CI pipeline

* Added edittable logo, fixed small rst things, fixed compression of cores

* Added some figures, added reference to license, added license

* Started on AminoAcid class (#28)

* Started on AminoAcid class

* Added comments in core, still bugs to sort out

* Fixed more bugs in the core when adding AminoAcid class

* Moved part of bind

* Integrated AminoAcid class and fixed Protein tests

* Mid way testing for new depth-first approach

* Added local check script and depth_first works for HPPH

* Fixed depth_first search new version

* Fixed depth_first_bnb algorithm using new system

* Fixed small core bugs, working on new logo

* Mid-way of changing bond_value  structure

* Cleaned up bugs from intermediate version. Bumped versions of requirements. Introduced max_weights string for keeping track of possible future scores. Merged bond_semetry model setup with the else model setup. Fixed bug with cur_len of protein always being 1. Fixed getting the weight of a amino bond

* Bumbed python version in github workflow for matplotlib version dependency

* Bumped workflow python version to 3.9 as numpy 1.23 requires so

* Removed h_idxs from prune function. Nothing has been tested

* Fixed Protein signature for pybind build

* Setup for debugging current protein issues

* Introduced core testing code

* Finished test script for amino acids

* Started on Protein core tests

* Fixed protein test compilation

* Fixed first couple protein generation checks

* Added more debug statements for core tests

* Fixed bugs with bond checks

* Fixed generation of weighted amino maps

* Finished all protein generation test

* Added debug options in script to run core tests with gdb

* Added removal of amino tests

* Updated some pytest asserts. Added pytest and core_test asserts for score updates

* Updated reference for black in pre-commit

* Try adding core build in github actions pipeline

* Fixed local algorithm core tests

* Fixed dfs_bnb

* Fixed pybind11 change to providing protein pointers

* Added special compilation case for MacOS

* Changed minimum Python version to 3.9 as 3.11 will release soon

* Changed always build to only build python 3.9 versions

* Changed CIwheel builds to be specific instead of exlcuding based

* Leaving documentation as is and adding issue for the future

* Added more licensing references

* Added config file for rtfd to set python version to 3.9

* Temp commit to switch branch

* Update core merge (#33)

* Started on AminoAcid class

* Added comments in core, still bugs to sort out

* Fixed more bugs in the core when adding AminoAcid class

* Moved part of bind

* Integrated AminoAcid class and fixed Protein tests

* Mid way testing for new depth-first approach

* Added local check script and depth_first works for HPPH

* Fixed depth_first search new version

* Fixed depth_first_bnb algorithm using new system

* Fixed small core bugs, working on new logo

* Mid-way of changing bond_value  structure

* Cleaned up bugs from intermediate version. Bumped versions of requirements. Introduced max_weights string for keeping track of possible future scores. Merged bond_semetry model setup with the else model setup. Fixed bug with cur_len of protein always being 1. Fixed getting the weight of a amino bond

* Bumbed python version in github workflow for matplotlib version dependency

* Bumped workflow python version to 3.9 as numpy 1.23 requires so

* Removed h_idxs from prune function. Nothing has been tested

* Fixed Protein signature for pybind build

* Setup for debugging current protein issues

* Introduced core testing code

* Finished test script for amino acids

* Started on Protein core tests

* Fixed protein test compilation

* Fixed first couple protein generation checks

* Added more debug statements for core tests

* Fixed bugs with bond checks

* Fixed generation of weighted amino maps

* Finished all protein generation test

* Added debug options in scriptn to run core tests with gdb

* Fixed the last_pos indexing error from place_amino. Changed the 'changed' variable to 'solutions_found'-like variable

* Solved typing issues

* Finished protein movement tests

* Added removal of amino tests

* Updated some pytest asserts. Added pytest and core_test asserts for score updates

* Updated reference for black in pre-commit

* Fixed score generation of core_test

* Fixed score update through removal

* Try adding core build in github actions pipeline

* Started on algorithm code

* Changed signature of depth_first to use pointers. Added testing code for 2d and 3d depth_first tests

* Fixed local algorithm core tests

* Fixed dfs_bnb

* Fixed pybind11 change to providing protein pointers

* Added dynamic_lookup for linking python in case of undefined symbols

* New way of setting -undefined flag

* Updated the way of passing -undefined setting for macos

* Added special compilation case for MacOS

* Saving Furo update for issue

* Changed minimum Python version to 3.9 as 3.11 will release soon

* Updated versions for wheel deployment

* Changed always build to only build python 3.9 versions

* Changed CIwheel builds to be specific instead of exlcuding based

* Leaving documentation as is and adding issue for the future

* Added more licensing references

* Added config file for rtfd to set python version to 3.9

* Removed commented code

* Merge visualization updates (#41) (#42)

* Develop merge into master to sync commits. (#41)

* Rework readme (#6)

* Renamed actions and added badges to readme

* Switched slash for dash

* Fix import structure (#10)

* Fixed import structure

* Removed pull_request target as push also seems to trigger on pull request?

* Fix visualization helpers (#13)

* Fixed bugs

* Added pull_request again as trigger for workflow

* Update build_deploy.yml

* Fix compressing core and installed pre-commit (#15)

* Pre-commit test

* Added local hook for zipping core

* Added .zip and .tar.gz autozips into core_archives folder

* Zip test

* tar.gz test

* Compressing works, only really ugly workaround for moving files

* Refered to the archives in the README

* Fix datasets (#17)

* Release v0.2a1 (#14)

* Rework readme (#6)

* Renamed actions and added badges to readme

* Switched slash for dash

* Fix import structure (#10)

* Fixed import structure

* Removed pull_request target as push also seems to trigger on pull request?

* Fix visualization helpers (#13)

* Fixed bugs

* Added pull_request again as trigger for workflow

* Deleted old log file and changed setup version

* Restructured dataset files and added package_data to setup.py, also changed max-line-length for black to 79

* New setup for loading datasets

* Added dataset inclusion

* Added archiving for datasets

* Test for matrix include (#18)

* Test for matrix include

* Added runOns variable

* Changed to a custom action

* Added inputFile

* Copied literal line

* Changed strategy order

* Check only ubuntu

* Extended matrix with all OS and extra CIBW_BUILD ENV flag

* Added default of only python 3.6 builds for 64-bit if push is not to master

* Added enter to README

* Release v0.2a2 (#20)

* Release v0.2a1 (#14)

* Rework readme (#6)

* Renamed actions and added badges to readme

* Switched slash for dash

* Fix import structure (#10)

* Fixed import structure

* Removed pull_request target as push also seems to trigger on pull request?

* Fix visualization helpers (#13)

* Fixed bugs

* Added pull_request again as trigger for workflow

* Deleted old log file and changed setup version

* Changed master trigger to release trigger

* Moved wildcard

* Moved wildcard of JMESPath

* Added dot

* Trying starts_with

* Switched arguments

* Excluded python 2.7 pypy

* New jmespath filter test

* Changed version number

* Add PyTest to repo and CI (#21)

* Added first pytest script for protein class and a script for performing local tests.

* Added pytest in CI

* Forgot -r for file

* Version of pytest with pytest at end of pipeline

* New pytest CI where pip installs local package

* Fixed tabs and added caching of python/pip environment

* Removed dot and added removal of build dirs to manage clean command

* Added cache ignores for env setup and ids for the caches

* Fixed cache IDs

* Renamed cache because GitHub does not allow for clearing caches...

* Moved python setup to be before cache loading

* Run that will install the dependencies

* Uncommented the cache-hit detection for installing dependencies

* Updated pre-commit version in hope that runner will create new cache

* Added more tests and added flake8 incompatability

* Other flake8 config try

* Reset to .flake8 file

* Downgrade of pre-commit to force dep. installation in CI

* Different pre-commit version

* Added depth_first tests

* Added depth_first_bnb tests

* Push to try and install all dependencies correctly

* Added back cache check for installing dependencies. New way of calling flake8, added class dependencies on tests

* Removed ls

* Core change test

* Core change test - new correctly

* Core archiving works

* Fixed pytest ordering and upgraded pandas version to trigger new cache

* Upgraded pandas

* Changed pandas version to 1.1.0

* Removed caching of CI and moved code to new PR

* Add CI caching for python environments (#23)

* Added first pytest script for protein class and a script for performing local tests.

* Added pytest in CI

* Forgot -r for file

* Version of pytest with pytest at end of pipeline

* New pytest CI where pip installs local package

* Fixed tabs and added caching of python/pip environment

* Removed dot and added removal of build dirs to manage clean command

* Added cache ignores for env setup and ids for the caches

* Fixed cache IDs

* Renamed cache because GitHub does not allow for clearing caches...

* Moved python setup to be before cache loading

* Run that will install the dependencies

* Uncommented the cache-hit detection for installing dependencies

* Updated pre-commit version in hope that runner will create new cache

* Added more tests and added flake8 incompatability

* Other flake8 config try

* Reset to .flake8 file

* Downgrade of pre-commit to force dep. installation in CI

* Different pre-commit version

* Added depth_first tests

* Added depth_first_bnb tests

* Push to try and install all dependencies correctly

* Added back cache check for installing dependencies. New way of calling flake8, added class dependencies on tests

* Removed ls

* Core change test

* Core change test - new correctly

* Core archiving works

* Fixed pytest ordering and upgraded pandas version to trigger new cache

* Upgraded pandas

* Changed pandas version to 1.1.0

* Dependency check

* new flake8 installation

* Flake8 action

* Added pip update flag

* Cleaned up the flake8 action usage

* Trying to install new deps

* Removed caching, only using dependencies during pytest

* Add documentation to project (#24)

* Ran the sphinx quickstart, ignored mypy on docs

* First version of docs

* Added installation instructions for python

* Finished installation page and added quickstart info (not done yet)

* Finished v1 of the quickstart guide

* Removed heterogeneous setup page and added todo for creating example

* Added manpages for the datasets and algorithms

* Added helpers and visualize documentation

* Added placeholders for the Protein properties

* Added methods of Protein to the documentation

* Small changes

* Reworked the README

* Added whitespace for enter

* Added github star and filler-logo

* Starting on logo

* Added logo

* Removed github fork banner

* Logo test

* Changed logo loading

* New test

* Trying image tag

* Trying image tag 2.0

* Trying image tag 2.0

* Trying relative link

* New size

* New logo test

* New logo try

* New logo

* Reworked logo

* Downgraded matplotlib to alllow CI pipeline

* Added edittable logo, fixed small rst things, fixed compression of cores

* Added some figures, added reference to license, added license

* Started on AminoAcid class (#28)

* Started on AminoAcid class

* Added comments in core, still bugs to sort out

* Fixed more bugs in the core when adding AminoAcid class

* Moved part of bind

* Integrated AminoAcid class and fixed Protein tests

* Mid way testing for new depth-first approach

* Added local check script and depth_first works for HPPH

* Fixed depth_first search new version

* Fixed depth_first_bnb algorithm using new system

* Fixed small core bugs, working on new logo

* Mid-way of changing bond_value  structure

* Cleaned up bugs from intermediate version. Bumped versions of requirements. Introduced max_weights string for keeping track of possible future scores. Merged bond_semetry model setup with the else model setup. Fixed bug with cur_len of protein always being 1. Fixed getting the weight of a amino bond

* Bumbed python version in github workflow for matplotlib version dependency

* Bumped workflow python version to 3.9 as numpy 1.23 requires so

* Removed h_idxs from prune function. Nothing has been tested

* Fixed Protein signature for pybind build

* Setup for debugging current protein issues

* Introduced core testing code

* Finished test script for amino acids

* Started on Protein core tests

* Fixed protein test compilation

* Fixed first couple protein generation checks

* Added more debug statements for core tests

* Fixed bugs with bond checks

* Fixed generation of weighted amino maps

* Finished all protein generation test

* Added debug options in script to run core tests with gdb

* Added removal of amino tests

* Updated some pytest asserts. Added pytest and core_test asserts for score updates

* Updated reference for black in pre-commit

* Try adding core build in github actions pipeline

* Fixed local algorithm core tests

* Fixed dfs_bnb

* Fixed pybind11 change to providing protein pointers

* Added special compilation case for MacOS

* Changed minimum Python version to 3.9 as 3.11 will release soon

* Changed always build to only build python 3.9 versions

* Changed CIwheel builds to be specific instead of exlcuding based

* Leaving documentation as is and adding issue for the future

* Added more licensing references

* Added config file for rtfd to set python version to 3.9

* Temp commit to switch branch

* Update core merge (#33)

* Started on AminoAcid class

* Added comments in core, still bugs to sort out

* Fixed more bugs in the core when adding AminoAcid class

* Moved part of bind

* Integrated AminoAcid class and fixed Protein tests

* Mid way testing for new depth-first approach

* Added local check script and depth_first works for HPPH

* Fixed depth_first search new version

* Fixed depth_first_bnb algorithm using new system

* Fixed small core bugs, working on new logo

* Mid-way of changing bond_value  structure

* Cleaned up bugs from intermediate version. Bumped versions of requirements. Introduced max_weights string for keeping track of possible future scores. Merged bond_semetry model setup with the else model setup. Fixed bug with cur_len of protein always being 1. Fixed getting the weight of a amino bond

* Bumbed python version in github workflow for matplotlib version dependency

* Bumped workflow python version to 3.9 as numpy 1.23 requires so

* Removed h_idxs from prune function. Nothing has been tested

* Fixed Protein signature for pybind build

* Setup for debugging current protein issues

* Introduced core testing code

* Finished test script for amino acids

* Started on Protein core tests

* Fixed protein test compilation

* Fixed first couple protein generation checks

* Added more debug statements for core tests

* Fixed bugs with bond checks

* Fixed generation of weighted amino maps

* Finished all protein generation test

* Added debug options in scriptn to run core tests with gdb

* Fixed the last_pos indexing error from place_amino. Changed the 'changed' variable to 'solutions_found'-like variable

* Solved typing issues

* Finished protein movement tests

* Added removal of amino tests

* Updated some pytest asserts. Added pytest and core_test asserts for score updates

* Updated reference for black in pre-commit

* Fixed score generation of core_test

* Fixed score update through removal

* Try adding core build in github actions pipeline

* Started on algorithm code

* Changed signature of depth_first to use pointers. Added testing code for 2d and 3d depth_first tests

* Fixed local algorithm core tests

* Fixed dfs_bnb

* Fixed pybind11 change to providing protein pointers

* Added dynamic_lookup for linking python in case of undefined symbols

* New way of setting -undefined flag

* Updated the way of passing -undefined setting for macos

* Added special compilation case for MacOS

* Saving Furo update for issue

* Changed minimum Python version to 3.9 as 3.11 will release soon

* Updated versions for wheel deployment

* Changed always build to only build python 3.9 versions

* Changed CIwheel builds to be specific instead of exlcuding based

* Leaving documentation as is and adding issue for the future

* Added more licensing references

* Added config file for rtfd to set python version to 3.9

* Removed commented code

* Splitted visualization function to allow for multiple styles

* Fixed function for plotting proteins

* Fixed bug where no bonds would form

* Fixed paper style

* V1 paper style plots

* Fixed first paper visualization. Added visualization to test set

* Ran pre-commit

* Increased version to make new visualizations available

* Add beam (#47)

* V1 (untested) of a beam_search function

* Compiles and runs, does not work

* In mids of debug

* Small changes

* Changed wrong author usage in toml. Fixing copy issues with proteins and amino acids

* Fixed copy operators for Protein and AminoAcid

* Fixed bug in assignment and copy operators. New try for testing beam, which is also semi fixed

* Fixed beam_search bugs

* Added a more specific heuristic function for beam search and removed unnescessary branching in reach_prune

* Solved bug in beam_search and add protein length to print

* Finished beam search tests

* Extended AminoAcid with << and = operator overloads

* Added ptests for beam search and naive prune

* Fixed typo for beam search class

* Trying other pytest approach for mac

* Trying run-on conditional from matrix

* Removed file specifier for pytest

* Added Windows runner check to linux

* Enabled windows runner again

* ALso removed big beam width

* Removing dir slash in setuptools for windows buil

* Removed windows due to Pybind11 bug

* 32 change documentation to match core functionality (#53)

* Made abstraction for version identification. Changed docs style to Furo. Updated internal contents to match core more. Visualization and Datasets still need to be done, as well as more visualizations

* Wrote more on visualization and datasets. Only need to add correct figures, and fix pipeline issue when generating the core

* Fixed versioning and importing for compilation. Added new figures for quickstart docs

* Added last missing method

* Added AminoAcid class to the API focs

* Added beam search to the docs api

* Added furo to docs requirements.txt

* Trying different configuration for building readthedocs

* Removed versioning

* Exended and pinned requirements for docs

* Changed python version to make readthedocs work. Also changed some small things

* More minimal setup for furo

* Upped versioning and new try for dong data reading

* Removed commented code

* Trying Windows build again

* Trying full pytest on MacOS

* Different Pip upgrade line for window

* Excluded Windows again because it wants to be a special snowflake..

* Upped pybind in setup
  • Loading branch information
okkevaneck authored Jul 16, 2023
1 parent 7c1a30b commit 24e68a3
Show file tree
Hide file tree
Showing 23 changed files with 389 additions and 88 deletions.
12 changes: 6 additions & 6 deletions .github/workflows/matrix_includes.BAK
Original file line number Diff line number Diff line change
Expand Up @@ -3,37 +3,37 @@
"runOn": "master",
"os": "ubuntu-latest",
"cibw_skip": "",
"cibw_build": "cp39-* cp310-* pp37-* pp38-* pp39-*"
"cibw_build": "cp39-* cp310-* pp39-*"
},
{
"runOn": "master",
"os": "windows-latest",
"cibw_skip": "",
"cibw_build": "cp39-* cp310-* pp37-* pp38-* pp39-*"
"cibw_build": "cp39-* cp310-* pp39-*"
},
{
"runOn": "master",
"os": "macos-latest",
"cibw_skip": "",
"cibw_build": "cp39-* cp310-* pp37-* pp38-* pp39-*"
"cibw_build": "cp39-* cp310-* pp39-*"
},
{
"runOn": "release-",
"os": "ubuntu-latest",
"cibw_skip": "",
"cibw_build": "cp39-* cp310-* pp37-* pp38-* pp39-*"
"cibw_build": "cp39-* cp310-* pp39-*"
},
{
"runOn": "release-",
"os": "windows-latest",
"cibw_skip": "",
"cibw_build": "cp39-* cp310-* pp37-* pp38-* pp39-*"
"cibw_build": "cp39-* cp310-* pp39-*"
},
{
"runOn": "release-",
"os": "macos-latest",
"cibw_skip": "",
"cibw_build": "cp39-* cp310-* pp37-* pp38-* pp39-*"
"cibw_build": "cp39-* cp310-* pp39-*"
},
{
"runOn": "always",
Expand Down
8 changes: 4 additions & 4 deletions .github/workflows/matrix_includes.json
Original file line number Diff line number Diff line change
Expand Up @@ -3,25 +3,25 @@
"runOn": "master",
"os": "ubuntu-latest",
"cibw_skip": "",
"cibw_build": "cp39-* cp310-* pp37-* pp38-* pp39-*"
"cibw_build": "cp39-* cp310-* pp39-*"
},
{
"runOn": "master",
"os": "macos-latest",
"cibw_skip": "",
"cibw_build": "cp39-* cp310-* pp37-* pp38-* pp39-*"
"cibw_build": "cp39-* cp310-* pp39-*"
},
{
"runOn": "release-",
"os": "ubuntu-latest",
"cibw_skip": "",
"cibw_build": "cp39-* cp310-* pp37-* pp38-* pp39-*"
"cibw_build": "cp39-* cp310-* pp39-*"
},
{
"runOn": "release-",
"os": "macos-latest",
"cibw_skip": "",
"cibw_build": "cp39-* cp310-* pp37-* pp38-* pp39-*"
"cibw_build": "cp39-* cp310-* pp39-*"
},
{
"runOn": "always",
Expand Down
11 changes: 9 additions & 2 deletions .readthedocs.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -3,8 +3,15 @@ version: 2
build:
os: "ubuntu-20.04"
tools:
python: "3.10"
python: "3.9"

# Build from the docs/ directory with Sphinx
# Build from the docs/ directory with Sphinx.
sphinx:
configuration: docs/source/conf.py

# Install Python requirements.
python:
install:
- requirements: docs/requirements.txt
- method: pip
path: .
6 changes: 5 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,12 +2,16 @@
<p align="center">
<img src="docs/source/_static/prospr_logo.png" alt="Prospr's logo" width="496" height="308">
</p>
<div align="center">

![GitHub](https://img.shields.io/github/license/OkkeVanEck/prospr)
![GitHub release (latest by date including pre-releases)](https://img.shields.io/github/v/release/OkkeVanEck/prospr?include_prereleases)
![GitHub Workflow Status (branch)](https://img.shields.io/github/actions/workflow/status/OkkeVanEck/prospr/.github/workflows/build_deploy.yml?branch=master)
[![Documentation Status](https://readthedocs.org/projects/prospr/badge/?version=latest)](https://prospr.readthedocs.io/en/latest/?badge=latest)
[![pre-commit](https://img.shields.io/badge/pre--commit-enabled-brightgreen?logo=pre-commit&logoColor=white)](https://github.com/pre-commit/pre-commit)
[![pre-commit](https://img.shields.io/badge/pre--commit-enabled-brightgreen?logo=pre-commit&logoColor=white)](https://github.com/pre-commit/pre-commit)

</div>

**Creator:** Okke van Eck

Prospr is a universal toolbox for protein structure prediction within the
Expand Down
3 changes: 3 additions & 0 deletions docs/requirements.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
Sphinx==7.0.1
docutils==0.20.01
furo==2023.5.20
Binary file modified docs/source/_static/prospr_logo.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file removed docs/source/_static/prospr_logo.xcf
Binary file not shown.
Binary file added docs/source/_static/quickstart_basic.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added docs/source/_static/quickstart_paper.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added docs/source/_static/quickstart_paper_outer.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
150 changes: 143 additions & 7 deletions docs/source/api.rst
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ specifying a submodule, e.g.
| *Returns:*
| * **Protein** - the Protein object set at the found
conformation and with updated properties according to the
performedmoves.
performed moves.
| **depth_first_bnb**\ (*protein*)
| Finds the most optimal conformation using a depth-first
Expand All @@ -37,9 +37,85 @@ specifying a submodule, e.g.
| * **protein** - *Protein*: the Protein object to fold.
| *Returns:*
| * **Protein** - the Protein object set at the found
conformationand with updated properties according to the
conformation and with updated properties according to the
performed moves.
| **beam_search**\ (*protein, beam_width=-1*)
| Finds a best-effort conformation using a beam search algorithm.
| *Does not reset the Protein properties beforehand!*
| *Parameters:*
| * **protein** - *Protein*: the Protein object to fold.
| * **beam_width** - *int (optional)*: the beam width to use,
where -1 indicates traversal of the entire search space.
| *Returns:*
| * **Protein** - the Protein object set at the found
conformation and with updated properties according to the
performed moves.
AminoAcid - core
----------------
Protein objects use AminoAcid objects internally to keep track of the chain on
the grid. AminoAcid objects have read-only properties, which are consulted
internally by the Protein object. The AminoAcid class can be imported directly
from *prospr* without specifying a submodule, e.g.

.. code-block:: python
from prospr import AminoAcid
AminoAcid Properties
~~~~~~~~~~~~~~~~~~~~
When using the Python package, each property can be directly called as an
attribute. If the C++ core is used, the property can be accessed using a method.
Each property is described below with the Python and C++ syntax for accessing
them.

| **type**
| Type of the AminoAcid.
+-----------------+---------------+
| **Python** | *.type* |
+-----------------+---------------+
| **C++** | *.get_type()* |
+-----------------+---------------+
| **Return type** | *str* |
+-----------------+---------------+

| **index**
| Index of the AminoAcid within the Protein's sequence.
+-----------------+----------------+
| **Python** | *.index* |
+-----------------+----------------+
| **C++** | *.get_index()* |
+-----------------+----------------+
| **Return type** | *int* |
+-----------------+----------------+

| **prev_move**
| Move to perform in order to get to the previous AminoAcid in the
chain.
+-----------------+--------------------+
| **Python** | *.prev_move* |
+-----------------+--------------------+
| **C++** | *.get_prev_move()* |
+-----------------+--------------------+
| **Return type** | *int* |
+-----------------+--------------------+

| **next_move**
| Move to perform in order to get to the next AminoAcid in the chain.
+-----------------+--------------------+
| **Python** | *.next_move* |
+-----------------+--------------------+
| **C++** | *.get_next_move()* |
+-----------------+--------------------+
| **Return type** | *int* |
+-----------------+--------------------+


Datasets
--------
Prospr provides many datasets. Each can be imported from the *prospr.datasets*
Expand All @@ -61,11 +137,23 @@ submodule, e.g.
sequences.
| **load_vanEck1000**\ (*length=10*)
| Loads the vanEck250 dataset containing 1000 proteins per length, with
lengths from 10 till 100.
| Loads the vanEck1000 dataset containing 1000 proteins per length,
with lengths from 10 till 100.
| *Parameters:*
| * **length** - *int (optional)*: the length of the protein
sequences to load.
| *Returns:*
| * **DataFrame** - a Pandas DataFrame containing the protein
sequences.
| **load_vanEck_hratio**\ (*length=25, hratio=0.1*)
| Loads the vanEck_hratio dataset containing proteins per length and
hratio combination.
| *Parameters:*
| * **length** - *int (optional)*: the length of the protein
sequences to load.
| * **hratio** - *float (optional)*: the hratio upperbound of
the hratio interval to use.
| *Returns:*
| * **DataFrame** - a Pandas DataFrame containing the protein
sequences.
Expand Down Expand Up @@ -130,13 +218,24 @@ directly from *prospr* without specifying a submodule, e.g.
from prospr import Protein
..
Properties
~~~~~~~~~~
Protein Properties
~~~~~~~~~~~~~~~~~~
When using the Python package, each property can be directly called as an
attribute. If the C++ core is used, the property can be accessed using a method.
Each property is described below with the Python and C++ syntax for accessing
them.

| **bond_values**
| The ways to form bonds and their stability.
+-----------------+----------------------+
| **Python** | *.bond_values* |
+-----------------+----------------------+
| **C++** | *.get_bond_values()* |
+-----------------+----------------------+
| **Return type** | *Dict[str, int]* |
+-----------------+----------------------+

| **changes**
| The number of amino acids placed so far.
Expand Down Expand Up @@ -203,6 +302,17 @@ them.
| **Return type** | *List[int]* |
+-----------------+-------------------+

| **max_weigths**
| For each amino acid, the maximum value a bond can make.
+-----------------+----------------------+
| **Python** | *.max_weigths* |
+-----------------+----------------------+
| **C++** | *.get_max_weigths()* |
+-----------------+----------------------+
| **Return type** | *List[int]* |
+-----------------+----------------------+

| **score**
| The score of the current conformation.
Expand Down Expand Up @@ -241,6 +351,15 @@ references below.
move.
| E.g. `[0, 1]`
| **.get_bonds**\ ()
| Returns a list of amino acid index pairs that are bonding.
| *Parameters:*
| * **None**
| *Returns:*
| * **List[Tuple[int,int]]** - a list of tuples with two amino
acid indexes that bond.
| E.g. `[(0, 9), (2, 9), (9, 2), (9, 0)]`
| **.hash_fold**\ ()
| Returns a list of moves representing the current conformation.
| *Parameters:*
Expand Down Expand Up @@ -313,10 +432,27 @@ e.g.
from prospr.visualize import plot_protein
..
| **plot_protein**\ (*protein*)
| **plot_protein**\ (*protein, style="basic", ax=None, legend=True,
legend_style="inner", show=True,*
| *linewidth=2.5, markersize=210, annotate_first=False*)
| Plots the current set conformation of the given Protein object.
| *Parameters:*
| * **protein** - *Protein*: a Protein object to plot the
conformation of.
| * **style** - *str (optional)*: The figure style to use,
either 'basic' or 'paper'.
| * **ax** - *Axes (optional)*: If given, plot the conformation
on the given Matplotlib Axes.
| * **legend** - *bool (optional)*: Set to False to disable the
legend.
| * **legend_style** - *str (optional)*: The legend style to
use, either 'inner' or 'outer'.
| * **show** - *bool (optional)*: Set to False to disable
plt.show() call.
| * **linewidth** - *float (optional)*: Line width of the chain.
| * **markersize** - *float (optional)*: Size of the amino
acids.
| * **annotate_first** - *float (optional)*: Set to True to
highlight first amino acid with a color.
| *Returns:*
| * **None**
Loading

0 comments on commit 24e68a3

Please sign in to comment.