本文整理汇总了C++中NDArray::isColumnVector方法的典型用法代码示例。如果您正苦于以下问题:C++ NDArray::isColumnVector方法的具体用法?C++ NDArray::isColumnVector怎么用?C++ NDArray::isColumnVector使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类NDArray
的用法示例。
在下文中一共展示了NDArray::isColumnVector方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: if
void Householder<T>::mulLeft(NDArray<T>& matrix, const NDArray<T>& tail, const T coeff) {
// if(matrix.rankOf() != 2)
// throw "ops::helpers::Householder::mulLeft method: input array must be 2D matrix !";
if(matrix.sizeAt(0) == 1)
matrix *= (T)1. - coeff;
else if(coeff != (T)0.) {
NDArray<T>* bottomPart = matrix.subarray({{1, matrix.sizeAt(0)}, {}});
NDArray<T> bottomPartCopy = *bottomPart;
if(tail.isColumnVector()) {
NDArray<T> column = tail;
NDArray<T>* row = tail.transpose();
NDArray<T> resultingRow = mmul(*row, bottomPartCopy);
NDArray<T>* fistRow = matrix.subarray({{0,1}, {}});
resultingRow += *fistRow;
*fistRow -= resultingRow * coeff;
*bottomPart -= mmul(column, resultingRow) * coeff;
delete row;
delete fistRow;
}
else {
NDArray<T> row = tail;
NDArray<T>* column = tail.transpose();
NDArray<T> resultingRow = mmul(row, bottomPartCopy);
NDArray<T>* fistRow = matrix.subarray({{0,1}, {}});
resultingRow += *fistRow;
*fistRow -= resultingRow * coeff;
*bottomPart -= mmul(*column, resultingRow) * coeff;
delete column;
delete fistRow;
}
delete bottomPart;
}
}