Rosetta 3.5
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
BackrubSegment.cc
Go to the documentation of this file.
1 // -*- mode:c++;tab-width:2;indent-tabs-mode:t;show-trailing-whitespace:t;rm-trailing-spaces:t -*-
2 // vi: set ts=2 noet:
3 //
4 // (c) Copyright Rosetta Commons Member Institutions.
5 // (c) This file is part of the Rosetta software suite and is made available under license.
6 // (c) The Rosetta software is developed by the contributing members of the Rosetta Commons.
7 // (c) For more information, see http://www.rosettacommons.org. Questions about this can be
8 // (c) addressed to University of Washington UW TechTransfer, email: license@u.washington.edu.
9 
10 /// @file protocols/backrub/BackrubSegment.cc
11 /// @brief implmentation of BackrubSegment class
12 /// @author Colin A. Smith (colin.smith@ucsf.edu)
13 
14 
16 
17 // Core Headers
18 #include <core/id/AtomID.hh>
21 #include <core/pose/Pose.hh>
22 #include <core/types.hh>
23 
24 // Protocols Headers
25 
26 // Utility Headers
27 #include <utility/keys/Key3Vector.hh>
28 
29 #include <utility/vector1.hh>
30 
31 
32 // C++ Headers
33 
34 using namespace core;
35 
36 namespace protocols {
37 namespace backrub {
38 
39 void
41  core::pose::Pose const & pose,
42  core::kinematics::tree::AtomCOP & start_atom_m1,
44  core::kinematics::tree::AtomCOP & start_atom_p1
45 ) const
46 {
47  kinematics::AtomTree const & atom_tree(pose.atom_tree());
48 
49  start_atom = & atom_tree.atom(start_atomid_);
50  start_atom_m1 = start_atom->stub_atom2();
51  start_atom_p1 = & atom_tree.atom(start_atomid1_);
52 }
53 
54 void
56  core::pose::Pose const & pose,
57  core::kinematics::tree::AtomCOP & start_atom_m2,
58  core::kinematics::tree::AtomCOP & start_atom_m1,
60  core::kinematics::tree::AtomCOP & start_atom_p1,
61  core::kinematics::tree::AtomCOP & start_atom_p2
62 ) const
63 {
64  start_atoms1(pose, start_atom_m1, start_atom, start_atom_p1);
65 
66  start_atom_m2 = start_atom->stub_atom3();
67  start_atom_p2 = & pose.atom_tree().atom(start_atomid2_);
68 }
69 
72  core::pose::Pose const & pose
73 )
74 {
75  kinematics::tree::AtomCOP start_atom_m1, start_atom, start_atom_p1;
76  start_atoms1(pose, start_atom_m1, start_atom, start_atom_p1);
77 
78  if (start_atom_m1->id() < start_atom_p1->id()) {
79  return BondAngleKey(start_atom_m1->id(), start_atom->id(), start_atom_p1->id());
80  }
81 
82  return BondAngleKey(start_atom_p1->id(), start_atom->id(), start_atom_m1->id());
83 }
84 
85 void
87  core::pose::Pose const & pose,
88  core::kinematics::tree::AtomCOP & end_atom_m1,
91 ) const
92 {
93  end_atom = & pose.atom_tree().atom(end_atomid_);
94  end_atom_m1 = end_atom->parent();
95  end_atom_p1 = end_atom->get_nonjump_atom(0);
96 }
97 
98 void
100  core::pose::Pose const & pose,
101  core::kinematics::tree::AtomCOP & end_atom_m2,
102  core::kinematics::tree::AtomCOP & end_atom_m1,
104  core::kinematics::tree::AtomCOP & end_atom_p1,
105  core::kinematics::tree::AtomCOP & end_atom_p2
106 ) const
107 {
108  end_atoms1(pose, end_atom_m1, end_atom, end_atom_p1);
109 
110  runtime_assert(end_atom_m1);
111 
112  end_atom_m2 = end_atom_m1->parent();
113  end_atom_p2 = end_atom_p1 ? end_atom_p1->get_nonjump_atom(0) : core::kinematics::tree::AtomCOP(0) ;
114 }
115 
118  core::pose::Pose const & pose
119 )
120 {
121  kinematics::tree::AtomCOP end_atom_m1, end_atom, end_atom_p1;
122  end_atoms1(pose, end_atom_m1, end_atom, end_atom_p1);
123 
124  if (!end_atom_p1) {
125  return BondAngleKey(end_atom_m1->id(), end_atom->id(), id::BOGUS_ATOM_ID);
126  }
127 
128  if (end_atom_m1->id() < end_atom_p1->id()) {
129  return BondAngleKey(end_atom_m1->id(), end_atom->id(), end_atom_p1->id());
130  }
131 
132  return BondAngleKey(end_atom_p1->id(), end_atom->id(), end_atom_m1->id());
133 }
134 
135 void
137  core::pose::Pose const & pose,
138  BackrubSegment::BondAngleKey bond_angle_key,
142 )
143 {
144  kinematics::AtomTree const & atom_tree(pose.atom_tree());
145 
146  runtime_assert(bond_angle_key.key1().valid());
147  runtime_assert(bond_angle_key.key2().valid());
148 
149  atom_m1 = & atom_tree.atom(bond_angle_key.key1());
150  atom = & atom_tree.atom(bond_angle_key.key2());
151  atom_p1 = bond_angle_key.key3().valid() ? & atom_tree.atom(bond_angle_key.key3()) : NULL;
152 }
153 
154 } // moves
155 } // protocols