source: tests/regression/Potential/FitFragmentPartialCharges/testsuite-potential-fit-fragment-partial-charges.at@ 4d08b7

Add_FitFragmentPartialChargesAction Fix_ChargeSampling_PBC Fix_FitPartialCharges
Last change on this file since 4d08b7 was 4d08b7, checked in by Frederik Heber <heber@…>, 8 years ago

Added FitFragmentPartialChargesAction that fits partial charges to fragments in result container.

  • Property mode set to 100644
File size: 3.9 KB
Line 
1#
2# MoleCuilder - creates and alters molecular systems
3# Copyright (C) 2013 Frederik Heber
4#
5# This program is free software: you can redistribute it and/or modify
6# it under the terms of the GNU General Public License as published by
7# the Free Software Foundation, either version 3 of the License, or
8# (at your option) any later version.
9#
10# This program is distributed in the hope that it will be useful,
11# but WITHOUT ANY WARRANTY; without even the implied warranty of
12# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13# GNU General Public License for more details.
14#
15# You should have received a copy of the GNU General Public License
16# along with this program. If not, see <http://www.gnu.org/licenses/>.
17#
18### fit fragment partial particle charges
19
20AT_SETUP([Potential - Fit fragment partial charges - atomfragment check])
21AT_KEYWORDS([potential parse-fragment-results fit-fragment-partial-charges save-particle-parameters])
22AT_SKIP_IF([../../molecuilder --help fit-fragment-partial-charges; if test $? -eq 5; then /bin/true; else /bin/false; fi])
23
24input=water.pdb
25resultsfile=results_grid.dat
26AT_CHECK([/bin/cp -f ${abs_top_srcdir}/tests/regression/Potential/FitFragmentPartialCharges/pre/$input $input], 0)
27AT_CHECK([chmod u+w $input], 0, [ignore], [ignore])
28AT_CHECK([/bin/cp -f ${abs_top_srcdir}/tests/regression/Potential/FitFragmentPartialCharges/pre/$resultsfile $resultsfile], 0)
29AT_CHECK([chmod u+w $resultsfile], 0, [ignore], [ignore])
30# fails because atomFragments has not been parsed
31AT_CHECK([../../molecuilder -l $input --select-all-atoms --parse-fragment-results $resultsfile --fit-fragment-partial-charges --radius 1.5 --save-particle-parameters water.particles], 5, [stdout], [ignore])
32
33AT_CLEANUP
34
35AT_SETUP([Potential - Fit partial charges to water])
36AT_KEYWORDS([potential parse-fragment-results fit-partial-charges save-particle-parameters])
37AT_SKIP_IF([../../molecuilder --help fit-partial-charges; if test $? -eq 5; then /bin/true; else /bin/false; fi])
38
39# homology file created with water.pdb and as follows:
40# molecuilder -i water.pdb --select-all-atoms --fragment-molecule --distance 2 --order 1 --fragment-automation --server-address 127.0.0.1 --server-port 1026 --DoLongrange 1 --grid 5 --store-grids 1 --save-fragment-results results_grid.dat --save-atom-fragments atomfragments.dat
41input=water.pdb
42resultsfile=results_grid.dat
43atomfragmentsfile=atomfragments.dat
44AT_CHECK([/bin/cp -f ${abs_top_srcdir}/tests/regression/Potential/FitFragmentPartialCharges/pre/$input $input], 0)
45AT_CHECK([chmod u+w $input], 0, [ignore], [ignore])
46AT_CHECK([/bin/cp -f ${abs_top_srcdir}/tests/regression/Potential/FitFragmentPartialCharges/pre/$resultsfile $resultsfile], 0)
47AT_CHECK([chmod u+w $resultsfile], 0, [ignore], [ignore])
48AT_CHECK([/bin/cp -f ${abs_top_srcdir}/tests/regression/Potential/FitFragmentPartialCharges/pre/$atomfragmentsfile $atomfragmentsfile], 0)
49AT_CHECK([chmod u+w $atomfragmentsfile], 0, [ignore], [ignore])
50AT_CHECK([../../molecuilder -l $input --select-all-atoms --parse-fragment-results $resultsfile --parse-atom-fragments $atomfragmentsfile --fit-fragment-partial-charges --radius 1.5 --save-particle-parameters water.particles], 0, [stdout], [ignore])
51# check that L_2 error is below 1e-6
52AT_CHECK([grep "L2-Norm" stdout | awk '{if ($6 > 1e1) exit 1}'], 0, [ignore], [ignore])
53AT_CHECK([grep "L1-Norm" stdout | awk '{if ($6 > 1e0) exit 1}'], 0, [ignore], [ignore])
54AT_CHECK([grep "Adding particle O1.*-0.73" stdout], 0, [ignore], [ignore])
55AT_CHECK([grep "Adding particle H1.*0.36" stdout], 0, [ignore], [ignore])
56AT_CHECK([grep "atom O1.*received .*O1" stdout], 0, [ignore], [ignore])
57AT_CHECK([grep "atom H2.*received .*H1" stdout], 0, [ignore], [ignore])
58AT_CHECK([grep "atom H3.*received .*H1" stdout], 0, [ignore], [ignore])
59AT_CHECK([diff water.particles ${abs_top_srcdir}/tests/regression/Potential/FitFragmentPartialCharges/post/water.particles], 0)
60
61AT_CLEANUP
Note: See TracBrowser for help on using the repository browser.