c 03/9/4版
c アスキーフォーマットのppm画像ファイルの R値、G値、B値それぞれの
c 平均と標準偏差を求める。また、
c ppm画像データの各行の輝度信号(Y=0.31R+0.59G+0.11B)の横方向の平均を
c 1列に並べたデータ(yokosima.d)と、
c ppm画像データの各列の輝度信号(Y=0.31R+0.59G+0.11B)の縦方向の平均を
c 1列に並べたデータ(tatesima.d)を出力する。ppm.fがやるのはここまで。
c ------------------意図----------------
c   貴家仁志『よくわかるディジタル画像処理』(CQ出版社)
c   付属の1次元FFTプログラム(fftvec)に、
c yokosima.d とtatesima.d を
c 入力して、画像ファイルの横縞成分の振幅スペクトルyokospe.dと
c 縦縞成分の振幅スペクトルtatespe.dを求める。
c それらをspe2dg.fに入力すると、パワーと周波数で両対数プロット
c した場合の横縞パワーと縦縞パワーの回帰直線の
c 傾きの平均、標準偏差の平均、傾きの差などを
c 定量化のための数値指標として出力する。
c 例えば、gazou01.ppm という画像データに対しては、
c ppm < gazou01.ppm > rgb.01
c fftvec yokosima.d > yokospe.d
c fftvec tatesima.d > tatespe.d
c spe2dg > spe.01
c みたいな手順で実行する。
c ----------------------------------------
c だけど、データ入力は、
c ppmファイルの各行のデータの個数がどういうふうになっているかに
c 応じて、書き換えなければならない。
c 以下は、
c http://www.vector.co.jp/soft/win95/art/se165334.html
c ここのフリーソフト「疾風 -Tokikaze-」(作者:PAPYさん)
c で、256×256ピクセルで出力された ppm ファイルに対応した例。
c
        program ppm
       implicit real*8 (a-h, o-z)
       dimension rgb3(196608),r(65536),g(65536),b(65536),
     & zy(65536),zi(65536),zq(65536)
       character p3*2,mozi*35
          read(*,100) p3
          read(*,110) mozi
100      format(a2)
110      format(a35)
           write(*,*) 'マジックナンバー:',p3
           write(*,*) 'コメント行:',mozi
          read(*,*) m,n
          write(*,*) '幅:',m
          write(*,*) '高さ:',n
           mn=m*n
          read(*,*) max
          write(*,*) '最大値:',max
          read(*,*) (rgb3(i),i=1,18)
          n1=18
          read(*,*) (rgb3(n1+i),i=1,18)
          n1=n1+18
          read(*,*) (rgb3(n1+i),i=1,18)
          n1=n1+18
          read(*,*) (rgb3(n1+i),i=1,18)
          n1=n1+18
          read(*,*) (rgb3(n1+i),i=1,15)
          n1=n1+15
c          write(*,*) 'n1=',n1
          mn3=mn*3
          n2=mn3-n1-9
          n2=n2/69
c          write(*,*) 'n2=',n2
        do j=1,n2
          read(*,*) (rgb3(n1+i),i=1,18)
          n1=n1+18
          read(*,*) (rgb3(n1+i),i=1,18)
          n1=n1+18
          read(*,*) (rgb3(n1+i),i=1,18)
          n1=n1+18
          read(*,*) (rgb3(n1+i),i=1,15)
          n1=n1+15
        end do
          read(*,*) (rgb3(n1+i),i=1,9)
c          write(*,*) 'nsaigo=',n1+9
c  以上がデータ入力
c
        do i=1,mn
          r(i)=rgb3((i-1)*3+1)
          g(i)=rgb3((i-1)*3+2)
          b(i)=rgb3((i-1)*3+3)
       end do
          call heikin(mn,r,ar,sr)
          call heikin(mn,g,ag,sg)
          call heikin(mn,b,ab,sb)
        write(*,*) 'R値の平均=',ar,'(標準偏差:',sr,')'
        write(*,*) 'G値の平均=',ag,'(標準偏差:',sg,')'
        write(*,*) 'B値の平均=',ab,'(標準偏差:',sb,')'
           x=float(max)
        write(*,*) '------------------------------------------'
        write(*,*) '最大値1に正規化'
        write(*,*) 'R値の平均=',ar/x,'(標準偏差:',sr/x,')'
        write(*,*) 'G値の平均=',ag/x,'(標準偏差:',sg/x,')'
        write(*,*) 'B値の平均=',ab/x,'(標準偏差:',sb/x,')'
        write(*,*) '------------------------------------------'
c
c RGB の平均を YIQ に変換
        do i=1,mn
         zy(i)=0.31d0 * r(i) + 0.59d0 * g(i) + 0.11d0 * b(i)
         zi(i)=0.60d0 * r(i) - 0.28d0 * g(i) - 0.32d0 * b(i)
         zq(i)=0.21d0 * r(i) - 0.52d0 * g(i) + 0.31d0 * b(i)
        end do
          call heikin(mn,zy,ay,sy)
          call heikin(mn,zi,ai,si)
          call heikin(mn,zq,aq,sq)
        write(*,*) 'Y値の平均=',ay,'(標準偏差:',sy,')'
        write(*,*) 'I値の平均=',ai,'(標準偏差:',si,')'
        write(*,*) 'Q値の平均=',aq,'(標準偏差:',sq,')'
        write(*,*) '------------------------------------------'
        write(*,*) '最大値1に正規化'
        write(*,*) 'Y値の平均=',ay/x,'(標準偏差:',sy/x,')'
        write(*,*) 'I値の平均=',ai/x,'(標準偏差:',si/x,')'
        write(*,*) 'Q値の平均=',aq/x,'(標準偏差:',sq/x,')'
c
       open(7,file='yokosima.d')
          write(7,*) m
        do i=1,n
          im=(i-1)*m
          yoko=0.d0
         do j=im+1,im+m
          yoko=yoko+0.31d0*r(j) +0.59d0*g(j) +0.11d0*b(j)
         end do
          yoko=yoko/float(max)
          write(7,200) yoko
c          write(7,210) i,yoko
        end do
       close(7)
c
       open(7,file='tatesima.d')
          write(7,*) m
        do j=1,m
          mnj=m*(n-1)+j
          tate=0.d0
         do i=j,mnj,m
          tate=tate+0.31d0*r(i) +0.59d0*g(i) +0.11d0*b(i)
         end do
          tate=tate/float(max)
          write(7,200) tate
c          write(7,210) j,tate
        end do
       close(7)
c
200     format(1pd13.5)
210     format(i4,1pd13.5)
c
          end
c
          subroutine heikin(mn,x,a,s)
       implicit real*8 (a-h, o-z)
       dimension x(mn)
         a=0.d0
         s=0.d0
        do i=1,mn
         a=a+x(i)
        end do
         a=a/float(mn)
        do i=1,mn
         s=s+ ( x(i)-a )**2
        end do
         s=sqrt(s/mn)
        return
        end
c