mirror of
https://github.com/Discngine/fpocket.git
synced 2026-06-04 11:54:21 +08:00
554 lines
46 KiB
HTML
554 lines
46 KiB
HTML
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
|
|
<html><head><meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
|
|
<title>fpocket: dpocket.c File Reference</title>
|
|
<link href="tabs.css" rel="stylesheet" type="text/css">
|
|
<link href="doxygen.css" rel="stylesheet" type="text/css">
|
|
</head><body>
|
|
<img src="fpocket_logo_small.png" width="545" height="150">
|
|
<!-- Generated by Doxygen 1.5.6 -->
|
|
<script type="text/javascript">
|
|
<!--
|
|
function changeDisplayState (e){
|
|
var num=this.id.replace(/[^[0-9]/g,'');
|
|
var button=this.firstChild;
|
|
var sectionDiv=document.getElementById('dynsection'+num);
|
|
if (sectionDiv.style.display=='none'||sectionDiv.style.display==''){
|
|
sectionDiv.style.display='block';
|
|
button.src='open.gif';
|
|
}else{
|
|
sectionDiv.style.display='none';
|
|
button.src='closed.gif';
|
|
}
|
|
}
|
|
function initDynSections(){
|
|
var divs=document.getElementsByTagName('div');
|
|
var sectionCounter=1;
|
|
for(var i=0;i<divs.length-1;i++){
|
|
if(divs[i].className=='dynheader'&&divs[i+1].className=='dynsection'){
|
|
var header=divs[i];
|
|
var section=divs[i+1];
|
|
var button=header.firstChild;
|
|
if (button!='IMG'){
|
|
divs[i].insertBefore(document.createTextNode(' '),divs[i].firstChild);
|
|
button=document.createElement('img');
|
|
divs[i].insertBefore(button,divs[i].firstChild);
|
|
}
|
|
header.style.cursor='pointer';
|
|
header.onclick=changeDisplayState;
|
|
header.id='dynheader'+sectionCounter;
|
|
button.src='closed.gif';
|
|
section.id='dynsection'+sectionCounter;
|
|
section.style.display='none';
|
|
section.style.marginLeft='14px';
|
|
sectionCounter++;
|
|
}
|
|
}
|
|
}
|
|
window.onload = initDynSections;
|
|
-->
|
|
</script>
|
|
<div class="navigation" id="top">
|
|
<div class="tabs">
|
|
<ul>
|
|
<li><a href="index.html"><span>Main Page</span></a></li>
|
|
<li><a href="annotated.html"><span>Data Structures</span></a></li>
|
|
<li class="current"><a href="files.html"><span>Files</span></a></li>
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
<div class="contents">
|
|
<h1>dpocket.c File Reference</h1><code>#include "<a class="el" href="dpocket_8h-source.html">../headers/dpocket.h</a>"</code><br>
|
|
|
|
<p>
|
|
<a href="dpocket_8c-source.html">Go to the source code of this file.</a><table border="0" cellpadding="0" cellspacing="0">
|
|
<tr><td></td></tr>
|
|
<tr><td colspan="2"><br><h2>Functions</h2></td></tr>
|
|
<tr><td class="memItemLeft" nowrap align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="dpocket_8c.html#7b962a8ea0d00ac566609fb14336c17b">dpocket</a> (<a class="el" href="structs__dparams.html">s_dparams</a> *par)</td></tr>
|
|
|
|
<tr><td class="memItemLeft" nowrap align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="dpocket_8c.html#5413a47106630839ae6ecd90ba9bf9fd">desc_pocket</a> (char fcomplexe[], const char ligname[], <a class="el" href="structs__dparams.html">s_dparams</a> *par, FILE *f[3])</td></tr>
|
|
|
|
<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="el" href="structs__atm.html">s_atm</a> ** </td><td class="memItemRight" valign="bottom"><a class="el" href="dpocket_8c.html#fca470f9d8d1c8e84528205c7aeed723">get_explicit_desc</a> (<a class="el" href="structs__pdb.html">s_pdb</a> *pdb_cplx_l, <a class="el" href="structs__lst__vvertice.html">s_lst_vvertice</a> *verts, <a class="el" href="structs__atm.html">s_atm</a> **lig, int nal, <a class="el" href="structs__dparams.html">s_dparams</a> *par, int *nai, <a class="el" href="structs__desc.html">s_desc</a> *desc)</td></tr>
|
|
|
|
<tr><td class="memItemLeft" nowrap align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="dpocket_8c.html#c32aae31fed030bdb0f31f447fd2e79f">write_pocket_desc</a> (const char fc[], const char l[], <a class="el" href="structs__desc.html">s_desc</a> *d, float lv, float ovlp, float dst, float c4, float c5, FILE *f)</td></tr>
|
|
|
|
</table>
|
|
<hr><h2>Function Documentation</h2>
|
|
<a class="anchor" name="5413a47106630839ae6ecd90ba9bf9fd"></a><!-- doxytag: member="dpocket.c::desc_pocket" ref="5413a47106630839ae6ecd90ba9bf9fd" args="(char fcomplexe[], const char ligname[], s_dparams *par, FILE *f[3])" -->
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">void desc_pocket </td>
|
|
<td>(</td>
|
|
<td class="paramtype">char </td>
|
|
<td class="paramname"> <em>fcomplexe</em>[], </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">const char </td>
|
|
<td class="paramname"> <em>ligname</em>[], </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype"><a class="el" href="structs__dparams.html">s_dparams</a> * </td>
|
|
<td class="paramname"> <em>par</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">FILE * </td>
|
|
<td class="paramname"> <em>f</em>[3]</td><td> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td></td><td></td>
|
|
</tr>
|
|
</table>
|
|
</div>
|
|
<div class="memdoc">
|
|
|
|
<p>
|
|
## FUNCTION: desc_pocket<p>
|
|
## SPECIFICATION: @ const char fcomplexe[] : File containing the PDB @ const char ligname[] : Ligand resname identifier @ <a class="el" href="structs__dparams.html">s_dparams</a> *par : Parameters @ FILE *f[3] : The 3 FILE * to write output in<p>
|
|
## PARAMETRES:<p>
|
|
## RETURN:
|
|
<p>Definition at line <a class="el" href="dpocket_8c-source.html#l00184">184</a> of file <a class="el" href="dpocket_8c-source.html">dpocket.c</a>.</p>
|
|
|
|
<p>References <a class="el" href="descriptors_8c-source.html#l00086">allocate_s_desc()</a>, <a class="el" href="atom_8c-source.html#l00287">atm_corsp()</a>, <a class="el" href="pocket_8h-source.html#l00064">s_pocket::bary</a>, <a class="el" href="pocket_8c-source.html#l01214">c_lst_pocket_free()</a>, <a class="el" href="neighbor_8c-source.html#l00610">count_atm_prop_vert_neigh()</a>, <a class="el" href="neighbor_8c-source.html#l00503">count_pocket_lig_vert_ovlp()</a>, <a class="el" href="calc_8c-source.html#l00075">dist()</a>, <a class="el" href="pocket_8h-source.html#l00089">c_lst_pockets::first</a>, <a class="el" href="dparams_8h-source.html#l00120">s_dparams::fpar</a>, <a class="el" href="rpdb_8c-source.html#l00794">free_pdb_atoms()</a>, <a class="el" href="dpocket_8c-source.html#l00336">get_explicit_desc()</a>, <a class="el" href="atom_8c-source.html#l00179">get_mol_volume_ptr()</a>, <a class="el" href="pocket_8c-source.html#l01369">get_pocket_pvertices()</a>, <a class="el" href="voronoi__lst_8c-source.html#l00225">get_vert_contacted_atms()</a>, <a class="el" href="rpdb_8h-source.html#l00076">s_pdb::latm_lig</a>, <a class="el" href="tpocket_8h-source.html#l00053">M_CRIT4_D</a>, <a class="el" href="tpocket_8h-source.html#l00054">M_CRIT5_D</a>, <a class="el" href="rpdb_8h-source.html#l00050">M_DONT_KEEP_LIG</a>, <a class="el" href="rpdb_8h-source.html#l00049">M_KEEP_LIG</a>, <a class="el" href="memhandler_8c-source.html#l00255">my_free()</a>, <a class="el" href="rpdb_8h-source.html#l00078">s_pdb::natm_lig</a>, <a class="el" href="fparams_8h-source.html#l00141">s_fparams::nb_mcv_iter</a>, <a class="el" href="pocket_8h-source.html#l00080">node_pocket::next</a>, <a class="el" href="pocket_8h-source.html#l00061">s_pocket::pdesc</a>, <a class="el" href="pocket_8h-source.html#l00082">node_pocket::pocket</a>, <a class="el" href="atom_8h-source.html#l00063">s_atm::res_id</a>, <a class="el" href="rpdb_8c-source.html#l00478">rpdb_open()</a>, <a class="el" href="rpdb_8c-source.html#l00599">rpdb_read()</a>, <a class="el" href="fpocket_8c-source.html#l00082">search_pocket()</a>, <a class="el" href="pocket_8h-source.html#l00070">s_pocket::size</a>, <a class="el" href="pocket_8h-source.html#l00063">s_pocket::v_lst</a>, <a class="el" href="pocket_8h-source.html#l00094">c_lst_pockets::vertices</a>, and <a class="el" href="dpocket_8c-source.html#l00403">write_pocket_desc()</a>.</p>
|
|
|
|
<p>Referenced by <a class="el" href="dpocket_8c-source.html#l00116">dpocket()</a>.</p>
|
|
<div class="fragment"><pre class="fragment"><a name="l00186"></a>00186 {
|
|
<a name="l00187"></a>00187 <a class="code" href="structc__lst__pockets.html">c_lst_pockets</a> *pockets = NULL ;
|
|
<a name="l00188"></a>00188 <a class="code" href="structs__lst__vvertice.html">s_lst_vvertice</a> *verts = NULL ;
|
|
<a name="l00189"></a>00189
|
|
<a name="l00190"></a>00190 <a class="code" href="structs__atm.html">s_atm</a> **interface = NULL ;
|
|
<a name="l00191"></a>00191 <a class="code" href="structs__desc.html">s_desc</a> *edesc ;
|
|
<a name="l00192"></a>00192 <a class="code" href="structs__atm.html">s_atm</a> **lig = NULL,
|
|
<a name="l00193"></a>00193 **patoms ;
|
|
<a name="l00194"></a>00194
|
|
<a name="l00195"></a>00195 <span class="keywordtype">float</span> vol, ovlp, dst = 0.0, tmp, c4, c5 ;
|
|
<a name="l00196"></a>00196 <span class="keywordtype">int</span> nal = 0,
|
|
<a name="l00197"></a>00197 nai = 0, <span class="comment">/* Number of atoms in the interface */</span>
|
|
<a name="l00198"></a>00198 nbpa ;
|
|
<a name="l00199"></a>00199 <span class="keywordtype">int</span> j ;
|
|
<a name="l00200"></a>00200
|
|
<a name="l00201"></a>00201 <span class="comment">/*</span>
|
|
<a name="l00202"></a>00202 <span class="comment"> fprintf(stdout, "dpocket: Loading pdb... ") ; fflush(stdout) ;</span>
|
|
<a name="l00203"></a>00203 <span class="comment">*/</span>
|
|
<a name="l00204"></a>00204 <a class="code" href="structs__pdb.html">s_pdb</a> *pdb_cplx_l = <a class="code" href="rpdb_8c.html#29ed3bff6fdc59fd8bf806a35c3127d7">rpdb_open</a>(fcomplexe, ligname, <a class="code" href="rpdb_8h.html#66a6a8deb20e74fd1fd4e597b46ead20">M_KEEP_LIG</a>);
|
|
<a name="l00205"></a>00205 <a class="code" href="structs__pdb.html">s_pdb</a> *pdb_cplx_nl = <a class="code" href="rpdb_8c.html#29ed3bff6fdc59fd8bf806a35c3127d7">rpdb_open</a>(fcomplexe, ligname, <a class="code" href="rpdb_8h.html#067223f2b95bbd02c1861d7d45f393b7">M_DONT_KEEP_LIG</a>) ;
|
|
<a name="l00206"></a>00206
|
|
<a name="l00207"></a>00207 <span class="keywordflow">if</span>(! pdb_cplx_l || !pdb_cplx_nl || pdb_cplx_l-><a class="code" href="structs__pdb.html#659b83804ffc576f1307beac00c1486b">natm_lig</a> <= 0) {
|
|
<a name="l00208"></a>00208 <span class="keywordflow">if</span>(pdb_cplx_l-><a class="code" href="structs__pdb.html#659b83804ffc576f1307beac00c1486b">natm_lig</a> <= 0) {
|
|
<a name="l00209"></a>00209 fprintf(stdout, <span class="stringliteral">"ERROR - No ligand %s found in %s.\n"</span>, ligname, fcomplexe) ;
|
|
<a name="l00210"></a>00210
|
|
<a name="l00211"></a>00211 }
|
|
<a name="l00212"></a>00212 <span class="keywordflow">else</span> fprintf(stdout, <span class="stringliteral">"ERROR - PDB file %s could not be opened\n"</span>, fcomplexe) ;
|
|
<a name="l00213"></a>00213
|
|
<a name="l00214"></a>00214 return ;
|
|
<a name="l00215"></a>00215 }
|
|
<a name="l00216"></a>00216
|
|
<a name="l00217"></a>00217 <a class="code" href="rpdb_8c.html#1ec399102f369c72b06a9944616715b0">rpdb_read</a>(pdb_cplx_l, ligname, <a class="code" href="rpdb_8h.html#66a6a8deb20e74fd1fd4e597b46ead20">M_KEEP_LIG</a>) ;
|
|
<a name="l00218"></a>00218 <a class="code" href="rpdb_8c.html#1ec399102f369c72b06a9944616715b0">rpdb_read</a>(pdb_cplx_nl, ligname, <a class="code" href="rpdb_8h.html#067223f2b95bbd02c1861d7d45f393b7">M_DONT_KEEP_LIG</a>) ;
|
|
<a name="l00219"></a>00219 <span class="comment">/*</span>
|
|
<a name="l00220"></a>00220 <span class="comment"> fprintf(stdout, " OK\n") ;</span>
|
|
<a name="l00221"></a>00221 <span class="comment">*/</span>
|
|
<a name="l00222"></a>00222
|
|
<a name="l00223"></a>00223 lig = pdb_cplx_l-><a class="code" href="structs__pdb.html#fe85c6dd76ee9c740d2869ee30621ea5">latm_lig</a> ;
|
|
<a name="l00224"></a>00224 nal = pdb_cplx_l-><a class="code" href="structs__pdb.html#659b83804ffc576f1307beac00c1486b">natm_lig</a> ;
|
|
<a name="l00225"></a>00225
|
|
<a name="l00226"></a>00226 <span class="comment">/*check if there are multiple ligand mols*/</span>
|
|
<a name="l00227"></a>00227 <span class="keywordtype">int</span> n_lig_molecules=1;
|
|
<a name="l00228"></a>00228 <span class="keywordtype">char</span> chain_tmp[2];
|
|
<a name="l00229"></a>00229 <span class="keywordtype">int</span> resnumber_tmp;
|
|
<a name="l00230"></a>00230 strcpy(chain_tmp,lig[0]->chain);
|
|
<a name="l00231"></a>00231 resnumber_tmp = lig[0]-><a class="code" href="structs__atm.html#7c42c076ce151f4af210bef730b2b88f">res_id</a>;
|
|
<a name="l00232"></a>00232
|
|
<a name="l00233"></a>00233 <span class="keywordflow">for</span> (j = 1 ; j < nal ; j++) {
|
|
<a name="l00234"></a>00234 <span class="keywordflow">if</span>(strcmp(chain_tmp,lig[j]->chain) !=0 || resnumber_tmp!=lig[j]->res_id){
|
|
<a name="l00235"></a>00235 n_lig_molecules++;
|
|
<a name="l00236"></a>00236 strcpy(chain_tmp,lig[j]->chain);
|
|
<a name="l00237"></a>00237 resnumber_tmp =lig[j]-><a class="code" href="structs__atm.html#7c42c076ce151f4af210bef730b2b88f">res_id</a>;
|
|
<a name="l00238"></a>00238 }
|
|
<a name="l00239"></a>00239 }
|
|
<a name="l00240"></a>00240
|
|
<a name="l00241"></a>00241 <span class="comment">/* Getting explicit interface using the known ligand */</span>
|
|
<a name="l00242"></a>00242 <span class="comment">/*</span>
|
|
<a name="l00243"></a>00243 <span class="comment"> fprintf(stdout, "dpocket: Explicit pocket definition... \n") ; </span>
|
|
<a name="l00244"></a>00244 <span class="comment"> fflush(stdout) ;</span>
|
|
<a name="l00245"></a>00245 <span class="comment">*/</span>
|
|
<a name="l00246"></a>00246 pockets = <a class="code" href="fpocket_8c.html#23faf120fcf6ef1442496cba08d4fbd1">search_pocket</a>(pdb_cplx_nl, par-><a class="code" href="structs__dparams.html#84c3e94630fcd2402fd190aad5a0ffbf">fpar</a>,pdb_cplx_l) ;
|
|
<a name="l00247"></a>00247 <span class="keywordflow">if</span>(pockets == NULL) {
|
|
<a name="l00248"></a>00248 fprintf(stdout, <span class="stringliteral">"ERROR - No pocket found for %s\n"</span>, fcomplexe) ;
|
|
<a name="l00249"></a>00249 return ;
|
|
<a name="l00250"></a>00250 }
|
|
<a name="l00251"></a>00251 <span class="comment">//else write_out_fpocket(pockets, pdb_cplx_nl, fcomplexe);</span>
|
|
<a name="l00252"></a>00252 <span class="comment">/*</span>
|
|
<a name="l00253"></a>00253 <span class="comment"> verts = load_vvertices(pdb_cplx_nl, 3, par->fpar->asph_min_size,</span>
|
|
<a name="l00254"></a>00254 <span class="comment"> par->fpar->asph_max_size) ;</span>
|
|
<a name="l00255"></a>00255 <span class="comment">*/</span>
|
|
<a name="l00256"></a>00256
|
|
<a name="l00257"></a>00257 verts = pockets-><a class="code" href="structc__lst__pockets.html#8d86cfec23ef9aa0079cf8258b39863e">vertices</a> ;
|
|
<a name="l00258"></a>00258 edesc = <a class="code" href="descriptors_8c.html#0313250c68f4a7a8e292b674c30ae9fa">allocate_s_desc</a>() ;
|
|
<a name="l00259"></a>00259 interface = <a class="code" href="dpocket_8c.html#fca470f9d8d1c8e84528205c7aeed723">get_explicit_desc</a>(pdb_cplx_l, verts, lig, nal, par,
|
|
<a name="l00260"></a>00260 &nai, edesc) ;
|
|
<a name="l00261"></a>00261
|
|
<a name="l00262"></a>00262 <span class="comment">/* Writing output */</span>
|
|
<a name="l00263"></a>00263 vol = <a class="code" href="atom_8c.html#d0f577a82cfdb135f707700c2b84e6a5">get_mol_volume_ptr</a>(lig, nal, par-><a class="code" href="structs__dparams.html#84c3e94630fcd2402fd190aad5a0ffbf">fpar</a>-><a class="code" href="structs__fparams.html#8caeadbae2db7d24763497290e6b9220">nb_mcv_iter</a>) ;
|
|
<a name="l00264"></a>00264 <a class="code" href="dpocket_8c.html#c32aae31fed030bdb0f31f447fd2e79f">write_pocket_desc</a>(fcomplexe, ligname, edesc, vol, 100.0, 0.0, 1.0, 1.0, f[0]) ;
|
|
<a name="l00265"></a>00265
|
|
<a name="l00266"></a>00266 <a class="code" href="structnode__pocket.html">node_pocket</a> *cur = pockets-><a class="code" href="structc__lst__pockets.html#cf82eb35ce757228759a9af7675f5ad9">first</a> ;
|
|
<a name="l00267"></a>00267 <a class="code" href="structs__vvertice.html">s_vvertice</a> **pvert = NULL ;
|
|
<a name="l00268"></a>00268 <span class="keywordflow">while</span>(cur) {
|
|
<a name="l00269"></a>00269 <span class="comment">/* Get the natomic overlap */</span>
|
|
<a name="l00270"></a>00270 patoms = <a class="code" href="voronoi__lst_8c.html#1aea5e4bcd4dae927a55f7c4dafa194d">get_vert_contacted_atms</a>(cur-><a class="code" href="structnode__pocket.html#8dbdbb50f893fa45bba2d8c03aff6553">pocket</a>-><a class="code" href="structs__pocket.html#cf07f539404d23c1956373f8c93a4fcc">v_lst</a>, &nbpa) ;
|
|
<a name="l00271"></a>00271 ovlp = <a class="code" href="atom_8c.html#a960d66d3bd7cce701a12f56999056b4">atm_corsp</a>(interface, nai, patoms, nbpa) ;
|
|
<a name="l00272"></a>00272
|
|
<a name="l00273"></a>00273 <span class="comment">/* Get the smallest distance of the ligand to the pocket</span>
|
|
<a name="l00274"></a>00274 <span class="comment"> (PocketPicker criteria) */</span>
|
|
<a name="l00275"></a>00275 <span class="keywordflow">for</span> (j = 0 ; j < nal ; j++) {
|
|
<a name="l00276"></a>00276 tmp = <a class="code" href="calc_8c.html#615f3353fc9ccc88069adb4000b21e73">dist</a>(lig[j]->x, lig[j]->y, lig[j]->z,
|
|
<a name="l00277"></a>00277 cur-><a class="code" href="structnode__pocket.html#8dbdbb50f893fa45bba2d8c03aff6553">pocket</a>-><a class="code" href="structs__pocket.html#45fdf0337674ecb9e96cc7d52a08926f">bary</a>[0], cur-><a class="code" href="structnode__pocket.html#8dbdbb50f893fa45bba2d8c03aff6553">pocket</a>-><a class="code" href="structs__pocket.html#45fdf0337674ecb9e96cc7d52a08926f">bary</a>[1],
|
|
<a name="l00278"></a>00278 cur-><a class="code" href="structnode__pocket.html#8dbdbb50f893fa45bba2d8c03aff6553">pocket</a>-><a class="code" href="structs__pocket.html#45fdf0337674ecb9e96cc7d52a08926f">bary</a>[2]) ;
|
|
<a name="l00279"></a>00279 <span class="keywordflow">if</span>(j == 0) dst = tmp ;
|
|
<a name="l00280"></a>00280 <span class="keywordflow">else</span> {
|
|
<a name="l00281"></a>00281 <span class="keywordflow">if</span>(tmp < dst) dst = tmp ;
|
|
<a name="l00282"></a>00282 }
|
|
<a name="l00283"></a>00283 }
|
|
<a name="l00284"></a>00284
|
|
<a name="l00285"></a>00285 <span class="comment">/* Get the consensus criteria too */</span>
|
|
<a name="l00286"></a>00286 pvert = <a class="code" href="pocket_8c.html#86288d8af02eeeb7c4a1b18df3a82af3">get_pocket_pvertices</a>(cur-><a class="code" href="structnode__pocket.html#8dbdbb50f893fa45bba2d8c03aff6553">pocket</a>) ;
|
|
<a name="l00287"></a>00287
|
|
<a name="l00288"></a>00288 c4 = <a class="code" href="neighbor_8c.html#72eb34a8654b78fc8fe8e64b8d49b31a">count_atm_prop_vert_neigh</a>( lig, pdb_cplx_l-><a class="code" href="structs__pdb.html#659b83804ffc576f1307beac00c1486b">natm_lig</a>,
|
|
<a name="l00289"></a>00289 pvert, cur-><a class="code" href="structnode__pocket.html#8dbdbb50f893fa45bba2d8c03aff6553">pocket</a>-><a class="code" href="structs__pocket.html#50722d86f4f1bf5b66b092b2bcbc661f">size</a>, <a class="code" href="tpocket_8h.html#bfe7ce08e878d91f96ca004bace09338">M_CRIT4_D</a>,n_lig_molecules) ;
|
|
<a name="l00290"></a>00290 c5 = <a class="code" href="neighbor_8c.html#3740ecf8c19f6a9a230fc19553ec23ba">count_pocket_lig_vert_ovlp</a>(lig, pdb_cplx_l-><a class="code" href="structs__pdb.html#659b83804ffc576f1307beac00c1486b">natm_lig</a>,
|
|
<a name="l00291"></a>00291 pvert, cur-><a class="code" href="structnode__pocket.html#8dbdbb50f893fa45bba2d8c03aff6553">pocket</a>-><a class="code" href="structs__pocket.html#50722d86f4f1bf5b66b092b2bcbc661f">size</a>, <a class="code" href="tpocket_8h.html#ae4ceec65f3391993a39f87da79e798b">M_CRIT5_D</a>) ;
|
|
<a name="l00292"></a>00292
|
|
<a name="l00293"></a>00293 <span class="comment">/* */</span>
|
|
<a name="l00294"></a>00294 <span class="keywordflow">if</span>(ovlp > 40.0 || dst < 4.0) {
|
|
<a name="l00295"></a>00295 <a class="code" href="dpocket_8c.html#c32aae31fed030bdb0f31f447fd2e79f">write_pocket_desc</a>(fcomplexe, ligname, cur-><a class="code" href="structnode__pocket.html#8dbdbb50f893fa45bba2d8c03aff6553">pocket</a>-><a class="code" href="structs__pocket.html#aba02d3ca1a41adf62ad69884c85fed5">pdesc</a>, vol,
|
|
<a name="l00296"></a>00296 ovlp, dst, c4, c5, f[1]) ;
|
|
<a name="l00297"></a>00297 }
|
|
<a name="l00298"></a>00298 <span class="keywordflow">else</span> {
|
|
<a name="l00299"></a>00299 <a class="code" href="dpocket_8c.html#c32aae31fed030bdb0f31f447fd2e79f">write_pocket_desc</a>(fcomplexe, ligname, cur-><a class="code" href="structnode__pocket.html#8dbdbb50f893fa45bba2d8c03aff6553">pocket</a>-><a class="code" href="structs__pocket.html#aba02d3ca1a41adf62ad69884c85fed5">pdesc</a>, vol,
|
|
<a name="l00300"></a>00300 ovlp, dst, c4, c5, f[2]) ;
|
|
<a name="l00301"></a>00301 }
|
|
<a name="l00302"></a>00302 <a class="code" href="memhandler_8c.html#a49400242a007d208c641f79856ea4c6">my_free</a>(patoms) ;
|
|
<a name="l00303"></a>00303 cur = cur-><a class="code" href="structnode__pocket.html#a33c910dd9e6996001374199f250267e">next</a> ;
|
|
<a name="l00304"></a>00304 }
|
|
<a name="l00305"></a>00305
|
|
<a name="l00306"></a>00306 <span class="comment">/* Free memory */</span>
|
|
<a name="l00307"></a>00307 <a class="code" href="pocket_8c.html#a9afcc69c1f7bdce1f22b0c48397b242">c_lst_pocket_free</a>(pockets) ;
|
|
<a name="l00308"></a>00308 <a class="code" href="memhandler_8c.html#a49400242a007d208c641f79856ea4c6">my_free</a>(interface) ;
|
|
<a name="l00309"></a>00309 <a class="code" href="rpdb_8c.html#fda283d39ae56654675e9e858f5ffdea">free_pdb_atoms</a>(pdb_cplx_l) ;
|
|
<a name="l00310"></a>00310 <a class="code" href="rpdb_8c.html#fda283d39ae56654675e9e858f5ffdea">free_pdb_atoms</a>(pdb_cplx_nl) ;
|
|
<a name="l00311"></a>00311
|
|
<a name="l00312"></a>00312 }
|
|
</pre></div>
|
|
<p>
|
|
|
|
</div>
|
|
</div><p>
|
|
<a class="anchor" name="7b962a8ea0d00ac566609fb14336c17b"></a><!-- doxytag: member="dpocket.c::dpocket" ref="7b962a8ea0d00ac566609fb14336c17b" args="(s_dparams *par)" -->
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">void dpocket </td>
|
|
<td>(</td>
|
|
<td class="paramtype"><a class="el" href="structs__dparams.html">s_dparams</a> * </td>
|
|
<td class="paramname"> <em>par</em> </td>
|
|
<td> ) </td>
|
|
<td></td>
|
|
</tr>
|
|
</table>
|
|
</div>
|
|
<div class="memdoc">
|
|
|
|
<p>
|
|
## FUNCTION: dpocket<p>
|
|
## SPECIFICATION: Dpocket main function. Simple loop is performed over all files.<p>
|
|
## PARAMETRES: @ <a class="el" href="structs__dparams.html">s_dparams</a> *par: Parameters of the programm<p>
|
|
## RETURN: void
|
|
<p>Definition at line <a class="el" href="dpocket_8c-source.html#l00116">116</a> of file <a class="el" href="dpocket_8c-source.html">dpocket.c</a>.</p>
|
|
|
|
<p>References <a class="el" href="dpocket_8c-source.html#l00184">desc_pocket()</a>, <a class="el" href="dparams_8h-source.html#l00111">s_dparams::f_exp</a>, <a class="el" href="dparams_8h-source.html#l00111">s_dparams::f_fpcknp</a>, <a class="el" href="dparams_8h-source.html#l00111">s_dparams::f_fpckp</a>, <a class="el" href="dparams_8h-source.html#l00108">s_dparams::fcomplex</a>, <a class="el" href="aa_8c-source.html#l00117">get_aa_name3()</a>, <a class="el" href="dparams_8h-source.html#l00108">s_dparams::ligs</a>, <a class="el" href="dpocket_8h-source.html#l00064">M_DP_OUTP_HEADER</a>, and <a class="el" href="dparams_8h-source.html#l00117">s_dparams::nfiles</a>.</p>
|
|
|
|
<p>Referenced by <a class="el" href="dpmain_8c-source.html#l00067">main()</a>.</p>
|
|
<div class="fragment"><pre class="fragment"><a name="l00117"></a>00117 {
|
|
<a name="l00118"></a>00118 <span class="keywordtype">int</span> i, j ;
|
|
<a name="l00119"></a>00119 FILE *fout[3] ;
|
|
<a name="l00120"></a>00120
|
|
<a name="l00121"></a>00121 <span class="keywordflow">if</span>(par) {
|
|
<a name="l00122"></a>00122 <span class="comment">/* Opening output file file */</span>
|
|
<a name="l00123"></a>00123
|
|
<a name="l00124"></a>00124 fout[0] = fopen(par-><a class="code" href="structs__dparams.html#eed722b226fde5c51dfa3e2f83d9a6d3">f_exp</a>,<span class="stringliteral">"w"</span>) ;
|
|
<a name="l00125"></a>00125 fout[1] = fopen(par-><a class="code" href="structs__dparams.html#3f14e5f303fbf919cd6f9abab8505c68">f_fpckp</a>,<span class="stringliteral">"w"</span>) ;
|
|
<a name="l00126"></a>00126 fout[2] = fopen(par-><a class="code" href="structs__dparams.html#b1b7fc562b81d0670f3044252a2d4c34">f_fpcknp</a>,<span class="stringliteral">"w"</span>) ;
|
|
<a name="l00127"></a>00127
|
|
<a name="l00128"></a>00128 <span class="keywordflow">if</span>(fout[0] && fout[1] && fout[2]) {
|
|
<a name="l00129"></a>00129
|
|
<a name="l00130"></a>00130 <span class="comment">/* Writing column names */</span>
|
|
<a name="l00131"></a>00131
|
|
<a name="l00132"></a>00132 <span class="keywordflow">for</span>( i = 0 ; i < 3 ; i++ ) {
|
|
<a name="l00133"></a>00133 fprintf(fout[i], <a class="code" href="dpocket_8h.html#23343f9b8e0f8438a1e800f657eebc55">M_DP_OUTP_HEADER</a>) ;
|
|
<a name="l00134"></a>00134 <span class="keywordflow">for</span>( j = 0 ; j < 20 ; j++ ) fprintf(fout[i], <span class="stringliteral">" %s"</span>, <a class="code" href="aa_8c.html#f071a7d6353978202a07fd66f2ff68d8">get_aa_name3</a>(j));
|
|
<a name="l00135"></a>00135 fprintf(fout[i], <span class="stringliteral">"\n"</span>);
|
|
<a name="l00136"></a>00136 }
|
|
<a name="l00137"></a>00137
|
|
<a name="l00138"></a>00138 <span class="comment">/* Begins dpocket */</span>
|
|
<a name="l00139"></a>00139 <span class="keywordflow">for</span>(i = 0 ; i < par-><a class="code" href="structs__dparams.html#04c48f5eb6778c9a5022588e507043d3">nfiles</a> ; i++) {
|
|
<a name="l00140"></a>00140 fprintf(stdout, <span class="stringliteral">"<dpocket>s %d/%d - %s:"</span>,
|
|
<a name="l00141"></a>00141 i+1, par-><a class="code" href="structs__dparams.html#04c48f5eb6778c9a5022588e507043d3">nfiles</a>, par-><a class="code" href="structs__dparams.html#a98295f566006ae97eef0628a9c94a86">fcomplex</a>[i]) ;
|
|
<a name="l00142"></a>00142
|
|
<a name="l00143"></a>00143 <a class="code" href="dpocket_8c.html#5413a47106630839ae6ecd90ba9bf9fd">desc_pocket</a>(par-><a class="code" href="structs__dparams.html#a98295f566006ae97eef0628a9c94a86">fcomplex</a>[i], par-><a class="code" href="structs__dparams.html#d3fbaf401c68c3abf7ef662259e547d6">ligs</a>[i], par, fout) ;
|
|
<a name="l00144"></a>00144 <span class="keywordflow">if</span>(i == par-><a class="code" href="structs__dparams.html#04c48f5eb6778c9a5022588e507043d3">nfiles</a> - 1) fprintf(stdout,<span class="stringliteral">"\n"</span>) ;
|
|
<a name="l00145"></a>00145 <span class="keywordflow">else</span> fprintf(stdout,<span class="stringliteral">"\r"</span>) ;
|
|
<a name="l00146"></a>00146
|
|
<a name="l00147"></a>00147 fflush(stdout) ;
|
|
<a name="l00148"></a>00148 }
|
|
<a name="l00149"></a>00149
|
|
<a name="l00150"></a>00150 <span class="keywordflow">for</span>( i = 0 ; i < 3 ; i++ ) fclose(fout[i]) ;
|
|
<a name="l00151"></a>00151 }
|
|
<a name="l00152"></a>00152 <span class="keywordflow">else</span> {
|
|
<a name="l00153"></a>00153 <span class="keywordflow">if</span>(! fout[0]) {
|
|
<a name="l00154"></a>00154 fprintf(stdout, <span class="stringliteral">"! Output file <%s> couldn't be opened.\n"</span>,
|
|
<a name="l00155"></a>00155 par-><a class="code" href="structs__dparams.html#eed722b226fde5c51dfa3e2f83d9a6d3">f_exp</a>) ;
|
|
<a name="l00156"></a>00156 }
|
|
<a name="l00157"></a>00157 <span class="keywordflow">else</span> <span class="keywordflow">if</span> (! fout[1]) {
|
|
<a name="l00158"></a>00158 fprintf(stdout, <span class="stringliteral">"! Output file <%s> couldn't be opened.\n"</span>,
|
|
<a name="l00159"></a>00159 par-><a class="code" href="structs__dparams.html#3f14e5f303fbf919cd6f9abab8505c68">f_fpckp</a>) ;
|
|
<a name="l00160"></a>00160 }
|
|
<a name="l00161"></a>00161 <span class="keywordflow">else</span> {
|
|
<a name="l00162"></a>00162 fprintf(stdout, <span class="stringliteral">"! Output file <%s> couldn't be opened.\n"</span>,
|
|
<a name="l00163"></a>00163 par-><a class="code" href="structs__dparams.html#b1b7fc562b81d0670f3044252a2d4c34">f_fpcknp</a>) ;
|
|
<a name="l00164"></a>00164 }
|
|
<a name="l00165"></a>00165 }
|
|
<a name="l00166"></a>00166 }
|
|
<a name="l00167"></a>00167 }
|
|
</pre></div>
|
|
<p>
|
|
|
|
</div>
|
|
</div><p>
|
|
<a class="anchor" name="fca470f9d8d1c8e84528205c7aeed723"></a><!-- doxytag: member="dpocket.c::get_explicit_desc" ref="fca470f9d8d1c8e84528205c7aeed723" args="(s_pdb *pdb_cplx_l, s_lst_vvertice *verts, s_atm **lig, int nal, s_dparams *par, int *nai, s_desc *desc)" -->
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname"><a class="el" href="structs__atm.html">s_atm</a>** get_explicit_desc </td>
|
|
<td>(</td>
|
|
<td class="paramtype"><a class="el" href="structs__pdb.html">s_pdb</a> * </td>
|
|
<td class="paramname"> <em>pdb_cplx_l</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype"><a class="el" href="structs__lst__vvertice.html">s_lst_vvertice</a> * </td>
|
|
<td class="paramname"> <em>verts</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype"><a class="el" href="structs__atm.html">s_atm</a> ** </td>
|
|
<td class="paramname"> <em>lig</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">int </td>
|
|
<td class="paramname"> <em>nal</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype"><a class="el" href="structs__dparams.html">s_dparams</a> * </td>
|
|
<td class="paramname"> <em>par</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">int * </td>
|
|
<td class="paramname"> <em>nai</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype"><a class="el" href="structs__desc.html">s_desc</a> * </td>
|
|
<td class="paramname"> <em>desc</em></td><td> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td></td><td></td>
|
|
</tr>
|
|
</table>
|
|
</div>
|
|
<div class="memdoc">
|
|
|
|
<p>
|
|
## FUNCTION: get_explicit_desc<p>
|
|
## SPECIFICATION: Determine the explicit pocket (see comments at the top of the file), and calculate descriptors (and fill the input structure)<p>
|
|
## PARAMETRES: @ <a class="el" href="structs__pdb.html">s_pdb</a> *pdb_cplx_l : The pdb structure @ <a class="el" href="structs__lst__vvertice.html">s_lst_vvertice</a> *verts : The vertices found @ <a class="el" href="structs__atm.html">s_atm</a> **lig : Atoms of the ligand @ int nal : Number of atom in the ligand @ <a class="el" href="structs__dparams.html">s_dparams</a> *par : Parameters @ int *nai : OUTPUT Number of atom in the interface @ <a class="el" href="structs__desc.html">s_desc</a> *desc : OUTPUT Descriptors<p>
|
|
## RETURN: <a class="el" href="structs__atm.html">s_atm</a> **: List of pointer to atoms defining the explicit pocket. plus nai and desc are filled.
|
|
<p>Definition at line <a class="el" href="dpocket_8c-source.html#l00336">336</a> of file <a class="el" href="dpocket_8c-source.html">dpocket.c</a>.</p>
|
|
|
|
<p>References <a class="el" href="fparams_8h-source.html#l00139">s_fparams::flag_do_asa_and_volume_calculations</a>, <a class="el" href="dparams_8h-source.html#l00120">s_dparams::fpar</a>, <a class="el" href="neighbor_8c-source.html#l00090">get_mol_atm_neigh()</a>, <a class="el" href="neighbor_8c-source.html#l00332">get_mol_ctd_atm_neigh()</a>, <a class="el" href="neighbor_8c-source.html#l00213">get_mol_vert_neigh()</a>, <a class="el" href="dparams_8h-source.html#l00115">s_dparams::interface_dist_crit</a>, <a class="el" href="dparams_8h-source.html#l00117">s_dparams::interface_method</a>, <a class="el" href="rpdb_8h-source.html#l00074">s_pdb::latoms_p</a>, <a class="el" href="dparams_8h-source.html#l00066">M_INTERFACE_METHOD2</a>, <a class="el" href="neighbor_8h-source.html#l00053">M_INTERFACE_SEARCH</a>, <a class="el" href="memhandler_8c-source.html#l00255">my_free()</a>, <a class="el" href="rpdb_8h-source.html#l00078">s_pdb::natoms</a>, <a class="el" href="fparams_8h-source.html#l00141">s_fparams::nb_mcv_iter</a>, <a class="el" href="voronoi_8h-source.html#l00100">s_lst_vvertice::nvert</a>, <a class="el" href="voronoi_8h-source.html#l00096">s_lst_vvertice::pvertices</a>, and <a class="el" href="descriptors_8c-source.html#l00182">set_descriptors()</a>.</p>
|
|
|
|
<p>Referenced by <a class="el" href="dpocket_8c-source.html#l00184">desc_pocket()</a>.</p>
|
|
<div class="fragment"><pre class="fragment"><a name="l00338"></a>00338 {
|
|
<a name="l00339"></a>00339 <span class="keywordtype">int</span> nvn = 0 ; <span class="comment">/* Number of vertices in the interface */</span>
|
|
<a name="l00340"></a>00340
|
|
<a name="l00341"></a>00341 <a class="code" href="structs__atm.html">s_atm</a> **interface = NULL ;
|
|
<a name="l00342"></a>00342
|
|
<a name="l00343"></a>00343 <span class="comment">/*</span>
|
|
<a name="l00344"></a>00344 <span class="comment"> fprintf(stdout, "dpocket: Determning explicit interface... ") ; </span>
|
|
<a name="l00345"></a>00345 <span class="comment"> fflush(stdout) ;</span>
|
|
<a name="l00346"></a>00346 <span class="comment">*/</span>
|
|
<a name="l00347"></a>00347
|
|
<a name="l00348"></a>00348 <span class="keywordflow">if</span>(par-><a class="code" href="structs__dparams.html#f48783ed6b360f7a3e83eb4c7ae11300">interface_method</a> == <a class="code" href="dparams_8h.html#8364a85272afb754f95f5f76832a82ac">M_INTERFACE_METHOD2</a>) {
|
|
<a name="l00349"></a>00349 <span class="comment">/* Use the distance-based method to define the interface */</span>
|
|
<a name="l00350"></a>00350 interface = <a class="code" href="neighbor_8c.html#48bd2094854cf343b3f75e93997bea04">get_mol_atm_neigh</a>( lig, nal, pdb_cplx_l-><a class="code" href="structs__pdb.html#4517e3a82dbf0f34e73d1865e484dbfd">latoms_p</a>,
|
|
<a name="l00351"></a>00351 pdb_cplx_l-><a class="code" href="structs__pdb.html#85aaf7bdb931bb303af1ca736a998b98">natoms</a>,
|
|
<a name="l00352"></a>00352 par-><a class="code" href="structs__dparams.html#09b829e05d79410ee1471242ab622cac">interface_dist_crit</a>, nai) ;
|
|
<a name="l00353"></a>00353 }
|
|
<a name="l00354"></a>00354 <span class="keywordflow">else</span> {
|
|
<a name="l00355"></a>00355 <span class="comment">/* Use the voronoi vertices-based method to define the interface */</span>
|
|
<a name="l00356"></a>00356
|
|
<a name="l00357"></a>00357 interface = <a class="code" href="neighbor_8c.html#60519bcf15270301f71419d124eb930c">get_mol_ctd_atm_neigh</a>(lig, nal, verts-><a class="code" href="structs__lst__vvertice.html#638d9ede844bca411ed99cb8e22b0e56">pvertices</a>, verts-><a class="code" href="structs__lst__vvertice.html#c6b07ac45ca65ccd944b68afd4c18bfb">nvert</a>,
|
|
<a name="l00358"></a>00358 par-><a class="code" href="structs__dparams.html#09b829e05d79410ee1471242ab622cac">interface_dist_crit</a>,
|
|
<a name="l00359"></a>00359 <a class="code" href="neighbor_8h.html#1c318ac74ea9b85f4cc72cc40b4709c8">M_INTERFACE_SEARCH</a>, nai) ;
|
|
<a name="l00360"></a>00360 }
|
|
<a name="l00361"></a>00361
|
|
<a name="l00362"></a>00362 <span class="comment">/* Get a tab of pointer for interface's vertices to send a correct argument </span>
|
|
<a name="l00363"></a>00363 <span class="comment"> * type to set_descriptors */</span>
|
|
<a name="l00364"></a>00364 <a class="code" href="structs__vvertice.html">s_vvertice</a> **tpverts = <a class="code" href="neighbor_8c.html#7bed24829e9d106de97de75a5538199a">get_mol_vert_neigh</a>(lig, nal, verts-><a class="code" href="structs__lst__vvertice.html#638d9ede844bca411ed99cb8e22b0e56">pvertices</a>, verts-><a class="code" href="structs__lst__vvertice.html#c6b07ac45ca65ccd944b68afd4c18bfb">nvert</a>,
|
|
<a name="l00365"></a>00365 par-><a class="code" href="structs__dparams.html#09b829e05d79410ee1471242ab622cac">interface_dist_crit</a>, &nvn) ;
|
|
<a name="l00366"></a>00366
|
|
<a name="l00367"></a>00367 <span class="comment">/* Ok we have the interface and the correct vertices list, now calculate </span>
|
|
<a name="l00368"></a>00368 <span class="comment"> * descriptors and write it.</span>
|
|
<a name="l00369"></a>00369 <span class="comment"> **/</span>
|
|
<a name="l00370"></a>00370 <span class="comment">/*</span>
|
|
<a name="l00371"></a>00371 <span class="comment"> fprintf(stdout, "dpocket: Calculating descriptors... ") ; fflush(stdout) ;</span>
|
|
<a name="l00372"></a>00372 <span class="comment">*/</span>
|
|
<a name="l00373"></a>00373 <a class="code" href="descriptors_8c.html#9cfae44d2e72d4c92d38a4b73538d8c4">set_descriptors</a>(interface, *nai, tpverts, nvn, desc, par-><a class="code" href="structs__dparams.html#84c3e94630fcd2402fd190aad5a0ffbf">fpar</a>-><a class="code" href="structs__fparams.html#8caeadbae2db7d24763497290e6b9220">nb_mcv_iter</a>,pdb_cplx_l,par-><a class="code" href="structs__dparams.html#84c3e94630fcd2402fd190aad5a0ffbf">fpar</a>-><a class="code" href="structs__fparams.html#771a10e1c94346d353eb6cb87b4abb18">flag_do_asa_and_volume_calculations</a>);
|
|
<a name="l00374"></a>00374 <span class="comment">/*</span>
|
|
<a name="l00375"></a>00375 <span class="comment"> fprintf(stdout, " OK\n") ;</span>
|
|
<a name="l00376"></a>00376 <span class="comment">*/</span>
|
|
<a name="l00377"></a>00377
|
|
<a name="l00378"></a>00378 <span class="comment">/* Free memory */</span>
|
|
<a name="l00379"></a>00379 <a class="code" href="memhandler_8c.html#a49400242a007d208c641f79856ea4c6">my_free</a>(tpverts) ;
|
|
<a name="l00380"></a>00380
|
|
<a name="l00381"></a>00381 <span class="keywordflow">return</span> interface ;
|
|
<a name="l00382"></a>00382 }
|
|
</pre></div>
|
|
<p>
|
|
|
|
</div>
|
|
</div><p>
|
|
<a class="anchor" name="c32aae31fed030bdb0f31f447fd2e79f"></a><!-- doxytag: member="dpocket.c::write_pocket_desc" ref="c32aae31fed030bdb0f31f447fd2e79f" args="(const char fc[], const char l[], s_desc *d, float lv, float ovlp, float dst, float c4, float c5, FILE *f)" -->
|
|
<div class="memitem">
|
|
<div class="memproto">
|
|
<table class="memname">
|
|
<tr>
|
|
<td class="memname">void write_pocket_desc </td>
|
|
<td>(</td>
|
|
<td class="paramtype">const char </td>
|
|
<td class="paramname"> <em>fc</em>[], </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">const char </td>
|
|
<td class="paramname"> <em>l</em>[], </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype"><a class="el" href="structs__desc.html">s_desc</a> * </td>
|
|
<td class="paramname"> <em>d</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">float </td>
|
|
<td class="paramname"> <em>lv</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">float </td>
|
|
<td class="paramname"> <em>ovlp</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">float </td>
|
|
<td class="paramname"> <em>dst</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">float </td>
|
|
<td class="paramname"> <em>c4</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">float </td>
|
|
<td class="paramname"> <em>c5</em>, </td>
|
|
</tr>
|
|
<tr>
|
|
<td class="paramkey"></td>
|
|
<td></td>
|
|
<td class="paramtype">FILE * </td>
|
|
<td class="paramname"> <em>f</em></td><td> </td>
|
|
</tr>
|
|
<tr>
|
|
<td></td>
|
|
<td>)</td>
|
|
<td></td><td></td><td></td>
|
|
</tr>
|
|
</table>
|
|
</div>
|
|
<div class="memdoc">
|
|
|
|
<p>
|
|
## FUNCTION: write_pocket_desc<p>
|
|
## SPECIFICATION: Write pocket descriptors into a file.<p>
|
|
## PARAMETRES: @ const char fc[] : Name of the pdb file @ const char l[] : Resname of the ligand @ <a class="el" href="structs__desc.html">s_desc</a> *d : Stucture of descriptors @ float lv : Ligand volume @ float ovlp : Overlap @ FILE *f : Buffer to write in<p>
|
|
## RETURN: void
|
|
<p>Definition at line <a class="el" href="dpocket_8c-source.html#l00403">403</a> of file <a class="el" href="dpocket_8c-source.html">dpocket.c</a>.</p>
|
|
|
|
<p>References <a class="el" href="descriptors_8h-source.html#l00094">s_desc::aa_compo</a>, <a class="el" href="tpocket_8h-source.html#l00059">M_CRIT4_VAL</a>, <a class="el" href="tpocket_8h-source.html#l00060">M_CRIT5_VAL</a>, <a class="el" href="dpocket_8h-source.html#l00066">M_DP_OUTP_FORMAT</a>, and <a class="el" href="dpocket_8h-source.html#l00067">M_DP_OUTP_VAR</a>.</p>
|
|
|
|
<p>Referenced by <a class="el" href="dpocket_8c-source.html#l00184">desc_pocket()</a>.</p>
|
|
<div class="fragment"><pre class="fragment"><a name="l00405"></a>00405 {
|
|
<a name="l00406"></a>00406 <span class="keywordtype">int</span> status = 0 ;
|
|
<a name="l00407"></a>00407 <span class="keywordflow">if</span>(dst < 4.0) status = 1 ;
|
|
<a name="l00408"></a>00408
|
|
<a name="l00409"></a>00409 <span class="keywordtype">int</span> c6 = (c4 >= <a class="code" href="tpocket_8h.html#e6144aeda44c4bb02f1f9497785d2510">M_CRIT4_VAL</a> && c5 >= <a class="code" href="tpocket_8h.html#8e29f7a52f508cd17213fe9e6d7f9b03">M_CRIT5_VAL</a>) ?1:0 ;
|
|
<a name="l00410"></a>00410 <span class="keywordtype">float</span> c6_c = ((c4 - <a class="code" href="tpocket_8h.html#e6144aeda44c4bb02f1f9497785d2510">M_CRIT4_VAL</a>)/ (1-<a class="code" href="tpocket_8h.html#e6144aeda44c4bb02f1f9497785d2510">M_CRIT4_VAL</a>)) + ((c5 - <a class="code" href="tpocket_8h.html#8e29f7a52f508cd17213fe9e6d7f9b03">M_CRIT5_VAL</a>)/ (1-<a class="code" href="tpocket_8h.html#8e29f7a52f508cd17213fe9e6d7f9b03">M_CRIT5_VAL</a>)) ;
|
|
<a name="l00411"></a>00411
|
|
<a name="l00412"></a>00412 fprintf(f, <a class="code" href="dpocket_8h.html#37abd6af8ee30c796fbb1515bb8b8254">M_DP_OUTP_FORMAT</a>, <a class="code" href="dpocket_8h.html#f3b98e7b7baf7f23c259c71912aa40d9">M_DP_OUTP_VAR</a>(fc, l, ovlp, status, dst, c4, c5, c6, c6_c, lv, d)) ;
|
|
<a name="l00413"></a>00413
|
|
<a name="l00414"></a>00414 <span class="keywordtype">int</span> i ;
|
|
<a name="l00415"></a>00415 <span class="keywordflow">for</span>(i = 0 ; i < 20 ; i++) fprintf(f, <span class="stringliteral">" %3d"</span>, d-><a class="code" href="structs__desc.html#12f239c0748ce08dba80fac61722117f">aa_compo</a>[i]) ;
|
|
<a name="l00416"></a>00416
|
|
<a name="l00417"></a>00417 fprintf(f, <span class="stringliteral">"\n"</span>) ;
|
|
<a name="l00418"></a>00418 }
|
|
</pre></div>
|
|
<p>
|
|
|
|
</div>
|
|
</div><p>
|
|
</div>
|
|
<hr size="1"><address style="text-align: right;"><small>Generated on Mon Jun 7 16:44:23 2010 for fpocket by
|
|
<a href="http://www.doxygen.org/index.html">
|
|
<img src="doxygen.png" alt="doxygen" align="middle" border="0"></a> 1.5.6 </small></address>
|
|
</body>
|
|
</html>
|