亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? exam6_2.m

?? 名字已經很清楚了
?? M
?? 第 1 頁 / 共 2 頁
字號:
function exam6_2
% 本程序為第六章的第二個算例,采用20結點六面體等參元計算端部受橫向力的懸臂梁
%  輸入參數: 
%       無

    file_in = 'exam6_2.dat' ;
    
    % 檢查文件是否存在
    if exist( file_in ) == 0
        disp( sprintf( '錯誤:文件 %s 不存在', file_in ) )
        disp( sprintf( '程序終止' ) )
        return ;
    end
    
    % 根據輸入文件名稱生成輸出文件名稱
    [path_str,name_str,ext_str] = fileparts( file_in ) ;
    ext_str_out = '.mat' ;
    file_out = fullfile( path_str, [name_str, ext_str_out] ) ;
    
    % 檢查輸出文件是否存在
    if exist( file_out ) ~= 0 
        answer = input( sprintf( '文件 %s 已經存在,是否覆蓋? ( Yes / [No] ):  ', file_out ), 's' ) ;
        if length( answer ) == 0
            answer = 'no' ;
        end
        
        answer = lower( answer ) ;
        if answer ~= 'y' | answer ~= 'yes' 
            disp( sprintf( '請使用另外的文件名,或備份已有的文件' ) ) ;
            disp( sprintf( '程序終止' ) );
            return ; 
        end
    end

    FemModel( file_in ) ;       % 定義有限元模型
    SolveModel ;                % 求解有限元模型
    SaveResults( file_out ) ;   % 保存計算結果
    DisplayResults ;            % 把計算結果顯示出來 
return

function FemModel( file_in )
%  定義有限元模型
%  輸入參數:
%      file_in ---- 有限模型數據文件
%  返回值:
%      無

%  全局變量及名稱
%      gNode ------ 節點坐標
%      gElement --- 單元定義
%      gMaterial -- 材料性質
%      gBC1 ------- 第一類約束條件
%      gNF -------- 集中力
    global gNode gElement gMaterial gBC1 gNF
    
    % 打開文件
    fid = fopen( file_in, 'r' ) ;
    
    % 節點坐標
    node_number = fscanf( fid, '%d', 1 ) ;
    gNode = zeros( node_number, 3 ) ;
    for i = 1:node_number
        dummy = fscanf( fid, '%d', 1 ) ;
        gNode( i, : ) = fscanf( fid, '%f', [1 3] ) ;
    end
    
    % 單元定義
    element_number = fscanf( fid, '%d', 1 ) ;
    gElement = zeros( element_number, 21 ) ;
    for i = 1:element_number
        dummy = fscanf( fid, '%d', 1 ) ;
        gElement( i, : ) = fscanf( fid, '%d', [1 21] ) ;
    end
    
    % 材料性質
    material_number = fscanf( fid, '%d', 1 ) ;
    gMaterial = zeros( material_number, 2 ) ;
    for i = 1:material_number
        dummy = fscanf( fid, '%d', 1 ) ;
        gMaterial( i, : ) = fscanf( fid, '%f', [1 2] ) ;
    end
    
    % 第一類約束條件
    bc1_number = fscanf( fid, '%d', 1 ) ;
    gBC1 = zeros( bc1_number, 3 ) ;
    for i=1:bc1_number
        gBC1(i,1) = fscanf( fid, '%d', 1 ) ;  % 結點號
        gBC1(i,2) = fscanf( fid, '%d', 1 ) ;  % 自由度號
        gBC1(i,3) = fscanf( fid, '%f', 1 ) ;  % 約束值
    end
    
    % 集中力
    nf_number = fscanf( fid, '%d', 1 ) ;
    gNF = zeros( nf_number, 3 ) ;
    for i=1:nf_number
        gNF(i,1) = fscanf( fid, '%d', 1 ) ;  % 結點號
        gNF(i,2) = fscanf( fid, '%d', 1 ) ;  % 自由度號
        gNF(i,3) = fscanf( fid, '%f', 1 ) ;  % 集中力大小
    end
    
    % 關閉文件
    fclose( fid ) ;
return

function SolveModel
%  求解有限元模型
%  輸入參數:
%     無
%  返回值:
%     無
%  說明:
%      該函數求解有限元模型,過程如下
%        1. 計算單元剛度矩陣,集成整體剛度矩陣
%        2. 計算單元的等效節點力,集成整體節點力向量
%        3. 處理約束條件,修改整體剛度矩陣和節點力向量
%        4. 求解方程組,得到整體節點位移向量

%  全局變量及名稱
%      gNode ----------- 節點坐標
%      gElement -------- 單元定義
%      gMaterial ------- 材料性質
%      gBC1 ------------ 第一類約束條件
%      gNF ------------- 集中力
%      gK -------------- 整體剛度矩陣
%      gDelta ---------- 結點位移向量
%      gElementStress -- 每個單元的結點應力
    global gNode gElement gMaterial gBC1 gNF gK gDelta gElementStress

    % step1. 定義整體剛度矩陣和節點力向量
    [node_number,dummy] = size( gNode ) ;
    %gK = sparse( node_number * 3, node_number * 3 ) ;   % 由于稀疏矩陣的存儲速度很慢,因此改成普通矩陣運算
    %f = sparse( node_number * 3, 1 ) ;                  % 如果計算機內存不夠,就恢復這兩句,并注釋掉下面兩句。
    gK = zeros( node_number*3,node_number*3) ;
     f = zeros( node_number*3,1 ) ;
     
    % step2. 計算單元剛度矩陣,并集成到整體剛度矩陣中
    [element_number,dummy] = size( gElement ) ;
    for ie=1:1:element_number
        disp( sprintf(  '計算單元剛度矩陣并集成,當前單元: %d', ie  ) ) ;
        k = StiffnessMatrix( ie ) ;
        AssembleStiffnessMatrix( ie, k ) ;
    end
    
    spy(gK) ;
    nz=nnz(gK) ;
    fprintf( 'non-zeros elements/total elmements = %g%%',nz/node_number/node_number/9*100) ;
    pause ;
    
    % step3. 把集中力集成到整體節點力向量中
    [nf_number, dummy] = size( gNF ) ;
    for idf = 1:1:nf_number
        node  = gNF(idf, 1) ;
        dim   = gNF(idf, 2) ;
        force = gNF(idf, 3) ;
        f( (node-1)*3+dim ) = f( (node-1)*3+dim ) + force ;
    end
    
    % step4. 處理第一類約束條件,修改剛度矩陣和節點力向量。采用乘大數法
    [bc1_number,dummy] = size( gBC1 ) ;
    for ibc=1:1:bc1_number
        n = gBC1(ibc, 1 ) ;
        d = gBC1(ibc, 2 ) ;
        m = (n-1)*3 + d ;
        f(m,:) = gBC1(ibc, 3)* gK(m,m) * 1e15 ;
        gK(m,m) = gK(m,m) * 1e15 ;
    end
    
    % step5. 求解方程組,得到節點位移向量
    gDelta = gK \ f ;
    
    % step6. 計算每個單元的結點應力
    gElementStress = zeros( element_number, 20, 6 ) ;
    delta = zeros( 60, 1 ) ;
    x = [-1, 1, 1, -1, -1, 1, 1, -1, 0, 0, 0, 0, 1, 1, -1, -1, -1, 1, 1, -1];
    e = [-1, -1, 1, 1, -1, -1, 1, 1, -1, 1, 1, -1, 0, 0, 0, 0, -1, -1, 1, 1];
    z = [-1, -1, -1, -1, 1, 1, 1, 1, -1, -1, 1, 1, -1, 1, 1, -1, 0, 0, 0, 0];
    for ie = 1:element_number
        fprintf( '計算單元應力,當前單元號:%d\n', ie ) ;
        for n=1:20
            B = MatrixB( ie, x(n), e(n), z(n) ) ;
            D = MatrixD( ie ) ;
            delta(1:3:58) = gDelta( gElement(ie,1:20)*3-2) ;
            delta(2:3:59) = gDelta( gElement(ie,1:20)*3-1) ;
            delta(3:3:60) = gDelta( gElement(ie,1:20)*3) ;
            sigma = D*B*delta ;
            gElementStress( ie, n, : ) = sigma ;
        end
    end
return

function k = StiffnessMatrix( ie )   
%  計算平面應變等參數單元的剛度矩陣
%  輸入參數:
%     ie -- 單元號
%  返回值:
%     k  -- 單元剛度矩陣
%  說明:
%     用高斯積分法求解平面等參數單元的剛度矩陣

    k = zeros( 60, 60 ) ;
    D = MatrixD( ie ) ;
    %3 x 3 x 3 高斯積分點和權系數
    %x = [-0.774596669241483,              0.0,0.774596669241483] ;   
    %w = [ 0.555555555555556,0.888888888888889,0.555555555555556] ;  
    %for i=1:1:length(x)
    %    for j=1:1:length(x)
    %        for m=1:1:length(x)
    %            B = MatrixB( ie, x(i), x(j), x(m) ) ;
    %            J = Jacobi( ie, x(i), x(j), x(m) ) ;
    %            k = k + w(i)*w(j)*w(m)*transpose(B)*D*B*det(J) ;   
    %        end
    %    end
    %end
    
    %14點 irons 積分, 詳細參見以下文獻 
    % Irons B. M., 1971 Quadrature rules for brick based finite elements, 
    %   International Journal for Numerical Methods in Engineering, 
    %   3(2):293-294.
    b0 = 320/361 ;
    c0 = 121/361 ;
    b  = sqrt( 19/30 ) ;
    c  = sqrt( 19/33 ) ;
    x1 = [-b,  0,  0
           b,  0,  0
           0, -b,  0
           0,  b,  0
           0,  0, -b
           0,  0,  b ] ;
    x2 = [-c, -c, -c
           c,  c,  c
           c, -c, -c
          -c,  c, -c
          -c, -c,  c
           c,  c, -c
          -c,  c,  c
           c, -c,  c ] ;
    for i=1:6
        B = MatrixB( ie, x1(i,1), x1(i,2), x1(i,3) ) ;
        J = Jacobi( ie, x1(i,1), x1(i,2), x1(i,3) ) ;
        k = k + b0*transpose(B)*D*B*det(J) ;
    end
    for i=1:8
        B = MatrixB( ie, x2(i,1), x2(i,2), x2(i,3) ) ;
        J = Jacobi( ie, x2(i,1), x2(i,2), x2(i,3) ) ;
        k = k + c0*transpose(B)*D*B*det(J) ;
    end
return

function D = MatrixD( ie )
%  計算單元的彈性矩陣D
%  輸入參數:
%     ie --------- 單元號
%  返回值:
%     D  --------- 彈性矩陣D

%  全局變量及名稱
%      gElement -------- 單元定義
%      gMaterial ------- 材料性質
    global gElement gMaterial 

    E  = gMaterial( gElement(ie, 21), 1 ) ;   % 彈性模量
    mu = gMaterial( gElement(ie, 21), 2 ) ;   % 泊松比 
    A1 = mu/(1-mu) ;                        
    A2 = (1-2*mu)/2/(1-mu) ;                
    A3 = E*(1-mu)/(1+mu)/(1-2*mu) ;         
    D = A3*[  1  A1  A1   0   0   0
             A1   1  A1   0   0   0
             A1  A1   1   0   0   0
              0   0   0  A2   0   0
              0   0   0   0  A2   0
              0   0   0   0   0  A2] ;
return

function B = MatrixB( ie, xi, eta, zeta )
%  計算單元的應變矩陣B
%  輸入參數:
%     ie --------------- 單元號
%     xi,eta, zeta ----- 局部坐標  
%  返回值:
%     B  --------------- 在局部坐標處的應變矩陣B

    [N_x, N_y, N_z] = N_xyz( ie, xi, eta, zeta ); 
    B = zeros( 6, 60 ) ;
    for i=1:1:20
        B(:,(3*i-2):3*i) = [ N_x(i)       0       0
                                  0  N_y(i)       0
                                  0       0  N_z(i)
                                  0  N_z(i)  N_y(i)
                             N_z(i)      0   N_x(i)
                             N_y(i)  N_x(i)       0 ] ;
    end
return

function [N_x, N_y, N_z] = N_xyz( ie, xi, eta, zeta )
%  計算形函數對整體坐標的導數

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩一区二区免费在线观看| 成人精品一区二区三区四区| 欧美日韩卡一卡二| 天天亚洲美女在线视频| 精品欧美乱码久久久久久1区2区| 蜜桃久久av一区| 欧美激情一区在线观看| 成人中文字幕在线| 一区二区三区四区不卡在线 | 国产曰批免费观看久久久| 精品国产123| 国产91对白在线观看九色| 亚洲嫩草精品久久| 91精品国产综合久久香蕉麻豆 | 国产精品久久久久久福利一牛影视| 福利一区二区在线观看| 亚洲自拍偷拍网站| 欧美刺激午夜性久久久久久久| 国产精品影视天天线| 日韩毛片视频在线看| 56国语精品自产拍在线观看| 国产又黄又大久久| 一区二区久久久久| 欧美精品一区二区三区久久久| 99re这里都是精品| 日本欧美韩国一区三区| 中文字幕欧美国产| 欧美精品国产精品| 91影院在线免费观看| 蜜臀av一区二区在线观看| 国产精品传媒入口麻豆| 日韩一卡二卡三卡四卡| 91丨porny丨蝌蚪视频| 视频在线观看91| 中文字幕中文在线不卡住| 日韩欧美一级片| 日本丰满少妇一区二区三区| 国产一区二区在线视频| 亚洲午夜久久久久久久久电影院| 久久综合视频网| 欧美日韩一区精品| 白白色 亚洲乱淫| 美腿丝袜在线亚洲一区| 亚洲国产日韩a在线播放性色| 国产欧美精品在线观看| 日韩欧美国产一区二区三区| 欧美视频中文一区二区三区在线观看| 国产精品99久久久久久似苏梦涵 | 国产精品久久毛片a| 日韩一区二区三区免费观看| 91福利国产精品| 国产成人免费视频| 精品一区二区三区在线观看| 亚洲mv大片欧洲mv大片精品| 一区二区在线观看视频| 国产精品久久久久天堂| 久久久久国产精品免费免费搜索| 欧美日韩高清一区二区不卡| 一本到三区不卡视频| jizzjizzjizz欧美| 国产成人精品网址| 国产麻豆成人精品| 国内外成人在线视频| 免费久久精品视频| 美女视频一区二区| 蜜桃视频一区二区三区在线观看| 视频一区中文字幕| 无码av中文一区二区三区桃花岛| 亚洲一二三专区| 亚洲成人午夜影院| 日韩福利电影在线观看| 日韩av一区二| 麻豆91精品91久久久的内涵| 日韩**一区毛片| 美女看a上一区| 久久精品国产在热久久| 国内外成人在线视频| 国产精选一区二区三区| 国产99久久精品| 91香蕉视频黄| 欧美羞羞免费网站| 欧美精品在线一区二区三区| 欧美精品一卡两卡| 精品免费99久久| 欧美国产丝袜视频| 亚洲女人小视频在线观看| 一区二区三区在线视频观看| 亚洲综合男人的天堂| 丝袜亚洲另类欧美| 韩国精品主播一区二区在线观看| 国产馆精品极品| 色综合天天综合色综合av| 欧美调教femdomvk| 日韩精品综合一本久道在线视频| 久久人人爽人人爽| 亚洲人成7777| 视频一区二区国产| 狠狠色综合日日| 不卡高清视频专区| 在线观看91精品国产入口| 91精品蜜臀在线一区尤物| 久久久久九九视频| 亚洲综合精品久久| 国产一区二区在线视频| 色综合久久中文综合久久牛| 在线不卡中文字幕播放| 久久欧美中文字幕| 亚洲黄色在线视频| 精品一二三四区| 91美女片黄在线观看91美女| 91精品国产高清一区二区三区| 精品国产人成亚洲区| 中文字幕五月欧美| 看电影不卡的网站| 91猫先生在线| 久久久久久久综合| 亚洲高清免费在线| 成人午夜在线视频| 日韩欧美在线1卡| 亚洲色图制服丝袜| 国产美女主播视频一区| 精品1区2区3区| 中文字幕国产一区二区| 免费观看在线色综合| 91丨porny丨首页| 久久综合色一综合色88| 午夜婷婷国产麻豆精品| 懂色av噜噜一区二区三区av| 欧美日韩一区二区在线观看| 国产网站一区二区| 日韩精品久久久久久| 91在线视频18| 国产午夜精品美女毛片视频| 免费成人av在线| 一本色道久久综合亚洲aⅴ蜜桃| 欧美成人女星排名| 午夜精品福利一区二区三区av| 成人夜色视频网站在线观看| 日韩精品资源二区在线| 性欧美疯狂xxxxbbbb| 色综合久久久久综合99| 国产精品美女久久久久久2018| 蜜桃一区二区三区在线观看| 欧美日韩在线三级| 亚洲欧美激情视频在线观看一区二区三区 | 亚洲国产精品国自产拍av| 欧美aaaaa成人免费观看视频| 色88888久久久久久影院野外| 国产日韩欧美在线一区| 蜜臀91精品一区二区三区| 欧美男女性生活在线直播观看| 日韩毛片在线免费观看| www.色精品| 中文字幕电影一区| 成人在线视频一区二区| 国产亚洲精品精华液| 国产一区二区三区四区五区入口| 欧美一区二区高清| 免费高清不卡av| 欧美sm极限捆绑bd| 蜜臀av亚洲一区中文字幕| 91精品一区二区三区在线观看| 天天综合天天综合色| 制服丝袜成人动漫| 日本最新不卡在线| 精品国产乱码久久久久久闺蜜| 久久精品国产一区二区三| 欧美一卡二卡在线观看| 久久国产三级精品| 精品成人a区在线观看| 黄色日韩网站视频| 日本一区二区三级电影在线观看 | 亚洲精品一区二区精华| 久久99精品久久久久久动态图| 欧美成人三级电影在线| 国产精品一区二区三区99| 午夜视黄欧洲亚洲| 欧美日韩国产另类不卡| 麻豆免费看一区二区三区| 精品第一国产综合精品aⅴ| 国产精品123| 亚洲乱码日产精品bd| 欧美日韩午夜精品| 蜜桃av一区二区| 欧美高清在线视频| 色婷婷综合激情| 亚洲va欧美va国产va天堂影院| 日韩欧美区一区二| 成人午夜av电影| 亚洲一线二线三线视频| 日韩欧美综合一区| 成人动漫一区二区三区| 亚洲一区二区影院| 精品国产亚洲在线| 91啪九色porn原创视频在线观看| 艳妇臀荡乳欲伦亚洲一区| 日韩欧美电影一区| 一本色道久久综合亚洲aⅴ蜜桃 | 久久影院午夜论| 91在线国产观看|