我試圖把一個方法一起以計算不規則但否則凸pyhedron的體積: 它使用三角測量來分裂多面體成多個子四面體(單工)和獨立地計算體積,然後總結所有子卷值。卷不規則多面體
但是,我得到了奇怪的結果爲單位 - 在我的測試下面的立方體。任何人都知道錯誤所在的位置?
class Simplex(object):
def __init__(self,coordinates):
if not len(coordinates) == 4:
raise RuntimeError('You must provide only 4 coordinates!')
self.coordinates = coordinates
def volume(self):
'''
volume: Return volume of simplex. Formula from http://de.wikipedia.org/wiki/Tetraeder
'''
import numpy
vA = numpy.array(self.coordinates[1]) - numpy.array(self.coordinates[0])
vB = numpy.array(self.coordinates[2]) - numpy.array(self.coordinates[0])
vC = numpy.array(self.coordinates[3]) - numpy.array(self.coordinates[0])
return numpy.abs(numpy.dot(numpy.cross(vA,vB),vC))/6.0
'''
Old code that did not work
class Polyeder(object):
def __init__(self,coordinates):
if len(coordinates) < 4:
raise RuntimeError('You must provide at least 4 coordinates!')
self.coordinates = coordinates
def volume(self):
pivotCoordinate = self.coordinates[0]
volumeSum = 0
for i in xrange(1,len(self.coordinates)-3):
newCoordinates = [pivotCoordinate]
for j in xrange(i,i+3):
newCoordinates.append(self.coordinates[j])
simplex = Simplex(newCoordinates)
volumeSum += simplex.volume()
return volumeSum
'''
class Polyeder(object):
def __init__(self,coordinates):
'''
Constructor
'''
if len(coordinates) < 4:
raise RuntimeError('You must provide at least 4 coordinates!')
self.coordinates = coordinates
def volume(self):
from pyhull.delaunay import DelaunayTri
delaunay = DelaunayTri(self.coordinates,joggle=True)
volume = 0
for vertices in delaunay.vertices:
coords = [self.coordinates[i] for i in vertices]
simplex = Simplex(coords)
volume += simplex.volume()
return volume
coords = []
coords.append([0,0,0])
coords.append([1,0,0])
coords.append([0,1,0])
coords.append([0,0,1])
s = Simplex(coords)
print s.volume()
coords.append([0,1,1])
coords.append([1,0,1])
coords.append([1,1,0])
coords.append([1,1,1])
p = Polyeder(coords)
print p.volume()
舊效果的打印輸出是:
0.166666666667
0.666666666667
值應爲1/6四面體(正確的),但1單位立方體
新的結果是: 0.166666666667 1.0
我不確定,但你需要排列其他座標,而不是簡單地通過它們?看起來你只計算4個四面體的體積,應該計算6個。 –
是的,這也是我的猜測,我錯過了其他三個單純形點的排列。會給它一個鏡頭。 –
我的心理例子可能就像是一個(簡單化)明亮切割的鑽石,如果你的支點是重點;如果您只是順次循環訪問錶冠上的點,您將永遠無法計算表格形成的圓錐體的體積。 –