File: kiltq.f

package info (click to toggle)
scilab 2.6-4
  • links: PTS
  • area: non-free
  • in suites: woody
  • size: 54,632 kB
  • ctags: 40,267
  • sloc: ansic: 267,851; fortran: 166,549; sh: 10,005; makefile: 4,119; tcl: 1,070; cpp: 233; csh: 143; asm: 135; perl: 130; java: 39
file content (126 lines) | stat: -rw-r--r-- 3,503 bytes parent folder | download | duplicates (5)
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
      subroutine kiltq(b,c,coderf,delta,ex,la2,lp2,ma,mm,n,
     &     or,phibar,phir,pile,piv,predw,sufval,type,waqc)
      implicit integer (a-z)
      dimension lp2(*),la2(mm),or(ma),ex(ma)
      dimension b(ma),c(ma),type(ma)
      dimension pile(n),predw(n)
      doubleprecision piv(n),sufval(n),waqc(ma)
      doubleprecision infr,delta,phir(ma),gamma1,gamma2,teta
      doubleprecision ep,eps,eps1,eps2,zero,ref,min,phibar(ma)
      icon=0
      zero=0.00001
      infr=10.d6
 100  continue
      do 160 u=1,ma
         type(u)=11
         if(phir(u).le.c(u))go to 110
         type(u)=10
         go to 160
 110     if(phir(u).ge.b(u))go to 115
         type(u)=9
         go to 160
 115     if(c(u).ne.b(u)) goto 120
         type(u)=8
         goto 160
 120     teta=piv(ex(u))-piv(or(u))
         gamma1=waqc(u)*(phir(u)+delta*.5-phibar(u))
         gamma2=waqc(u)*(phir(u)-delta*.5-phibar(u))
         if(abs(phir(u)-b(u)).ge.zero) go to 130
         if((teta-gamma1).gt.zero)type(u)=6
         if((gamma1-teta).gt.zero)type(u)=1
         if(abs(teta-gamma1).le.zero)type(u)=4
         go to 160
 130     if(abs(phir(u)-c(u)).ge.zero)go to 140
         if((teta-gamma2).gt.zero)type(u)=3
         if((gamma2-teta).gt.zero)type(u)=7
         if(abs(teta-gamma2).le.zero)type(u)=5
         go to 160
 140     if((teta-gamma1).gt.zero)type(u)=6
         if((gamma2-teta).gt.zero)type(u)=7
         if(abs(teta-gamma2).le.zero)type(u)=51
         if(abs(teta-gamma1).le.zero)type(u)=41
 160  continue
      do 210 u=1,ma
         if(type(u).ne.6.and.type(u).ne.7.and.
     &        type(u).ne.9.and.type(u).ne.10) goto 210
         u0=u
         goto 300
 210  continue
      return
 300  continue
      if(type(u0).eq.7.or.type(u0).eq.10) goto 310
      if(type(u0).eq.6.or.type(u0).eq.9) goto 320
 310  i1=ex(u0)
      j1=or(u0)
      goto 330
 320  continue
      j1=ex(u0)
      i1=or(u0)
 330  continue
      call mintyq(b,c,coderf,delta,ex,i1,infr,j1,la2,lp2,ma,
     &     mm,n,or,phibar,phir,pile,piv,predw,
     &     sufval,type,u0,waqc)
      icon=icon+1
      if(icon .gt. ma+1) then
         coderf=2
         return
      endif
      if(coderf.ne.0) return
      if(predw(i1).le.zero) go to 100
      eps1 = infr
      eps2 = infr
      jj=i1
      goto 403
 400  continue
      if(jj.eq.i1)goto 420
 403  continue
      u=predw(jj)
      teta=piv(ex(u))-piv(or(u))
      if(jj.eq.ex(u)) go to 405
      go to 410
 405  if(type(u).ne.9)go to 406
      if(teta.gt.(waqc(u)*(b(u)+delta*.5-phibar(u))))go to 406
      eps1=min(eps1,(b(u)-phir(u)))
      go to 409
 406  k=1
 407  ref=waqc(u)*((k-1/2)*delta+b(u)-phibar(u))+zero
      if(teta.le.ref)go to 408
      k=k+1
      go to 407
 408  ep=k*delta+b(u)-phir(u)
      eps1=min(eps1,ep)
 409  jj=or(u)
      goto 400
 410  continue
      if(type(u).ne.10)go to 412
      if(teta.lt.(waqc(u)*(c(u)-delta*.5-phibar(u))))goto 412
      eps2=min(eps2,(phir(u)-c(u)))
      goto 415
 412  k=1
 413  ref=waqc(u)*((k-1/2)*delta+b(u)-phibar(u))+zero
      if(teta.lt.ref)go to 414
      k=k+1
      goto 413
 414  ep=phir(u)-(k-1)*delta-b(u)
      eps2=min(eps2,ep)
 415  jj=ex(u)
      goto 400
 420  continue
      eps=min(eps1,eps2)
      jj=i1
      goto 435
 430  continue
      if(jj.eq.i1)goto 450
 435  continue
      u=predw(jj)
      if(jj.eq.or(u)) go to 440
      phir(u)=phir(u)+eps
      jj=or(u)
      goto 430
 440  continue
      phir(u)=phir(u)-eps
      jj=ex(u)
      goto 430
 450  continue
      goto 100
      end