// Copyright (C) 2007-2025 CEA, EDF, OPEN CASCADE // // Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN, // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS // // This library is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 2.1 of the License, or (at your option) any later version. // // This library is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. // // You should have received a copy of the GNU Lesser General Public // License along with this library; if not, write to the Free Software // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA // // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com // // File : SMESH_Gen.idl // Author : Paul RASCLE, EDF #ifndef _SMESH_GEN_IDL_ #define _SMESH_GEN_IDL_ #include "SALOME_Exception.idl" #include "SALOME_Component.idl" #include "SALOMEDS.idl" #include "GEOM_Gen.idl" #include "SMESH_Mesh.idl" #include "SMESH_Hypothesis.idl" #include "SMESH_smIdType.idl" module SMESHHOMARD { interface HOMARD_Gen; }; module SMESH { typedef sequence sobject_list; typedef sequence object_array; typedef sequence mesh_array; interface FilterManager; interface SMESH_Pattern; interface Measurements; interface MG_ADAPT; interface MG_ADAPT_OBJECT; /*! * Tags definition */ // Top level const long Tag_HypothesisRoot = 1; // hypotheses root const long Tag_AlgorithmsRoot = 2; // algorithms root const long Tag_FirstMeshRoot = 3; // first mesh root // Mesh/Submesh const long Tag_RefOnShape = 1; // references to shape const long Tag_RefOnAppliedHypothesis = 2; // applied hypotheses root const long Tag_RefOnAppliedAlgorithms = 3; // applied algorithms root // Mesh only: sub-meshes roots by type const long Tag_FirstSubMesh = 4; const long Tag_SubMeshOnVertex = 4; const long Tag_SubMeshOnEdge = 5; const long Tag_SubMeshOnWire = 6; const long Tag_SubMeshOnFace = 7; const long Tag_SubMeshOnShell = 8; const long Tag_SubMeshOnSolid = 9; const long Tag_SubMeshOnCompound = 10; const long Tag_LastSubMesh = 10; // Mesh only: group roots by type const long Tag_FirstGroup = 11; const long Tag_NodeGroups = 11; const long Tag_EdgeGroups = 12; const long Tag_FaceGroups = 13; const long Tag_VolumeGroups = 14; const long Tag_0DElementsGroups = 15; const long Tag_BallElementsGroups = 16; const long Tag_LastGroup = 16; /*! * Hypothesis definition error */ struct AlgoStateError { Hypothesis_Status state; string algoName; long algoDim; boolean isGlobalAlgo; }; typedef sequence algo_error_array; /*! * Mesh computation error */ enum ComputeErrorName { COMPERR_OK , COMPERR_BAD_INPUT_MESH, // wrong mesh on lower submesh COMPERR_STD_EXCEPTION , // some std exception raised COMPERR_OCC_EXCEPTION , // OCC exception raised COMPERR_SLM_EXCEPTION , // SALOME exception raised COMPERR_EXCEPTION , // other exception raised COMPERR_MEMORY_PB , // memory allocation problem COMPERR_ALGO_FAILED , // computation failed COMPERR_BAD_SHAPE , // bad geometry COMPERR_WARNING , // algo reports error but sub-mesh is computed anyway COMPERR_CANCELED , // compute canceled COMPERR_NO_MESH_ON_SHAPE,// no mesh elements assigned to sub-mesh COMPERR_BAD_PARMETERS // incorrect hypotheses parameters }; struct ComputeError { short code; // ComputeErrorName or, if negative, algo specific code string comment; // textual problem description string algoName; long subShapeID; // id of sub-shape of a shape to mesh boolean hasBadMesh; // there are elements preventing computation available for visualization }; typedef sequence compute_error_array; /*! * Way to initialize hypothesis */ struct HypInitParams { short way; // 0 - by mesh, 1 - by geometry size + preferred parameters, 2 - by averageLength double averageLength; boolean quadDominated; }; interface SMESH_Gen : Engines::EngineComponent, SALOMEDS::Driver { //GEOM::GEOM_Gen SetGeomEngine( in string containerLoc ); void SetGeomEngine( in GEOM::GEOM_Gen geomcompo ); FilterManager CreateFilterManager(); SMESH_Pattern GetPattern(); Measurements CreateMeasurements(); /*! Set the current mode */ void SetEmbeddedMode( in boolean theMode ); /*! Get the current mode */ boolean IsEmbeddedMode(); /*! Update the study */ void UpdateStudy(); /*! Set enable publishing in the study */ void SetEnablePublish( in boolean theIsEnablePublish ); /*! Get enable publishing in the study */ boolean IsEnablePublish(); /*! * Create a hypothesis that can be shared by different parts of the mesh. * An hypothesis is either: * - a method used to generate or modify a part of the mesh (algorithm). * - a parameter or a law used by an algorithm. * Algorithms are 1D, 2D or 3D. */ SMESH_Hypothesis CreateHypothesis( in string theHypName, in string theLibName ) raises ( SALOME::SALOME_Exception ); /*! * Create a hypothesis and initialize it by average length */ SMESH_Hypothesis CreateHypothesisByAverageLength( in string theHypName, in string theLibName, in double theAverageLength, in boolean theQuadDominated) raises ( SALOME::SALOME_Exception ); /*! * Return a hypothesis holding parameter values corresponding either to the mesh * existing on the given geometry or to size of the geometry. * The returned hypothesis may be the one existing in a study and used * to compute the mesh, or a temporary one created just to pass parameter * values. */ SMESH_Hypothesis GetHypothesisParameterValues( in string theHypName, in string theLibName, in SMESH_Mesh theMesh, in GEOM::GEOM_Object theGeom, in HypInitParams theWay) raises ( SALOME::SALOME_Exception ); /*! * Returns \c True if a hypothesis is assigned to a sole sub-mesh in a current Study * \param [in] theHyp - the hypothesis of interest * \param [out] theMesh - the sole mesh using \a theHyp * \param [out] theShape - the sole geometry \a theHyp is assigned to * \return boolean - \c True if \a theMesh and \a theShape are sole using \a theHyp */ boolean GetSoleSubMeshUsingHyp( in SMESH_Hypothesis theHyp, out SMESH_Mesh theMesh, out GEOM::GEOM_Object theShape); /*! * Sets number of segments per diagonal of boundary box of geometry by which * default segment length of appropriate 1D hypotheses is defined */ void SetBoundaryBoxSegmentation( in long theNbSegments ) raises ( SALOME::SALOME_Exception ); /*! * \brief Sets default number of segments per edge */ void SetDefaultNbSegments( in long theNbSegments) raises ( SALOME::SALOME_Exception ); /*! * Set the object name */ void SetName( in string theObjectIOR, in string theObjectName ) raises ( SALOME::SALOME_Exception ); /*! * Create a Mesh object, given a geometry shape. * Mesh is created empty (no points, no elements). * Shape is explored via GEOM_Client to create local copies. * of TopoDS_Shapes and bind CORBA references of shape & subshapes * with TopoDS_Shapes */ SMESH_Mesh CreateMesh( in GEOM::GEOM_Object theObject ) raises ( SALOME::SALOME_Exception ); /*! * Create a Mesh object, given a geometry shape. * Mesh is created empty (no points, no elements). * Shape is explored via GEOM_Client to create local copies. * of TopoDS_Shapes and bind CORBA references of shape & subshapes * with TopoDS_Shapes * The mesh is a parallel one */ SMESH_ParallelMesh CreateParallelMesh( in GEOM::GEOM_Object theObject ) raises ( SALOME::SALOME_Exception ); /*! * Create an empty mesh object */ SMESH_Mesh CreateEmptyMesh() raises ( SALOME::SALOME_Exception ); SMESH_Mesh ReloadMeshFromFile(in SMESH_Mesh sourceMesh) raises(SALOME::SALOME_Exception); /*! * Create Mesh object importing data from given UNV file * (UNV supported version is I-DEAS 10) */ SMESH_Mesh CreateMeshesFromUNV( in string theFileName ) raises ( SALOME::SALOME_Exception ); /*! * Create Mesh object(s) importing data from given MED file */ mesh_array CreateMeshesFromMED( in string theFileName, out SMESH::DriverMED_ReadStatus theStatus ) raises ( SALOME::SALOME_Exception ); /*! * Create Mesh object importing data from given STL file */ SMESH_Mesh CreateMeshesFromSTL( in string theFileName ) raises ( SALOME::SALOME_Exception ); /*! * Create Mesh object(s) importing data from given CGNS file */ mesh_array CreateMeshesFromCGNS( in string theFileName, out SMESH::DriverMED_ReadStatus theStatus ) raises ( SALOME::SALOME_Exception ); /*! * Create Mesh object importing data from given GMF file * \param theFileName - a name of file to import * \param theMakeRequiredGroups - if true, groups of required entities will be created */ SMESH_Mesh CreateMeshesFromGMF( in string theFileName, in boolean theMakeRequiredGroups, out SMESH::ComputeError theError) raises ( SALOME::SALOME_Exception ); /*! * Create a mesh and import data from any file supported by meshio library */ mesh_array CreateMeshesFromMESHIO(in string theFileName, out SMESH::DriverMED_ReadStatus theStatus) raises (SALOME::SALOME_Exception); /*! * Create a dual mesh of a Tetrahedron mesh * \param mesh - TetraHedron mesh to create dual from * \param meshName - a name of the new mesh * \param adaptToShape - if True project boundary point on shape */ SMESH_Mesh CreateDualMesh(in SMESH_IDSource mesh, in string meshName, in boolean adaptToShape) raises ( SALOME::SALOME_Exception ); /*! * Create a mesh by copying a part of another mesh * \param meshPart - a part of mesh to copy * \param meshName - a name of the new mesh * \param toCopyGroups - to create in the new mesh groups * the copied elements belongs to * \param toKeepIDs - to preserve IDs of the copied elements or not */ SMESH_Mesh CopyMesh(in SMESH_IDSource meshPart, in string meshName, in boolean toCopyGroups, in boolean toKeepIDs) raises ( SALOME::SALOME_Exception ); /*! * Create a mesh by copying definitions of another mesh to a given geometry * \param sourceMesh - a mesh to copy * \param newGeometry - a new geometry * \param meshName - a name of the new mesh * \param toCopyGroups - to create groups in the new mesh * \param toReuseHypotheses - if True, existing hypothesis will be used by the new mesh, * otherwise new hypotheses with the same parameters will be created for the new mesh. * \param toCopyElements - to copy mesh elements of same sub-shapes of the two geometries * \param newMesh - return a new mesh * \param newGroups - return new groups * \param newSubmeshes - return new sub-meshes * \param newHypotheses - return new algorithms and hypotheses * \param invalidEntries - return study entries of objects whose * counterparts are not found in the newGeometry, followed by entries * of mesh sub-objects that are invalid because they depend on a not found * preceding sub-shape */ boolean CopyMeshWithGeom( in SMESH_Mesh sourceMesh, in GEOM::GEOM_Object newGeometry, in string meshName, in boolean toCopyGroups, in boolean toReuseHypotheses, in boolean toCopyElements, out SMESH_Mesh newMesh, out ListOfGroups newGroups, out submesh_array newSubmeshes, out ListOfHypothesis newHypotheses, out string_array invalidEntries) raises ( SALOME::SALOME_Exception ); /*! * Concatenate the given meshes or groups into one mesh, * optionally to theMeshToAppendTo. * Union groups with the same name and type if * theUniteIdenticalGroups flag is true. * Merge coincident nodes and elements if * theMergeNodesAndElements flag is true. */ SMESH_Mesh Concatenate(in ListOfIDSources theMeshesArray, in boolean theUniteIdenticalGroups, in boolean theMergeNodesAndElements, in double theMergeTolerance, in SMESH_Mesh theMeshToAppendTo) raises ( SALOME::SALOME_Exception ); /*! * Concatenate the given meshes into one mesh, * optionally to theMeshToAppendTo. * Union groups with the same name and type if * theUniteIdenticalGroups flag is true. * Merge coincident nodes and elements if * theMergeNodesAndElements flag is true. * Create the groups of all elements from initial meshes. */ SMESH_Mesh ConcatenateWithGroups(in ListOfIDSources theMeshesArray, in boolean theUniteIdenticalGroups, in boolean theMergeNodesAndElements, in double theMergeTolerance, in SMESH_Mesh theMeshToAppendTo) raises ( SALOME::SALOME_Exception ); /*! * Mesh a subShape. * First, verify list of hypothesis associated with the Sub-shape, * return NOK if hypothesis are not sufficient */ boolean Compute( in SMESH_Mesh theMesh, in GEOM::GEOM_Object theSubObject ) raises ( SALOME::SALOME_Exception ); /*! * Cancel a computation. */ void CancelCompute( in SMESH_Mesh theMesh, in GEOM::GEOM_Object theSubObject ); /*! * Return true if hypotheses are defined well */ boolean IsReadyToCompute( in SMESH_Mesh theMesh, in GEOM::GEOM_Object theSubObject ) raises ( SALOME::SALOME_Exception ); /*! * Evaluates size of prospective mesh on a shape */ smIdType_array Evaluate(in SMESH_Mesh theMesh, in GEOM::GEOM_Object theSubObject) raises ( SALOME::SALOME_Exception ); /*! * Calculate Mesh as preview till indicated dimension * First, verify list of hypothesis associated with the Sub-shape. * Return mesh preview structure */ MeshPreviewStruct Precompute( in SMESH_Mesh theMesh, in GEOM::GEOM_Object theSubObject, in Dimension theDimension, inout long_array theShapesId ) raises ( SALOME::SALOME_Exception ); /*! * Return errors of hypotheses definition * algo_error_array is empty if everything is OK */ algo_error_array GetAlgoState( in SMESH_Mesh theMesh, in GEOM::GEOM_Object theSubObject ) raises ( SALOME::SALOME_Exception ); /*! * Return errors of mesh computation * compute_error_array is empty if everything is OK */ compute_error_array GetComputeErrors( in SMESH_Mesh theMesh, in GEOM::GEOM_Object theSubObject ) raises ( SALOME::SALOME_Exception ); /*! * Return mesh elements preventing computation of a sub-shape */ MeshPreviewStruct GetBadInputElements( in SMESH_Mesh theMesh, in short theSubShapeID ) raises ( SALOME::SALOME_Exception ); /*! * Create groups of elements preventing computation of a sub-shape */ SMESH::ListOfGroups MakeGroupsOfBadInputElements( in SMESH_Mesh theMesh, in short theSubShapeID, in string theGroupName) raises ( SALOME::SALOME_Exception ); /*! * Return indices of faces, edges and vertices of given sub-shapes * within theMainObject */ long_array GetSubShapesId( in GEOM::GEOM_Object theMainObject, in object_array theListOfSubObjects ) raises ( SALOME::SALOME_Exception ); /*! * Return geometrical object the given element is built on. * The returned geometrical object, if not nil, is either found in the * study or is published by this method with the given name */ GEOM::GEOM_Object GetGeometryByMeshElement( in SMESH_Mesh theMesh, in smIdType theElementID, in string theGeomName) raises ( SALOME::SALOME_Exception ); /*! * Return geometrical object the given element is built on. * The returned geometrical object not published in study by this method. */ GEOM::GEOM_Object FindGeometryByMeshElement( in SMESH_Mesh theMesh, in smIdType theElementID) raises ( SALOME::SALOME_Exception ); /*! * \brief Return id of object, registered in current study context * * Can be used to check if the object was created in the same container, as this engine. */ long GetObjectId(in Object theObject); /*! * \brief Get version of MED format being used. */ string GetMEDFileVersion(); /*! * \brief Get MED version of the file by its name. */ string GetMEDVersion(in string theFileName); /*! * \brief Check compatibility of file with MED format being used, for read only. */ boolean CheckCompatibility(in string theFileName); /*! * \brief Check compatibility of file with MED format being used, for append on write. */ boolean CheckWriteCompatibility(in string theFileName); /*! * \brief Get names of meshes defined in file with the specified name. */ string_array GetMeshNames(in string theFileName); /*! * \brief Moves objects to the specified position * \param what objects being moved * \param where parent object where objects are moved to * \param row position in the parent object's children list at which objects are moved * * This function is used in the drag-n-drop functionality. */ void Move( in sobject_list what, in SALOMEDS::SObject where, in long row ); /*! * Returns true if algorithm can be used to mesh a given geometry * \param theAlgoType - the algorithm type * \param theLibName - a name of the Plug-in library implementing the algorithm * \param theShapeObject - the geometry to mesh * \param toCheckAll - if \c True, returns \c True if all shapes are meshable, * else, returns \c True if at least one shape is meshable */ boolean IsApplicable( in string theAlgoType, in string theLibName, in GEOM::GEOM_Object theShapeObject, in boolean toCheckAll ); /*! * Return indices of elements, which are located inside the sphere * \param theSource - mesh, sub-mesh or group * \param theElemType - mesh element type * \param theX - x coordinate of the center of the sphere * \param theY - y coordinate of the center of the sphere * \param theZ - y coordinate of the center of the sphere * \param theR - radius of the sphere */ long_array GetInsideSphere( in SMESH_IDSource theSource, in ElementType theElemType, in double theX, in double theY, in double theZ, in double theR ); /*! * Return indices of elements, which are located inside the box * \param theSource - mesh, sub-mesh or group * \param theElemType - mesh element type * \param theX1 - x coordinate of the first opposite point * \param theY1 - y coordinate of the first opposite point * \param theZ1 - y coordinate of the first opposite point * \param theX2 - x coordinate of the second opposite point * \param theY2 - y coordinate of the second opposite point * \param theZ2 - y coordinate of the second opposite point */ long_array GetInsideBox( in SMESH_IDSource theSource, in ElementType theElemType, in double theX1, in double theY1, in double theZ1, in double theX2, in double theY2, in double theZ2); /*! * Return indices of elements, which are located inside the box * \param theSource - mesh, sub-mesh or group * \param theElemType - mesh element type * \param theX - x coordinate of the cented of the bottom face * \param theY - y coordinate of the cented of the bottom face * \param theZ - y coordinate of the cented of the bottom face * \param theDX - x coordinate of the cented of the base vector * \param theDY - y coordinate of the cented of the base vector * \param theDZ - z coordinate of the cented of the base vector * \param theH - height of the cylinder * \param theR - radius of the cylinder */ long_array GetInsideCylinder( in SMESH_IDSource theSource, in ElementType theElemType, in double theX, in double theY, in double theZ, in double theDX, in double theDY, in double theDZ, in double theH, in double theR ); /*! * Return indices of elements, which are located inside the geometry * \param theSource - mesh, sub-mesh or group * \param theElemType - mesh element type * \param theGeom - geometrical object * \param theTolerance - tolerance for selection. */ long_array GetInside( in SMESH_IDSource theSource, in ElementType theElemType, in GEOM::GEOM_Object theGeom, in double theTolerance ); MG_ADAPT CreateMG_ADAPT(); SMESHHOMARD::HOMARD_Gen CreateHOMARD_ADAPT() raises ( SALOME::SALOME_Exception ); //MG_ADAPT_OBJECT Adaptation(in string adaptType); SALOME::GenericObj Adaptation(in string adaptType) raises ( SALOME::SALOME_Exception ); MG_ADAPT CreateAdaptationHypothesis(); }; }; #endif