Definition at line 102 of file IPositionBuilder.h.
◆ Finite2DLatticePositionBuilder()
Definition at line 177 of file IPositionBuilder.cpp.
std::unique_ptr< InterferenceFunctionFinite2DLattice > m_iff
InterferenceFunctionFinite2DLattice * clone() const override
Returns a clone of this ISampleNode object.
◆ ~Finite2DLatticePositionBuilder()
Finite2DLatticePositionBuilder::~Finite2DLatticePositionBuilder |
( |
| ) |
|
|
overridedefault |
◆ generatePositions()
std::vector< std::vector< double > > IPositionBuilder::generatePositions |
( |
double |
layer_size, |
|
|
double |
density = 0.0 |
|
) |
| const |
|
inherited |
Definition at line 28 of file IPositionBuilder.cpp.
35 std::random_device rd;
36 std::mt19937 gen(rd());
37 std::normal_distribution<double> dis(0.0, std::sqrt(pos_var));
38 for (
auto& position : positions) {
39 for (
auto& coordinate : position)
40 coordinate += dis(gen);
virtual std::vector< std::vector< double > > generatePositionsImpl(double layer_size, double density=0.0) const =0
virtual double positionVariance() const =0
References IPositionBuilder::generatePositionsImpl(), and IPositionBuilder::positionVariance().
◆ generatePositionsImpl()
std::vector< std::vector< double > > Finite2DLatticePositionBuilder::generatePositionsImpl |
( |
double |
layer_size, |
|
|
double |
density = 0.0 |
|
) |
| const |
|
overrideprivatevirtual |
Implements IPositionBuilder.
Definition at line 186 of file IPositionBuilder.cpp.
188 auto& lattice =
m_iff->lattice();
189 double l1 = lattice.length1();
190 double l2 = lattice.length2();
191 double alpha = lattice.latticeAngle();
192 double xi = lattice.rotationAngle();
195 double sina = std::abs(std::sin(alpha));
197 n1 = l1 == 0.0 ? 2 :
static_cast<unsigned>(2.0 * layer_size * std::sqrt(2.0) / l1);
198 n2 = l2 == 0.0 ? 2 :
static_cast<unsigned>(2.0 * layer_size * std::sqrt(2.0) / l2);
200 n1 = l1 == 0.0 ? 2 :
static_cast<unsigned>(2.0 * layer_size * std::sqrt(2.0) / l1 / sina);
201 n2 = l2 == 0.0 ? 2 :
static_cast<unsigned>(2.0 * layer_size * std::sqrt(2.0) / l2 / sina);
203 n1 = std::min(n1,
m_iff->numberUnitCells1());
204 n2 = std::min(n2,
m_iff->numberUnitCells2());
206 return Generate2DLatticePoints(l1, l2, alpha, xi, n1, n2);
References m_iff.
◆ positionVariance()
double Finite2DLatticePositionBuilder::positionVariance |
( |
| ) |
const |
|
overrideprivatevirtual |
◆ m_iff
The documentation for this class was generated from the following files: