FreeCAD

Форк
0
/
SplineSurface.py 
47 строк · 1.2 Кб
1
# FreeCAD TemplatePyMod module
2
# (c) 2013 Werner Mayer LGPL
3

4
# http://de.wikipedia.org/wiki/Non-Uniform_Rational_B-Spline
5
# len(knot_u) := nNodes_u + degree_u + 1
6
# len(knot_v) := nNodes_v + degree_v + 1
7

8
import FreeCAD
9

10
degree_u=2
11
degree_v=2
12
nNodes_u=5
13
nNodes_v=5
14

15
#knot_u=[0,0,0,0.3333,0.6666,1,1,1]
16
#knot_v=[0,0,0,0.3333,0.6666,1,1,1]
17
knot_u=[0,0,0,0.2,0.7,1,1,1]
18
knot_v=[0,0,0,0.2,0.7,1,1,1]
19
#knot_u=[0,0,0.2,0.4,0.6,0.8,1,1]
20
#knot_v=[0,0,0.2,0.4,0.6,0.8,1,1]
21
coor=[[0,0,1],[1,0,2],[2,0,0],[3,0,1],[4,0,2],\
22
      [0,1,2],[1,1,0],[2,1,0],[3,1,0],[4,1,0],\
23
      [0,2,0],[1,2,0],[2,2,0],[3,2,0],[4,2,0],\
24
      [0,3,1],[1,3,0],[2,3,0],[3,3,3],[4,3,0],\
25
      [0,4,2],[1,4,0],[2,4,0],[3,4,0],[4,4,0]]
26

27
bs=Part.BSplineSurface()
28
bs.increaseDegree(degree_u,degree_v)
29

30
id=1
31
for i in range(0,len(knot_u)-1):
32
        if knot_u[i+1] > knot_u[i]:
33
                bs.insertUKnot(knot_u[i],id,0.0000001)
34

35
id=1
36
for i in range(0,len(knot_v)-1):
37
        if knot_v[i+1] > knot_v[i]:
38
                bs.insertVKnot(knot_v[i],id,0.0000001)
39

40
i=0
41
for jj in range(0,nNodes_v):
42
        for ii in range(0,nNodes_u):
43
                bs.setPole(ii+1,jj+1,FreeCAD.Vector((coor[i][0],coor[i][1],coor[i][2])),1);
44
                i=i+1;
45

46
s=bs.toShape()
47
Part.show(s)
48

Использование cookies

Мы используем файлы cookie в соответствии с Политикой конфиденциальности и Политикой использования cookies.

Нажимая кнопку «Принимаю», Вы даете АО «СберТех» согласие на обработку Ваших персональных данных в целях совершенствования нашего веб-сайта и Сервиса GitVerse, а также повышения удобства их использования.

Запретить использование cookies Вы можете самостоятельно в настройках Вашего браузера.