-
Wuttke, Joachim authoredWuttke, Joachim authored
FormFactorWeighted.cpp 3.11 KiB
// ************************************************************************************************
//
// BornAgain: simulate and fit reflection and scattering
//
//! @file Sample/Particle/FormFactorWeighted.cpp
//! @brief Implements class FormFactorWeighted.
//!
//! @homepage http://www.bornagainproject.org
//! @license GNU General Public License v3 or higher (see COPYING)
//! @copyright Forschungszentrum Jülich GmbH 2018
//! @authors Scientific Computing Group at MLZ (see CITATION, AUTHORS)
//
// ************************************************************************************************
#include "Sample/Particle/FormFactorWeighted.h"
#include "Base/Util/Algorithms.h"
FormFactorWeighted::~FormFactorWeighted()
{
for (size_t index = 0; index < m_form_factors.size(); ++index)
delete m_form_factors[index];
}
FormFactorWeighted* FormFactorWeighted::clone() const
{
auto* result = new FormFactorWeighted();
for (size_t index = 0; index < m_form_factors.size(); ++index)
result->addFormFactor(*m_form_factors[index], m_weights[index]);
return result;
}
double FormFactorWeighted::radialExtension() const
{
double result{0.0};
for (size_t index = 0; index < m_form_factors.size(); ++index)
result += m_weights[index] * m_form_factors[index]->radialExtension();
return result;
}
double FormFactorWeighted::bottomZ(const IRotation& rotation) const
{
if (m_form_factors.empty())
throw std::runtime_error("FormFactorWeighted::bottomZ() -> Error: "
"'this' contains no form factors.");
return BaseUtils::algo::min_value(
m_form_factors.begin(), m_form_factors.end(),
[&rotation](IFormFactor* ff) { return ff->bottomZ(rotation); });
}
double FormFactorWeighted::topZ(const IRotation& rotation) const
{
if (m_form_factors.empty())
throw std::runtime_error("FormFactorWeighted::topZ() -> Error: "
"'this' contains no form factors.");
return BaseUtils::algo::max_value(m_form_factors.begin(), m_form_factors.end(),
[&rotation](IFormFactor* ff) { return ff->topZ(rotation); });
}
void FormFactorWeighted::addFormFactor(const IFormFactor& form_factor, double weight)
{
m_form_factors.push_back(form_factor.clone());
m_weights.push_back(weight);
}
void FormFactorWeighted::setAmbientMaterial(const Material& material)
{
for (size_t index = 0; index < m_form_factors.size(); ++index)
m_form_factors[index]->setAmbientMaterial(material);
}
complex_t FormFactorWeighted::theFF(const WavevectorInfo& wavevectors) const
{
complex_t result(0.0, 0.0);
for (size_t index = 0; index < m_form_factors.size(); ++index)
result += m_weights[index] * m_form_factors[index]->theFF(wavevectors);
return result;
}
Eigen::Matrix2cd FormFactorWeighted::thePolFF(const WavevectorInfo& wavevectors) const
{
Eigen::Matrix2cd result = Eigen::Matrix2cd::Zero();
for (size_t index = 0; index < m_form_factors.size(); ++index)
result += m_weights[index] * m_form_factors[index]->thePolFF(wavevectors);
return result;
}