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 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104
|
#pragma once
#include "PyMOLGlobals.h"
struct DistSet;
namespace pymol
{
enum InteractionDir {
cInteractionNone,
cInteractionBoth,
cInteractionForward,
};
/**
* Halogen bond criteria
*/
class HalogenBondCriteria
{
public:
// Cutoff distance
float m_distance = 3.5f;
// halogen as a donor minimum donor angle
float m_as_donor_min_donor_angle = 140.0f;
// halogen as a donor minimum acceptor angle
float m_as_donor_min_acceptor_angle = 90.0f;
// halogen as an acceptor minimum donor angle
float m_as_acceptor_min_donor_angle = 120.0f;
// halogen as an acceptor minimum acceptor angle
float m_as_acceptor_min_acceptor_angle = 90.0f;
// halogen as an acceptor maximum acceptor angle
float m_as_acceptor_max_acceptor_angle = 170.0f;
public:
/**
* Construct a new Halogen Bond Criteria object
* and initialize it's member variables
*/
HalogenBondCriteria(PyMOLGlobals* G);
};
/**
* Salt Bridge criteria
*/
class SaltBridgeCriteria
{
public:
// Cutoff distance
float m_distance = 5.0f;
public:
/**
* Construct a new Salt Bridge Criteria object and initialize it's member variables
*/
SaltBridgeCriteria(PyMOLGlobals* G);
};
DistSet* FindPiInteractions(PyMOLGlobals* G,
DistSet* ds, //
int sele1, int state1, //
int sele2, int state2, //
bool pipi = true, //
InteractionDir picat = cInteractionBoth);
/**
* Find Halogen bond interactions
*
* @param ds - DistSet
* @param sele1 - selections index
* @param state1 - state index
* @param sele2 - selection index
* @param state2 - state index
* @param cutoff - cutoff distance
* @param result - result average distance
*
* @return DistSet - distance set
*/
DistSet* FindHalogenBondInteractions(PyMOLGlobals* G, DistSet* ds, int sele1,
int state1, int sele2, int state2, float cutoff, float* result);
/**
* Find Salt-bridge interactions
*
* @param ds - DistSet
* @param sele1 - selections index
* @param state1 - state index
* @param sele2 - selection index
* @param state2 - state index
* @param cutoff - cutoff distance
* @param result - result average distance
*
* @return DistSet - distance set
*/
DistSet* FindSaltBridgeInteractions(PyMOLGlobals* G, DistSet* ds, int sele1,
int state1, int sele2, int state2, float cutoff, float* result);
}
|