青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

eryar

PipeCAD - Plant Piping Design Software.
PlantAssistant - Translate AVEVA RVM/SP3D VUE to glTF, STEP, etc.
posts - 606, comments - 590, trackbacks - 0, articles - 0

OpenCASCADE Gauss Integration

Posted on 2014-09-11 21:52 eryar 閱讀(2849) 評論(0)  編輯 收藏 引用 所屬分類: 2.OpenCASCADE

OpenCASCADE Gauss Integration

eryar@163.com

Abstract. Numerical integration is the approximate computation of an integral using numerical techniques. The numerical computation of an integral is sometimes called quadrature. The most straightforward numerical integration technique uses the Newton-Cotes formulas(also called quadrature formulas), which approximate a function tabulated sequence of regularly spaced intervals by various degree polynomials. If the functions are known analytically instead of being tabulated at equally spaced intervals, the best numerical method of integrations is called Gauss Integration(Gaussian quadrature). By picking the abscissas at which to evaluate the function, Gaussian quadrature produces the most accurate approximations possible. In OpenCASCADE math package it implement the Gauss-Legendre integration. So I will focus on the usage of the class in OpenCASCADE.

Key Words. OpenCASCADE, Gauss Integration, Gauss-Legendre, Numerical Analysis

1. Introduction

在科學和工程計算問題中,經常要計算一些定積分或微分,它們的精確值無法算出或計算量太大,只能用數值的方法給出具有指定誤差限的近似值。最直觀的數值積分方法有Newton-Cotes,其將積分區間等分之,并取分點為積分節點。這種做法雖然簡化了計算,但卻降低了所得公式的代數精度。

Gauss型求積公式是一種高精度的數值積分公式。在求積節點數相同的情況下,即計算工作量相近的情況下,利用Gauss型求積公式往往可以獲得準確程序較高的積分結果,只是它在不等距的無理數上計算被積函數。

OpenCASCADE的math包中實現了Gauss-Legendre積分算法。本文主要介紹其使用方法,進而對其應用進行理解。

2. The Gauss-Legendre Integration

Gauss型求積公式是數值穩定的,且對有限閉區間上的連續函數,Gauss求積的數值隨節點數目的增加而收斂到準確積分值。

常用的Gauss型求積公式有Gauss-Legendre求積公式,Gauss-Chebyshev求積公式,Gauss-Laguerre求積公式和Gauss-Hermite求積公式等。

對于一般區間[a, b]上的Gauss型求積公式,可通過變量變換,由Gauss-Legendre求積公式得到:

wps_clip_image-12252其中:

wps_clip_image-28519

OpenCASCADE中對應的類有math_GaussSingleIntegration,主要實現的函數為Perform(),計算過程如下:

v 查表求得Gauss點及求積系數;

//Recuperation des points de Gauss dans le fichier GaussPoints.
  math::GaussPoints(Order,GaussP);
  math::GaussWeights(Order,GaussW);

v 根據Gauss-Legendre求積公式計算;

 

// Changement de variable pour la mise a l'echelle [Lower, Upper] :
  xm = 0.5*(Upper + Lower);
  xr 
= 0.5*(Upper - Lower);
  Val 
= 0.;

  Standard_Integer ind 
= Order/2, ind1 = (Order+1)/2;
  
if(ind1 > ind) { // odder case
    Ok1 = F.Value(xm, Val);
    
if (!Ok1) return;
    Val 
*= GaussW(ind1);
  }
// Sommation sur tous les points de Gauss: avec utilisation de la symetrie.
  for (j = 1; j <= ind; j++) {
    dx 
= xr*GaussP(j);
    Ok1 
= F.Value(xm-dx, F1);
    
if(!Ok1) return;
    Ok1 
= F.Value(xm+dx, F2);
    
if(!Ok1) return;
    
// Multiplication par les poids de Gauss.
    Standard_Real FT = F1+F2;
    Val 
+= GaussW(j)*FT;  
  }
  
// Mise a l'echelle de l'intervalle [Lower, Upper]
  Val *= xr;

對比Gauss-Legendre求積公式來理解上述代碼還是比較清晰的。下面給出使用此類的一個具體實例:

 

/*
*    Copyright (c) 2014 eryar All Rights Reserved.
*
*        File    : Main.cpp
*        Author  : eryar@163.com
*        Date    : 2014-09-11 20:46
*        Version : 1.0v
*
*    Description : Demo for Gauss-Legendre Integration usage.
*
*      Key words : OpenCascade, Gauss-Legendre Integration
*/

#define WNT
#include 
<math_Function.hxx>
#include 
<math_GaussSingleIntegration.hxx>

#pragma comment(lib, 
"TKernel.lib")
#pragma comment(lib, 
"TKMath.lib")

class Test_GaussFunction : public math_Function
{
public:
    
virtual Standard_Boolean Value(const Standard_Real x, Standard_Real &y)
    {
        y 
= x;

        
return Standard_True;
    }

private:
};

void TestGaussIntegration(void)
{
    Test_GaussFunction aFunction;
    math_GaussSingleIntegration aSolver(aFunction, 
11010);

    std::cout 
<< aSolver << std::endl;
}

int main(int argc, char* argv[])
{
    TestGaussIntegration();

    
return 0;
}

主要是從math_Function派生一個類來在虛函數Value()中重定義求積函數即可。上述實例中計算的是如下積分:

wps_clip_image-4533

計算結果如下圖所示:

wps_clip_image-15082

Figure 2.1 Gauss-Legendre Integtation Result

3. Application

由高等數學知識可知,積分的應用主要用于計算圖形面積,體積及曲線的弧長,功等。

積分在OpenCASCADE中的主要應用有計算曲線長度,曲面面積及實體的體積等。如下圖所示:

wps_clip_image-13853

Figure 3.1 Compute Area of a Surface

示例代碼如下所示:

TopoDS_Shape S = BRepBuilderAPI_MakeFace(BSS, Precision::Confusion()).Face();

GProp_GProps System;
BRepGProp::SurfaceProperties(S,System);
gp_Pnt G 
= System.CentreOfMass ();
Standard_Real Area 
= System.Mass();
gp_Mat I 
= System.MatrixOfInertia();


 


4. Conclusion

OpenCASCADE中實現的Gauss-Legendre求積算法,由于是查表求得Gauss點及求積系數,所以計算速度快。唯一不足是對高斯點數有限制。

綜上所述,可知數值計算在OpenCASCADE中重要作用。一個TKMath庫相當于實現了一本《數值分析》課本中的大部分內容。所以有興趣的朋友可結合《數值分析》或《計算方法》之類的書籍,來對OpenCASCADE的數學庫TKMath進行理論聯系實際的深入理解。

5. References

1. Wolfram MathWorld, Numerical Integration, 

http://mathworld.wolfram.com/NumericalIntegration.html

2. 易大義,沈云寶,李有法編. 計算方法. 浙江大學出版社. 2002

3. 易大義,陳道琦編. 數值分析引論. 浙江大學出版社. 1998

4. 李慶楊,王能超,易大義.數值分析.華中理工大學出版社. 1986

5. 同濟大學數學教研室. 高等數學(第四版). 高等教育出版社. 1996

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲视频在线一区| 这里只有视频精品| 欧美在线|欧美| 免费久久精品视频| 在线成人激情| 国产精品一区二区在线观看不卡| 久久免费高清| 亚洲砖区区免费| 欧美成人免费观看| 免费久久99精品国产| 欧美一乱一性一交一视频| 亚洲一区二区av电影| 激情久久综合| 狠狠色丁香久久婷婷综合丁香| 欧美黄色一区| 欧美不卡视频一区发布| 另类激情亚洲| 欧美激情 亚洲a∨综合| 久久不射电影网| 日韩一级片网址| 亚洲综合首页| 一区二区成人精品 | 亚洲第一精品久久忘忧草社区| 最新中文字幕一区二区三区| 亚洲国产精品va在线观看黑人 | 欧美激情亚洲视频| 久久蜜桃av一区精品变态类天堂| 久久精品夜色噜噜亚洲a∨| 国产乱子伦一区二区三区国色天香| 久久久久久亚洲精品杨幂换脸| 日韩一二三在线视频播| 久久av一区二区| 欧美视频在线观看| 亚洲国产中文字幕在线观看| 久久久久se| 欧美一区二区三区视频免费| 欧美日韩一区二区精品| 亚洲人成啪啪网站| 欧美 日韩 国产精品免费观看| 亚洲欧美在线一区| 国产乱码精品一区二区三区av| 99re热精品| 亚洲免费视频一区二区| 亚洲精品免费看| 西西人体一区二区| 亚洲一区二区三区免费视频| 免费久久精品视频| 美日韩丰满少妇在线观看| 亚洲欧美日韩国产综合在线 | 亚洲欧美日本精品| 欧美伦理影院| 久久精品免费观看| 久久精品女人天堂| 亚洲精品视频一区二区三区| 欧美激情精品久久久久久久变态| 老鸭窝毛片一区二区三区| 国产精品综合av一区二区国产馆| 亚洲国产91| 欧美高清视频www夜色资源网| 欧美日韩国产精品| 亚洲私拍自拍| 中文精品视频一区二区在线观看| 欧美a级在线| 一本久道久久综合中文字幕| 亚洲激情第一页| 国内精品久久久久影院 日本资源| 欧美顶级少妇做爰| 国产亚洲一区二区三区在线播放| 欧美成年人视频网站| 国产精品五区| 亚洲国产精品999| 亚洲高清久久网| 欧美激情影音先锋| 欧美日韩激情小视频| 亚洲在线国产日韩欧美| 日韩亚洲欧美一区| 激情欧美一区二区三区| 亚洲午夜精品久久久久久app| 亚洲人成毛片在线播放女女| 一本久道久久综合狠狠爱| 久久久91精品国产一区二区精品| 亚洲午夜精品一区二区三区他趣| 一本久道久久久| 国产精品毛片a∨一区二区三区|国 | 久久精品盗摄| 在线精品在线| 亚洲免费影视第一页| 亚洲国产综合视频在线观看| 亚洲一区二区三区乱码aⅴ蜜桃女| 亚洲精选在线| 久久人人超碰| 老司机精品久久| 亚洲精品1区2区| 欧美精品久久久久久久久老牛影院| 亚洲精品一区二区在线观看| 亚洲美女视频| 国产亚洲成人一区| 久久偷看各类wc女厕嘘嘘偷窃| 麻豆91精品91久久久的内涵| 国产精品扒开腿做爽爽爽软件| 91久久国产精品91久久性色| 国产精品一二三| 久久福利精品| 两个人的视频www国产精品| 国产欧美亚洲视频| 欧美在线观看一区二区| 久久久水蜜桃av免费网站| 亚洲国产婷婷综合在线精品| 国产精品多人| 欧美福利一区| 久久精品国产视频| 91久久久久久久久久久久久| 亚洲精品在线视频观看| 国产精品色一区二区三区| 久久久中精品2020中文| 国产精品亚洲一区二区三区在线| 一区二区三区免费观看| 亚洲一区二区在线看| 久久久久久免费| 性做久久久久久久久| 亚洲自拍都市欧美小说| 亚洲激情在线视频| 尤物yw午夜国产精品视频| 狠狠干综合网| 亚洲免费中文字幕| 亚洲区一区二| 国产亚洲精品久久飘花| 欧美午夜电影网| 欧美精品97| 欧美成人精品一区二区三区| 欧美一区二区三区啪啪| 久久精品一区二区国产| 久久综合网hezyo| 国产农村妇女精品一区二区 | 亚洲午夜激情免费视频| 亚洲级视频在线观看免费1级| 国产精品视频1区| 国产精品麻豆成人av电影艾秋| 欧美日韩亚洲一区二区三区四区 | 亚洲图片在线观看| 久久精品国产精品亚洲综合| 99re热这里只有精品免费视频| 亚洲黄一区二区| 亚洲一区二区三区在线| 久久久精品一区| 欧美视频日韩视频| 在线观看成人av| 欧美在线国产| 一区二区毛片| 欧美激情亚洲一区| 国产欧美一区二区三区沐欲| 国产老肥熟一区二区三区| 一区二区三区免费网站| 亚洲视频视频在线| 欧美电影在线观看完整版| 国产精品久久久久秋霞鲁丝| 日韩香蕉视频| 亚洲日本aⅴ片在线观看香蕉| 亚洲字幕在线观看| 性色一区二区| 欧美日韩国产色视频| 国产欧美日韩一区| 日韩性生活视频| 亚洲高清不卡| 欧美日韩免费高清一区色橹橹| 狠狠色综合播放一区二区| 久久九九99视频| 久久久免费av| 亚洲精品在线二区| 欧美成人蜜桃| 久久精品国产77777蜜臀| 国产日韩精品在线| 欧美高清在线视频| 欧美日韩亚洲另类| 久久超碰97中文字幕| 久久精品成人一区二区三区蜜臀| 国产欧美日韩免费看aⅴ视频| 亚洲欧美自拍偷拍| 9久re热视频在线精品| 欧美午夜片欧美片在线观看| 欧美一区激情视频在线观看| 亚洲欧美日韩国产中文| 国产真实乱偷精品视频免| 久久久久久久久一区二区| 欧美va日韩va| 久久精品国产精品亚洲精品| 欧美精品激情blacked18| 99精品热视频| 欧美一区二区成人| 亚洲最快最全在线视频| 久久精品国产免费观看| 欧美一区二区在线看| 国产精品99免费看| 久久久久久欧美| 欧美日韩三级电影在线| 亚洲电影下载| 国产一区二区欧美| 欧美亚洲综合在线| 亚洲综合三区| 日韩一级免费|