Skip to main content

Cython Based Fast FES Calculation Toolkit.

Project description

CyFES:GPU加速高性能数据透视工具

Hex.pm Hex.pm Hex.pm Hex.pm Hex.pm

介绍

这是一个使用Cython+CUDA+Python编写的高性能FES计算软件,可以用于加速数据透视的计算:

$$ E(x)=-kT\log\left(\frac{\sum_{j=1}^Ne^{\frac{V_j}{kT}}e^{-\frac{(x-n_j)^2}{2\sigma^2}}}{N\Pi_i\sqrt{2\pi}\sigma_i}\right) $$

安装

pip安装

本项目可以直接使用pip进行安装:

$ python3 -m pip install cyfes --user --upgrade -i https://pypi.org/simple

源码安装

首先将本仓库clone到本地:

$ git clone https://gitee.com/dechin/cy-fes.git && cd cy-fes/

然后直接运行setup.py进行安装:

$ python3 -m pip install .

安装测试

在本仓库的test路径下存放了一个测试用例,用于测试cyfes是否安装成功。用户可以直接简单的运行:

$ python3 tests/test_path_fes.py 
[0.00902854 0.         0.09338432 0.02065182]
[0.03961432 0.         0.01514649 0.02259541]
[0.00129778 0.         0.02988457 0.0869869 ]
[0.01712827 0.01378975 0.         0.02229569]
[0.0114323  0.03356422 0.         0.0328276 ]

若输出为多个数组,则表示安装成功。也可以使用单元测试运行,但是这需要在本地先安装pytest

$ python3 -m pip install pytest

然后直接在仓库的根目录下运行:

$ py.test
============================ test session starts =============================
platform linux -- Python 3.7.5, pytest-7.4.4, pluggy-1.2.0
rootdir: /home/cy-fes
collected 5 items                                                            

tests/test_path_fes.py .....                                           [100%]

============================= 5 passed in 14.23s =============================

没有报错,则表示安装成功。

使用方法

在安装成功后,可以直接在Python脚本中调用:

import numpy as np
from cyfes import PathFES
np.random.seed(0)

def test_path_fes():
    atoms = 4
    cvs = 10000
    crd = np.random.random((atoms, 3))
    cv = np.random.random((cvs, 3))
    bw = np.random.random(3)
    bias = np.random.random(cvs)-1

    fes = np.asarray(PathFES(crd, cv, bw, bias))
    print (fes)

if __name__ == '__main__':
    test_path_fes()

还可以使用命令行模式:

$ python3 -m cyfes --help
usage: __main__.py [-h] [-i I] [-ic IC] [-ib IB] [-s S] [-e E] [-g G] [-o O]
                   [-no_bias NO_BIAS] [-f32 F32] [-sigma SIGMA]
                   [-device DEVICE]

optional arguments:
  -h, --help        show this help message and exit
  -i I              Set the input record file path.
  -ic IC            Set the cv index of input record file. Default: 0,1,2
  -ib IB            Set the bias index of input record file. Default: 3
  -s S              CV length. Default: None
  -e E              Edge length. Default: 1.0
  -g G              Grid numbers. Default: 10,10,10
  -o O              Set the output FES file path.
  -no_bias NO_BIAS  Do not use the bias from input file. Default: false
  -f32 F32          Use float32. Default: false
  -sigma SIGMA      Sigma value when calculating FES. Default: 0.3
  -device DEVICE    Set the device ids separated with commas. Default: 0

假如我们有一个三维的CV,那么最简单的运行方式为:

$ python3 -m cyfes -i /home/Data/xyz_bias.txt -o ./work_dir/z.cub

那么最后产生的文件内容为:

$ head -n 10 work_dir/z.cub
Generated by CyFES
Total	1000	grids
1	21.6622	19.8498	42.3652
10	6.40465	0	0
10	0	7.02147	0
10	0	0	6.33118
1	1.000000	53.6854	54.9571	74.0211
450	450	450	450	450	450	
450	450	450	450	450	450	
450	450	70.0855	70.848	450	450	

该cube格式的文件可以在支持的软件(如VMD)中进行可视化操作。

已知问题

  1. 使用numpy==1.22.2的版本中会出现ImportError: numpy.core.multiarray failed to import问题。解决方案:升级numpy版本:python3 -m pip install numpy --upgrade
  2. 执行python3 -m cyfes --help报错ModuleNotFoundError: No module named 'cyfes.wrapper',这是因为执行命令的目录下存在名为cyfes的文件夹,需要切换执行命令的位置。
  3. 使用cyfes出现Segmentation fault段错误问题,是因为找不到编译好的动态链接库文件,大概率是系统环境下权限不足,没有site路径的权限,可以使用如下脚本进行检查:
# check_dynamics.py
import os
import site
from pathlib import Path

site_path = Path(site.getsitepackages()[0])
site_file_path = site_path.parent.parent.parent / 'cyfes' / 'libcufes.so'
site_dynamics_path = str(site_file_path)

user_site_path = Path(site.USER_SITE)
user_file_path = user_site_path.parent.parent.parent / 'cyfes' / 'libcufes.so'
user_dynamics_path = str(user_file_path)

if not os.path.exists(site_dynamics_path) and not os.path.exists(user_dynamics_path):
    print ('Check dynamics complete, no libcufes.so file founded!')
else:
    print ('Installation of CyFES success!')

使用python3运行该脚本,即可判断动态链接库是否被正确安装。

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

CyFES-3.4.tar.gz (346.8 kB view details)

Uploaded Source

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

CyFES-3.4-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.7 MB view details)

Uploaded CPython 3.10manylinux: glibc 2.17+ x86-64

CyFES-3.4-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.7 MB view details)

Uploaded CPython 3.9manylinux: glibc 2.17+ x86-64

CyFES-3.4-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.7 MB view details)

Uploaded CPython 3.8manylinux: glibc 2.17+ x86-64

CyFES-3.4-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (1.6 MB view details)

Uploaded CPython 3.7mmanylinux: glibc 2.17+ x86-64

File details

Details for the file CyFES-3.4.tar.gz.

File metadata

  • Download URL: CyFES-3.4.tar.gz
  • Upload date:
  • Size: 346.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.7.5

File hashes

Hashes for CyFES-3.4.tar.gz
Algorithm Hash digest
SHA256 04e33a48dfbaf1d6de128ed56f2580b38567e92e75700a2928e8b8c4d158351b
MD5 498727ab4a12a751489a90e3aa12bcef
BLAKE2b-256 d9627eb3d00235b2533afb409d473f80cd013b9a57c60ca14947f6d65fac9c48

See more details on using hashes here.

File details

Details for the file CyFES-3.4-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for CyFES-3.4-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 0c37929e1cf68a7088aa1c01ff1b978897879d10786b63d7acab3c46e727c106
MD5 386276b811ab5c102906948f131ca8d9
BLAKE2b-256 e9702166f2446b0d0dc501f7891ba6e92f5f2efefea1a77cc2f791b486e47a30

See more details on using hashes here.

File details

Details for the file CyFES-3.4-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for CyFES-3.4-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 651e5306219e0ea6924909b4fc19ef0ba28e68a662da8925602a65d90dc02886
MD5 e130a480ee9da8231ea1b073e3efa728
BLAKE2b-256 c6f88c0cd3fad514acbbfeda8bbaa4bcf2c3d71b7a2263af1a7298d0b9fcad63

See more details on using hashes here.

File details

Details for the file CyFES-3.4-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for CyFES-3.4-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 e42a2b5a9957a3d5c8b55c77a08f41c03d305e11435df335bfaeccf9cc3b6471
MD5 eda3b0fc53c2af2c7daccedc09b1dd36
BLAKE2b-256 d8375fe5074e83763bd5c92ba64a789b6f3b1d393d52b111ca49f5fe8fe46935

See more details on using hashes here.

File details

Details for the file CyFES-3.4-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for CyFES-3.4-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 58471c9d9e3ff4afa75766797dc6ae196c725bac82bb1bdbf10ca5e926da488c
MD5 15c9826b1a6f39745f7c1eaff8df7f9e
BLAKE2b-256 b6ac6a5344b9f0fbce7e7df33cab88ee067be6bdb033561ffee7f5521e60b026

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page