Я пытаюсь представить следующую функцию c ++ для python, используя boost.python:
template <typename genType>
genType refract(
genType const & I,
genType const & N,
typename genType::value_type const & eta);
, и я получил следующее:
template<typename N>
N reflect(N const & i, N const & n, typename N::value_type const & eta)
{
return glm::N refract(i,n,eta);
}
BOOST_PYTHON_MODULE(foo)
{
def("reflect", reflect<float>);
def("reflect", reflect<double>);
}
и у меня есть следующееошибка при компиляции:
ошибка C2780: 'void boost :: python :: def (const char *, F, const A1 &, const A2 &, const A3 &)': ожидается 5 аргументов - 2 при условии *
Как мне его обернуть?
----- edit ------
Работает:
template<class T>
T floor(T x)
{
return glm::core::function::common::floor(x);
}
BOOST_PYTHON_MODULE(busta)
{
def("floor", floor<double>);
def("floor", floor<float>);
}
из ссылки, floor()
определение является следующим:
template< typename genType >
genType floor (genType const &x)
Я могу построить это как DLL, затем импортировать ее в python и использовать оттуда floor ().Жизнь так приятна ... но ..
Это не сработает, и я хотел бы понять, почему:
template<class genType >
genType reflect (genType i, genType n, genType eta)
{
return glm::core::function::geometric::refract(i, n,eta);
}
BOOST_PYTHON_MODULE(busta)
{
def("reflect", reflect<float>);
}
refract () - определение в верхней части этого поста.
ошибка, которую я получаю сейчас, такова:
1>foo.cpp(37): error C2893: Failed to specialize function template 'genType glm::core::function::geometric::refract(const genType &,const genType &,const genType::value_type &)'
1> With the following template arguments:
1> 'float'
1> foo.cpp(60) : see reference to function template instantiation 'genType
`anonymous-namespace'::reflect<float>(genType,genType,genType)' being compiled
1> with
1> [
1> genType=float
1> ]
1>
1>Build FAILED.