双二次Lagrange 有限元计算特征值程序(基于iFEM)
function lambda = c0P2(h)
%% Mesh
[node,elem] = squarequadmesh([,,,],h);
elem = elem(:,[,,,]);
showmesh(node,elem);
findnode(node);
findquadelem(node,elem);
%% Construct Data Structure
[elem2dof,edge,inDof] = c0dofP2(elem);
elem2dof=double(elem2dof);
N = size(node,); NT = size(elem,);
Ndof = N+NT+size(edge,);
A=sparse(Ndof,Ndof);
B=sparse(Ndof,Ndof);
%% Assemble stiffness matrix
% Since Dphi_i*Dphi_j is quadratic,
% numerical quadrature rule is used here
option.quadorder = ; % default order
[pts,weight] = quadquadpts(option.quadorder);
pts=pts*-;
x=pts(:,);y=pts(:,);
h1=h/;h2=h1;
area=h2*h1;
%% Assemble Matrix
for i=:
for j=i:
DuDv=area*(Dxphi(x,y,h1,i).*Dxphi(x,y,h1,j)...
+Dyphi(x,y,h2,i).*Dyphi(x,y,h2,j))'*weight;
uv=area*(phi(x,y,i).*phi(x,y,j))'*weight;
if i==j
A = A + sparse(elem2dof(:,i),elem2dof(:,j),DuDv,Ndof,Ndof);
B = B + sparse(elem2dof(:,i),elem2dof(:,j),uv,Ndof,Ndof);
else
A = A + sparse([elem2dof(:,i);elem2dof(:,j)],...
[elem2dof(:,j);elem2dof(:,i)],DuDv,Ndof,Ndof);
B = B + sparse([elem2dof(:,i);elem2dof(:,j)],...
[elem2dof(:,j);elem2dof(:,i)],uv,Ndof,Ndof);
end
end
end
%% Solve Ax = lambda Bx, and its first solution is *pi^
lambda=eigs(A(inDof,inDof),B(inDof,inDof),,'sm');
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% subfunction Dxphi
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
function s = Dxphi(xi,eta,L1,i) % gradient of basis phi for x
switch i
case
s = (eta.*(.*xi - ).*(eta - ))/(*L1);
case
s = (eta.*(.*xi + ).*(eta - ))/(*L1);
case
s = (eta.*(.*xi + ).*(eta + ))/(*L1);
case
s = (eta.*(.*xi - ).*(eta + ))/(*L1);
case
s = -(eta.*xi.*(eta - ))/L1;
case
s = -((eta.^ - ).*(*xi + ))/(*L1);
case
s = -(eta.*xi.*(eta + ))/L1;
case
s = -((eta.^ - ).*(.*xi - ))/(*L1);
case
s = (*xi.*(eta.^ - ))/L1;
end
end
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% subfunction Dxphi
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
function s = Dyphi(xi,eta,L2,i) % gradient of basis phi for y
switch i
case
s = (xi.*(.*eta - ).*(xi - ))/(*L2);
case
s = (xi.*(.*eta - ).*(xi + ))/(*L2);
case
s = (xi.*(.*eta + ).*(xi + ))/(*L2);
case
s = (xi.*(.*eta + ).*(xi - ))/(*L2);
case
s = -((.*eta - ).*(xi.^ - ))/(*L2);
case
s = -(eta.*xi.*(xi + ))/L2;
case
s =-((*eta + ).*(xi.^ - ))/(*L2);
case
s = -(eta.*xi.*(xi - ))/L2;
case
s = (*eta.*(xi.^ - ))/L2;
end
end %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% subfunction phi
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
function s = phi(xi,eta,i) % gradient of basis phi
switch i
case
s = (eta.*xi.*(eta - ).*(xi - ))/;
case
s = (eta.*xi.*(eta - ).*(xi + ))/;
case
s = (eta.*xi.*(eta + ).*(xi + ))/;
case
s = (eta.*xi.*(eta + ).*(xi - ))/;
case
s = -(eta.*(xi.^ - ).*(eta - ))/;
case
s = -(xi.*(eta.^ - ).*(xi + ))/;
case
s = -(eta.*(xi.^ - ).*(eta + ))/;
case
s = -(xi.*(eta.^ - ).*(xi - ))/;
case
s = (eta.^ - ).*(xi.^ - );
end
end
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
end
lambda = c0P2(h)
function [elem2dof,edge,inDof] = c0dofP2(elem)
totalEdge=sort([elem(:,[,]);elem(:,[,]);elem(:,[,]);elem(:,[,])],);
[edge, i2, j] = myunique(totalEdge);
N = max(elem(:));
NT = size(elem,);
NE = size(edge,);
elem2edge = reshape(j,NT,);
elem2dof = uint32([elem N+elem2edge (N+NE+:N+NE+NT)']);
i1(j(*NT:-:)) = *NT:-:;
i1 = i1';
bdEdgeIdx = (i1 == i2);
isBdDof = false(N+NE+NT,);
isBdDof(edge(bdEdgeIdx,:)) = true; % nodal
idx = find(bdEdgeIdx);
isBdDof(N+idx) = true;
inDof = find(~isBdDof);
end
[elem2dof,edge,inDof] = c0dofP2(elem)

http://files.cnblogs.com/files/wangshixi12/%E5%8F%8C%E4%BA%8C%E6%AC%A1Lagrange%E6%9C%89%E9%99%90%E5%85%83.rar
双二次Lagrange 有限元计算特征值程序(基于iFEM)的更多相关文章
- (原)使用mkl计算特征值和特征向量
转载请注明出处: http://www.cnblogs.com/darkknightzh/p/5585271.html 参考文档:mkl官方文档 lapack_int LAPACKE_sgeev(in ...
- 第十六届“二十一世纪的计算”学术研讨会 密西根州立大学教授Anil K. Jain主题演讲
Biometrics---How Do I Know Who You Are? 密西根州立大学教授Anil K. Jain主题演讲" title="第十六届"二十一世纪的 ...
- 第十六届“二十一世纪的计算”学术研讨会 图灵奖获得者Butler W. Lampson主题演讲
Personal Control of Digital Data 图灵奖获得者Butler W. Lampson主题演讲" title="第十六届"二十一世纪的计算&qu ...
- 三种计算c#程序运行时间的方法
三种计算c#程序运行时间的方法 第一种: 利用 System.DateTime.Now // example1: System.DateTime.Now method DateTime dt1 = S ...
- 二 ASP.NET MVC 第一个程序 hello world
二 ASP.NET MVC 第一个程序 hello world https://blog.csdn.net/xmroom/article/details/51335917 我使用的Visual s ...
- Senparc.Weixin.MP SDK 微信公众平台开发教程(二十一):在小程序中使用 WebSocket (.NET Core)
本文将介绍如何在 .NET Core 环境下,借助 SignalR 在小程序内使用 WebSocket.关于 WebSocket 和 SignalR 的基础理论知识不在这里展开,已经有足够的参考资料, ...
- 第十六届“二十一世纪的计算”学术研讨会 牛津大学肿瘤成像学教授Michael Brady主题演讲
Computing and Healthcare 牛津大学肿瘤成像学教授Michael Brady主题演讲" title="第十六届"二十一世纪的计算"学术研讨 ...
- Spark练习之通过Spark Streaming实时计算wordcount程序
Spark练习之通过Spark Streaming实时计算wordcount程序 Java版本 Scala版本 pom.xml Java版本 import org.apache.spark.Spark ...
- 微信小程序-基于canvas画画涂鸦
代码地址如下:http://www.demodashi.com/demo/14461.html 一.前期准备工作 软件环境:微信开发者工具 官方下载地址:https://mp.weixin.qq.co ...
随机推荐
- HBase 常用Shell命令
两个月前使用过hbase,现在最基本的命令都淡忘了,留一个备查~ 进入hbase shell console$HBASE_HOME/bin/hbase shell如果有kerberos认证,需要事先使 ...
- 百度地图API功能集锦
1.点个数太多导致加载缓慢的解决. 2.可视化区域内加载的解决. 3.自定义信息窗口解决. 4.区域/板块/商圈等的绘制功能解决. 基本包含了用到百度地图API会使用到的大部分常规性场景.(聚合点功能 ...
- deep learning 练习 多变量线性回归
多变量线性回归(Multivariate Linear Regression) 作业来自链接:http://openclassroom.stanford.edu/MainFolder/Document ...
- IIS发布问题汇总
1.未能加载文件或程序集“System.Data.SQLite” 在IIS界面选择应用程序池->选择所使用的.net 版本->高级设置->将"使用32位应用程序" ...
- Spring框架的XML扩展特性
Spring框架从2.0版本开始,提供了基于Schema风格的XML扩展机制,允许开发者扩展spring配置文件.现在我们来看下怎么实现这个功能,可以参考spring帮助文档中的<Extensi ...
- Docker 的 Image 太大,怎么变小?
铛~铛~铛~Docker即将颠覆整个软件产业,从云计算平台到软件开发.测试,整个SDLC都会极度依赖Docker. 圈子里面一定有很多讨论Docker的话题,简而言之,Docker其实只解决一个问题: ...
- 初学PHP
这东西必须得静下心来学,快是快不来的,得有一个痛苦的过程.<PHP和MySQL WEB开发>这本书很值得一看,有了坚实的基础,推荐看<深入php++面向对象.模式与实践+第三版> ...
- C++设计模式-Command命令模式
Command命令模式作用:将一个请求封装为一个对象,从而使你可用不同的请求对客户进行参数化:对请求排队或记录请求日志,以及支持可撤销的操作. 由于“行为请求者”与“行为实现者”的紧耦合,使用命令模式 ...
- 转:10年程序员谈.Net程序员的职业规划
从事Dotnet程序开发工作近10年了,从开始的月薪3k的小程序员菜鸟,到现在年薪60w的项目总经理,从战战兢兢的去各个公司应聘,到现在开始面试那些战战兢兢的小程序员,回想起这近十年来的经验,看着还是 ...
- Ninject之旅之九:Ninject上下文绑定(附程序下载)
摘要 既然在插件模型里,每一个服务类型可以被映射到多个实现,绑定方法不用决定要返回哪个实现.因为kernel应该返回所有的实现.然而,上下文绑定是多个绑定场景,在这个场景里,kernel需要根据给定的 ...