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 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150
|
/* Copyright (C) 2001 Damir Zucic */
/*=============================================================================
edit_phi.c
Purpose:
Edit phi angle. If edit_single_bondF is zero, edit phi for every
selected residue in the specified macromolecular complex. If the
flag edit_single_bondF is different from zero, edit only the phi
angle for the bond specified by the given atomic array indices.
A residue is treated as selected if the first atom of this
residue is selected. For protein residues, this is typically N
atom (nitrogen).
Input:
(1) Pointer to MolComplexS structure.
(2) Pointer to RuntimeS structure.
(3) Pointer to ConfigS structure.
(4) Rotation angle.
Output:
(1) Phi angle changed for chosen residue(s).
(2) Return value.
Return value:
(1) Positive always (trivial).
========includes:============================================================*/
#include <stdio.h>
#include <string.h>
#include <X11/Xlib.h>
#include <X11/Xutil.h>
#include <X11/Xos.h>
#include <X11/Xatom.h>
#include "defines.h"
#include "typedefs.h"
/*======function prototypes:=================================================*/
int ExtractNCA_ (VectorS *, VectorS *, AtomS *, size_t, size_t);
int RotateAtom_ (AtomS *, VectorS *, VectorS *, double);
int DihedralAngles_ (MolComplexS *, ConfigS *);
/*======change phi angle for selected residues:==============================*/
int EditPhi_ (MolComplexS *mol_complexSP,
RuntimeS *runtimeSP, ConfigS *configSP,
double delta_phi)
{
int residuesN, residueI;
size_t atomsN;
ResidueS *residueSP;
size_t atom_startI, atom_endI, atomI;
AtomS *atomSP;
int n;
static VectorS N_vectorS, CA_vectorS;
/* Copy the number of residues in the current complex: */
residuesN = mol_complexSP->residuesN;
/* Copy the number of atoms in the current complex: */
atomsN = mol_complexSP->atomsN;
/* Scan residues: */
for (residueI = 0; residueI < residuesN; residueI++)
{
/* Pointer to the current residue: */
residueSP = mol_complexSP->residueSP + residueI;
/* Prepare the atomic index range: */
atom_startI = residueSP->residue_startI;
atom_endI = residueSP->residue_endI;
/* Pointer to the first atom: */
atomSP = mol_complexSP->atomSP + atom_startI;
/* Check the edit_single_bondF flag. If this flag is equal */
/* to zero, the current selection should be taken into */
/* account. Otherwise, the selection should be ignored. */
/* Editing of a single phi angle requested: */
if (runtimeSP->edit_single_bondF)
{
/* Check the array indices of N and CA: */
if ((runtimeSP->atom1_arrayI < atom_startI) ||
(runtimeSP->atom1_arrayI > atom_endI) ||
(runtimeSP->atom2_arrayI < atom_startI) ||
(runtimeSP->atom2_arrayI > atom_endI))
{
continue;
}
}
/* Editing of phi angles for all selected residues requested: */
else
{
/* If the first atom of the current residue is */
/* not selected, the residue is not selected: */
if (atomSP->selectedF == 0) continue;
}
/* Extract N and CA coordinates: */
n = ExtractNCA_ (&N_vectorS, &CA_vectorS,
mol_complexSP->atomSP, atom_startI, atom_endI);
if (n < 2) continue;
/* Change the phi angle: */
for (atomI = atom_startI; atomI <= atom_endI; atomI++)
{
/* Pointer to the current atom: */
atomSP = mol_complexSP->atomSP + atomI;
/* Do not rotate H, N and CA: */
if ((strcmp (atomSP->raw_atomS.pure_atom_nameA, "H") == 0) ||
(strcmp (atomSP->raw_atomS.pure_atom_nameA, "N") == 0) ||
(strcmp (atomSP->raw_atomS.pure_atom_nameA, "CA") == 0))
{
continue;
}
/* Rotate the current atom about N-CA bond: */
RotateAtom_ (atomSP, &N_vectorS, &CA_vectorS, delta_phi);
}
/* Rotate all atoms after the current residue about N-CA bond: */
for (atomI = atom_endI + 1; atomI < atomsN; atomI++)
{
/* Pointer to the current atom: */
atomSP = mol_complexSP->atomSP + atomI;
/* Rotate atom: */
RotateAtom_ (atomSP, &N_vectorS, &CA_vectorS, delta_phi);
}
}
/* Update dihedral angles and cis-trans flags: */
DihedralAngles_ (mol_complexSP, configSP);
/* Return positive value (trivial): */
return 1;
}
/*===========================================================================*/
|