aboutsummaryrefslogtreecommitdiff
path: root/blas/level1_real_impl.h
diff options
context:
space:
mode:
authorAndroid Build Coastguard Worker <android-build-coastguard-worker@google.com>2022-02-26 04:02:30 +0000
committerAndroid Build Coastguard Worker <android-build-coastguard-worker@google.com>2022-02-26 04:02:30 +0000
commit6ed47ba57d52fe5179586e410db9cb893be711cd (patch)
treefb979fb4cf4f8052c8cc66b1ec9516d91fcd859b /blas/level1_real_impl.h
parent02f44805248634694d5fa911c91aaba375279d32 (diff)
parentbc0f5df265caa21a2120c22453655a7fcc941991 (diff)
downloadeigen-android13-d1-release.tar.gz
Change-Id: Icbf1e7e38b968ba0f18b25855d89d57751f3f1ee
Diffstat (limited to 'blas/level1_real_impl.h')
-rw-r--r--blas/level1_real_impl.h22
1 files changed, 22 insertions, 0 deletions
diff --git a/blas/level1_real_impl.h b/blas/level1_real_impl.h
index 02586d519..c58771125 100644
--- a/blas/level1_real_impl.h
+++ b/blas/level1_real_impl.h
@@ -23,6 +23,28 @@ RealScalar EIGEN_BLAS_FUNC(asum)(int *n, RealScalar *px, int *incx)
else return make_vector(x,*n,std::abs(*incx)).cwiseAbs().sum();
}
+int EIGEN_CAT(i, EIGEN_BLAS_FUNC(amax))(int *n, RealScalar *px, int *incx)
+{
+ if(*n<=0) return 0;
+ Scalar* x = reinterpret_cast<Scalar*>(px);
+
+ DenseIndex ret;
+ if(*incx==1) make_vector(x,*n).cwiseAbs().maxCoeff(&ret);
+ else make_vector(x,*n,std::abs(*incx)).cwiseAbs().maxCoeff(&ret);
+ return int(ret)+1;
+}
+
+int EIGEN_CAT(i, EIGEN_BLAS_FUNC(amin))(int *n, RealScalar *px, int *incx)
+{
+ if(*n<=0) return 0;
+ Scalar* x = reinterpret_cast<Scalar*>(px);
+
+ DenseIndex ret;
+ if(*incx==1) make_vector(x,*n).cwiseAbs().minCoeff(&ret);
+ else make_vector(x,*n,std::abs(*incx)).cwiseAbs().minCoeff(&ret);
+ return int(ret)+1;
+}
+
// computes a vector-vector dot product.
Scalar EIGEN_BLAS_FUNC(dot)(int *n, RealScalar *px, int *incx, RealScalar *py, int *incy)
{