将结构化文本(ST)转换为梯形图(LADDER)的挑战与限制

目录

1.理解ST代码:

2.识别主要逻辑块:

3.将ST逻辑转换为图形表示:

4.测试和调整:

5.使用转换工具:

6.考虑可读性和可维护性:

7.总结


        在PLC(可编程逻辑控制器)编程中,结构化文本(ST)和梯形图(LADDER)是两种常见的编程语言。结构化文本类似于高级编程语言,如Pascal或C,而梯形图则是一种图形化编程语言,它模拟了电路中的开关和继电器的行为。

        将ST转换为LADDER并不是一个简单的直接转换过程,因为两种语言的结构和表达方式有很大的不同。但是,有一些基本的步骤和考虑因素可以帮助你进行这种转换。

1.理解ST代码:

        首先,你需要完全理解结构化文本的代码。了解每个变量、函数、条件语句和循环的作用和逻辑。

2.识别主要逻辑块:

        在ST代码中,通常会有不同的逻辑块,如初始化块、主程序块、中断块等。这些块在梯形图中也需要相应的表示。

3.将ST逻辑转换为图形表示:

        将ST代码中的每个逻辑元素(如变量、条件语句、循环等)转换为梯形图中的相应图形元素。这可能需要一些经验和知识,因为并不是所有的ST逻辑都可以直接映射到梯形图的图形元素上。

  • 变量通常可以表示为梯形图中的地址或位置。
  • 条件语句(如IF-THEN-ELSE)可以转换为梯形图中的决策元素(如菱形决策框)。
  • 循环可能需要使用特定的梯形图结构或元素来表示。

4.测试和调整:

        在转换过程中,需要不断地测试和调整梯形图,以确保其逻辑与原始的ST代码一致。这可能需要进行多次迭代和调整。

5.使用转换工具:

        有些PLC编程软件提供了从ST到LADDER的自动转换工具。这些工具可以帮助你快速地将ST代码转换为梯形图,但你可能仍然需要手动调整和优化转换结果。

6.考虑可读性和可维护性:

        在转换过程中,还需要考虑梯形图的可读性和可维护性。合理地组织图形元素、使用注释和标签等可以帮助其他工程师更容易地理解和修改梯形图。

7.总结

        需要注意的是,将ST转换为LADDER可能并不总是可能的或理想的。有些复杂的逻辑或算法可能更适合用结构化文本表示,而不是梯形图。因此,在进行转换之前,最好先评估转换的必要性和可行性。

        将结构化文本(ST)转换为梯形图(LADDER)确实需要一定的专业知识和经验,但通过仔细理解ST代码的逻辑结构,并将其映射到梯形图的相应图形元素上,是可以实现这一转换。但有这种想法的人肯定不是费劲只为了实现依次转换就完事了,肯定是尝试设计一种软件实现对任何ST语言对LADDER的自动转换。这种软件可能会存在,但作者认为自动转换的结果可能不总是完美的,需要手动调整和优化转换结果。

        最后,将ST转换为LADDER可能并不总是最佳选择。在某些情况下,保持使用结构化文本可能更为合适,特别是当逻辑非常复杂或算法需要高级编程功能时。因此,在进行转换之前,请务必评估转换的必要性和可行性。

        但有一种情况是完全可以实现的,那就是用ST语言编写功能块,然后再在梯形图文件中调用这个功能块,实现ST语言与梯形图的混合编程。

梯形图转换语句表,软件测试阶段 IMPLEMENT_DYNCREATE(VDisPlayView, CScrollView) VDisPlayView::VDisPlayView() { //P_LIST cDatList; EnableAutomation(); } VDisPlayView::~VDisPlayView() { } HFONT C_SetFont(UINT uFont) { HFONT hFont = (HFONT)GetStockObject(DEFAULT_GUI_FONT); if (hFont == NULL) hFont = (HFONT)GetStockObject(ANSI_VAR_FONT); return hFont ; } void VDisPlayView::OnFinalRelease() { // When the last reference for an automation object is released // OnFinalRelease is called. The base class will automatically // deletes the object. Add additional cleanup required for your // object before calling the base class. CScrollView::OnFinalRelease(); } BEGIN_MESSAGE_MAP(VDisPlayView, CScrollView) ON_WM_CREATE() // ON_WM_MOUSEMOVE() ON_MESSAGE(WM_DRAWDATA, OnDrawData) // ON_WM_MOUSEHWHEEL() ON_WM_SIZE() // ON_WM_MOUSELEAVE() ON_WM_NCMOUSELEAVE() END_MESSAGE_MAP() BEGIN_DISPATCH_MAP(VDisPlayView, CScrollView) END_DISPATCH_MAP() // Note: we add support for IID_IViScroll to support typesafe binding // from VBA. This IID must match the GUID that is attached to the // dispinterface in the .IDL file. // {C1771C4B-2FF0-46ED-A4FE-D381086A49E4} static const IID IID_IViScroll = { 0xC1771C4B, 0x2FF0, 0x46ED, { 0xA4, 0xFE, 0xD3, 0x81, 0x8, 0x6A, 0x49, 0xE4 } }; BEGIN_INTERFACE_MAP(VDisPlayView, CScrollView) INTERFACE_PART(VDisPlayView, IID_IViScroll, Dispatch) END_INTERFACE_MAP() // VDisPlayView drawing void VDisPlayView::OnInitialUpdate() { //CScrollView::OnInitialUpdate(); //CSize sizeTotal; // TODO: calculate the total size of this view //sizeTotal.cx = sizeTotal.cy = 1000; // SetScrollSizes(MM_TEXT, sizeTotal); SetScrollSizes(MM_TEXT, CSize(VIEW_WIDTH,VIEW_HIGHT)); CScrollView::OnInitialUpdate(); } //void VDisPlayView::OnDraw(CDC* pDC) //{ // CDocument* pDoc = GetDocument(); // //CAutoPanDoc* pDoc = GetDocument(); // ASSERT_VALID(pDoc); // // // Get the invalidated rectangle of the view, or in the case // // of printing, the clipping region of the printer dc. // CRect rectClip; // CRect rectCloud; // pDC->GetClipBox(&rectClip;); // pDC->LPtoDP(&rectClip;); // rectClip.InflateRect(1, 1); // avoid rounding to nothing // // // Note: CScrollView::OnPaint() will have already adjusted the // // viewport origin before calling OnDraw(), to reflect the // // currently scrolled position. ///* for(int x=0; x<1600; x+=50) // { // for(int y=0; yFillSolidRect(rc, RGB(x,y,x*y)); // } // }*/ // // // // // TODO: add draw code here //} // VDisPlayView diagnostics #ifdef _DEBUG void VDisPlayView::AssertValid() const { CScrollView::AssertValid(); } #ifndef _WIN32_WCE void VDisPlayView::Dump(CDumpContext& dc) const { CScrollView::Dump(dc); } #endif #endif //_DEBUG // VDisPlayView message handlers int VDisPlayView::OnCreate(LPCREATESTRUCT lpCreateStruct) { if (CScrollView::OnCreate(lpCreateStruct) == -1) return -1; m_pDC=new CClientDC(this); uRowNumber=10000;// uColNumber=4; /* UINT uRowNumber ,uColNumber, *uPerCol_Width,*uPerRow_height ,;*/ uPerCol_Width =new WORD[uColNumber]; uPerRow_height=new WORD[uRowNumber]; UINT i; for(i=0;i<uColNumber;i++) { *(uPerCol_Width+i)=123; } *(uPerCol_Width+2)=323; for(i=0;ipvRemark=&cDatList; //LVS_EDITABELS 允许项文本能够适本地进行编辑。父窗口必须运行了LVN_ENDLABLEDIT //ListView_SetExtendedListViewStyle //cDatList.SetExtendedStyle(LVS_EX_GRIDLINES| LVS_EDITLABELS); /* LV_COLUMN lvcol; lvcol.mask = LVCF_SUBITEM | LVCF_TEXT | LVCF_WIDTH; lvcol.pszText = L"索引"; lvcol.iSubItem = 0; lvcol.cx = 130; cDatList.InsertColumn(0, &lvcol;); lvcol.mask = LVCF_SUBITEM | LVCF_TEXT | LVCF_WIDTH; lvcol.pszText = L"元件"; lvcol.iSubItem = 1; lvcol.cx = 130; cDatList.InsertColumn(1,&lvcol;); lvcol.mask = LVCF_SUBITEM | LVCF_TEXT | LVCF_WIDTH; lvcol.pszText = L"注释"; lvcol.iSubItem = 2; lvcol.cx = 130; cDatList.InsertColumn(2,&lvcol;); lvcol.mask = LVCF_SUBITEM | LVCF_TEXT | LVCF_WIDTH; lvcol.pszText = L"辅助标号"; lvcol.iSubItem = 3; lvcol.cx = 130; cDatList.InsertColumn(3,&lvcol;); */ // cDatList.InsertColumn(0, L"序号", LVCFMT_LEFT, 40); // cDatList.InsertColumn(1,L"地物名称", LVCFMT_LEFT, 80); // cDatList.InsertColumn(2,L"地物颜色", LVCFMT_LEFT, 120); // CString strName, strIndex; // int m; // for(int i=0; i<32; i++) // { // strIndex.Format(L"%d", i+1); // strName.Format(L"Class%d", i+1); // cDatList.InsertItem( i, strIndex); // cDatList.SetItemText(i, 1, strName); //cDatList.SetItemText(i, 1, strName); //cDatList.SetItemData(i, RGB(rand(), rand(), rand())); // } //cDatList.ApproximateViewRect(CSize(670,700),-1); //cDatList.SetRowHeigt(26); //cDatList.SetExtendedStyle(LVS_EX_FULLROWSELECT | LVS_EX_GRIDLINES | LVS_EX_HEADERDRAGDROP); //cDatList.Create(_T("CONTROL"),(LPCWSTR) NULL,WS_CHILD|WS_VISIBLE,rect,this,ID_FUNCTION_INSERT); /* if (!cDatList.CreateEx(0L,_T("CSCROLLVIEW"),(LPCWSTR) NULL, WS_CHILD|WS_VISIBLE| ES_AUTOHSCROLL|
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

wenchm

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值