当前位置: 首页>>代码示例>>C++>>正文


C++ Model::FormRegionFrom方法代码示例

本文整理汇总了C++中Model::FormRegionFrom方法的典型用法代码示例。如果您正苦于以下问题:C++ Model::FormRegionFrom方法的具体用法?C++ Model::FormRegionFrom怎么用?C++ Model::FormRegionFrom使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Model的用法示例。


在下文中一共展示了Model::FormRegionFrom方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: configure

		/**
		This is based on a nearest node criterion to all boundaries.

		@todo Improve efficiency. In most cases, we should be able to specify boundaries as planes
		@todo Somewhat dependent on the resolution of the model boundary
		*/
		bool OmegaBDistanceConfigurator::configure(Model& m) const
		{
			Point<3> ebc;
			m.UpdateIndices();
			vector<size_t> omega_ids;
			omega_ids.reserve(m.Region("Model").Elements());
			for (const auto& eit : m.Region("Model").ElementVector())
			{
				ebc = eit->BaryCenter();
				double dmin = numeric_limits<double>::max();
				for (Model::boundaryIterator bit = m.BoundariesBegin(); bit != m.BoundariesEnd(); ++bit)
				{
					if (!is_main_boundary_id(bit->first.second))
						continue;
					for (const auto& bnit : bit->second.NodeVector())
					{
						double const dist = ebc.DistanceTo(bnit->Coordinate());
						if (dist < dmin)
							dmin = dist;
					}
				}
				if (dmin >= dist_)
					omega_ids.push_back(eit->Idx());
			}
			if (omega_ids.size()) {
				m.FormRegionFrom("omega", omega_ids);
				return true;
			}
			return false;
		}
开发者ID:robinnthomas,项目名称:tensor_permeability,代码行数:36,代码来源:omega_bdistance_configurator.cpp

示例2: configure

		bool OmegaCornerPointsConfigurator::configure(Model& m) const
		{		
			size_t i(0);
			Point<3> ebc;
			m.UpdateIndices();
			for (const auto& cpp : cpts_) {
				auto cmm = min_max(cpp);
				vector<size_t> omega_ids;
				omega_ids.reserve(m.Region("Model").Elements());
				for (const auto& eit : m.Region("Model").ElementVector())
				{
					ebc = eit->BaryCenter();
					if (!within_bounds(ebc, cmm))
						continue;						// not within min-max bounds
					omega_ids.push_back(eit->Idx());    // is within min-max bounds
				}
				auto rname = (string)"omega_" + to_string(i); ++i;
				if (omega_ids.size())
					m.FormRegionFrom(rname.c_str(), omega_ids);
			}
			return true;
		}
开发者ID:robinnthomas,项目名称:tensor_permeability,代码行数:22,代码来源:omega_corner_points_configurator.cpp


注:本文中的Model::FormRegionFrom方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。