~ubuntu-branches/ubuntu/karmic/scilab/karmic

« back to all changes in this revision

Viewing changes to routines/calelm/wwpowe.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 wwpowe(vr,vi,pr,pi,rr,ri,ierr)
 
2
c!purpose
 
3
c     computes v^p with v complex and p complex
 
4
c!calling sequence 
 
5
c     subroutine wdpowe(vr,vi,p,rr,ri,ierr)
 
6
c     integer ierr
 
7
c     double precision vr,vi,pr,pi,rr,ri
 
8
c     vr   : real part of v
 
9
c     vi   : imaginary part of v
 
10
c     pr   : real part of p
 
11
c     pi   : imaginary part of p
 
12
c     rr   : result's real part
 
13
c     ri   : result's imaginary part
 
14
c     ierr : error flag
 
15
c            ierr=0 if ok
 
16
c            ierr=1 if 0**0
 
17
c            ierr=2 if  0**k with k<0
 
18
c!origin
 
19
c Serge Steer INRIA 1996
 
20
c!
 
21
c     Copyright INRIA
 
22
      integer ierr
 
23
      double precision vr,vi,pr,pi,sr,si,rr,ri
 
24
c
 
25
      ierr=0
 
26
c     
 
27
      if(pi.eq.0.0d+0) then
 
28
         call wdpowe(vr,vi,pr,rr,ri,ierr)
 
29
      else
 
30
         if(abs(vr)+abs(vi).ne.0.0d+0) then
 
31
            call wlog(vr,vi,sr,si)
 
32
            call wmul(sr,si,pr,pi,sr,si)
 
33
            sr=exp(sr)
 
34
            rr=sr*cos(si)
 
35
            ri=sr*sin(si)
 
36
         else
 
37
            ri=0.0d0
 
38
            rr=infinity(ri)
 
39
            ierr=2
 
40
         endif
 
41
      endif
 
42
c     
 
43
      return
 
44
      end