Main Page   Namespace List   Class Hierarchy   Alphabetical List   Compound List   File List   Namespace Members   Compound Members   File Members   Related Pages  

BondSearch.C File Reference

#include <stdio.h>
#include <math.h>
#include <stdlib.h>
#include "BondSearch.h"
#include "Timestep.h"
#include "BaseMolecule.h"
#include "Molecule.h"
#include "Inform.h"
#include "WKFThreads.h"
#include "WKFUtils.h"
#include <ctype.h>
#include <string.h>

Go to the source code of this file.

Compounds

struct  bondsearchthrparms

Functions

GridSearchPairlistvmd_gridsearch_bonds (const float *pos, const float *radii, int natoms, float pairdist, int maxpairs)
 Grid search for the case of a single set of atoms. It ignore pairs between atoms with identical coords. The maxpairs parameter is set to -1 for no-limit pairlist calculation, or a maximum value otherwise. This is the same code as gridsearch1(), but simplified and hopefully a bit faster. More...

void * bondsearchthread (void *)
int vmd_bondsearch_thr (const float *pos, const float *radii, GridSearchPairlist *head, int totb, int **boxatom, int *numinbox, int **nbrlist, int maxpairs, float pairdist)
 Multithreaded bond search worker routine handles spawning and joining all of the worker threads, and merging their results into a single list. More...

int vmd_bond_search (BaseMolecule *mol, const Timestep *ts, float cutoff, int dupcheck)
 Compute bonds for the molecule using the given timestep (which must not be NULL) and adds them to the given molecule. Return success. The code currently calls gridsearch1 with a pairlist limit of 27 * natoms, which should easily be sufficient for any real structure. More...


Function Documentation

void * bondsearchthread void *   
 

Definition at line 275 of file BondSearch.C.

References ResizeArray::append, bondsearchthrparms::boxatom, bondsearchthrparms::head, bondsearchthrparms::maxpairs, bondsearchthrparms::nbrlist, GridSearchPairlist::next, NULL, bondsearchthrparms::numinbox, bondsearchthrparms::pairdist, GridSearchPairlist::pairlist, bondsearchthrparms::pairlistmutex, bondsearchthrparms::pos, bondsearchthrparms::radii, bondsearchthrparms::threadcount, bondsearchthrparms::threadid, bondsearchthrparms::totb, wkf_msg_timer_create, wkf_msg_timer_destroy, wkf_msg_timer_timeout, wkf_mutex_lock, wkf_mutex_t, and wkf_mutex_unlock.

Referenced by vmd_bondsearch_thr.

int vmd_bond_search BaseMolecule   mol,
const Timestep   ts,
float    cutoff,
int    dupcheck
 

Compute bonds for the molecule using the given timestep (which must not be NULL) and adds them to the given molecule. Return success. The code currently calls gridsearch1 with a pairlist limit of 27 * natoms, which should easily be sufficient for any real structure.

Definition at line 373 of file BondSearch.C.

References BaseMolecule::add_bond, BaseMolecule::add_bond_dupcheck, MolAtom::altlocindex, BaseMolecule::altlocNames, BaseMolecule::atom, ATOMHYDROGEN, BaseMolecule::atomNames, MolAtom::atomType, IS_HYDROGEN, NameList< int >::name, MolAtom::nameindex, BaseMolecule::nAtoms, GridSearchPairlist::next, NULL, ResizeArray< int >::num, GridSearchPairlist::pairlist, Timestep::pos, BaseMolecule::radius, and vmd_gridsearch_bonds.

int vmd_bondsearch_thr const float *    pos,
const float *    radii,
GridSearchPairlist   head,
int    totb,
int **    boxatom,
int *    numinbox,
int **    nbrlist,
int    maxpairs,
float    pairdist
 

Multithreaded bond search worker routine handles spawning and joining all of the worker threads, and merging their results into a single list.

Definition at line 210 of file BondSearch.C.

References bondsearchthread, bondsearchthrparms::boxatom, bondsearchthrparms::head, bondsearchthrparms::maxpairs, bondsearchthrparms::nbrlist, GridSearchPairlist::next, NULL, bondsearchthrparms::numinbox, bondsearchthrparms::pairdist, bondsearchthrparms::pairlistmutex, bondsearchthrparms::pos, bondsearchthrparms::radii, bondsearchthrparms::threadcount, bondsearchthrparms::threadid, bondsearchthrparms::totb, wkf_mutex_destroy, wkf_mutex_init, wkf_mutex_t, wkf_thread_create, wkf_thread_join, wkf_thread_numprocessors, and wkf_thread_t.

GridSearchPairlist* vmd_gridsearch_bonds const float *    pos,
const float *    radii,
int    natoms,
float    pairdist,
int    maxpairs
 

Grid search for the case of a single set of atoms. It ignore pairs between atoms with identical coords. The maxpairs parameter is set to -1 for no-limit pairlist calculation, or a maximum value otherwise. This is the same code as gridsearch1(), but simplified and hopefully a bit faster.

Definition at line 37 of file BondSearch.C.

References find_minmax_all, make_neighborlist, minmax_3fv_aligned, GridSearchPairlist::next, NULL, num, vec_sub, and vmd_bondsearch_thr.


Generated on Fri Oct 24 02:45:48 2025 for VMD (current) by doxygen1.2.14 written by Dimitri van Heesch, © 1997-2002