24小时热门版块排行榜    

查看: 2189  |  回复: 4

tcclab

银虫 (正式写手)

[交流] 已知三点坐标求夹角 已有2人参与

最近需要处理大量数据,需要对化学键键角批量输出。
我已经把原子坐标以xyz的形式给出。
现在搞不定如何把夹角以degree(度数)的方式给求出来。
哪位知道怎么弄?
本人很菜,别笑话。
#It is 4 Bond Angles
for XYZ in `ls *.xyz`
do
#read in the atom Nr.
AN1=`echo $[$1+2]`
AN2=`echo $[$2+2]`
AN3=`echo $[$3+2]`
echo $AN1 $AN2 $AN3
#The first atom
A11=`awk "NR==$AN1" $XYZ |awk '{print $1}'`
A1x=`awk "NR==$AN1" $XYZ |awk '{print $2}'`
A1y=`awk "NR==$AN1" $XYZ |awk '{print $3}'`
A1z=`awk "NR==$AN1" $XYZ |awk '{print $4}'`
#The second atom
A21=`awk "NR==$AN2" $XYZ |awk '{print $1}'`
A2x=`awk "NR==$AN2" $XYZ |awk '{print $2}'`
A2y=`awk "NR==$AN2" $XYZ |awk '{print $3}'`
A2z=`awk "NR==$AN2" $XYZ |awk '{print $4}'`
#
A31=`awk "NR==$AN3" $XYZ |awk '{print $1}'`
A3x=`awk "NR==$AN3" $XYZ |awk '{print $2}'`
A3y=`awk "NR==$AN3" $XYZ |awk '{print $3}'`
A3z=`awk "NR==$AN3" $XYZ |awk '{print $4}'`
#
echo -e "$A11\t$A1x\t$A1y\t$A1z\t"
echo -e "$A21\t$A2x\t$A2y\t$A2z\t"
echo -e "$A31\t$A3x\t$A3y\t$A3z\t"
#
TT=`echo -e "$A11\t$A1x\t$A1y\t$A1z\t$A21\t$A2x\t$A2y\t$A2z\t$A31\t$A3x\t$A3y\t$A3z\t" `
echo $TT
#
A1A2=`echo $TT | awk '{print $6-$2,$7-$3,$8-$4}' `
echo A1A2 $A1A2
A1A2X=`echo $TT | awk '{print $6-$2}' `
A1A2Y=`echo $TT | awk '{print $7-$3}' `
A1A2Z=`echo $TT | awk '{print $8-$4}' `
A2A3=`echo $TT | awk '{print $10-$6,$11-$7,$12-$8}' `
echo A2A3 $A2A3
A2A3X=`echo $TT | awk '{print $10-$6}' `
A2A3Y=`echo $TT | awk '{print $11-$7}' `
A2A3Z=`echo $TT | awk '{print $12-$8}' `
A1A2A2A3=`echo $A1A2  $A2A3 `
echo A1A2A2A3 $A1A2A2A3
#乘积A1A2*A2A3=(x2-x1)*(x3-x2)+(y2-y1)*(y3-y2)+(z2-z1)*(z3-z2)
TA1A2A2A3=`echo $A1A2A2A3 | awk '{print $1*$4+$2*$5+$3*$6}'`
echo TA1A2A2A3 $TA1A2A2A3
#
A1A2A1A2=`echo $A1A2 | awk '{print $1^2+$2^2+$3^2}'`
A2A3A2A3=`echo $A2A3 | awk '{print $1^2+$2^2+$3^2}'`
echo A1A2A1A2 $A1A2A1A2
echo A2A3A2A3 $A2A3A2A3
#|P1P2|=根号[(x2-x1)2+(y2-y1)2+(z2-z1)2] |P2P3|=根号[(x3-x2)2+(y3-y2)2+(z3-z2)2]
#var absA1A2A2A3=A1A2*A2A3
absA1A2=`echo $A1A2A1A2 | awk '{print sqrt($1)}'`
echo absA1A2 $absA1A2
absA2A3=`echo $A2A3A2A3 | awk '{print sqrt($1)}'`
echo absA2A3 $absA2A3
#
#cos(A1A2,A2A3)=A1A2*A2A3/(|A1A2|*|A2A3|)
A1A2A3=`echo $TA1A2A2A3 $absA1A2 $absA2A3 `
echo A1A2A3 $A1A2A3
# 前面检查,读入和输出,应该是正确的,但下面这部分搞不定了
cosA1A2A3=`echo $A1A2A3 | awk '{print $1/($2*$3)}'`
#弧度=角度乘以π后再除以180 角度=弧度除以π再乘以180
#pi=3.1415926535898
cosA1A2A3=`echo $cosA1A2A3 | awk '{print cos($1)}'`
Angle=`echo $acosA1A2A3 | awk '{print $1*180/3.1415926535898}' `
echo $A1A2 $A1A2XX $A1A2YY $A1A2ZZ $A1A2A1A2 $cosA1A2A3
echo $cosA1A2A3
echo $Angle
done

xyz 文件如下:
36

  Fe  4.84655858507584      0.56633277215833      0.34035878855785
  Al  4.79235130609276      2.90413572930704      0.18293815072370
  H   4.28535603237677      3.97006317825069      1.30657195333100
  O   1.96706095735722      1.03530980080275      0.77397530855226
  O   4.93691132336707     -2.35361098202682      0.67632768640727
  O   6.77764534437593      1.25909183704602      2.45505687074638
  O   5.76193037993391      0.63511115108140     -2.45907090865639
  N   2.60533354124266      4.09822722851467     -1.75829932419780
....
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

jerkwin

专家顾问 (正式写手)


小木虫: 金币+0.5, 给个红包,谢谢回帖
果然很菜啊
直接上awk就是了, 别bash, awk混用
2楼2014-01-29 23:34:33
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

btx97

金虫 (小有名气)

★ ★
小木虫: 金币+0.5, 给个红包,谢谢回帖
jjdg: 金币+1, 春节快乐 2014-01-31 00:24:59
先距离再余弦公式
话说用shell, awk做计算能给力吗?
3楼2014-01-30 03:48:48
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

tcclab

银虫 (正式写手)

引用回帖:
2楼: Originally posted by jerkwin at 2014-01-29 23:34:33
果然很菜啊
直接上awk就是了, 别bash, awk混用

能给个指导?
4楼2014-01-30 17:08:46
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

tcclab

银虫 (正式写手)


jjdg: 金币+1, 春节快乐 2014-01-31 00:24:47
引用回帖:
3楼: Originally posted by btx97 at 2014-01-30 03:48:48
先距离再余弦公式
话说用shell, awk做计算能给力吗?

仅仅用来处理文本
5楼2014-01-30 17:09:11
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 tcclab 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 环境学硕288求调剂 +8 皮皮皮123456 2026-03-22 8/400 2026-03-23 23:47 by 热情沙漠
[考研] 一志愿河北工业大学0817化工278分求调剂 +7 jhybd 2026-03-23 11/550 2026-03-23 23:29 by 呆呆师姐
[考研] 279分求调剂 一志愿211 +17 chaojifeixia 2026-03-19 19/950 2026-03-23 23:26 by 呆呆师姐
[考研] 材料专硕找调剂 +3 哈哈哈吼吼吼哈 2026-03-23 3/150 2026-03-23 23:13 by peike
[考研] 336求调剂 +4 收到VS 2026-03-20 4/200 2026-03-23 19:02 by macy2011
[考研] 336化工调剂 +4 王大坦1 2026-03-23 5/250 2026-03-23 18:32 by allen-yin
[考研] 工科0856求调剂 +5 沐析汀汀 2026-03-21 5/250 2026-03-23 17:56 by 海瑟薇-
[考研] 北科281学硕材料求调剂 +8 tcxiaoxx 2026-03-20 9/450 2026-03-23 12:16 by tcxiaoxx
[考研] 305分求调剂(食品工程) +4 Sxy112 2026-03-21 6/300 2026-03-22 15:26 by 无懈可击111
[考研] 303求调剂 +5 安忆灵 2026-03-22 6/300 2026-03-22 12:46 by 素颜倾城1988
[考研] 280求调剂 +11 咕噜晓晓 2026-03-18 12/600 2026-03-21 22:40 by ACS Nano——
[考研] 313求调剂 +4 肆叁贰壹22 2026-03-19 4/200 2026-03-21 17:33 by ColorlessPI
[考研] 材料与化工(0856)304求 B区 调剂 +3 邱gl 2026-03-21 3/150 2026-03-21 13:47 by lature00
[考研] 求调剂 +3 Ma_xt 2026-03-17 3/150 2026-03-21 02:05 by JourneyLucky
[考研] 一志愿武理材料305分求调剂 +6 想上岸的鲤鱼 2026-03-18 7/350 2026-03-21 01:03 by JourneyLucky
[考研] 0817 化学工程 299分求调剂 有科研经历 有二区文章 +22 rare12345 2026-03-18 22/1100 2026-03-20 20:39 by zhukairuo
[考研] 261求B区调剂,科研经历丰富 +3 牛奶很忙 2026-03-20 4/200 2026-03-20 19:34 by JourneyLucky
[考研] 288求调剂,一志愿华南理工大学071005 +5 ioodiiij 2026-03-17 5/250 2026-03-19 18:22 by zcl123
[考研] 085600材料与化工调剂 324分 +10 llllkkkhh 2026-03-18 12/600 2026-03-19 14:33 by llllkkkhh
[考研] 一志愿福大288有机化学,求调剂 +3 小木虫200408204 2026-03-18 3/150 2026-03-19 13:31 by houyaoxu
信息提示
请填处理意见