diff --git a/Makefile b/Makefile index 5dbbba1..8f35eeb 100644 --- a/Makefile +++ b/Makefile @@ -13,7 +13,7 @@ default: echo "making $@ in $$subdir"; \ echo; (cd $$subdir && $(MAKE) TMR_DIR=${TMR_DIR}) || exit 1; \ done - ${CXX} ${SO_LINK_FLAGS} ${TMR_OBJS} ${TMR_EXTERN_LIBS} -o ${TMR_DIR}/lib/libtmr.${SO_EXT} + ${CXX} ${SO_LINK_FLAGS} ${TMR_OBJS} ${TMR_EXTERN_LIBS} -o ${TMR_DIR}/lib/libtmr.${SO_EXT} debug: echo "Building Real TMR" @@ -24,7 +24,7 @@ debug: ${CXX} ${SO_LINK_FLAGS} ${TMR_OBJS} ${TMR_EXTERN_LIBS} -o ${TMR_DIR}/lib/libtmr.${SO_EXT} interface: - ${PYTHON} setup.py build_ext --inplace + pip install -e . clean: ${RM} lib/*.a lib/*.so diff --git a/examples/egads/crm/dcel.py b/examples/egads/crm/dcel.py index d483d46..ecee3ef 100644 --- a/examples/egads/crm/dcel.py +++ b/examples/egads/crm/dcel.py @@ -1,6 +1,7 @@ """ Implementation of a DECL data structure """ + import numpy as np diff --git a/examples/poisson/poisson_agg_error.py b/examples/poisson/poisson_agg_error.py index a836edf..8d57e82 100644 --- a/examples/poisson/poisson_agg_error.py +++ b/examples/poisson/poisson_agg_error.py @@ -2,6 +2,7 @@ Plot the aggregation error as a function of rho for the KS and p-norm functionals """ + from __future__ import print_function import tikzplots as tkz import numpy as np diff --git a/examples/pygeometryloader/plate/plate.py b/examples/pygeometryloader/plate/plate.py index 8284187..6b0f188 100644 --- a/examples/pygeometryloader/plate/plate.py +++ b/examples/pygeometryloader/plate/plate.py @@ -3,6 +3,7 @@ To run the defaults: mpirun -np 2 python plate.py """ + # imports import os from mpi4py import MPI diff --git a/examples/pytacsadapt/plate/plate_adapt.py b/examples/pytacsadapt/plate/plate_adapt.py index 2747842..eee08d4 100644 --- a/examples/pytacsadapt/plate/plate_adapt.py +++ b/examples/pytacsadapt/plate/plate_adapt.py @@ -13,6 +13,7 @@ 3. run `mpirun -np 4 python plate_adapt.py --niters 10 --strategy fixed_growth --ref_factor 0.1` 4. compare the results of uniform and adaptive refinement between step 2 and 3 """ + import os import argparse from mpi4py import MPI diff --git a/examples/smooth/smooth_stl.py b/examples/smooth/smooth_stl.py index 3e4255c..e33dd7e 100644 --- a/examples/smooth/smooth_stl.py +++ b/examples/smooth/smooth_stl.py @@ -1,6 +1,7 @@ """ Imports a STL file and applies a smoothing to it """ + from __future__ import print_function # Import the locate point code diff --git a/examples/topology_optimization/eigenvalue/lbracket_eigenvalue.py b/examples/topology_optimization/eigenvalue/lbracket_eigenvalue.py index c6452fd..d5d0ea2 100644 --- a/examples/topology_optimization/eigenvalue/lbracket_eigenvalue.py +++ b/examples/topology_optimization/eigenvalue/lbracket_eigenvalue.py @@ -2,6 +2,7 @@ Solve the eigenvalue-constrained optimization problem """ + from mpi4py import MPI from tmr import TMR, TopOptUtils from paropt import ParOpt, ParOptEig diff --git a/examples/topology_optimization/qn-correction/compliance/comp-min.py b/examples/topology_optimization/qn-correction/compliance/comp-min.py index 0fe7601..cc42cdb 100644 --- a/examples/topology_optimization/qn-correction/compliance/comp-min.py +++ b/examples/topology_optimization/qn-correction/compliance/comp-min.py @@ -397,9 +397,9 @@ def evalObjConGrad(self, x, g, gcon): prob.driver.opt_settings["Minor print level"] = 0 if max_iterations > 1 and step == max_iterations - 1: - prob.driver.opt_settings[ - "Major iterations limit" - ] = args.niter_finest + prob.driver.opt_settings["Major iterations limit"] = ( + args.niter_finest + ) else: prob.driver.opt_settings["Major iterations limit"] = args.max_iter diff --git a/examples/topology_optimization/qn-correction/eigenvalue/eig-max-lite.py b/examples/topology_optimization/qn-correction/eigenvalue/eig-max-lite.py index 615fab7..d3c1927 100644 --- a/examples/topology_optimization/qn-correction/eigenvalue/eig-max-lite.py +++ b/examples/topology_optimization/qn-correction/eigenvalue/eig-max-lite.py @@ -1,6 +1,7 @@ """ This script performs eigenvalue minimization with mass constraint """ + import numpy as np from mpi4py import MPI import argparse diff --git a/examples/topology_optimization/qn-correction/frequency-baseline/baseline.py b/examples/topology_optimization/qn-correction/frequency-baseline/baseline.py index 327fad0..623111e 100644 --- a/examples/topology_optimization/qn-correction/frequency-baseline/baseline.py +++ b/examples/topology_optimization/qn-correction/frequency-baseline/baseline.py @@ -1,6 +1,7 @@ """ Compute the base frequencies for different domains with concentrated mass """ + from tmr import TMR, TopOptUtils from tacs import TACS, constitutive diff --git a/examples/topology_optimization/qn-correction/refactor_compfreq/compfreq.py b/examples/topology_optimization/qn-correction/refactor_compfreq/compfreq.py index 7478325..fcb7d52 100644 --- a/examples/topology_optimization/qn-correction/refactor_compfreq/compfreq.py +++ b/examples/topology_optimization/qn-correction/refactor_compfreq/compfreq.py @@ -475,9 +475,9 @@ def evalObjConGrad(self, x, g, gcon): omprob.driver.opt_settings["Minor print level"] = 0 if args.n_mesh_refine > 1 and step == args.n_mesh_refine - 1: - omprob.driver.opt_settings[ - "Major iterations limit" - ] = args.niter_finest + omprob.driver.opt_settings["Major iterations limit"] = ( + args.niter_finest + ) else: omprob.driver.opt_settings["Major iterations limit"] = args.max_iter diff --git a/examples/topology_optimization/qn-correction/refactor_frequency/refactor_frequency.py b/examples/topology_optimization/qn-correction/refactor_frequency/refactor_frequency.py index 4d4f719..f989bfe 100644 --- a/examples/topology_optimization/qn-correction/refactor_frequency/refactor_frequency.py +++ b/examples/topology_optimization/qn-correction/refactor_frequency/refactor_frequency.py @@ -447,9 +447,9 @@ def evalObjConGrad(self, x, g, gcon): omprob.driver.opt_settings["Minor print level"] = 0 if n_refine_steps > 1 and step == n_refine_steps - 1: - omprob.driver.opt_settings[ - "Major iterations limit" - ] = args.niter_finest + omprob.driver.opt_settings["Major iterations limit"] = ( + args.niter_finest + ) else: omprob.driver.opt_settings["Major iterations limit"] = args.max_iter diff --git a/setup.py b/setup.py index 083bfd6..78cfc43 100644 --- a/setup.py +++ b/setup.py @@ -2,17 +2,16 @@ from subprocess import check_output import sys -# Numpy/mpi4py must be installed prior to installing TACS +# Numpy/mpi4py must be installed prior to installing import numpy import mpi4py # Import distutils -from setuptools import setup +from setuptools import setup, find_packages from distutils.core import Extension as Ext from Cython.Build import cythonize from Cython.Compiler import Options -Options.embedsignature = True Options.docstrings = True @@ -77,6 +76,7 @@ def get_mpi_flags(): if "tacs" in sys.modules: inc_dirs.extend(tacs.get_include()) inc_dirs.extend(tacs.get_cython_include()) + inc_dirs.append(os.path.split(tacs.get_cython_include()[0])[0]) tacs_lib_dirs, tacs_libs = tacs.get_libraries() lib_dirs.extend(tacs_lib_dirs) libs.extend(tacs_libs) @@ -88,6 +88,7 @@ def get_mpi_flags(): if "paropt" in sys.modules: inc_dirs.extend(paropt.get_include()) inc_dirs.extend(paropt.get_cython_include()) + inc_dirs.append(os.path.split(paropt.get_cython_include()[0])[0]) paropt_lib_dirs, paropt_libs = paropt.get_libraries() lib_dirs.extend(paropt_lib_dirs) libs.extend(paropt_libs) @@ -99,6 +100,7 @@ def get_mpi_flags(): if "egads4py" in sys.modules: inc_dirs.extend(egads4py.get_include()) inc_dirs.extend(egads4py.get_cython_include()) + inc_dirs.append(os.path.split(egads4py.get_cython_include()[0])[0]) egads4py_lib_dirs, egads4py_libs = egads4py.get_libraries() lib_dirs.extend(egads4py_lib_dirs) libs.extend(egads4py_libs) @@ -127,16 +129,16 @@ def get_mpi_flags(): for e in exts: e.cython_directives = { - "language_level": "3", "embedsignature": True, "binding": True, } setup( name="tmr", - version=0.1, + version=1.0, description="Parallel mesh generation utilities", author="Graeme J. Kennedy", author_email="graeme.kennedy@ae.gatech.edu", + packages=find_packages(include=["tmr*"]), ext_modules=cythonize(exts, include_path=inc_dirs), ) diff --git a/tmr/TMR.pxd b/tmr/TMR.pxd index a960e27..71cf983 100644 --- a/tmr/TMR.pxd +++ b/tmr/TMR.pxd @@ -18,26 +18,47 @@ # See the License for the specific language governing permissions and # limitations under the License. -# For MPI -from mpi4py.libmpi cimport * -cimport mpi4py.MPI as MPI - -# Import string stuff -from libc.string cimport const_char -from libc.stdint cimport int32_t, int16_t - -# Import the python version information -from cpython.version cimport PY_MAJOR_VERSION - -# Import numpy -cimport numpy as np -import numpy as np - # Import TACS -from paropt.ParOpt cimport * -from tacs.TACS cimport * -from tacs.constitutive cimport * -from egads4py.egads cimport * +from tacs import TACS +from tacs.TACS import Vec, VecInterp, Assembler, Mg, Element, Function, Pc +from tacs.TACS cimport ( + Vec, + VecInterp, + Assembler, + Mg, + Element, + Function, + Pc, + TACSFunction, + TACSBVec, + TACSBVecInterp, + TACSAssembler, + TACSMg, + _init_Vec, + _init_VecInterp, + _init_Assembler, + _init_Mg, + _dynamicTACSMg, +) +from tacs.constitutive import ( + PlaneStressConstitutive, + SolidConstitutive, + MaterialProperties, +) +from tacs.constitutive cimport ( + PlaneStressConstitutive, + SolidConstitutive, + MaterialProperties, + TACSMaterialProperties, +) + +# Import ParOpt +from paropt.ParOpt import PVec, ProblemBase +from paropt.ParOpt cimport PVec, ProblemBase, ParOptVec, _init_PVec + +# Import EGADS +from egads4py.egads import pyego +from egads4py.egads cimport pyego cdef inline char* tmr_convert_str_to_chars(s): if isinstance(s, unicode): @@ -47,666 +68,5 @@ cdef inline char* tmr_convert_str_to_chars(s): cdef inline str tmr_convert_char_to_str(const char* s): if s == NULL: return None - elif PY_MAJOR_VERSION >= 3: - return s.decode('utf-8') else: - return str(s) - -cdef extern from "TMRBase.h": - enum: - TMR_MAX_LEVEL"TMR_MAX_LEVEL" - - cdef cppclass TMREntity: - void incref() - void decref() - void setName(const char*) - const char* getName() - int getEntityId() - - cdef cppclass TMRPoint: - double x - double y - double z - - cdef cppclass TMRIndexWeight: - int index - double weight - - cdef cppclass TMR_STLTriangle: - TMRPoint p[3] - - void TMRInitialize() - int TMRIsInitialized() - void TMRFinalize() - - enum TMRInterpolationType: - TMR_UNIFORM_POINTS - TMR_GAUSS_LOBATTO_POINTS - TMR_BERNSTEIN_POINTS - -cdef extern from "TMRTopology.h": - cdef cppclass TMRTopology(TMREntity): - TMRTopology(MPI_Comm, TMRModel*) - void getVolume(int, TMRVolume**) - void getFace(int, TMRFace**) - void getEdge(int, TMREdge**) - void getVertex(int, TMRVertex**) - - cdef cppclass TMRVertex(TMREntity): - TMRVertex() - int evalPoint(TMRPoint*) - int setNodeNum(int*) - int getNodeNum(int*) - void setCopySource(TMRVertex*) - void getCopySource(TMRVertex**) - int isSame(TMRVertex*) - - cdef cppclass TMREdge(TMREntity): - TMREdge() - void setSource(TMREdge*) - void getSource(TMREdge**) - void getRange(double*, double*) - int evalPoint(double, TMRPoint*) - int evalDeriv(double, TMRPoint*, TMRPoint*) - int invEvalPoint(TMRPoint, double*) - void setVertices(TMRVertex*, TMRVertex*) - void getVertices(TMRVertex**, TMRVertex**) - int isDegenerate() - void setMesh(TMREdgeMesh*) - void getMesh(TMREdgeMesh**) - void setCopySource(TMREdge*) - void getCopySource(TMREdge**) - void writeToVTK(char*) - int isSame(TMREdge*) - - cdef cppclass TMRFace(TMREntity): - TMRFace() - TMRFace(int) - void getRange(double*, double*, double*, double*) - int evalPoint(double, double, TMRPoint*) - void setSource(TMRVolume*, TMRFace*) - void getSource(TMRVolume**, TMRFace**) - int getNumEdgeLoops() - void addEdgeLoop(int, TMREdgeLoop*) - void getEdgeLoop(int, TMREdgeLoop**) - void setMesh(TMRFaceMesh*) - void getMesh(TMRFaceMesh**) - void setCopySource(int, TMRFace*) - void getCopySource(int*, TMRFace**) - void writeToVTK(char*) - int isSame(TMRFace*) - - cdef cppclass TMREdgeLoop(TMREntity): - TMREdgeLoop(int, TMREdge**, const int*) - void getEdgeLoop(int*, TMREdge***, const int**) - - cdef cppclass TMRVolume(TMREntity): - TMRVolume(int, TMRFace**) - void getFaces(int*, TMRFace***) - void writeToVTK(char*) - - cdef cppclass TMRModel(TMREntity): - TMRModel(int, TMRVertex**, - int, TMREdge**, - int, TMRFace**, - int, TMRVolume**) - void getVertices(int*,TMRVertex***) - void getEdges(int*,TMREdge***) - void getFaces(int*,TMRFace***) - void getVolumes(int*,TMRVolume***) - -cdef extern from "TMRGeometry.h": - cdef cppclass TMRCurve(TMREntity): - void writeToVTK(char*) - - cdef cppclass TMRSurface(TMREntity): - void addCurveSegment(int, TMRCurve**, int*) - void writeToVTK(char*) - - cdef cppclass TMRPcurve(TMREntity): - pass - -cdef extern from "TMRNativeTopology.h": - cdef cppclass TMRVertexFromPoint(TMRVertex): - TMRVertexFromPoint(TMRPoint) - - cdef cppclass TMRVertexFromEdge(TMRVertex): - TMRVertexFromEdge(TMREdge*, double) - TMRVertexFromEdge(TMREdge*, TMRPoint) - - cdef cppclass TMRVertexFromFace(TMRVertex): - TMRVertexFromFace(TMRFace*, double, double) - TMRVertexFromFace(TMRFace*, TMRPoint) - - cdef cppclass TMREdgeFromFace(TMREdge): - TMREdgeFromFace(TMRFace*, TMRPcurve*) - TMREdgeFromFace(TMRFace*, TMRPcurve*, int) - void addEdgeFromFace(TMRFace*, TMRPcurve*) - - cdef cppclass TMRSplitEdge(TMREdge): - TMRSplitEdge(TMREdge*, double, double) - TMRSplitEdge(TMREdge*, TMRVertex*, TMRVertex*) - - cdef cppclass TMREdgeFromCurve(TMREdge): - TMREdgeFromCurve(TMRCurve*) - - cdef cppclass TMRFaceFromSurface(TMRFace): - TMRFaceFromSurface(TMRSurface*) - - cdef cppclass TMRTFIEdge(TMREdge): - TMRTFIEdge(TMRVertex*, TMRVertex*) - - cdef cppclass TMRTFIFace(TMRFace): - TMRTFIFace(TMREdge**, const int*, TMRVertex**) - -cdef extern from "TMRBspline.h": - cdef cppclass TMRBsplineCurve(TMRCurve): - TMRBsplineCurve(int, int, TMRPoint*) - TMRBsplineCurve(int, int, double*, TMRPoint*) - TMRBsplineCurve(int, int, double*, double*, TMRPoint*) - void getData(int*, int*, const double**, - const double**, const TMRPoint**) - void split(double, TMRBsplineCurve**, TMRBsplineCurve**) - - cdef cppclass TMRBsplineSurface(TMRSurface): - TMRBsplineSurface(int, int, int, int, TMRPoint*) - TMRBsplineSurface(int, int, int, int, - double*, double*, TMRPoint*) - TMRBsplineSurface(int, int, int, int, - double*, double*, double*, TMRPoint*) - void getData(int*, int*, int*, int*, const double**, const double**, - const double**, const TMRPoint**) - - cdef cppclass TMRBsplinePcurve(TMRPcurve): - TMRBsplinePcurve(int, int, double*) - TMRBsplinePcurve(int, int, double*, double*) - TMRBsplinePcurve(int, int, double*, double*, double*) - - cdef cppclass TMRCurveInterpolation(TMREntity): - TMRCurveInterpolation(TMRPoint*, int) - void setNumControlPoints(int) - TMRBsplineCurve *createCurve(int) - - cdef cppclass TMRCurveLofter(TMREntity): - TMRCurveLofter(TMRBsplineCurve**, int) - TMRBsplineSurface* createSurface(int) - -cdef extern from "": - void _deleteMe "delete [] "(int *array) - TMRBsplineCurve* _dynamicBsplineCurve "dynamic_cast"(TMRCurve*) - TMRBsplineSurface* _dynamicBsplineSurface "dynamic_cast"(TMRSurface*) - TMREdgeFromFace* _dynamicEdgeFromFace "dynamic_cast"(TMREdge*) - TMRTopoProblem* _dynamicTopoProblem "dynamic_cast"(ParOptProblem*) - ParOptBVecWrap* _dynamicParOptBVecWrap "dynamic_cast"(ParOptVec*) - -cdef extern from "TMRFeatureSize.h": - cdef cppclass TMRElementFeatureSize(TMREntity): - TMRElementFeatureSize() - TMRElementFeatureSize(double) - double getFeatureSize(TMRPoint) - - cdef cppclass TMRLinearElementSize(TMRElementFeatureSize): - TMRLinearElementSize(double, double, - double, double, double, double) - - cdef cppclass TMRBoxFeatureSize(TMRElementFeatureSize): - TMRBoxFeatureSize(TMRPoint, TMRPoint, double, double) - void addBox(TMRPoint, TMRPoint, double) - - cdef cppclass TMRPointFeatureSize(TMRElementFeatureSize): - TMRPointFeatureSize(int, TMRPoint*, double*, double, double, int) - - cdef cppclass TMRPointLocator(TMREntity): - TMRPointLocator(int, TMRPoint*) - void locateClosest(int, TMRPoint, int*, int*, double*) - -cdef class PointLocator: - cdef TMRPointLocator *ptr - -cdef extern from "TMREdgeMesh.h": - cdef cppclass TMREdgeMesh(TMREntity): - TMREdgeMesh(MPI_Comm, TMREdge*, TMRPoint*, int) - void mesh(TMRMeshOptions, TMRElementFeatureSize*) - void writeToVTK(const char*) - -cdef extern from "TMRFaceMesh.h": - cdef cppclass TMRFaceMesh(TMREntity): - TMRFaceMesh(MPI_Comm, TMRFace*, TMRPoint*, int, int*, int) - void mesh(TMRMeshOptions, TMRElementFeatureSize*) - void writeToVTK(const char*) - -cdef extern from "TMRVolumeMesh.h": - cdef cppclass TMRVolumeMesh(TMREntity): - TMRVolumeMesh(MPI_Comm, TMRVolume*) - void mesh(TMRMeshOptions) - void writeToVTK(const char*) - -cdef extern from "TMRMesh.h": - enum TMRFaceMeshType: - TMR_NO_MESH - TMR_STRUCTURED - TMR_UNSTRUCTURED - TMR_TRIANGLE - - cdef cppclass TMRMesh(TMREntity): - TMRMesh(MPI_Comm, TMRModel*) - void mesh(TMRMeshOptions, double) - void mesh(TMRMeshOptions, TMRElementFeatureSize*) - int getMeshPoints(TMRPoint**) - int getQuadConnectivity(int*, const int**) - int getTriConnectivity(int*, const int**) - int getHexConnectivity(int*, const int**) - int getTetConnectivity(int*, const int**) - - TMRModel *createModelFromMesh() - void writeToVTK(const char*, int) - void writeToBDF(const char*, int, TMRBoundaryConditions*) - - cdef cppclass TMRMeshOptions: - TMRMeshOptions() - TMRFaceMeshType mesh_type_default - int triangularize_print_level - int triangularize_print_iter - int write_mesh_quality_histogram - int num_smoothing_steps - double frontal_quality_factor - int reset_mesh_objects - int write_init_domain_triangle - int write_triangularize_intermediate - int write_pre_smooth_triangle - int write_post_smooth_triangle - int write_dual_recombine - int write_pre_smooth_quad - int write_post_smooth_quad - int write_quad_dual - -cdef extern from "TMRQuadrant.h": - cdef cppclass TMRQuadrant: - int childId() - void getSibling(int, TMRQuadrant*) - void parent(TMRQuadrant*) - void edgeNeighbor(int, TMRQuadrant*) - void cornerNeighbor(int, TMRQuadrant*) - int contains(TMRQuadrant*) - int32_t face - int32_t x - int32_t y - int32_t tag - int16_t level - int16_t info - - cdef cppclass TMRQuadrantArray: - TMRQuadrantArray(TMRQuadrant*, int) - TMRQuadrantArray* duplicate() - void getArray(TMRQuadrant**, int*) - void sort() - TMRQuadrant* contains(TMRQuadrant *q, int) - -cdef extern from "TMRQuadForest.h": - cdef cppclass TMRQuadForest(TMREntity): - TMRQuadForest(MPI_Comm, int, TMRInterpolationType) - MPI_Comm getMPIComm() - void setTopology(TMRTopology*) - TMRTopology* getTopology() - void setConnectivity(int, const int*, int) - void setFullConnectivity(int, int, int, const int*, const int*) - void repartition() - void createTrees(int) - void createRandomTrees(int, int, int) - void refine(int*, int, int) - TMRQuadForest *duplicate() - TMRQuadForest *coarsen() - void balance(int) - void createNodes() - int getMeshOrder() - TMRInterpolationType getInterpType() - void setMeshOrder(int, TMRInterpolationType) - void getNodeConn(const int**, int*) - int getDepNodeConn(const int**, const int**, const double**) - TMRQuadrantArray* getQuadsWithName(const char*) - int getNodesWithName(const char*, int**) - void createInterpolation(TMRQuadForest*, TACSBVecInterp*) - int getOwnedNodeRange(const int**) - void getQuadrants(TMRQuadrantArray**) - int getPoints(TMRPoint**) - int getLocalNodeNumber(int); - int getExtPreOffset() - void writeToVTK(const char*) - void writeForestToVTK(const char*) - -cdef extern from "TMROctant.h": - cdef cppclass TMROctant: - int childId() - void getSibling(int, TMROctant*) - void parent(TMROctant*) - void edgeNeighbor(int, TMROctant*) - void cornerNeighbor(int, TMROctant*) - void faceNeighbor(int, TMROctant) - int contains(TMROctant*) - int32_t block - int32_t x - int32_t y - int32_t z - int32_t tag - int16_t level - int16_t info - - cdef cppclass TMROctantArray: - TMROctantArray(TMROctant*, int) - TMROctantArray* duplicate() - void getArray(TMROctant**, int*) - void sort() - TMROctant* contains(TMROctant*, int) - -cdef extern from "TMROctForest.h": - cdef cppclass TMROctForest(TMREntity): - TMROctForest(MPI_Comm, int, TMRInterpolationType) - MPI_Comm getMPIComm() - void setTopology(TMRTopology*) - TMRTopology* getTopology() - void setConnectivity(int, const int*, int) - void setFullConnectivity(int, int, int, const int*, const int*) - void repartition(int) - void createTrees(int) - void createRandomTrees(int, int, int) - void refine(int*, int, int) - TMROctForest *duplicate() - TMROctForest *coarsen() - void balance(int) - void createNodes() - int getMeshOrder() - TMRInterpolationType getInterpType() - void setMeshOrder(int, TMRInterpolationType) - void getNodeConn(const int**, int*) - int getDepNodeConn(const int**, const int**, const double**) - TMROctantArray* getOctsWithName(const char*) - int getNodesWithName(const char*, int**) - void createInterpolation(TMROctForest*, TACSBVecInterp*) - int getOwnedNodeRange(const int**) - void getOctants(TMROctantArray**) - int getPoints(TMRPoint**) - int getExtPreOffset() - void writeToVTK(const char*) - void writeForestToVTK(const char*) - -cdef extern from "TMRBoundaryConditions.h": - cdef cppclass TMRBoundaryConditions(TMREntity): - TMRBoundaryConditions() - void addBoundaryCondition(const char*, int, const int*, - const TacsScalar*) - int getNumBoundaryConditions() - -cdef extern from "TMR_TACSCreator.h": - cdef cppclass TMRQuadTACSCreator(TMREntity): - TMRQuadTACSCreator(TMRBoundaryConditions*, int, TMRQuadForest*) - TMRQuadForest* getFilter() - - cdef cppclass TMROctTACSCreator(TMREntity): - TMROctTACSCreator(TMRBoundaryConditions*, int, TMROctForest*) - TMROctForest* getFilter() - -cdef extern from "TMROpenCascade.h": - cdef void TMR_SewModelIGES(char *, const char *, int, double, bool) - cdef void TMR_SewModelSTEP(char *, const char *, int, double, bool) - cdef TMRModel* TMR_LoadModelFromIGESFile(const char*, const char*, int) - cdef TMRModel* TMR_LoadModelFromSTEPFile(const char*, const char*, int) - -cdef extern from "TMREgads.h" namespace "TMR_EgadsInterface": - cdef TMRModel* TMR_ConvertEGADSModel"TMR_EgadsInterface::TMR_ConvertEGADSModel"(ego, int) - cdef TMRModel* TMR_LoadModelFromEGADSFile"TMR_EgadsInterface::TMR_LoadModelFromEGADSFile"(const char*, const char*, int) - -cdef extern from "TMR_RefinementTools.h": - void TMR_CreateTACSMg(int, TACSAssembler**, - TMRQuadForest**, TACSMg**, double, int, int, int) - void TMR_ComputeInterpSolution(TMRQuadForest*, TACSAssembler*, - TMRQuadForest*, TACSAssembler*, - TACSBVec*, TACSBVec*) - void TMR_ComputeReconSolution(TMRQuadForest*, TACSAssembler*, - TMRQuadForest*, TACSAssembler*, - TACSBVec*, TACSBVec*, int) - double TMR_StrainEnergyErrorEst(TMRQuadForest*, TACSAssembler*, - TMRQuadForest *, TACSAssembler*, - double*) - double TMR_AdjointErrorEst(TMRQuadForest*, TACSAssembler*, - TMRQuadForest*, TACSAssembler*, - TACSBVec*, TACSBVec*, double*, double*, double*) - - void TMR_CreateTACSMg(int, TACSAssembler**, - TMROctForest**, TACSMg**, double, int, int, int) - void TMR_ComputeInterpSolution(TMROctForest*, TACSAssembler*, - TMROctForest*, TACSAssembler*, - TACSBVec*, TACSBVec*) - void TMR_ComputeReconSolution(TMROctForest*, TACSAssembler*, - TMROctForest*, TACSAssembler*, - TACSBVec*, TACSBVec*, int) - double TMR_StrainEnergyErrorEst(TMROctForest*, TACSAssembler*, - TMROctForest *, TACSAssembler*, - double*) - double TMR_AdjointErrorEst(TMROctForest*, TACSAssembler*, - TMROctForest*, TACSAssembler*, - TACSBVec*, TACSBVec*, double*, double*) - -cdef extern from "TMRCyCreator.h": - ctypedef TACSElement* (*createquadelements)(void*, int, TMRQuadrant*) - ctypedef TACSElement* (*createoctelements)(void*, int, TMROctant*) - ctypedef TACSElement* (*createquadtopoelements)( - void*, int, TMRQuadrant*, int, TMRIndexWeight*) - ctypedef TACSElement* (*createocttopoelements)( - void*, int, TMROctant*, int, TMRIndexWeight*) - - cdef cppclass TMRCyQuadCreator(TMRQuadTACSCreator): - TMRCyQuadCreator(TMRBoundaryConditions*, int, TMRQuadForest*) - void setSelfPointer(void*) - void setCreateQuadElement( - TACSElement* (*createquadelements)(void*, int, TMRQuadrant*)) - TACSAssembler *createTACS(TMRQuadForest*, OrderingType, int, const char**) - - cdef cppclass TMRCyOctCreator(TMROctTACSCreator): - TMRCyOctCreator(TMRBoundaryConditions*, int, TMROctForest*) - void setSelfPointer(void*) - void setCreateOctElement( - TACSElement* (*createoctelements)(void*, int, TMROctant*)) - TACSAssembler *createTACS(TMROctForest*, OrderingType, int, const char**) - - cdef cppclass TMRCyTopoQuadCreator(TMRQuadTACSCreator): - TMRCyTopoQuadCreator(TMRBoundaryConditions*, int, TMRQuadForest*) - void setSelfPointer(void*) - void setCreateQuadTopoElement( - TACSElement* (*createquadtopoelements)( - void*, int, TMRQuadrant*, int, TMRIndexWeight*)) - TACSAssembler *createTACS(TMRQuadForest*, OrderingType) - - cdef cppclass TMRCyTopoOctCreator(TMROctTACSCreator): - TMRCyTopoOctCreator(TMRBoundaryConditions*, int, TMROctForest*) - void setSelfPointer(void*) - void setCreateOctTopoElement( - TACSElement* (*createocttopoelements)( - void*, int, TMROctant*, int, TMRIndexWeight*)) - TACSAssembler *createTACS(TMROctForest*, OrderingType) - - cdef cppclass TMRCyTopoQuadConformCreator(TMRQuadTACSCreator): - TMRCyTopoQuadConformCreator(TMRBoundaryConditions*, int, TMRQuadForest*, - int, TMRInterpolationType) - void setSelfPointer(void*) - void setCreateQuadTopoElement( - TACSElement* (*createquadtopoelements)( - void*, int, TMRQuadrant*, int, const int*, TMRQuadForest*)) - TACSAssembler *createTACS(TMRQuadForest*, OrderingType) - - cdef cppclass TMRCyTopoOctConformCreator(TMROctTACSCreator): - TMRCyTopoOctConformCreator(TMRBoundaryConditions*, int, TMROctForest*, - int, TMRInterpolationType) - void setSelfPointer(void*) - void setCreateOctTopoElement( - TACSElement* (*createocttopoelements)( - void*, int, TMROctant*, int, const int*, TMROctForest*)) - TACSAssembler *createTACS(TMROctForest*, OrderingType) - -cdef extern from "TMRTopoFilter.h": - cdef cppclass TMRTopoFilter(TMREntity): - TACSAssembler* getAssembler() - TMRQuadForest* getFilterQuadForest() - TMROctForest* getFilterOctForest() - void setDesignVars(TACSBVec*) - void getDesignVars(TACSBVec*) - void addValues(TACSBVec*) - void applyFilter(TACSBVec*, TACSBVec*) - void applyTranspose(TACSBVec*, TACSBVec*) - -cdef class TopoFilter: - cdef TMRTopoFilter *ptr - -cdef inline _init_TopoFilter(TMRTopoFilter *ptr): - fltr = TopoFilter() - fltr.ptr = ptr - fltr.ptr.incref() - return fltr - -cdef extern from "TMRLagrangeFilter.h": - cdef cppclass TMRLagrangeFilter(TMRTopoFilter): - TMRLagrangeFilter(int, TACSAssembler**, TMROctForest**) - TMRLagrangeFilter(int, TACSAssembler**, TMRQuadForest**) - -cdef extern from "TMRConformFilter.h": - cdef cppclass TMRConformFilter(TMRTopoFilter): - TMRConformFilter(int, TACSAssembler**, TMROctForest**) - TMRConformFilter(int, TACSAssembler**, TMRQuadForest**) - -cdef extern from "TMRHelmholtzFilter.h": - cdef cppclass TMRHelmholtzFilter(TMRTopoFilter): - TMRHelmholtzFilter(double, int, TACSAssembler**, TMROctForest**) - TMRHelmholtzFilter(double, int, TACSAssembler**, TMRQuadForest**) - -cdef extern from "TMRMatrixFilter.h": - cdef cppclass TMRMatrixFilter(TMRTopoFilter): - TMRMatrixFilter(double, int, int, TACSAssembler**, TMROctForest**) - TMRMatrixFilter(double, int, int, TACSAssembler**, TMRQuadForest**) - -cdef extern from "TMROctConstitutive.h": - cdef enum TMRTopoPenaltyType: - TMR_SIMP_PENALTY - TMR_RAMP_PENALTY - - cdef cppclass TMRStiffnessProperties(TMREntity): - TMRStiffnessProperties(int, TACSMaterialProperties**, - double, double, double, - TMRTopoPenaltyType, double, double, - double, double, double, double, int) - int nmats - TACSMaterialProperties **props - TMRTopoPenaltyType penalty_type - double stiffness_penalty_value - double stiffness_offset - double mass_penalty_value - double conduction_penalty_value - double temperature_penalty_value - double stress_relax_value - double ks_penalty - double beta - double xoffset - int use_project - - cdef cppclass TMROctConstitutive(TACSSolidConstitutive): - TMROctConstitutive(TMRStiffnessProperties*, TMROctForest*) - -cdef extern from "TMRQuadConstitutive.h": - cdef cppclass TMRQuadConstitutive(TACSPlaneStressConstitutive): - TMRQuadConstitutive(TMRStiffnessProperties*, TMRQuadForest*) - -cdef extern from "TMRHelmholtzPUFilter.h": - ctypedef int (*getinteriorstencil)( void*, int, int, - TacsScalar*, double* ) - ctypedef int (*getboundarystencil)( void*, int, TacsScalar*, int, - TacsScalar*, double* ) - - cdef cppclass TMRCallbackHelmholtzPUFilter(TMRTopoFilter): - TMRCallbackHelmholtzPUFilter(int, int, TACSAssembler**, - TMROctForest**) - TMRCallbackHelmholtzPUFilter(int, int, TACSAssembler**, - TMRQuadForest**) - void initialize() - void setSelfPointer(void*) - void setGetInteriorStencil(getinteriorstencil) - void setGetBoundaryStencil(getboundarystencil) - -cdef extern from "TMRTopoProblem.h": - ctypedef void (*writeoutputcallback)(void*, const char*, int, - TMROctForest*, TMRQuadForest*, - TACSBVec*) - ctypedef void (*constraintcallback)(void*, TMRTopoFilter*, TACSMg*, - int, TacsScalar*) - ctypedef void (*constraintgradientcallback)(void*, TMRTopoFilter*, TACSMg*, - int, TACSBVec**) - ctypedef void (*objectivecallback)(void*, TMRTopoFilter*, TACSMg*, - TacsScalar*) - ctypedef void (*objectivegradientcallback)(void*, TMRTopoFilter*, TACSMg*, - TACSBVec*) - ctypedef void (*qncorrectioncallback)(int, void*, ParOptVec*, ParOptScalar*, - ParOptVec*, ParOptVec*, ParOptVec*) - - cdef cppclass TMRTopoProblem(ParOptProblem): - TMRTopoProblem(TMRTopoFilter*, TACSMg*, int, double) - TACSAssembler *getAssembler() - TMRQuadForest* getFilterQuadForest() - TMROctForest* getFilterOctForest() - TMRTopoFilter* getTopoFilter() - TACSMg* getMg() - void setLoadCases(TACSBVec**, int) - int getNumLoadCases() - void addConstraints(int, TACSFunction**, - const TacsScalar*, const TacsScalar*, int) - void addLinearConstraints(ParOptVec**, TacsScalar*, int) - void addFrequencyConstraint(double, int, TacsScalar, - TacsScalar, TacsScalar, int, - double, int, int, double, double, - int, JDRecycleType) - void addBucklingConstraint(double, int, TacsScalar, - TacsScalar, TacsScalar, int, double) - void addConstraintCallback(int, int, void*, - void (*constraintcallback)(void*, TMRTopoFilter*, TACSMg*, - int, TacsScalar*), - void*, - void (*constraintgradientcallback)(void*, TMRTopoFilter*, TACSMg*, - int, TACSBVec**)) - void addQnCorrectionCallback(int, void*, - void (*qncorrectioncallback)(int, void*, ParOptVec*, ParOptScalar*, - ParOptVec*, ParOptVec*, ParOptVec*)) - void setObjective(const TacsScalar*) - void setObjective(const TacsScalar*, TACSFunction**) - void addObjectiveCallback(void*, - void (*objectivecallback)(void*, TMRTopoFilter*, TACSMg*, - TacsScalar*), - void*, - void (*objectivegradientcallback)(void*, TMRTopoFilter*, TACSMg*, - TACSBVec*)) - void initialize() - void setPrefix(const char*) - void setInitDesignVars(ParOptVec*,ParOptVec*,ParOptVec*) - void setIterationCounter(int) - ParOptVec* createDesignVec() - void setF5OutputFlags(int, ElementType, int) - void setF5EigenOutputFlags(int, ElementType, int) - void setOutputCallback(void*, - void (*writeoutputcallback)(void*, const char*, int, - TMROctForest*, TMRQuadForest*, - TACSBVec*)) - void useQnCorrectionComplianceObj() - void addNonDesignMass(ParOptVec*) - int evalObjCon(ParOptVec*, ParOptScalar*, ParOptScalar*) - int evalObjConGradient(ParOptVec*, ParOptVec*, ParOptVec**) - - cdef cppclass ParOptBVecWrap(ParOptVec): - ParOptBVecWrap(TACSBVec*) - TACSBVec *vec - -cdef extern from "TMR_STLTools.h": - int TMR_GenerateBinFile(const char*, TMROctForest*, - TACSBVec*, int, double) - int TMR_GenerateSTLTriangles(int, TMROctForest*, TACSBVec*, - int, double, int*, TMR_STLTriangle**) - -cdef extern from "TMRApproximateDistance.h": - void TMRApproximateDistance(TMRQuadForest*, int, double, double, - TACSBVec*, const char*, double*) - void TMRApproximateDistance(TMROctForest*, int, double, double, - TACSBVec*, const char*, double*) + return s.decode('utf-8') diff --git a/tmr/TMR.pyx b/tmr/TMR.pyx index 9a0fae6..a7851b9 100644 --- a/tmr/TMR.pyx +++ b/tmr/TMR.pyx @@ -1,4 +1,4 @@ -# distutils: language=c++ +#distutils: language=c++ # This file is part of the package TMR for adaptive mesh refinement. @@ -18,55 +18,45 @@ # See the License for the specific language governing permissions and # limitations under the License. -from __future__ import print_function, division - -# For the use of MPI -from mpi4py.libmpi cimport * +# # For the use of MPI cimport mpi4py.MPI as MPI # Import numpy cimport numpy as np import numpy as np -# Import the string library -from libcpp.string cimport string -from libc.string cimport strcpy - -cdef tmr_init(): - if not TMRIsInitialized(): - TMRInitialize() - # Ensure that numpy is initialized np.import_array() -# Initialize the MPI libraries in TMR (if not already done) -tmr_init() +# Import the string library +from libcpp.string cimport string +from libc.string cimport strcpy # Import tracebacks for callbacks import traceback from sys import exit # Import the definition required for const strings -from libc.string cimport const_char -from libc.stdlib cimport malloc, free +from libc.stdlib cimport const_char, malloc, free +from libcpp cimport bool # Import C methods for python from cpython cimport PyObject, Py_INCREF -# Include numpy and datatype related definitions -include "ParOptDefs.pxi" +# Import all of the TMR header files +from tmr.cpp_headers.TMR cimport * -# Import TACS and ParOpt -from tacs.TACS cimport * -from tacs.constitutive cimport * -from tacs.functions cimport * -from paropt.ParOpt cimport * -from egads4py.egads cimport * from tacs import TACS -from egads4py import egads -# Import the definitions -from TMR cimport * +cdef tmr_init(): + if not TMRIsInitialized(): + TMRInitialize() + +# Initialize the MPI libraries in TMR (if not already done) +tmr_init() + +# Include numpy and datatype related definitions +include "ParOptDefs.pxi" # Include the mpi4py header cdef extern from "mpi-compat.h": @@ -2345,6 +2335,7 @@ cdef class PointFeatureSize(ElementFeatureSize): return cdef class PointLocator: + cdef TMRPointLocator *ptr def __cinit__(self, np.ndarray[double, ndim=2, mode='c'] X): cdef int npts = 0 cdef TMRPoint *pts @@ -3814,16 +3805,16 @@ def sewModel(file, units="M", int print_level=0, sew_options={}): cdef char *filename = tmr_convert_str_to_chars(file) cdef const char *units_chars = tmr_convert_str_to_chars(units) if file.lower().endswith(('step', 'stp')): - TMR_SewModelSTEP(filename, - units_chars, - print_level, - sew_options.get("sew_tol",1e-6), + TMR_SewModelSTEP(filename, + units_chars, + print_level, + sew_options.get("sew_tol",1e-6), sew_options.get("nonmanifold_mode",False)) elif file.lower().endswith(('iges', 'igs')): - TMR_SewModelIGES(filename, - units_chars, - print_level, - sew_options.get("sew_tol",1e-6), + TMR_SewModelIGES(filename, + units_chars, + print_level, + sew_options.get("sew_tol",1e-6), sew_options.get("nonmanifold_mode",False)) else: print("model file extension not supported") @@ -3948,7 +3939,7 @@ cdef class BoundaryConditions: return cdef TACSElement* _createQuadElement(void *_self, int order, - TMRQuadrant *quad): + TMRQuadrant *quad) noexcept: cdef TACSElement *elem = NULL q = Quadrant() q.quad.x = quad.x @@ -4032,7 +4023,7 @@ cdef class QuadCreator: return None cdef TACSElement* _createOctElement(void *_self, int order, - TMROctant *octant): + TMROctant *octant) noexcept: cdef TACSElement *elem = NULL o = Octant() o.octant.x = octant.x @@ -4122,7 +4113,7 @@ cdef class OctCreator: cdef TACSElement* _createQuadTopoElement(void *_self, int order, TMRQuadrant *quad, int nweights, - TMRIndexWeight *weights): + TMRIndexWeight *weights) noexcept: cdef TACSElement *elem = NULL q = Quadrant() q.quad.x = quad.x @@ -4171,7 +4162,7 @@ cdef TACSElement* _createQuadConformTopoElement(void *_self, int order, TMRQuadrant *quad, int nweights, const int *index, - TMRQuadForest *filtr): + TMRQuadForest *filtr) noexcept: cdef TACSElement *elem = NULL q = Quadrant() q.quad.x = quad.x @@ -4222,7 +4213,7 @@ cdef class QuadConformTopoCreator: cdef TACSElement* _createOctTopoElement(void *_self, int order, TMROctant *octant, int nweights, - TMRIndexWeight *weights): + TMRIndexWeight *weights) noexcept: cdef TACSElement *elem = NULL oct = Octant() oct.octant.x = octant.x @@ -4273,7 +4264,7 @@ cdef TACSElement* _createOctConformTopoElement( void *_self, int order, TMROctant *octant, int nweights, const int *index, - TMROctForest *filtr): + TMROctForest *filtr) noexcept: cdef TACSElement *elem = NULL Oct = Octant() Oct.octant.x = octant.x @@ -4504,7 +4495,7 @@ def adjointError(forest, Assembler coarse, err_est = TMR_AdjointErrorEst(quad_forest, coarse.ptr, quad_forest_refined, refined.ptr, solution.getBVecPtr(), adjoint.getBVecPtr(), - node_error.data, + node_error.data, elem_error.data, &adj_corr) return err_est, adj_corr, elem_error, node_error @@ -4513,7 +4504,7 @@ def computeInterpSolution(forest, Assembler coarse, forest_refined, Assembler refined, Vec uvec=None, Vec uvec_refined=None): """ - Given coarse and fine sets of forests and assemblers, interpolates a field + Given coarse and fine sets of forests and assemblers, interpolates a field from the coarse space in the fine space using its higher-order basis. Parameters @@ -4563,9 +4554,9 @@ def computeReconSolution(forest, Assembler coarse, compute_diff=False): """ Given coarse and fine sets of forests and assemblers, reconstruct a field - in the fine-space given a field in the coarse-space. Enriches the field in + in the fine-space given a field in the coarse-space. Enriches the field in the fine-space with higher-order information obtained from local least- - square solutions on each element. + square solutions on each element. Parameters ----------- @@ -4584,10 +4575,10 @@ def computeReconSolution(forest, Assembler coarse, The fine-space field that is returned. If None, a vector is created by the fine assembler. compute_diff: Bool - If True, uvec_refined is the difference between the high-order + If True, uvec_refined is the difference between the high-order reconstructed field in the fine-space and the coarse-space field that is interpolated on the fine-space. If False, uvec_refined is just the high- - order reconstructed field in the fine-space. + order reconstructed field in the fine-space. """ cdef TMROctForest *oct_forest = NULL cdef TMROctForest *oct_forest_refined = NULL @@ -4664,11 +4655,11 @@ def getSTLTriangles(OctForest forest, Vec x, int offset=0, else: points = np.array([[]]) - # delete [] tris - return points cdef class TopoFilter: + cdef TMRTopoFilter *ptr + def __cinit__(self, *args, **kwargs): self.ptr = NULL @@ -4776,6 +4767,12 @@ cdef class TopoFilter: if self.ptr != NULL: self.ptr.applyTranspose(vec_in.getBVecPtr(), vec_out.getBVecPtr()) +cdef _init_TopoFilter(TMRTopoFilter *ptr): + fltr = TopoFilter() + fltr.ptr = ptr + fltr.ptr.incref() + return fltr + cdef class LagrangeFilter(TopoFilter): def __cinit__(self, list assemblers, list filters): cdef int nlevels = 0 @@ -4956,7 +4953,7 @@ cdef inplace_array_1d(int nptype, int dim1, void *data_ptr): return ndarray cdef int _getinteriorstencil(void *_self, int diag, int npts, - const TacsScalar *X, double *alphas ): + const TacsScalar *X, double *alphas) noexcept: cdef int fail = 0 try: _X = inplace_array_1d(np.NPY_DOUBLE, 3*npts, X) @@ -4971,7 +4968,7 @@ cdef int _getinteriorstencil(void *_self, int diag, int npts, cdef int _getboundarystencil(void *_self, int diag, const TacsScalar *n, int npts, - const TacsScalar *X, double *alphas ): + const TacsScalar *X, double *alphas) noexcept: cdef int fail = 0 try: _n = np.array([n[0], n[1], n[2]]) @@ -5279,7 +5276,7 @@ def ApproximateDistance(filtr, Vec x, int index=0, cdef void writeOutputCallback(void *func, const char *prefix, int iter, TMROctForest *octforest, TMRQuadForest *quadforest, - TACSBVec *x): + TACSBVec *x) noexcept: try: oct = None quad = None @@ -5296,7 +5293,7 @@ cdef void writeOutputCallback(void *func, const char *prefix, int iter, return cdef void constraintCallback(void *func, TMRTopoFilter *fltr, TACSMg *mg, - int ncon, TacsScalar *cvals): + int ncon, TacsScalar *cvals) noexcept: try: mgobj = None if mg != NULL: @@ -5311,7 +5308,7 @@ cdef void constraintCallback(void *func, TMRTopoFilter *fltr, TACSMg *mg, return cdef void constraintGradientCallback(void *func, TMRTopoFilter *fltr, TACSMg *mg, - int ncon, TACSBVec **dcdx): + int ncon, TACSBVec **dcdx) noexcept: try: mgobj = None if mg != NULL: @@ -5327,7 +5324,7 @@ cdef void constraintGradientCallback(void *func, TMRTopoFilter *fltr, TACSMg *mg return cdef void objectiveCallback(void *func, TMRTopoFilter *fltr, TACSMg *mg, - TacsScalar *fobj): + TacsScalar *fobj) noexcept: try: mgobj = None if mg != NULL: @@ -5340,7 +5337,7 @@ cdef void objectiveCallback(void *func, TMRTopoFilter *fltr, TACSMg *mg, return cdef void objectiveGradientCallback(void *func, TMRTopoFilter *fltr, TACSMg *mg, - TACSBVec *dfdx): + TACSBVec *dfdx) noexcept: try: mgobj = None if mg != NULL: @@ -5355,7 +5352,7 @@ cdef void objectiveGradientCallback(void *func, TMRTopoFilter *fltr, TACSMg *mg, return cdef void qnCorrectionCallback(int ncon, void *func, ParOptVec *_x, ParOptScalar *_z, - ParOptVec *_zw, ParOptVec *_s, ParOptVec *_y): + ParOptVec *_zw, ParOptVec *_s, ParOptVec *_y) noexcept: try: x = _init_PVec(_x) z = inplace_array_1d(np.NPY_DOUBLE, ncon, _z) diff --git a/tmr/__init__.pxd b/tmr/__init__.pxd new file mode 100644 index 0000000..e69de29 diff --git a/tmr/__init__.py b/tmr/__init__.py index fcb21ef..55b0793 100644 --- a/tmr/__init__.py +++ b/tmr/__init__.py @@ -4,6 +4,8 @@ import os +__all__ = [] + def get_cython_include(): """ diff --git a/tmr/cpp_headers/TMR.pxd b/tmr/cpp_headers/TMR.pxd new file mode 100644 index 0000000..a1cfa63 --- /dev/null +++ b/tmr/cpp_headers/TMR.pxd @@ -0,0 +1,696 @@ +# distutils: language=c++ + +# This file is part of the package TMR for adaptive mesh refinement. + +# Copyright (C) 2015 Georgia Tech Research Corporation. +# Additional copyright (C) 2015 Graeme Kennedy. +# All rights reserved. + +# TMR is licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this software except in compliance with the License. +# You may obtain a copy of the License at + +# http://www.apache.org/licenses/LICENSE-2.0 + +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +# For MPI +from mpi4py.libmpi cimport * +cimport mpi4py.MPI as MPI + +# Import string stuff +from libc.string cimport const_char +from libc.stdint cimport int32_t, int16_t + +# Import the definitions from the headers +from paropt.cpp_headers.ParOpt cimport ParOptScalar, ParOptVec, ParOptProblem +from tacs.cpp_headers.TACS cimport ( + TacsScalar, + TACSAssembler, + TACSElement, + TACSFunction, + TACSBVec, + TACSBVecInterp, + TACSMg, + OrderingType, + ElementType, + JDRecycleType, + JD_NUM_RECYCLE, +) +from tacs.cpp_headers.constitutive cimport ( + TACSMaterialProperties, + TACSPlaneStressConstitutive, + TACSSolidConstitutive, +) +from egads4py.egads cimport ego + +cdef extern from "TMRBase.h": + enum: + TMR_MAX_LEVEL"TMR_MAX_LEVEL" + + cdef cppclass TMREntity: + void incref() + void decref() + void setName(const char*) + const char* getName() + int getEntityId() + + cdef cppclass TMRPoint: + double x + double y + double z + + cdef cppclass TMRIndexWeight: + int index + double weight + + cdef cppclass TMR_STLTriangle: + TMRPoint p[3] + + void TMRInitialize() + int TMRIsInitialized() + void TMRFinalize() + + enum TMRInterpolationType: + TMR_UNIFORM_POINTS + TMR_GAUSS_LOBATTO_POINTS + TMR_BERNSTEIN_POINTS + +cdef extern from "TMRTopology.h": + cdef cppclass TMRTopology(TMREntity): + TMRTopology(MPI_Comm, TMRModel*) + void getVolume(int, TMRVolume**) + void getFace(int, TMRFace**) + void getEdge(int, TMREdge**) + void getVertex(int, TMRVertex**) + + cdef cppclass TMRVertex(TMREntity): + TMRVertex() + int evalPoint(TMRPoint*) + int setNodeNum(int*) + int getNodeNum(int*) + void setCopySource(TMRVertex*) + void getCopySource(TMRVertex**) + int isSame(TMRVertex*) + + cdef cppclass TMREdge(TMREntity): + TMREdge() + void setSource(TMREdge*) + void getSource(TMREdge**) + void getRange(double*, double*) + int evalPoint(double, TMRPoint*) + int evalDeriv(double, TMRPoint*, TMRPoint*) + int invEvalPoint(TMRPoint, double*) + void setVertices(TMRVertex*, TMRVertex*) + void getVertices(TMRVertex**, TMRVertex**) + int isDegenerate() + void setMesh(TMREdgeMesh*) + void getMesh(TMREdgeMesh**) + void setCopySource(TMREdge*) + void getCopySource(TMREdge**) + void writeToVTK(char*) + int isSame(TMREdge*) + + cdef cppclass TMRFace(TMREntity): + TMRFace() + TMRFace(int) + void getRange(double*, double*, double*, double*) + int evalPoint(double, double, TMRPoint*) + void setSource(TMRVolume*, TMRFace*) + void getSource(TMRVolume**, TMRFace**) + int getNumEdgeLoops() + void addEdgeLoop(int, TMREdgeLoop*) + void getEdgeLoop(int, TMREdgeLoop**) + void setMesh(TMRFaceMesh*) + void getMesh(TMRFaceMesh**) + void setCopySource(int, TMRFace*) + void getCopySource(int*, TMRFace**) + void writeToVTK(char*) + int isSame(TMRFace*) + + cdef cppclass TMREdgeLoop(TMREntity): + TMREdgeLoop(int, TMREdge**, const int*) + void getEdgeLoop(int*, TMREdge***, const int**) + + cdef cppclass TMRVolume(TMREntity): + TMRVolume(int, TMRFace**) + void getFaces(int*, TMRFace***) + void writeToVTK(char*) + + cdef cppclass TMRModel(TMREntity): + TMRModel(int, TMRVertex**, + int, TMREdge**, + int, TMRFace**, + int, TMRVolume**) + void getVertices(int*,TMRVertex***) + void getEdges(int*,TMREdge***) + void getFaces(int*,TMRFace***) + void getVolumes(int*,TMRVolume***) + +cdef extern from "TMRGeometry.h": + cdef cppclass TMRCurve(TMREntity): + void writeToVTK(char*) + + cdef cppclass TMRSurface(TMREntity): + void addCurveSegment(int, TMRCurve**, int*) + void writeToVTK(char*) + + cdef cppclass TMRPcurve(TMREntity): + pass + +cdef extern from "TMRNativeTopology.h": + cdef cppclass TMRVertexFromPoint(TMRVertex): + TMRVertexFromPoint(TMRPoint) + + cdef cppclass TMRVertexFromEdge(TMRVertex): + TMRVertexFromEdge(TMREdge*, double) + TMRVertexFromEdge(TMREdge*, TMRPoint) + + cdef cppclass TMRVertexFromFace(TMRVertex): + TMRVertexFromFace(TMRFace*, double, double) + TMRVertexFromFace(TMRFace*, TMRPoint) + + cdef cppclass TMREdgeFromFace(TMREdge): + TMREdgeFromFace(TMRFace*, TMRPcurve*) + TMREdgeFromFace(TMRFace*, TMRPcurve*, int) + void addEdgeFromFace(TMRFace*, TMRPcurve*) + + cdef cppclass TMRSplitEdge(TMREdge): + TMRSplitEdge(TMREdge*, double, double) + TMRSplitEdge(TMREdge*, TMRVertex*, TMRVertex*) + + cdef cppclass TMREdgeFromCurve(TMREdge): + TMREdgeFromCurve(TMRCurve*) + + cdef cppclass TMRFaceFromSurface(TMRFace): + TMRFaceFromSurface(TMRSurface*) + + cdef cppclass TMRTFIEdge(TMREdge): + TMRTFIEdge(TMRVertex*, TMRVertex*) + + cdef cppclass TMRTFIFace(TMRFace): + TMRTFIFace(TMREdge**, const int*, TMRVertex**) + +cdef extern from "TMRBspline.h": + cdef cppclass TMRBsplineCurve(TMRCurve): + TMRBsplineCurve(int, int, TMRPoint*) + TMRBsplineCurve(int, int, double*, TMRPoint*) + TMRBsplineCurve(int, int, double*, double*, TMRPoint*) + void getData(int*, int*, const double**, + const double**, const TMRPoint**) + void split(double, TMRBsplineCurve**, TMRBsplineCurve**) + + cdef cppclass TMRBsplineSurface(TMRSurface): + TMRBsplineSurface(int, int, int, int, TMRPoint*) + TMRBsplineSurface(int, int, int, int, + double*, double*, TMRPoint*) + TMRBsplineSurface(int, int, int, int, + double*, double*, double*, TMRPoint*) + void getData(int*, int*, int*, int*, const double**, const double**, + const double**, const TMRPoint**) + + cdef cppclass TMRBsplinePcurve(TMRPcurve): + TMRBsplinePcurve(int, int, double*) + TMRBsplinePcurve(int, int, double*, double*) + TMRBsplinePcurve(int, int, double*, double*, double*) + + cdef cppclass TMRCurveInterpolation(TMREntity): + TMRCurveInterpolation(TMRPoint*, int) + void setNumControlPoints(int) + TMRBsplineCurve *createCurve(int) + + cdef cppclass TMRCurveLofter(TMREntity): + TMRCurveLofter(TMRBsplineCurve**, int) + TMRBsplineSurface* createSurface(int) + +cdef extern from "": + void _deleteMe "delete [] "(int *array) + TMRBsplineCurve* _dynamicBsplineCurve "dynamic_cast"(TMRCurve*) + TMRBsplineSurface* _dynamicBsplineSurface "dynamic_cast"(TMRSurface*) + TMREdgeFromFace* _dynamicEdgeFromFace "dynamic_cast"(TMREdge*) + TMRTopoProblem* _dynamicTopoProblem "dynamic_cast"(ParOptProblem*) + ParOptBVecWrap* _dynamicParOptBVecWrap "dynamic_cast"(ParOptVec*) + +cdef extern from "TMRFeatureSize.h": + cdef cppclass TMRElementFeatureSize(TMREntity): + TMRElementFeatureSize() + TMRElementFeatureSize(double) + double getFeatureSize(TMRPoint) + + cdef cppclass TMRLinearElementSize(TMRElementFeatureSize): + TMRLinearElementSize(double, double, + double, double, double, double) + + cdef cppclass TMRBoxFeatureSize(TMRElementFeatureSize): + TMRBoxFeatureSize(TMRPoint, TMRPoint, double, double) + void addBox(TMRPoint, TMRPoint, double) + + cdef cppclass TMRPointFeatureSize(TMRElementFeatureSize): + TMRPointFeatureSize(int, TMRPoint*, double*, double, double, int) + + cdef cppclass TMRPointLocator(TMREntity): + TMRPointLocator(int, TMRPoint*) + void locateClosest(int, TMRPoint, int*, int*, double*) + +cdef extern from "TMREdgeMesh.h": + cdef cppclass TMREdgeMesh(TMREntity): + TMREdgeMesh(MPI_Comm, TMREdge*, TMRPoint*, int) + void mesh(TMRMeshOptions, TMRElementFeatureSize*) + void writeToVTK(const char*) + +cdef extern from "TMRFaceMesh.h": + cdef cppclass TMRFaceMesh(TMREntity): + TMRFaceMesh(MPI_Comm, TMRFace*, TMRPoint*, int, int*, int) + void mesh(TMRMeshOptions, TMRElementFeatureSize*) + void writeToVTK(const char*) + +cdef extern from "TMRVolumeMesh.h": + cdef cppclass TMRVolumeMesh(TMREntity): + TMRVolumeMesh(MPI_Comm, TMRVolume*) + void mesh(TMRMeshOptions) + void writeToVTK(const char*) + +cdef extern from "TMRMesh.h": + enum TMRFaceMeshType: + TMR_NO_MESH + TMR_STRUCTURED + TMR_UNSTRUCTURED + TMR_TRIANGLE + + cdef cppclass TMRMesh(TMREntity): + TMRMesh(MPI_Comm, TMRModel*) + void mesh(TMRMeshOptions, double) + void mesh(TMRMeshOptions, TMRElementFeatureSize*) + int getMeshPoints(TMRPoint**) + int getQuadConnectivity(int*, const int**) + int getTriConnectivity(int*, const int**) + int getHexConnectivity(int*, const int**) + int getTetConnectivity(int*, const int**) + + TMRModel *createModelFromMesh() + void writeToVTK(const char*, int) + void writeToBDF(const char*, int, TMRBoundaryConditions*) + + cdef cppclass TMRMeshOptions: + TMRMeshOptions() + TMRFaceMeshType mesh_type_default + int triangularize_print_level + int triangularize_print_iter + int write_mesh_quality_histogram + int num_smoothing_steps + double frontal_quality_factor + int reset_mesh_objects + int write_init_domain_triangle + int write_triangularize_intermediate + int write_pre_smooth_triangle + int write_post_smooth_triangle + int write_dual_recombine + int write_pre_smooth_quad + int write_post_smooth_quad + int write_quad_dual + +cdef extern from "TMRQuadrant.h": + cdef cppclass TMRQuadrant: + int childId() + void getSibling(int, TMRQuadrant*) + void parent(TMRQuadrant*) + void edgeNeighbor(int, TMRQuadrant*) + void cornerNeighbor(int, TMRQuadrant*) + int contains(TMRQuadrant*) + int32_t face + int32_t x + int32_t y + int32_t tag + int16_t level + int16_t info + + cdef cppclass TMRQuadrantArray: + TMRQuadrantArray(TMRQuadrant*, int) + TMRQuadrantArray* duplicate() + void getArray(TMRQuadrant**, int*) + void sort() + TMRQuadrant* contains(TMRQuadrant *q, int) + +cdef extern from "TMRQuadForest.h": + cdef cppclass TMRQuadForest(TMREntity): + TMRQuadForest(MPI_Comm, int, TMRInterpolationType) + MPI_Comm getMPIComm() + void setTopology(TMRTopology*) + TMRTopology* getTopology() + void setConnectivity(int, const int*, int) + void setFullConnectivity(int, int, int, const int*, const int*) + void repartition() + void createTrees(int) + void createRandomTrees(int, int, int) + void refine(int*, int, int) + TMRQuadForest *duplicate() + TMRQuadForest *coarsen() + void balance(int) + void createNodes() + int getMeshOrder() + TMRInterpolationType getInterpType() + void setMeshOrder(int, TMRInterpolationType) + void getNodeConn(const int**, int*) + int getDepNodeConn(const int**, const int**, const double**) + TMRQuadrantArray* getQuadsWithName(const char*) + int getNodesWithName(const char*, int**) + void createInterpolation(TMRQuadForest*, TACSBVecInterp*) + int getOwnedNodeRange(const int**) + void getQuadrants(TMRQuadrantArray**) + int getPoints(TMRPoint**) + int getLocalNodeNumber(int); + int getExtPreOffset() + void writeToVTK(const char*) + void writeForestToVTK(const char*) + +cdef extern from "TMROctant.h": + cdef cppclass TMROctant: + int childId() + void getSibling(int, TMROctant*) + void parent(TMROctant*) + void edgeNeighbor(int, TMROctant*) + void cornerNeighbor(int, TMROctant*) + void faceNeighbor(int, TMROctant) + int contains(TMROctant*) + int32_t block + int32_t x + int32_t y + int32_t z + int32_t tag + int16_t level + int16_t info + + cdef cppclass TMROctantArray: + TMROctantArray(TMROctant*, int) + TMROctantArray* duplicate() + void getArray(TMROctant**, int*) + void sort() + TMROctant* contains(TMROctant*, int) + +cdef extern from "TMROctForest.h": + cdef cppclass TMROctForest(TMREntity): + TMROctForest(MPI_Comm, int, TMRInterpolationType) + MPI_Comm getMPIComm() + void setTopology(TMRTopology*) + TMRTopology* getTopology() + void setConnectivity(int, const int*, int) + void setFullConnectivity(int, int, int, const int*, const int*) + void repartition(int) + void createTrees(int) + void createRandomTrees(int, int, int) + void refine(int*, int, int) + TMROctForest *duplicate() + TMROctForest *coarsen() + void balance(int) + void createNodes() + int getMeshOrder() + TMRInterpolationType getInterpType() + void setMeshOrder(int, TMRInterpolationType) + void getNodeConn(const int**, int*) + int getDepNodeConn(const int**, const int**, const double**) + TMROctantArray* getOctsWithName(const char*) + int getNodesWithName(const char*, int**) + void createInterpolation(TMROctForest*, TACSBVecInterp*) + int getOwnedNodeRange(const int**) + void getOctants(TMROctantArray**) + int getPoints(TMRPoint**) + int getExtPreOffset() + void writeToVTK(const char*) + void writeForestToVTK(const char*) + +cdef extern from "TMRBoundaryConditions.h": + cdef cppclass TMRBoundaryConditions(TMREntity): + TMRBoundaryConditions() + void addBoundaryCondition(const char*, int, const int*, + const TacsScalar*) + int getNumBoundaryConditions() + +cdef extern from "TMR_TACSCreator.h": + cdef cppclass TMRQuadTACSCreator(TMREntity): + TMRQuadTACSCreator(TMRBoundaryConditions*, int, TMRQuadForest*) + TMRQuadForest* getFilter() + + cdef cppclass TMROctTACSCreator(TMREntity): + TMROctTACSCreator(TMRBoundaryConditions*, int, TMROctForest*) + TMROctForest* getFilter() + +cdef extern from "TMROpenCascade.h": + cdef void TMR_SewModelIGES(char *, const char *, int, double, bool) + cdef void TMR_SewModelSTEP(char *, const char *, int, double, bool) + cdef TMRModel* TMR_LoadModelFromIGESFile(const char*, const char*, int) + cdef TMRModel* TMR_LoadModelFromSTEPFile(const char*, const char*, int) + +cdef extern from "TMREgads.h" namespace "TMR_EgadsInterface": + cdef TMRModel* TMR_ConvertEGADSModel"TMR_EgadsInterface::TMR_ConvertEGADSModel"(ego, int) + cdef TMRModel* TMR_LoadModelFromEGADSFile"TMR_EgadsInterface::TMR_LoadModelFromEGADSFile"(const char*, const char*, int) + +cdef extern from "TMR_RefinementTools.h": + void TMR_CreateTACSMg(int, TACSAssembler**, + TMRQuadForest**, TACSMg**, double, int, int, int) + void TMR_ComputeInterpSolution(TMRQuadForest*, TACSAssembler*, + TMRQuadForest*, TACSAssembler*, + TACSBVec*, TACSBVec*) + void TMR_ComputeReconSolution(TMRQuadForest*, TACSAssembler*, + TMRQuadForest*, TACSAssembler*, + TACSBVec*, TACSBVec*, int) + double TMR_StrainEnergyErrorEst(TMRQuadForest*, TACSAssembler*, + TMRQuadForest *, TACSAssembler*, + double*) + double TMR_AdjointErrorEst(TMRQuadForest*, TACSAssembler*, + TMRQuadForest*, TACSAssembler*, + TACSBVec*, TACSBVec*, double*, double*, double*) + + void TMR_CreateTACSMg(int, TACSAssembler**, + TMROctForest**, TACSMg**, double, int, int, int) + void TMR_ComputeInterpSolution(TMROctForest*, TACSAssembler*, + TMROctForest*, TACSAssembler*, + TACSBVec*, TACSBVec*) + void TMR_ComputeReconSolution(TMROctForest*, TACSAssembler*, + TMROctForest*, TACSAssembler*, + TACSBVec*, TACSBVec*, int) + double TMR_StrainEnergyErrorEst(TMROctForest*, TACSAssembler*, + TMROctForest *, TACSAssembler*, + double*) + double TMR_AdjointErrorEst(TMROctForest*, TACSAssembler*, + TMROctForest*, TACSAssembler*, + TACSBVec*, TACSBVec*, double*, double*) + +cdef extern from "TMRCyCreator.h": + ctypedef TACSElement* (*createquadelements)(void*, int, TMRQuadrant*) + ctypedef TACSElement* (*createoctelements)(void*, int, TMROctant*) + ctypedef TACSElement* (*createquadtopoelements)( + void*, int, TMRQuadrant*, int, TMRIndexWeight*) + ctypedef TACSElement* (*createocttopoelements)( + void*, int, TMROctant*, int, TMRIndexWeight*) + + cdef cppclass TMRCyQuadCreator(TMRQuadTACSCreator): + TMRCyQuadCreator(TMRBoundaryConditions*, int, TMRQuadForest*) + void setSelfPointer(void*) + void setCreateQuadElement( + TACSElement* (*createquadelements)(void*, int, TMRQuadrant*)) + TACSAssembler *createTACS(TMRQuadForest*, OrderingType, int, const char**) + + cdef cppclass TMRCyOctCreator(TMROctTACSCreator): + TMRCyOctCreator(TMRBoundaryConditions*, int, TMROctForest*) + void setSelfPointer(void*) + void setCreateOctElement( + TACSElement* (*createoctelements)(void*, int, TMROctant*)) + TACSAssembler *createTACS(TMROctForest*, OrderingType, int, const char**) + + cdef cppclass TMRCyTopoQuadCreator(TMRQuadTACSCreator): + TMRCyTopoQuadCreator(TMRBoundaryConditions*, int, TMRQuadForest*) + void setSelfPointer(void*) + void setCreateQuadTopoElement( + TACSElement* (*createquadtopoelements)( + void*, int, TMRQuadrant*, int, TMRIndexWeight*)) + TACSAssembler *createTACS(TMRQuadForest*, OrderingType) + + cdef cppclass TMRCyTopoOctCreator(TMROctTACSCreator): + TMRCyTopoOctCreator(TMRBoundaryConditions*, int, TMROctForest*) + void setSelfPointer(void*) + void setCreateOctTopoElement( + TACSElement* (*createocttopoelements)( + void*, int, TMROctant*, int, TMRIndexWeight*)) + TACSAssembler *createTACS(TMROctForest*, OrderingType) + + cdef cppclass TMRCyTopoQuadConformCreator(TMRQuadTACSCreator): + TMRCyTopoQuadConformCreator(TMRBoundaryConditions*, int, TMRQuadForest*, + int, TMRInterpolationType) + void setSelfPointer(void*) + void setCreateQuadTopoElement( + TACSElement* (*createquadtopoelements)( + void*, int, TMRQuadrant*, int, const int*, TMRQuadForest*)) + TACSAssembler *createTACS(TMRQuadForest*, OrderingType) + + cdef cppclass TMRCyTopoOctConformCreator(TMROctTACSCreator): + TMRCyTopoOctConformCreator(TMRBoundaryConditions*, int, TMROctForest*, + int, TMRInterpolationType) + void setSelfPointer(void*) + void setCreateOctTopoElement( + TACSElement* (*createocttopoelements)( + void*, int, TMROctant*, int, const int*, TMROctForest*)) + TACSAssembler *createTACS(TMROctForest*, OrderingType) + +cdef extern from "TMRTopoFilter.h": + cdef cppclass TMRTopoFilter(TMREntity): + TACSAssembler* getAssembler() + TMRQuadForest* getFilterQuadForest() + TMROctForest* getFilterOctForest() + void setDesignVars(TACSBVec*) + void getDesignVars(TACSBVec*) + void addValues(TACSBVec*) + void applyFilter(TACSBVec*, TACSBVec*) + void applyTranspose(TACSBVec*, TACSBVec*) + +cdef extern from "TMRLagrangeFilter.h": + cdef cppclass TMRLagrangeFilter(TMRTopoFilter): + TMRLagrangeFilter(int, TACSAssembler**, TMROctForest**) + TMRLagrangeFilter(int, TACSAssembler**, TMRQuadForest**) + +cdef extern from "TMRConformFilter.h": + cdef cppclass TMRConformFilter(TMRTopoFilter): + TMRConformFilter(int, TACSAssembler**, TMROctForest**) + TMRConformFilter(int, TACSAssembler**, TMRQuadForest**) + +cdef extern from "TMRHelmholtzFilter.h": + cdef cppclass TMRHelmholtzFilter(TMRTopoFilter): + TMRHelmholtzFilter(double, int, TACSAssembler**, TMROctForest**) + TMRHelmholtzFilter(double, int, TACSAssembler**, TMRQuadForest**) + +cdef extern from "TMRMatrixFilter.h": + cdef cppclass TMRMatrixFilter(TMRTopoFilter): + TMRMatrixFilter(double, int, int, TACSAssembler**, TMROctForest**) + TMRMatrixFilter(double, int, int, TACSAssembler**, TMRQuadForest**) + +cdef extern from "TMROctConstitutive.h": + cdef enum TMRTopoPenaltyType: + TMR_SIMP_PENALTY + TMR_RAMP_PENALTY + + cdef cppclass TMRStiffnessProperties(TMREntity): + TMRStiffnessProperties(int, TACSMaterialProperties**, + double, double, double, + TMRTopoPenaltyType, double, double, + double, double, double, double, int) + int nmats + TACSMaterialProperties **props + TMRTopoPenaltyType penalty_type + double stiffness_penalty_value + double stiffness_offset + double mass_penalty_value + double conduction_penalty_value + double temperature_penalty_value + double stress_relax_value + double ks_penalty + double beta + double xoffset + int use_project + + cdef cppclass TMROctConstitutive(TACSSolidConstitutive): + TMROctConstitutive(TMRStiffnessProperties*, TMROctForest*) + +cdef extern from "TMRQuadConstitutive.h": + cdef cppclass TMRQuadConstitutive(TACSPlaneStressConstitutive): + TMRQuadConstitutive(TMRStiffnessProperties*, TMRQuadForest*) + +cdef extern from "TMRHelmholtzPUFilter.h": + ctypedef int (*getinteriorstencil)( void*, int, int, + TacsScalar*, double* ) + ctypedef int (*getboundarystencil)( void*, int, TacsScalar*, int, + TacsScalar*, double* ) + + cdef cppclass TMRCallbackHelmholtzPUFilter(TMRTopoFilter): + TMRCallbackHelmholtzPUFilter(int, int, TACSAssembler**, + TMROctForest**) + TMRCallbackHelmholtzPUFilter(int, int, TACSAssembler**, + TMRQuadForest**) + void initialize() + void setSelfPointer(void*) + void setGetInteriorStencil(getinteriorstencil) + void setGetBoundaryStencil(getboundarystencil) + +cdef extern from "TMRTopoProblem.h": + ctypedef void (*writeoutputcallback)(void*, const char*, int, + TMROctForest*, TMRQuadForest*, + TACSBVec*) + ctypedef void (*constraintcallback)(void*, TMRTopoFilter*, TACSMg*, + int, TacsScalar*) + ctypedef void (*constraintgradientcallback)(void*, TMRTopoFilter*, TACSMg*, + int, TACSBVec**) + ctypedef void (*objectivecallback)(void*, TMRTopoFilter*, TACSMg*, + TacsScalar*) + ctypedef void (*objectivegradientcallback)(void*, TMRTopoFilter*, TACSMg*, + TACSBVec*) + ctypedef void (*qncorrectioncallback)(int, void*, ParOptVec*, ParOptScalar*, + ParOptVec*, ParOptVec*, ParOptVec*) + + cdef cppclass TMRTopoProblem(ParOptProblem): + TMRTopoProblem(TMRTopoFilter*, TACSMg*, int, double) + TACSAssembler *getAssembler() + TMRQuadForest* getFilterQuadForest() + TMROctForest* getFilterOctForest() + TMRTopoFilter* getTopoFilter() + TACSMg* getMg() + void setLoadCases(TACSBVec**, int) + int getNumLoadCases() + void addConstraints(int, TACSFunction**, + const TacsScalar*, const TacsScalar*, int) + void addLinearConstraints(ParOptVec**, TacsScalar*, int) + void addFrequencyConstraint(double, int, TacsScalar, + TacsScalar, TacsScalar, int, + double, int, int, double, double, + int, JDRecycleType) + void addBucklingConstraint(double, int, TacsScalar, + TacsScalar, TacsScalar, int, double) + void addConstraintCallback(int, int, void*, + void (*constraintcallback)(void*, TMRTopoFilter*, TACSMg*, + int, TacsScalar*), + void*, + void (*constraintgradientcallback)(void*, TMRTopoFilter*, TACSMg*, + int, TACSBVec**)) + void addQnCorrectionCallback(int, void*, + void (*qncorrectioncallback)(int, void*, ParOptVec*, ParOptScalar*, + ParOptVec*, ParOptVec*, ParOptVec*)) + void setObjective(const TacsScalar*) + void setObjective(const TacsScalar*, TACSFunction**) + void addObjectiveCallback(void*, + void (*objectivecallback)(void*, TMRTopoFilter*, TACSMg*, + TacsScalar*), + void*, + void (*objectivegradientcallback)(void*, TMRTopoFilter*, TACSMg*, + TACSBVec*)) + void initialize() + void setPrefix(const char*) + void setInitDesignVars(ParOptVec*,ParOptVec*,ParOptVec*) + void setIterationCounter(int) + ParOptVec* createDesignVec() + void setF5OutputFlags(int, ElementType, int) + void setF5EigenOutputFlags(int, ElementType, int) + void setOutputCallback(void*, + void (*writeoutputcallback)(void*, const char*, int, + TMROctForest*, TMRQuadForest*, + TACSBVec*)) + void useQnCorrectionComplianceObj() + void addNonDesignMass(ParOptVec*) + int evalObjCon(ParOptVec*, ParOptScalar*, ParOptScalar*) + int evalObjConGradient(ParOptVec*, ParOptVec*, ParOptVec**) + + cdef cppclass ParOptBVecWrap(ParOptVec): + ParOptBVecWrap(TACSBVec*) + TACSBVec *vec + +cdef extern from "TMR_STLTools.h": + int TMR_GenerateBinFile(const char*, TMROctForest*, + TACSBVec*, int, double) + int TMR_GenerateSTLTriangles(int, TMROctForest*, TACSBVec*, + int, double, int*, TMR_STLTriangle**) + +cdef extern from "TMRApproximateDistance.h": + void TMRApproximateDistance(TMRQuadForest*, int, double, double, + TACSBVec*, const char*, double*) + void TMRApproximateDistance(TMROctForest*, int, double, double, + TACSBVec*, const char*, double*) diff --git a/tmr/cpp_headers/__init__.pxd b/tmr/cpp_headers/__init__.pxd new file mode 100644 index 0000000..e69de29 diff --git a/tmr/pytacsadapt.py b/tmr/pytacsadapt.py index 48e67d0..a56b801 100644 --- a/tmr/pytacsadapt.py +++ b/tmr/pytacsadapt.py @@ -436,9 +436,9 @@ def setupModel(self, model_type, **kwargs): # record the number of degrees of freedom for this model nnodes = model.assembler.getNumOwnedNodes() - self.mesh_history[ - model.prob_name - ] = model.assembler.getVarsPerNode() * model.comm.allreduce(nnodes, op=MPI.SUM) + self.mesh_history[model.prob_name] = ( + model.assembler.getVarsPerNode() * model.comm.allreduce(nnodes, op=MPI.SUM) + ) return def solvePrimal(self, model_type, writeSolution=False, **kwargs): @@ -662,9 +662,9 @@ def estimateOutputError(self, writeSolution=False): # update histories self.error_history[f"adapt_iter_{self.fine.refine_iter}_error"] = error_estimate - self.error_history[ - f"adapt_iter_{self.fine.refine_iter}_correction" - ] = output_correction + self.error_history[f"adapt_iter_{self.fine.refine_iter}_correction"] = ( + output_correction + ) # write out the nodal error field if writeSolution: @@ -942,9 +942,9 @@ def writeModelHistory(self, filename=""): for key, val in self.adaptation_history["element_errors"].items(): h5[f"adaptation_history/element_errors/{key}"] = val if self.adapt_strategy: - h5["adaptation_history"].attrs[ - "strategy" - ] = self.adapt_strategy.replace("_", " ").lower() + h5["adaptation_history"].attrs["strategy"] = ( + self.adapt_strategy.replace("_", " ").lower() + ) h5["adaptation_history"].attrs["error_tolerance"] = self.error_tol h5["adaptation_history"].attrs[ "max_refine_levels"