跳到主要內容

lsp畫橢圓

文章日期:2009-01-08 08:48


使用AutoLisp畫橢圓


AutoCAD本身就有提供畫橢圓的功能,但是並沒有提供橢圓上各點的座標若要銑削時,就要自行求得橢圓上各個點的座標

本文旨在以AutoLisp語言來求得橢圓上各點的座標,並以AutoLisp畫出橢圓,以應證求得的橢圓上各點的座標是否正確
橢圓有長軸跟短軸,假設長軸之半為a,短軸之半為b則座標( a*cos(k1), b*sin(k1) )為橢圓上的一點,其結構如下圖所示:

據此資料來做橢圓圖時,則可得下列lisp程式:
(defun c:kk( / x1 y1 x2 y2 )
  (setvar "osmode" 0)
  (command "color" "bylayer")
  (setq xc 0.0  yc 0.0 )
  (setq pc (getpoint "Enter the center point of the ellipse. : "))
  (setq xc (car pc) yc (cadr pc))
  (setq a0 (getreal "\nEnter the longer axial length a. : <100> ") )
  (if (or (= a0 "")(= a0 nill))
      (setq a0 50.0)
      (setq a0 (/ a0 2)) )
  (setq b0 (getreal "\nEnter the shorter axial length b. : <50> ") )
  (if (or (= b0 "")(= b0 nill))
      (setq b0 25.0)
      (setq b0 (/ b0 2)) )
  (setq i1 1   x1 0.0  y1 0.0  x2 0.0 y2  0.0  )
  (setq unitAng (/ 3.1415926 180.0) wkAng 0)
  (while (< i1 362)
    (setq wkAng (+ wkAng unitAng))
    (setq x2 (+ xc (* a0 (cos wkAng))))
    (setq y2 (+ yc (* b0 (sin wkAng))))
    (if(> i1 1.5)
        (command "line" (list x1 y1)(list x2 y2) "") )
    (setq x1 x2  y1 y2 i1 (+ 1 i1))
  )
)

上面的AutoLisp是以作圖角方法來求得橢圓座標,但是該橢圓角(橢圓座標與橢圓中心的夾角)並不等於作圖角(請參考上圖),若要改以:在橢圓上每隔1度之橢圓角來求一個橢圓上的點座標,則AutoLisp更改如下:

(defun c:kk( / x1 y1 x2 y2 )
  (setvar "osmode" 0)
  (setq xc 0.0  yc 0.0 )
  (setq pc (getpoint "Enter the center point of the ellipse. : "))
  (if (or (= pc "")(= pc nill))
      (setq pc (list 0 0 0)))
  (setq xc (car pc) yc (cadr pc))
  (setq a0 (getreal "\nEnter the longer axial length a. : <100> ") )
  (if (or (= a0 "")(= a0 nill))
      (setq a0 50.0)
      (setq a0 (/ a0 2)) )
  (setq b0 (getreal "\nEnter the shorter axial length b. : <50> ") )
  (if (or (= b0 "")(= b0 nill))
      (setq b0 25.0)
      (setq b0 (/ b0 2)) )
  (setq i1 1   x1 0.0  y1 0.0  x2 0.0 y2  0.0  )
  (setq unitAng (/ 3.1415926 180.0) wkAng 0 eAng 0.0)
  (while (< i1 91)
    (setq wkAng (+ wkAng unitAng))
    (setq eAng (atan (/ (* b0 (sin wkAng)) (* a0 (cos wkAng)))))
    (setq x2 (+ xc (* a0 (cos eAng))))
    (setq y2 (+ yc (* b0 (sin eAng))))
    (if(> i1 1.5)
        (command "line" (list x1 y1)(list x2 y2) "") )
    (setq x1 x2  y1 y2 i1 (+ 1 i1))
  )
)

 到底要每隔多少角度來求一個橢圓座標才是適當的呢?角度太小則座標離得太近,若低於0.001mm,則CNC控制器無法讓機台移動,若是太大,則橢圓誤差大,一般較佳的方式並不是用角度當做重算間隔,而是以限定最大弦誤差的方式來當做重算間隔,弦誤差如下圖所示,此外,若要以銑刀來銑橢圓,還得考慮刀具半徑的偏置問題,http://tw.myblog.yahoo.com/cu01joe/article?mid=357&prev=362&next=341&l=f&fid=9,若是手寫程式,則以G41或G42行之則較簡便,使用上要注意初始的補正漸入及最後的補正漸出那兩個單節,不然極易過切或少切,請參考http://tw.myblog.yahoo.com/cu01joe/article?mid=429&prev=467&next=400&l=f&fid=9若是用CAD/CAM的方法,則直接算出偏置點為之 

留言

這個網誌中的熱門文章

管牙PT

文章日期:2009-07-12 23:08 本文旨在講解 PT錐度管牙 常見的標準的管牙規範計有:  NPT , NPTF ,NPS , PS ,PF , PT.. ,前3者有N開頭的是美國標準的管牙 ,牙角(又稱螺紋角)60度 ,後面這3者則是英國標準的管牙 ,牙角55度 ,這些代號裡面的T意指Taper ,也就是錐度牙 。 不論是PT還是NPT,他們的錐度值都是1/16, 換算成角度值是 2*tan-1(0.5/16)=3.57982度 = 3度34分47.356秒, 3.57982度為什麼等於3度34分47.356分呢? 這是因為角度的單位換算是六十進位,3.5798212度後面的小數點0.5798212"度"要換算成""分"時,0.5798212度 = 0.57982*60分 = 34.789273分 ,而34.789273分後面的小數點0.789273分要換算成秒, 則0.789273*60秒 = 47.356秒。 此外,切記在車削錐牙時得採半錐角,也就是1度47分23.7秒。 NPT (美制管用推拔螺紋) 制定在 ANSI 規格中,稱為美國標準管用推拔螺紋,有外螺紋與內螺紋。 NPT 外螺紋不但對 NPT 內螺紋配合,有時也配合 NPSC ,這點類似 PT 。螺紋峰與根切成同形,又因公差大,餘隙、緊密兩種配合都可用。如用潤滑劑,則變成耐密用,耐密用者另有稱為乾封閉之如 NPTF,NPSF 等付有 F 之一群。 NPTF (美制管用耐密推拔螺紋) NPTF 外螺紋,像 PT.NPT 有時也配合 NPSF.NPSI (都是內螺紋)。因這種螺紋都是峯尖、根淺,峯不是密接於根就是食進,可防止在此部分變成螺旋狀間隙,這是前述耐密性之理由。 PT( 英制管用推拔螺紋 ) 以前是使用面直角的螺紋峯,現在將規格統一為軸直角者。 JIS 定為耐密用而組合外螺紋和內螺紋。 PT 外螺紋除了配合 PT 內螺紋,有時也配合 PS 。 PS ( 英制管用推拔螺紋用平行內螺紋   ─   耐密用 )     屬於 JIS 內 PT 的規格,舊 JIS 裏 PS 牙的外螺紋已被取消,配合的外螺紋現規定要用 PT 。 PF( 英制管用平行螺紋   ─  

G76車牙

文章日期:2008-10-10 00:02 工具機若使用 Fanuc 控制器,車牙轉速有一個先天上的限制: S × P < 4000 請參考 車牙的 NC 碼計有 G32 、 G92 、 G76 三種 ( 使用方法 這三個指令中,手寫 G92 一般是直進式切削,牙刀的兩刃皆受力,直進式切削 ,每刀吃深不多,以免造成牙面粗糙,反觀 G76 則是斜進式單邊車削 ,可以有較大的進刀深度 , 寫法也簡短方便廣受採用,不論多大的牙, G76 只要兩個單節就可解決了。 由於 G76 有單邊切削的效果,廣受學校或職訓單位的喜愛,如下圖所示。         Fanuc0T系列控制器之G76 格式如下 : 指令說明 (m) : 精車次數。 (r) : 車牙末端 拔刀時留下的不完全牙長度(倍率)。 (a) :牙刀之角度,可選擇 80 °、 60 °、 55 °、 30 °、 29 °、 0 °等角度。 Q( △ dmin) :最小進刀深度。 R(d) :精車預留量。 X(u) :螺紋程式終點的 X 軸方向座標。 Z(w) :螺紋程式終點的 Z 軸方向座標。 R(i) :螺紋部份的半徑差,如果 I=0 可作一般直線螺紋車削。 P(k) :螺紋高度即牙深度, K 為正值在 X 軸方向用半徑值指定。 Q( △ d) :第一次螺紋的切削深度,用半徑值指定。 F(l) :螺紋的導程,與 G32 相同。 以M20X2.5外螺紋為例 , 常見的寫法如下 : G76 P01 00 60 Q40 R0.02 G76 X16.933 Z-10.0  P1533    Q500   F2.5 1. G76第一行的 P01 00 60 ,這01表示最後精車時只車一刀精車, 00 表示車牙最後拔刀時不留倒角 ,此所謂之倒角是 不完全牙之意 ,亦即因拔刀而在工件上留下牙深較淺的牙 ,Fanuc的拔刀精度是0.1倍的導程 , 若是此值改成10,則表示拔刀時在軸向會留下一倍導程長度的不完全牙,這一倍就是指導程2.5的一倍,也就是不完全牙會有2.5mm那麼長, 60 表示要車的牙角是 60 度 , G76 所 適應的刀角範圍不但很大, Fanu

錐度值

文章日期:2008-02-01 08:40 做傳統車床的人通常會遇到車錐度時要調複式刀座,而複式刀座所調的角度為工件錐度部位之半錐角,為甚麼要調的是半錐角,而不是全錐角呢?為甚麼工件的錐度值乘以 28.65 就是所要調的是半錐角呢? 如下圖所示,將工件錐度部位的稜線延伸至交接,就可看出工件完整的錐度,將這工件全錐度的一半定為 a ,則可得半錐角,由於複式刀座的前進方向是水平的,所以只要將複式刀座依逆時針方向調動半錐角,就可車削工件的錐度。 工件錐度部位之錐度值的計算公式: T=(D-d)/L D 為錐度部位之大徑, d 為錐度部位之小徑, L 為錐度部位之軸向長度。 工件錐度部位之半錐角計算公式: tan(a) = 0.5*(D-d)/L tan 是指正切函數,意思就是 : "對邊除以鄰邊",三角函數裡所指的三角形一定要用直角三角形,直角三角形最長的邊稱為斜邊,鄰邊與斜邊所包的角度就是三角函數角,如下圖的角 a ,三角函數角 a 對面的那個邊就是對邊,三角形會因擺放的位置不同而顯得有點昏頭轉向,不過只要依照上述的原則,就不會認錯邊名了。 從上述說明來看下圖就可以瞭解半錐角計算公式 tan(a) = 0.5*(D-d)/L ,從下圖放大的三角形中可以看出鄰邊長度是 L ,對邊長度是 0.5*(D-d) ,所以 tan(a) =  對邊 / 鄰邊 =0.5*(D-d)/L ,如果已算出 0.5*(D-d)/L 的值要反推角 a 的角度,就必需要這樣做 a=tan -1 (0.5*(D-d)/L) ,也就是用反三角來得角 a 大的小,反三角的值在三十年前常用查表方式求得,近年來只要按一按計算機就可顯示出,不過這對於在工作現場的人來說太麻煩了,所以就有一個半錐角速算公式  : a=28.65*( 錐度值 )=28.65*(D-d)/L) ,那麼這 28.65 到底是怎麼來的呢 ? 其實只要用計算機按按看就可以得到答案,將計算機輸入 1/tan(1 0 ) ,就可得到 57.2899616307594246... ,但由於我們要求的是半錐角,所以再將此值除以 2 就可得到 28.6449808153797... ,簡以 28.65 代之即可,不過這個半錐角速算公式是近似值,只能用來大概調動複式刀座,真正的校正還得