24小时热门版块排行榜    

Znn3bq.jpeg
查看: 3488  |  回复: 10

青春逍遥啊

新虫 (小有名气)

[求助] 求救,如何将xyz格式的文件转化为可以让lammps读的data文件,求大神,感激不尽 。 已有2人参与

如题/
回复此楼

» 猜你喜欢

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
回帖支持 ( 显示支持度最高的前 50 名 )

bluewhale

铁杆木虫 (正式写手)

引用回帖:
7楼: Originally posted by 青春逍遥啊 at 2015-12-08 09:12:52
就是一个石墨烯的坐标模型,都是c原子,。。。...

仅仅.xyz转过去是不完整的(见下),还有bond, angle, dihedral的定义。
xyz2lmp.m
--------------
function xyz2lmp(f_xyz)
% This script converts .xyz file to lammps data file.
% Input:
%   f_xyz: name of the input .xyz file.
% Example:
%   xyz2lmp('PdAu.xyz')
% NOTE: The second line must be in specified format as:
%   PdAu xlo xhi ylo yhi zlo zhi
% Poweed by Xianbao Duan
% Email: xianbao.d@gmail.com
% Website: http://www.52souji.net/

% open the .xyz file
fidin = fopen(f_xyz,'r');
if fidin == -1
    error('Failed to open the file. Please check!');
end

% number of all the atoms
atom_num_a = fscanf(fidin,'%d');

% comment
comment = textscan(fidin,'%s %f %f %f %f %f %f',1);
xlo = comment{2};
xhi= comment{3};
ylo = comment{4};
yhi= comment{5};
zlo = comment{6};
zhi= comment{7};

% coordinates of the atoms
atoms = textscan(fidin,'%s %f %f %f',atom_num_a);
fclose(fidin);

% initialize
type_name = atoms{1}(1);    % names of types
atom_num(1) = 1;            % atom number of each type

% sort the atoms according to their types
for i = 2: length(atoms{1})
    flag = 0;
    for j = 1:length(type_name)
        if strcmp(atoms{1}(i),type_name(j)) == 1
            atom_num(j) = atom_num(j) + 1;
            flag = 1;
            break;
        end
    end
    if flag == 0
        type_name(end+1) = atoms{1}(i);
        atom_num(end+1) = 1;
    end
end
type_num = length(type_name);

% write the lammps file
outfilename = strrep(f_xyz,'.xyz','.lmp');
fidout = fopen(outfilename, 'w');
new_comment =  ['Converted from .xyz to .lmp @ ',datestr(now) ];
fprintf(fidout,'%s\n\n',new_comment);
fprintf(fidout,'%d \t %s\n',atom_num_a,'atoms');
fprintf(fidout,'%d \t %s\n',type_num,'atom types');
fprintf(fidout,'%f  %f \t%s\n',xlo,xhi,'xlo xhi');
fprintf(fidout,'%f  %f \t%s\n',ylo,yhi,'ylo yhi');
fprintf(fidout,'%f  %f \t%s\n\n',zlo,zhi,'zlo zhi');
fprintf(fidout,'%s\n\n','Atoms');
% the data
for i = 1:length(atoms{1})
    for j = 1:type_num
        if strcmp(atoms{1}(i),type_name(j)) == 1
            fprintf(fidout,'%d \t %d \t %f \t %f \t %f \n',...
                i,j,atoms{2}(i),atoms{3}(i),atoms{4}(i));
            break;
        end
    end
end
fclose(fidout);
8楼2015-12-08 11:05:38
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
普通回帖

luftf

木虫 (正式写手)

【答案】应助回帖

感谢参与,应助指数 +1
首先要看你用lammps模拟什么材料,用的什么势函数
data文件的结构跟势函数有关
不同势函数用的data文件的结构都不一样
LAMMPS手册里面有具体的说明
2楼2015-12-07 20:16:28
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

cyfjkf

至尊木虫 (著名写手)

3楼2015-12-07 21:18:57
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

bluewhale

铁杆木虫 (正式写手)

【答案】应助回帖

感谢参与,应助指数 +1
有机分子,还是纯金属?
4楼2015-12-07 23:34:49
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

青春逍遥啊

新虫 (小有名气)

引用回帖:
2楼: Originally posted by luftf at 2015-12-07 20:16:28
首先要看你用lammps模拟什么材料,用的什么势函数
data文件的结构跟势函数有关
不同势函数用的data文件的结构都不一样
LAMMPS手册里面有具体的说明

我现在是有一份石墨烯的xyz文件,我需要把它设置成为lammps能够识别的data文件就可以了,。不知道应该用什么办法?
5楼2015-12-08 09:10:26
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

青春逍遥啊

新虫 (小有名气)

引用回帖:
3楼: Originally posted by cyfjkf at 2015-12-07 21:18:57
用VMD软件

应该怎么做?有教程么?
6楼2015-12-08 09:11:39
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

青春逍遥啊

新虫 (小有名气)

引用回帖:
4楼: Originally posted by bluewhale at 2015-12-07 23:34:49
有机分子,还是纯金属?

就是一个石墨烯的坐标模型,都是c原子,。。。
7楼2015-12-08 09:12:52
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

bluewhale

铁杆木虫 (正式写手)

【答案】应助回帖

为什么不自己建:

units metal
boundary        p p p
atom_style      molecular
lattice            custom 2.4595 a1 1  0  0  a2 0 1.73203 0  a3 0.0 0.0 10  basis 0 0 0  basis 0.5 0.16666666666666666 0 basis 0.5 0.5 0 basis 0 0.6666666666666666 0

region box     block 0 80 0 120 -0.5 0.5
create_box     1 box
create_atoms  1 box
region           coldest block INF INF 0 1.5 INF INF
region           hottest block INF INF 60 61.5 INF INF
mass            1    12

pair_style tersoff
pair_coeff * * SiC_1994.tersoff C
9楼2015-12-08 13:56:58
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

青春逍遥啊

新虫 (小有名气)

引用回帖:
9楼: Originally posted by bluewhale at 2015-12-08 13:56:58
为什么不自己建:

units metal
boundary        p p p
atom_style      molecular
lattice            custom 2.4595 a1 1  0  0  a2 0 1.73203 0  a3 0.0 0.0 10  basis 0 0 0  basis 0.5 0.166666666666666 ...

你这个in文件是lammps官网的那个例子吧?我现在就在研究这个in文件啊。我有很多疑问,如果你方便,可以加我q详谈么,287503735 很需要你的帮助,谢谢。
10楼2015-12-08 23:44:37
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 青春逍遥啊 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 322求调剂,08工科 +4 今天是个小号 2026-04-08 4/200 2026-04-13 00:20 by baobaoye
[考研] 复试调剂 +14 积极向上; 2026-04-10 16/800 2026-04-12 20:02 by gruyclewee
[考研] 310求调剂 +13 666真好 2026-04-11 14/700 2026-04-12 16:48 by 1005715100
[考研] 化工调剂求导师收留!一志愿失利,踏实肯干,有植物提取科研经历 +20 yzyzx 2026-04-09 21/1050 2026-04-12 00:12 by 小小小小啦啦啦
[考研] 药学专硕调剂 +8 ? 一路生?花? 2026-04-10 10/500 2026-04-11 21:21 by zhouxiaoyu
[考研] 288求调剂,一志愿华南理工大学071005 +18 ioodiiij 2026-04-08 18/900 2026-04-11 20:25 by liyun12321
[考研] 求调剂,一志愿大连理工大学354分 +5 雨声余生 2026-04-11 6/300 2026-04-11 16:12 by 雨声余生
[考研] 311求调剂 +13 xyp想读书 2026-04-10 14/700 2026-04-11 09:41 by 猪会飞
[考研] 080500求调剂 +17 黄宇博 2026-04-06 17/850 2026-04-11 08:36 by zhq0425
[考研] 一志愿京区985,085401,与本科专业一致,电子信息工程, +4 阳光开朗的男孩 2026-04-10 4/200 2026-04-10 18:27 by shenrf
[考研] 085404,285分求调剂 +12 薇薇考研 2026-04-07 14/700 2026-04-09 23:10 by parmtree
[考研] 278求调剂 +27 范婷娜 2026-04-07 31/1550 2026-04-09 20:49 by zhouxiaoyu
[考研] 348求调剂 +3 candyyyi 2026-04-09 3/150 2026-04-09 17:20 by 段伟艳
[考研] 265求调剂 +4 风说她早忘了 2026-04-07 4/200 2026-04-09 13:59 by only周
[考研] 机械工程313分找工科调剂 +3 双一流本科机械 2026-04-08 3/150 2026-04-08 20:41 by 土木硕士招生
[考研] 264求调剂 +11 麦小叮当 2026-04-07 11/550 2026-04-08 16:05 by 一只好果子?
[考研] 304求调剂 +10 素年祭语 2026-04-06 17/850 2026-04-08 09:05 by 蓝云思雨
[考研] 机械工程264学硕求调剂 +3 qiushangxian 2026-04-06 3/150 2026-04-08 01:53 by Linzejun
[考研] 307求调剂 +3 Youth@@ 2026-04-07 3/150 2026-04-07 22:00 by hemengdong
[考研] 307求调剂 +3 所念及所望 2026-04-06 3/150 2026-04-06 17:30 by 土木硕士招生
信息提示
请填处理意见