1 :
テンションアホ:
C++愛好者の皆さん,マトリックスクラスは何をお使いですか?
4則演算等はもちろんのこと,LU,固有値,特異値,一般逆等
もサポートされているものが望ましいです.
Lapack++やtntは激速だけど,使用が不完全すぎます. かと
言って,ちまたのwebで素人が配布してるのは遅すぎるし,ド
キュメントが充実していないのがほとんどです.
この際,Lapack並みの速さは求めないとして,ドキュメントの
充実しているC++マトリックスクラスは無いものでしょうか?
教えて下さい.
2 :
名無しさん@1周年:01/11/22 00:42
無い。
...と思う。
3 :
テンションアホ:01/11/22 01:18
無いんですか...
では,皆様がお使いのマトリックスクラスは何ですか?
「自作!!」と胸を張って答えて下さる方,是非入手先を
教えて下さい.
ちなみに,僕自身はLapack++を渋々使っています.
4 :
テンションアホ:01/11/22 01:38
6 :
名無しさん@1周年:01/11/22 12:38
そんなに行列を使いたいなら、Cでなくてもいいでしょうに。
COBOL使え。Sなんてのもあるぞよ。
7 :
テンションアホ:01/11/24 00:08
COBOLとかSはマトリックス数値解析に使うような言語なのでしょうか?
Lapack並みの計算速度 or C++やJAVA等によるクラスならではの操作性の
どちらも無い気がするのですが? 無知なもので...
是非COBOLやSでマトリックス数値計算をする利点をご教授下さい.
COBOLで・・・・なんて冗談ですよ。ちなみに>6じゃないけど。
Sならわかる。
でも、その分野ならMATLABそのものじゃないですか。
C++から使いたければ、簡単に関数呼べますよ。
9 :
テンションアホ:01/11/25 00:54
冗談きついです.
> でも、その分野ならMATLABそのものじゃないですか。
> C++から使いたければ、簡単に関数呼べますよ。
MATLABは有料なのが問題なんです. また,移植性の
ことを考えると,C++のソースのみで完結させたいです.
でも,最近のMATLABは内部でBlas,Lapackを使っている
らしくて,異常に計算速いと評判です.
どなたかC++マトリックスクラスユーザはいらっしゃい
ませんでしょうか?
>ことを考えると,C++のソースのみで完結させたいです
MATLABで作った関数をCに落としちゃうんじゃだめ?
11 :
名無しさん@Emacs:01/12/07 01:45
MTL 使ってる俺は厨房か?
12 :
中級エロゲーマー:01/12/07 02:52
俺は行列と言えば、3DCGで使うぐらいだからな…
というわけでDirectXのD3DMATRIX構造体を使っている。
14 :
名無しさん@1周年:01/12/07 19:48
16 :
名無しさん@1周年:01/12/07 22:32
17 :
名無しさん@1周年:01/12/13 02:57
この板の住人でJava使ってるやつっているの?
MATLABは,Lapackの上にラッパークラスを被せているだけなので,
本質的にLapackを使うのとは変わらないように見えるが,
Matlab上でメモリアロケーションの工夫は,ほとんど出来ないので,
大規模数値計算プログラミングをするならば,MATLABはほとんど使えない.
せいぜい,1000×1000のフルマトリックス位が精一杯てとこだな.
自作しないでやるなら,newmatが一番完成度高いと思う.
lapackのラッパークラスを自作した方が,何かと都合が良いとはおもうけど.
19 :
名無しさん@1周年:01/12/13 22:56
20 :
うふっ!私もおうえんするね♪:01/12/15 05:45
22 :
名無しさん@1周年:01/12/16 13:44
GSL(GNU Scientific Library)って基本的にCですよね?
>>21 マトリックス演算を"A*B"の様には書けないと思うのですが...
もちろん,ラッパーを作れば出来そうですが,あるんでしょうか?
23 :
名無しさん@1周年:01/12/18 11:05
自作
>>19 どこが嘘なのでしょうか?
MATLABでは,フルマトリックスと,スパースしか作れないので,
有限要素法のようにバンドマトリックスが必要となる場合には,
スパースからバンドへの変換をしなくてはならず,これは,非常に
大規模な有限要素解析の際には,致命的になります.ここは,反論あります?
あと,MATLABは,Lapackの上にラッパーを被せているというのは,間違えないと
思うのですが.確かに,色々拡張機能はありますが,行列計算に関するルーチンに関しては,
LAPACKの拡張と考えて差し支えないと考えていますが,いかが?
1000×1000のフルマトリックスが関の山と書いたのは,それ以上出来ないと
言ったのではなくて,それ以上の規模になったら,プログラム自作が一番良い
ということが言いたかったわけです.
反論は具体的にお願いします.
確かに嘘書いていました.
MATLABで,1000*1000行列のLU分解は10秒で済みました.
フルマトリックスの効率が悪くないというのは,大いに納得しましたが,
果たして,数十万*数十万のバンドでは計算できるのかどうか疑問です.
どうなのでしょうか?
26 :
名無しさん@1周年:01/12/22 12:35
プログラム板が妥当かと思った冬の昼下がり
27 :
名無しさん@1周年:01/12/22 16:07
なんでMATLABってあんなに早く計算できるの?
28 :
名無しさん@1周年:01/12/28 00:51
俺もMTL使っている。
厨房だ
>>9 遅レスだけど
有料が嫌ならOctaveやScilabを使えばいいじゃん.
30 :
名無しさん@1周年:02/01/01 16:54
win環境で、2*2行列だけ、昔(学生時代)自作したのを拡張して使ってる。
31 :
アピッシャー ◆KEIZ/w.o :02/04/29 03:51
( ゚プ) ハイハイハイハイハイ!!
(つつ
-=≡( ゚ ゚) > >≡( ゚ ゚)
↑ WW ↑
マーガレット フランソワ
(゚プ) コノスレ・・・・
⊂U⊃
( ゚ ゚) ∧ (゚ ゚ )
WW
( ゚プ) オモシロイ!
(つつ
( ゚ ゚) / | ( ゚ ゚)
WW
⊂(゚プ)つ サイコー!!
U_
( ゚ ゚ ) / W ( ゚ ゚ )
W
(゚プ ) デハマタゴジツ。
⊂⊂) )))
(゚ ゚ ))) < < (゚ ゚ ) )))
WW
/ ̄\
(´υ` )
\д/
/ ̄\
(´υ` )
\ д /
/ ̄\
│´υ` │
\ д /
/ ̄\
│´υ` │
\ д /
36 :
名無しさん@1周年:02/10/21 16:45
マトリックスって何?
誰か分かりやすく教えて!
C++の話題ではないです。参考意見程度に聴いてチョ。
自分は、マトリクス処理するときは、APLで組んでたけど。。
もともと言語仕様にマトリクスが含まれてるから、余計な事
(行列演算パッケージのインストール)しなくても使えたし。
APLで面倒だったのは、コーディングのときかな?特殊な文
字を色々と使うので、そこいらへんを憶えるのが・・・。
俺は自作。
行列の雛形をbasic_matrixテンプレートクラスで作っておいて、
要素の格納形式に応じて、それから派生させたmatrix、skyline_matrixその他。
ネットでいろいろ見たんだけどね。
自分の要求を満たす物はなかったので。
40 :
名無しさん@1周年:02/12/06 21:09
やっぱりvalarrayからつくったほうがいいのかなぁ?
41 :
名無しさん@1周年:02/12/07 14:20
. l ::::|l .i ::::::::::;;;',;::;゙、:;;',、:::::;;;;;l ,,、-、'""、;;:;::::;;;',. ヾ;;゙、 ,r<_,.,、、z゙'、、゙;、ヾ;゙、;;;;;;l;;;!;;::::::::::::
',::::l ! :.l. . .:::::::::::;;;;',;:;;,゙、;;',゙、::;、rl'" ,,.゙、',..,゙'、;;;;;;;;゙、 ヾ;、 ,,,;;シ''!"~~゙゙';,ヾx、.゙、;;;!;;l;;;:;::::::::::
',:::l ',:;;',.:゙、;;;::::::::;;;;;',;;;;, ヾ;r'、::;;;;!.r'',,、zェュ、. ヾ、;;;;゙、 ヽ''" l, ,,、:':'、 ヾ:;、;!;l;;;';;::::::::::
. ゙、:!. ',:;',、::゙、;;;;:::::;;;;',゙、;;/ヽ.ヾ;;;'ill!'''"゙i ~` ゙ヾ、゙、. lr''゙!::li!::;i, ヾj//;;;;::::::
ヾ ゙、:',゙、:゙'、;;;;::::;;;゙、ヾ;、 ヽ;lrヾ、 .,i, `` l;;::ゞン;::;j ツ;/;;;;;;::::;;
゙、 ゙、.!:ヽ、ヾ;;;;;;;;;゙;、 ヽ、;ll!. l ,r';::l, l;;;. .::: ,;;j ',;イ:;;;;;;;;::;;;;
,'ヽ、;:::l';,、゙、r、;;゙;、. ill!. ';;:'゙'i,,j;::l, 、,. ゞ--一゙- ,//:;;;;;;;;;;;;;;;
i ::::;:::!;;;;;;;l゙'',、.゙、ヽll!. 'i;:: ゙''゙:. l、 ,/'/;;;;;;;;;;;;;;/;;
! :::: :::l;;;;;;;;;! l .゙、. ヾ、. ゙、;;;;:、‐'''''" / /;;;;;;;;;;;;;シツ'
. |.:::;:: :::l;;;;;;;;;l 、〈゙、 、 '´ , ´ ,.';;;;;;、-'" ´
. l::::; ::i:::l;;;;;;;;;ヽ, ヽ、゙、 ;l /''" / 藍より青し 公式ホームページ
l::::;;:::',::',;;;;;;;;;゙、゙ヽ、. ゙、. ゙' ,イ
http://www.aiyoriaoshi.com/index2.html ',:::;;;:::',::',;;;;;;;;;;r'"~゙''ー'、 -‐ '''''" ,.';;;! 2話 - 夕餉 - 画像
゙、:;;;;::;',:゙、'''" ヽ、 、:::' /!;;;i!l
http://wqio6xt.hp.infoseek.co.jp/aiao/idx022.html
人間は、地球をほろぼすウイルスだ!!
今いる世界は現実ではないことはないのだ!
(^^)
(^^)
何のためのC++だ
自分の要求にあった派生クラス作れ
(^^)
∧_∧
( ^^ )< ぬるぽ(^^)
━―━―━―━―━―━―━―━―━[JR山崎駅(^^)]━―━―━―━―━―━―━―━―━―
∧_∧
ピュ.ー ( ^^ ) <これからも僕を応援して下さいね(^^)。
=〔~∪ ̄ ̄〕
= ◎――◎ 山崎渉
__∧_∧_
|( ^^ )| <寝るぽ(^^)
|\⌒⌒⌒\
\ |⌒⌒⌒~| 山崎渉
~ ̄ ̄ ̄ ̄
__∧_∧_
|( ^^ )| <寝るぽ(^^)
|\⌒⌒⌒\
\ |⌒⌒⌒~| 山崎渉
~ ̄ ̄ ̄ ̄
∧_∧
( ^^ )< ぬるぽ(^^)
∧_∧ ∧_∧
ピュ.ー ( ・3・) ( ^^ ) <これからも僕たちを応援して下さいね(^^)。
=〔~∪ ̄ ̄ ̄∪ ̄ ̄〕
= ◎――――――◎ 山崎渉&ぼるじょあ
55 :
名無しさん@3周年:03/08/04 20:40
今すぐ会いたいの。ひろみはあなたなしじゃもうだめみたい。
私、ここにいるから・・・・・探しに来て、くれる?
7日間会費フリー、10分間無料になってるの、だから来て。
あなたに会えなくちゃ、寂しくて死んじゃいそうだから
待ってます。来てくださいね!
→→→
http://www.gals-cafe.com
56 :
名無しさん@3周年:03/08/13 02:22
57 :
名無しさん@3周年:03/08/13 07:23
58 :
名無しさん@3周年:03/08/13 15:09
堤さやかちゃんの引退記念作です。
これは絶対見るしかないでしょう。
甘えたしゃべりかた、小さな身体に大きなオッパイ、そしてこの顔。
どれをとっても特A級!こんな子がAV女優だったなんて信じられませんね。
無料ムービー観てちょ
http://www.exciteroom.com/
スレンダーなロリ体形ながらもオマンコ方はしっかり発達しちゃってます。
大きなオチンチンを喉の奥までくわえ込んでのフェラは大人顔負けですぞ。
挿入シーンは少ないながらも小さなオマンコにしっかり挿入されているシーンが勃起モノ!
若い娘はいいですな。
無料ムービーはこちら!
http://www.cappuchinko.com/
60 :
マリーナの夏:03/08/13 15:57
(⌒V⌒)
│ ^ ^ │<これからも僕を応援して下さいね(^^)。
⊂| |つ
(_)(_) 山崎パン
.,. -──-、
/. : : : : : : : : \
/┛┗ : : : : : : : : : ヽ l⌒)OOo ∩___∩
. {:┓┏ '⌒' '⌒'i: : :} { ) ) | ノ --‐' 、_\
{:: : : : | ェェ ェェ |: : :} | ::::::/ / ,_;:;:;ノ、 ● |
. { : : : :| ,. |:: :;! / ::::|,,・_ | ( _●_) ミ
. ヾ: :: :i r‐-ニ-┐| ::ノ / )’,∴ ・¨彡、 |∪| ミ
ゞイ! ヽ 二゙ノ イゞ / / ̄∵ ’ / ヽノ ̄ヽ
/ _` ー一'´ ̄ / / / /\ 〉
(___) / / / /
63 :
mayaqua-penguin-softether-gateway.softether.jp:04/03/10 11:47
test
boostのublas。これ最強。
そうかぁ?
あれにもいろいろ不満が・・・
:::::::::::/ ヽ::::::::::::
:::::::::::| ば じ き i::::::::::::
:::::::::::.ゝ か つ み ノ:::::::::::
:::::::::::/ だ に は イ:::::::::::::
::::: | な。 ゙i ::::::
\_ ,,-'
――--、..,ヽ__ _,,-''
:::::::,-‐、,‐、ヽ. )ノ _,,...-
:::::_|/ 。|。ヽ|-i、 ∠_:::::::::
/. ` ' ● ' ニ 、 ,-、ヽ|:::::::::
ニ __l___ノ |・ | |, -、::
/ ̄ _ | i ゚r ー'
>>1 |::
|( ̄`' )/ / ,.. i '-
`ー---―' / '(__ ) ヽ 、
====( i)==::::/ ,/ニニニ
:/ ヽ:::i /;;;;;;;;;;;;;;;;
68 :
名無しさん@5周年:2005/12/21(水) 00:29:57
荒れてるな
69 :
名無しさん@5周年:2005/12/22(木) 13:28:48
blitz++
71 :
名無しさん@5周年:2006/05/02(火) 16:44:09
C++ のmatrixクラスか。使い勝手が良くて効率が良いライブラリはない。
なんせ、演算子のオーバーロードを使うと、関数値としてマトリックス
を返すときに、要素が全部コピーされるという絶望的な状況に陥るし。
それを避けるために、閉包や数式テンプレートのテクニック
使うと、呪文みたいに難しくなる。
あと、演算子*+−の両側のオペランドが作業用の一時マトリックス
かどうかをチェックしながら、グローバルオブジェクトの参照を返す
というテクニックもあるけど、マルチスレッドでは無力。
結局、今のところ決定的なテクニックはない。FORTRANやCみたいに
シコシコ引数を渡すのが一番効率的。
あれてるなぁ.使ってるのはcvmat.
73 :
名無しさん@5周年:2007/06/16(土) 14:56:16
>>9 遅レスだけど
有料が嫌ならOctaveやScilabを使えばいいじゃん.
74 :
名無しさん@5周年:2008/05/12(月) 18:15:00
ublas + OpenTissue
75 :
名無しさん@5周年:2008/06/21(土) 18:15:16
TNT
76 :
ひゃ:2009/06/14(日) 12:00:31
演算子のオーバーロード遅いって言ってるやつへ
遅いがまじめに返すと、演算子のオーバーロードをしたら遅くなるって言ってるやつ多いが、
演算子は普通の関数と処理速度は変わらんから、組み方が悪いだけと言える。
読み取らせたいだけなら、参照渡しで渡せば良いだけだしな
演算子のオーバーロードがどのぐらい利いてくるかちょっと試すためにdouble型の要素を3つ持つ、
ベクトルの足し算が出来るの作ってみるとさ、確かに、普通にコンパイルすると、
多少こっちの方が遅かった。
でも、最適化を有効にしてコンパイルすると全く速度が変わらなかった。
結局アルゴリズムが同じなら、最適化されればどっちも同じ速度らしい。
78 :
名無しさん@5周年:2009/08/06(木) 19:03:45
ttp://www.esnips.com/doc/c30b4188-1e9b-48ea-9c7a-bd902b44fcea/inst_all_new 例
#include <instMatrix.h>
using namespace inst;
#define MAT(rows,cols) MATRIX<Float,rows,cols>
#define VEC(rows) MATRIX<Float,rows,1>
const VEC(n) X0 = {-1.0f, -1.0f, -1.0f};
const MAT(n,n) W =
{0.2f, 0.0f, 0.0f,
0.0f, 1.2f, 0.0f,
0.0f, 0.0f, 0.2f};
const VEC(n) T = {-0.9f, 0.0f, 0.9f};
VEC(n) NET(Int t) { return W * X(t-1) - T; } // 便利
VEC(n) X(Int t) { if(0==t) return X0; else return Each(satlins, NET(t)); }
79 :
名無しさん@5周年:2009/08/06(木) 20:49:21
PS.俺の名前空間は、INST_DEBUGを予め定義してください
PS2.その名前空間内のリストは、(test用のみだから)iteratorはまだ実装していないから、
本格的なリスト操作なら、stlを使ってください。
80 :
名無しさん@5周年:2009/12/10(木) 13:26:59
>>76 ベクトル演算くらいで偉そうにグダグダ言うな。この馬鹿!
やるならマトリックスの乗算で議論しろや。
あっ、言っておくが、RVOのテクニック使っても、(A+B)*C*(D+E)の
ような(演算子オーバーロードによる)演算では要素コピーはほんの
一部しか避けられん。
じゃ、数式テンプレートと言い出すだろうが、行列のサイズが大きく
なるにつれてコンパイル時間が異常にかかってしまう。サイズ10×10
以上では事実上不可能。
81 :
名無しさん@5周年:2010/04/10(土) 15:35:27
76じゃないが、
>(A+B)*C*(D+E)
速度を気にする場所でこんな書き方するほうがおかしい。
temp1 = D;
temp1 += E;
temp2 = A;
temp2 += B;
temp2 *= C;
temp2 *= temp1;
こうすりゃ一緒じゃねーの?
あと数式テンプレートってなんのこと?
まさか値がコンパイル時にわからないもの同士の計算をコンパイル時に出来ると思ってないよね?
82 :
81:2010/04/15(木) 13:34:18
めっさ勘違いしてた。
たまたま自前のベクトルクラス作ってたんだが、
>(A+B)*C*(D+E)
こう書いた方が速かった。
(環境はVC2008EE、operator +,*は当然インラインメンバ関数)
下手に一時変数を自分で書くよりも、
メモリからのロード順や計算順序を最適化しやすいのかもしれない。
逆アセ見たら、無駄な一時オブジェクトを発生させることもなく
計算用レジスタに直接ぶちこまれて直接計算してた。
というわけで
>RVOのテクニック使っても
>要素コピーはほんの一部しか避けられん
大嘘こいてんじゃねえ。
83 :
名無しさん@5周年:2010/05/07(金) 15:32:30
↑馬鹿
計算結果が正しいかチェックしてみな
84 :
名無しさん@5周年:2010/05/10(月) 20:49:34
馬鹿はお前だ
85 :
名無しさん@5周年:
>>81 式テンプレートすら知らんお前がしゃしゃりでてくんな糞野郎