思思久久96热在精品国产10-思思久久96热在精品国产免费-思思久久99-思思久久99热-一级毛片免费观看视频-一级毛片免费看

智趣黃sir
級別: 正式會員
精華主題: 0
發(fā)帖數(shù)量: 62 個
工控威望: 95 點
下載積分: 1762 分
在線時間: 29(小時)
注冊時間: 2023-07-06
最后登錄: 2025-03-05
查看智趣黃sir的 主題 / 回貼
樓主  發(fā)表于: 2024-12-16 14:22
1,采用匯川的EASy521,程序想實現(xiàn)自動切手動,只動氣缸,怕操作者移動軸,因為軸如果移動的話,沒法監(jiān)測到是否移動,再切回自動的話,會導致撞車。
本人的思路是如以下程序,切到手動的M3下降沿,記錄當前位置,再切回自動,進行差值計算,只能實現(xiàn)部分,還請各位大神指點。M3是自動模式,M4是自動運行中。現(xiàn)在的問題是可以實現(xiàn)部分功能,但是拍急停的話,就會出現(xiàn)報警,因為急停拍下后,各個軸就立即停止。


自動模式下降沿(CLK := M3,Q => );
IF 自動模式下降沿.Q THEN
    X自動前位置old:=X_Axis.fActPosition;
    Y自動前位置old:=Y_Axis.fActPosition;
    Z自動前位置old:=Z_Axis.fActPosition;
    L自動前位置old:=Lift_Axis.fActPosition;
END_IF;

自動模式上升沿(CLK := M4 ,Q => );
IF 自動模式上升沿.Q then
    X自動前位置new:=X_Axis.fActPosition;
    Y自動前位置new:=Y_Axis.fActPosition;
    Z自動前位置new:=Z_Axis.fActPosition;
    L自動前位置new:=Lift_Axis.fActPosition;

    X自動前位置差值:=X自動前位置new-X自動前位置old;
    X自動前位置點位差值:=X自動前位置new-POSTION_X[X_Axis_AutoAbNum];
    X自動前位置差值絕對值:=ABS(X自動前位置差值);
    X自動前位置點位差值絕對值:=ABS(X自動前位置點位差值);

    Y自動前位置差值:=Y自動前位置new-Y自動前位置old;
    Y自動前位置點位差值:=Y自動前位置new-POSTION_Y[Y_Axis_AutoAbNum];
    Y自動前位置差值絕對值:=ABS(Y自動前位置差值);
    Y自動前位置點位差值絕對值:=ABS(Y自動前位置點位差值);
    
        Z自動前位置差值:=Z自動前位置new-Z自動前位置old;
    Z自動前位置點位差值:=Z自動前位置new-POSTION_Z[Z_Axis_AutoAbNum];
    Z自動前位置差值絕對值:=ABS(Z自動前位置差值);
    Z自動前位置點位差值絕對值:=ABS(Z自動前位置點位差值);
    
        L自動前位置差值:=L自動前位置new-L自動前位置old;
    L自動前位置差值絕對值:=ABS(L自動前位置差值);

END_IF;

IF M4=true AND X自動前位置差值絕對值>E0.5  AND X自動前位置點位差值絕對值>E0.5 THEN
           Alarm[86]:=TRUE;
END_IF;
IF M4=true AND Y自動前位置差值絕對值>E0.5  AND Y自動前位置點位差值絕對值>E0.5 THEN
           Alarm[87]:=TRUE;
END_IF;
IF M4=true AND Z自動前位置差值絕對值>E0.5  AND Z自動前位置點位差值絕對值>E0.5 THEN
           Alarm[88]:=TRUE;
END_IF;
IF M4=true AND L自動前位置差值絕對值>E0.5  THEN
           Alarm[89]:=TRUE;
END_IF;
payfsl
級別: 工控俠客
精華主題: 2 篇
發(fā)帖數(shù)量: 2620 個
工控威望: 2896 點
下載積分: 40081 分
在線時間: 488(小時)
注冊時間: 2010-08-03
最后登錄: 2025-03-17
查看payfsl的 主題 / 回貼
1樓  發(fā)表于: 83天前
您的程序邏輯是在自動模式切換到手動模式時記錄軸的位置,然后從手動模式切換回自動模式時計算位置差值,如果差值超過設定的閾值,則觸發(fā)報警。這個邏輯是合理的,但是您提到的問題是在急停情況下會出現(xiàn)報警,因為急停會導致軸立即停止,這可能會導致位置差值計算出現(xiàn)異常。

為了解決這個問題,您可以考慮以下幾個步驟:

1. **增加急停狀態(tài)檢測**:在您的程序中增加一個變量來檢測急停狀態(tài),當急停按鈕被按下時,這個變量會被設置為真。

2. **在急停狀態(tài)下跳過位置差值計算**:在您的程序中,當檢測到急停狀態(tài)時,跳過位置差值的計算和報警觸發(fā)。

3. **急停恢復后重置位置**:當急停狀態(tài)被解除后,重置軸的位置記錄,以便下一次從手動切換到自動時能夠正確計算位置差值。

以下是修改后的程序示例:

```pascal
VAR
    急停狀態(tài): BOOL; (* 急停狀態(tài)標志 *)
    X自動前位置old: REAL;
    Y自動前位置old: REAL;
    Z自動前位置old: REAL;
    L自動前位置old: REAL;
    X自動前位置new: REAL;
    Y自動前位置new: REAL;
    Z自動前位置new: REAL;
    L自動前位置new: REAL;
    X自動前位置差值: REAL;
    Y自動前位置差值: REAL;
    Z自動前位置差值: REAL;
    L自動前位置差值: REAL;
    X自動前位置點位差值: REAL;
    Y自動前位置點位差值: REAL;
    Z自動前位置點位差值: REAL;
    X自動前位置差值絕對值: REAL;
    Y自動前位置差值絕對值: REAL;
    Z自動前位置差值絕對值: REAL;
    L自動前位置差值絕對值: REAL;
    X自動前位置點位差值絕對值: REAL;
    Y自動前位置點位差值絕對值: REAL;
    Z自動前位置點位差值絕對值: REAL;
END_VAR

自動模式下降沿(CLK := M3, Q => );
IF 自動模式下降沿.Q THEN
    IF NOT 急停狀態(tài) THEN
        X自動前位置old := X_Axis.fActPosition;
        Y自動前位置old := Y_Axis.fActPosition;
        Z自動前位置old := Z_Axis.fActPosition;
        L自動前位置old := Lift_Axis.fActPosition;
    END_IF;
END_IF;

自動模式上升沿(CLK := M4, Q => );
IF 自動模式上升沿.Q THEN
    IF NOT 急停狀態(tài) THEN
        X自動前位置new := X_Axis.fActPosition;
        Y自動前位置new := Y_Axis.fActPosition;
        Z自動前位置new := Z_Axis.fActPosition;
        L自動前位置new := Lift_Axis.fActPosition;

        X自動前位置差值 := X自動前位置new - X自動前位置old;
        X自動前位置點位差值 := X自動前位置new - POSTION_X[X_Axis_AutoAbNum];
        X自動前位置差值絕對值 := ABS(X自動前位置差值);
        X自動前位置點位差值絕對值 := ABS(X自動前位置點位差值);

        Y自動前位置差值 := Y自動前位置new - Y自動前位置old;
        Y自動前位置點位差值 := Y自動前位置new - POSTION_Y[Y_Axis_AutoAbNum];
        Y自動前位置差值絕對值 := ABS(Y自動前位置差值);
        Y自動前位置點位差值絕對值 := ABS(Y自動前位置點位差值);

        Z自動前位置差值 := Z自動前位置new - Z自動前位置old;
        Z自動前位置點位差值 := Z自動前位置new - POSTION_Z[Z_Axis_AutoAbNum];
        Z自動前位置差值絕對值 := ABS(Z自動前位置差值);
        Z自動前位置點位差值絕對值 := ABS(Z自動前位置點位差值);

        L自動前位置差值 := L自動前位置new - L自動前位置old;
        L自動前位置差值絕對值 := ABS(L自動前位置差值);

        IF M4 = TRUE AND X自動前位置差值絕對值 > E0.5 AND X自動前位置點位差值絕對值 > E0.5 THEN
            Alarm[86] := TRUE;
        END_IF;
        IF M4 = TRUE AND Y自動前位置差值絕對值 > E0.5 AND Y自動前位置點位差值絕對值 > E0.5 THEN
            Alarm[87] := TRUE;
        END_IF;
        IF M4 = TRUE AND Z自動前位置差值絕對值 > E0.5 AND Z自動前位置點位差值絕對值 > E0.5 THEN
            Alarm[88] := TRUE;
        END_IF;
        IF M4 = TRUE AND L自動前位置差值絕對值 > E0.5 THEN
            Alarm[89] := TRUE;
        END_IF;
    END_IF;
END_IF;

(* 急停按鈕被按下時設置急停狀態(tài) *)
急停按鈕按下(CLK := E-Stop, Q => );
IF 急停按鈕按下.Q THEN
    急停狀態(tài) := TRUE;
END_IF;

(* 急停按鈕釋放后重置急停狀態(tài)和軸位置 *)
急停按鈕釋放(CLK := E-Stop, Q => );
IF 急停按鈕釋放.Q THEN
    急停狀態(tài) := FALSE;
    X自動前位置old := X_Axis.fActPosition;
    Y自動前位置old := Y_Axis.fActPosition;
    Z自動前位置old := Z_Axis.fActPosition;
    L自動前位置old := Lift_Axis.fActPosition;
END_IF;
```

請注意,您需要根據(jù)您的實際硬件和軟件環(huán)境調(diào)整上述代碼。希望這些修改能夠幫助您解決問題。
本帖最近評分記錄:
  • 下載積分:+1(一輪明月) X動前位置點位差值這個的 ..
  • 下載積分:+2(智趣黃sir) 謝謝大佬,思路清晰
  • 三人行必有我?guī)熝桑瑩衿渖普叨鴱闹?,學而不思則罔,思而不學則殆

    主站蜘蛛池模板: 久久久国产精品va麻豆 | 高清一级做a爱过程不卡视频 | 国产网站黄色 | 久久久久久久久女黄 | 国产片一区二区三区 | 国产精品蜜臀 | 国产精品免费观看视频播放 | 国产精品护士 | 毛片1毛片2毛片3毛片4 | 国产欧美精品综合一区 | 国产新疆成人a一片在线观看 | 国产最爽的乱淫视频国语对 | 久久www免费人成_看片高清 | 国产三级网站在线观看播放 | 久久久久久综合对白国产 | 福利小视频在线播放 | 成人永久免费福利视频网站 | 国产精品1区2区3区在线播放 | 国产成人综合在线观看网站 | 久久午夜影院 | 久久久国产麻豆 | 免费在线欧美 | 久久第一页 | 国产在线观看自拍 | 久久久精品免费国产四虎 | 久久成人免费网站 | 国产欧美日韩在线播放 | 久99久爱精品免费观看视频 | 国产成人h福利小视频在线观看 | 国产日韩精品在线 | 国产成人精品第一区二区 | 成人自拍视频网站 | 国产年成美女网站视频免费看 | 成人精品一区二区三区 | 久久国产精品久久久 | 国产黄在线免费观看 | 大色香蕉色视频大全 | 成人影片在线播放 | 黄色三级在线观看 | 国产综合久久 | 美女发福视频在线免费看 |