亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
亚洲福利一二三区| 国产精品久久久久久久久免费桃花 | 91久久精品一区二区| 国产91精品入口| 国产成人在线视频网址| 国产精品综合一区二区| 国产曰批免费观看久久久| 久久精品国产精品亚洲综合| 精品一区中文字幕| 国产一区二区三区在线观看精品| 狠狠网亚洲精品| 国产成人a级片| www.日韩精品| 在线观看欧美精品| 欧美日韩久久一区| 欧美一三区三区四区免费在线看| 欧美一级高清大全免费观看| 日韩欧美在线观看一区二区三区| 日韩亚洲欧美综合| 欧美大片国产精品| 亚洲丝袜美腿综合| 亚洲综合视频在线观看| 免费看日韩精品| www.性欧美| 欧美日韩精品免费| 久久久www成人免费无遮挡大片| www久久精品| 国产精品福利在线播放| 亚洲午夜激情av| 久久成人免费日本黄色| av激情成人网| 91精品视频网| 国产精品视频九色porn| 亚洲五月六月丁香激情| 久久国产综合精品| 一本高清dvd不卡在线观看| 在线成人av网站| 欧美激情艳妇裸体舞| 亚洲成人7777| av中文字幕在线不卡| 欧美一区二区大片| 亚洲另类春色国产| 韩国av一区二区| 欧美日韩国产影片| 国产精品天天看| 蜜臀av性久久久久蜜臀aⅴ流畅| a在线欧美一区| 日韩西西人体444www| 亚洲色图20p| 国产一区二区久久| 欧美日韩电影在线| 亚洲日本丝袜连裤袜办公室| 精品亚洲成av人在线观看| 日本高清无吗v一区| 精品福利一二区| 亚洲大尺度视频在线观看| 不卡大黄网站免费看| 精品欧美一区二区久久 | 91福利小视频| 国产网红主播福利一区二区| 蜜臀av性久久久久蜜臀aⅴ | 成人免费电影视频| 椎名由奈av一区二区三区| 美女国产一区二区三区| 欧美日韩色综合| 亚洲视频综合在线| 不卡视频在线观看| 国产午夜久久久久| 精品一区二区影视| 日韩欧美黄色影院| 日产国产欧美视频一区精品| 在线欧美日韩精品| 亚洲人被黑人高潮完整版| 成人精品电影在线观看| 久久久精品日韩欧美| 国产麻豆日韩欧美久久| 久久众筹精品私拍模特| 久久99精品久久久久久动态图| 666欧美在线视频| 美女网站色91| 精品国产乱码91久久久久久网站| 日韩精品乱码av一区二区| 精品视频一区二区不卡| 香蕉加勒比综合久久| 欧美丰满高潮xxxx喷水动漫| 亚洲国产裸拍裸体视频在线观看乱了 | 国产乱码精品一品二品| 2021中文字幕一区亚洲| 国产99久久久国产精品潘金网站| 久久精品夜色噜噜亚洲aⅴ| 国产精品一区二区久久不卡| 国产午夜精品在线观看| 成人中文字幕电影| 日韩理论电影院| 日本韩国欧美在线| 肉肉av福利一精品导航| 日韩毛片在线免费观看| 欧美日韩一级视频| 麻豆91在线观看| 中文一区二区完整视频在线观看| av不卡免费电影| 偷拍亚洲欧洲综合| 久久久精品tv| 欧美亚洲国产bt| 另类欧美日韩国产在线| 国产精品网友自拍| 在线播放/欧美激情| 国产曰批免费观看久久久| 亚洲男人的天堂av| 日韩欧美一区二区免费| 99re热这里只有精品免费视频| 亚洲成人在线观看视频| 国产午夜精品一区二区三区嫩草| 在线观看免费亚洲| 国产自产视频一区二区三区| 亚洲欧美综合网| 日韩欧美第一区| 91国产成人在线| 国内一区二区在线| 日韩中文字幕亚洲一区二区va在线| 国产三级精品视频| 欧美一区二区三区在线电影 | 日韩理论在线观看| 欧美成人精品二区三区99精品| 97精品超碰一区二区三区| 精品一区二区三区在线观看国产| 1区2区3区国产精品| 欧美电影免费观看高清完整版在线观看| 99免费精品在线观看| 蜜臀久久久99精品久久久久久| 亚洲精品国产精华液| 久久久国产精华| 欧美成人vr18sexvr| 欧美日韩在线精品一区二区三区激情| 国产精品自在在线| 日韩国产一二三区| 一区二区三区四区av| 中文字幕第一区综合| 日韩精品一区在线观看| 欧美日韩日本视频| 色成年激情久久综合| 成人av在线网站| 大桥未久av一区二区三区中文| 精品中文字幕一区二区| 首页亚洲欧美制服丝腿| 亚洲国产精品久久不卡毛片| 亚洲一区二区综合| 亚洲欧美欧美一区二区三区| 一区二区中文字幕在线| 中文一区在线播放| 中文乱码免费一区二区 | 97se亚洲国产综合在线| av一区二区三区| 一本在线高清不卡dvd| 99久久99久久久精品齐齐| 成人国产精品免费网站| 99久久99久久精品免费看蜜桃| 成人av资源下载| 91免费版pro下载短视频| 色婷婷综合久久| 欧美亚洲动漫精品| 欧美精品乱码久久久久久| 欧美一卡二卡三卡四卡| 欧美成人video| 久久综合国产精品| 国产精品剧情在线亚洲| 亚洲精品久久久蜜桃| 亚洲电影一区二区三区| 日精品一区二区| 精品一区二区三区久久久| 国产真实乱对白精彩久久| 成人免费视频caoporn| 不卡在线观看av| 欧美午夜免费电影| 精品国产乱码久久| 国产精品女同互慰在线看| 夜夜亚洲天天久久| 久久国产精品第一页| av电影一区二区| 91精品国产综合久久精品麻豆| 精品少妇一区二区| 中文字幕制服丝袜一区二区三区 | 一本久久a久久精品亚洲| 欧美日韩小视频| 2023国产精品自拍| 成人免费小视频| 久久不见久久见中文字幕免费| 99热精品一区二区| 欧美一级在线免费| 欧美国产日韩精品免费观看| 亚洲自拍欧美精品| 国产精品一区二区视频| 91福利视频网站| 国产三级一区二区| 日韩精品成人一区二区三区| 国产精品91xxx| 6080国产精品一区二区| 国产精品久久三| 蓝色福利精品导航| 色94色欧美sute亚洲线路一久|