PROGRAM SETUAZ
C=======================================================================
C      DATA GENERATING PROGRAM FOR BEM8LINU.FOR
C   PROJECT: DOUBLE-LET   PROJECT NAME: Dirichlet boundary condition
C    DOMAIN: INFINITE
C    ELEMENT: TWO-NODED LINEAR BOUNDARY ELEMENT
C     EIJI FUKUMORI DECEMBER 29, 1993 
C=======================================================================
      IMPLICIT REAL*8 ( A-H , O-Z )
      PARAMETER ( ND=2,MXE=500,MXN=MXE, MXI=100 )
      PARAMETER ( NDVEC=4,MXEVEC=5000000,MXNVEC=5500000 )
C=======================================================================
      DIMENSION NODEX(MXE,ND),XCOORD(MXN), YCOORD(MXN)
      DIMENSION XI(MXI), YI(MXI), IELTYPE(MXE),BV(MXE,ND)
      DIMENSION NODEXVEC(MXEVEC,NDVEC), XCOORDVEC(MXNVEC)
      DIMENSION YCOORDVEC(MXNVEC)
C=======================================================================
CCCCCCCCCCCCCCCCCCCCCCCCC      NC=16
      NC=64
      FMU = 1.D0
      POTENTIL = 0.5D0
      WRITE (*,*) 'Prescribed potential Value on The boundary=',POTENTIL
C=======================================================================
      PI = 4.* DATAN( 1.D0)
      RADIUS = 1.0D0
      XC1 = 0.D0
      WRITE (*,*) 'RADIUS = ', RADIUS
      WRITE(*,*) 'TYPE IN GAP BETWEEN WIRE ELEMENTS'
      READ (*,*) GAP
      YC1 = RADIUS + GAP/2.D0
      IF ( GAP .LE. 0.D0 ) STOP 'A VALUE OF GAP MUST BE MORE THAN ZERO'
      XC2 =  XC1
      YC2 = -YC1
C=======================================================================
C-----     NORDAL COORDINATES CREATION
      SEG = NC
      HSEG = SEG/2.D0
      DO I = 1 , NC
      XCOORD(I) = RADIUS*COS ( -I*PI/HSEG )
      YCOORD(I) = RADIUS*SIN ( -I*PI/HSEG )
      END DO
      DO I = 1 , NC
      XCOORD(I+NC) = XCOORD(I) + XC2
      YCOORD(I+NC) = YCOORD(I) + YC2
      XCOORD(I) = XCOORD(I) + XC1
      YCOORD(I) = YCOORD(I) + YC1
      END DO
      NNODE = NC*2
C=======================================================================
C                    ELEMENT CREATION
C----------------  CIRCUMFERENCE = 2*PI*RADIUS
C  MAGNETIC FLUX DENSITY ON SURFACE = ELECTRIC CURRENT/(CIRCUMFERENCE)
C-------- DIRECTIN = INTEGRAL DIRECTION ------
      DIRECTIN = -1.D0
      DO I = 1 , NC
      J = I+1
      IF ( I .EQ. NC ) J = 1
      NODEX(I,1) = I
      NODEX(I,2) = J
      IELTYPE(I) = 1
      BV(I,1) = POTENTIL
      BV(I,2) = POTENTIL
      END DO
      DO I = 1+NC , NC*2
      J = I+1
      IF ( I .EQ. NC*2 ) J = 1+NC
      NODEX(I,1) = I
      NODEX(I,2) = J
      IELTYPE(I) = 1
      BV(I,1) = -POTENTIL
      BV(I,2) = -POTENTIL
      END DO
      NE = NC*2
C=======================================================================
C--------INTERNAL POINTS
      NIP = 0
      NIP = NIP + 1
      XI(NIP) = 0.D0
      YI(NIP) = 0.0001D0
      NIP = NIP + 1
      XI(NIP) = 0.
      YI(NIP) = (YC1-RADIUS)/4.D0
      NIP = NIP + 1
      XI(NIP) = 0.D0
      YI(NIP) = (YC1-RADIUS)/2.D0
      NIP = NIP + 1
      XI(NIP) = 0.D0
      YI(NIP) = (YC1-RADIUS)/4.D0*3.D0
      NIP = NIP + 1
      XI(NIP) = 0.D0
      YI(NIP) = YC1 - RADIUS/4.D0*3.D0
      NIP = NIP + 1
      XI(NIP) = 0.D0
      YI(NIP) = YC1 - RADIUS/4.D0
      NIP = NIP + 1
      XI(NIP) = 0.D0
      YI(NIP) = YC1 + RADIUS/4.D0
      NIP = NIP + 1
      XI(NIP) = 0.
      YI(NIP) = YC1 + RADIUS/4.D0*3.D0
      NIP = NIP + 1
      XI(NIP) = 0.D0
      YI(NIP) = YC1 + RADIUS*1.D0 + RADIUS/4.D0
      NIP = NIP + 1
      XI(NIP) = 0.D0
      YI(NIP) = YC1 + RADIUS*2.D0
      NIP = NIP + 1
      XI(NIP) = 0.D0
      YI(NIP) = YC1 + RADIUS*3.D0
      NIP = NIP + 1
      XI(NIP) = 0.D0
      YI(NIP) = YC1 + RADIUS*4.D0
      NIP = NIP + 1
      XI(NIP) = 0.D0
      YI(NIP) = YC1 + RADIUS*5.D0
C
      DO I = 3 , 30
      NIP = NIP + 1
      XI(NIP) = 0.
      YI(NIP) = YC1 + RADIUS*I*2.D0
      END DO
C
      NNN = NIP
      DO I = 1 , NNN
      NIP = NIP + 1
      XI(NIP) = 0.D0
      YI(NIP) = -YI(I)
      END DO
C
C
      DO I = 1 , NIP-1
      YMIN = YI(I)
      K = I
      DO J = I+1 , NIP
      IF ( YI(J) .LT. YMIN ) THEN
      YMIN = YI(J)
      K = J
      END IF
      END DO
      YI(K) = YI(I)
      YI(I) = YMIN
      END DO
C=======================================================================
C                     MAKING DATA FILES
      OPEN ( 1, FILE='BEM1.DAT', STATUS='UNKNOWN' )
      WRITE (1,*) FMU
      WRITE (1,*) NE
      DO I = 1 , NE
      WRITE (1,*) I,(NODEX(I,J),J=1,ND),IELTYPE(I), (BV(I,J),J=1,ND)
      END DO
      NNODE = NE
      DO I = 1 , NNODE
      WRITE (1,*) I, XCOORD(I), YCOORD(I)
      END DO
C------ INTERNAL POINT
      WRITE(1,*) NIP
      IF ( NIP .GE. 1 ) THEN
      DO I = 1 , NIP
      WRITE(1,*) I, XI(I), YI(I)
      END DO
      END IF
      CLOSE (1)
      WRITE(*,*) 'NE=',NE
      WRITE(*,*) 'NNODE=',NNODE
C------------- BOUNDARY configuration
      OPEN ( 2, FILE='BOUNDARY.DAT', STATUS='UNKNOWN' )
      DO IEL = 1 , NE
      WRITE (2,*) XCOORD(NODEX(IEL,1)), YCOORD(NODEX(IEL,1))
      WRITE (2,*) XCOORD(NODEX(IEL,2)), YCOORD(NODEX(IEL,2))
      WRITE (2,*)
      END DO
      CLOSE (2)
C=======================================================================
C
C              ELEMENT CREATION FOR VECTOR PLOT GRAPHICS
C
C=======================================================================
      DL = RADIUS / 2.5D0
      XLENGTH = 8*RADIUS
      YLENGTH = 6*RADIUS + GAP
      NEX = XLENGTH / DL
      NEY = YLENGTH / DL
      NEX = NEX/2*2
      NEY = NEY/2*2
      DX = XLENGTH / NEX
      DY = YLENGTH / NEY
      NDX = NEX + 1
      NDY = NEY + 1
      NEVEC = 0
      DO I = 1 , NEY
      DO J = 1 , NEX
      NEVEC = NEVEC + 1
      IF ( NEVEC .GT. MXEVEC ) STOP 'NEVEC > MXE'
      NODEXVEC(NEVEC,1) = NDX*(I-1) + J
      NODEXVEC(NEVEC,2) = NODEXVEC(NEVEC,1) + 1
      NODEXVEC(NEVEC,3) = NODEXVEC(NEVEC,2) +NDX
      NODEXVEC(NEVEC,4) = NODEXVEC(NEVEC,1)+NDX
      END DO
      END DO
C--------------- NODAL INFORMATION -------------------
      NNODEVEC = 0
      DO J = 1 , NDY
      DO I = 1 , NDX
      NNODEVEC = NNODEVEC + 1
      XCOORDVEC(NNODEVEC) = (I-(NEX/2+1))*DX
      YCOORDVEC(NNODEVEC) = (J-(NEY/2+1))*DY
      END DO
      END DO
      WRITE(*,*) 'NEVEX=',NEVEC
      WRITE(*,*) 'NNODEVEC=',NNODEVEC
C--------------MAKING INPUT FILE------------------------
      OPEN ( 5, FILE='VECTORCG.DAT', STATUS = 'UNKNOWN' )
      WRITE(5,*) NEVEC
      DO I = 1 , NEVEC
      WRITE (5,*) I,(NODEXVEC(I,J),J=1,NDVEC)
      END DO
      WRITE(5,*) NNODEVEC
      DO I = 1 , NNODEVEC
      WRITE(5,*) I, XCOORDVEC(I), YCOORDVEC(I)
      END DO
      CLOSE (5)
C=======================================================================
      STOP
      END