aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--libcrystfel/src/asdf.c2
-rw-r--r--libcrystfel/src/cell-utils.c25
2 files changed, 12 insertions, 15 deletions
diff --git a/libcrystfel/src/asdf.c b/libcrystfel/src/asdf.c
index 72b110d7..6c9e6ca0 100644
--- a/libcrystfel/src/asdf.c
+++ b/libcrystfel/src/asdf.c
@@ -1083,7 +1083,7 @@ int run_asdf(struct image *image, void *ipriv)
d_max = max(a, b, c) * 3 * 1e10;
- double volume = cell_get_volume(dp->template);
+ double volume = cell_get_volume(dp->template) / 1e30;
/* Divide volume constraints by number of lattice points per
* unit cell since asdf always finds primitive cell */
diff --git a/libcrystfel/src/cell-utils.c b/libcrystfel/src/cell-utils.c
index 59e98775..82b42b98 100644
--- a/libcrystfel/src/cell-utils.c
+++ b/libcrystfel/src/cell-utils.c
@@ -1637,32 +1637,29 @@ int forbidden_reflection(UnitCell *cell,
/**
- * \returns cell volume in A^3
+ * \returns cell volume in m^3
*/
double cell_get_volume(UnitCell *cell)
{
- double asx, asy, asz;
- double bsx, bsy, bsz;
- double csx, csy, csz;
+ double ax, ay, az;
+ double bx, by, bz;
+ double cx, cy, cz;
struct rvec aCb;
- double rec_volume;
- if ( cell_get_reciprocal(cell, &asx, &asy, &asz,
- &bsx, &bsy, &bsz,
- &csx, &csy, &csz) ) {
+ if ( cell_get_cartesian(cell, &ax, &ay, &az,
+ &bx, &by, &bz,
+ &cx, &cy, &cz) ) {
ERROR("Couldn't get reciprocal cell.\n");
return 0;
}
/* "a" cross "b" */
- aCb.u = asy*bsz - asz*bsy;
- aCb.v = - (asx*bsz - asz*bsx);
- aCb.w = asx*bsy - asy*bsx;
+ aCb.u = ay*bz - az*by;
+ aCb.v = - (ax*bz - az*bx);
+ aCb.w = ax*by - ay*bx;
/* "a cross b" dot "c" */
- rec_volume = (aCb.u*csx + aCb.v*csy + aCb.w*csz)/1e30;
-
- return 1/rec_volume;
+ return (aCb.u*cx + aCb.v*cy + aCb.w*cz);
}