--- /dev/null
+// Copyright ©2017 The Gonum Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style
+// license that can be found in the LICENSE file.
+
+package gonum
+
+import (
+ "strconv"
+ "testing"
+
+ "gonum.org/v1/gonum/blas"
+ "gonum.org/v1/gonum/blas/testblas"
+)
+
+func BenchmarkDtrmv(b *testing.B) {
+ for _, n := range []int{testblas.MediumMat, testblas.LargeMat} {
+ for _, incX := range []int{1, 5} {
+ for _, uplo := range []blas.Uplo{blas.Upper, blas.Lower} {
+ for _, trans := range []blas.Transpose{blas.NoTrans, blas.Trans} {
+ for _, unit := range []blas.Diag{blas.NonUnit, blas.Unit} {
+ var str string
+ if n == testblas.MediumMat {
+ str += "Med"
+ } else if n == testblas.LargeMat {
+ str += "Large"
+ }
+ str += "_Inc" + strconv.Itoa(incX)
+ if uplo == blas.Upper {
+ str += "_UP"
+ } else {
+ str += "_LO"
+ }
+ if trans == blas.NoTrans {
+ str += "_NT"
+ } else {
+ str += "_TR"
+ }
+ if unit == blas.NonUnit {
+ str += "_NU"
+ } else {
+ str += "_UN"
+ }
+ lda := n
+ b.Run(str, func(b *testing.B) {
+ testblas.DtrmvBenchmark(b, Implementation{}, n, lda, incX, uplo, trans, unit)
+ })
+ }
+ }
+ }
+ }
+ }
+}