1 // Copyright (C) 2007-2016 CEA/DEN, EDF R&D, OPEN CASCADE
3 // Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
6 // This library is free software; you can redistribute it and/or
7 // modify it under the terms of the GNU Lesser General Public
8 // License as published by the Free Software Foundation; either
9 // version 2.1 of the License, or (at your option) any later version.
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 // Lesser General Public License for more details.
16 // You should have received a copy of the GNU Lesser General Public
17 // License along with this library; if not, write to the Free Software
18 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
20 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
23 // NETGENPlugin : C++ implementation
24 // File : NETGENPlugin_Hypothesis_i.cxx
25 // Author : Michael Sazonov (OCN)
28 //=============================================================================
30 #include "NETGENPlugin_Hypothesis_i.hxx"
31 #include "SMESH_Gen.hxx"
32 #include "SMESH_PythonDump.hxx"
34 #include "Utils_CorbaException.hxx"
35 #include "utilities.h"
39 //=============================================================================
41 * Specialization of isToSetParameter<T> for double
43 //=============================================================================
46 bool NETGENPlugin_Hypothesis_i::isToSetParameter<double>(double curValue,
48 /*SettingMethod*/int meth)
50 return isToSetParameter(true, (fabs(curValue - newValue) < 1e-20), meth);
53 //=============================================================================
55 * NETGENPlugin_Hypothesis_i::NETGENPlugin_Hypothesis_i
59 //=============================================================================
60 NETGENPlugin_Hypothesis_i::
61 NETGENPlugin_Hypothesis_i (PortableServer::POA_ptr thePOA,
62 ::SMESH_Gen* theGenImpl)
63 : SALOME::GenericObj_i( thePOA ),
64 SMESH_Hypothesis_i( thePOA ),
67 myBaseImpl = new ::NETGENPlugin_Hypothesis (theGenImpl->GetANewId(),
71 //=============================================================================
73 * NETGENPlugin_Hypothesis_i::~NETGENPlugin_Hypothesis_i
77 //=============================================================================
78 NETGENPlugin_Hypothesis_i::~NETGENPlugin_Hypothesis_i()
82 //=============================================================================
84 * NETGENPlugin_Hypothesis_i::SetMaxSize
88 //=============================================================================
89 void NETGENPlugin_Hypothesis_i::SetMaxSize (CORBA::Double theValue)
91 if ( isToSetParameter( GetMaxSize(), theValue, METH_SetMaxSize ))
93 this->GetImpl()->SetMaxSize(theValue);
94 SMESH::TPythonDump() << _this() << ".SetMaxSize( " << SMESH::TVar(theValue) << " )";
98 //=============================================================================
100 * NETGENPlugin_Hypothesis_i::GetMaxSize
104 //=============================================================================
105 CORBA::Double NETGENPlugin_Hypothesis_i::GetMaxSize()
107 return this->GetImpl()->GetMaxSize();
110 //=============================================================================
112 * NETGENPlugin_Hypothesis_i::SetMinSize
116 //=============================================================================
117 void NETGENPlugin_Hypothesis_i::SetMinSize (CORBA::Double theValue)
119 if ( isToSetParameter( GetMinSize(), theValue, METH_SetMinSize ))
121 this->GetImpl()->SetMinSize(theValue);
122 SMESH::TPythonDump() << _this() << ".SetMinSize( " << SMESH::TVar(theValue) << " )";
126 //=============================================================================
128 * NETGENPlugin_Hypothesis_i::GetMinSize
132 //=============================================================================
133 CORBA::Double NETGENPlugin_Hypothesis_i::GetMinSize()
135 return this->GetImpl()->GetMinSize();
138 //=============================================================================
140 * NETGENPlugin_Hypothesis_i::SetSecondOrder
142 * Set SecondOrder flag
144 //=============================================================================
145 void NETGENPlugin_Hypothesis_i::SetSecondOrder (CORBA::Boolean theValue)
147 if ( isToSetParameter( GetSecondOrder(), theValue, METH_SetSecondOrder ))
149 this->GetImpl()->SetSecondOrder(theValue);
150 SMESH::TPythonDump() << _this() << ".SetSecondOrder( " << theValue << " )";
154 //=============================================================================
156 * NETGENPlugin_Hypothesis_i::GetSecondOrder
158 * Get SecondOrder flag
160 //=============================================================================
161 CORBA::Boolean NETGENPlugin_Hypothesis_i::GetSecondOrder()
163 return this->GetImpl()->GetSecondOrder();
166 //=============================================================================
168 * NETGENPlugin_Hypothesis_i::SetOptimize
172 //=============================================================================
173 void NETGENPlugin_Hypothesis_i::SetOptimize (CORBA::Boolean theValue)
175 if ( isToSetParameter( GetOptimize(), theValue, METH_SetOptimize ))
177 this->GetImpl()->SetOptimize(theValue);
178 SMESH::TPythonDump() << _this() << ".SetOptimize( " << theValue << " )";
182 //=============================================================================
184 * NETGENPlugin_Hypothesis_i::GetOptimize
188 //=============================================================================
189 CORBA::Boolean NETGENPlugin_Hypothesis_i::GetOptimize()
191 return this->GetImpl()->GetOptimize();
194 //=============================================================================
196 * NETGENPlugin_Hypothesis_i::SetFineness
200 //=============================================================================
201 void NETGENPlugin_Hypothesis_i::SetFineness (CORBA::Long theValue)
203 if ( isToSetParameter( GetFineness(), theValue, METH_SetFineness ))
205 this->GetImpl()->SetFineness((::NETGENPlugin_Hypothesis::Fineness)theValue);
206 SMESH::TPythonDump() << _this() << ".SetFineness( " << theValue << " )";
210 //=============================================================================
212 * NETGENPlugin_Hypothesis_i::GetFineness
216 //=============================================================================
217 CORBA::Long NETGENPlugin_Hypothesis_i::GetFineness()
219 return this->GetImpl()->GetFineness();
222 //=============================================================================
224 * NETGENPlugin_Hypothesis_i::SetGrowthRate
228 //=============================================================================
229 void NETGENPlugin_Hypothesis_i::SetGrowthRate (CORBA::Double theValue)
231 if ( isToSetParameter( GetGrowthRate(), theValue, METH_SetGrowthRate ))
233 this->GetImpl()->SetGrowthRate(theValue);
234 SMESH::TPythonDump() << _this() << ".SetGrowthRate( " << SMESH::TVar(theValue) << " )";
238 //=============================================================================
240 * NETGENPlugin_Hypothesis_i::GetGrowthRate
244 //=============================================================================
245 CORBA::Double NETGENPlugin_Hypothesis_i::GetGrowthRate()
247 return this->GetImpl()->GetGrowthRate();
250 //=============================================================================
252 * NETGENPlugin_Hypothesis_i::SetNbSegPerEdge
256 //=============================================================================
257 void NETGENPlugin_Hypothesis_i::SetNbSegPerEdge (CORBA::Double theValue)
259 if ( isToSetParameter( GetNbSegPerEdge(), theValue, METH_SetNbSegPerEdge ))
261 this->GetImpl()->SetNbSegPerEdge(theValue);
262 SMESH::TPythonDump() << _this() << ".SetNbSegPerEdge( " << SMESH::TVar(theValue) << " )";
266 //=============================================================================
268 * NETGENPlugin_Hypothesis_i::GetNbSegPerEdge
272 //=============================================================================
273 CORBA::Double NETGENPlugin_Hypothesis_i::GetNbSegPerEdge()
275 return this->GetImpl()->GetNbSegPerEdge();
278 //=============================================================================
280 * NETGENPlugin_Hypothesis_i::SetNbSegPerRadius
284 //=============================================================================
285 void NETGENPlugin_Hypothesis_i::SetNbSegPerRadius (CORBA::Double theValue)
287 if ( isToSetParameter( GetNbSegPerRadius(), theValue, METH_SetNbSegPerRadius ))
289 this->GetImpl()->SetNbSegPerRadius(theValue);
290 SMESH::TPythonDump() << _this() << ".SetNbSegPerRadius( " << SMESH::TVar(theValue) << " )";
294 //=============================================================================
296 * NETGENPlugin_Hypothesis_i::GetNbSegPerRadius
300 //=============================================================================
301 CORBA::Double NETGENPlugin_Hypothesis_i::GetNbSegPerRadius()
303 return this->GetImpl()->GetNbSegPerRadius();
306 //=============================================================================
308 void NETGENPlugin_Hypothesis_i::SetChordalErrorEnabled(CORBA::Boolean theValue)
310 if ( isToSetParameter( GetChordalErrorEnabled(), theValue, METH_SetChordalErrorEnabled ))
312 this->GetImpl()->SetChordalErrorEnabled(theValue);
313 SMESH::TPythonDump() << _this() << ".SetChordalErrorEnabled( " << theValue << " )";
317 CORBA::Boolean NETGENPlugin_Hypothesis_i::GetChordalErrorEnabled()
319 return GetImpl()->GetChordalErrorEnabled();
322 void NETGENPlugin_Hypothesis_i::SetChordalError(CORBA::Double theValue)
324 if ( isToSetParameter( GetChordalError(), theValue, METH_SetChordalError ))
326 this->GetImpl()->SetChordalError(theValue);
327 SMESH::TPythonDump() << _this() << ".SetChordalError( " << SMESH::TVar(theValue) << " )";
331 CORBA::Double NETGENPlugin_Hypothesis_i::GetChordalError()
333 return GetImpl()->GetChordalError();
336 //=============================================================================
338 void NETGENPlugin_Hypothesis_i::SetLocalSizeOnShape(GEOM::GEOM_Object_ptr GeomObj,
339 CORBA::Double localSize)
340 throw (SALOME::SALOME_Exception)
343 entry = GeomObj->GetStudyEntry();
345 THROW_SALOME_CORBA_EXCEPTION( "SetLocalSizeOnShape(), shape is not published in study!",
347 SetLocalSizeOnEntry(entry.c_str(), localSize);
350 //=============================================================================
352 void NETGENPlugin_Hypothesis_i::SetLocalSizeOnEntry(const char* entry,
353 CORBA::Double localSize)
355 if ( isToSetParameter( GetLocalSizeOnEntry(entry), localSize, METH_SetLocalSizeOnEntry ))
357 this->GetImpl()->SetLocalSizeOnEntry(entry, localSize);
359 << _this() << ".SetLocalSizeOnShape(" << entry << ", " << localSize << ")";
363 //=============================================================================
365 CORBA::Double NETGENPlugin_Hypothesis_i::GetLocalSizeOnEntry(const char* entry)
367 return this->GetImpl()->GetLocalSizeOnEntry(entry);
370 //=============================================================================
372 NETGENPlugin::string_array* NETGENPlugin_Hypothesis_i::GetLocalSizeEntries()
374 NETGENPlugin::string_array_var result = new NETGENPlugin::string_array();
375 const ::NETGENPlugin_Hypothesis::TLocalSize localSizes =
376 this->GetImpl()->GetLocalSizesAndEntries();
377 result->length(localSizes.size());
378 ::NETGENPlugin_Hypothesis::TLocalSize::const_iterator it = localSizes.begin();
379 for (int i=0 ; it != localSizes.end() ; i++, it++)
381 string entry = (*it).first;
382 result[i] = CORBA::string_dup(entry.c_str());
384 return result._retn();
387 //=============================================================================
389 void NETGENPlugin_Hypothesis_i::UnsetLocalSizeOnEntry(const char* entry)
391 this->GetImpl()->UnsetLocalSizeOnEntry(entry);
392 SMESH::TPythonDump() << _this() << ".UnsetLocalSizeOnEntry(\"" << entry << "\")";
395 //=============================================================================
397 void NETGENPlugin_Hypothesis_i::SetMeshSizeFile(const char* fileName)
399 if ( GetImpl()->GetMeshSizeFile() != fileName )
401 GetImpl()->SetMeshSizeFile( fileName );
402 SMESH::TPythonDump() << _this() << ".SetMeshSizeFile( '" << fileName << "' )";
406 //=============================================================================
408 char* NETGENPlugin_Hypothesis_i::GetMeshSizeFile()
410 return CORBA::string_dup( GetImpl()->GetMeshSizeFile().c_str() );
413 //=============================================================================
415 void NETGENPlugin_Hypothesis_i::SetQuadAllowed (CORBA::Boolean theValue)
417 if ( NETGENPlugin_Hypothesis_i::isToSetParameter( GetQuadAllowed(),
419 METH_SetQuadAllowed ))
421 this->GetImpl()->SetQuadAllowed(theValue);
422 SMESH::TPythonDump() << _this() << ".SetQuadAllowed( " << theValue << " )";
426 //=============================================================================
428 CORBA::Boolean NETGENPlugin_Hypothesis_i::GetQuadAllowed()
430 return this->GetImpl()->GetQuadAllowed();
433 //=============================================================================
435 void NETGENPlugin_Hypothesis_i::SetUseSurfaceCurvature (CORBA::Boolean theValue)
437 if ( NETGENPlugin_Hypothesis_i::isToSetParameter( GetUseSurfaceCurvature(),
439 METH_SetSurfaceCurvature ))
441 this->GetImpl()->SetSurfaceCurvature(theValue);
442 SMESH::TPythonDump() << _this() << ".SetUseSurfaceCurvature( " << theValue << " )";
446 //=============================================================================
448 CORBA::Boolean NETGENPlugin_Hypothesis_i::GetUseSurfaceCurvature()
450 return this->GetImpl()->GetSurfaceCurvature();
453 //=============================================================================
455 void NETGENPlugin_Hypothesis_i::SetFuseEdges (CORBA::Boolean theValue)
457 if ( NETGENPlugin_Hypothesis_i::isToSetParameter( GetFuseEdges(),
461 this->GetImpl()->SetFuseEdges(theValue);
462 SMESH::TPythonDump() << _this() << ".SetFuseEdges( " << theValue << " )";
466 //=============================================================================
468 CORBA::Boolean NETGENPlugin_Hypothesis_i::GetFuseEdges()
470 return this->GetImpl()->GetFuseEdges();
473 //=======================================================================
474 //function : SetNbSurfOptSteps
476 //=======================================================================
478 void NETGENPlugin_Hypothesis_i::SetNbSurfOptSteps(CORBA::Short nb )
480 if ( GetNbSurfOptSteps() != nb )
482 this->GetImpl()->SetNbSurfOptSteps( nb );
483 SMESH::TPythonDump() << _this() << ".SetNbSurfOptSteps( " << SMESH::TVar(nb) << " )";
487 //=======================================================================
488 //function : GetNbSurfOptSteps
490 //=======================================================================
492 CORBA::Short NETGENPlugin_Hypothesis_i::GetNbSurfOptSteps()
494 return GetImpl()->GetNbSurfOptSteps();
497 //=======================================================================
498 //function : SetNbVolOptSteps
500 //=======================================================================
502 void NETGENPlugin_Hypothesis_i::SetNbVolOptSteps(CORBA::Short nb )
504 if ( GetNbVolOptSteps() != nb )
506 this->GetImpl()->SetNbVolOptSteps( nb );
507 SMESH::TPythonDump() << _this() << ".SetNbVolOptSteps( " << SMESH::TVar(nb) << " )";
512 //=======================================================================
513 //function : GetNbVolOptSteps
515 //=======================================================================
517 CORBA::Short NETGENPlugin_Hypothesis_i::GetNbVolOptSteps()
519 return GetImpl()->GetNbVolOptSteps();
522 //=======================================================================
523 //function : SetElemSizeWeight
525 //=======================================================================
527 void NETGENPlugin_Hypothesis_i::SetElemSizeWeight(CORBA::Double size )
529 if ( GetElemSizeWeight() != size )
531 this->GetImpl()->SetElemSizeWeight( size );
532 SMESH::TPythonDump() << _this() << ".SetElemSizeWeight( " << SMESH::TVar(size) << " )";
536 //=======================================================================
537 //function : GetElemSizeWeight
539 //=======================================================================
541 CORBA::Double NETGENPlugin_Hypothesis_i::GetElemSizeWeight()
543 return GetImpl()->GetElemSizeWeight();
546 //=======================================================================
547 //function : SetWorstElemMeasure
549 //=======================================================================
551 void NETGENPlugin_Hypothesis_i::SetWorstElemMeasure(CORBA::Short val )
553 if ( GetWorstElemMeasure() != val )
555 this->GetImpl()->SetWorstElemMeasure( val );
556 SMESH::TPythonDump() << _this() << ".SetWorstElemMeasure( " << SMESH::TVar(val) << " )";
560 //=======================================================================
561 //function : GetWorstElemMeasure
563 //=======================================================================
565 CORBA::Short NETGENPlugin_Hypothesis_i::GetWorstElemMeasure()
567 return GetImpl()->GetWorstElemMeasure();
570 //=======================================================================
571 //function : SetUseDelauney
573 //=======================================================================
575 void NETGENPlugin_Hypothesis_i::SetUseDelauney(CORBA::Boolean toUse)
577 if ( GetUseDelauney() != toUse )
579 this->GetImpl()->SetUseDelauney( toUse );
580 SMESH::TPythonDump() << _this() << ".SetUseDelauney( " << toUse << " )";
584 //=======================================================================
585 //function : GetUseDelauney
587 //=======================================================================
589 CORBA::Boolean NETGENPlugin_Hypothesis_i::GetUseDelauney()
591 return GetImpl()->GetUseDelauney();
594 //=======================================================================
595 //function : SetCheckOverlapping
597 //=======================================================================
599 void NETGENPlugin_Hypothesis_i::SetCheckOverlapping(CORBA::Boolean toCheck )
601 if ( GetCheckOverlapping() != toCheck )
603 this->GetImpl()->SetCheckOverlapping( toCheck );
604 SMESH::TPythonDump() << _this() << ".SetCheckOverlapping( " << toCheck << " )";
608 //=======================================================================
609 //function : GetCheckOverlapping
611 //=======================================================================
613 CORBA::Boolean NETGENPlugin_Hypothesis_i::GetCheckOverlapping()
615 return GetImpl()->GetCheckOverlapping();
618 //=======================================================================
619 //function : SetCheckChartBoundary
621 //=======================================================================
623 void NETGENPlugin_Hypothesis_i::SetCheckChartBoundary(CORBA::Boolean toCheck )
625 if ( GetCheckChartBoundary() != toCheck )
627 this->GetImpl()->SetCheckChartBoundary( toCheck );
628 SMESH::TPythonDump() << _this() << ".SetCheckChartBoundary( " << toCheck << " )";
632 //=======================================================================
633 //function : GetCheckChartBoundary
634 //purpose : Get implementation
635 //=======================================================================
637 CORBA::Boolean NETGENPlugin_Hypothesis_i::GetCheckChartBoundary()
639 return GetImpl()->GetCheckChartBoundary();
642 //=============================================================================
644 * NETGENPlugin_Hypothesis_i::GetImpl
648 //=============================================================================
649 ::NETGENPlugin_Hypothesis* NETGENPlugin_Hypothesis_i::GetImpl()
651 return (::NETGENPlugin_Hypothesis*)myBaseImpl;
654 //================================================================================
656 * \brief Verify whether hypothesis supports given entity type
657 * \param type - dimension (see SMESH::Dimension enumeration)
658 * \retval CORBA::Boolean - TRUE if dimension is supported, FALSE otherwise
660 * Verify whether hypothesis supports given entity type (see SMESH::Dimension enumeration)
662 //================================================================================
663 CORBA::Boolean NETGENPlugin_Hypothesis_i::IsDimSupported( SMESH::Dimension type )
665 return type == SMESH::DIM_3D;
668 //================================================================================
670 * \brief method intended to remove explicit treatment of Netgen hypotheses from SMESH_NoteBook
672 //================================================================================
674 int NETGENPlugin_Hypothesis_i::getParamIndex(const TCollection_AsciiString& method,
677 if ( method == "SetMaxSize" ) return 0;
678 if ( method == "SetGrowthRate" ) return 1;
679 if ( method == "SetNbSegPerEdge" ) return 2;
680 if ( method == "SetNbSegPerRadius" ) return 3;
681 if ( method == "SetMinSize" ) return nbVars-1;
683 return SMESH_Hypothesis_i::getParamIndex( method, nbVars ); // return default value
686 //================================================================================
688 * \brief Method used to convert variable parameters stored in an old study
689 * into myMethod2VarParams. It should return a method name for an index of
690 * variable parameters. Index is countered from zero
692 //================================================================================
694 std::string NETGENPlugin_Hypothesis_i::getMethodOfParameter(const int paramIndex,
697 switch ( paramIndex ) {
698 case 0: return "SetMaxSize";
699 case 1: return nbVars == 2 ? "SetMinSize" : "SetGrowthRate";
700 case 2: return "SetNbSegPerEdge";
701 case 3: return "SetNbSegPerRadius";
702 case 4: return "SetMinSize";
707 //================================================================================
709 * \brief Return geometry this hypothesis depends on. Return false if there is no geometry parameter
711 //================================================================================
714 NETGENPlugin_Hypothesis_i::getObjectsDependOn( std::vector< std::string > & entryArray,
715 std::vector< int > & subIDArray ) const
717 typedef ::NETGENPlugin_Hypothesis THyp;
719 const THyp* h = static_cast< ::NETGENPlugin_Hypothesis* >( myBaseImpl );
720 const THyp::TLocalSize& ls = h->GetLocalSizesAndEntries();
722 THyp::TLocalSize::const_iterator entry2size = ls.cbegin();
723 for ( ; entry2size != ls.cend(); ++entry2size )
724 entryArray.push_back( entry2size->first );
729 //================================================================================
731 * \brief Set new geometry instead of that returned by getObjectsDependOn()
733 //================================================================================
736 NETGENPlugin_Hypothesis_i::setObjectsDependOn( std::vector< std::string > & entryArray,
737 std::vector< int > & subIDArray )
739 typedef ::NETGENPlugin_Hypothesis THyp;
741 const THyp* h = static_cast< ::NETGENPlugin_Hypothesis* >( myBaseImpl );
743 THyp::TLocalSize& lsNew = const_cast< THyp::TLocalSize& >( h->GetLocalSizesAndEntries() );
747 THyp::TLocalSize::const_iterator entry2size = ls.cbegin();
748 for ( int i = 0; entry2size != ls.cend(); ++entry2size, ++i )
749 if ( !entryArray[ i ].empty() )
750 lsNew[ entryArray[ i ]] = entry2size->second;