1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 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 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
|
#include <gtest/gtest.h>
extern "C" {
#include "spglib.h"
#include "utils.h"
}
TEST(Standardization, test_spg_standardize_cell_BCC) {
double lattice[3][3] = {{3.97, 0, 0}, {0, 4.03, 0}, {0, 0, 4.0}};
double position[][3] = {{0.002, 0, 0}, {0.5, 0.5001, 0.5}};
int types[] = {1, 1};
int j, k;
int num_atom = 2;
double symprec = 1e-1;
/* lattice, position, and types are overwritten. */
printf("*** spg_standardize_cell (BCC unitcell --> primitive) ***:\n");
printf("------------------------------------------------------\n");
for (j = 0; j < 2; j++) {
for (k = 0; k < 2; k++) {
ASSERT_EQ(sub_spg_standardize_cell(lattice, position, types,
num_atom, symprec, j, k),
0);
printf("------------------------------------------------------\n");
}
}
}
TEST(Standardization, test_spg_standardize_cell_corundum) {
double lattice[3][3] = {{4.8076344022756095, -2.4038172011378047, 0},
{0, 4.1635335244786962, 0},
{0, 0, 13.1172699198127543}};
double position[][3] = {
{0.0000000000000000, 0.0000000000000000, 0.3521850942289043},
{0.6666666666666643, 0.3333333333333357, 0.6855184275622400},
{0.3333333333333357, 0.6666666666666643, 0.0188517608955686},
{0.0000000000000000, 0.0000000000000000, 0.6478149057711028},
{0.6666666666666643, 0.3333333333333357, 0.9811482391044314},
{0.3333333333333357, 0.6666666666666643, 0.3144815724377600},
{0.0000000000000000, 0.0000000000000000, 0.1478149057710957},
{0.6666666666666643, 0.3333333333333357, 0.4811482391044314},
{0.3333333333333357, 0.6666666666666643, 0.8144815724377600},
{0.0000000000000000, 0.0000000000000000, 0.8521850942288972},
{0.6666666666666643, 0.3333333333333357, 0.1855184275622400},
{0.3333333333333357, 0.6666666666666643, 0.5188517608955686},
{0.3061673906454899, 0.0000000000000000, 0.2500000000000000},
{0.9728340573121541, 0.3333333333333357, 0.5833333333333357},
{0.6395007239788255, 0.6666666666666643, 0.9166666666666643},
{0.6938326093545102, 0.0000000000000000, 0.7500000000000000},
{0.3604992760211744, 0.3333333333333357, 0.0833333333333357},
{0.0271659426878458, 0.6666666666666643, 0.4166666666666643},
{0.0000000000000000, 0.3061673906454899, 0.2500000000000000},
{0.6666666666666643, 0.6395007239788255, 0.5833333333333357},
{0.3333333333333357, 0.9728340573121541, 0.9166666666666643},
{0.0000000000000000, 0.6938326093545102, 0.7500000000000000},
{0.6666666666666643, 0.0271659426878458, 0.0833333333333357},
{0.3333333333333357, 0.3604992760211744, 0.4166666666666643},
{0.6938326093545102, 0.6938326093545102, 0.2500000000000000},
{0.3604992760211744, 0.0271659426878458, 0.5833333333333357},
{0.0271659426878458, 0.3604992760211744, 0.9166666666666643},
{0.3061673906454899, 0.3061673906454899, 0.7500000000000000},
{0.9728340573121541, 0.6395007239788255, 0.0833333333333357},
{0.6395007239788255, 0.9728340573121541, 0.4166666666666643},
};
int types[30];
int i, j, k;
int num_atom = 30;
double symprec = 1e-5;
for (i = 0; i < 12; i++) {
types[i] = 1;
}
for (i = 12; i < 30; i++) {
types[i] = 2;
}
/* lattice, position, and types are overwritten. */
printf("*** spg_standardize_cell (Corundum) ***:\n");
printf("------------------------------------------------------\n");
for (j = 0; j < 2; j++) {
for (k = 0; k < 2; k++) {
ASSERT_EQ(sub_spg_standardize_cell(lattice, position, types,
num_atom, symprec, j, k),
0);
printf("------------------------------------------------------\n");
}
}
}
|