开源改变世界!!

加载文件时出错“错误启动流:空” #1282

推推 grbl 2年前 (2023-01-28) 154次浏览
打开
绕线器 打开了这个问题 2019 年 10 月 7 日 · 11 条评论
打开

加载文件时出错“错误启动流:空”#1282

绕线器 打开了这个问题 2019 年 10 月 7 日 · 11 条评论

注释

加载文件时出错“错误启动流:空” #1282
所有者

问题描述

加载程序时,可能会快速单击发送并出现此错误。我通过在一台非常慢的计算机(2010 年的上网本,1.6 GHz Intel Atom N270 处理器,1 GB RAM)上运行一个相当大的程序(80k 行)注意到了这一点

发送按钮起作用之前可能需要 10 多秒。

据推测这是因为文件在加载时被处理并序列化为文件,直到该过程完成发送才有问题。

预期行为

更好的错误消息或进度指示器。

加载文件时出错“错误启动流:空” #1282 绕线器 添加了 漏洞 标签 2019 年 10 月 7 日
加载文件时出错“错误启动流:空” #1282
滚珠丝杠鲍勃 评论了 2019 年 10 月 13 日  

这一直是一个问题/错误,文件越大,某些文件导致 UGS 锁定的情况就越糟糕。我不认为进度指示器会有帮助,因为根本原因似乎在于文件处理本身。
不过,更好的消息可能会更好。

系统速度似乎并不重要,因为具有 8 GB(很快将达到 16 GB)的四核 AMD 具有相当精简和干净的操作系统(win 7 pro 但经过调整)仍然会遇到这些问题。

此外,当您运行大文件时,UGS 上的控件通常不会在运行时响应,因此更好地中断按钮也需要成为同一问题的一部分。
我可以在控制台中看到发出了取消文件传输的命令,但除非文件很小,否则它根本不会执行该操作。

加载文件时出错“错误启动流:空” #1282
合作者

这里有一些问题可能会影响您的体验@BallscrewBob你可能是对的,这只会显示问题的症状。例如,#1197表明我们将打开的流加载并保存到文件中多次。

我在加载文件时添加了额外的日志消息,这似乎是打开文件时的 4 次。

INFO [com.willwinder.ugs.nbm.visualizer.RendererInputHandler]: Loading file /Users/zefal/Development/Universal-G-Code-Sender/test_files/circle.gcode
INFO [com.willwinder.ugs.nbm.visualizer.renderables.GcodeModel]: About to process {}
INFO [com.willwinder.ugs.nbm.visualizer.renderables.GcodeModel]: Done setting gcode file.
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Start preprocessing
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Preprocessing /Users/zefal/Development/Universal-G-Code-Sender/test_files/circle.gcode to /private/var/folders/3v/0fyq0c51003cc_h7cwdwbngm0000gn/T/1570947536295-0/circle.gcode_ugs_1570947536297
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Took 126ms to preprocess
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Getting processed gcode file.
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Getting processed gcode file.
INFO [com.willwinder.universalgcodesender.uielements.panels.SendStatusPanel]: Loading file circle.gcode_ugs_1570947536297
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Getting processed gcode file.
INFO [com.willwinder.ugs.nbm.visualizer.RendererInputHandler]: Loading file /var/folders/3v/0fyq0c51003cc_h7cwdwbngm0000gn/T/1570947536295-0/circle.gcode_ugs_1570947536297
INFO [com.willwinder.ugs.nbm.visualizer.renderables.GcodeModel]: About to process {}
INFO [com.willwinder.ugs.nbm.visualizer.renderables.GcodeModel]: Done setting gcode file.
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Getting processed gcode file.
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Getting processed gcode file.
INFO [com.willwinder.universalgcodesender.uielements.toolbars.SendStatusLine]: Loading file circle.gcode_ugs_1570947536297
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Getting processed gcode file.
INFO [com.willwinder.universalgcodesender.utils.SettingsFactory]: Saving settings.
INFO [org.netbeans.core.ui.focus]: External Changes Refresh on focus gain disabled

启动文件流时,状态面板似乎多次打开文件:

INFO [com.willwinder.ugs.nbp.core.actions.ConnectDisconnectAction]: openclose button, connection open: false
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Connecting to Testing (Delay) on port tty.usbmodem1421
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Setting gcode file.
INFO [com.willwinder.ugs.nbm.visualizer.RendererInputHandler]: Loading file /Users/zefal/Development/Universal-G-Code-Sender/test_files/circle.gcode
INFO [com.willwinder.ugs.nbm.visualizer.renderables.GcodeModel]: About to process {}
INFO [com.willwinder.ugs.nbm.visualizer.renderables.GcodeModel]: Done setting gcode file.
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Start preprocessing
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Preprocessing /Users/zefal/Development/Universal-G-Code-Sender/test_files/circle.gcode to /private/var/folders/3v/0fyq0c51003cc_h7cwdwbngm0000gn/T/1570947536295-0/circle.gcode_ugs_1570947717383
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Took 6ms to preprocess
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Getting processed gcode file.
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Getting processed gcode file.
INFO [com.willwinder.universalgcodesender.uielements.panels.SendStatusPanel]: Loading file circle.gcode_ugs_1570947717383
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Getting processed gcode file.
INFO [com.willwinder.ugs.nbm.visualizer.RendererInputHandler]: Loading file /var/folders/3v/0fyq0c51003cc_h7cwdwbngm0000gn/T/1570947536295-0/circle.gcode_ugs_1570947717383
INFO [com.willwinder.ugs.nbm.visualizer.renderables.GcodeModel]: About to process {}
INFO [com.willwinder.ugs.nbm.visualizer.renderables.GcodeModel]: Done setting gcode file.
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Getting processed gcode file.
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Getting processed gcode file.
INFO [com.willwinder.universalgcodesender.uielements.toolbars.SendStatusLine]: Loading file circle.gcode_ugs_1570947717383
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Getting processed gcode file.
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Applying settings.
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Setting gcode file.
INFO [com.willwinder.ugs.nbm.visualizer.RendererInputHandler]: Loading file /Users/zefal/Development/Universal-G-Code-Sender/test_files/circle.gcode
INFO [com.willwinder.ugs.nbm.visualizer.renderables.GcodeModel]: About to process {}
INFO [com.willwinder.ugs.nbm.visualizer.renderables.GcodeModel]: Done setting gcode file.
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Start preprocessing
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Preprocessing /Users/zefal/Development/Universal-G-Code-Sender/test_files/circle.gcode to /private/var/folders/3v/0fyq0c51003cc_h7cwdwbngm0000gn/T/1570947536295-0/circle.gcode_ugs_1570947717606
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Took 7ms to preprocess
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Getting processed gcode file.
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Getting processed gcode file.
INFO [com.willwinder.universalgcodesender.uielements.panels.SendStatusPanel]: Loading file circle.gcode_ugs_1570947717606
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Getting processed gcode file.
INFO [com.willwinder.ugs.nbm.visualizer.RendererInputHandler]: Loading file /var/folders/3v/0fyq0c51003cc_h7cwdwbngm0000gn/T/1570947536295-0/circle.gcode_ugs_1570947717606
INFO [com.willwinder.ugs.nbm.visualizer.renderables.GcodeModel]: About to process {}
INFO [com.willwinder.ugs.nbm.visualizer.renderables.GcodeModel]: Done setting gcode file.
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Getting processed gcode file.
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Getting processed gcode file.
INFO [com.willwinder.universalgcodesender.uielements.toolbars.SendStatusLine]: Loading file circle.gcode_ugs_1570947717606
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Getting processed gcode file.
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Start preprocessing
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Took 0ms to preprocess
WARNING [org.openide.util.ImageUtilities]: Initial slashes in Utilities.loadImage deprecated (cf. #20072): /org/netbeans/core/windows/resources/error.png
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Sending gcode file.
INFO [com.willwinder.universalgcodesender.model.GUIBackend]: Loading file circle.gcode_ugs_1570947717606

@winder我在想创建一个稍后可以流式传输的预处理文件的想法是个好主意。但是无论如何,我们将几乎所有数据加载到 Visualizer 的内存中。

我想知道我们是否应该尝试重写文件加载机制,一次将整个文件读入内存,然后创建从内存而不是文件流读取的 gcodestreamer?

加载文件时出错“错误启动流:空” #1282
滚珠丝杠鲍勃 评论了 2019 年 10 月 13 日  

从我的角度来看,这是一个非常好的主意。
阻止我完全信任 UGS 的原因是我不得不关闭该程序很多次,而且我 100% 确定它按照您建议的方式处理文件。

只是为了添加一些辅助信息,该文件经常被任何人检查,我的意思是任何防病毒软件。
这可能会使问题复杂化,我目前正在积极测试这一点,因为通过在 Win 7 pro 下的 USER 文件夹中添加目录,我已经至少将程序本身的加载时间提高了 75%。

二是改进加载系统的想法。

加载文件时出错“错误启动流:空” #1282
所有者作者

@breiler我认为清理文件加载是个好主意,但我不确定它会如何导致事件延迟。也许其中EvokeLater一个事件处理程序落后了,这可能会导致复杂的问题,最终使 UI 停止运行。

加载文件时出错“错误启动流:空” #1282

我们在 2Gb ram 的 WIndows 10 mini PC 上加载超过 1,000,000 行长的文件。我们的技巧是打开“发送进度”窗口并等待“文件中的行”填充,然后单击播放。我们通常会关闭可视化工具窗口,但如果您不这样做,请注意刀具路径图形将在文件显示在“发送进度”窗口中很久之前加载。我们的计算机等待一百万行以上的文件可能需要几分钟,但它始终会加载。

另一方面,事实证明,更改某些窗口可以解决大文件的一些冻结问题。

  1. 将性能设置更改为最大性能
  2. 关闭通知
  3. 关闭所有后台应用程序
  4. 在启动时禁用所有不需要的程序。

不确定这是否有帮助,但它似乎对我们有用。在这些长时间运行期间,UGS 命令似乎不可用,但我们的硬连线“暂停”和“恢复”按钮有效。

只是为了补充信息。我们的文件以每分钟 200 到 300 英寸的速度切割,大多数时候 Z 会减慢速度。这些文件需要 5 到 9 个小时才能运行。

加载文件时出错“错误启动流:空” #1282
滚珠丝杠鲍勃 评论了 2019 年 10 月 16 日  

@rlwoodjr.

虽然这些步骤确实有助于解决问题,但
这里的 Box 已经设置为最高性能,甚至很多普通人看不到的设置也在这里进行了调整。启动也被削减了很多。

当使用覆盖将作业速度提高到 MAX 时,这里的速度和进给可能会导致一些轻微的滞后,而降低到较慢的进给似乎不会造成问题,而且似乎确实有帮助。
取决于任务和材料,这里也有类似的工作时间。(以木雕为主)

此外,在这些锁定或停顿期间,UNLOCK 和 SOFT RESET 可能变得不可用。

加载文件时出错“错误启动流:空” #1282

我从我们的测试中了解到,在以“快速”进给速率运行的大文件中,会导致 GUI 和串行通信之间出现滞后。因此 GUI 不是实时的。它落后了。当我们完成一个大文件(主轴返回原位,项目完成)时,UGS 屏幕仍有 30% 到 50% 的行需要处理。实际上,我让它继续运行了几次,它最终完成并返回了 GUI。这适用于 16Gb 双处理器或 2Gb 微型计算机。

使用我们的正常生产文件(小而多的直线),GUI 保持同步。

加载文件时出错“错误启动流:空” #1282
滚珠丝杠鲍勃 评论了 2019 年 10 月 19 日  

无论是光栅还是基于曲线的矢量,我都可以获得相同的锁定。
不要认为它是可视化工具(没有它运行)而不是完全速度设置(一直运行默认或较低速度)

过去几天的测试似乎表明控制台可能是大部分问题的幕后黑手。
在接下来的几天内尝试不使用控制台,看看是否有帮助。

加载文件时出错“错误启动流:空” #1282

跟进…
两个不同的作业都在没有可视化器和控制台的情况下运行。
我仍然可以进入滞后/失速状态。

接下来是在没有 DRO 显示器的情况下运行相同的作业,因为我可以清楚地看到那里也有一些问题,因为它断断续续。

令人高兴的是,STOP / PAUSE 命令现在似乎可以更快地工作,而无需在出现错误框之前进行长时间的停顿。
但它仍然没有使 GUI 的其余部分恢复正常,并且大多数选项仍然显示为灰色/不可用。

加载文件时出错“错误启动流:空” #1282

更新
即使没有启用 DRO 并且其他所有东西都关闭了可视化器等,大文件大小也会出现延迟和滞后/停顿问题。
奇怪的是 SourceRabbit 没有给我同样的问题。可惜我不太喜欢那个,因为它没有 UGS 的感觉。

加载文件时出错“错误启动流:空” #1282 绕线器 添加 表现 并删除 表现 标签 2020 年 1 月 6 日
加载文件时出错“错误启动流:空” #1282
合作者

免费注册 在 GitHub 上加入此对话。已有帐户? 登录评论
标签
项目

还没有

发展

没有分支机构或拉取请求

4人参加
加载文件时出错“错误启动流:空” #1282加载文件时出错“错误启动流:空” #1282加载文件时出错“错误启动流:空” #1282加载文件时出错“错误启动流:空” #1282

喜欢 (0)