找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1666|回复: 9

[研讨] 拟合直线

[复制链接]

已领礼包: 1883个

财富等级: 堆金积玉

发表于 2016-4-13 20:28:04 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

×
(defun c:tt()
  (setq sn (ssget ":N" '((0 . "point"))))
  (setq i 0 n (sslength sn) plist nil)
  (while (< i n)
        (setq plist (cons (cdr (assoc 10 (entget (ssname sn i)))) plist))
        (setq i (+ i 1))
   )

  (setq xlist (mapcar '(lambda (x) (car x)) plist))
  (setq ylist (mapcar '(lambda (y) (cadr y)) plist))
  (setq xmin (apply 'min xlist))
  (setq xmax (apply 'max xlist))
  (setq x_av (/ (apply '+ xlist) (float n)))
  (setq y_av (/ (apply '+ ylist) (float n)))
  (setq xy_av (/ (apply '+ (mapcar '(lambda (xy) (* (car xy) (cadr xy))) plist)) (float n)) )
  (setq xx_av (/ (apply '+ (mapcar '(lambda (xx) (* (car xx) (car xx))) plist)) (float n)) )
  (setq B (/ (- (* x_av y_av) xy_av) (- (* x_av x_av) xx_av)))
  (setq A (- y_av (* B x_av)))
  (command "line" (list xmin (+ A (* B xmin))) (list xmax (+ A (* B xmax))) "")
)
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!

已领礼包: 145个

财富等级: 日进斗金

发表于 2016-4-13 21:39:04 | 显示全部楼层
楼主能否和大家说说你的程序如何操作,和你对拟合直线的想法啊?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1883个

财富等级: 堆金积玉

 楼主| 发表于 2016-4-13 23:10:42 来自手机 | 显示全部楼层
算法就是按最小二乘法的结果输出,显示该拟合直线而已。直观上来说,拟合直线"附近"区域点分布密集些,远离拟合直线区域点分布稀疏些。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 5604个

财富等级: 富甲天下

发表于 2016-4-14 07:48:32 | 显示全部楼层
楼主,这是个好程序,再盼望你能开发一种拟合为圆弧的程序。谢谢!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 6个

财富等级: 恭喜发财

发表于 2016-4-14 08:32:22 | 显示全部楼层
试了下楼主的程序,如图,黄*色线是程序生成的,矩形框是点集的最小矩形框,请问下楼主,你的算法生成的直线和最小矩形框有什么关系?
搜狗截图20160414082631.png

点评

没有任何关系.  详情 回复 发表于 2016-4-14 20:01
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1883个

财富等级: 堆金积玉

 楼主| 发表于 2016-4-14 20:01:55 | 显示全部楼层
CSharpBoy 发表于 2016-4-14 08:32
试了下楼主的程序,如图,黄*色线是程序生成的,矩形框是点集的最小矩形框,请问下楼主,你的算法生成的直 ...


没有任何关系.
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2016-6-7 16:44:24 | 显示全部楼层
首先我要点赞,最新进展如何?

点评

什么最新进展?  详情 回复 发表于 2016-6-7 22:32
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1883个

财富等级: 堆金积玉

 楼主| 发表于 2016-6-7 22:32:19 | 显示全部楼层
WhoCanSay 发表于 2016-6-7 16:44
首先我要点赞,最新进展如何?

什么最新进展?

点评

pdf的直线,如果是斜的,转成dwg就是很多短直线,如何框选转成直线?进入这一实用步骤没有?  详情 回复 发表于 2016-6-8 08:16
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2016-6-8 08:16:54 | 显示全部楼层

pdf的直线,如果是斜的,转成dwg就是很多短直线,如何框选转成直线?进入这一实用步骤没有?

点评

试试插件论坛的支持容差的批量融合线段插件。  详情 回复 发表于 2016-6-8 09:12
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 40个

财富等级: 招财进宝

发表于 2016-6-8 09:12:10 | 显示全部楼层
WhoCanSay 发表于 2016-6-8 08:16
pdf的直线,如果是斜的,转成dwg就是很多短直线,如何框选转成直线?进入这一实用步骤没有?

试试插件论坛的支持容差的批量融合线段插件。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-12-22 11:02 , Processed in 0.461717 second(s), 51 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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