Newer
Older
#ifndef MANTID_GEOMETRY_INDEXING_UTILS_TEST_H_
#define MANTID_GEOMETRY_INDEXING_UTILS_TEST_H_
#include <cxxtest/TestSuite.h>
#include <MantidKernel/Timer.h>
#include <MantidKernel/System.h>
#include <iostream>
#include <iomanip>
Gigg, Martyn Anthony
committed
#include <MantidKernel/V3D.h>
#include <MantidKernel/Matrix.h>
#include <MantidGeometry/Crystal/IndexingUtils.h>
using namespace Mantid::Geometry;
Gigg, Martyn Anthony
committed
using Mantid::Kernel::V3D;
using Mantid::Kernel::Matrix;
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
class IndexingUtilsTest : public CxxTest::TestSuite
{
public:
void test_BestFit_UB()
{
double h_vals[] = { 1, 0, 0, -1, 0, 0, 1, 1 };
double k_vals[] = { .1, 1, 0, 0, -1, 0, 1, 2 };
double l_vals[] = {-.1, 0, 1, 0, 0, -1, 1, 3 };
double qx_vals[] = { 2, 0, 0, -2, 0, 0, 2, 2 };
double qy_vals[] = { 1, 3, 0, 0, -3, 0, 3, 6 };
double qz_vals[] = { 0, 0, 4, 0, 0, -4, 4, 12 };
double correct_UB[] = { 2.000000e+00, 0.000000e+00, -0.000000e+00,
2.766704e-01, 2.959570e+00, -7.214043e-02,
1.580974e-01, -2.310306e-02, 3.958777e+00 };
size_t N_INDEXED_PEAKS = 8;
Matrix<double> UB(3,3,false);
std::vector<V3D> q_list( N_INDEXED_PEAKS );
for ( size_t row = 0; row < N_INDEXED_PEAKS; row++ )
{
V3D qxyz( qx_vals[row], qy_vals[row], qz_vals[row] );
q_list[row] = qxyz;
}
std::vector<V3D> hkl_list( N_INDEXED_PEAKS );
for ( size_t row = 0; row < N_INDEXED_PEAKS; row++ )
{
V3D hkl( h_vals[row], k_vals[row], l_vals[row] );
hkl_list[row] = hkl;
}
double sum_sq_error = IndexingUtils::BestFit_UB( UB, hkl_list, q_list );
std::vector<double> UB_returned = UB.get_vector();
for ( int i = 0; i < 3; i++ )
TS_ASSERT_DELTA( UB_returned[i], correct_UB[i], 1.e-5 );
TS_ASSERT_DELTA( sum_sq_error, 0.390147, 1e-5 );
}
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
void test_NumberIndexed()
{
Matrix<double> UB(3,3,false);
V3D row_values( -0.141251, 0.3042650, -0.147160 );
UB.setRow( 0, row_values );
row_values( 0.120633, 0.0907082, 0.106323 );
UB.setRow( 1, row_values );
row_values( 0.258332, -0.0062807, -0.261151 );
UB.setRow( 2, row_values );
std::vector<V3D> q_list( 5 );
V3D qxyz( -1.02753, 0.47106, -0.25957 );
q_list[0] = qxyz;
qxyz( -2.05753, 0.93893, -0.51988 );
q_list[1] = qxyz;
qxyz( -2.19878, 1.05926, -0.27486 );
q_list[2] = qxyz;
qxyz( -2.63576, 1.39119, -0.53007 );
q_list[3] = qxyz;
qxyz( -1.75324, 1.02999, -0.52537 );
q_list[4] = qxyz;
TS_ASSERT_EQUALS( IndexingUtils::NumberIndexed( UB, q_list, 0.017 ), 4 );
}
void test_ValidIndex()
{
V3D hkl(0,0,0);
TS_ASSERT_EQUALS( IndexingUtils::ValidIndex(hkl,0.1), false );
hkl( 2.09, -3.09, -2.91 );
TS_ASSERT_EQUALS( IndexingUtils::ValidIndex(hkl,0.1), true );
hkl( 2.11, -3.09, -2.91 );
TS_ASSERT_EQUALS( IndexingUtils::ValidIndex(hkl,0.1), false );
hkl( 2.09, -3.11, -2.91 );
TS_ASSERT_EQUALS( IndexingUtils::ValidIndex(hkl,0.1), false );
hkl( 2.09, -3.09, -2.89 );
TS_ASSERT_EQUALS( IndexingUtils::ValidIndex(hkl,0.1), false );
}
void test_MakeHemisphereDirections()
{
std::vector<V3D> direction_list=IndexingUtils::MakeHemisphereDirections(5);
TS_ASSERT_EQUALS( direction_list.size(), 64 );
// check some random entries
TS_ASSERT_DELTA( direction_list[0].X(), 0, 1e-5 );
TS_ASSERT_DELTA( direction_list[0].Y(), 1, 1e-5 );
TS_ASSERT_DELTA( direction_list[0].Z(), 0, 1e-5 );
TS_ASSERT_DELTA( direction_list[5].X(), -0.154508, 1e-5 );
TS_ASSERT_DELTA( direction_list[5].Y(), 0.951057, 1e-5 );
TS_ASSERT_DELTA( direction_list[5].Z(), -0.267617, 1e-5 );
TS_ASSERT_DELTA( direction_list[10].X(), 0, 1e-5 );
TS_ASSERT_DELTA( direction_list[10].Y(), 0.809017, 1e-5 );
TS_ASSERT_DELTA( direction_list[10].Z(), 0.587785, 1e-5 );
TS_ASSERT_DELTA( direction_list[63].X(), -0.951057, 1e-5 );
TS_ASSERT_DELTA( direction_list[63].Y(), 0, 1e-5 );
TS_ASSERT_DELTA( direction_list[63].Z(), 0.309017, 1e-5 );
}
};
#endif /* MANTID_GEOMETRY_INDEXING_UTILS_TEST_H_ */