30 use,
intrinsic :: iso_c_binding
36 recursive subroutine my_error(message)
38 character(len=*, kind=c_char),
intent(in) :: message
40 print *,
"* Error : ", trim(message)
46 character(len=*, kind=c_char),
intent(in) :: message
48 print *,
"* Warning : ", trim(message)
58 use,
intrinsic :: iso_c_binding
63 integer(c_int) function c_system(cmd) bind(c, name="system")
64 use,
intrinsic :: iso_c_binding
65 character(c_char),
intent(in) :: cmd(*)
69 integer(c_int) :: ierr
70 integer(c_int) :: extent
71 integer(c_int) :: no_fields
74 type(kim_simulator_model_handle_type) :: sm
76 character(len=2048, kind=c_char) s_name
77 character(len=2048, kind=c_char) s_ver
78 character(len=2048, kind=c_char) species
79 character(len=2048, kind=c_char) field_name
80 character(len=2048, kind=c_char) line
81 character(len=2048, kind=c_char) dir_name
82 character(len=2048, kind=c_char) spec_name
83 character(len=2048, kind=c_char) param_basename
85 call kim_simulator_model_create( &
86 "Sim_LAMMPS_LJcut_AkersonElliott_Alchemy_PbAu", sm, ierr)
92 call kim_get_simulator_name_and_version(sm, s_name, s_ver)
93 print *,
"Simulator name : ", trim(s_name)
94 print *,
"Simulator version : ", trim(s_ver)
97 call kim_get_number_of_supported_species(sm, extent)
98 print *,
"SM supports", extent,
" species:" 100 call kim_get_supported_species(sm, i, species, ierr)
102 call my_error(
"Unable to get species.")
104 print
'(A,I2," ",A)', achar(9), i, trim(species)
109 call kim_add_template_map(sm,
"atom-type-sym-list",
"Pb Pb Au Pb", ierr)
111 call my_error(
"Unable to add template map.")
113 call kim_close_template_map(sm)
114 call kim_get_number_of_simulator_fields(sm, no_fields)
115 print
'("SM has ",I2," fields :")', no_fields
117 call kim_get_simulator_field_metadata(sm, i, extent, field_name, ierr)
118 print
'(" Field",I2," is ",A," and has ",I2," lines:")', &
119 i, trim(field_name), extent
122 call kim_get_simulator_field_line(sm, i, j, line, ierr)
124 call my_error(
"Unable to get field line.")
126 print
'(A,A)', achar(9), trim(line)
132 call kim_get_parameter_file_directory_name(sm, dir_name)
133 print
'("SM param dir name is ",A)', trim(dir_name)
135 call kim_get_specification_file_name(sm, spec_name)
136 print
'("SM spec file name is ",A)', trim(spec_name)
137 ierr = c_system(
"cat "//trim(dir_name)//
"/"//trim(spec_name)//c_null_char)
139 call kim_get_number_of_parameter_files(sm, extent)
140 print
'("SM has ",I1," parameter files:")', extent
142 call kim_get_parameter_file_basename(sm, i, param_basename, ierr)
144 call my_error(
"Unable to get parameter file basename.")
146 print
'("Parameter file ",I2," has basename ",A)', i, trim(param_basename)
148 "cat "//trim(dir_name)//
"/"//trim(param_basename)//c_null_char)
153 call kim_simulator_model_destroy(sm)
recursive subroutine my_warning(message)
recursive subroutine my_error(message)
program collections_example_fortran