def __init__(self, OutputGeometryFile, OutputXmlFile, VoxelSizeMetres, OpenAxis, LengthVoxels, SideVoxels, InletPressure=None, OutletPressure=None): """Clip the STL and set attributes on the SWIG-proxied C++ GeometryGenerator object. """ GeometryGenerator.__init__(self) assert OpenAxis in (0, 1, 2) self.OpenAxis = OpenAxis self.LengthVoxels = LengthVoxels self.SideVoxels = SideVoxels self.Sizes = Generation.DoubleVector(SideVoxels, SideVoxels, SideVoxels) self.Sizes[OpenAxis] = LengthVoxels self.InletPressure = InletPressure self.OutletPressure = OutletPressure self._profile = Profile() self._profile.StlFileUnitId = Profile._UnitChoices.index(metre) self._profile.VoxelSize = VoxelSizeMetres self._profile.OutputGeometryFile = OutputGeometryFile self._profile.OutputXmlFile = OutputXmlFile self._MakeIolets() self.generator = Generation.SquareDuctGenerator() self._SetCommonGeneratorProperties() self.generator.SetOpenAxis(self.OpenAxis) lb = self.Sizes * -0.5 self.generator.SetLowerBound(lb) ub = self.Sizes * 0.5 self.generator.SetUpperBound(ub) return