当前位置: 首页 > news >正文

洛阳市网站建设_网站建设公司_过渡效果_seo优化

seo网站排名优化案例,虚拟主机如何安装WordPress,成都最新的防疫通告,湖人队最新消息文章目录 前言一、一、8*32面 受均布载荷 二、最小的面#xff08;8*16#xff09;受均布载荷三、最大的面受均布载荷 前言 只是为方便学习#xff0c;不做其他用途#xff0c; 一、 一、8*32面 受均布载荷 /// This is an example of using the linear elasticity solver… 文章目录 前言一、一、8*32面 受均布载荷 二、最小的面8*16受均布载荷三、最大的面受均布载荷 前言 只是为方便学习不做其他用途 一、 一、8*32面 受均布载荷 /// This is an example of using the linear elasticity solver on a 3D multi-patch geometry. /// The problems is part of the EU project Terrific. /// /// 示例边长为 8 16 32 的长方体 /// 8*32面 受均布载荷 /// Authors: O. Weeger (2012-1015, TU Kaiserslautern), /// A.Shamanskiy (2016 - ...., TU Kaiserslautern) #include gismo.h #include gsElasticity/gsElasticityAssembler.h #include gsElasticity/gsWriteParaviewMultiPhysics.h #include gsElasticity/gsGeoUtils.h #includeiostreamusing namespace std; using namespace gismo;int main(int argc, char* argv[]) {gsInfo Testing the linear elasticity solver in 3D-线弹性求解器的三维测试.\n;////// Input ////////std::string filename(terrific.xml);//初始数据文件std::string filename(test.xml);//初始数据文件real_t youngsModulus 1e5;//杨氏模量real_t poissonsRatio 0.3;//泊松比index_t numUniRef 0;//节点插入数index_t numDegElev 1;//升阶次数index_t numPlotPoints 10000;//preview软件画图的点数量// minimalistic user interface for terminal 终端最简用户界面gsCmdLine cmd(Testing the linear elasticity solver in 3D.);// 定义一个gsCmdLine类 命名为cmdcmd.addInt(r, refine, Number of uniform refinement application, numUniRef);cmd.addInt(d, degelev, Number of degree elevation application, numDegElev);cmd.addInt(p, points, Number of points to plot to Paraview, numPlotPoints);try { cmd.getValues(argc, argv); } // 不太用看 不知道这个命令代表啥catch (int rv) { return rv; }////// Scanning geometry and creating bases:扫描几何和创建基函数 //////// scanning geometry 扫描几何gsMultiPatch geometry; // 定义一个多片gsReadFile(filename, geometry);// 将plateWithHole.xml文件中的数据赋值给 geometry// creating basis 生成基函数gsMultiBasis basis(geometry);for (index_t i 0; i numDegElev; i) // 升阶次数basis.degreeElevate();for (index_t i 0; i numUniRef; i) // k细化节点插入次数basis.uniformRefine();gsInfo basis;////// Setting loads and boundary conditions 设置载荷和边界条件 //////// source function, rhs 源函数-解析解gsConstantFunction f(0., 0., 0., 3); // g 0 0 0gsInfo f \n f \n ;// surface load, neumann BC 黎曼边界对应载荷边界条件 荷载BC 力的边界条件int W 8;int H 32;int g1 1e3 / (W * H);gsConstantFunction g(0, 0, g1, 3); // g 0 0//gsConstantFunction g(0, 0, 100, 3); // g 0 0gsInfo g \n g \n ;// boundary conditions 边界条件 黎曼边界对应载荷边界条件 dirichlete对应位移边界条件gsBoundaryConditions bcInfo;// Dirichlet BC are imposed separately for every component (coordinate) 对每个分量(坐标)分别施加 Dirichlet BCfor (index_t d 0; d 3; d){bcInfo.addCondition(0, boundary::west, condition_type::dirichlet, 0, d);}// Neumann BC are imposed as one function 将 Neumann BC 作为一个函数bcInfo.addCondition(0, boundary::east, condition_type::neumann, g);////// Assembling solving //////// creating assembler 创建刚度矩阵?gsElasticityAssemblerreal_t assembler(geometry, basis, bcInfo, f);assembler.options().setReal(YoungsModulus, youngsModulus);assembler.options().setReal(PoissonsRatio, poissonsRatio);//assembler.options().setInt(DirichletValues, dirichlet::l2Projection);gsInfo Assembling...\n;gsStopwatch clock;clock.restart();assembler.assemble();//assembler.matrix();//总刚gsInfo Assembled a system with assembler.numDofs() dofs in clock.stop() s.\n;gsInfo Solving...\n;clock.restart();#ifdef GISMO_WITH_PARDISOgsSparseSolver::PardisoLDLT solver(assembler.matrix());gsVector solVector solver.solve(assembler.rhs());gsInfo Solved the system with PardisoLDLT solver in clock.stop() s.\n; #elsegsSparseSolver::SimplicialLDLT solver(assembler.matrix());gsVector solVector solver.solve(assembler.rhs());gsInfo Solved the system with EigenLDLT solver in clock.stop() s.\n; #endif// 输出的位移和总刚都是将 位移不变的自由度去掉得到的结果/*gsInfo 位移solVector \n solVector;cout \n ;*/double max solVector.maxCoeff();cout \n 最大节点位移 solVector \n max endl;double Solution 6.667e-5;double error (max - Solution) / max;cout \n 误差 abs(error) * 100 % endl;////// Output //////// constructing solution as an IGA functiongsMultiPatch solution;assembler.constructSolution(solVector, assembler.allFixedDofs(), solution);/*gsInfo solution \n solution;cout \n ;*/// constructing stressesgsPiecewiseFunction stresses;assembler.constructCauchyStresses(solution, stresses, stress_components::von_mises);if (numPlotPoints 0){// constructing an IGA field (geometry solution)gsField solutionField(assembler.patches(), solution);gsField stressField(assembler.patches(), stresses, true);// creating a container to plot all fields to one Paraview filestd::mapstd::string, const gsField* fields;fields[Deformation] solutionField;fields[von Mises] stressField;gsWriteParaviewMultiPhysics(fields, test3_le, numPlotPoints);gsInfo Open \test3_le.pvd\ in Paraview for visualization.\n;}return 0; }二、最小的面8*16受均布载荷 /// This is an example of using the linear elasticity solver on a 3D multi-patch geometry. /// The problems is part of the EU project Terrific. /// /// 示例边长为 8 16 32 的长方体 /// 最小的面8*16受均布载荷 /// Authors: O. Weeger (2012-1015, TU Kaiserslautern), /// A.Shamanskiy (2016 - ...., TU Kaiserslautern) #include gismo.h #include gsElasticity/gsElasticityAssembler.h #include gsElasticity/gsWriteParaviewMultiPhysics.h #include gsElasticity/gsGeoUtils.h #includeiostreamusing namespace std; using namespace gismo;int main(int argc, char* argv[]) {gsInfo Testing the linear elasticity solver in 3D-线弹性求解器的三维测试.\n;////// Input ////////std::string filename(terrific.xml);//初始数据文件std::string filename(test.xml);//初始数据文件real_t youngsModulus 74e9;//杨氏模量real_t poissonsRatio 0.33;//泊松比index_t numUniRef 2;//节点插入数index_t numDegElev 1;//升阶次数index_t numPlotPoints 10000;//preview软件画图的点数量// minimalistic user interface for terminal 终端最简用户界面gsCmdLine cmd(Testing the linear elasticity solver in 3D.);// 定义一个gsCmdLine类 命名为cmdcmd.addInt(r, refine, Number of uniform refinement application, numUniRef);cmd.addInt(d, degelev, Number of degree elevation application, numDegElev);cmd.addInt(p, points, Number of points to plot to Paraview, numPlotPoints);try { cmd.getValues(argc, argv); } // 不太用看 不知道这个命令代表啥catch (int rv) { return rv; }////// Scanning geometry and creating bases:扫描几何和创建基函数 //////// scanning geometry 扫描几何gsMultiPatch geometry; // 定义一个多片gsReadFile(filename, geometry);// 将plateWithHole.xml文件中的数据赋值给 geometry// creating basis 生成基函数gsMultiBasis basis(geometry);for (index_t i 0; i numDegElev; i) // 升阶次数basis.degreeElevate();for (index_t i 0; i numUniRef; i) // k细化节点插入次数basis.uniformRefine();gsInfo basis;////// Setting loads and boundary conditions 设置载荷和边界条件 //////// source function, rhs 源函数-解析解gsConstantFunction f(0., 0., 0., 3); // g 0 0 0gsInfo f \n f \n ;// surface load, neumann BC 黎曼边界对应载荷边界条件 荷载BC 力的边界条件int W 8;int H 16;int g1 2e7 / (W * H);gsConstantFunction g(g1, 0, 0, 3); // g 0 0gsInfo g \n g \n ;// boundary conditions 边界条件 黎曼边界对应载荷边界条件 dirichlete对应位移边界条件gsBoundaryConditions bcInfo;// Dirichlet BC are imposed separately for every component (coordinate) 对每个分量(坐标)分别施加 Dirichlet BCfor (index_t d 0; d 3; d){bcInfo.addCondition(0, boundary::south, condition_type::dirichlet, 0, d);}// Neumann BC are imposed as one function 将 Neumann BC 作为一个函数bcInfo.addCondition(0, boundary::north, condition_type::neumann, g);////// Assembling solving //////// creating assembler 创建刚度矩阵?gsElasticityAssemblerreal_t assembler(geometry, basis, bcInfo, f);assembler.options().setReal(YoungsModulus, youngsModulus);assembler.options().setReal(PoissonsRatio, poissonsRatio);//assembler.options().setInt(DirichletValues, dirichlet::l2Projection);gsInfo Assembling...\n;gsStopwatch clock;clock.restart();assembler.assemble();gsInfo Assembled a system with assembler.numDofs() dofs in clock.stop() s.\n;gsInfo Solving...\n;clock.restart();#ifdef GISMO_WITH_PARDISOgsSparseSolver::PardisoLDLT solver(assembler.matrix());gsVector solVector solver.solve(assembler.rhs());gsInfo Solved the system with PardisoLDLT solver in clock.stop() s.\n; #elsegsSparseSolver::SimplicialLDLT solver(assembler.matrix());gsVector solVector solver.solve(assembler.rhs());gsInfo Solved the system with EigenLDLT solver in clock.stop() s.\n; #endif// 输出的位移和总刚都是将 位移不变的自由度去掉得到的结果/*gsInfo 位移solVector \n solVector;cout \n ;*/double max solVector.maxCoeff();cout \n 最大节点位移 solVector \n max endl;double Solution 6.667e-5;double error (max - Solution) / max;cout \n 误差 abs(error) * 100 % endl;////// Output //////// constructing solution as an IGA functiongsMultiPatch solution;assembler.constructSolution(solVector, assembler.allFixedDofs(), solution);/*gsInfo solution \n solution;cout \n ;*/// constructing stressesgsPiecewiseFunction stresses;assembler.constructCauchyStresses(solution, stresses, stress_components::von_mises);if (numPlotPoints 0){// constructing an IGA field (geometry solution)gsField solutionField(assembler.patches(), solution);gsField stressField(assembler.patches(), stresses, true);// creating a container to plot all fields to one Paraview filestd::mapstd::string, const gsField* fields;fields[Deformation] solutionField;fields[von Mises] stressField;gsWriteParaviewMultiPhysics(fields, test2_le, numPlotPoints);gsInfo Open \test2_le.pvd\ in Paraview for visualization.\n;}return 0; }三、最大的面受均布载荷 /// This is an example of using the linear elasticity solver on a 3D multi-patch geometry. /// The problems is part of the EU project Terrific. /// /// 最大的面受均布载荷 /// Authors: O. Weeger (2012-1015, TU Kaiserslautern), /// A.Shamanskiy (2016 - ...., TU Kaiserslautern) #include gismo.h #include gsElasticity/gsElasticityAssembler.h #include gsElasticity/gsWriteParaviewMultiPhysics.h #include gsElasticity/gsGeoUtils.h #includeiostreamusing namespace std; using namespace gismo;int main(int argc, char* argv[]) {gsInfo Testing the linear elasticity solver in 3D-线弹性求解器的三维测试.\n;////// Input ////////std::string filename(terrific.xml);//初始数据文件std::string filename(test.xml);//初始数据文件real_t youngsModulus 74e9;//杨氏模量real_t poissonsRatio 0.33;//泊松比index_t numUniRef 2;//节点插入数index_t numDegElev 1;//升阶次数index_t numPlotPoints 10000;//preview软件画图的点数量// minimalistic user interface for terminal 终端最简用户界面gsCmdLine cmd(Testing the linear elasticity solver in 3D.);// 定义一个gsCmdLine类 命名为cmdcmd.addInt(r, refine, Number of uniform refinement application, numUniRef);cmd.addInt(d, degelev, Number of degree elevation application, numDegElev);cmd.addInt(p, points, Number of points to plot to Paraview, numPlotPoints);try { cmd.getValues(argc, argv); } // 不太用看 不知道这个命令代表啥catch (int rv) { return rv; }////// Scanning geometry and creating bases:扫描几何和创建基函数 //////// scanning geometry 扫描几何gsMultiPatch geometry; // 定义一个多片gsReadFile(filename, geometry);// 将plateWithHole.xml文件中的数据赋值给 geometry// creating basis 生成基函数gsMultiBasis basis(geometry);for (index_t i 0; i numDegElev; i) // 升阶次数basis.degreeElevate();for (index_t i 0; i numUniRef; i) // k细化节点插入次数basis.uniformRefine();gsInfo basis;////// Setting loads and boundary conditions 设置载荷和边界条件 //////// source function, rhs 源函数-解析解gsConstantFunction f(0., 0., 0., 3); // g 0 0 0gsInfo f \n f \n ;// surface load, neumann BC 黎曼边界对应载荷边界条件 荷载BC 力的边界条件int W 16;int H 32;int g1 2e7 / (W * H);gsConstantFunction g(0, g1, 0, 3); // g 0 0gsInfo g \n g \n ;// boundary conditions 边界条件 黎曼边界对应载荷边界条件 dirichlete对应位移边界条件gsBoundaryConditions bcInfo;// Dirichlet BC are imposed separately for every component (coordinate) 对每个分量(坐标)分别施加 Dirichlet BCfor (index_t d 0; d 3; d){bcInfo.addCondition(0, boundary::back, condition_type::dirichlet, 0, d);}// Neumann BC are imposed as one function 将 Neumann BC 作为一个函数bcInfo.addCondition(0, boundary::front, condition_type::neumann, g);////// Assembling solving //////// creating assembler 创建刚度矩阵?gsElasticityAssemblerreal_t assembler(geometry, basis, bcInfo, f);assembler.options().setReal(YoungsModulus, youngsModulus);assembler.options().setReal(PoissonsRatio, poissonsRatio);assembler.options().setInt(DirichletValues, dirichlet::l2Projection);gsInfo Assembling...\n;gsStopwatch clock;clock.restart();assembler.assemble();gsInfo Assembled a system with assembler.numDofs() dofs in clock.stop() s.\n;gsInfo Solving...\n;clock.restart();#ifdef GISMO_WITH_PARDISOgsSparseSolver::PardisoLDLT solver(assembler.matrix());gsVector solVector solver.solve(assembler.rhs());gsInfo Solved the system with PardisoLDLT solver in clock.stop() s.\n; #elsegsSparseSolver::SimplicialLDLT solver(assembler.matrix());gsVector solVector solver.solve(assembler.rhs());gsInfo Solved the system with EigenLDLT solver in clock.stop() s.\n; #endif// 输出的位移和总刚都是将 位移不变的自由度去掉得到的结果//gsInfo 位移solVector \n solVector;//cout \n ;double max solVector.maxCoeff();cout \n 最大节点位移 solVector \n max endl;double Solution 4.696e-6;double error (max - Solution) / max;cout \n 误差 abs(error) * 100 % endl;////// Output //////// constructing solution as an IGA functiongsMultiPatch solution;assembler.constructSolution(solVector, assembler.allFixedDofs(), solution);gsInfo solution \n solution;cout \n ;// constructing stressesgsPiecewiseFunction stresses;assembler.constructCauchyStresses(solution, stresses, stress_components::von_mises);if (numPlotPoints 0){// constructing an IGA field (geometry solution)gsField solutionField(assembler.patches(), solution);gsField stressField(assembler.patches(), stresses, true);// creating a container to plot all fields to one Paraview filestd::mapstd::string, const gsField* fields;fields[Deformation] solutionField;fields[von Mises] stressField;gsWriteParaviewMultiPhysics(fields, test1_le, numPlotPoints);gsInfo Open \test1_le.pvd\ in Paraview for visualization.\n;}return 0; }
http://www.ihoyoo.com/news/52971.html

相关文章:

  • 衡水seo_衡水网站建设-燕丰收安徽网站建设论坛
  • 学编程做网站成都本地做网站的
  • 海南建设银行官网招聘网站临海房产中介网站如何制作
  • 服务好的高端网站建设服务商北京注册网站
  • 如何在建设厅网站搜索企业如何让百度收录
  • 怎样让百度收录自己的网站网页界面设计和网页设计的差异表现在哪些方面
  • 毕业设计做网站还是系统网页版梦幻西游仙玉做什么划算
  • 网站h1标签用在哪里哪些网站可以用gif做头像
  • 网站空间怎么购买济南 网站开发
  • 商务网站建设项目的技术可行性互联网高端官网
  • 通辽市网站建设高端品牌网站建设方案
  • 网站开发图书管理系统报告摘要答辩的时间_老师问了我做的网站可以同时支持的并发用户是多少
  • 网站运营外包方案临沂网站制作哪家好
  • 石排网站设计wordpress主题带个人中心
  • wordpress自建站上可以买卖自己怎么做网站链接
  • 做网站语言最好自助网页制作免费
  • 网站企业管理培训课程低价网站建设
  • 免费html网站登录模板南京做网站优化
  • 滨海新区建设和交通局网站wordpress替换图片
  • 注册网站用于跳转虚拟货币网站违法wordpress 商场模板
  • 做瞹瞹爱免费网站h5响应式网站模板制作
  • 网站功能建设流程图库车建设工程信息网站
  • 网页制作与网站建设完全学习手册下载扁平风格网站欣赏
  • 建一个小型的购物网站服务器一年要多少钱广告设计软件培训中心
  • 合肥高端网站建设工作室做一个主题wordpress
  • 如何做像淘宝一样的网站上海公司推荐
  • 网站建设与管理实训心得百度官网认证免费
  • 找网站公司制作网站石狮app网站开发价格
  • 学做网站从零开始产品展厅柜设计公司
  • 自学做网站界面linux系统 wordpress