找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 124|回复: 0

[几何] XD::GEOM:POINT-FUZ

[复制链接]

已领礼包: 40个

财富等级: 招财进宝

发表于 2025-5-11 19:39:40 | 显示全部楼层 |阅读模式

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

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

×
  1. ;; ------------------------------------------------------------------------
  2. ;;; 函数名称 / Function Name: XD::GEOM:POINT-FUZ
  3. ;;;
  4. ;;; 【功能说明 / Description】
  5. ;;;     检测点在两个不同基向量定义的坐标系之间往返变换时产生的数值误差。
  6. ;;;     通过测量点经过两次坐标系转换(v1 -> v2 -> v1)后的位置偏差,评估坐标变换函数的数值稳定性和准确性。
  7. ;;;     同时对点坐标放大两倍后重复测试,检测误差随坐标尺度变化的情况。
  8. ;;;
  9. ;;; 【参数说明 / Parameters】
  10. ;;;     p1 - (list) 二维或三维点坐标列表,例如 (x y) 或 (x y z)
  11. ;;;
  12. ;;; 【返回值 / Return Value】
  13. ;;;     (float) 点经过两次往返变换后的位置偏差距离的最大值。
  14. ;;;
  15. ;;; 【依赖函数 / Dependencies】
  16. ;;;     - trans : 坐标系转换函数,格式 (trans point from-basis to-basis)
  17. ;;;     - distance : 计算两点欧氏距离函数,格式 (distance point1 point2)
  18. ;;;
  19. ;;; 【使用示例 / Example Usage】
  20. ;;;     (XD::GEOM:POINT-FUZ '(1.0 2.0 3.0))
  21. ;;;     => 返回点经过两次变换后的最大误差距离
  22. ;;;
  23. ;;; 【备注 / Notes】
  24. ;;;     - v1 和 v2 是两个不同方向的基向量,v2 不能与 v1 共线或为零向量。
  25. ;;;     - 该函数适合用于调试和评估坐标变换模块的数值稳定性。
  26. ;;;
  27. (defun XD::GEOM:POINT-FUZ (p1)
  28.   ;; 该函数用于检测点在两个不同基向量定义的坐标系之间往返变换时产生的数值误差。
  29.   ;; 输入:
  30.   ;;   p1 - 一个二维或三维点坐标 (x y) 或 (x y z)
  31.   ;; 输出:
  32.   ;;   返回点经过两次基向量空间变换后的位置偏差距离的最大值,反映变换函数的数值稳定性和误差大小。

  33.   ;; 1. 确保点为三维坐标,方便统一处理
  34.   (if (= (length p1) 2)
  35.     (setq p1 (list (first p1) (second p1) 0.0))
  36.   )

  37.   ;; 2. 定义两个基向量 v1 和 v2,代表两个不同的坐标系方向
  38.   ;;    v1 是 z 轴单位向量 (0,0,1)
  39.   ;;    v2 是指向空间对角线方向的向量 (sin(π/4), sin(π/4), sin(π/4)) ≈ (0.7071,0.7071,0.7071)
  40.   (setq v1 '(0.0 0.0 1.0))
  41.   (setq v2 (sin (/ pi 4.0)))
  42.   (setq v2 (list v2 v2 v2))

  43.   ;; 3. 通过 trans 函数,将点从 v1 坐标系变换到 v2 坐标系,再变换回 v1 坐标系
  44.   ;;    理论上点应回到原位,但实际中会有数值误差
  45.   (setq p2 (trans p1 v1 v2))
  46.   (setq p2 (trans p2 v2 v1))

  47.   ;; 4. 计算变换前后点的欧氏距离,作为误差指标
  48.   (setq d (distance p1 p2))

  49.   ;; 5. 将点坐标放大两倍,重复上述变换和误差计算
  50.   ;;    用于检测误差随坐标尺度变化的情况
  51.   (setq p1 (mapcar (lambda (x) (* 2 x)) p1))
  52.   (setq p2 (trans p1 v1 v2))
  53.   (setq p2 (trans p2 v2 v1))
  54.   (setq d (max d (distance p1 p2)))

  55.   ;; 6. 返回最大误差距离,反映变换函数的数值稳定性
  56.   d
  57. )

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

本版积分规则

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

GMT+8, 2025-9-7 02:36 , Processed in 0.149133 second(s), 29 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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