forked from mosdef-hub/gmso
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge remote-tracking branch 'upstream/master' into 284-docstrings
- Loading branch information
Showing
25 changed files
with
917 additions
and
105,908 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1,56 @@ | ||
Contributing | ||
------------ | ||
plz help | ||
============ | ||
Contributions are welcomed via `pull requests on GitHub <https://github.com/mattwthompson/topology/pulls>`_. Developers and/or | ||
users will review requested changes and make comments. The rest of this file will serve as a set of general guidelines | ||
for contributors. | ||
|
||
Features | ||
-------- | ||
Implement functionality in a general and flexible fashion | ||
********************************************************* | ||
GMSO is designed to be general and flexible, not limited to single chemistries, file formats, simulation engines, or | ||
simulation methods. Additions to core features should attempt to provide something that is applicable to a variety of | ||
use-cases and not targeted at only the focus area of your research. However, some specific features targeted toward | ||
a limited use case may be appropriate. Speak to the developers before writing your code and they will help you make design | ||
choices that allow flexibility. | ||
|
||
Version control | ||
--------------- | ||
|
||
We currently use the "standard" Pull Request model. Contributions should be implemented on feature branches of forks. | ||
Please try to keep the `master` branch of your fork up-to-date with the `master` branch of the main repository. | ||
|
||
Propose a single set of related changes | ||
**************************************** | ||
|
||
Small changes are preferred over large changes. A major contribution can often be broken down into smaller PRs. Large PRs that | ||
affect many parts of the codebase can be harder to review and are more likely to cause merge conflicts. | ||
|
||
Source code | ||
----------- | ||
Use a consistent style | ||
************************* | ||
It is important to have a consistent style throughout the source code. The following criteria are desired: | ||
|
||
* Lines wrapped to 80 characters | ||
* Lines are indented with spaces | ||
* Lines do not end with whitespace | ||
* For other details, refer to `PEP8 <https://www.python.org/dev/peps/pep-0008>`_ | ||
|
||
To help with the above, there are tools such as `flake8 <https://pypi.org/project/flake8/>`_ and `Black <https://github.com/psf/black>`_. | ||
|
||
Document code with comments | ||
**************************** | ||
All public-facing functions should have docstrings using the numpy style. This includes concise paragraph-style description | ||
of what the class or function does, relevant limitations and known issues, and descriptions of arguments. Internal functions | ||
can have simple one-liner docstrings. | ||
|
||
|
||
Tests | ||
----- | ||
Write unit tests | ||
**************** | ||
All new functionality in GMSO should be tested with automatic unit tests that execute in a few seconds. These tests | ||
should attempt to cover all options that the user can select. All or most of the added lines of source code should be | ||
covered by unit test(s). We currently use `pytest <https://docs.pytest.org/en/latest/>`_, which can be executed simply by calling | ||
`pytest` from the root directory of the package. |
File renamed without changes.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,162 @@ | ||
{ | ||
"cells": [ | ||
{ | ||
"cell_type": "code", | ||
"execution_count": null, | ||
"metadata": {}, | ||
"outputs": [], | ||
"source": [ | ||
"!conda install --file env.txt --yes" | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"metadata": {}, | ||
"source": [ | ||
"This example requires LAMMPS. You can install it from source or conda via `conda install -c conda-forge lammps`.\n", | ||
"You also need to `pip install -e` the topology/gmso package after February 14, 2020, when PR #121 was merged." | ||
] | ||
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": null, | ||
"metadata": {}, | ||
"outputs": [], | ||
"source": [ | ||
"import warnings\n", | ||
"warnings.filterwarnings('ignore')\n", | ||
"\n", | ||
"import mbuild as mb\n", | ||
"import gmso\n", | ||
"from gmso.external.convert_mbuild import from_mbuild\n", | ||
"from gmso.formats.lammpsdata import write_lammpsdata" | ||
] | ||
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": null, | ||
"metadata": {}, | ||
"outputs": [], | ||
"source": [ | ||
"# Generate a small box of Argon atoms using mBuild\n", | ||
"ar = mb.Compound(name='Ar')\n", | ||
"\n", | ||
"packed_system = mb.fill_box(\n", | ||
" compound=ar,\n", | ||
" n_compounds=329,\n", | ||
" box=mb.Box([2.5, 2.5, 2.5]),\n", | ||
")\n", | ||
"\n", | ||
"packed_system.visualize()" | ||
] | ||
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": null, | ||
"metadata": {}, | ||
"outputs": [], | ||
"source": [ | ||
"# Convert system to a backend object\n", | ||
"top = from_mbuild(packed_system)\n", | ||
"\n", | ||
"# Load force field from XML\n", | ||
"ff = gmso.ForceField('ar.xml')\n", | ||
"ar_type = ff.atom_types['Ar']\n", | ||
"\n", | ||
"# Manually set types, bypassing foyer or any atomtyping engine\n", | ||
"for site in top.sites:\n", | ||
" site.atom_type = ar_type\n", | ||
"\n", | ||
"top.update_topology()\n", | ||
"\n", | ||
"# Save files to disk\n", | ||
"write_lammpsdata(top, 'data.ar')" | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"metadata": {}, | ||
"source": [ | ||
"Next, we run the simulations (energy minimizaiton and then NVE MD) using LAMMPS" | ||
] | ||
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": null, | ||
"metadata": {}, | ||
"outputs": [], | ||
"source": [ | ||
"!lmp_serial < in.argon" | ||
] | ||
}, | ||
{ | ||
"cell_type": "markdown", | ||
"metadata": {}, | ||
"source": [ | ||
"Finally we can use use `numpy` and `matplotlib` to do some quick checks of the properties of the system" | ||
] | ||
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": null, | ||
"metadata": {}, | ||
"outputs": [], | ||
"source": [ | ||
"import matplotlib.pyplot as plt\n", | ||
"import numpy as np" | ||
] | ||
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": null, | ||
"metadata": {}, | ||
"outputs": [], | ||
"source": [ | ||
"data = np.loadtxt('thermo.txt')" | ||
] | ||
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": null, | ||
"metadata": {}, | ||
"outputs": [], | ||
"source": [ | ||
"plt.plot(data[:,0], data[:,1])\n", | ||
"plt.xlabel('step')\n", | ||
"plt.ylabel('Temperature (K)')" | ||
] | ||
}, | ||
{ | ||
"cell_type": "code", | ||
"execution_count": null, | ||
"metadata": {}, | ||
"outputs": [], | ||
"source": [ | ||
"plt.plot(data[:,0], data[:,2])\n", | ||
"plt.xlabel('step')\n", | ||
"plt.ylabel('Potential Energy (kcal/mol)')" | ||
] | ||
} | ||
], | ||
"metadata": { | ||
"kernelspec": { | ||
"display_name": "Python 3", | ||
"language": "python", | ||
"name": "python3" | ||
}, | ||
"language_info": { | ||
"codemirror_mode": { | ||
"name": "ipython", | ||
"version": 3 | ||
}, | ||
"file_extension": ".py", | ||
"mimetype": "text/x-python", | ||
"name": "python", | ||
"nbconvert_exporter": "python", | ||
"pygments_lexer": "ipython3", | ||
"version": "3.7.6" | ||
} | ||
}, | ||
"nbformat": 4, | ||
"nbformat_minor": 4 | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,28 @@ | ||
dimension 3 | ||
units real | ||
boundary p p p | ||
|
||
atom_style full | ||
pair_style lj/cut 12 | ||
box tilt large | ||
|
||
neighbor 2.0 bin | ||
neigh_modify every 1 delay 1 check yes | ||
|
||
read_data data.ar | ||
|
||
velocity all create 100 12345 | ||
|
||
minimize 0.0 0.0 100 4000 | ||
reset_timestep 0 | ||
|
||
timestep 1.0 | ||
thermo 100 | ||
compute PE all pe | ||
|
||
fix MyNVE all nve | ||
dump NVEdump all atom 100 ar_nve.lammpstrj | ||
fix thermoprint all print 100 "$(step) $(temp) $(c_PE)" file thermo.txt | ||
|
||
#step1-start | ||
run 100000 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.