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

posts - 18,  comments - 104,  trackbacks - 0

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

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

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

比如:
d(d(x*x*x, x),x)(3.0)                           表示對(duì)x*x*x求二階導(dǎo)數(shù)在x=3.0時(shí)候的值。
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)后的表達(dá)式輸出,不用給變量給值。
cout<<d(x*x, x)     //  結(jié)果是:2*x

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

boost::function<double (double)> df = d(pow(x, const_<10>::type()), x); //df 參數(shù)為1個(gè)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 尹東斐 閱讀(2624) 評(píng)論(6)  編輯 收藏 引用

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

因?yàn)槭蔷幾g期求導(dǎo)的,所以不可能接受一個(gè)函數(shù)指針,編譯器需要表達(dá)式的信息在編譯期對(duì)表達(dá)式求導(dǎo),結(jié)果是一個(gè)求導(dǎo)后的表達(dá)式,值是在后面帶進(jìn)去的。

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

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

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


<2009年5月>
262728293012
3456789
10111213141516
17181920212223
24252627282930
31123456

常用鏈接

留言簿(4)

隨筆檔案

文章分類

文章檔案

相冊(cè)

好友博客

搜索

  •  

最新評(píng)論

閱讀排行榜

評(píng)論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            美女主播精品视频一二三四| 久久免费视频在线| 国产精品区二区三区日本| 亚洲午夜精品17c| 欧美一区二区视频在线观看2020| 国产精品免费福利| 新狼窝色av性久久久久久| 久久久久久夜| 91久久精品国产91性色| 欧美日韩黄色大片| 欧美一区二区三区久久精品茉莉花 | 欧美日一区二区三区在线观看国产免| 夜夜嗨av一区二区三区网页 | 久久电影一区| 欧美国产日韩一区| 亚洲欧美日韩精品一区二区| 国产一区清纯| 欧美精品一区二区三区视频| 在线一区二区三区做爰视频网站| 久久精品日产第一区二区| 亚洲激情在线播放| 国产精品制服诱惑| 欧美va亚洲va香蕉在线| 一本色道久久综合一区| 每日更新成人在线视频| 亚洲免费一在线| 亚洲高清中文字幕| 国产精品视频久久久| 美女脱光内衣内裤视频久久网站| 在线综合+亚洲+欧美中文字幕| 久久夜色精品国产噜噜av| 在线亚洲电影| 亚洲国产乱码最新视频| 国产午夜精品理论片a级探花| 欧美电影免费观看高清| 亚洲一区三区电影在线观看| 欧美大学生性色视频| 欧美一区日韩一区| 亚洲私人影院在线观看| 亚洲激情小视频| 狠狠狠色丁香婷婷综合激情| 国产精品成av人在线视午夜片| 欧美成人一区二区三区| 久久深夜福利| 久久黄色小说| 午夜久久tv| 亚洲香蕉伊综合在人在线视看| 亚洲黄一区二区三区| 久久嫩草精品久久久精品一| 香蕉久久夜色| 亚洲欧美激情视频| 一区二区电影免费观看| 亚洲人成在线观看一区二区| 在线播放国产一区中文字幕剧情欧美 | 国产精品乱码一区二区三区| 欧美精品久久99久久在免费线| 久久亚洲影音av资源网| 久久国产高清| 久久精品视频播放| 久久国产手机看片| 久久精品在线| 久久免费视频网站| 久久精品视频一| 久久精品视频在线播放| 久久超碰97中文字幕| 国产在线精品成人一区二区三区| 欧美日韩一区二区高清| 麻豆成人精品| 久久人人97超碰精品888| 久久精品91久久香蕉加勒比| 欧美主播一区二区三区| 久久国产欧美精品| 久久久精品国产免费观看同学| 亚洲欧美日本另类| 欧美一区二区三区在线| 欧美在线视频一区二区| 久久久久久有精品国产| 久久只精品国产| 久久噜噜亚洲综合| 麻豆精品视频| 欧美日韩123| 国产精品高潮呻吟久久av无限| 国产精品成人一区二区网站软件 | 日韩视频专区| 中文一区字幕| 欧美成人一区二区三区在线观看 | 欧美性做爰猛烈叫床潮| 国产精品超碰97尤物18| 国产欧美日韩亚州综合| 一区二区三区在线高清| 亚洲国产欧美在线人成| 夜夜爽夜夜爽精品视频| 亚洲欧美一区二区激情| 久久视频这里只有精品| 欧美激情一区二区三区成人| 亚洲精品字幕| 欧美一区二区三区成人| 久久一区二区三区国产精品| 欧美人与性动交α欧美精品济南到 | 亚洲伊人一本大道中文字幕| 欧美亚洲一区二区在线| 久久久久五月天| 亚洲国产三级在线| 在线一区观看| 久久精品在线| 欧美三级电影精品| 精品动漫一区二区| 一本久久a久久免费精品不卡| 欧美一级视频| 亚洲国产日韩一级| 亚洲欧美综合精品久久成人| 欧美jizzhd精品欧美巨大免费| 国产精品久久久久999| 亚洲福利视频在线| 午夜在线精品偷拍| 最新日韩在线| 久久国产精品色婷婷| 欧美日韩亚洲综合在线| 狠狠色丁香久久婷婷综合丁香 | 欧美午夜不卡视频| 亚洲视频大全| 久久久精品网| 亚洲免费影院| 亚洲另类春色国产| 狠狠色综合色区| 欧美日韩1080p| 久久久久久久999精品视频| 欧美顶级艳妇交换群宴| 欧美综合第一页| 亚洲一区在线免费| av不卡在线看| 亚洲国产小视频| 激情丁香综合| 国产亚洲一区二区三区在线观看| 久久久免费av| 久久夜色精品国产| 亚洲女同在线| 久久久精品五月天| 欧美成人精品在线| 久久国产66| 99精品视频一区二区三区| 久久综合狠狠综合久久激情| 亚洲一区二区成人| 亚洲一区二区久久| 欧美激情亚洲一区| 欧美激情国产高清| 国内一区二区三区在线视频| 国产又爽又黄的激情精品视频| 亚洲视频在线一区| 亚洲日本中文| 免费高清在线视频一区·| 尤物精品在线| 免费亚洲电影在线观看| 久久av一区| 国内精品嫩模av私拍在线观看| 欧美一区二区三区免费在线看| 一区二区日韩免费看| 欧美日韩一区二区三| 日韩视频永久免费| 亚洲人成在线观看| 欧美日本亚洲| 亚洲一二三区视频在线观看| 亚洲免费av电影| 国产精品va在线| 欧美一区观看| 欧美在线视频一区二区三区| 国产主播一区二区三区| 麻豆久久久9性大片| 美国十次了思思久久精品导航| 亚洲成人在线网| 亚洲国产日韩欧美在线99| 欧美风情在线| 亚洲午夜小视频| 亚洲女同性videos| 狠狠色伊人亚洲综合成人| 欧美国产日韩一二三区| 欧美日本在线观看| 亚洲欧美日韩综合一区| 欧美一区二视频在线免费观看| 狠狠色伊人亚洲综合网站色| 欧美高清视频免费观看| 欧美日韩在线三区| 久久av在线看| 蜜桃av久久久亚洲精品| 亚洲性线免费观看视频成熟| 在线视频一区二区| 国产一区二区中文| 亚洲高清免费在线| 欧美午夜电影一区| 久久综合九色九九| 欧美伦理在线观看| 亚洲视频免费看| 久久一区中文字幕| 免费不卡在线观看av| 日韩一区二区精品在线观看| 亚洲视频精选在线| 亚洲韩国精品一区| 亚洲一区二区在线视频| 亚洲高清不卡一区| 99热这里只有精品8|