找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 508|回复: 6

[每日一码] 一组纯数学实现几何函数

[复制链接]

已领礼包: 20个

财富等级: 恭喜发财

发表于 2017-7-20 22:15:06 | 显示全部楼层 |阅读模式

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

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

×
1 点是否在直线上

  1. (defun pointonline (pt p0 p1 /)
  2.   (if (and pt p0 p1)
  3.     (if        (equal (+ (distance p0 pt) (distance p1 pt))
  4.                (distance p0 p1)
  5.                0.00001
  6.         )
  7.       T
  8.     )
  9.   )
  10. )


2 圆弧长度

游客,本帖隐藏的内容需要积分高于 50 才可浏览,您当前积分为 0


3 点是否在圆弧上

  1. (defun pointonarc (pt cen r pa1 pa2 /)
  2.   (if (and pa1 pa2)
  3.     (if
  4.       (equal (+ (arclength cen r pa1 pt) (arclength cen r pt pa2))
  5.              (arclength cen r pa1 pa2)
  6.              0.00001
  7.       )
  8.        T
  9.     )
  10.     (if        (equal (distance cen pt) r 0.00001)
  11.       T
  12.     )
  13.   )
  14. )


4 直线和圆的交点

  1. (defun inters_linecircle (pl1  pl2  cen         r    pa1  pa2        cve  /          x1
  2.                           y1   x2   y2         h    r2   k        yt1  yt2  pt1
  3.                           pt2  m    yk2         xt1  xt2  a        b    c          z
  4.                           lst1
  5.                          )
  6.   (setq        x1  (car pl1)
  7.         y1  (cadr pl1)
  8.         x2  (car pl2)
  9.         y2  (cadr pl2)
  10.         r2  (expt r 2)
  11.         h   (car cen)
  12.         xh2 (expt (- x1 h) 2)
  13.         k   (cadr cen)
  14.   )
  15.   (if (equal x2 x1 0.00001)
  16.     (if        (>= r2 xh2)
  17.       (setq yt1        (+ (expt (- r2 xh2) 0.5) k)
  18.             yt2        (- k (expt (- r2 xh2) 0.5))
  19.             pt1        (list x1 yt1)
  20.             pt2        (list x1 yt2)
  21.       )
  22.     )
  23.     (progn
  24.       (setq m (/ (- y2 y1) (- x2 x1)))
  25.       (if (equal m 0 0.00001)
  26.         (if (>= r2 (setq yk2 (expt (- y1 k) 2)))
  27.           (setq        xt1 (+ (expt (- r2 yk2) 0.5) h)
  28.                 xt2 (- h (expt (- r2 yk2) 0.5))
  29.                 pt1 (list xt1 y1)
  30.                 pt2 (list xt2 y2)
  31.           )
  32.         )
  33.         (progn
  34.           (setq        a (+ 1.0 (expt m 2))
  35.                 b (- (* 2.0 m (- x1 h (* m k))) (* 2.0 y1))
  36.                 c (+ (expt (+ (* m (- h x1)) y1) 2)
  37.                      (* (expt m 2) (- (expt k 2) r2))
  38.                   )
  39.           )
  40.           (if (>= (setq z (- (expt b 2) (* 4 a c))) 0)
  41.             (setq yt1 (/ (- (expt z 0.5) b) (* 2.0 a))
  42.                   yt2 (/ (* -1.0 (+ (expt z 0.5) b)) (* 2.0 a))
  43.                   xt1 (+ (/ (- yt1 y1) m) x1)
  44.                   xt2 (+ (/ (- yt2 y1) m) x1)
  45.                   pt1 (list xt1 yt1)
  46.                   pt2 (list xt2 yt2)
  47.             )
  48.           )
  49.         )
  50.       )
  51.     )
  52.   )
  53.   (if (= cve "")
  54.     (progn
  55.       (if (and pt1
  56.                (pointonline pt1 pl1 pl2)
  57.                (pointonarc pt1 cen r pa1 pa2)
  58.           )
  59.         (setq lst1 (append lst1 (list pt1)))
  60.       )
  61.       (if (and pt2
  62.                (pointonline pt2 pl1 pl2)
  63.                (pointonarc pt2 cen r pa1 pa2)
  64.           )
  65.         (setq lst1 (append lst1 (list pt2)))
  66.       )
  67.     )
  68.     (setq lst1 (append lst1 (list pt1) (list pt2)))
  69.   )
  70.   lst1
  71. )


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

已领礼包: 6056个

财富等级: 富甲天下

发表于 2017-7-21 00:08:46 | 显示全部楼层
谢谢分享,收藏了。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 604个

财富等级: 财运亨通

发表于 2017-7-21 07:59:43 | 显示全部楼层
直线同弧最近的一个交点,怎么求?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 773个

财富等级: 财运亨通

发表于 2017-7-21 12:43:08 | 显示全部楼层
谢谢大师分享,收藏了!!!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 19个

财富等级: 恭喜发财

发表于 2017-7-21 12:59:44 | 显示全部楼层

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

使用道具 举报

已领礼包: 24个

财富等级: 恭喜发财

发表于 2017-12-2 17:53:02 | 显示全部楼层
谢谢,看看
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复

使用道具 举报

已领礼包: 488个

财富等级: 日进斗金

发表于 2017-12-6 11:00:17 | 显示全部楼层
直线和圆的交点,是不是应该加入一个参数,看是否要延伸
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-9-23 22:32 , Processed in 0.387445 second(s), 40 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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