-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathid31check.f90
118 lines (117 loc) · 4.2 KB
/
id31check.f90
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
program id31check
implicit none
character(len=256)::line
integer :: ier, iarg, ioutunit, jjj
integer, external :: iargc
integer(kind=4) :: i, ndata, iscan, n, j, k, n3s, n6s
real(kind=8) :: x,y,esd, diff, c2, wd, tthlow, tthhigh, step
real(kind=8),allocatable,dimension(:,:) :: data
integer(kind=4),external :: jbin
! Read epf file in
i=0; ier=0
call getarg(1,line) ! name of epf file
open(unit=20,file=line(1:len_trim(line)),status='OLD',iostat=ier)
if(ier.ne.0)then
write(*,'(a)')'Error opening '//line(1:len_trim(line))
stop
endif
open(unit=21,status='SCRATCH',form='UNFORMATTED')
1 read(20,*,end=10,err=11)x,y,esd
write(21)x,y,esd
i=i+1
goto 1
11 stop 'Data format problem'
10 allocate(data(3,i),stat=ier)
if(ier.ne.0)stop 'Memory allocation problem'
ndata=i
rewind(21)
do i=1,ndata
read(21)data(1,i),data(2,i),data(3,i)
enddo
close(21)
close(20)
jjj=1; ioutunit=19
! write a file in plotmtv format with the 9 channels and sum
open(unit=ioutunit,file='scans.mtv',status='UNKNOWN', &
& form='FORMATTED', access='SEQUENTIAL',iostat=ier)
if(ier.ne.0)stop 'error opening diagnostic file'
write(ioutunit,'(a)')'$ DATA = CURVE2D'
write(ioutunit,'(a)')'% xlabel = "Two Theta"'
write(ioutunit,'(a)')'% ylabel = "Cts/Monitor"'
write(ioutunit,'(a)')'% toplabel= "Scans and total plot"'
write(ioutunit,'(a,i2,a)')'% linelabel = "Total" '
write(ioutunit,'(a,i2)')'% linecolor = ',jjj
write(ioutunit,'(a)')'% linetype=1 markertype=0'
do j=1,ndata
write(ioutunit,'(2F15.8)')data(1,j),data(2,j)
enddo
write(ioutunit,*)
! Epf file is now in array data
step=(data(1,ndata)-data(1,1))/real(ndata-1,8)
tthlow=data(1,1)-step/2.0d0
tthhigh=data(1,ndata)+step/2.0d0
write(*,*)'Opened summed file ',line(1:len_trim(line)),' npts ', &
& ndata
write(*,1000)'Step ',step,' tthlow ',tthlow,' tthhigh ',tthhigh
1000 format(3(a,F15.8))
! Now read in the series of scans
iarg=iargc() ! total number of cmdline arguments
if(iarg.le.1)then
stop 'need to supply a list of scans to check'
endif
! 1234567890123456789012345678901234567890
write(*,999)
999 format(' Scan npts 3-sigma 6-sigma chi**2')
do i=2,iarg
call getarg(i,line)
line=adjustl(line)
n=len_trim(line)
write(line,'(a)')line(1:n)//'.inp'
open(unit=20,file=line(1:len_trim(line)),status='OLD',iostat=ier)
if(ier.ne.0)then
write(*,'(a)') 'Error opening '//line(1:len_trim(line))
stop
endif
! write(*,*)'Opened '//line(1:len_trim(line))
write(ioutunit,*)
write(ioutunit,'(a,a,a)')'% linelabel = "', &
& line(1:len_trim(line)),'"'
jjj=jjj+1
write(ioutunit,'(a,i3)')'% linecolor = ',jjj
write(ioutunit,'(a)')'% linetype=1 markertype=0'
c2=0.0d0; n3s=0; n6s=0; n=0
! read and check the .inp against the .epf now
2 read(20,*,end=21,err=22)x,y,esd
write(ioutunit,'(2F15.8)')x,y
k=jbin(x,tthlow,tthhigh,step)
! test binning ! write(*,*)x,data(1,k)
if(k.gt.0)then
n=n+1
diff=y-data(2,k)
wd=diff*diff/(esd*esd+data(3,k)*data(3,k))
c2=c2+wd
if(wd.gt.9.0d0)n3s=n3s+1
if(wd.gt.27.0d0)n6s=n6s+1
endif
goto 2
22 write(*,'(a)')'Data format problem in'//line(1:len_trim(line))
stop
21 close(20)
write(*,1001)line(1:len_trim(line)),n,n3s,n6s,c2/real(n,8)
1001 format(a10,3i10,F16.8)
enddo
write(ioutunit,'(a)')'$ END'
close(ioutunit)
end program id31check
integer(kind=4) function jbin(tth,tthlow,tthhigh,step)
implicit none
real(kind=8),intent(in)::tth, tthlow, tthhigh, step
real(kind=8)::x
if(tth.ge.tthlow .and. tth.le.tthhigh)then
x=(tth-tthlow)/step+0.5d0
jbin=nint(x)
else
jbin=-1
endif
return
end function jbin