File: ExampleSodiumChloride.cpp

package info (click to toggle)
molmodel 3.1.0-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 24,384 kB
  • sloc: cpp: 39,830; perl: 526; ansic: 107; makefile: 41
file content (69 lines) | stat: -rw-r--r-- 1,943 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
#include "SimTKmolmodel.h"
#include "SimTKsimbody_aux.h" // for vtk visualization

#include <iostream>
#include <exception>

using namespace SimTK;
using namespace std;

int main() { try 
{
    // molecule-specialized simbody System
    CompoundSystem system;
	SimbodyMatterSubsystem matter(system);
    DecorationSubsystem decorations(system);
 
    // molecular force field
    TinkerDuMMForceFieldSubsystem dumm(system); 

	dumm.loadAmber99Parameters();

	SodiumIon sodium1, sodium2, sodium3;
	ChlorideIon chloride1, chloride2, chloride3;
	MagnesiumIon magnesium1, magnesium2, magnesium3;

	// dumm.setGbsaGlobalScaleFactor(0);
	// dumm.setCoulombGlobalScaleFactor(0);

	LithiumIon::setAmberLikeParameters(dumm);
	SodiumIon::setAmberLikeParameters(dumm);
	PotassiumIon::setAmberLikeParameters(dumm);
	MagnesiumIon::setAmberLikeParameters(dumm);
	ChlorideIon::setAmberLikeParameters(dumm);

    // system.adoptCompound(magnesium1, Vec3(-0.3, 0, 0)); 
    // system.adoptCompound(magnesium2, Vec3( 0.3, 0, 0)); 
    system.adoptCompound(sodium1, Vec3(-0.3, 0, 0.3)); 
    // system.adoptCompound(sodium2, Vec3( 0.3, 0, 0.3)); 
    system.adoptCompound(chloride1, Vec3(0, -0.3, 0)); 
    // system.adoptCompound(chloride2, Vec3(0,  0.3, 0)); 
    // system.adoptCompound(chloride3, Vec3(0,  0.3, 0.3)); 

    system.updDefaultSubsystem().addEventReporter(new VTKEventReporter(system,
        0.010));

    system.modelCompounds(); // finalize multibody system

    State state = system.realizeTopology(); 

    // Simulate it.
    
    VerletIntegrator integ(system);
    TimeStepper ts(system, integ);
    ts.initialize(state);
    ts.stepTo(500.0);

    return 0;

} 
catch(const std::exception& e) {
    std::cerr << "ERROR: " << e.what() << std::endl;
    return 1;
}
catch(...) {
    std::cerr << "ERROR: An unknown exception was raised" << std::endl;
    return 1;
}

}