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

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

?? 點集的直徑-對拓.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"))))                  ;選擇點集
  (setq sel (ssget))
  (if (setq ptlist (getpt sel))                             ;構造點集
    (progn
      (setq t1 (getvar "CDATE"))                            ;計時開始
      ;;(setq t0 (getvar "TDUSRTIMER"))                       ;開始計時
      (setq p1 (hull ptlist))                               ;求凸包
      (setq t2 (getvar "CDATE"))                            ;計時結束
      (setq pp (Max-distance p1))
      (setq t3 (getvar "CDATE")) 
      (princ "\n求點集的凸包用時:")
      (princ (* (- t2 t1) 1e6))
      (princ "秒")
      (princ "\n凸包共有")
      (princ (length p1))
      (princ "個頂點")
      (princ "\n求凸包的直徑用時:")
      (princ (* (- t3 t2) 1e6))
      (princ "秒")
      (princ "\n總用時=最大距離點對用時:")
      (princ (* (- t3 t1) 1e6))
      (princ "秒")      
      ;;(princ (* (- (getvar "TDUSRTIMER") t0) 86400))        ;結束計時
    )
  )
  (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 0))                                  ;閉合的
	(list (cons 62 1))                                  ;紅色的
      )
    )
  )
  (princ)
)
;;;==========================
;;;程序主段,可以單獨成為函數
;;;==========================

;;;右半部的凸包
(defun hull1 (pts MaxPt MinPt / nextPt hullPt)
  (if (< (length pts) 3)
    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 Max-distance (ptlist / maxD halfPi HullP1 l HullP2 midPts
		              i j Pi+1 Qi+1 Ai+1 D-i PairPt)
  (setq MaxD nil)
  ;;(setq 2Pi  (* 2 pi))
  ;;(setq halfPi (/ Pi 2))
  (setq HullP1 (Hull ptlist))
  (setq HullP2 (append HullP1
		       (list
			 (car HullP1)
			 (cadr HullP1)
			 (caddr HullP1))))
  ;;(setq midPts (mapcar 'mid-pt HullP1 HullP2))
  (setq l      (length HullP1))
  (setq i 1)
  (foreach pt HullP1
    (setq j i)
    (setq Pi+1 (nth i HullP2))
    (setq Pi+2 (nth (1+ i) HullP2))
    (setq dx1  (- (car  Pi+1) (car  pt)))
    (setq dy1  (- (cadr Pi+1) (cadr pt)))
    (setq dx2  (- (car  Pi+2) (car  Pi+1)))
    (setq dy2  (- (cadr Pi+2) (cadr Pi+1)))
    (setq v-i  (det2 dx1 dy1 dx2 dy2))
    (while (and (> v-i 0) (< j l))
      (setq j (1+ j))
      (setq Pj+1 (nth j HullP2))
      (setq Pj+2 (nth (1+ j) HullP2))
      (setq dx2  (- (car  Pj+2) (car  Pj+1)))
      (setq dy2  (- (cadr Pj+2) (cadr Pj+1)))
      (setq v-i (det2 dx1 dy1 dx2 dy2))
    )
    (setq D-i  (distance pt (nth j HullP2)))
    (setq MAXD (cons (list D-i (1- i) j) MAXD)) 	  
    (setq i (1+ i))  
  )
  (setq PairPt (assoc (apply 'Max (mapcar 'car MaxD)) MaxD))
  (list
    (nth (cadr  PairPt) HullP2)
    (nth (caddr PairPt) 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 det2 (dx1 dy1 dx2 dy2)
  (- (* dx1 dy2) (* dx2 dy1))
)  
;;定義三點的行列式,即三點之倍面積
(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 mid-pt (p1 p2)
  (list
    (* (+ (car  p1) (car  p2)) 0.5)
    (* (+ (cadr p1) (cadr p2)) 0.5)
  )
)
;;;============
;;;程序主段結束
;;;============

;;;依據曉東網站的代碼改寫而成的取點函數
(defun getpt1 (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
)
;;定義三點的夾角函數
(defun ang (p1 p2 p3 / x)
  (setq x (abs (- (angle p1 p3) (angle p1 p2))))
  (if (< x Pi) x (- 2Pi x)) 
)
(defun C:tt (/ p1 p2 p3)
  (initget 1)
  (setq p1 (getpoint "\n輸入第一點:"))
  (setq p2 (getpoint "\n輸入第二點:"))
  (setq p3 (getpoint "\n輸入第三點:"))
  (ang p1 p2 p3)
)  
;;;取點函數2
(defun getpt (ss / i listpp a b c d)
  (setq	i 0)
  (if ss
    (repeat (sslength ss)
      (setq a (ssname ss i))
      (setq b (entget a))
      (setq ename (cdr (assoc 0 b)))
      (cond
	( (= ename "LWPOLYLINE")
	  (setq c (get-LWpolyline-vertexs b))
	  (setq listpp (append c listpp))
	)
	( (= ename "LINE")
	  (setq c (cdr (assoc 10 b)))
	  (setq d (cdr (assoc 11 b)))
	  (setq c (list (car c) (cadr c)))
	  (setq d (list (car d) (cadr d)))
	  (setq listpp (cons c listpp))
	  (setq listpp (cons d listpp))
	)
	( (= ename "POINT")
	  (setq c (cdr (assoc 10 b)))
	  (setq c (list (car c) (cadr c)))
	  (setq listpp (cons c listpp))
	)
      )
      (setq i (1+ i))
    )
  )
  listpp
)
;;取得多邊形頂點
(defun get-LWpolyline-vertexs (entlst / n lst)
  (foreach n entlst
    (if (= (car n) 10)
      (setq lst (cons (cdr n) lst))
    )
  )
  lst
)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美va日韩va| 精品对白一区国产伦| 久草热8精品视频在线观看| 一级女性全黄久久生活片免费| 久久一区二区视频| 久久免费国产精品| 国产亚洲欧洲一区高清在线观看| 日韩欧美一区在线| 精品国产区一区| 久久婷婷国产综合国色天香| 精品三级在线看| 91精品国产综合久久精品app| 欧美久久久久久久久| 一个色妞综合视频在线观看| 亚洲欧美视频在线观看| 亚洲色图都市小说| 亚洲成人免费在线观看| 日韩国产一区二| 国产一区二区三区在线观看免费视频 | 一区二区三区日韩精品视频| 亚洲精品高清视频在线观看| 午夜精品久久一牛影视| 日本色综合中文字幕| 国内不卡的二区三区中文字幕| 国产精品一区二区黑丝| 成人黄色国产精品网站大全在线免费观看 | 色综合欧美在线视频区| 欧美日韩国产精品成人| 2020国产精品| 亚洲激情图片小说视频| 麻豆视频观看网址久久| av在线一区二区| 欧美日韩国产免费| 亚洲国产精品黑人久久久| 一级日本不卡的影视| 看片的网站亚洲| 一本色道久久综合亚洲91| 日韩欧美中文字幕制服| 综合色天天鬼久久鬼色| 蜜臀久久99精品久久久久久9 | 国产精品成人一区二区三区夜夜夜| 樱桃视频在线观看一区| 国产原创一区二区三区| 色94色欧美sute亚洲线路一久| 日韩午夜电影av| 亚洲欧洲综合另类在线| 美女网站在线免费欧美精品| 色先锋久久av资源部| 久久精品在线观看| 午夜精品福利在线| 91美女片黄在线| 久久久国产精品麻豆| 日本亚洲三级在线| 欧美三级乱人伦电影| 国产精品入口麻豆原神| 精品一区二区影视| 91麻豆精品国产91久久久资源速度| 国产精品久久久久永久免费观看| 日本中文一区二区三区| 欧美特级限制片免费在线观看| 亚洲国产高清不卡| 国产精品原创巨作av| 精品少妇一区二区| 免费成人在线视频观看| 欧美疯狂性受xxxxx喷水图片| 亚洲欧洲日韩女同| 丁香六月综合激情| 国产欧美日本一区二区三区| 精品一区在线看| 日韩欧美一二三四区| 日韩主播视频在线| 欧美人狂配大交3d怪物一区| 亚洲午夜一二三区视频| 欧美在线免费播放| 亚洲最大色网站| 色美美综合视频| 亚洲黄色在线视频| 91丨九色丨蝌蚪丨老版| 一区二区三区中文字幕电影| 色婷婷久久99综合精品jk白丝| 综合激情成人伊人| 91色在线porny| 亚洲精品成人精品456| 在线免费av一区| 夜夜嗨av一区二区三区网页| 欧美丝袜丝nylons| 午夜视频在线观看一区| 欧美一区二区三区四区在线观看| 丝袜诱惑亚洲看片| 日韩欧美激情一区| 国产麻豆91精品| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 成人一级视频在线观看| 国产精品国产三级国产aⅴ入口| 99国产精品久久久久| 亚洲欧美区自拍先锋| 欧美三级蜜桃2在线观看| 石原莉奈一区二区三区在线观看| 日韩欧美成人午夜| 国产精品一区不卡| 亚洲美女视频在线观看| 欧美日韩亚洲综合在线 欧美亚洲特黄一级 | 91亚洲精品久久久蜜桃网站 | 欧美肥胖老妇做爰| 玖玖九九国产精品| 国产精品国产三级国产普通话蜜臀| 一道本成人在线| 久久99精品视频| 中文字幕日韩精品一区| 欧美久久久影院| 国产精品自拍毛片| 亚洲高清中文字幕| 久久精品视频一区二区| 欧美在线不卡视频| 国产在线一区观看| 亚洲国产一区二区在线播放| 久久日韩精品一区二区五区| 91丨国产丨九色丨pron| 另类欧美日韩国产在线| 中文字幕在线不卡一区二区三区| 欧美老女人第四色| 成人国产精品免费观看动漫| 日韩黄色片在线观看| 日韩理论片在线| 久久天堂av综合合色蜜桃网| 欧美午夜电影网| 99精品视频在线观看免费| 久久爱www久久做| 亚洲高清久久久| 欧美国产激情二区三区 | 久久久久久毛片| 777久久久精品| 在线免费观看视频一区| 成人免费视频视频| 国产米奇在线777精品观看| 午夜免费欧美电影| 亚洲精品乱码久久久久久久久 | 亚洲h在线观看| 亚洲免费成人av| 国产精品麻豆视频| 欧美精品一区二区三区很污很色的| 欧美日韩一区二区在线观看视频| 成人小视频在线观看| 国产一区二区电影| 韩国成人精品a∨在线观看| 天堂va蜜桃一区二区三区漫画版 | 欧美性生活影院| 色猫猫国产区一区二在线视频| 成人黄动漫网站免费app| 国产精品原创巨作av| 国产伦精一区二区三区| 国精产品一区一区三区mba视频| 日韩不卡一二三区| 日本欧美大码aⅴ在线播放| 国产一区二区三区久久悠悠色av| 亚洲成va人在线观看| 一区二区三区精品视频| 亚洲男同1069视频| 亚洲裸体在线观看| 亚洲乱码一区二区三区在线观看| 亚洲视频在线一区观看| 亚洲婷婷国产精品电影人久久| 国产精品欧美一区喷水| 国产精品三级视频| 亚洲日本中文字幕区| 亚洲综合小说图片| 午夜私人影院久久久久| 日韩国产欧美在线观看| 久久精品免费观看| 国产aⅴ综合色| 99国产精品视频免费观看| 日本韩国一区二区三区视频| 欧美伊人久久久久久久久影院 | 亚洲欧美在线另类| 一区二区三区日韩精品视频| 夜夜嗨av一区二区三区| 日韩高清不卡一区二区| 蜜臀av一区二区在线免费观看 | 亚洲最大成人综合| 日韩高清在线一区| 国产精品综合二区| 91美女在线看| 精品女同一区二区| 中文字幕一区二区三区乱码在线| 亚洲在线观看免费视频| 激情图区综合网| www.亚洲人| 日韩欧美久久久| 综合电影一区二区三区| 麻豆精品新av中文字幕| 99久久精品情趣| 欧美变态凌虐bdsm| 国产精品乱码人人做人人爱| 亚洲国产美女搞黄色| 国产成人夜色高潮福利影视| 欧美日韩三级一区| 国产人成一区二区三区影院| 亚洲午夜私人影院| 成人动漫在线一区| 欧美va日韩va|