Browse Source

Merge pull request #4560 from martin-frbg/issue4551-3

Add support for negative increments to the ?NRM2 kernels for RISC-V RVV targets
tags/v0.3.27
Martin Kroeker GitHub 1 year ago
parent
commit
dc0338af47
No known key found for this signature in database GPG Key ID: B5690EEEBB952194
4 changed files with 9 additions and 9 deletions
  1. +3
    -3
      kernel/riscv64/nrm2_rvv.c
  2. +3
    -3
      kernel/riscv64/nrm2_vector.c
  3. +1
    -1
      kernel/riscv64/znrm2_rvv.c
  4. +2
    -2
      kernel/riscv64/znrm2_vector.c

+ 3
- 3
kernel/riscv64/nrm2_rvv.c View File

@@ -101,7 +101,7 @@ FLOAT CNAME(BLASLONG n, FLOAT *x, BLASLONG inc_x)
{
BLASLONG i=0;

if (n <= 0 || inc_x <= 0) return(0.0);
if (n <= 0 || inc_x == 0) return(0.0);
if(n == 1) return (ABS(x[0]));

unsigned int gvl = 0;
@@ -119,7 +119,7 @@ FLOAT CNAME(BLASLONG n, FLOAT *x, BLASLONG inc_x)
unsigned int stride_x = inc_x * sizeof(FLOAT);
int idx = 0;

if( n >= gvl ) // don't pay overheads if we're not doing useful work
if( n >= gvl && inc_x > 0 ) // don't pay overheads if we're not doing useful work
{
for(i=0; i<n/gvl; i++){
v0 = VLSEV_FLOAT( &x[idx], stride_x, gvl );
@@ -190,7 +190,7 @@ FLOAT CNAME(BLASLONG n, FLOAT *x, BLASLONG inc_x)
//finish any tail using scalar ops
i*=gvl*inc_x;
n*=inc_x;
while(i < n){
while(abs(i) < abs(n)){
if ( x[i] != 0.0 ){
FLOAT absxi = ABS( x[i] );
if ( scale < absxi ){


+ 3
- 3
kernel/riscv64/nrm2_vector.c View File

@@ -104,7 +104,7 @@ FLOAT CNAME(BLASLONG n, FLOAT *x, BLASLONG inc_x)
{
BLASLONG i=0;

if (n <= 0 || inc_x <= 0) return(0.0);
if (n <= 0 || inc_x == 0) return(0.0);
if(n == 1) return (ABS(x[0]));

unsigned int gvl = 0;
@@ -122,7 +122,7 @@ FLOAT CNAME(BLASLONG n, FLOAT *x, BLASLONG inc_x)
unsigned int stride_x = inc_x * sizeof(FLOAT);
int idx = 0;

if( n >= gvl ) // don't pay overheads if we're not doing useful work
if( n >= gvl && inc_x > 0) // don't pay overheads if we're not doing useful work
{
for(i=0; i<n/gvl; i++){
v0 = VLSEV_FLOAT( &x[idx], stride_x, gvl );
@@ -193,7 +193,7 @@ FLOAT CNAME(BLASLONG n, FLOAT *x, BLASLONG inc_x)
//finish any tail using scalar ops
i*=gvl*inc_x;
n*=inc_x;
while(i < n){
while(abs(i)< abs(n)){
if ( x[i] != 0.0 ){
FLOAT absxi = ABS( x[i] );
if ( scale < absxi ){


+ 1
- 1
kernel/riscv64/znrm2_rvv.c View File

@@ -69,7 +69,7 @@ FLOAT CNAME(BLASLONG n, FLOAT *x, BLASLONG inc_x)
{
BLASLONG i=0, j=0;

if (n <= 0 || inc_x <= 0) return(0.0);
if (n <= 0 || inc_x == 0) return(0.0);

FLOAT_V_T vr, v0, v_zero;
unsigned int gvl = 0;


+ 2
- 2
kernel/riscv64/znrm2_vector.c View File

@@ -96,7 +96,7 @@ FLOAT CNAME(BLASLONG n, FLOAT *x, BLASLONG inc_x)
{
BLASLONG i=0;

if (n <= 0 || inc_x <= 0) return(0.0);
if (n <= 0 || inc_x == 0) return(0.0);

FLOAT_V_T v_ssq, v_scale, v0, v1, v_zero;
unsigned int gvl = 0;
@@ -176,7 +176,7 @@ FLOAT CNAME(BLASLONG n, FLOAT *x, BLASLONG inc_x)
}

i += inc_x*2;
}while(i<n);
}while(abs(i)<abs(n));
}

return(scale * sqrt(ssq));


Loading…
Cancel
Save