CSCAL scales a vector by a constant.
Type | Intent | Optional | Attributes | Name | ||
---|---|---|---|---|---|---|
integer(kind=ilp), | intent(in) | :: | n | |||
complex(kind=sp), | intent(in) | :: | ca | |||
complex(kind=sp), | intent(inout) | :: | cx(*) | |||
integer(kind=ilp), | intent(in) | :: | incx |
pure subroutine stdlib_cscal(n,ca,cx,incx) !! CSCAL scales a vector by a constant. ! -- reference blas level1 routine -- ! -- reference blas is a software package provided by univ. of tennessee, -- ! -- univ. of california berkeley, univ. of colorado denver and nag ltd..-- ! Scalar Arguments complex(sp), intent(in) :: ca integer(ilp), intent(in) :: incx, n ! Array Arguments complex(sp), intent(inout) :: cx(*) ! ===================================================================== ! Local Scalars integer(ilp) :: i, nincx if (n<=0 .or. incx<=0) return if (incx==1) then ! code for increment equal to 1 do i = 1,n cx(i) = ca*cx(i) end do else ! code for increment not equal to 1 nincx = n*incx do i = 1,nincx,incx cx(i) = ca*cx(i) end do end if return end subroutine stdlib_cscal