|
|
|
@ -10,6 +10,7 @@ module io
|
|
|
|
|
integer :: outfilenum = 0, infilenum = 0
|
|
|
|
|
character(len=100) :: outfiles(10), infiles(10)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public
|
|
|
|
|
contains
|
|
|
|
|
|
|
|
|
@ -62,9 +63,14 @@ module io
|
|
|
|
|
outfilenum=outfilenum+1
|
|
|
|
|
outfiles(outfilenum) = temp_outfile
|
|
|
|
|
exit
|
|
|
|
|
case('cac')
|
|
|
|
|
lmpcac = .true.
|
|
|
|
|
outfilenum=outfilenum+1
|
|
|
|
|
outfiles(outfilenum) = temp_outfile
|
|
|
|
|
exit
|
|
|
|
|
case default
|
|
|
|
|
print *, "File type: ", trim(temp_outfile(scan(temp_outfile,'.',.true.):)), "not currently accepted. ", &
|
|
|
|
|
"please input a filename with extension from following list: xyz, lmp, vtk."
|
|
|
|
|
print *, "File type: ", trim(temp_outfile(scan(temp_outfile,'.',.true.):)), " not currently accepted. ", &
|
|
|
|
|
"please input a filename with extension from following list: xyz, lmp, vtk, cac."
|
|
|
|
|
read(*,*) temp_outfile
|
|
|
|
|
|
|
|
|
|
end select
|
|
|
|
@ -72,7 +78,6 @@ module io
|
|
|
|
|
|
|
|
|
|
end subroutine get_out_file
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
subroutine write_out
|
|
|
|
|
!This subroutine loops over alll of the outfile types defined and calls the correct writing subroutine
|
|
|
|
|
|
|
|
|
@ -94,6 +99,8 @@ module io
|
|
|
|
|
call write_mb(outfiles(i))
|
|
|
|
|
case('restart')
|
|
|
|
|
call write_pycac(outfiles(i))
|
|
|
|
|
case('cac')
|
|
|
|
|
call write_lmpcac(outfiles(i))
|
|
|
|
|
case default
|
|
|
|
|
print *, "The extension ", trim(adjustl(outfiles(i)(scan(outfiles(i),'.',.true.)+1:))), &
|
|
|
|
|
" is not accepted for writing. Please select from: xyz and try again"
|
|
|
|
@ -193,6 +200,71 @@ module io
|
|
|
|
|
end do
|
|
|
|
|
end subroutine write_lmp
|
|
|
|
|
|
|
|
|
|
subroutine write_lmpcac(file)
|
|
|
|
|
!This subroutine writes out a .lmp style dump file
|
|
|
|
|
character(len=100), intent(in) :: file
|
|
|
|
|
integer :: write_num, i, inod, ibasis
|
|
|
|
|
real(kind=dp) :: mass
|
|
|
|
|
|
|
|
|
|
1 format(i16, ' Eight_Node', 4i16)
|
|
|
|
|
2 format(i16, ' Atom', 4i16)
|
|
|
|
|
3 format(3i16,3f23.15)
|
|
|
|
|
|
|
|
|
|
open(unit=11, file=trim(adjustl(file)), action='write', status='replace',position='rewind')
|
|
|
|
|
|
|
|
|
|
!Comment line
|
|
|
|
|
write(11, '(a)') '# CAC input file made with cacmb'
|
|
|
|
|
write(11, '(a)')
|
|
|
|
|
!Calculate total atom number
|
|
|
|
|
write_num = atom_num + ele_num
|
|
|
|
|
|
|
|
|
|
!Write total number of atoms + elements
|
|
|
|
|
write(11, '(i16, a)') write_num, ' cac elements'
|
|
|
|
|
!Write number of atom types
|
|
|
|
|
write(11, '(i16, a)') atom_types, ' atom types'
|
|
|
|
|
|
|
|
|
|
write(11,'(a)') ' '
|
|
|
|
|
!Write box bd
|
|
|
|
|
write(11, '(2f23.15, a)') box_bd(1:2), ' xlo xhi'
|
|
|
|
|
write(11, '(2f23.15, a)') box_bd(3:4), ' ylo yhi'
|
|
|
|
|
write(11, '(2f23.15, a)') box_bd(5:6), ' zlo zhi'
|
|
|
|
|
|
|
|
|
|
!Masses
|
|
|
|
|
write(11, '(a)') 'Masses'
|
|
|
|
|
|
|
|
|
|
write(11, '(a)') ' '
|
|
|
|
|
do i =1, atom_types
|
|
|
|
|
call atommass(type_to_name(i),mass)
|
|
|
|
|
write(11, '(i16, f23.15, 2a)') i, mass, ' # ', type_to_name(i)
|
|
|
|
|
end do
|
|
|
|
|
write(11, '(a)') ' '
|
|
|
|
|
|
|
|
|
|
write(11, '(a)') 'CAC Elements'
|
|
|
|
|
write(11, '(a)') ' '
|
|
|
|
|
|
|
|
|
|
!Write element nodal positions
|
|
|
|
|
do i = 1, ele_num
|
|
|
|
|
select case(trim(adjustl(type_ele(i))))
|
|
|
|
|
case('fcc')
|
|
|
|
|
!The first entry is the element specifier
|
|
|
|
|
write(11,1) i, basisnum(lat_ele(i)), size_ele(i), size_ele(i), size_ele(i)
|
|
|
|
|
do ibasis = 1, basisnum(lat_ele(i))
|
|
|
|
|
do inod = 1, 8
|
|
|
|
|
!Nodal information for every node
|
|
|
|
|
write(11,3) inod, ibasis, basis_type(ibasis,lat_ele(i)), r_node(:,ibasis,inod,i)
|
|
|
|
|
end do
|
|
|
|
|
end do
|
|
|
|
|
end select
|
|
|
|
|
end do
|
|
|
|
|
|
|
|
|
|
do i = 1, atom_num
|
|
|
|
|
!Element specifier dictating that it is an atom
|
|
|
|
|
write(11,2) ele_num+i, 1, 1, 1, 1
|
|
|
|
|
!Write the atomic information
|
|
|
|
|
write(11,3) 1, 1, type_atom(i), r_atom(:,i)
|
|
|
|
|
end do
|
|
|
|
|
end subroutine write_lmpcac
|
|
|
|
|
|
|
|
|
|
subroutine write_vtk(file)
|
|
|
|
|
!This subroutine writes out a vtk style dump file
|
|
|
|
|
integer :: i, j, inod, ibasis
|
|
|
|
@ -249,7 +321,7 @@ module io
|
|
|
|
|
do i = 1, ele_num
|
|
|
|
|
do inod=1, ng_node(lat_ele(i))
|
|
|
|
|
do ibasis = 1, basisnum(lat_ele(i))
|
|
|
|
|
write(11, '(3f23.1)') sum(r_node(:,:,inod,i),2)/basisnum(lat_ele(i))
|
|
|
|
|
write(11, '(3f23.15)') sum(r_node(:,:,inod,i),2)/basisnum(lat_ele(i))
|
|
|
|
|
end do
|
|
|
|
|
end do
|
|
|
|
|
end do
|
|
|
|
|