-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdensity1.f
130 lines (128 loc) · 2.95 KB
/
density1.f
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
127
128
129
130
program density
parameter(n=1000)
complex :: gv
real :: a(n,n),d(n),e(n)
pi = 4.*atan(1.)
ge0=2.5
a = 0.
do i = 1,n
d(i) = 0.
e(i) = 1.
a(i,i) = 1.
end do
call tql2(n,n,d,e,a,ierr)
open(10,file='density1.txt')
do j = 0,101
ge = -ge0+j*2.*ge0/101
gv = 0.
do i = 1,n
gv = gv+1./(complex(ge,0.01)-d(i))
end do
g = -imag(gv/n)/pi
write(10,*) ge,g
end do
end
c finds the eigenvalues and eigenvectors of a tridiagonal matrix
subroutine tql2(nm,n,d,e,z,ierr)
real d(n),e(n),z(nm,n)
ierr = 0
if (n .eq. 1) go to 1001
do 100 i = 2, n
100 e(i-1) = e(i)
f = 0.0e0
tst1 = 0.0e0
e(n) = 0.0e0
do 240 l = 1, n
j = 0
h = abs(d(l)) + abs(e(l))
if (tst1 .lt. h) tst1 = h
do 110 m = l, n
tst2 = tst1 + abs(e(m))
if (tst2 .eq. tst1) go to 120
110 continue
120 if (m .eq. l) go to 220
130 if (j .eq. 30) go to 1000
j = j + 1
l1 = l + 1
l2 = l1 + 1
g = d(l)
p = (d(l1) - g) / (2.0e0 * e(l))
r = pythag(p,1.0e0)
d(l) = e(l) / (p + sign(r,p))
d(l1) = e(l) * (p + sign(r,p))
dl1 = d(l1)
h = g - d(l)
if (l2 .gt. n) go to 145
do 140 i = l2, n
140 d(i) = d(i) - h
145 f = f + h
p = d(m)
c = 1.0e0
c2 = c
el1 = e(l1)
s = 0.0e0
mml = m - l
do 200 ii = 1, mml
c3 = c2
c2 = c
s2 = s
i = m - ii
g = c * e(i)
h = c * p
r = pythag(p,e(i))
e(i+1) = s * r
s = e(i) / r
c = p / r
p = c * d(i) - s * g
d(i+1) = h + s * (c * g + s * d(i))
do 180 k = 1, n
h = z(k,i+1)
z(k,i+1) = s * z(k,i) + c * h
z(k,i) = c * z(k,i) - s * h
180 continue
200 continue
p = -s * s2 * c3 * el1 * e(l) / dl1
e(l) = s * p
d(l) = c * p
tst2 = tst1 + abs(e(l))
if (tst2 .gt. tst1) go to 130
220 d(l) = d(l) + f
240 continue
do 300 ii = 2, n
i = ii - 1
k = i
p = d(i)
do 260 j = ii, n
if (d(j) .ge. p) go to 260
k = j
p = d(j)
260 continue
if (k .eq. i) go to 300
d(k) = d(i)
d(i) = p
do 280 j = 1, n
p = z(j,i)
z(j,i) = z(j,k)
z(j,k) = p
280 continue
300 continue
go to 1001
1000 ierr = l
1001 return
end
c finds sqrt(a**2+b**2)
real function pythag(a,b)
p = amax1(abs(a),abs(b))
if (p .eq. 0.0e0) go to 20
r = (amin1(abs(a),abs(b))/p)**2
10 continue
t = 4.0e0 + r
if (t .eq. 4.0e0) go to 20
s = r/t
u = 1.0e0 + 2.0e0*s
p = u*p
r = (s/u)**2 * r
go to 10
20 pythag = p
return
end