# MCPoly
Some methods to deal with some manipulation of computational chemistry, mostly about mechanical properties of polymers.
![](./reference/function.png)
## Overview
`MCPoly` is a Python library to make some steps of computational chemistry easier. It includes some functions of drawing molecule structures, creating proper .xyz , .inp , .mol and .data file, which specialised for using ORCA and LAMMPS, and some functions for researching the mechanical property of some polymers.
## Updated in v0.6.1(11.10.23)
1. Add molesplit function in 'status' package to judge the location of the atom.
2. Add Hbond function in 'status' package to count the number of hydrogen bonds.
## Updated in v0.6.0(08.08.23)
1. Standardise the package to fit PEP 8 style, so 'DATAtoXYZ' is changed into 'DataToXyz', 'DATAtomolTXT' is changed into 'DataToMolTxt', 'XYZtoINP' is changed into 'XyzToInp'.
2. Add special functions about Molecular Dynamic functions in ORCA.
3. Fix some bugs about ORCA Calculations Settings.
4. Fix some bugs about ORCA GUI display.
5. Fix some bugs about judging the maximum iteration of atoms.
6. Fix some bugs about save .xyz file in ORCA GUI.
7. Fix some bugs about selecting files in ComboBox by file location.
8. Add special functions 'untie' to tidy up your molecule number.
## Updated in v0.5.1.3(29.06.23)
1. Add 'rebuild' in 'lmpset' package. You can now use it to rebuild geometry structure of LAMMPS input data now.
2. Add 'DATAtoXYZ' in 'lmpset' package to convert LAMMPS Data File into XYZ File
3. Add 'DATAtomolTXT' to convert LAMMPS Data File into LAMMPS Molecule Text File.
4. All these functions can be used by lmpset.mould().XXX() now.
5. Fix some bugs about ORCA Calculations Settings.
6. Fix some bugs about ORCA GUI display.
7. Fix some bugs about judging the maximum iteration of atoms.
## Updated in v0.4.2.3(12.06.23)
1. BIG UPDATE: Molecule Designer GUI is included in this package. You can now use it to draw molecule with 3D view at the same time.
<img src="https://github.com/Omicron-Fluor/MCPoly/blob/main/reference/moldraw_gui.png">
2. Add 'chain' in 'lmpset' package. You can now use it to convert periodic polymer structure input data now.
3. Fix some bugs about ORCA Calculations.
4. Fix some bugs about calculating stress-strain curve.
## Functions for ORCA
<img src="https://github.com/Omicron-Fluor/MCPoly/blob/main/reference/ORCA.png" width="400" height="263" >
### orcaset
Used to create ORCA input files and run it on ORCA. It's especially handy for researching mechanical property of polymers.
### status
Because we can't use ORCA to visualize the geometry structure, this command can be used to see the optimisation status and the trait of geometry structure.
### view3d
See the 3D structure of a normal .xyz file.
### sscurve
With calculated .xyz file, we can draw the stress-strain curve of each polymer, and we can also calculate the Young's modulus of relevant polymers.
### moldraws (Under Construction)
Used to build a simple molecule and save it under .xyz form.
## Functions for LAMMPS
<img src="https://github.com/Omicron-Fluor/MCPoly/blob/main/reference/LAMMPS.png" width="395" height="100" >
### lmpset
Used to draw special patterns of polymers. Mostly in grids.
## Installation
To get `MCPoly`, you can install it with pip:
`$ pip install MCPoly`
If you want to get the latest version of `MCPoly`, you can see the latest release here:
<https://github.com/Omicron-Fluor/MCPoly/release>
There will be a corresponding release on `pip` for each release on GitHub, and you can update your `MCPoly` with:
`$ pip install MCPoly --upgrade`
## How to cite
<https://github.com/Omicron-Fluor/MCPoly>
## Outlook
We will add some new function about polymers based on ReaxFF.
Raw data
{
"_id": null,
"home_page": "https://github.com/Omicron-Fluor/MCPoly/",
"name": "MCPoly",
"maintainer": "",
"docs_url": null,
"requires_python": "",
"maintainer_email": "",
"keywords": "ORCA,Mechanical Property,Computational Chemistry",
"author": "Omicron Fluor",
"author_email": "cxs454@student.bham.ac.uk",
"download_url": "https://files.pythonhosted.org/packages/eb/85/9086187c700830f47641549741d9a56401606dc411e4524166807f1d9719/MCPoly-0.6.1.tar.gz",
"platform": null,
"description": "# MCPoly\nSome methods to deal with some manipulation of computational chemistry, mostly about mechanical properties of polymers.\n![](./reference/function.png)\n\n## Overview\n`MCPoly` is a Python library to make some steps of computational chemistry easier. It includes some functions of drawing molecule structures, creating proper .xyz , .inp , .mol and .data file, which specialised for using ORCA and LAMMPS, and some functions for researching the mechanical property of some polymers.\n\n## Updated in v0.6.1(11.10.23)\n1. Add molesplit function in 'status' package to judge the location of the atom.\n2. Add Hbond function in 'status' package to count the number of hydrogen bonds.\n\n## Updated in v0.6.0(08.08.23)\n1. Standardise the package to fit PEP 8 style, so 'DATAtoXYZ' is changed into 'DataToXyz', 'DATAtomolTXT' is changed into 'DataToMolTxt', 'XYZtoINP' is changed into 'XyzToInp'.\n2. Add special functions about Molecular Dynamic functions in ORCA.\n3. Fix some bugs about ORCA Calculations Settings.\n4. Fix some bugs about ORCA GUI display.\n5. Fix some bugs about judging the maximum iteration of atoms.\n6. Fix some bugs about save .xyz file in ORCA GUI.\n7. Fix some bugs about selecting files in ComboBox by file location.\n8. Add special functions 'untie' to tidy up your molecule number.\n\n## Updated in v0.5.1.3(29.06.23)\n1. Add 'rebuild' in 'lmpset' package. You can now use it to rebuild geometry structure of LAMMPS input data now.\n2. Add 'DATAtoXYZ' in 'lmpset' package to convert LAMMPS Data File into XYZ File\n3. Add 'DATAtomolTXT' to convert LAMMPS Data File into LAMMPS Molecule Text File.\n4. All these functions can be used by lmpset.mould().XXX() now.\n5. Fix some bugs about ORCA Calculations Settings.\n6. Fix some bugs about ORCA GUI display.\n7. Fix some bugs about judging the maximum iteration of atoms.\n\n## Updated in v0.4.2.3(12.06.23)\n1. BIG UPDATE: Molecule Designer GUI is included in this package. You can now use it to draw molecule with 3D view at the same time.\n<img src=\"https://github.com/Omicron-Fluor/MCPoly/blob/main/reference/moldraw_gui.png\">\n2. Add 'chain' in 'lmpset' package. You can now use it to convert periodic polymer structure input data now.\n3. Fix some bugs about ORCA Calculations.\n4. Fix some bugs about calculating stress-strain curve.\n\n## Functions for ORCA\n<img src=\"https://github.com/Omicron-Fluor/MCPoly/blob/main/reference/ORCA.png\" width=\"400\" height=\"263\" >\n\n### orcaset\nUsed to create ORCA input files and run it on ORCA. It's especially handy for researching mechanical property of polymers.\n\n### status\nBecause we can't use ORCA to visualize the geometry structure, this command can be used to see the optimisation status and the trait of geometry structure.\n\n### view3d\nSee the 3D structure of a normal .xyz file.\n\n### sscurve\nWith calculated .xyz file, we can draw the stress-strain curve of each polymer, and we can also calculate the Young's modulus of relevant polymers.\n\n### moldraws (Under Construction)\nUsed to build a simple molecule and save it under .xyz form.\n\n## Functions for LAMMPS\n<img src=\"https://github.com/Omicron-Fluor/MCPoly/blob/main/reference/LAMMPS.png\" width=\"395\" height=\"100\" >\n\n### lmpset\nUsed to draw special patterns of polymers. Mostly in grids.\n\n## Installation\nTo get `MCPoly`, you can install it with pip:\n `$ pip install MCPoly`\n\nIf you want to get the latest version of `MCPoly`, you can see the latest release here:\n\n<https://github.com/Omicron-Fluor/MCPoly/release> \n\nThere will be a corresponding release on `pip` for each release on GitHub, and you can update your `MCPoly` with:\n\n`$ pip install MCPoly --upgrade`\n\n## How to cite\n<https://github.com/Omicron-Fluor/MCPoly>\n\n## Outlook\nWe will add some new function about polymers based on ReaxFF.\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "Useful tools for Computational Chemistry for polymers",
"version": "0.6.1",
"project_urls": {
"Homepage": "https://github.com/Omicron-Fluor/MCPoly/"
},
"split_keywords": [
"orca",
"mechanical property",
"computational chemistry"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "f1580145e1651ac3ab30c11c4126e79596ec4bf909e01fd310d157a5596b7559",
"md5": "1876da3d39ecd363a5d7ddfbb10f4545",
"sha256": "0fd060f9f9cb6ee5c63f3067181cfa900f050e7a35c375455dd6ba4d6d2699dd"
},
"downloads": -1,
"filename": "MCPoly-0.6.1-py3-none-any.whl",
"has_sig": false,
"md5_digest": "1876da3d39ecd363a5d7ddfbb10f4545",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": null,
"size": 124434,
"upload_time": "2023-10-11T16:01:15",
"upload_time_iso_8601": "2023-10-11T16:01:15.190293Z",
"url": "https://files.pythonhosted.org/packages/f1/58/0145e1651ac3ab30c11c4126e79596ec4bf909e01fd310d157a5596b7559/MCPoly-0.6.1-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "eb859086187c700830f47641549741d9a56401606dc411e4524166807f1d9719",
"md5": "a5169fdef58d100b5d38b585d8217d56",
"sha256": "6a889d9f1ee6d798733fa078ed3f071217bf396df3414fc4aa0e92ba9e6dbb59"
},
"downloads": -1,
"filename": "MCPoly-0.6.1.tar.gz",
"has_sig": false,
"md5_digest": "a5169fdef58d100b5d38b585d8217d56",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 102178,
"upload_time": "2023-10-11T16:01:17",
"upload_time_iso_8601": "2023-10-11T16:01:17.315443Z",
"url": "https://files.pythonhosted.org/packages/eb/85/9086187c700830f47641549741d9a56401606dc411e4524166807f1d9719/MCPoly-0.6.1.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2023-10-11 16:01:17",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "Omicron-Fluor",
"github_project": "MCPoly",
"travis_ci": false,
"coveralls": false,
"github_actions": false,
"requirements": [
{
"name": "ase",
"specs": [
[
">=",
"3.20.0"
]
]
},
{
"name": "ipywidgets",
"specs": [
[
">=",
"8.0.0"
]
]
},
{
"name": "numpy",
"specs": [
[
">=",
"1.22.0"
]
]
},
{
"name": "matplotlib",
"specs": [
[
">=",
"3.6.0"
]
]
},
{
"name": "pandas",
"specs": [
[
">=",
"1.4.0"
]
]
},
{
"name": "seaborn",
"specs": [
[
">=",
"0.11.0"
]
]
},
{
"name": "py3dmol",
"specs": [
[
">=",
"2.0.0"
]
]
},
{
"name": "rdkit",
"specs": [
[
">=",
"2022.9.3"
]
]
},
{
"name": "scikit-learn",
"specs": [
[
">=",
"1.1.2"
]
]
},
{
"name": "ipython",
"specs": [
[
">=",
"6.1.0"
]
]
},
{
"name": "jupyterlab",
"specs": [
[
">=",
"3.1.0"
]
]
}
],
"lcname": "mcpoly"
}