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

posts - 18,  comments - 104,  trackbacks - 0

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

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

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

比如:
d(d(x*x*x, x),x)(3.0)                           表示對x*x*x求二階導數在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把求導后的表達式輸出,不用給變量給值。
cout<<d(x*x, x)     //  結果是:2*x

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

boost::function<double (double)> df = d(pow(x, const_<10>::type()), x); //df 參數為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

輸出結果如下:
 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 尹東斐 閱讀(2616) 評論(6)  編輯 收藏 引用

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

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

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

具體用法參見前面的example。  回復  更多評論
  
# re: 自動求導模板庫
2011-09-08 08:49 | 哥哥小情歌
把上面的代碼改為Java形式的!  回復  更多評論
  
# re: 自動求導模板庫
2012-09-18 11:29 | 謝謝
謝謝樓主 順便鄙視下樓上 不懂禮貌  回復  更多評論
  
<2009年5月>
262728293012
3456789
10111213141516
17181920212223
24252627282930
31123456

常用鏈接

留言簿(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>
            久久黄色级2电影| 亚洲一区视频| 国产精品超碰97尤物18| 夜夜嗨一区二区| 久久亚洲私人国产精品va媚药 | 欧美成人蜜桃| 久久久久国产免费免费| 亚洲一区二区在线看| 亚洲电影免费观看高清完整版在线 | 午夜在线精品偷拍| 亚洲免费在线播放| 亚洲视频一区二区免费在线观看| 永久域名在线精品| 国产自产高清不卡| 欧美日韩国产一区二区| 国产欧美日韩三级| 在线观看91精品国产入口| 国产欧美精品日韩| 激情六月婷婷综合| 亚洲二区在线视频| 国产资源精品在线观看| 亚洲国产精品久久久久婷婷884| 亚洲伦理在线| 亚洲午夜精品17c| 性欧美暴力猛交另类hd| 久久国产精品免费一区| 久久九九精品99国产精品| 久久国产精品久久久| 欧美激情一二三区| 亚洲少妇最新在线视频| 久久久久.com| 欧美精品精品一区| 国产欧美在线观看| 亚洲国产精品久久久久婷婷老年| 久久久久国产一区二区三区四区| 欧美a级在线| 亚洲你懂的在线视频| 老牛国产精品一区的观看方式| 欧美精品www| 国产精品素人视频| 亚洲一区二区三区国产| 国产精品入口夜色视频大尺度| 国产欧美日韩精品一区 | 一本久道久久综合中文字幕| 亚洲主播在线播放| 亚洲国产日韩欧美| 欧美一区二区免费视频| 国产精品高潮呻吟久久av无限| 国产在线日韩| 久久精品国产亚洲精品| 欧美a级片一区| 欧美国产精品劲爆| 亚洲图片在线| 99国产精品99久久久久久| 亚洲精品一区二区三区在线观看 | 国产精品久久91| 亚洲最新在线视频| 亚洲乱码精品一二三四区日韩在线 | 亚洲欧美日韩精品久久奇米色影视| 农村妇女精品| 亚洲国产精品成人精品| 看欧美日韩国产| 国产精品女主播在线观看 | 在线视频亚洲| 麻豆乱码国产一区二区三区| 亚洲精选视频在线| 亚洲欧美日韩视频一区| 尤物网精品视频| 亚洲精品一区二区三区婷婷月 | 欧美主播一区二区三区| 黄色小说综合网站| 欧美一区二区视频在线观看| 99视频精品| 亚洲一品av免费观看| 免费成人高清| 美女成人午夜| 国产美女精品视频免费观看| 狂野欧美性猛交xxxx巴西| 欧美高清成人| 夜夜夜久久久| 欧美日韩国产区一| 久久综合给合久久狠狠色| 欧美日韩国产黄| 亚洲高清av| 国模 一区 二区 三区| 欧美国产日韩xxxxx| 国内成人精品一区| 久久国产精品亚洲77777| 亚洲一级片在线看| 美日韩精品免费| 西西裸体人体做爰大胆久久久| 国产精品久久久久久av下载红粉| 久久精品日韩欧美| 国产亚洲毛片| 最新国产乱人伦偷精品免费网站| 一本色道综合亚洲| 欧美深夜福利| 久久国产天堂福利天堂| 久久天天躁狠狠躁夜夜av| 国产在线国偷精品产拍免费yy| 欧美黑人国产人伦爽爽爽| 亚洲第一黄网| 亚洲成色777777在线观看影院| 久久久之久亚州精品露出| 欧美精品在线一区二区三区| 黄色成人在线免费| 欧美午夜电影一区| 亚洲欧美日韩国产精品| 欧美sm视频| 99国产精品久久久久老师 | 久久国产精彩视频| 在线日韩精品视频| 欧美日韩精品一区二区三区四区 | 欧美一区二区| 欧美激情中文字幕乱码免费| 欧美日韩三级| 亚洲精华国产欧美| 午夜一区二区三区在线观看| 日韩一级在线观看| 亚洲国产女人aaa毛片在线| 国产日韩亚洲欧美| 国产精品美女在线观看| 欧美日韩亚洲国产一区| 麻豆91精品| 欧美国产日韩在线观看| 欧美成年人视频网站| 久久亚洲免费| 欧美成人综合| 欧美美女日韩| 国产精品久久久久影院色老大| 欧美日韩在线第一页| 久久久久久网站| 亚洲一区二区三| 国产精品久久久久久久久久久久久| 亚洲精品欧美精品| 亚洲美女电影在线| 欧美精品二区三区四区免费看视频| 国产亚洲福利社区一区| 久久久青草青青国产亚洲免观| 久久久久久久久久看片| 你懂的国产精品| 欧美一区亚洲| 狠狠网亚洲精品| 黄色精品网站| 亚洲影院免费观看| 久久精彩视频| 久久夜色精品国产欧美乱极品| 欧美一区二区在线免费播放| 亚洲男人第一网站| 欧美成人激情视频| 99精品视频免费全部在线| 欧美粗暴jizz性欧美20| 欧美国产在线电影| 一本色道久久综合亚洲精品不 | 亚洲欧美日韩一区二区三区在线观看| 久久一区二区视频| 一区二区欧美日韩视频| 久久精品视频网| 亚洲欧美日产图| 欧美四级伦理在线| 激情欧美日韩| 欧美一区二区三区免费观看视频| 亚洲黄色免费| 欧美激情一区二区三级高清视频| 欧美亚州一区二区三区| 在线日韩中文字幕| 91久久黄色| 久久免费的精品国产v∧| 午夜免费久久久久| 国产精品成人一区二区网站软件| 亚洲在线观看免费| 亚洲精品乱码久久久久久黑人| 欧美国产免费| 亚洲一区二区三区欧美 | 狠狠色综合网| 欧美成人a视频| 久久精品国产久精国产思思| 欧美四级在线观看| 免费试看一区| 久久久噜噜噜久久中文字幕色伊伊 | 欧美日韩在线不卡一区| 99亚洲视频| 午夜日韩在线观看| 日韩视频免费大全中文字幕| 亚洲精品老司机| 国产精品资源在线观看| 欧美激情a∨在线视频播放| 欧美日韩日本视频| 欧美在线亚洲综合一区| 欧美精品精品一区| 美女精品国产| 国产精品入口夜色视频大尺度 | 欧美日韩一卡二卡| 久久久精品午夜少妇| 国产精品红桃| 亚洲精品一区二区网址| 欧美日韩视频一区二区三区| 亚洲综合日韩在线| 欧美吻胸吃奶大尺度电影| 国自产拍偷拍福利精品免费一|