5

我正在使用 ublas 作为我的矩阵代码,但我希望它是可交换的,所以我这样做了:

typedef boost::numeric::ublas::matrix<double> cMatrix;

今天,我需要将其中一些矩阵更改为有界大小,所以我也会有这个:

typedef boost::numeric::ublas::bounded_matrix<double, 3, 3> Matrix3d;

问题是我的旧函数声明:

void cClass::function(int param1,
                      int param2,
                      cMatrix &param3,
                      int param4);

不再工作。它给了我:

error : a reference of type "cMatrix &" (not const-qualified) cannot be initialized with a value of type "Matrix3d"

我设法通过将声明更改为:

template <class A>
void cClass::function(int param1,
                      int param2,
                      boost::numeric::ublas::matrix<double, boost::numeric::ublas::row_major, A> &param3,
                      int param4);

问题是我的定义是一个 cpp 文件,所以我必须在 cpp 中做这样的事情:

void dummyFunc()
{
  cClass dummy(NULL, NULL);
  cMatrix c;
  Matrix12d d12;
  dummy.function(-1, -1, c, -1);
  dummy.function(-1, -1, d12, -1);
}

有什么方法可以避免执行 dummyFunc 或以其他方式概括该函数?

4

2 回答 2

1

我建议对 Thibaut 的(正确)答案进行改进:

template<class UblasMatrix, typename /*Dummy*/ = UblasMatrix::array_type>
void cClass::function(int param1,
                      int param2,
                      UblasMatrix &param3,
                      int param4);

多亏了 SFINAE,第二个模板参数只是(几乎)确定您正在使用某种 ublas 矩阵而不是其他东西(比如,假设std::vector<doubel>)调用该函数。这避免了令人困惑的错误消息。

于 2013-06-06T10:45:12.070 回答
1

如果两者都matrix具有bounded_matrix完全相同的 API,则可以抽象类型并cClass::function使用可变参数模板进行泛化:

template<template <class...> class M, class... Arg>
void cClass::function(int param1,
                      int param2,
                      M<Arg...> &param3,
                      int param4);
于 2013-03-21T19:16:50.503 回答