亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? 步進法凸包改進4.lsp

?? 計算幾何中的幾種lisp語言的算法
?? LSP
字號:
;;;************************************************************************
;;;一個求點集合的凸包的lisp程序--------------------------------------------
;;;------采用的算法為禮品包扎法--------------------------------------------
;;;方法為最右端的點開始處理,將該點作為凸包邊界的第一個點P1,從最初的垂直線
;;;方向繞P1順時針旋轉,直到碰到另一個P2這就是凸包邊界的第二個點P2,依此類推
;;;p2求得p3......直到又重新回到p1,已經考慮了各種退化情況和浮點運算,其算法
;;;時間不超過O(n.h),其中h是凸包的復雜度,時間還是很快的。大家不妨驗證。    
;;;參考文獻<<計算幾何-算法及其應用>>(第二版),以及參考了其他網站的一些源代碼
;;;------------------------------------------------------------------------
;;;其中程序主段是核心算法,其他的附加程序為取得點集,畫凸包邊界線,測試大量
;;;點集函數處理所花費的時間。----------------------------------------------
;;;用法: 加載lisp運行test選取點,直線段,或多義線(全是直線段組成)即可。----
;;;************************************************************************
(defun C:test (/ sel t0 ptlist pp 2Pi)
  (setq 2Pi (* 2 pi))
  (setq	sel (ssget (list '(0 . "POINT"))))                  ;選擇點集
  (if (setq ptlist (getpt sel))                             ;構造點集
    (progn
      (setq t0 (getvar "TDUSRTIMER"))                       ;開始計時
      (setq pp (hull ptlist))                               ;求凸包
      (princ "\n用時")  
      (princ (* (- (getvar "TDUSRTIMER") t0) 86400))        ;結束計時
      (princ "秒")
    )
  )
  (if (null pp)
    (alert "點的有效數目太小,請重新輸入!")
    (entmake                                                ;畫凸包
      (append
       '( (0 . "LWPOLYLINE")
	  (100 . "AcDbEntity")
	  (100 . "AcDbPolyline")
	)
	(list (cons 90 (length pp)))                        ;頂點個數
	(mapcar '(lambda (x) (cons 10 x)) pp)               ;多段線頂點
	(list (cons 70 1))                                  ;閉合的
	(list (cons 62 1))                                  ;紅色的
      )
    )
  )
  (princ)
)
;;;==========================
;;;程序主段,可以單獨成為函數
;;;==========================

;;;右半部的凸包
(defun hull1 (pts MaxPt MinPt / nextPt hullPt)
  (if pts 
    (progn
      (setq nextPt (Max-angle1 pts MaxPt))                  ;從最上面的點開始
      (setq hullPt (cons nextPt (cons MaxPt hullPt)))       ;順時針求得第一點
      (while (not (equal nextPt MinPt 1e-8))                ;到最下面的點為止
        (setq nextPt (Max-angle pts nextPt))                ;循環求凸包每一點
	(setq hullPt (cons nextPt hullPt))                  ;把每點加入凸包集
      )
    )
  )
)
;;;左半部的凸包
(defun hull (ptlist / revPts 2ndPts maxYp1 minYp1 maxYp2 minYp2
	              ptlst1 ptlst2 +ptlst -ptlst hullp1 hullp2)
  (setq revPts (mapcar 'reverse ptlist))                    ;點表的X和Y交換
  (setq 2ndPts (mapcar 'cadr ptlist))                       ;點表的Y值的表
  (setq maxYp1 (reverse (assoc (apply 'max 2ndPts) revPts)));最上面的點
  (setq minYp1 (reverse (assoc (apply 'min 2ndPts) revPts)));最下面的點
  (setq maxYp2 (list (- (car maxYp1)) (cadr maxYp1)))       ;鏡像后最上面的點
  (setq minYp2 (list (- (car minYp1)) (cadr minYp1)))       ;鏡像后最下面的點
  (foreach n ptlist                                         ;把點表分成兩部分
    (if (> (det minYp1 n maxYp1) 0)                         ;如果左轉
      (setq ptlst1 (cons n ptlst1))                         ;加入右半部分
      (setq ptlst2 (cons n ptlst2))                         ;否則左半部分
    )
  )
  (setq +ptlst (cons minYp1 (cons maxYp1 ptlst1)))          ;右半部分
  (setq -ptlst (Mirror-list-X ptlst2))                      ;左半部分以Y軸鏡像
  (setq hullp1 (hull1 +ptlst maxYp1 minYp1))                ;右半部分的凸包
  (setq hullp2 (hull1 -ptlst maxYp2 minYp2))                ;左半部分鏡像的凸包
  (setq hullp2 (cdr (reverse (cdr hullp2))))
  (setq hullp2 (Mirror-list-X hullp2))                      ;左半部分的凸包
  (append hullp1 hullp2)                                    ;把凸包左右相加
)
;;;鏡像左半部分
(defun Mirror-list-X (ptlist)
  (mapcar (function (lambda (x)(list (- (car x))(cadr x)))) ptlist)
)
;;;求點集中夾角的最大值的點
(defun Max-angle (ptlist pt / An)
  (setq An (mapcar (function (lambda (x) (angle pt x))) ptlist))
  (nth (- (length An) (length (member (apply 'max An) An))) ptlist)
)
(defun Max-angle1 (ptlist pt / An)
  (setq An
    (mapcar
      (function
        (lambda (x)
	  (if
	    (and
	      (equal (cadr x) (cadr pt) 1e-8)
	      (> (car x) (car pt))
	    )
	    (+ 2Pi (- (car x) (car pt)))
	    (angle pt x)
	  )	   
	)
      )
      ptlist
    )
  )
  (nth (- (length An) (length (member (apply 'max An) An))) ptlist)
)
;;定義三點的行列式,即三點之倍面積
(defun det (p1 p2 p3 / dx1 dy1 dx2 dy2)
  (setq	dx1 (- (car  p2) (car  p1))
	dy1 (- (cadr p2) (cadr p1))
	dx2 (- (car  p3) (car  p1))
	dy2 (- (cadr p3) (cadr p1))
  )
  (- (* dx1 dy2) (* dx2 dy1))
)				     
;;;============
;;;程序主段結束
;;;============

;;;依據曉東網站的代碼改寫而成的取點函數
(defun getpt (ss / a b c d i p)
  (setq	i 0)
  (if ss
    (repeat (sslength ss)
      (setq a (ssname ss i))
      (setq b (entget a))
      (setq c (cdr (assoc 10 b)))
      (setq c (list (car c) (cadr c)))
      (setq p (cons c p))
      (setq i (1+ i))
    )
  )
  p
)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美亚洲禁片免费| 韩国女主播成人在线| 国产精品入口麻豆九色| 精品三级在线观看| 26uuu久久综合| 久久中文字幕电影| 欧美国产精品v| 中文字幕一区免费在线观看 | 日韩精品国产精品| 午夜精品一区二区三区电影天堂| 一区二区三区欧美亚洲| 有码一区二区三区| 婷婷一区二区三区| 国产一区亚洲一区| 成人福利视频在线| 欧美中文字幕亚洲一区二区va在线| 在线区一区二视频| 欧美精品久久99| 久久天天做天天爱综合色| 欧美国产日韩精品免费观看| 中文字幕在线播放不卡一区| 亚洲男人的天堂一区二区| 亚洲电影一级片| 免费看欧美美女黄的网站| 国产一区二区影院| 色88888久久久久久影院野外| 欧美视频一区二| 日韩欧美高清dvd碟片| 亚洲国产高清aⅴ视频| 亚洲一区二区黄色| 国产中文字幕一区| 91啪亚洲精品| 日韩免费性生活视频播放| 亚洲欧洲日韩av| 日韩电影在线一区| 国产.欧美.日韩| 欧美日韩成人在线| 亚洲欧美在线高清| 美女尤物国产一区| 色播五月激情综合网| 26uuu亚洲综合色| 亚洲精品日产精品乱码不卡| 久久99在线观看| 色噜噜狠狠色综合欧洲selulu| 日韩一区二区三区电影在线观看| 中文字幕免费观看一区| 蜜臀a∨国产成人精品| 91色在线porny| 国产婷婷色一区二区三区在线| 日韩制服丝袜av| 在线免费观看日本一区| 国产免费观看久久| 久草热8精品视频在线观看| 在线亚洲一区二区| 国产精品高潮呻吟| 国产原创一区二区| 日韩女同互慰一区二区| 亚洲一区中文日韩| 91色九色蝌蚪| 亚洲男人的天堂一区二区| 国产激情视频一区二区在线观看| 日韩三级在线观看| 日韩中文欧美在线| 欧美精品在欧美一区二区少妇| 亚洲欧美日韩综合aⅴ视频| 国产精品伊人色| 欧美精品一区二区三区视频| 天天操天天干天天综合网| 欧美亚洲日本国产| 亚洲自拍偷拍麻豆| 91行情网站电视在线观看高清版| 国产精品国产三级国产专播品爱网| 激情六月婷婷久久| 久久亚洲欧美国产精品乐播| 精品中文av资源站在线观看| 日韩一区二区精品在线观看| 亚洲3atv精品一区二区三区| 欧美日韩精品一区二区三区蜜桃 | 蜜桃一区二区三区在线观看| 欧美日韩性生活| 亚洲国产精品一区二区www在线| 色婷婷av一区二区三区软件| 亚洲男人都懂的| 欧美日韩在线亚洲一区蜜芽| 亚洲h在线观看| 日韩欧美国产一二三区| 国内成人免费视频| 中文字幕一区二区三区色视频| www.亚洲在线| 亚洲一区在线观看网站| 欧美日韩免费观看一区二区三区| 亚洲小说春色综合另类电影| 欧美另类videos死尸| 久久精品国产精品亚洲综合| 精品盗摄一区二区三区| 成人免费看的视频| 一区二区三区精品久久久| 欧美肥胖老妇做爰| 国产精品一级片| 亚洲欧美激情一区二区| 4438亚洲最大| 国产精品亚洲成人| 一区二区在线看| 日韩欧美一区电影| 成人av资源在线观看| 婷婷久久综合九色综合伊人色| 精品国产欧美一区二区| 99久久精品免费精品国产| 亚州成人在线电影| 欧美国产成人精品| 在线不卡中文字幕播放| 国产成人鲁色资源国产91色综| 亚洲美女屁股眼交| 久久亚洲一区二区三区四区| 一本久久a久久精品亚洲| 免费在线观看精品| 亚洲欧美日韩系列| 精品国产乱码久久久久久影片| 99久久精品国产麻豆演员表| 青青草一区二区三区| 亚洲欧美视频在线观看视频| 久久伊人蜜桃av一区二区| 色噜噜狠狠成人中文综合| 国产美女主播视频一区| 天天av天天翘天天综合网色鬼国产| 国产三级欧美三级日产三级99| 91国内精品野花午夜精品| 国产河南妇女毛片精品久久久| 午夜成人免费电影| 亚洲摸摸操操av| 亚洲国产电影在线观看| 精品国产一区二区三区av性色| 日本高清成人免费播放| 成人精品鲁一区一区二区| 美女mm1313爽爽久久久蜜臀| 亚洲国产精品久久不卡毛片| 国产精品美女久久久久aⅴ国产馆| 91麻豆精品国产91久久久久久久久 | 日韩av中文在线观看| 亚洲日韩欧美一区二区在线| 久久亚洲欧美国产精品乐播| 日韩一级片在线观看| 精品视频一区二区三区免费| 色婷婷香蕉在线一区二区| 99视频国产精品| 成人h版在线观看| 国产伦精一区二区三区| 国产一区在线精品| 国产综合一区二区| 国产在线视频不卡二| 久久精品国产精品亚洲综合| 美脚の诱脚舐め脚责91| 久久99精品久久只有精品| 麻豆国产精品视频| 极品销魂美女一区二区三区| 老司机精品视频导航| 久久 天天综合| 国产美女在线观看一区| 风间由美中文字幕在线看视频国产欧美 | 丝袜美腿一区二区三区| 五月婷婷激情综合网| 天天影视涩香欲综合网| 日韩精品午夜视频| 国产一区二区三区综合| 国产一区二区精品在线观看| 大胆亚洲人体视频| 91视频观看免费| 欧美一区二区三区在线观看| 日韩精品一区二区三区视频在线观看 | 亚洲一级二级在线| 日韩精品免费专区| 国内精品国产成人| 99综合电影在线视频| 色婷婷亚洲综合| 日韩亚洲欧美在线观看| 国产网站一区二区| 亚洲最大成人网4388xx| 奇米综合一区二区三区精品视频| 黄页视频在线91| 成人美女在线视频| 欧美精选午夜久久久乱码6080| 精品欧美乱码久久久久久1区2区| 欧美国产欧美亚州国产日韩mv天天看完整| 国产精品久久久久久久久搜平片| 一区二区免费在线| 韩国女主播一区| 日本福利一区二区| 久久无码av三级| 亚洲一区二区三区免费视频| 麻豆91在线播放免费| 色偷偷成人一区二区三区91| 欧美一区二区三区免费观看视频| 中文字幕va一区二区三区| 亚洲不卡一区二区三区| 国产白丝精品91爽爽久久| 欧美人体做爰大胆视频| 欧美国产禁国产网站cc| 久久成人免费电影| 欧美三片在线视频观看| 国产精品进线69影院|