diff options
author | Thomas White <taw@physics.org> | 2011-07-29 11:31:49 +0200 |
---|---|---|
committer | Thomas White <taw@physics.org> | 2012-02-22 15:27:35 +0100 |
commit | 529830b38e4380a7a35b454324672aaea19580db (patch) | |
tree | 8dfba714d1644bb5bb1bbc38840dca3724ef92fe /src | |
parent | 2f0e2601135491f0aef7ad08738d53e1c2ae6b7b (diff) |
Generate vectors for ReAx search
Diffstat (limited to 'src')
-rw-r--r-- | src/reax.c | 36 |
1 files changed, 36 insertions, 0 deletions
@@ -38,18 +38,54 @@ struct dvec struct reax_private { IndexingPrivate base; + struct dvec *directions; }; IndexingPrivate *reax_prepare() { struct reax_private *priv; + int ui, vi; + int samp; + double angular_inc; priv = calloc(1, sizeof(*priv)); if ( priv == NULL ) return NULL; priv->base.indm = INDEXING_REAX; + /* Decide on sampling interval */ + angular_inc = 0.03; /* From Steller (1997) */ + samp = (2.0 * M_PI) / angular_inc; + + priv->directions = malloc(samp*samp*sizeof(struct dvec)); + if ( priv == NULL) { + free(priv); + return NULL; + } + + for ( ui=0; ui<samp; ui++ ) { + for ( vi=0; vi<samp; vi++ ) { + + double u, v; + double th, ph; + struct dvec *dir; + + u = (double)ui/samp; + v = (double)vi/samp; + + th = 2.0 * M_PI * u; + ph = acos(2.0*v - 1.0); + + dir = &priv->directions[ui + vi*samp]; + + dir->x = cos(th) * sin(ph); + dir->y = sin(th) * sin(th); + dir->z = cos(ph); + + } + } + return (IndexingPrivate *)priv; } |