CSSCAL scales a complex vector by a real constant.
Type | Intent | Optional | Attributes | Name | ||
---|---|---|---|---|---|---|
integer(kind=ilp), | intent(in) | :: | n | |||
real(kind=sp), | intent(in) | :: | sa | |||
complex(kind=sp), | intent(inout) | :: | cx(*) | |||
integer(kind=ilp), | intent(in) | :: | incx |
pure subroutine stdlib_csscal(n,sa,cx,incx) !! CSSCAL scales a complex vector by a real 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 real(sp), intent(in) :: sa integer(ilp), intent(in) :: incx, n ! Array Arguments complex(sp), intent(inout) :: cx(*) ! ===================================================================== ! Local Scalars integer(ilp) :: i, nincx ! Intrinsic Functions intrinsic :: aimag,cmplx,real if (n<=0 .or. incx<=0) return if (incx==1) then ! code for increment equal to 1 do i = 1,n cx(i) = cmplx(sa*real(cx(i),KIND=sp),sa*aimag(cx(i)),KIND=sp) end do else ! code for increment not equal to 1 nincx = n*incx do i = 1,nincx,incx cx(i) = cmplx(sa*real(cx(i),KIND=sp),sa*aimag(cx(i)),KIND=sp) end do end if return end subroutine stdlib_csscal