埃德蒙顿华人社区-Edmonton China

 找回密码
 注册
查看: 59816|回复: 65

[技术互助] 需要学习PLC CNC的同志请在这里交流

[复制链接]
鲜花(0) 鸡蛋(0)
发表于 2009-2-7 22:19 | 显示全部楼层 |阅读模式
老杨团队,追求完美;客户至上,服务到位!
共同学习提高PLC CNC 维修水平,请大家踊跃发言
鲜花(0) 鸡蛋(0)
 楼主| 发表于 2009-2-7 22:26 | 显示全部楼层
我会陆续发表一些fanuc16/18 ,simens840的一些维修经验,有感兴趣的朋友可以讨论一下
大型搬家
鲜花(1) 鸡蛋(0)
发表于 2009-2-7 22:35 | 显示全部楼层

回复 沙发 的帖子

好贴,不顶不行!
鲜花(0) 鸡蛋(0)
发表于 2009-2-7 22:37 | 显示全部楼层
老杨团队 追求完美
原帖由 korg707 于 2009-2-7 22:19 发表
0 H7 }9 u) I- D' y& A共同学习提高PLC CNC 维修水平,请大家踊跃发言
( d* j, Y1 L& }
期待中...............
鲜花(0) 鸡蛋(0)
发表于 2009-2-7 23:10 | 显示全部楼层
鲜花(0) 鸡蛋(0)
发表于 2009-2-7 23:53 | 显示全部楼层
Waitting...........
鲜花(0) 鸡蛋(0)
 楼主| 发表于 2009-2-8 02:04 | 显示全部楼层

NC程序中PLC信号的读取方法(simens840d)

老杨团队,追求完美;客户至上,服务到位!
NC程序中,很多时候为了安全的考虑,NC程序需要快速直接从PLC中读取信号。在SIEMENS 840D系统中,能够实现NC与PLC之间数据直接交换的方式很多,现介绍EX-CELL-O XS321机床中应用的方法一:
* C0 ^! H7 Y: c& @- _7 C( I7 s1应用形式+ U* J1 d) q* T; s8 r* U
在XS321机床的换刀程序中(WZ_BELADEN.SPF),我们会看到如下的NC程序,
5 C+ [) i& G& V, F4 ~# a9 V. t“N460 WHENEVER $A_IN[34]==FALSE DO $AC_OVR=0”
1 y, F1 j3 q, i从这句程序的大体意思中可以看出,此句程序将变量$A_IN[34]的值作为判定条件,根据条件是否满足来选择往下继续执行。% n" R, E4 r3 L! ~% _2 I
程序的大体意思我们可以读懂,但是很多人可能要疑虑$A_IN[34]到底是做什么用的呢?其实$A_IN[34]是NC程序中,直接用来读取PLC数据的变量。$A_IN[n]用来读取PLC的信号(有的时候是直接读取外部I信号,而不需要经过PLC);$A_OUT[n]用来向PLC输出信号(有的时候是直接写给外部O信号,而不需要经过PLC)。' \3 H" @( a8 d3 j: a- T0 T
2信号详述- Z: G, K% d- H1 e, I
那么这些变量与PLC数据之间又有什么对照关系呢?其实3 m3 f! b0 G* K
/ _, x, i0 d1 W* g  a; p4 G
9 L% q- R: t* o. {
$A_IN[34]对应着PLC中的DB10.DBX129.1,其总用就是用来直接读取PLC中DB10.DBX129.1的值。顺着这个关系我们继续往里深入。在PLC程序中(FC167 NETWORK32)可以看到如下程序:
( h# S, _/ B: P8 u: U0 a4 ^O M 121.48 m9 R' Z/ N4 i
O& H" c6 u# a2 _- |3 ]* R# H. i
A "m_AUTOCYCL" //M82.2 OPERATION MODE AUTOMATIC FOLLOW.SET
3 T1 g2 d0 ?% C, s- MA M 121.3
% M. A  y& T' `= "DB_SIEM_NCK".A_Set_Inp34 //SET DIGI.NCK INPUT 34.
. z) s! D/ E) Y% L1 F继续向前查找M121.4与M121.3我们可以知道,这两个信号换刀门打开的信号,都是来自于外部的输入I72.7。这样,我们就可以理解为什么NC程序中为什么要用到$A_IN[34]变量了。通过读取PLC中DB10.DBX129.1的值,来判断换刀门是否打开,如果已经打开,才能继续执行换刀的过程。: _7 W" S- l1 N( \- E* e; q
3信号对照表
" R4 A4 _) P% _& D( `& J+ f除了$A_IN[34]外,在NC程序中,还用到了很多这种直接读取的变量,这些变量与PLC中数据的对照关系如下:6 _7 X9 v! D; y. Y5 V3 W6 @  T
NC变量
0 H1 \! w9 I. x/ O7 }PLC地址
& S/ X+ e1 k+ o6 X. T1 A  UNC变量0 I; W: B4 |; a0 \
PLC地址. B; S( w. X# N# n' N" t9 R8 G
$A_IN[9]" X9 ?. ~7 ^- Y/ q1 c" Y0 l
DB10.DBX123.0
8 }* ?8 x9 R9 r( ]  s+ ^$A_OUT[9]. V. z. ]3 }: H
DB10.DBX190.0
6 f) x& E  y3 f, {# U0 V9 j$A_IN[10]
- f6 [4 G) ]2 O: _1 N2 gDB10.DBX123.1
; ]: l. A5 z0 Y$A_OUT[10]
' Z8 n/ p3 G0 x+ n; _1 X9 \% hDB10.DBX190.1; S+ }9 p5 y& G
$A_IN[11]
* {1 r. f6 [1 @: W5 Z  o  XDB10.DBX123.2( j+ i6 b2 V3 {! a
$A_OUT[11]; Z5 l6 b  d& G' V- P/ E7 V
DB10.DBX190.2
, X, Q$ o+ Z( Q. O$A_IN[12]
# N  ?+ P+ D& j, X2 ADB10.DBX123.3$ h* _6 J" u, a2 ]( a2 g, E3 Y
$A_OUT[12]+ }1 t( ^& G$ n$ Z$ @4 R
DB10.DBX190.3" n2 T( L' N, U; m
$A_IN[13]
; j, C, N. V, ~; n. zDB10.DBX123.4
  O4 P, R1 ]. j+ u4 g1 n. }$A_OUT[13]
8 [4 _: k. q$ PDB10.DBX190.4; S- \3 Z& B2 o' y3 n( c
$A_IN[14]
9 W& S/ ~1 Z  B  a5 EDB10.DBX123.5
1 e8 ~( X) L$ G& L" e' c$A_OUT[14]$ n) m" _( _0 D
DB10.DBX190.5$ J- u# t: z9 i' j$ x8 e
$A_IN[15]
; V1 h. ]9 \4 [! ~( ~DB10.DBX123.6
! E( z6 o- |) g" @2 e& a; F$ ~$A_OUT[15]5 e. R/ @. e" x+ C) o$ h
DB10.DBX190.6+ A; a9 \3 H8 i  a; s( F$ o0 Q2 f
$A_IN[16]" C+ ~8 L  ^" m6 ]. F9 Q
DB10.DBX123.7
8 Z. j, W2 O' r" {' ^$A_OUT[16]- }6 c; o* |$ d0 Z4 F! S
DB10.DBX190.7+ v% c( k; D% T/ _/ R5 C
$A_IN[17]9 J: u+ G7 A6 Y& R
DB10.DBX125.0
% c8 T* q% B5 G' h/ M$A_OUT[17]' c9 ]4 B: ~9 g/ |6 `6 E- q
DB10.DBX191.0/ i1 o' z  \& ]  u. G1 T4 f8 W9 e
$A_IN[18], D$ w+ ?; W4 g& f& J
DB10.DBX125.18 e) [9 l! R2 U$ i* ~+ q( Y2 `0 J6 |
$A_OUT[18]9 O+ h4 ?7 F; x6 N8 t
DB10.DBX191.1  j' D. F4 S6 k/ K
$A_IN[19]
# D( g2 r7 Q8 C" UDB10.DBX125.2% e' e" e$ o, M% s% m! n
$A_OUT[19]( ?7 [6 z! Q; j- x
DB10.DBX191.2' J, f1 v: k9 P& h) G* ]$ X- e
$A_IN[20]' ?0 j; v% J  f; B* z7 \, }
DB10.DBX125.3$ w9 ~/ @* |' m2 P, o4 m! R+ \
$A_OUT[20]) c  A7 `5 N8 E4 O0 s  d
DB10.DBX191.3
+ p; T7 y1 p% ?/ _$A_IN[21]+ O- Y8 ^4 X  G5 `0 k, m
DB10.DBX125.4% |0 P& ?- p$ L# o8 H7 ~: _
$A_OUT[21]; E# }/ Y+ W$ M% n8 k
DB10.DBX191.4
+ v1 ?3 Q! P/ [+ X  g" g) N$A_IN[22]
# @/ J! N( Q/ O; }% n" VDB10.DBX125.5+ Q2 Q( S# D) |2 I& m1 U2 O
$A_OUT[22]/ F3 u% o0 P# n: o6 n
DB10.DBX191.5
3 o0 F4 L0 o% u5 }  ?$A_IN[23]9 K5 d' }. v5 f
DB10.DBX125.6
" B- L6 ?8 I, H5 l) m$A_OUT[23]; o# ?. C$ k2 E2 c8 x
DB10.DBX191.6( g( O& ^! x( Y- U( o3 w
梁景利 第 2 页 2007-1-3
/ }: B: m2 B  U格物致知 KEEP STUDYING
. S6 C4 m1 z' ~! {; p$A_IN[24]$ j# c/ Q0 C1 T( M6 W
DB10.DBX125.72 G) H2 f+ X4 x: \9 U, M) ?. U
$A_OUT[24]- }0 c& ], R" `& l2 e
DB10.DBX191.7
4 n; E/ f' x, W2 n1 }5 V/ J! D0 i$A_IN[25]
% Z: h" L( J) m. R0 hDB10.DBX127.0$ b. H$ Q: v% @
$A_OUT[25]
$ _, B# M; W6 s% \% C( E6 ?" IDB10.DBX192.0" m8 H4 j! a8 ?: b+ k/ Z+ L
$A_IN[26]) Y  s5 X) _9 f! \5 ?
DB10.DBX127.1! T" N5 m  L: G, g9 u
$A_OUT[26]
! b4 D: o3 L, I) z) KDB10.DBX192.1
' d; p, |3 Q6 G) B+ ~, p/ e. F+ I$A_IN[27]
' Z$ l( M  q: W% g( n$ G9 fDB10.DBX127.22 T/ d9 T. M+ M8 L' r7 U0 E2 |
$A_OUT[27]7 A+ w; L# L6 ^* F4 Q2 g
DB10.DBX192.2
0 j6 e$ N1 m5 u; @* n6 P$A_IN[28]
, l1 y7 ^! O" E4 e4 v  P  e' HDB10.DBX127.3# g0 J* ~" D. N
$A_OUT[28]
! v) h" K1 H& z5 F" d: S& j7 D1 UDB10.DBX192.3
0 R6 D' S- ^4 E/ Q$A_IN[29]
1 S6 @+ m& ]4 q4 h5 yDB10.DBX127.4
& ?/ g% i4 G1 b) x8 {. @$A_OUT[29]
4 D2 Z8 {7 P; E( ~DB10.DBX192.43 `; e% P8 s  k8 d
$A_IN[30]
6 p/ x! C4 J4 E' _3 r! cDB10.DBX127.55 P3 K; I9 x  f3 U6 u- x
$A_OUT[30]$ L3 Q- ]" j8 g5 X" g, A# c
DB10.DBX192.5( {2 Y( |* N$ R) j4 t8 |
$A_IN[31]
0 c/ A3 U2 O) a& \) ]DB10.DBX127.68 n4 W5 Y' K) N% s# F- U9 _
$A_OUT[31]
1 `2 t9 l" |6 d- f: BDB10.DBX192.6
9 Y5 s" z1 M- h: S# C$A_IN[32]
: m. M3 z! |2 b* e0 [' r% VDB10.DBX127.79 C8 e$ ^& d! x/ ]5 L* ^
$A_OUT[32]
) H' I- T' r. V* O% G# ]DB10.DBX192.7
8 R, e! }- {2 l" K$A_IN[33]
; ?) |/ d2 G2 d% ODB10.DBX129.0
" @3 S3 E' M2 o$A_OUT[33]
8 ~5 H( Z1 J; H3 ^# {- y- ]DB10.DBX193.0
! c# \( d0 D. H5 h$A_IN[34]
$ n+ c! ^8 y: H- {$ b& }3 uDB10.DBX129.16 D9 D% ^! t* t- o; K* _0 W4 W
$A_OUT[34]
6 f+ q4 b: p7 D% n3 s' a. ~DB10.DBX193.1
# {5 t. x& ?- v3 \$A_IN[35]% Y: r* I3 o! K( [, S
DB10.DBX129.2( _+ e+ K4 Y& d3 }5 n- h& e1 s/ o4 o
$A_OUT[35]
1 f% T* {. Z- N  p; TDB10.DBX193.2% t; L8 V2 v0 J( X
$A_IN[36]
/ q3 ^& e( j+ s& U' G: fDB10.DBX129.3) ?5 H/ O4 Z  \
$A_OUT[36]
$ G  v/ i% f" K9 ^DB10.DBX193.3# t7 r, A* Z# }8 Y9 [
$A_IN[37]
) W% z% r7 Y( SDB10.DBX129.4) I% }  o! ~$ I1 F; Z% c* g
$A_OUT[37]
/ i1 N! @8 D6 J! g4 }# Y9 F! A, c4 m* vDB10.DBX193.4
! h9 m' X' _2 c' R/ S$A_IN[38]- P( i8 U5 w" g% i; a
DB10.DBX129.5& E/ h; I1 _9 K; k1 }3 S
$A_OUT[38]
9 }! B5 H$ y$ sDB10.DBX193.5
1 }/ R# x7 m# S& g9 c0 d0 D+ |$A_IN[39]( F( w8 w; q. |2 n/ p
DB10.DBX129.6
! r5 N, X' K/ L6 L8 a3 |, Q# T$A_OUT[39]4 n$ I/ {7 w, A# I+ W  O  b
DB10.DBX193.6
; z9 p, N0 G; k5 u* ?" x& V$A_IN[40]
. n% i: F% ^7 N8 l: @DB10.DBX129.7
9 f" ^# b4 q2 v) Z. V$A_OUT[40]
- f+ X  A* |; k. v  \& xDB10.DBX193.72 j4 r- M9 l) R% {: W
对照此表,找到对应的PLC中的点,这样,能够读懂PLC程序便可以知道这些变量的具体含义,对于NC程序,也可以有更深刻的理解。
鲜花(22) 鸡蛋(0)
发表于 2009-2-8 10:43 | 显示全部楼层
天书,不懂. PLC我会,CNC白痴.我是搞高压的.
鲜花(1) 鸡蛋(0)
发表于 2009-2-8 10:48 | 显示全部楼层
老杨团队,追求完美;客户至上,服务到位!
顶,看过lz的另一贴,好帖,cnc系统听说过,但没这方面经验看不太懂.SIEMENS 840D等是不是机床的数控系统.?另外一个问题,NC程序看起来不象plc程序,它存储在哪? 和PLC是怎样连接的? 谢谢,期待继续.....
鲜花(0) 鸡蛋(0)
 楼主| 发表于 2009-2-8 17:28 | 显示全部楼层
老杨团队,追求完美;客户至上,服务到位!
原帖由 shenyang-china 于 2009-2-8 10:48 发表 ; H& c7 y, x4 d: t1 _
顶,看过lz的另一贴,好帖,cnc系统听说过,但没这方面经验看不太懂.SIEMENS 840D等是不是机床的数控系统.?另外一个问题,NC程序看起来不象plc程序,它存储在哪? 和PLC是怎样连接的? 谢谢,期待继续.....

! ^: h6 i$ U% A: R0 r: j* rcnc的概念我就不多讲了,大家可以在网上看,simes840d是现在较为流行的一种数控系统,很多加工厂在用,包括GM在内.如果你想维修cnc前提是你必须要会plc,现在的plc功能比较强大,形式多样化,日系和德系有很大区别.simens840d系统集成了s7-300PLC,cnc里的plc主要用于和外围的输入输出部件联系,例如传感器.电磁阀等,有时也用于定位系统,也就是不进行插补运算的轴的运动,例如刀库轴.840d的加工程序有时要访问plc,具体在前面已经说了,还有就是要学习一下profibus bus system .
鲜花(1) 鸡蛋(0)
发表于 2009-2-8 20:52 | 显示全部楼层
Thank you. NC的程序是PLC的程序吗?
' [0 Z2 E5 D1 \" y7 R  S另外,在这里如果做这种PLC,cnc的工作,英语无法交流的话,我想肯定是不行的.不知道工艺流程,怎么编程呢.我觉得专业和经验对lz来说不是问题,如果英语好一切就ok了.
- s! j, ^+ V3 ?9 p( H- k本人在国内做plc HMI的,来之前在BBA(宝马工厂)工作两年,之前的公司是AB东北区的核心分销商.但英语说不明白,真不敢找专业工作.如果你英语好,早点来吧,给我们公司修机床电工薪水相当的好..
鲜花(0) 鸡蛋(0)
 楼主| 发表于 2009-2-8 21:52 | 显示全部楼层
原帖由 shenyang-china 于 2009-2-8 20:52 发表 & a' ~- U( l" `: s
Thank you. NC的程序是PLC的程序吗?
' O% m3 X. C6 H+ `  l+ x另外,在这里如果做这种PLC,cnc的工作,英语无法交流的话,我想肯定是不行的.不知道工艺流程,怎么编程呢.我觉得专业和经验对lz来说不是问题,如果英语好一切就ok了.  ^' R  `+ `3 d1 J, x
本人在国内做pl ...
4 i/ P* r! b' m9 T
nc程序是一种根据加工工艺所编写的程序,是根据系统本身提供的编程指令来编写,所以不同的系统是有差别的,而plc是根据机床外围的需要来编写(在cnc 中plc是由机床厂家编写好的,一般不允许改动)例如M3s2000这句加工程序,m3是主轴正转,s2000指的是转速,m3会被plc译码(fanuc system) simens则不需要,它有固定的地址(DBDnn.DBXnn),数控维修必须要有专业阅读能力(看专业资料)口语好用处不大(本人看法)
鲜花(1) 鸡蛋(0)
发表于 2009-2-8 22:27 | 显示全部楼层
同言同羽 置业良晨
thank you. 也许我有点理解了.plc 所做的是机床的所具控制的功能,也许轴的控制和定位的控制,各种电气的控制,nc则是用户自己编写的加工零件的程序,先做外径在做内径之类的吧.nc是在控制面板之类人机界面做的吧,并且下载的位置也是这种人机界面吧. 
0 e1 i5 C0 g# q; o! nI guess, thank you.
理袁律师事务所
鲜花(0) 鸡蛋(0)
 楼主| 发表于 2009-2-9 02:13 | 显示全部楼层
老杨团队,追求完美;客户至上,服务到位!
当各轴需要进行插补运算的时候 那么这时候是nc控制的(如加工),当各轴只是去定位(如换刀)这时候会自动切换到plc控制.加工程序和plc都可以在hmi做,但是很多时候plc的修改是需要权限的 如simens840d  加工程序编好后存放在mmc,用的时候被nc调用,加工程序不需要维修电工,而是有工艺方面的人员编写,但电工最好也要知道点,这样有利于维修.
鲜花(0) 鸡蛋(0)
 楼主| 发表于 2009-2-10 06:48 | 显示全部楼层
数 控 系 统 原 理7 }, z. I3 \' T9 K4 ~
Cnc        
) ^7 i: C6 P" J( R/ c
" g  [# g! s; Z! x4 x% V数控技术是指用数字、文字和符号组成的数字指令来实现一台或多台机械设备动作控制的技术。它所控制的通常是位置、角度、速度等机械量和与机械能量流向有关的开关量。数控的产生依赖于数据载体和二进制形式数据运算的出现。1908年,穿孔的金属薄片互换式数据载体问世;19世纪末,以纸为数据载体并具有辅助功能的控制系统被发明;1938年,香农在美国麻省理工学院进行了数据快速运算和传输,奠定了现代计算机,包括计算机数字控制系统的基础。数控技术是与机床控制密切结合发展起来的。1952年,第一台数控机床问世,成为世界机械工业史上一件划时代的事件,推动了自动化的发展。
7 c1 F( p: E/ ]1 V! v% I+ f现在,数控技术也叫计算机数控技术,目前它是采用计算机实现数字程序控制的技术。这种技术用计算机按事先存贮的控制程序来执行对设备的控制功能。由于采用计算机替代原先用硬件逻辑电路组成的数控装置,使输入数据的存贮、处理、运算、逻辑判断等各种控制机能的实现,均可通过计算机软件来完成。
$ W+ Q$ Z. B3 Q; ~/ {4 s0 e! g数控系统(cnc)是一个概念,主要指的是用数字量控制的运动系统,主要是相对于其前的模拟量的控制系统,数控系统的好处在于数字量的处理标准化,远程控制,可通讯,精确度高,可控性好。
; W1 V* A& N$ Z7 _5 J  E如果把数控机床比作为一个人的话,那么数控机床的大脑就他的数控系统NC,床身是他的身体,运动的各个轴和伺服电机就是他的胳膊和腿,正如人的腿和手一样,人的手和腿上有神经,所以人知道自己的位置,而机床的神经就是位置开关、接近开关、编码器、光栅尺等。
; m/ X0 B+ {( }- `/ E以siemens的840D为例,主要有以下几个部分:上位电脑、下位NC。上位电脑的作用是建立一个人和下位nc通讯的平台,在机床正常工作的时候,只有下位nc在工作,上位电脑关掉都无所谓,只有当你想查看下位nc的内容和做修改时才有用,上位电脑就是一部改装的pc,安装了修改过的winxp系统,siemens在里面安装了很多的通讯芯片,所以这部电脑支持其它的通讯协议,比如:mpi\profibus等。
3 j# S4 T: t% @* G4 [5 V5 x7 a! e下位nc安装在一个大盒子里,在这个大盒子里,还有其它部分:电源模块、驱动板、控制板,集成的plc也在这面,电源模块负责供电,为母线提供600v的直流电压,送给驱动板,这也是伺服电机的主要能源,nc主要负责计算,比如差补运算等,nc上开放了mpi接口和profibus等接口,可以直接接pg,进行编程或是通讯。3 V9 T; T- e" I5 b  X, A2 t  Y' O$ [
控制板接受nc计算出来的数据,再经过本身的算法运算,比如pid运算,然后将数据传给驱动板,控制板上留有编码器的接口和光栅尺的接口,用于接收伺服电机的编码器的反馈信号和光栅尺的位置信号,构成闭环控制系统,这只是比较大的环,在控制板的内部还有电流控制环等闭环,驱动板的作用主要是变频、直流变交流的逆变等,驱动板的大小决定于带的电机的容量,所以大小不等,驱动板的下端接三相电机。
  w8 r! |8 P4 ?: {: J数控系统的软件控制:所有的数控系统都需要有一个操作系统,fanuc的系统是自己研发的独立的系统,还有的是使用嵌入式linux,840d使用的是微软公司的kernel更换后的winxp,经过更改后的核心更适用于工业控制。) P# |% {3 `, M, `3 W1 m2 B
公司进口的excello机床所用的人机界面是siemens的hmi,在这个界面上,可以显示机床的各种参数和数据,包括当前的轴的坐标,各个传感器的状态,压力的数据,同时可以通过此界面对机床进行设置,可以说这就是机床面向人的一个窗口。
$ _- _: P" D7 L+ j3 b/ D2 m伺服驱动系统(Servo System)简称伺服系统,是一种以机械位置或角度作为控制对象的自动控制系统,例如数控机床等。使用在伺服系统中的驱动电机要求具有响应速度快、定位准确、转动惯量较大等特点,这类专用的电机称为伺服电机。当然,其基本工作原理和普通的交直流电机没有什么不同。该类电机的专用驱动单元称为伺服驱动单元,有时简称为伺服,一般其内部包括电流、速度和/或位置闭环。8 A. B8 U8 x/ P
数控系统的编程,在确定了工艺方案后,就需要根据零件的几何尺寸、加工路线等,计算刀具中心运动轨迹,以获得刀位数据。数控系统一般均具有直线插补与圆弧插补功能,对于加工由圆弧和直线组成的较简单的平面零件,只需要计算出零件轮廓上相邻几何元素交点或切点的坐标值,得出各几何元素的起点、终点、圆弧的圆心坐标值等,就能满足编程要求。当零件的几何形状与控制系统的插补功能不一致时,就需要进行较复杂的数值计算,一般需要使用计算机辅助计算,否则难以完成。
鲜花(0) 鸡蛋(0)
 楼主| 发表于 2009-2-10 07:05 | 显示全部楼层
原帖由 shenyang-china 于 2009-2-8 20:52 发表
( z1 |: e8 k3 J; RThank you. NC的程序是PLC的程序吗?
; {8 `- Y4 N8 a) T另外,在这里如果做这种PLC,cnc的工作,英语无法交流的话,我想肯定是不行的.不知道工艺流程,怎么编程呢.我觉得专业和经验对lz来说不是问题,如果英语好一切就ok了.
. Y  t3 g6 e" `4 U- U; A4 t. u本人在国内做pl ...
7 }- I# d" t7 ^3 N' @0 ~9 ^$ ^; D
如果有需要请加QQ:1013264819
鲜花(1) 鸡蛋(0)
发表于 2009-2-10 11:01 | 显示全部楼层
同言同羽 置业良晨
Thank you. 我没有QQ,我的MSN ywbsuper@hotmail.com.来Edmonton一年多了,在siemens培训过driver 产品,440,master driver 等,应用过siemens AB的plc做过项目,多交流.
6 M) H  P; t: |9 C9 ~' k如果你能用英语写出这些东西,那哥们早点来吧,这里别的我没觉的什么好,空气绝对的新鲜,在国内我一周洗一次车,这里,下天我根本就不用洗车,就冬天洗了三次.
# \* s2 G7 t. S% C2 @1 J做这种编成,和维修技术的工作,不说话或少说话是不可能的(在国内我是经常和操作人员交流,了解工艺和客户需求),不过真可以考虑先做电工,从简单的技术做起,在提高语言方面,也是个途径.好了,有事发邮件.- x. Z) }( e1 }; S7 A& [
"N460 WHENEVER $A_IN[34]==FALSE DO $AC_OVR=0",这不是个plc语句吧,cnc系统中,除了plc,还有其它存储控制程序的地方吗?
鲜花(0) 鸡蛋(0)
 楼主| 发表于 2009-2-11 03:25 | 显示全部楼层
原帖由 shenyang-china 于 2009-2-10 11:01 发表 + D$ ^- t( k' w0 q% b
Thank you. 我没有QQ,我的MSN ywbsuper@hotmail.com.来Edmonton一年多了,在siemens培训过driver 产品,440,master driver 等,应用过siemens AB的plc做过项目,多交流.' G4 s9 I5 D9 E
如果你能用英语写出这些东西,那哥们早点来吧,这里 ...

6 e& W; R/ K# {6 n8 j8 G是加工程序,cnc有很多参数分别存放在rom(os plc图形等) ram(plc参数T C K D的值,nc参数.加工参数等)ram 需要用电池后备.我已经给发邮件了
鲜花(0) 鸡蛋(0)
 楼主| 发表于 2009-2-12 03:22 | 显示全部楼层

西门子间接寻址

  7 _2 B6 D% W1 Q
 完整的一条指令,应该包含指令符+操作数(当然不包括那些单指令,比如NOT等)。其中的操作数是指令要执行的目标,也就是指令要进行操作的地址。
7 G5 c' ]1 W1 G% i! C% j  我们知道,在PLC中划有各种用途的存储区,比如物理输入输出区P、映像输入区I、映像输出区Q、位存储区M、定时器T、计数器C、数据区DB和L等,同时我们还知道,每个区域可以用位(BIT)、字节(BYTE)、字(WORD)、双字(DWORD)来衡量,或者说来指定确切的大小。当然定时器T、计数器C不存在这种衡量体制,它们仅用位来衡量。由此我们可以得到,要描述一个地址,至少应该包含两个要素:
( V9 k+ m$ r* F+ |  1、存储的区域
2 w! M- S2 X; t* ]+ r  2、这个区域中具体的位置3 P* V5 i  \4 l; y, x
  比如:A Q2.0
7 _' E7 B' l& n+ v0 m% o  R  其中的A是指令符,Q2.0是A的操作数,也就是地址。这个地址由两部分组成:( D2 W7 W4 d; m% k# a' N
  Q:指的是映像输出区) K0 K; X, p$ ^' K5 e) ]
  2.0:就是这个映像输出区第二个字节的第0位。
6 o6 N! S1 f9 @/ V. l/ y0 }  由此,我们得出, 一个确切的地址组成应该是:
& o+ Q0 G/ e& I  〖存储区符〗〖存储区尺寸符〗〖尺寸数值〗.〖位数值〗,例如:DBX200.0。
9 e$ l7 ?$ G* E3 T   DB X 200 . 0
6 @1 I0 H2 i* P* B; K$ Y, G  其中,我们又把〖存储区符〗〖存储区尺寸符〗这两个部分合称为:地址标识符。这样,一个确切的地址组成,又可以写成:
, P. W$ {/ S. a7 Y  地址标识符 + 确切的数值单元
9 [5 c, }8 b- Q1 P, t2 R) Q  【间接寻址的概念】
* {7 j1 b4 r, s3 X9 r# ^  寻址,就是指定指令要进行操作的地址。给定指令操作的地址方法,就是寻址方法。
6 Y2 u/ S+ L6 ^5 M2 U" g  在谈间接寻址之前,我们简单的了解一下直接寻址。所谓直接寻址,简单的说,就是直接给出指令的确切操作数,象上面所说的,A Q2.0,就是直接寻址,对于A这个指令来说,Q2.0就是它要进行操作的地址。% N' n; P/ {) K6 S& ]4 s5 X
  这样看来,间接寻址就是间接的给出指令的确切操作数。对,就是这个概念。3 U+ a' Z6 L. c0 w# N3 ~6 }: g
  比如:A Q[MD100] ,A T[DBW100]。程序语句中用方刮号 [ ] 标明的内容,间接的指明了指令要进行的地址,这两个语句中的MD100和DBW100称为指针Pointer,它指向它们其中包含的数值,才是指令真正要执行的地址区域的确切位置。间接由此得名。
# L8 M0 {8 c$ D9 J' S0 e/ u5 ^6 @  西门子的间接寻址方式计有两大类型:存储器间接寻址和寄存器间接寻址。
, l0 q/ N- I  o  ^) e. u  【存储器间接寻址】
) n9 m; E7 X1 B; Y- h  w+ n  存储器间接寻址的地址给定格式是:地址标识符+指针。指针所指示存储单元中所包含的数值,就是地址的确切数值单元。
. }/ }5 M' `. ]* L; W  存储器间接寻址具有两个指针格式:单字和双字。0 a4 k; j' r' Q: z, z+ a& ^* \
  单字指针是一个16bit的结构,从0-15bit,指示一个从0-65535的数值,这个数值就是被寻址的存储区域的编号。+ f% l" b/ F* S2 p! R, v) U
  双字指针是一个32bit的结构,从0-2bit,共三位,按照8进制指示被寻址的位编号,也就是0-7;而从3-18bit,共16位,指示一个从0-65535的数值,这个数值就是被寻址的字节编号。, x1 ^* E$ q# p8 U$ E! H# ]4 V) m
  指针可以存放在M、DI、DB和L区域中,也就是说,可以用这些区域的内容来做指针。
/ Q, ~1 e2 M2 C( C5 y  ^  单字指针和双字指针在使用上有很大区别。下面举例说明:
  k6 A4 \0 w! o4 o4 x  L DW#16#35 //将32位16进制数35存入ACC1
3 G; k( ?# m' H% U* A* J  T MD2 //这个值再存入MD2,这是个32位的位存储区域
4 D* }: Z& L5 {- l  L +10 //将16位整数10存入ACC1,32位16进制数35自动移动到ACC2
$ C3 X6 F" C6 m2 s. H  T MW100 //这个值再存入MW100,这是个16位的位存储区域4 e! f4 J4 {2 {8 O5 ~4 R
  OPN DBW[MW100] //打开DBW10。这里的[MW100]就是个单字指针,存放指针的区域是M区,
, F. `+ I6 j3 l- Q# a' N, W% d; [- i   MW100中的值10,就是指针间接指定的地址,它是个16位的值!
& M7 G4 k$ P5 ]" N! {1 f  --------2 Q' i/ q; k- N& Q% t0 ]. l5 \* N, Z5 {
  L L#+10 //以32位形式,把10放入ACC1,此时,ACC2中的内容为:16位整数101 W4 b4 R7 X+ R
  T MD104 //这个值再存入MD104,这是个32位的位存储区域
; v) E/ J3 @3 w% L! v* J  A I[MD104] //对I1.2进行与逻辑操作!% T0 E$ R7 o( d: X5 f( B
  =DIX[MD2] //赋值背景数据位DIX6.5!# o9 z6 J  Z. s
  --------
  Q5 o/ {8 H8 W1 {7 W  A DB[MW100].DBX[MD2] //读入DB10.DBX6.5数据位状态$ Y' F" M$ q7 `/ t; E- [
  =Q[MD2] //赋值给Q6.5/ T; L- z# A8 `6 j) V. r1 N9 O1 y& Z
  --------
- _+ V/ E7 o; L0 Z# {4 u  A DB[MW100].DBX[MD2] //读入DB10.DBX6.5数据位状态/ ]' c. {: z: q  W, T
  =Q[MW100] //错误!!没有Q10这个元件
+ R+ L1 m' r" @7 j  ---------------------------------------------------------------------------------------------------* D0 m8 e/ F4 L7 v
  从上面系列举例我们至少看出来一点:( K- p8 R8 H8 v) I0 p' R
  单字指针只应用在地址标识符是非位的情况下。的确,单字指针前面描述过,它确定的数值是0-65535,而对于byte.bit这种具体位结构来说,只能用双字指针。这是它们的第一个区别,单字指针的另外一个限制就是,它只能对T、C、DB、FC和FB进行寻址,通俗地说,单字指针只可以用来指代这些存储区域的编号。) i/ X- q/ {9 h
  相对于单字指针,双字指针就没有这样的限制,它不仅可以对位地址进行寻址,还可以对BYTE、WORD、DWORD寻址,并且没有区域的限制。不过,有得必有失,在对非位的区域进行寻址时,必须确保其0-2bit为全0!
, _. U4 f" w' a$ p0 p+ ?  总结一下:; O# }  z5 j5 I' i
  单字指针的存储器间接寻址只能用在地址标识符是非位的场合;双字指针由于有位格式存在,所以对地址标识符没有限制。也正是由于双字指针是一个具有位的指针,因此,当对字节、字或者双字存储区地址进行寻址时,必须确保双字指针的内容是8或者8的倍数。
  T6 A' S% {4 W, Z  现在,我们来分析一下上述例子中的A I[MD104] 为什么最后是对I1.2进行与逻辑操作。& a" Z( x1 T& I* m3 q" p( t" {
  通过L L#+10 ,我们知道存放在MD104中的值应该是:7 z' R! N( g! K2 W% ]
  MD104:0000 0000 0000 0000 0000 0000 0000 1010
6 x9 ~$ {* N3 e3 Z# W0 W  当作为双字指针时,就应该按照3-18bit指定byte,0-2bit指定bit来确定最终指令要操作的地址,因此:
: Z' [1 N) R$ @, P  0000 0000 0000 0000 0000 0000 0000 1010 = 1.2
4 w+ Q# i( O9 h% Z  详解西门子间接寻址<2>
( P- ?: E$ z" `, O( W3 o, v  【地址寄存器间接寻址】$ f5 d" u. Q: H. @
  在先前所说的存储器间接寻址中,间接指针用M、DB、DI和L直接指定,就是说,指针指向的存储区内容就是指令要执行的确切地址数值单元。但在寄存器间接寻址中,指令要执行的确切地址数值单元,并非寄存器指向的存储区内容,也就是说,寄存器本身也是间接的指向真正的地址数值单元。从寄存器到得出真正的地址数值单元,西门子提供了两种途径:2 ^9 f' W0 z7 N' {8 c
  1、区域内寄存器间接寻址$ e; G# I6 n4 z! S9 T! R
  2、区域间寄存器间接寻址
+ _1 U; ]  _" T6 S9 F% g7 F  地址寄存器间接寻址的一般格式是:
# I2 ~2 E' B- c9 G% J! W7 E& w  〖地址标识符〗〖寄存器,P#byte.bit〗,比如:DIX[AR1,P#1.5] 或 M[AR1,P#0.0] 。
$ {" X0 O0 o) j  〖寄存器,P#byte.bit〗统称为:寄存器寻址指针,而〖地址标识符〗在上帖中谈过,它包含〖存储区符〗+〖存储区尺寸符〗。但在这里,情况有所变化。比较一下刚才的例子:2 ]/ j+ @% [, A9 Z
  DIX [AR1,P#1.5] - `. }6 m9 Z$ c% n4 |5 U% A1 t
  X [AR1,P#1.5]
# y" n2 f, O& [3 z. Q1 y3 Y  DIX可以认为是我们通常定义的地址标识符,DI是背景数据块存储区域,X是这个存储区域的尺寸符,指的是背景数据块中的位。但下面一个示例中的M呢?X只是指定了存储区域的尺寸符,那么存储区域符在哪里呢?毫无疑问,在AR1中!/ s3 a1 b% S5 @' W
  DIX [AR1,P#1.5] 这个例子,要寻址的地址区域事先已经确定,AR1可以改变的只是这个区域内的确切地址数值单元,所以我们称之为:区域内寄存器间接寻址方式,相应的,这里的[AR1,P#1.5] 就叫做区域内寻址指针。
: Z$ o$ x" U+ f# D6 G  X [AR1,P#1.5] 这个例子,要寻址的地址区域和确切的地址数值单元,都未事先确定,只是确定了存储大小,这就是意味着我们可以在不同的区域间的不同地址数值单元以给定的区域大小进行寻址,所以称之为:区域间寄存器间接寻址方式,相应的,这里的[AR1,P#1.5] 就叫做区域间寻址指针。$ y* a. P$ J5 }1 n( K
  既然有着区域内和区域间寻址之分,那么,同样的AR1中,就存有不同的内容,它们代表着不同的含义。
5 |+ D7 E# f, z7 L- w  【AR的格式】
* D0 N- l/ R3 ^: E; E) p6 x4 {  地址寄存器是专门用于寻址的一个特殊指针区域,西门子的地址寄存器共有两个:AR1和AR2,每个32位。7 i) j0 N" ~3 F* \
  当使用在区域内寄存器间接寻址中时,我们知道这时的AR中的内容只是指明数值单元,因此,区域内寄存器间接寻址时,寄存器中的内容等同于上帖中提及的存储器间接寻址中的双字指针,也就是:
5 E% Q  g5 A/ Y1 ?  其0-2bit,指定bit位,3-18bit指定byte字节。其第31bit固定为0。; }9 J" ?7 M* L! [8 o
  AR:6 Z8 r3 o! F/ c4 T
  0000 0000 0000 0BBB BBBB BBBB BBBB BXXX! s/ I( L3 N8 o
  这样规定,就意味着AR的取值只能是:0.0 ——65535.7  B2 E8 |/ {- k: @7 P8 h& Q) R0 q- h
  例如:当AR=D4(hex)=0000 0000 0000 0000 0000 0000 1101 0100(b),实际上就是等于26.4。
* ?( l' z; \" L4 V8 o& G  而在区域间寄存器间接寻址中,由于要寻址的区域也要在AR中指定,显然这时的AR中内容肯定于寄存器区域内间接寻址时,对AR内容的要求,或者说规定不同。; U5 P$ m  G3 b7 I, t
  AR:
- X: |( g6 G$ |3 e5 K( r; Z9 d  1000 0YYY 0000 0BBB BBBB BBBB BBBB BXXX7 Y6 ?4 a% `  D3 Z
  比较一下两种格式的不同,我们发现,这里的第31bit被固定为1,同时,第24、25、26位有了可以取值的范围。聪明的你,肯定可以联想到,这是用于指定存储区域的。对,bit24-26的取值确定了要寻址的区域,它的取值是这样定义的:
: a$ q% S% K! [% B  区域标识符
1 ?1 U7 C2 e7 e( m% W1 k  r" \  26、25、24位
' H. v" p- N) T  P(外部输入输出) 5 v$ g& i1 l( k+ D
  000
( d6 L! @6 v% |) N7 w) ?1 J  I(输入映像区) # O' ^8 d. d! l; N8 X+ e
  001
9 J* O0 w7 Q; V  Q(输出映像区)
. @$ X- ^" A7 F5 m5 c2 v  010
4 P2 b( }& ^. u  M(位存储区)
4 K7 B2 i7 e) [; q6 P3 ]  011
& V; [9 Z9 o" W( H  DB(数据块)
2 ~- ]: X( X/ t) ~' j: X% {  100 2 f$ M' M+ U, ~1 {5 I5 \- n
  DI(背景数据块) - S+ V" ^0 c  U; m! y+ D
  101
: P& L7 o2 ?5 S  a& h  L(暂存数据区,也叫局域数据)
& _' I" x6 ?- N2 C- v: f  111 ' d3 ~6 l) R) p, A7 h
  如果我们把这样的AR内容,用HEX表示的话,那么就有:5 Y* y' d5 `& H6 B, y2 f* ~6 A
  当是对P区域寻址时,AR=800xxxxx  i6 {9 ?% w6 p2 w+ I3 u2 c
  当是对I区域寻址时,AR=810xxxxx
3 Y( I% s# E* P  P  当是对Q区域寻址时,AR=820xxxxx
3 h7 T) D$ [# F0 r. P; K" U  当是对M区域寻址时,AR=830xxxxx; K" X" S7 o6 I# G3 L/ Z! z
  当是对DB区域寻址时,AR=840xxxxx$ V- L0 L, v5 X4 ~6 w, K( k
  当是对DI区域寻址时,AR=850xxxxx8 \; Z2 |+ l1 N. h/ w
  当是对L区域寻址时,AR=870xxxxx& N% h+ {* L! p4 t' x
  经过列举,我们有了初步的结论:如果AR中的内容是8开头,那么就一定是区域间寻址;如果要在DB区中进行寻址,只需在8后面跟上一个40。84000000-840FFFFF指明了要寻址的范围是:: [8 m4 M6 `; K+ c6 p
  DB区的0.0——65535.7。
* r. ?. A6 ^2 Y) h( N' g  例如:当AR=840000D4(hex)=1000 0100 0000 0000 0000 0000 1101 0100(b),实际上就是等于DBX26.4。
1 g! A3 y, X% ^8 e' R2 N% n  我们看到,在寄存器寻址指针 [AR1/2,P#byte.bit] 这种结构中,P#byte.bit又是什么呢?
$ P, x) U3 `8 Z( x0 U$ q* l  【P#指针】
9 i1 a' o- t; m/ N* V; R  P#中的P是Pointer,是个32位的直接指针。所谓的直接,是指P#中的#后面所跟的数值或者存储单元,是P直接给定的。这样P#XXX这种指针,就可以被用来在指令寻址中,作为一个“常数”来对待,这个“常数”可以包含或不包含存储区域。例如:
& W4 K3 I2 i2 @6 M9 D  u( n  ● L P#Q1.0 //把Q1.0这个指针存入ACC1,此时ACC1的内容=82000008(hex)=Q1.0+ l% {1 u5 W- j5 m# M0 o
  ★ L P#1.0 //把1.0这个指针存入ACC1,此时ACC1的内容=00000008(hex)=1.03 R- l3 s3 z0 H& F3 L. q1 e
  ● L P#MB100 //错误!必须按照byte.bit结构给定指针。2 l4 L. J# y) E/ Q7 x: Q% [- F
  ● L P#M100.0 //把M100.0这个指针存入ACC1,此时ACC1的内容=83000320(hex)=M100.0
- k. ^! Y' a( E8 B  ● L P#DB100.DBX26.4 //错误!DBX已经提供了存储区域,不能重复指定。
' Y* N7 I5 X! a) X/ b. b  ● L P#DBX26.4 //把DBX26.4这个指针存入ACC1,此时ACC1的内容=840000D4(hex)=DBX26.4; W. N- N* a& p- G! F9 g& v8 J; J$ v
  我们发现,当对P#只是指定数值时,累加器中的值和区域内寻址指针规定的格式相同(也和存储器间接寻址双字指针格式相同);而当对P#指定带有存储区域时,累加器中的内容和区域间寻址指针内容完全相同。事实上,把什么样的值传给AR,就决定了是以什么样的方式来进行寄存器间接寻址。在实际应用中,我们正是利用P#的这种特点,根据不同的需要,指定P#指针,然后,再传递给AR,以确定最终的寻址方式。
0 n( R5 l9 U9 q: H: N- a# O+ k  在寄存器寻址中,P#XXX作为寄存器AR指针的偏移量,用来和AR指针进行相加运算,运算的结果,才是指令真正要操作的确切地址数值单元!
6 ~7 @1 C8 g" h+ h, W  无论是区域内还是区域间寻址,地址所在的存储区域都有了指定,因此,这里的P#XXX只能指定纯粹的数值,如上面例子中的★。* [+ V2 _- B  c5 W: A) U
  【指针偏移运算法则】
! `& B, X6 Y$ l; W& x/ M6 j  在寄存器寻址指针 [AR1/2,P#byte.bit] 这种结构中,P#byte.bit如何参与运算,得出最终的地址呢?: c& x9 @) y/ X5 R
  运算的法则是:AR1和P#中的数值,按照BYTE位和BIT位分类相加。BIT位相加按八进制规则运算,而BYTE位相加,则按照十进制规则运算。
! A- I; A1 Y3 c1 ]6 H( P9 _: d  例如:寄存器寻址指针是:[AR1,P#2.6],我们分AR1=26.4和DBX26.4两种情况来分析。' x$ l. g: k. @. w
  当AR1等于26.4,
7 I1 f! X+ ~/ P8 r$ f- c6 [   AR1:26.2( _1 g7 S2 K4 R) r+ F- z# R' J1 ^
   + P#: 2.6/ _/ c0 b( r( d: D; N
   ---------------------------
  R3 b* B9 H& ?8 d# K# v, t3 O3 N   = 29.7 这是区域内寄存器间接寻址的最终确切地址数值单元
5 m, z' u& r6 l  当AR1等于DBX26.4,
8 c; R9 m- n) R2 p# b" p/ A/ @6 l   AR1:DBX26.23 e! x/ E) j8 a: p4 H, f
   + P#: 2.6/ }0 |( S! Z7 F# x$ |
   ---------------------------
: M7 S1 [: ]/ k: n1 v- [   = DBX29.7 这是区域间寄存器间接寻址的最终确切地址数值单元
/ S2 L# n6 D) h3 D3 t0 W" O' _  K  【AR的地址数据赋值】
6 U9 c+ z2 u9 B" ^2 Y  通过前面的介绍,我们知道,要正确运用寄存器寻址,最重要的是对寄存器AR的赋值。同样,区分是区域内还是区域间寻址,也是看AR中的赋值。8 g6 e/ I; G7 m$ M+ u! L
  对AR的赋值通常有下面的几个方法:) U$ l5 m0 J3 o9 V" D: \
  1、直接赋值法  @: y5 f; \6 j; ?" e
  例如:
' v9 H0 k2 {; Q0 M  L DW#16#83000320& N+ q8 o! h7 N/ \
  LAR1! u) c0 J. d/ M" A" ^
  可以用16进制、整数或者二进制直接给值,但必须确保是32位数据。经过赋值的AR1中既存储了地址数值,也指定了存储区域,因此这时的寄存器寻址方式肯定是区域间寻址。- A" m1 z, j# q  h0 f% U" e
  2、间接赋值法7 l* T/ x  x- p" Q- E6 ?. R% Q
  例如:/ B* E" d8 j. h( _% N/ z. C
  L [MD100]
2 y% p! \" J3 u  Y# ~7 P+ J7 Z0 _8 Q  LAR1
9 I: |: k. S: P9 M  可以用存储器间接寻址指针给定AR1内容。具体内容存储在MD100中。9 C5 X0 T+ N9 A) [
  3、指针赋值法4 R' h/ L9 _3 [5 A9 L; F! q6 U
  例如:
, c. E, U+ N- u  LAR1 P#26.2* r. U% [) J: c* x9 i' Z) t, c
  使用P#这个32位“常数”指针赋值AR。4 ^4 d  Y# g0 s6 p0 R# h
  总之,无论使用哪种赋值方式,由于AR存储的数据格式有明确的规定,因此,都要在赋值前,确认所赋的值是否符合寻址规范。7 ^5 F6 o; x6 }! z
  详解西门子间接寻址<3>. O! @1 q; \+ z
  使用间接寻址的主要目的,是使指令的执行结果有动态的变化,简化程序是第一目的,在某些情况下,这样的寻址方式是必须的,比如对某存储区域数据遍历。此外,间接寻址,还可以使程序更具柔性,换句话说,可以标准化。
4 U( ]8 j; L7 ~  下面通过实例应用来分析如何灵活运用这些寻址方式,在实例分析过程中,将对前面帖子中的笔误、错误和遗漏做纠正和补充。
! ^  w  {1 |3 ~5 c$ F  【存储器间接寻址应用实例】# e$ \0 K+ r* d( M9 D  [
  我们先看一段示例程序:7 g  B- E" A* z( r6 o& k6 ~3 t
  L 100 3 C5 a5 b* q7 x2 j. {
  T MW 100 // 将16位整数100传入MW100
& V5 Y' u8 X/ r2 J  L DW#16#8 // 加载双字16进制数8,当把它用作双字指针时,按照BYTE.BIT结构,
( O5 j$ s# C& {. v( O2 b7 [   结果演变过程就是:8H=1000B=1.0% i! ?& A! K, i. W' G* E
  T MD 2 // MD2=8H0 z# o4 ]( u1 ~& u
  OPN DB [MW 100] // OPN DB100. C$ D# X! |( K1 q* N* D
  L DBW [MD 2] // L DB100.DBW1
* h, v9 e# ?9 K; j( ]  T MW[MD2] // T MW1 6 ?: ~/ N* I$ G/ Y; x% l! U
  A DBX [MD 2] // A DBX1.0
7 B, i3 a% ^4 r- Z# c/ D( C  = M [MD 2] // =M1.0
& v+ W" Y" r4 K: v, E! h. {( c  在这个例子中,我们中心思想其实就是:将DB100.DBW1中的内容传送到MW1中。这里我们使用了存储器间接寻址的两个指针——单字指针MW100用于指定DB块的编号,双字指针MD2用于指定DBW和MW存储区字地址。) _9 Y. ]+ H9 p, o% N5 ]
  -------------------------------------------------------------------------------------------------------------------------------------------------
" c/ q5 a8 K; s0 x  对于坛友提出的 DB[MW100].DBW[MD2] 这样的寻址是错误的提法,这里做个解释:  G: z9 k. m6 m' c, Y
  DB[MW100].DBW[MD2] 这样的寻址结构就寻址原理来说,是可以理解的,但从SIEMENS程序执行机理来看,是非法的。在实际程序中,对于这样的寻址,程序语句应该写成:
! x1 m. [! `; E( M. H/ W8 U  OPN DBW[WM100], L DBW[MD2]-------------------------------------------------------------------------------------------------------------------------------------------------
* O4 U; d2 Y3 h' c* Q7 r5 x. |  事实上,从这个例子的中心思想来看,根本没有必要如此复杂。但为什么要用间接寻址呢?- |8 a$ M: C  S" ^# u7 G. ?
  要澄清使用间接寻址的优势,就让我们从比较中,找答案吧。
1 K5 M$ Y0 M- n  例子告诉我们,它最终执行的是把DB的某个具体字的数据传送到位存储区某个具体字中。这是针对数据块100的1数据字传送到位存储区第1字中的具体操作。如果我们现在需要对同样的数据块的多个字(连续或者不连续)进行传送呢?直接的方法,就是一句一句的写这样的具体操作。有多少个字的传送,就写多少这样的语句。毫无疑问,即使不知道间接寻址的道理,也应该明白,这样的编程方法是不合理的。而如果使用间接寻址的方法,语句就简单多了。
; Q4 W" C7 @4 z# ^+ l# \) Y  【示例程序的结构分析】
2 o% F& l6 g$ k  我将示例程序从结构上做个区分,重新输入如下:
% G$ y3 o$ L. `# ^! Y  =========================== 输入1:指定数据块编号的变量- I7 f+ M8 j3 Q$ @+ u: ~1 R9 M2 ]
  || L 100
# k, D. O0 ~" j% {- {; K6 V  @6 U  || T MW 100
/ t& z# x  E8 `' L, U; j! t  ===========================输入2:指定字地址的变量% Q8 g/ d) c* K3 W
  || L DW#16#8   g0 t1 h& t0 E/ d8 y" X
  || T MD 2
, Z8 g+ Z* d& _5 S6 Q; n  ===========================操作主体程序
1 ^2 u7 t3 y! B9 y   OPN DB [MW 100] " R8 O  z" h" r8 u6 a7 @+ A8 v
   L DBW [MD 2]
) b8 d! J' c1 q3 {* k; u8 R! w   T MW[MD2]
8 `1 @0 l1 E: s7 e  显然,我们根本不需要对主体程序(红色部分)进行简单而重复的复写,而只需改变MW100和MD2的赋值(绿色部分),就可以完成应用要求。
8 w; R8 s, F& E" x% [) E9 e  结论:通过对间接寻址指针内容的修改,就完成了主体程序执行的结果变更,这种修改是可以是动态的和静态的。1 {" e2 \0 B; U: Y  b
  正是由于对真正的目标程序(主体程序)不做任何变动,而寻址指针是这个程序中唯一要修改的地方,可以认为,寻址指针是主体程序的入口参数,就好比功能块的输入参数。因而可使得程序标准化,具有移植性、通用性。6 X- |" V# T9 c# t: V
  那么又如何动态改写指针的赋值呢?不会是另一种简单而重复的复写吧。
# r' B2 T" [# J0 f  _  让我们以一个具体应用,来完善这段示例程序吧:
! D9 o7 l+ Q0 ?  S1 s" U2 w  将DB100中的1-11数据字,传送到MW1-11中; t' o" G( l  j" q7 G9 u6 o
  在设计完成这个任务的程序之前,我们先了解一些背景知识。
  X* n9 H! O/ N( b: E: ^  【数据对象尺寸的划分规则】' I2 c  r5 B: E, |- h, @( t
  数据对象的尺寸分为:位(BOOL)、字节(BYTE)、字(WORD)、双字(DWORD)。这似乎是个简单的概念,但如果,MW10=MB10+MB11,那么是不是说,MW11=MB12+MB13?如果你的回答是肯定的,我建议你继续看下去,不要跳过,因为这里的疏忽,会导致最终的程序的错误。' \2 f. |  d% F7 _, K0 t
  按位和字节来划分数据对象大小时,是以数据对象的bit来偏移。这句话就是说,0bit后就是1bit,1bit后肯定是2bit,以此类推直到7bit,完成一个字节大小的指定,再有一个bit的偏移,就进入下一个字节的0bit。7 D( L7 k/ b( c
  而按字和双字来划分数据对象大小时,是以数据对象的BYTE来偏移!这就是说,MW10=MB10+MB11,并不是说,MW11=MB12+MB13,正确的是MW11=MB11+MB12,然后才是MW12=MB12+MB13!
1 a1 P5 o1 D, s- h" u2 e! N  这个概念的重要性在于,如果你在程序中使用了MW10,那么,就不能对MW11进行任何的操作,因为,MB11是MW10和MW11的交集。8 i' ^( z1 m% c! R% ~
  也就是说,对于“将DB100中的1-11数据字,传送到MW1-11中”这个具体任务而言,我们只需要对DBW1、DBW3、DBW5、DBW7、DBW9、DBW11这6个字进行6次传送操作即可。这就是单独分出一节,说明数据对象尺寸划分规则这个看似简单的概念的目的所在。  M( l7 b* d7 e9 n( Q; z0 K3 W
  【循环的结构】
+ I0 v+ _0 p5 {0 \  要“将DB100中的1-11数据字,传送到MW1-11中”,我们需要将指针内容按照顺序逐一指向相应的数据字,这种对指针内容的动态修改,其实就是遍历。对于遍历,最简单的莫过于循环。
0 R; z; ~. j* h6 b6 ~2 g5 G  一个循环包括以下几个要素:
; P% @. @% `9 o8 O  1、初始循环指针
# f) n  [5 N: D' D0 o0 b  2、循环指针自加减
! Z  f8 c# F% @9 ]  2、继续或者退出循环体的条件判断4 j: o& D( ~, Z
  被循环的程序主体必须位于初始循环指针之后,和循环指针自加减之前。# i- M; x* }5 ^/ ]$ h$ r7 ?* e
  比如:( d! s/ ~, N9 K! p1 |0 k
  初始循环指针:X=0
( ^$ B8 b& c3 v3 i* s' U$ I  循环开始点M
7 I2 Q, i; m- y) y6 t; t9 A  被循环的程序主体:-------
. q- z+ m" m. m0 `7 z  循环指针自加减:X+1=X
( ^; ^" S. G8 q' R  循环条件判断:X≤10 ,False:GO TO M;True:GO TO N
8 Z# g6 ^- g5 v1 z5 P" g5 w3 V  循环退出点N
) ?) s$ t* {. f! \- P  如果把X作为间接寻址指针的内容,对循环指针的操作,就等于对寻址指针内容的动态而循环的修改了。
2 ?, H7 v8 z" `( H  【将DB100中的1-11数据字,传送到MW1-11中】
7 J# W+ B! g/ f% z! T   L L#1 //初始化循环指针。这里循环指针就是我们要修改的寻址指针& n4 I" P4 [+ F& p, m' d
   T MD 102 , k0 Z9 v$ Z- X! N+ ]: J
  M2: L MD 102
* ~8 ]  a/ L( v/ F   T #COUNTER_D 4 v0 _2 T* @8 H# H" `) t
   OPN DB100
- t3 r( K: L' ?) e   L DBW [MD 102]
' b. G/ `7 \9 e% X3 S7 r# p7 K4 z   T MW [MD 102]1 I# A' H8 r; ~2 ?' j+ Q$ u
   L #COUNTER_D
5 A! @, R! R$ x. Z) ~' ~9 `% @   L L#2 // +2,是因为数据字的偏移基准是字节。 5 i- F4 K. ?9 w) X: y) }# h7 A; T
   +D ) A- u$ }7 B. m5 L8 R
   T MD 102 //自加减循环指针,这是动态修改了寻址指针的关键 ) F3 X3 q  c( U! M) w3 m( y% w
   L L#11 //循环次数=n-1。n=6。这是因为,首次进入循环是无条件的,0 A, s) i6 e0 T, c. u# i
   但已事实上执行了一次操作。# ~, `, _2 }- J1 U8 J
   <=D " U- \8 j) e! J/ M5 Z
   JC M2
" z, V3 }; Q: Z" @& P5 E' L   有关于T MD102 ,L L#11, <=D的详细分析,请按照前面的内容推导。' F3 N3 v! l6 v$ {3 |2 \& v- c8 K6 }
  【将DB1-10中的1-11数据字,传送到MW1-11中】
( Y  Y/ b8 _# t( r, X5 }- y9 y* k/ J  这里增加了对DB数据块的寻址,使用单字指针MW100存储寻址地址,同样使用了循环,嵌套在数据字传送循环外,这样,要完成“将DB1-10中的1-11数据字,传送到MW1-11中”这个任务 ,共需要M1循环10次 × M2循环6次 =60次。# D9 c, _2 m, m9 U7 O
   L 12 a- S/ V3 U2 Q, J
   T MW 100
% H5 N  U$ K4 Y7 x; b   L L#1% A- T4 H2 w! y
   T MD 1023 k/ p6 o' t" u& d% r
  M1: L MW 100
* H1 d7 v* _. W$ w   T #COUNTER_W. {8 a5 m3 A( `
  M2: 对数据字循环传送程序,同上例/ ?! w: i" x7 `3 i/ Z, ^
   L #COUNTER_W
8 Z7 v1 L/ d/ u- {7 o6 j   L 1 //这里不是数据字的偏移,只是编号的简单递增,因此+1
1 W( j) W! O/ d   +I
1 h) D/ I) O' T% U0 v   T MW 100( n# d. \0 u! g4 V" t! _. r( J8 Q/ l' q
   L 9 //循环次数=n-1,n=10; s, q1 [( f/ m
   <=I 5 J8 N! G8 }* K' x$ }, H
   JC M15 W# N0 v2 a2 V
  通过示例分析,程序是让寻址指针在对要操作的数据对象范围内进行遍历来编程,完成这个任务。我们看到,这种对存储器间接寻址指针的遍历是基于字节和字的,如何对位进行遍历呢?3 d5 ?' H+ w; G' @
  这就是下一个帖子要分析的寄存器间接寻址的实例的内容了。
/ w- g$ j& `: m4 }- K3 ?9 p, k  详解西门子间接寻址<4>/ ^. V7 C0 R6 V# r4 }
  L [MD100]
' n+ d& Q" l4 |. i; n) G; v) x8 w8 E  LAR1* S& S( {2 G8 \
  与
7 H( y" T$ H! e9 H( K  t; N4 E6 M  
* S2 c8 J& U& Z) Y; ~  L MD100: ?4 b; }1 C7 M& x) t- \; P
  LAR17 W8 g9 d1 D. V! o
  有什么区别?2 P. m5 a7 @: V9 s+ E# \& E0 U
  当将MD100以这种 [MD100] 形式表示时,你既要在对MD100赋值时考虑到所赋的值是否符合存储器间接寻址双字指针的规范,又要在使用这个寻址格式作为语句一部分时,是否符合语法的规范。( U' v# U; c% C- v, t) L
  在你给出第一个例程的第一句:L [MD100]上,我们看出它犯了后一个错误。
% z/ Q; d8 }( H) t  存储器间接寻址指针,是作为指定的存储区域的确切数值单元来运用的。也就是说,指针不包含区域标识,它只是指明了一个数值。因此,要在 [MD100]前加上区域标识如: M、DB、I、Q、L等,还要加上存储区尺寸大小如:X、B、W、D等。在加存储区域和大小标识时,要考虑累加器加载指令L不能对位地址操作,因此,只能指定非位的地址。% V/ {; n! @! e" m8 ^
  为了对比下面的寄存器寻址方式,我们这里,修改为:L MD[MD100]。并假定MD100=8Hex,同时我们也假定MD1=85000018Hex。' Z$ e# V2 s. V4 D
  当把MD100这个双字作为一个双字指针运用时,其存储值的0-18bit将会按照双字指针的结构Byte.bit来重新“翻译”,“翻译”的结果才是指针指向的地址,因而MD100中的8Hex=1000B=1.0,所以下面的语句:
. {& j% {! e# Q4 o. D  L MD[MD100]
7 Q  {/ i! J$ W1 g) D  LAR1$ e9 S7 T) }: |1 `$ L8 S1 P
  经过“翻译”就是:. L9 Q# Y% I" X+ O8 ?7 D9 Z$ N
  L MD1! M& h1 K  T3 Z+ f- }
  LAR16 @: Z  s% ^6 r7 s
  前面我们已经假定了MD1=85000018,同样道理,MD1作为指针使用时,对0-18bit应该经过Byte.bit结构的“翻译”,由于是传送给AR地址寄存器,还要对24-31bit进行区域寻址“翻译”。这样,我们得出LAR1中最终的值=DIX3.0。就是说,我们在地址寄存器AR1中存储了一个指针,它指向DIX3.0。; M3 A7 \+ g! b
  -----------------------------
; f: Z9 m6 y. x- ~* y% u) [, m  L MD100) X$ L" ~$ x3 ~
  LAR10 |3 Z, G# C" s+ j  }
  这段语句,是直接把MD100的值传送给AR,当然也要经过“翻译”,结果AR1=1.0。就是说,我们在地址寄存器AR1中存储了一个指针,它指向1.0,这是由MD100直接赋值的。
% U  z, K: m; w5 H  似乎,两段语句,只是赋值给AR1的结果不同而已,其实不然。我们事先假定的值是考虑到对比的关系,特意指定的。如果MD100=CHex的呢?
  V! {  G, M& X- D  对于前一段,由于CHex=1100,其0-3bit为非0,程序将立即出错,无法执行。(因为没有MD1.4这种地址!!)
  t1 j* `3 d) ?( p  后一段AR1的值经过翻译以后,等于1.4,程序能正常执行。
鲜花(0) 鸡蛋(0)
 楼主| 发表于 2009-2-14 02:38 | 显示全部楼层

MPI 网络与全局数据通信

老杨团队,追求完美;客户至上,服务到位!
1.多点接口(MPI)协议的数据通信( z. d7 ?" M5 a& K3 I& E
MPI 是多点接口(Multi Point Interface)的简称,MPI 的物理层是( ~2 a" e4 Z- Z; D9 U8 p
RS-485,通过MPI 能同时连接运行STEP 7 的编程器、计算机、人机
" ~, e/ u! _0 B5 ^+ B$ o界面(HMI)及其他SIMATIC S7。通过MPI 接口实现全局数据(GD)服务,周期性地相互进行数据交换。3 G4 x' L3 J/ J$ _. Z. _
2 MPI 网络
& k/ t( ^; G  V' e, B周期性地相互交换少量的数据,最多15 个CPU。编程设备、人机接口和CPU 的默认地址分别为0,1,2。MPI 默认的传输速率为187.5 k bit/s 或1.5 M bit/s。相邻节点间的最大传送距离为50m,加中继器后为1000m,使用光纤和星形连接时为23.8 km。
) _' }, J1 X4 O* z! k  G4 B3 全局数据包  R: `: ?$ q: e  \9 K, r
参与全局数据包交换的CPU 构成了全局数据环(GD circle)。可
$ l- l& ~/ \0 W  r! U- C+ W- t以建立多个GD 环。具有相同的发送者和接收者的全局数据集合成一个全局数据包。数据包中的变量有变量号。例如GD1.2.3 是1 号GD 环、2 号GD 包中的3 号数据。
2 b! q# K) d% b# h# RS7-300 CPU 可以建立4 个全局数据环,每个环中一个CPU 只能发送和接收一个数据包,每个数据包最多包含22 个数据字节。S7-400 CPU 可以建立的全局数据环个数与CPU 的型号有关(16~64 个),每个环中一个CPU 只能发送一个数据包和接收两个数据包,每个数据包最多包含54 个数据字节。/ e' v9 f/ m  a( W* `8 D
4  MPI 网络的组态9 T9 ?4 }- b* }, t% ~
假设在SMATIC 管理器中生成3 个站,它们的CPU 分别是CPU413-1,CPU 313C 和CPU 312C。双击MPI 图标,打开NetPro 工 具,打开CPU 的属性设置对话框,设置MPI 站地址。将CPU 就被连接到MPI(1)子网上。保存CPU 的配置参数,用点对点的方式将它们分别下载到各CPU中。用PROFIBUS 电缆连接MPI 节点可以用管理器的“AccessibleNodes”功能来测试可以访问的节点。3 L: n$ h7 `' R
5  全局数据表2 {2 j2 ~! f- V+ U% |- D
a.生成和填写GD 表
0 m; L: ]& Z5 \9 N在“NetPro”窗口中用右键点击MPI 网络线,在弹出的窗口中执
6 @7 r- [( M; u& g- Y行执行菜单命令“Options →Define Global Data(定义全局数据)”同样的命令。在表的第一行输入3 个CPU 的名称。鼠标右键点击CPU 413-1 下面的单元(方格),在出现的菜单中选择“Sender”(发送者),输入要发送的全局数据的地址MW0。在每一行中只能有一个CPU 发送方。同一行中各个单元的字节数应相同。点击CPU 313C 下面的单元,输入QW0,该格的背景为白色,表示CPU 313C 是接收站。
& t  W/ |' U+ P7 u& u: Z( Yb 全局数据表% G1 v8 R- C$ L4 \1 n8 U3 i) U
MB20:4 表示MB20 开始的4 个字节。如果GD 包由若干个连续的
7 W% B% J+ N& U) W2 ^数据区组成,一个连续的数据区占用的空间为数据区内的字节数加上) s3 m# ~& M, W
两个头部说明字节。一个单独的双字占6 个字节,一个单独的字占4
! j2 U  e8 V& {7 b+ G4 l: ]个字节,一个单独的字节占3 个字节,一个单独的位也占3 个字节,
. [  ~+ s# G3 y: V7 T) G' \例如DB2.DBB0:10 和QW0:5 一共占用22 个字节。
5 z7 V; Q- E7 P发送方CPU 自动地周期性地将指定地址中的数据发送到接收方指定的地址区中。完成全局数据表的输入后,应执行菜单命令“GD
, j) j8 L3 D/ U6 w0 P* f) {Table→Compile…”,对它进行第一次编译。
- V# M+ X( M7 c" i# z9 ic.设置扫描速率和状态双字的地址* H% P+ n, J1 K  r, H9 {
执行菜单命令“View→Scan Rates”,每个数据包将增加标有“SR”
% A: `! x" R8 N的行,扫描速率单位是CPU 的循环扫描周期,S7-300 默认的扫描速
# n7 R2 q4 G- Z9 g! I0 l' k1 }率为8,S7-400 的为22,用户可以修改。S7-400 的扫描速率为0,表
) B8 p- @6 ~. n/ F7 S, m示是事件驱动的GD 发送和接收。- c' _) X0 G+ `$ m0 b9 d4 K! p
d. 第一次编译后的全局数据表5 L2 o: Y, h$ l4 d( @) J- w  h
GD 数据传输的状态双字用来检查数据是否被正确地传送,执行' X/ u5 {. Z5 [# k- h7 T& m
菜单命令“View→Status”,在出现的GDS 行中可以给每个数据包指6 M& R; Q2 ]( ?8 k8 {- F
定一个用于状态双字的地址。最上面一行的全局状态双字GST 是各' e) R' m0 q& _% I8 f
GDS 行中的状态双字相“与”的结果。设置好扫描速率和状态字的地址后,应对全局数据表进行第二次编译。将配置数据下载到CPU 中,以后可以自动交换数据。
鲜花(0) 鸡蛋(0)
 楼主| 发表于 2009-2-14 03:04 | 显示全部楼层
原帖由 shenyang-china 于 2009-2-8 10:48 发表
7 F! l8 f2 R# R2 O3 b' o, B5 g顶,看过lz的另一贴,好帖,cnc系统听说过,但没这方面经验看不太懂.SIEMENS 840D等是不是机床的数控系统.?另外一个问题,NC程序看起来不象plc程序,它存储在哪? 和PLC是怎样连接的? 谢谢,期待继续.....

, Y% }  R1 p& X3 G在的NC程序中会看到如下程序:) v5 U- I) L/ l+ f- Y" r& l
N110 IF ($A_DBB[42] B_AND 1)==1 GOTOF LoadReq ;load request
1 M, M4 w* M1 L" b- x5 Y1 _N120 IF ($A_DBB[42] B_AND 2)==2 GOTOF UnloadReq ;unload request5 |8 Y1 G0 R* h! Y( Z# p, @, X

) m3 ^1 k- X1 |N9010 $A_DBB[42] = 0                    ;delete order5 x7 B2 n0 R5 o7 K$ ^! S+ B
在加工程序中经常看到$A_DBB[n],$A_DBW[n],$A_DBD[n]等变量。那么这些变量是怎么来的呢!$ `" b) ^' w# P6 I6 I2 g
这些变量在NC程序中可以进行读写;同时也可由PLC读取这些变量的值、存放到PLC的地址中;也可由PLC写这些变量的值、NC程序来读取。与PLC的数据交换在PLC的程序里完成,具体的功能由FC21这个功能块来完成。. b( h. P, ~& i, B' ?; O
下面看一下FC21的应用例子。1 P% f, I+ x2 X' C
CALL  FC21   
% A4 q( J6 f) A( _8 T  ] Enable :=TRUE        解释:1=FC21 active0 x! O7 ^  g$ w5 C
Funct  :=B#16#4        解释:B#16#4=write(PLC写NC);B#16#3=read(PLC读NC)3 o( @2 D" {. B& K: V8 A* W5 ~; I
S7Var  :="HM_B_250"        解释:PLC中数据的地址( L! y0 `5 f) H+ t. b
IVAR1  :=42                解释:NC中的数据地址
% [+ s% e) \& A! e6 K( RIVAR2  :=-1
7 K1 I8 ^/ Q$ M8 `Error  :=#Er_FC21_DPR42_wri_A2- r( f0 H. o. c3 K
ErrCode:=#ErrC_FC21_DPR42_wri_A2/ {; K8 E( R3 z

# g2 {( [* x0 _; L! W) Z. D上面的例子实现了如下功能:将PLC地址MB250里的数据写到$A_DBB[42]里。然后NC程序就可以读取了。
鲜花(0) 鸡蛋(0)
发表于 2009-2-17 22:43 | 显示全部楼层
同言同羽 置业良晨
老兄是个人才,更难得的是能把自己的知识拿来和大家分享!:
鲜花(0) 鸡蛋(0)
 楼主| 发表于 2009-2-27 04:35 | 显示全部楼层

SIEMENS 840D GHOST

同言同羽 置业良晨
笔记本测需要的设定 :
4 A% Q# x/ e' C' l1 D5 k1 在笔记本有空间的硬盘分区中创建一文件夹, 属性为共享 ,同时名字要与下面第17步中的名字一样 例如:OP50A: {( n- A, K0 n/ D( ~9 F
2 在网卡属性设定中 对IP 地址进行设定,一般为:192 168 1 27 s5 Q4 }4 w  g+ L6 [6 U
255 255 255 00 q4 m  t, T2 N: x
3笔记本中必须要有下面用户名”AUDUSER”  并且必须是 “管理者”,至于用何用户名子登陆这台笔记本无所谓的(设定在控制面板中)
$ ?& r2 G- F- ^6 |4 笔记本的用户名字要与下面 第17部中一致  。(修改:点击我的电脑右键 属性).
  V- F" Q+ T$ f4 b机床控制面板侧操作如下:0 t2 M3 ?8 ]$ G8 `# m
1 启动设备 , 并执行tool change  position使刀具回到库
. g& H" A! p6 e8 i/ P$ o2作系统的系列备份 方法 :5 \0 S) ]3 Q  Y% L
a :MENU  SELECT
7 o0 I+ x3 M! Y5 i" BB:  SERVICES
9 {1 p3 D: @/ [, l* s, IC:  按扩展键出现 SERIES  START-UP! B/ y( ~% m( u8 W+ k( K* M; }( Z: J
D: 移动光标 到 NC     WITH COMPENSATION DATA 将两个小方框 全选上对号 。并在 ARCHIVE NAME 处写上名字。( S4 b: t# |7 d
E: 按 ARCHIVE这时NC的系列备份开始作了 。& X: v9 B, g8 `0 l4 y. p, H$ U
同样将 PLC也做一次 系列备份 。+ O$ Q& U* E: f% `! O* u- U( P
3 在按 MENU  SELECT/按扩展键出现EXIT,并重新起动840D工控机.3 [$ }' b! h) l$ I  F! X9 t4 j$ L8 L* U
4 出现 “SINUMERIK”按向下箭头并回车。
" L5 s0 U' _0 u3 g, j% G3 o5        选择7 BACKUP/RESTORE2 @$ L3 S% u$ P& q0 B
6        提示输入密码 : PSCNC4 B9 R" K" A7 x* F: ~4 }
7        选1 HARDDISK BACKUP /RESTORE WITH GHOST" ~2 I, {1 ]5 }4 n
8        选 1CONFIGURE  GHOST PARAMETERS2 I' ?. i4 S3 @/ W  S( s
9        GHOST CONNECTION MODE :LOCAL/NETWORK0 V3 a7 s8 f) R  f1 m: @
BACKUP TO IMAGE FILE:G:\OP55A.GHO' J, G- \  w# \8 z% G
RESTORE FROM IMAGE FILE:G:\55-CH-VI.GHO: J& `" H8 f, ]5 m
在第 3中可以设定备份的镜像文件的名字( R# W" i( r+ Q5 r' C
10        在 第6项中可以修改IP址MANAGE METWORK DRIVES
9 `/ M. M, [7 R6 j: n11        选4 CHANGE NETWORK SETTINGS
' j' u. F) J1 w# f" r! q7 u+ b; k6 ^MACHINE MAME         CNC321-OP50A3 I+ H1 S+ c& {3 N3 g
USER NAME                   AUDUSER: D1 S2 }$ Z6 ?
TRANSPORT  PROTOCOL            TCPIP  GET  IP ADDRESSES MANUALLY/ ~$ K! A  |6 O! \7 A0 L
LOGNO TO DOMAIN         YES
2 m5 D$ O. @. @- c+ pDOMAIN  NAME     WW0043 m/ m9 d5 C0 o0 J6 L& _" m8 [
CONNECTED NETWORK DRIVE    NONE
" ]6 {- I7 L  f' |2 E2 [12        选6CHANGE TCPIP SETTINGS
( v4 {1 x, M6 M( M$ z4 f" mGET IP SDDRESSES       MANUALLY0 o' M  F, F1 M5 p
MY IP ADDRESS    192 168 1 1! P3 e9 N# w1 N2 E9 L
SUBNETMASK       255 255  255 0
0 y- V5 P. E% [8 RGATEWAY              10 10 136 1
6 n" H4 V: b% a6 ^7 g  u如果需要修改IP 地址选择2  CHANGE IP ADDRESS
. j  k" h# B: i* w" Q! E+ j- r13        按 back to prvious menu* Y4 a- O# k1 M  z7 z
14        按 back to prvious menu
; f$ h" R( A6 M& J15        按 1 CONNECT TO NETWORK DRIVE- {) i; l! g  x8 a0 e( u3 O
16        出现提示输入密码:SUNRISE& g, m2 Q, M: c& t
17        出现 LETTER FOR NETWORK DRIVE [G]:G         G是指笔记本整个硬盘5 U9 J& Y( s' T9 v/ ]2 ~
DIRECTORY TO BE MOUNTED [\\SGM\OP50A]:\\SGM\OP50A其中SGM使笔记本的用户名OP50是笔记本中间的共享文件夹
; N# V( y. w! m6 P# s$ C( F18 提示输入笔记本的密码: SUNRISE              (这时画面回自动退到上一级去)8 b2 R$ r5 O# W: m2 x  E: U, C6 g
19  按 back to prvious menu          (提示是否要保存 ,输入Y)
+ c* N* l) r4 W1 R, d20        按 back to prvious menu5 s& T! {9 a8 V5 O7 Y7 Q) i3 I
21        按2  HARDDISK BACKUP TO G: \OP50A .GHO ,MODE LOCAL/NETWORK
& f: A( t# C9 X% L- @( u; `22        提示CONTIUNE BACKUP [Y,N]输入Y并回车,此时SIEMENS自动进入GHOST画面了。; @8 O% Y* j7 F/ l% e% h) M+ k
23        做完GHOST后重启840D电脑# y$ C/ o: R6 r* [2 Z
注意事项:1 网线要交叉网线
! F* u4 d9 S% j5 A0 g' M' x2 BACKUP TO IMAGE FILE:G:\OP55A.GHO一定是G盘
7 h; h# T: ~4 B7 y$ z' z3 操作面板侧 对IP地址进行设定时,不能用“点”例如:192.168.1.1这是不对的 ,正确的是192 168 1 1 用“空格”。
鲜花(0) 鸡蛋(0)
 楼主| 发表于 2009-3-3 03:21 | 显示全部楼层

fanuc 414报警

机床在加工过程中出现传送杆NC报警,机床停止加工.接上CRT显示414报警,造成414报警的原因大致有以下几种:(1)过载报警(2)电压不足报警(3)过电流报警(4)电流异常报警(5)过电压报警(6)放电报警(7)断线报警(8)伺服控制内部存储器的溢出报警。然后根据CRT中显示DGN200 ,HCA 1,这就是表示电流异常报警(伺服放大器侧的报警),伺服放大器上显示“8.”报警,这就是说明伺服放大器内的IPM内检测到异常(IPM内过电流,高温或驱动回路用电源电压下降).造成这种报警的可能一是伺服放大器模块自身有问题,二是电缆有问题,三是伺服电机有问题.
7 f6 h5 w4 \% \! y) X5 g    因为机床是在自动加工过程中出现的这种报警,所以模块自身的问题可能性很小,所以剩下的就是电缆和伺服电机的可能性最大.然后先将电源总开关断开再用兆欧表来对电缆和电机进行测量发现电缆电机绝缘以损坏对地,并有短路现象,这样就找到了故障的根本原因,然后拆开电机动力线接头发现接头内有冷却液残留物的迹象,这说明造成电机短路的主要原因就是由于长期受冷却液长期浸泡渗入所造成.
: U- i3 t6 U4 E( O: }解决方法就是更换电机,更换电机动力线接头,在更换动力线接头时要注意几点,一是因为接线端子都是焊接的,所以更换时一定要把动力线线头焊接处处理干净,以避免上面有氧化层,焊锡不能融合.二是焊接时一定要注意不要虚焊,因为电机启动时电流比较大,虚焊会增大阻值,造成局部温度过高,很容易开焊造成断路缺相现象.三是线头尺寸要掌握好避免线头裸露过多,造成隐患.四是当焊接完接头后要用兆欧表对其进行检查.
$ x6 |9 v, m1 _% h当电机和动力线安装完毕后,检查无误然后将总电源开关合上,打开机床液压,由于拆卸伺服电机就必须要拆掉编码器电缆这样伺服电机的原点就会丢失,就必须重新设定原点,设定原点的方法已经在前几次维修心得中介绍过了,在这就不在说明,在原点设定完后要检查所有工位和工件是否正常,确定正常后,手动将传送杆升起落下几次,观察工件与机床定位销的位置是否准确,以保证原点设定准确,然后通知操作者以自动加工,手动传送的方式进行加工,以这种方式进行几个循环后确认无误后才可以进行自动加工., q. k* s" j+ K. \8 b7 L
这就是此次维修的全部过程和通过这次维修总结的一点经验.
鲜花(1) 鸡蛋(0)
发表于 2009-3-3 17:39 | 显示全部楼层

回复 25楼 的帖子

老杨团队,追求完美;客户至上,服务到位!
鲜花(0) 鸡蛋(0)
发表于 2009-3-12 01:57 | 显示全部楼层
非常感谢分享经验。 任何CNC编程我非常熟悉, 但CNC的PLC编程不懂。 很想跟老大你学习CNC的维修, 不知有无相关CNC PLC的书籍推荐?
鲜花(0) 鸡蛋(0)
 楼主| 发表于 2009-3-15 17:49 | 显示全部楼层
cnc里的plc不需要你去编程,如果你会的话,那就黄金万两了,呵呵。还有你说cnc编程你都会,不过你应该学学海德翰系统,我打赌你这个肯定不会。
鲜花(34) 鸡蛋(0)
发表于 2009-3-18 21:01 | 显示全部楼层

我怎么觉得simenes的控制系统,在数控机床上用的并不是很多

我在这里,用过西门子的s7-200,设计工厂的自动冲床,主要的原因是便宜,上手快。好像在整个加拿大,很少工厂可以用到s7-400的水平。(加东就不知道了)。& i0 K" l3 y3 t0 m) g9 D) y3 |

) b) L, M8 q, D+ G" Q) Z6 v我一直都是维修mazak的数控机床,几乎就没有西门子的控制系统。
鲜花(0) 鸡蛋(0)
发表于 2009-3-19 13:28 | 显示全部楼层
老杨团队,追求完美;客户至上,服务到位!
原帖由 korg707 于 2009-3-15 18:49 发表
. p1 ^. M: y& l9 o4 d. vcnc里的plc不需要你去编程,如果你会的话,那就黄金万两了,呵呵。还有你说cnc编程你都会,不过你应该学学,我打赌你这个肯定不会。

% a& O' q# G9 s! M! Q5 n8 p. o- S- w- G
在edmonton有Heidenhain系统的机器估计不到15台, 大都是NICOLAS CORREA的五轴机器, 还有些台湾产的机器也是。 正好我曾经编程和运行过至少7-8台。 对海德翰系统数控编程, 我想爱城没有人比我更熟悉了。 但使用中发现运行海德翰系统的机器很不可靠, 即使是新机器也是半年内必出大问题。 远不如Mazak。  所以产生了学习机床维修的想法。8 f: m2 h) ]! A" H+ K1 a; ^
/ s- m) T; q; o; D% l
想请教楼主, 哪里找CNC里的PLC的学习资料。 * S+ o6 C/ m- u0 H. a- p
+ ~7 R4 L+ t) U" r! @+ g
另外借贴想问一问, 楼主手头是否知道有谁有二手的CNC mill出售??
鲜花(34) 鸡蛋(0)
发表于 2009-3-19 13:43 | 显示全部楼层

隔行如隔山

plc编程也不是复杂的不得了,不过在alberta基本上没有用武之地。公司的自动冲床和试验机,也都是我自己编程,毕竟不是很大的工程(比如机场的控制系统,就复杂得多拉)。# H  y! T% e4 j7 a- ?; ~: w: H6 J9 O9 C

+ d) G. t/ E3 R: t如果要学习cnc的维修,关键是可以看懂plc的语言。新一代的mazak数控机床,已经把plc的梯形图,直接包含在现实菜单里,可以直接在线调试,但关键是你要看懂。知道每一条的指令。。过去的是在书上,用地址单元自己去查询,累死了。。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

联系我们|小黑屋|手机版|Archiver|埃德蒙顿中文网

GMT-7, 2026-4-4 06:47 , Processed in 0.229311 second(s), 27 queries , Gzip On, APC On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表