29 #ifndef CDPL_FORCEFIELD_UTILITYFUNCTIONS_HPP
30 #define CDPL_FORCEFIELD_UTILITYFUNCTIONS_HPP
44 class MMFF94InteractionData;
63 template <
typename ValueType,
typename CoordsVec>
81 template <
typename ValueType,
typename CoordsVec>
82 ValueType
calcDistance(
const CoordsVec& atom1_pos,
const CoordsVec& atom2_pos);
107 template <
typename ValueType,
typename CoordsVec>
109 ValueType& bond_length1, ValueType& bond_length2);
134 template <
typename ValueType,
typename CoordsVec>
135 ValueType
calcBondLengthsAndAngle(
const CoordsVec& term_atom1_pos,
const CoordsVec& ctr_atom_pos,
const CoordsVec& term_atom2_pos,
136 ValueType& bond_length1, ValueType& bond_length2);
156 template <
typename ValueType,
typename CoordsVec>
157 ValueType
calcBondAngleCos(
const CoordsVec& term_atom1_pos,
const CoordsVec& ctr_atom_pos,
const CoordsVec& term_atom2_pos);
179 template <
typename ValueType,
typename CoordsVec>
180 ValueType
calcBondAngleCos(
const CoordsVec& term_atom1_pos,
const CoordsVec& ctr_atom_pos,
const CoordsVec& term_atom2_pos,
181 const ValueType& r_ij,
const ValueType& r_jk);
201 template <
typename ValueType,
typename CoordsVec>
202 ValueType
calcBondAngle(
const CoordsVec& term_atom1_pos,
const CoordsVec& ctr_atom_pos,
const CoordsVec& term_atom2_pos);
224 template <
typename ValueType,
typename CoordsVec>
225 ValueType
calcBondAngle(
const CoordsVec& term_atom1_pos,
const CoordsVec& ctr_atom_pos,
const CoordsVec& term_atom2_pos,
226 const ValueType& r_ij,
const ValueType& r_jk);
250 template <
typename ValueType,
typename CoordsVec>
252 const CoordsVec& term_atom2_pos,
const CoordsVec& oop_atom_pos);
277 template <
typename ValueType,
typename CoordsVec>
279 const CoordsVec& term_atom2_pos,
const CoordsVec& oop_atom_pos,
280 const ValueType& r_jl);
305 template <
typename ValueType,
typename CoordsVec>
307 const CoordsVec& ctr_atom2_pos,
const CoordsVec& term_atom2_pos);
331 template <
typename ValueType,
typename CoordsVec,
typename GradVec>
333 GradVec& atom1_deriv, GradVec& atom2_deriv);
365 template <
typename ValueType,
typename CoordsVec,
typename GradVec>
367 GradVec& term_atom1_deriv, GradVec& ctr_atom_deriv, GradVec& term_atom2_deriv);
410 template <
typename ValueType,
typename CoordsVec,
typename GradVec>
412 const CoordsVec& ctr_atom2_pos,
const CoordsVec& term_atom2_pos,
413 GradVec& term_atom1_deriv, GradVec& ctr_atom1_deriv,
414 GradVec& ctr_atom2_deriv, GradVec& term_atom2_deriv);
475 template <
typename ValueType,
typename CoordsVec,
typename GradVec>
477 const CoordsVec& term_atom2_pos,
const CoordsVec& oop_atom_pos,
478 GradVec& term_atom1_deriv, GradVec& ctr_atom_deriv,
479 GradVec& term_atom2_deriv, GradVec& oop_atom_deriv);
496 template <
typename VecType1,
typename VecType2,
typename VecType3>
497 void addVectors(
const VecType1& vec1,
const VecType2& vec2, VecType3& res)
499 res[0] = vec2[0] + vec1[0];
500 res[1] = vec2[1] + vec1[1];
501 res[2] = vec2[2] + vec1[2];
504 template <
typename VecType1,
typename VecType2>
505 void subVectors(
const VecType1& vec1,
const VecType1& vec2, VecType2& res)
507 res[0] = vec2[0] - vec1[0];
508 res[1] = vec2[1] - vec1[1];
509 res[2] = vec2[2] - vec1[2];
512 template <
typename ValueType,
typename VecType>
513 ValueType calcDotProduct(
const VecType& vec1,
const VecType& vec2)
515 return (vec1[0] * vec2[0] + vec1[1] * vec2[1] + vec1[2] * vec2[2]);
518 template <
typename VecType,
typename ResVecType>
519 void calcCrossProduct(
const VecType& vec1,
const VecType& vec2, ResVecType& cross_prod)
521 cross_prod[0] = vec1[1] * vec2[2] - vec1[2] * vec2[1];
522 cross_prod[1] = vec1[2] * vec2[0] - vec1[0] * vec2[2];
523 cross_prod[2] = vec1[0] * vec2[1] - vec1[1] * vec2[0];
526 template <
typename VecType1,
typename VecType2>
527 void copyVector(
const VecType1& vec1, VecType2& vec2)
534 template <
typename VecType>
535 void negateVector(VecType&
vec)
542 template <
typename VecType1,
typename VecType2>
543 void negateCopyVector(
const VecType1& vec1, VecType2& vec2)
550 template <
typename VecType,
typename T>
551 void scaleVector(VecType&
vec,
const T& factor)
558 template <
typename VecType,
typename T>
559 void invScaleVector(VecType&
vec,
const T& factor)
566 template <
typename VecType1,
typename VecType2,
typename T>
567 void scaleAddVector(
const VecType1& vec1,
const T& factor, VecType2& vec2)
569 vec2[0] += vec1[0] * factor;
570 vec2[1] += vec1[1] * factor;
571 vec2[2] += vec1[2] * factor;
574 template <
typename VecType1,
typename VecType2,
typename T>
575 void scaleCopyVector(
const VecType1& vec1,
const T& factor, VecType2& vec2)
577 vec2[0] = vec1[0] * factor;
578 vec2[1] = vec1[1] * factor;
579 vec2[2] = vec1[2] * factor;
582 template <
typename VecType1,
typename VecType2,
typename T>
583 void invScaleCopyVector(
const VecType1& vec1,
const T& factor, VecType2& vec2)
585 vec2[0] = vec1[0] / factor;
586 vec2[1] = vec1[1] / factor;
587 vec2[2] = vec1[2] / factor;
590 template <
typename ValueType>
591 ValueType clampCosine(
const ValueType& v)
593 if (v > ValueType(1))
596 if (v < ValueType(-1))
597 return ValueType(-1);
602 template <
typename ValueType,
typename Iter,
typename CoordsArray,
typename FuncType>
603 ValueType accumInteractionEnergies(Iter& beg,
const Iter& end,
const CoordsArray& coords,
const FuncType& func)
605 ValueType e = ValueType();
607 for (; beg != end; ++beg)
608 e += func(*beg, coords);
613 template <
typename ValueType,
typename Iter,
typename CoordsArray,
typename GradVector,
typename FuncType>
614 ValueType calcInteractionGradient(Iter& beg,
const Iter& end,
const CoordsArray& coords, GradVector& grad,
const FuncType& func)
616 ValueType e = ValueType();
618 for (; beg != end; ++beg)
619 e += func(*beg, coords, grad);
628 template <
typename ValueType,
typename CoordsVec>
631 ValueType pos_diff[3];
633 Detail::subVectors(atom1_pos, atom2_pos, pos_diff);
635 return Detail::calcDotProduct<ValueType>(pos_diff, pos_diff);
638 template <
typename ValueType,
typename CoordsVec>
641 return std::sqrt(calcSquaredDistance<ValueType>(atom1_pos, atom2_pos));
644 template <
typename ValueType,
typename CoordsVec>
646 ValueType& bond_length1, ValueType& bond_length2)
648 ValueType bond_vec1[3];
649 ValueType bond_vec2[3];
651 Detail::subVectors(ctr_atom_pos, term_atom1_pos, bond_vec1);
652 Detail::subVectors(ctr_atom_pos, term_atom2_pos, bond_vec2);
654 bond_length1 = std::sqrt(Detail::calcDotProduct<ValueType>(bond_vec1, bond_vec1));
655 bond_length2 = std::sqrt(Detail::calcDotProduct<ValueType>(bond_vec2, bond_vec2));
657 return Detail::clampCosine(Detail::calcDotProduct<ValueType>(bond_vec1, bond_vec2) / (bond_length1 * bond_length2));
660 template <
typename ValueType,
typename CoordsVec>
662 ValueType& bond_length1, ValueType& bond_length2)
667 template <
typename ValueType,
typename CoordsVec>
675 template <
typename ValueType,
typename CoordsVec>
677 const ValueType& r_ij,
const ValueType& r_jk)
679 ValueType bond_vec1[3];
680 ValueType bond_vec2[3];
682 Detail::subVectors(ctr_atom_pos, term_atom1_pos, bond_vec1);
683 Detail::subVectors(ctr_atom_pos, term_atom2_pos, bond_vec2);
685 return Detail::clampCosine(Detail::calcDotProduct<ValueType>(bond_vec1, bond_vec2) / (r_ij * r_jk));
688 template <
typename ValueType,
typename CoordsVec>
691 return std::acos(calcBondAngleCos<ValueType>(term_atom1_pos, ctr_atom_pos, term_atom2_pos));
694 template <
typename ValueType,
typename CoordsVec>
696 const ValueType& r_ij,
const ValueType& r_jk)
698 return std::acos(calcBondAngleCos<ValueType>(term_atom1_pos, ctr_atom_pos, term_atom2_pos, r_ij, r_jk));
701 template <
typename ValueType,
typename CoordsVec>
703 const CoordsVec& term_atom2_pos,
const CoordsVec& oop_atom_pos)
705 ValueType term_bond1_vec[3];
706 ValueType term_bond2_vec[3];
707 ValueType oop_bond_vec[3];
708 ValueType plane_normal[3];
710 Detail::subVectors(ctr_atom_pos, term_atom1_pos, term_bond1_vec);
711 Detail::subVectors(ctr_atom_pos, term_atom2_pos, term_bond2_vec);
712 Detail::subVectors(ctr_atom_pos, oop_atom_pos, oop_bond_vec);
713 Detail::calcCrossProduct(term_bond1_vec, term_bond2_vec, plane_normal);
715 ValueType pn_len = std::sqrt(Detail::calcDotProduct<ValueType>(plane_normal, plane_normal));
716 ValueType oop_bnd_len = std::sqrt(Detail::calcDotProduct<ValueType>(oop_bond_vec, oop_bond_vec));
717 ValueType ang_cos = Detail::clampCosine(Detail::calcDotProduct<ValueType>(plane_normal, oop_bond_vec) / (pn_len * oop_bnd_len));
719 return (ValueType(M_PI * 0.5) - std::acos(ang_cos));
722 template <
typename ValueType,
typename CoordsVec>
724 const CoordsVec& term_atom2_pos,
const CoordsVec& oop_atom_pos,
725 const ValueType& r_jl)
727 ValueType term_bond1_vec[3];
728 ValueType term_bond2_vec[3];
729 ValueType oop_bond_vec[3];
730 ValueType plane_normal[3];
732 Detail::subVectors(ctr_atom_pos, term_atom1_pos, term_bond1_vec);
733 Detail::subVectors(ctr_atom_pos, term_atom2_pos, term_bond2_vec);
734 Detail::subVectors(ctr_atom_pos, oop_atom_pos, oop_bond_vec);
735 Detail::calcCrossProduct(term_bond1_vec, term_bond2_vec, plane_normal);
737 ValueType pn_len = std::sqrt(Detail::calcDotProduct<ValueType>(plane_normal, plane_normal));
738 ValueType ang_cos = Detail::clampCosine(Detail::calcDotProduct<ValueType>(plane_normal, oop_bond_vec) / (pn_len * r_jl));
740 return (ValueType(M_PI * 0.5) - std::acos(ang_cos));
743 template <
typename ValueType,
typename CoordsVec>
745 const CoordsVec& ctr_atom2_pos,
const CoordsVec& term_atom2_pos)
747 ValueType term_bond1_vec[3];
748 ValueType ctr_bond_vec[3];
749 ValueType term_bond2_vec[3];
750 ValueType plane_normal1[3];
751 ValueType plane_normal2[3];
753 Detail::subVectors(ctr_atom1_pos, term_atom1_pos, term_bond1_vec);
754 Detail::subVectors(ctr_atom1_pos, ctr_atom2_pos, ctr_bond_vec);
755 Detail::subVectors(term_atom2_pos, ctr_atom2_pos, term_bond2_vec);
757 Detail::calcCrossProduct(term_bond1_vec, ctr_bond_vec, plane_normal1);
758 Detail::calcCrossProduct(ctr_bond_vec, term_bond2_vec, plane_normal2);
760 ValueType pn1_len = std::sqrt(Detail::calcDotProduct<ValueType>(plane_normal1, plane_normal1));
761 ValueType pn2_len = std::sqrt(Detail::calcDotProduct<ValueType>(plane_normal2, plane_normal2));
763 return Detail::clampCosine(Detail::calcDotProduct<ValueType>(plane_normal1, plane_normal2) / (pn1_len * pn2_len));
766 template <
typename ValueType,
typename CoordsVec,
typename GradVec>
768 GradVec& atom1_deriv, GradVec& atom2_deriv)
770 Detail::subVectors(atom1_pos, atom2_pos, atom1_deriv);
772 ValueType dist = std::sqrt(Detail::calcDotProduct<ValueType>(atom1_deriv, atom1_deriv));
774 Detail::invScaleVector(atom1_deriv, -dist);
775 Detail::negateCopyVector(atom1_deriv, atom2_deriv);
780 template <
typename ValueType,
typename CoordsVec,
typename GradVec>
782 GradVec& term_atom1_deriv, GradVec& ctr_atom_deriv, GradVec& term_atom2_deriv)
784 ValueType bond_vec1[3];
785 ValueType bond_vec2[3];
787 Detail::subVectors(ctr_atom_pos, term_atom1_pos, bond_vec1);
788 Detail::subVectors(ctr_atom_pos, term_atom2_pos, bond_vec2);
790 ValueType bond_length1 = std::sqrt(Detail::calcDotProduct<ValueType>(bond_vec1, bond_vec1));
791 ValueType bond_length2 = std::sqrt(Detail::calcDotProduct<ValueType>(bond_vec2, bond_vec2));
793 ValueType dot_prod = Detail::calcDotProduct<ValueType>(bond_vec1, bond_vec2);
794 ValueType bl_prod = bond_length1 * bond_length2;
796 Detail::invScaleCopyVector(bond_vec2, bl_prod, term_atom1_deriv);
797 Detail::scaleCopyVector(bond_vec1, dot_prod / (bond_length1 * bond_length1 * bl_prod), ctr_atom_deriv);
798 Detail::subVectors(ctr_atom_deriv, term_atom1_deriv, term_atom1_deriv);
800 Detail::invScaleCopyVector(bond_vec1, bl_prod, term_atom2_deriv);
801 Detail::scaleCopyVector(bond_vec2, dot_prod / (bond_length2 * bond_length2 * bl_prod), ctr_atom_deriv);
802 Detail::subVectors(ctr_atom_deriv, term_atom2_deriv, term_atom2_deriv);
804 Detail::negateCopyVector(term_atom1_deriv, ctr_atom_deriv);
805 Detail::subVectors(term_atom2_deriv, ctr_atom_deriv, ctr_atom_deriv);
807 return Detail::clampCosine(dot_prod / bl_prod);
810 template <
typename ValueType,
typename CoordsVec,
typename GradVec>
812 const CoordsVec& ctr_atom2_pos,
const CoordsVec& term_atom2_pos,
813 GradVec& term_atom1_deriv, GradVec& ctr_atom1_deriv,
814 GradVec& ctr_atom2_deriv, GradVec& term_atom2_deriv)
816 ValueType term_bond1_vec[3];
817 ValueType ctr_bond_vec[3];
818 ValueType term_bond2_vec[3];
819 ValueType term1_ctr2_vec[3];
820 ValueType plane_normal1[3];
821 ValueType plane_normal2[3];
823 Detail::subVectors(ctr_atom1_pos, term_atom1_pos, term_bond1_vec);
824 Detail::subVectors(ctr_atom1_pos, ctr_atom2_pos, ctr_bond_vec);
825 Detail::subVectors(term_atom2_pos, ctr_atom2_pos, term_bond2_vec);
826 Detail::subVectors(ctr_atom2_pos, term_atom1_pos, term1_ctr2_vec);
828 Detail::calcCrossProduct(term_bond1_vec, ctr_bond_vec, plane_normal1);
829 Detail::calcCrossProduct(ctr_bond_vec, term_bond2_vec, plane_normal2);
831 ValueType pn1_len = std::sqrt(Detail::calcDotProduct<ValueType>(plane_normal1, plane_normal1));
832 ValueType pn2_len = std::sqrt(Detail::calcDotProduct<ValueType>(plane_normal2, plane_normal2));
834 Detail::invScaleVector(plane_normal1, pn1_len);
835 Detail::invScaleVector(plane_normal2, pn2_len);
837 ValueType ang_cos = Detail::clampCosine(Detail::calcDotProduct<ValueType>(plane_normal1, plane_normal2));
842 Detail::scaleCopyVector(plane_normal1, -ang_cos, a);
843 Detail::addVectors(a, plane_normal2, a);
844 Detail::invScaleVector(a, pn1_len);
846 Detail::scaleCopyVector(plane_normal2, -ang_cos, b);
847 Detail::addVectors(b, plane_normal1, b);
848 Detail::invScaleVector(b, pn2_len);
850 Detail::calcCrossProduct(ctr_bond_vec, a, term_atom1_deriv);
851 Detail::calcCrossProduct(ctr_bond_vec, b, term_atom2_deriv);
853 Detail::calcCrossProduct(term1_ctr2_vec, a, ctr_atom1_deriv);
854 Detail::calcCrossProduct(term_bond2_vec, b, ctr_atom2_deriv);
856 Detail::subVectors(ctr_atom2_deriv, ctr_atom1_deriv, ctr_atom1_deriv);
858 Detail::addVectors(term_atom1_deriv, ctr_atom1_deriv, ctr_atom2_deriv);
859 Detail::addVectors(ctr_atom2_deriv, term_atom2_deriv, ctr_atom2_deriv);
860 Detail::negateVector(ctr_atom2_deriv);
865 template <
typename ValueType,
typename CoordsVec,
typename GradVec>
867 const CoordsVec& term_atom2_pos,
const CoordsVec& oop_atom_pos,
868 GradVec& term_atom1_deriv, GradVec& ctr_atom_deriv,
869 GradVec& term_atom2_deriv, GradVec& oop_atom_deriv)
871 ValueType term_bond1_vec[3];
872 ValueType term_bond2_vec[3];
873 ValueType oop_bond_vec[3];
874 ValueType term1_oop_vec[3];
875 ValueType term2_oop_vec[3];
878 Detail::subVectors(ctr_atom_pos, term_atom1_pos, term_bond1_vec);
879 Detail::subVectors(ctr_atom_pos, term_atom2_pos, term_bond2_vec);
880 Detail::subVectors(ctr_atom_pos, oop_atom_pos, oop_bond_vec);
881 Detail::subVectors(term_atom2_pos, oop_atom_pos, term2_oop_vec);
882 Detail::subVectors(term_atom1_pos, oop_atom_pos, term1_oop_vec);
884 Detail::calcCrossProduct(term_bond1_vec, term_bond2_vec, ijk_pn);
886 ValueType ijk_pn_len_2 = Detail::calcDotProduct<ValueType>(ijk_pn, ijk_pn);
887 ValueType ijk_pn_len = std::sqrt(ijk_pn_len_2);
888 ValueType oop_bnd_len = std::sqrt(Detail::calcDotProduct<ValueType>(oop_bond_vec, oop_bond_vec));
889 ValueType oop_ijk_pn_len_prod = ijk_pn_len * oop_bnd_len;
890 ValueType oop_ijk_pn_dot_prod = Detail::calcDotProduct<ValueType>(ijk_pn, oop_bond_vec);
891 ValueType ang_cos = Detail::clampCosine(oop_ijk_pn_dot_prod / oop_ijk_pn_len_prod);
896 Detail::calcCrossProduct(term_bond2_vec, oop_bond_vec, kjl_pn);
897 Detail::calcCrossProduct(oop_bond_vec, term_bond1_vec, lji_pn);
899 ctr_atom_deriv[0] = ijk_pn[1] * -term_bond2_vec[2] + ijk_pn[2] * term_bond2_vec[1];
900 ctr_atom_deriv[1] = ijk_pn[0] * term_bond2_vec[2] + ijk_pn[2] * -term_bond2_vec[0];
901 ctr_atom_deriv[2] = ijk_pn[0] * -term_bond2_vec[1] + ijk_pn[1] * term_bond2_vec[0];
903 Detail::scaleVector(ctr_atom_deriv, ang_cos / ijk_pn_len_2);
905 Detail::invScaleCopyVector(kjl_pn, oop_ijk_pn_len_prod, term_atom1_deriv);
906 Detail::subVectors(ctr_atom_deriv, term_atom1_deriv, term_atom1_deriv);
908 ctr_atom_deriv[0] = ijk_pn[1] * term_bond1_vec[2] + ijk_pn[2] * -term_bond1_vec[1];
909 ctr_atom_deriv[1] = ijk_pn[0] * -term_bond1_vec[2] + ijk_pn[2] * term_bond1_vec[0];
910 ctr_atom_deriv[2] = ijk_pn[0] * term_bond1_vec[1] + ijk_pn[1] * -term_bond1_vec[0];
912 Detail::scaleVector(ctr_atom_deriv, ang_cos / ijk_pn_len_2);
914 Detail::invScaleCopyVector(lji_pn, oop_ijk_pn_len_prod, term_atom2_deriv);
915 Detail::subVectors(ctr_atom_deriv, term_atom2_deriv, term_atom2_deriv);
917 Detail::calcCrossProduct(term2_oop_vec, term1_oop_vec, ctr_atom_deriv);
919 Detail::scaleCopyVector(oop_bond_vec, oop_ijk_pn_dot_prod / (oop_bnd_len * oop_bnd_len), oop_atom_deriv);
920 Detail::addVectors(oop_atom_deriv, lji_pn, oop_atom_deriv);
921 Detail::addVectors(oop_atom_deriv, kjl_pn, oop_atom_deriv);
922 Detail::addVectors(oop_atom_deriv, ctr_atom_deriv, oop_atom_deriv);
923 Detail::invScaleVector(oop_atom_deriv, -oop_ijk_pn_len_prod);
925 Detail::copyVector(term_atom1_deriv, ctr_atom_deriv);
926 Detail::addVectors(term_atom2_deriv, ctr_atom_deriv, ctr_atom_deriv);
927 Detail::addVectors(oop_atom_deriv, ctr_atom_deriv, ctr_atom_deriv);
928 Detail::negateVector(ctr_atom_deriv);
Definition of the type CDPL::Util::BitSet.
Definition of the preprocessor macro CDPL_FORCEFIELD_API.
#define CDPL_FORCEFIELD_API
Tells the compiler/linker which classes, functions and variables are part of the library API.
Definition: MMFF94InteractionData.hpp:51
constexpr unsigned int T
Specifies Hydrogen (Tritium).
Definition: AtomType.hpp:67
ValueType calcOutOfPlaneAngle(const CoordsVec &term_atom1_pos, const CoordsVec &ctr_atom_pos, const CoordsVec &term_atom2_pos, const CoordsVec &oop_atom_pos)
Calculates the out-of-plane angle between the bond j-l and the plane defined by the atoms i-j-k.
ValueType calcDihedralAngleCosDerivatives(const CoordsVec &term_atom1_pos, const CoordsVec &ctr_atom1_pos, const CoordsVec &ctr_atom2_pos, const CoordsVec &term_atom2_pos, GradVec &term_atom1_deriv, GradVec &ctr_atom1_deriv, GradVec &ctr_atom2_deriv, GradVec &term_atom2_deriv)
Calculates the partial derivatives of the cosine of the angle between the planes defined by the ato...
ValueType calcSquaredDistance(const CoordsVec &atom1_pos, const CoordsVec &atom2_pos)
Calculates the squared distance between two atoms i and j.
ValueType calcBondAngle(const CoordsVec &term_atom1_pos, const CoordsVec &ctr_atom_pos, const CoordsVec &term_atom2_pos)
Calculates the bond angle between the two bonds i-j and j-k.
ValueType calcBondLengthsAndAngleCos(const CoordsVec &term_atom1_pos, const CoordsVec &ctr_atom_pos, const CoordsVec &term_atom2_pos, ValueType &bond_length1, ValueType &bond_length2)
Calculates bond lengths and and the cosine of the bond angle between the two bonds i-j and j-k.
ValueType calcOutOfPlaneAngleCosDerivatives(const CoordsVec &term_atom1_pos, const CoordsVec &ctr_atom_pos, const CoordsVec &term_atom2_pos, const CoordsVec &oop_atom_pos, GradVec &term_atom1_deriv, GradVec &ctr_atom_deriv, GradVec &term_atom2_deriv, GradVec &oop_atom_deriv)
Calculates the partial derivatives of the cosine of the angle between the bond j-l and the normal o...
ValueType calcDihedralAngleCos(const CoordsVec &term_atom1_pos, const CoordsVec &ctr_atom1_pos, const CoordsVec &ctr_atom2_pos, const CoordsVec &term_atom2_pos)
Calculates the cosine of the dihedral angle between the planes defined by the atom triplets i-j-k an...
ValueType calcBondLengthsAndAngle(const CoordsVec &term_atom1_pos, const CoordsVec &ctr_atom_pos, const CoordsVec &term_atom2_pos, ValueType &bond_length1, ValueType &bond_length2)
Calculates bond lengths and and the bond angle between the two bonds i-j and j-k.
ValueType calcBondAngleCosDerivatives(const CoordsVec &term_atom1_pos, const CoordsVec &ctr_atom_pos, const CoordsVec &term_atom2_pos, GradVec &term_atom1_deriv, GradVec &ctr_atom_deriv, GradVec &term_atom2_deriv)
Calculates the partial derivatives of the of the cosine of the angle between the bonds i-j and j-k.
ValueType calcDistance(const CoordsVec &atom1_pos, const CoordsVec &atom2_pos)
Calculates the distance between two atoms i and j.
CDPL_FORCEFIELD_API void filterInteractions(const MMFF94InteractionData &ia_data, MMFF94InteractionData &filtered_ia_data, const Util::BitSet &inc_atom_mask)
ValueType calcBondAngleCos(const CoordsVec &term_atom1_pos, const CoordsVec &ctr_atom_pos, const CoordsVec &term_atom2_pos)
Calculates the cosine of the bond angle between the two bonds i-j and j-k.
ValueType calcDistanceDerivatives(const CoordsVec &atom1_pos, const CoordsVec &atom2_pos, GradVec &atom1_deriv, GradVec &atom2_deriv)
Calculates the partial derivatives of the distance between two atoms i and j.
QuaternionVectorAdapter< E > vec(QuaternionExpression< E > &e)
Definition: QuaternionAdapter.hpp:237
boost::dynamic_bitset BitSet
A dynamic bitset class.
Definition: BitSet.hpp:46
The namespace of the Chemical Data Processing Library.