~ubuntu-branches/ubuntu/hoary/scilab/hoary

« back to all changes in this revision

Viewing changes to routines/calelm/wdpowe.f

  • Committer: Bazaar Package Importer
  • Author(s): Torsten Werner
  • Date: 2002-03-21 16:57:43 UTC
  • Revision ID: james.westby@ubuntu.com-20020321165743-e9mv12c1tb1plztg
Tags: upstream-2.6
ImportĀ upstreamĀ versionĀ 2.6

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
      subroutine wdpowe(vr,vi,p,rr,ri,ierr)
 
2
c!purpose
 
3
c     computes v^p with v complex and p real
 
4
c!calling sequence 
 
5
c     subroutine wdpowe(vr,vi,p,rr,ri,ierr)
 
6
c     integer ierr
 
7
c     double precision vr,vi,p,rr,ri
 
8
c     vr   : real part of v
 
9
c     vi   : imaginary part of v
 
10
c     rr   : result's real part
 
11
c     ri   : result's imaginary part
 
12
c     ierr : error flag
 
13
c            ierr=0 if ok
 
14
c            ierr=1 if 0**0
 
15
c            ierr=2 if  0**k with k<0
 
16
c!origin
 
17
c Serge Steer INRIA 1996
 
18
c!
 
19
 
 
20
c     Copyright INRIA
 
21
      integer ierr
 
22
      double precision vr,vi,p,sr,si,rr,ri
 
23
c
 
24
      ierr=0
 
25
c
 
26
      if(dble(int(p)).eq.p) then 
 
27
         call wipowe(vr,vi,int(p),rr,ri,ierr)
 
28
      else
 
29
         if(abs(vr)+abs(vi).ne.0.0d+0) then
 
30
            call wlog(vr,vi,sr,si)
 
31
            sr=exp(sr*p)
 
32
            si=si*p
 
33
            rr=sr*cos(si)
 
34
            ri=sr*sin(si)
 
35
         else
 
36
            if(p.gt.0.0d+0) then
 
37
               rr=0.0d+0
 
38
               ri=0.0d+0
 
39
            elseif(p.lt.0.0d+0) then
 
40
               ri=0.0d+0
 
41
               rr=infinity(ri)
 
42
               ierr=2
 
43
            else
 
44
               rr=1.0d+0
 
45
               ri=0.0d+0
 
46
            endif
 
47
         endif
 
48
      endif
 
49
c     
 
50
      return
 
51
      end