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

posts - 18,  comments - 104,  trackbacks - 0

最近項目里總是要對很龐大的公式求導(dǎo),很煩人,手工求導(dǎo)容易出錯。
當然MATLAB是個好選擇,不過當它要錢的時候,您可能就不這么認為了。
于是,實現(xiàn)了一個可以編譯期求導(dǎo)(不用擔心運行時負擔)的小型庫,還不完全,僅支持多項式,sin,cos,pow,exp,log等函數(shù)求導(dǎo)。
后期的表達式優(yōu)化做的不是很好。
下面是一些測試代碼,完整的源碼在http://www.boostpro.com/vault/index.php?action=downloadfile&filename=[math]AD.zip
實現(xiàn)部分很復(fù)雜,請多多指教。

只有1個函數(shù), d(...)
支持高階,多元求導(dǎo)。

d(exp, var)(value1, value2, ...)
exp內(nèi)可以有多個變量,var表示要對其求導(dǎo)的變量,value表示求導(dǎo)以后用于計算表達式的變量的值。

比如:
d(d(x*x*x, x),x)(3.0)                           表示對x*x*x求二階導(dǎo)數(shù)在x=3.0時候的值。
d(d(x*x*y, x), y)(3.0, 4.0)                   表示d(x*x*y)/(dxdy)在x=3.0,y=4.0的值。
d(d(x*x*x, x) +d(y*x, y), y) (2.0)        則表示 (d(x*x*x)/dx + d(y*x)/dy)/dy == 0。

可以直接用cout把求導(dǎo)后的表達式輸出,不用給變量給值。
cout<<d(x*x, x)     //  結(jié)果是:2*x

這里沒有用任何迭代,是直接對表達式求導(dǎo)的。返回值是求導(dǎo)后的表達式,本質(zhì)是一個仿函數(shù)。可以用boost::function保存起來使用。
例如:

boost::function<double (double)> df = d(pow(x, const_<10>::type()), x); //df 參數(shù)為1個double,返回double

然后就可以在任何地方使用 df 了:

double res = df(3.0)   // res == pow(3, 9)

 1#include "ad.h"
 2#include <iostream>
 3#include <iterator>
 4
 5using namespace std;
 6
 7int main()
 8{
 9    variable<0>::type x;
10    variable<1>::type y;
11
12    double res[14];
13
14    res[0= d(pow(x, const_<10>::type()), x)(2.0);
15
16    res[1= d(x * x * x, x)(2.0);
17    res[2= d(x + x + x, x)(2.0);
18    res[3= d(x - x - x, x)(2.0);
19    res[4= d(x / x, x)(2.0);
20
21    res[5= d(pow(x, var(3.0)), x)(2.0);
22    res[6= d(pow(var(3.0), x), x)(2.0);
23    res[7= d(pow(x, x), x)(2.0);
24
25    res[8= d(log(x), x)(2.0);
26    res[9= d(exp(x), x)(2.0);
27
28    res[10= d(sin(x), x)(2.0);
29    res[11= d(cos(x), x)(2.0);
30
31    res[12= d(d(sin(x) * cos(y), x), y)(2.03.0);
32
33    res[13= (d(log(x) + x, x) * x)(2.0);
34
35    copy(res, res + 14, ostream_iterator<double>(cout, "\n"));
36
37    cout<<d(pow(x, const_<10>::type()), x)<<endl;
38
39    cout<<d(x * x * x, x)<<endl;
40    cout<<d(x + x + x, x)<<endl;
41    cout<<d(x - x - x, x)<<endl;
42    cout<<d(x / x / x, x)<<endl;
43
44    cout<<d(pow(x, var(3.0)), x)<<endl;
45    cout<<d(pow(var(3.0), x), x)<<endl;
46    cout<<d(pow(x, x), x)<<endl;
47
48    cout<<d(log(x), x)<<endl;
49    cout<<d(exp(x), x)<<endl;
50
51    cout<<d(sin(x), x)<<endl;
52    cout<<d(cos(x), x)<<endl;
53
54    cout<<d(d(sin(x) * cos(y), x), y)<<endl;
55
56    cout<<(d(log(x) + x, x) * x)<<endl;
57
58    return 0;
59}

60

輸出結(jié)果如下:
 1512
 212
 33
 4-1
 50
 612
 79.88751
 86.77259
 90.5
107.38906
11-0.416147
120.909297
13-0.0587266
143
15pow(x,9)
16(((x+x)*x)+(x*x))
173
18-1
19(-1/(x*x))
20(pow(x,3)*(3*(1/x)))
21(pow(3,x)*log(3))
22(pow(x,x)*(log(x)+1))
23(1/x)
24exp(x)
25cos(x)
26sin(x)
27(cos(x)*sin(y))
28(((1/x)+1)*x)
29

posted on 2009-05-01 23:50 尹東斐 閱讀(2622) 評論(6)  編輯 收藏 引用

FeedBack:
# re: 自動求導(dǎo)模板庫[未登錄]
2009-05-02 13:50 | wang feng
能否返回一個函數(shù)指針?
比如:
typedef double (fp*) ( const vector<double>&, const double);
fp f1;
........
fp f2 = d(f1);  回復(fù)  更多評論
  
# re: 自動求導(dǎo)模板庫
2009-05-02 22:22 | yindf
@wang feng

因為是編譯期求導(dǎo)的,所以不可能接受一個函數(shù)指針,編譯器需要表達式的信息在編譯期對表達式求導(dǎo),結(jié)果是一個求導(dǎo)后的表達式,值是在后面帶進去的。

函數(shù)指針需要在運行期才能知道具體函數(shù),一般用迭代法求導(dǎo)。  回復(fù)  更多評論
  
# re: 自動求導(dǎo)模板庫
2009-12-06 16:10 | ztf
請問,下載的文件應(yīng)該放在哪里?該如何引用 啊,我太菜了,給了東西都不會用  回復(fù)  更多評論
  
# re: 自動求導(dǎo)模板庫
2009-12-07 11:10 | 尹東斐
下載的文件放在和其他程序文件相同的目錄下,然后#include“ad.h”
要不你可以放在其他文件下,然后#include “xxx/ad.h"

具體用法參見前面的example。  回復(fù)  更多評論
  
# re: 自動求導(dǎo)模板庫
2011-09-08 08:49 | 哥哥小情歌
把上面的代碼改為Java形式的!  回復(fù)  更多評論
  
# re: 自動求導(dǎo)模板庫
2012-09-18 11:29 | 謝謝
謝謝樓主 順便鄙視下樓上 不懂禮貌  回復(fù)  更多評論
  

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


<2009年12月>
293012345
6789101112
13141516171819
20212223242526
272829303112
3456789

常用鏈接

留言簿(4)

隨筆檔案

文章分類

文章檔案

相冊

好友博客

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            午夜国产精品视频| 欧美日韩国产一区二区三区| 羞羞色国产精品| 在线观看国产精品淫| 国产精品国码视频| 欧美国产日本| 久久久久久久久久码影片| 亚洲婷婷在线| 日韩视频免费| 日韩视频在线一区| 亚洲靠逼com| 欧美激情片在线观看| 亚洲国产精品成人久久综合一区 | 国产一区二区精品丝袜| 国产精品日韩欧美大师| 欧美日韩一区二区三区免费看 | 欧美日韩午夜激情| 欧美精品一区在线发布| 欧美激情一区二区三区成人| 美日韩精品视频| 麻豆freexxxx性91精品| 免费国产一区二区| 欧美国产在线电影| 欧美精品二区| 国产精品v欧美精品v日韩| 国产精品v日韩精品v欧美精品网站| 欧美精品一级| 国产精品爽黄69| 韩日在线一区| 亚洲精品国久久99热| 一本色道久久综合亚洲二区三区| 国产三级欧美三级日产三级99| 精品999网站| 99av国产精品欲麻豆| 性欧美长视频| 欧美黄色一区| 亚洲图片在线观看| 欧美一级理论片| 亚洲欧美另类国产| 久久精品一区二区| 亚洲高清在线观看一区| 亚洲免费观看高清完整版在线观看熊 | 欧美激情亚洲| 国产精品久久久久一区二区三区共 | 美女免费视频一区| 日韩视频中文字幕| 久久精品在线| 欧美午夜精品久久久久久人妖| 国产一区二区三区在线免费观看| 亚洲精品欧美日韩| 欧美一区二区三区另类| 免费亚洲电影| 国产精品99久久不卡二区 | 久久日韩粉嫩一区二区三区| 亚洲国产中文字幕在线观看| 午夜视频久久久| 欧美日韩精品在线播放| 国产精品毛片一区二区三区| 1000部国产精品成人观看| 亚洲主播在线| 欧美激情一区二区久久久| 欧美黄免费看| 欧美专区18| 国产精品国产三级国产aⅴ浪潮| 又紧又大又爽精品一区二区| 亚洲欧美日韩在线高清直播| 亚洲国产精品毛片| 久久精品亚洲国产奇米99| 国产精品国产a级| 一本久久综合| 亚洲国产另类久久久精品极度| 久久精品人人爽| 国产精品自拍视频| 午夜国产精品影院在线观看| 亚洲人精品午夜| 欧美精品国产精品| 欧美午夜精品久久久久久超碰| 亚洲精选91| 欧美激情在线播放| 美女性感视频久久久| 亚洲韩国精品一区| 欧美一区二区三区播放老司机| 一区二区三区精品国产| 欧美日韩一区二区精品| 9色国产精品| 欧美wwwwww| 免费久久99精品国产自| 91久久精品一区二区三区| 欧美日韩和欧美的一区二区| 亚洲欧洲一区二区三区在线观看| 亚洲一区二区精品在线| 亚洲精品资源美女情侣酒店| 欧美激情精品久久久久久| 亚洲日本va在线观看| 欧美激情视频一区二区三区免费 | 在线观看福利一区| 欧美69视频| 国产精品激情偷乱一区二区∴| 久久伊人亚洲| 国产精品美女久久久浪潮软件| 久久香蕉国产线看观看av| 欧美片在线观看| 久久一二三国产| 欧美午夜久久| 91久久极品少妇xxxxⅹ软件| 国产精品任我爽爆在线播放| 欧美激情一区二区| 一区二区三区在线免费观看| 一区二区三区欧美日韩| 亚洲日本在线观看| 久久久久**毛片大全| 亚洲欧美精品在线| 欧美精品日韩www.p站| 美国三级日本三级久久99| 国产麻豆日韩欧美久久| 最新亚洲电影| 亚洲国产精品小视频| 久久aⅴ国产紧身牛仔裤| 亚洲自拍电影| 欧美日韩精品不卡| 亚洲国产婷婷香蕉久久久久久99 | 亚洲天堂男人| 欧美电影免费网站| 免费日本视频一区| 国模精品娜娜一二三区| 亚洲尤物精选| 亚洲伊人久久综合| 欧美日本一区二区高清播放视频| 你懂的视频一区二区| 好吊成人免视频| 久久国产欧美日韩精品| 久久精品五月| 国产一本一道久久香蕉| 亚洲女同同性videoxma| 亚洲欧美日韩在线一区| 国产精品av久久久久久麻豆网| 一本久道久久综合婷婷鲸鱼| 一区二区三区.www| 欧美色图五月天| 亚洲性xxxx| 久久精品女人| 伊人久久噜噜噜躁狠狠躁| 久久久精品欧美丰满| 农夫在线精品视频免费观看| 极品尤物久久久av免费看| 久久精品国产77777蜜臀| 老色批av在线精品| 亚洲国产免费看| 欧美成年人视频网站欧美| 久久久天天操| 午夜精品久久久99热福利| 欧美视频在线看| 99精品国产99久久久久久福利| 久久久人成影片一区二区三区观看| 亚洲精品字幕| 欧美日韩中文字幕| 中日韩午夜理伦电影免费| 9人人澡人人爽人人精品| 欧美视频一区二| 欧美一级黄色网| 久久精品亚洲国产奇米99| 91久久在线播放| 亚洲免费av电影| 国产精品女主播| 美女被久久久| 欧美看片网站| 久久久久久一区二区| 久久偷看各类wc女厕嘘嘘偷窃| 亚洲人成久久| 欧美影视一区| 国产精品99久久99久久久二8| 亚洲在线黄色| 99成人在线| 美国十次成人| 欧美中文日韩| 欧美三级资源在线| 欧美国产另类| 国产一区免费视频| 亚洲网站啪啪| 宅男噜噜噜66一区二区| 久久精品国产一区二区三| 一本大道久久a久久综合婷婷| 午夜精品婷婷| 久久se精品一区精品二区| 国产精品午夜在线| 亚洲综合色网站| 欧美一区不卡| 国产婷婷97碰碰久久人人蜜臀| 亚洲午夜在线观看视频在线| 亚洲一区二区在线免费观看视频| 欧美韩日视频| 亚洲图片你懂的| 久久超碰97人人做人人爱| 日韩视频国产视频| 亚洲夜晚福利在线观看| 欧美午夜视频一区二区| 日韩一级黄色片| 欧美亚洲免费在线| 极品少妇一区二区三区精品视频| 久久深夜福利|