乐筑天下

搜索
欢迎各位开发者和用户入驻本平台 尊重版权,从我做起,拒绝盗版,拒绝倒卖 签到、发布资源、邀请好友注册,可以获得银币 请注意保管好自己的密码,避免账户资金被盗
查看: 54|回复: 2

[编程交流] 按shor对选定实体排序

[复制链接]

31

主题

106

帖子

76

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
154
发表于 2022-7-5 18:08:54 | 显示全部楼层 |阅读模式
你好
有人能提出一种方法,按一个图元的终点坐标和下一个图元的起点坐标之间的最短距离对选定图元的列表进行排序吗?
 
下面是一个示例:

                               
登录/注册后可看大图

黄点代表实体的开始,数字是它们应该结束的顺序。
#1行最接近0,0;其终点坐标最接近拱门#2,然后是多段线#3,依此类推。
 
非常感谢。
 
附笔。
我试图实现的是优化绘图仪的绘图方式。它的驱动程序无法优化其绘制方式,这似乎遵循了在图形中创建实体的顺序。现在,我必须手动复制每个实体一个一个地在正确的顺序,我希望它的方式来绘图。。。
190856m8sava1m1181a1i6.png
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-5 18:48:34 | 显示全部楼层
该问题本质上是旅行商问题(即沿着最短路径访问所有节点)。以下是实现最近邻贪婪算法的解决方案-请注意,这种方法不会产生最佳结果:
  1. (defun sortentlist ( lst / foo rtn )
  2.    (setq foo
  3.        (lambda ( x l / a d r )
  4.            (setq d (distance (caddr x) (cadar l))
  5.                  r (car l)
  6.            )
  7.            (foreach y (cdr l)
  8.                (if (< (setq a (distance (cadr y) (caddr x))) d)
  9.                    (setq d a r y)
  10.                )
  11.            )
  12.            r
  13.        )
  14.    )
  15.    (setq lst (mapcar '(lambda ( x ) (list x (vlax-curve-getstartpoint x) (vlax-curve-getendpoint x))) lst)
  16.          rtn (list (car lst))
  17.          lst (cdr lst)
  18.    )
  19.    (while lst
  20.        (setq rtn (cons (foo (car rtn) lst) rtn)
  21.              lst (vl-remove (car rtn) lst)
  22.        )
  23.    )
  24.    (reverse (mapcar 'car rtn))
  25. )

 
该算法也可以使用排序来实现,但效率较低:
  1. (defun sortentlist ( lst / rtn )
  2.    (setq lst (mapcar '(lambda ( x ) (list x (vlax-curve-getstartpoint x) (vlax-curve-getendpoint x))) lst)
  3.          rtn (list (car lst))
  4.          lst (cdr lst)
  5.    )
  6.    (while lst
  7.        (setq lst (vl-sort lst '(lambda ( a b ) (< (distance (caddar rtn) (cadr a)) (distance (caddar rtn) (cadr b)))))
  8.              rtn (cons (car lst) rtn)
  9.              lst (vl-remove (car rtn) lst)
  10.        )
  11.    )
  12.    (reverse (mapcar 'car rtn))
  13. )
回复

使用道具 举报

106

主题

1万

帖子

101

银币

顶梁支柱

Rank: 50Rank: 50

铜币
1299
发表于 2022-7-5 19:35:19 | 显示全部楼层
李这不是另一个帖子的问题,如何使激光切割机做下一个最接近的项目,节省头部移动时间。
回复

使用道具 举报

发表回复

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

QQ|关于我们|小黑屋|乐筑天下 繁体中文

GMT+8, 2025-3-12 19:26 , Processed in 0.358734 second(s), 61 queries .

© 2020-2025 乐筑天下

联系客服 关注微信 帮助中心 下载APP 返回顶部 返回列表