1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
|
c Scilab ( http://www.scilab.org/ ) - This file is part of Scilab
c Copyright (C) 1985-2008 - INRIA - Carlos KLIMANN
c
c This file must be used under the terms of the CeCILL.
c This source file is licensed as described in the file COPYING, which
c you should have received as part of this distribution. The terms
c are also available at
c http://www.cecill.info/licences/Licence_CeCILL_V2.1-en.txt
C/MEMBR ADD NAME=WPMUL,SSI=0
c Copyright INRIA
subroutine wpmul(p1r,p1i,d1,p2r,p2i,d2,p3r,p3i,d3)
c!purpose
c ce sous programme effectue le calcul:
c
c p3(x) = p3(x) + (p1(x) * p2(x))
c
c ou p1, p2 et p3 sont des polynomes de degres d1, d2 et d3,
c respectivement, a coefficients complexes
c les coefficients sont ranges consecutivement et par puissance
c croissante
c Tous les parametres sont d'entree, sauf p3 et d3 qui sont
c d'entree-sortie.
c!
c &&var
implicit double precision (a-h,o-z)
double precision p1r(*),p1i(*),p2r(*),p2i(*),p3r(*),p3i(*)
integer d1,d2,d3
integer dmax,dmin,dsum
integer i, k, j, l
integer e1, e2
c &&ker
dsum = d1 + d2
c fixation de dmax et dmin
dmax = d1
if (d2 .gt. d1) dmax = d2
dmin = dsum - dmax
c fixation de d3
if (d3 .ge. dsum) goto 1
e1 = d3+2
e2 = dsum +1
do 2 i = e1 , e2
p3r(i) = 0.0d+0
p3i(i) = 0.0d+0
2 continue
d3 = dsum
1 continue
c cas des degres egaux a zero
if (d1 .eq. 0 .or. d2 .eq. 0) goto 53
c produit et addition
e1 = 1
e2 = dmin + 1
do 10 i = e1, e2
p3r(i) = p3r(i) + ddot(i,p1r(1),1,p2r(1),-1)
& - ddot(i,p1i(1),1,p2i(1),-1)
p3i(i) = p3i(i) + ddot(i,p1r(1),1,p2i(1),-1)
& + ddot(i,p1i(1),1,p2r(1),-1)
10 continue
k = 1
if (d1 .eq. d2) goto 21
e1 = dmin + 2
e2 = dmax + 1
c si d1 > d2
if (d1 .lt. d2) goto 25
do 20 i = e1, e2
k = k + 1
p3r(i) = p3r(i) + ddot(dmin+1, p1r(k), 1, p2r(1), -1)
& - ddot(dmin+1, p1i(k), 1, p2i(1), -1)
p3i(i) = p3i(i) + ddot(dmin+1, p1r(k), 1, p2i(1), -1)
& + ddot(dmin+1, p1i(k), 1, p2r(1), -1)
20 continue
21 e1 = dmax + 2
e2 = dsum + 1
l = 1
j = dmin + 1
do 40 i = e1, e2
j = j -1
k = k + 1
l =l + 1
p3r(i) = p3r(i) + ddot(j, p1r(k), 1, p2r(l), -1)
& - ddot(j, p1i(k), 1, p2i(l), -1)
p3i(i) = p3i(i) + ddot(j, p1r(k), 1, p2i(l), -1)
& + ddot(j, p1i(k), 1, p2r(l), -1)
40 continue
return
c si d2 > d1
25 do 30 i = e1, e2
k = k + 1
p3r(i) = p3r(i) + ddot(dmin+1, p2r(k), -1, p1r(1), 1)
& - ddot(dmin+1, p2i(k), -1, p1i(1), 1)
p3i(i) = p3i(i) + ddot(dmin+1, p2r(k), -1, p1i(1), 1)
& + ddot(dmin+1, p2i(k), -1, p1r(1), 1)
30 continue
e1 = dmax + 2
e2 = dsum + 1
l = 1
j = dmin + 1
do 50 i = e1, e2
j = j -1
k = k + 1
l =l + 1
p3r(i) = p3r(i) + ddot(j, p1r(l), 1, p2r(k), -1)
& - ddot(j, p1i(l), 1, p2i(k), -1)
p3i(i) = p3i(i) + ddot(j, p1r(l), 1, p2i(k), -1)
& + ddot(j, p1i(l), 1, p2r(k), -1)
50 continue
return
c cas des degres egaux a zero
53 if (d1 .eq. 0 .and. d2 .eq. 0) goto 100
e1 = 1
if (d1 .eq.0) goto 60
e2 = d1 + 1
do 55 i = e1, e2
p3r(i) = p3r(i) + p1r(i) * p2r(1) - p1i(i) * p2i(1)
p3i(i) = p3i(i) + p1r(i) * p2i(1) + p1i(i) * p2r(1)
55 continue
return
60 e2 = d2 + 1
do 65 i = e1, e2
p3r(i) = p3r(i) + p2r(i) * p1r(1) - p2i(i) * p1i(1)
p3i(i) = p3i(i) + p2r(i) * p1i(1) + p2i(i) * p1r(1)
65 continue
return
100 p3r(1) = p3r(1) + p1r(1) * p2r(1) - p1i(1) * p2i(1)
p3i(1) = p3i(1) + p1r(1) * p2i(1) + p1i(1) * p2r(1)
return
end
|