~madteam/mg5amcnlo/series2.0

50.9.3 by Johan Alwall
Added Template and HELAS into bzr
1
      subroutine wwwwxx(wm1,wp1,wm2,wp2,gwwa,gwwz , vertex)
2
c
3
c This subroutine computes an amplitude of the four-point W-/W+ coupling.
4
c
5
c input:
6
c       complex wm1(0:3)       : first  flow-out W-                  wm1
7
c       complex wp1(0:3)       : first  flow-out W+                  wp1
8
c       complex wm2(0:3)       : second flow-out W-                  wm2
9
c       complex wp2(0:3)       : second flow-out W+                  wp2
10
c       real    gwwa           : coupling constant of W and A       gwwa
11
c       real    gwwz           : coupling constant of W and Z       gwwz
12
c       real    zmass          : mass  of Z
13
c       real    zwidth         : width of Z
14
c
15
c output:
16
c       complex vertex         : amplitude        gamma(wm1,wp1,wm2,wp2)
17
c     
18
      implicit none
19
      double complex wm1(6),wp1(6),wm2(6),wp2(6),vertex
20
      double complex dv1(0:3),dv2(0:3),dv3(0:3),dv4(0:3),dvertx
21
      double complex v12,v13,v14,v23,v24,v34
22
      double precision pwm1(0:3),pwp1(0:3),pwm2(0:3),pwp2(0:3)
23
      double precision gwwa,gwwz
24
25
      double precision rZero, rOne, rTwo
26
      parameter( rZero = 0.0d0, rOne = 1.0d0, rTwo = 2.0d0 )
27
28
#ifdef HELAS_CHECK
29
      double precision pm
30
      double precision epsi
31
      parameter( epsi = 2.0d-5 )
32
      integer stdo
33
      parameter( stdo = 6 )
34
#endif
35
c
36
      pwm1(0) = dble( wm1(5))
37
      pwm1(1) = dble( wm1(6))
38
      pwm1(2) = dimag(wm1(6))
39
      pwm1(3) = dimag(wm1(5))
40
      pwp1(0) = dble( wp1(5))
41
      pwp1(1) = dble( wp1(6))
42
      pwp1(2) = dimag(wp1(6))
43
      pwp1(3) = dimag(wp1(5))
44
      pwm2(0) = dble( wm2(5))
45
      pwm2(1) = dble( wm2(6))
46
      pwm2(2) = dimag(wm2(6))
47
      pwm2(3) = dimag(wm2(5))
48
      pwp2(0) = dble( wp2(5))
49
      pwp2(1) = dble( wp2(6))
50
      pwp2(2) = dimag(wp2(6))
51
      pwp2(3) = dimag(wp2(5))
52
53
#ifdef HELAS_CHECK
54
      if (  abs(wm1(1))+abs(wm1(2))
55
     &     +abs(wm1(3))+abs(wm1(4)).eq.rZero ) then
56
         write(stdo,*) ' helas-warn  : wm1 in wwwwxx is zero vector'
57
      endif
58
      if ( abs(wm1(5))+abs(wm1(5)).eq.rZero ) then
59
         write(stdo,*)
60
     &        ' helas-error : wm1 in wwwwxx has zero momentum'
61
      endif
62
      if (  abs(wp1(1))+abs(wp1(2))
63
     &     +abs(wp1(3))+abs(wp1(4)).eq.rZero ) then
64
         write(stdo,*) ' helas-warn  : wp1 in wwwwxx is zero vector'
65
      endif
66
      if ( abs(wp1(5))+abs(wp1(5)).eq.rZero ) then
67
         write(stdo,*)
68
     &        ' helas-error : wp1 in wwwwxx has zero momentum'
69
      endif
70
      if (  abs(wm2(1))+abs(wm2(2))
71
     &     +abs(wm2(3))+abs(wm2(4)).eq.rZero ) then
72
         write(stdo,*) ' helas-warn  : wm2 in wwwwxx is zero vector'
73
      endif
74
      if ( abs(wm2(5))+abs(wm2(5)).eq.rZero ) then
75
         write(stdo,*)
76
     &        ' helas-error : wm2 in wwwwxx has zero momentum'
77
      endif
78
      if (  abs(wp2(1))+abs(wp2(2))
79
     &     +abs(wp2(3))+abs(wp2(4)).eq.rZero ) then
80
         write(stdo,*) ' helas-warn  : wp2 in wwwwxx is zero vector'
81
      endif
82
      if ( abs(wp2(5))+abs(wp2(5)).eq.rZero ) then
83
         write(stdo,*)
84
     &        ' helas-error : wp2 in wwwwxx has zero momentum'
85
      endif
86
      pm = max( abs(pwm1(0)),abs(pwp1(0)),abs(pwm2(0)),abs(pwp2(0)),
87
     &          abs(pwm1(1)),abs(pwp1(1)),abs(pwm2(1)),abs(pwp2(1)),
88
     &          abs(pwm1(2)),abs(pwp1(2)),abs(pwm2(2)),abs(pwp2(2)),
89
     &          abs(pwm1(3)),abs(pwp1(3)),abs(pwm2(3)),abs(pwp2(3)) )
90
      if (  abs(wm1(5)+wp1(5)+wm2(5)+wp2(5))
91
     &     +abs(wm1(6)+wp1(6)+wm2(6)+wp2(6)).ge.pm*epsi ) then
92
         write(stdo,*)
93
     &        ' helas-error : wm1,wp1,wm2,wp2 in wwwwxx'
94
         write(stdo,*)
95
     &        '             : have not balanced momenta'
96
      endif
97
      if ( gwwa.eq.rZero ) then
98
         write(stdo,*) ' helas-error : gwwa in wwwwxx is zero coupling'
99
      endif
100
      if ( gwwz.eq.rZero ) then
101
         write(stdo,*)
102
     &        ' helas-error : gwwz in wwwwxx is zero coupling'
103
      endif
104
      if ( gwwa.lt.rZero .or. gwwa.ge.gwwz ) then
105
         write(stdo,*)
106
     &  ' helas-warn  : gwwa/gwwz in wwwwxx are non-standard couplings'
107
         write(stdo,*) 
108
     &  '             : gwwa = ',gwwa,'  gwwz = ',gwwz
109
      endif
110
#endif
111
112
      dv1(0) = dcmplx(wm1(1))
113
      dv1(1) = dcmplx(wm1(2))
114
      dv1(2) = dcmplx(wm1(3))
115
      dv1(3) = dcmplx(wm1(4))
116
      dv2(0) = dcmplx(wp1(1))
117
      dv2(1) = dcmplx(wp1(2))
118
      dv2(2) = dcmplx(wp1(3))
119
      dv2(3) = dcmplx(wp1(4))
120
      dv3(0) = dcmplx(wm2(1))
121
      dv3(1) = dcmplx(wm2(2))
122
      dv3(2) = dcmplx(wm2(3))
123
      dv3(3) = dcmplx(wm2(4))
124
      dv4(0) = dcmplx(wp2(1))
125
      dv4(1) = dcmplx(wp2(2))
126
      dv4(2) = dcmplx(wp2(3))
127
      dv4(3) = dcmplx(wp2(4))
128
129
      v12 = dv1(0)*dv2(0)-dv1(1)*dv2(1)-dv1(2)*dv2(2)-dv1(3)*dv2(3)
130
      v13 = dv1(0)*dv3(0)-dv1(1)*dv3(1)-dv1(2)*dv3(2)-dv1(3)*dv3(3)
131
      v14 = dv1(0)*dv4(0)-dv1(1)*dv4(1)-dv1(2)*dv4(2)-dv1(3)*dv4(3)
132
      v23 = dv2(0)*dv3(0)-dv2(1)*dv3(1)-dv2(2)*dv3(2)-dv2(3)*dv3(3)
133
      v24 = dv2(0)*dv4(0)-dv2(1)*dv4(1)-dv2(2)*dv4(2)-dv2(3)*dv4(3)
134
      v34 = dv3(0)*dv4(0)-dv3(1)*dv4(1)-dv3(2)*dv4(2)-dv3(3)*dv4(3)
135
136
      dvertx = (v12*v34 + v14*v23 - rTwo*v13*v24)*(gwwa**2+gwwz**2)
137
138
      vertex = -dcmplx( dvertx )
139
c
140
      return
141
      end