246 :
デフォルトの名無しさん :
04/07/30 00:10 任意のラジアンを、[-2π,...,2π]の区間に正規化したいんですけど、なんか効率のいい方法はないですかね? 単純に下のやりかたでやってたんですけど、15439054.2345ラジアンとかいう莫大な値もとるので困ってます。 Real r = fabs( fRad ); while( r > NGL_PAI*2 ) { r -= NGL_PAI*2; } r = r * SIGN( fRad ); return r;
247 :
デフォルトの名無しさん :04/07/30 00:27
>>246 Real r = fRad - 2*NGL_PAI*floor(fRad / (NGL_PAI*2));
return r;
そのソースプログラムから言語の仕様を適当に類推して書いてみた。
floor(x)はxを超えない最大の整数。
これならいくら fRad が大きくても大丈夫。但し、fRad が大きいほど精度は落ちる。
keta = 5 r = r - ([r / (2*π)] * (2*π))
king≒void
250 :
デフォルトの名無しさん :04/07/30 01:40
> [-2π,...,2π]の区間に正規化 > [-2π,...,2π]の区間に正規化 > [-2π,...,2π]の区間に正規化 > [-2π,...,2π]の区間に正規化 > [-2π,...,2π]の区間に正規化 > [-2π,...,2π]の区間に正規化 > [-2π,...,2π]の区間に正規化
[0..2π)かなあ?
253 :
デフォルトの名無しさん :04/07/31 01:47
>>247-248 返答ありがとうございます。
除法定理で解くのも考えたんですが、仰るとおり誤差が問題なんです。
あと、どうせやるなら(-π, π]でした。
引き算繰り返したときは誤差は出ないのか?
あと、どうせやるなら[-π, π)でしょう?
return atan2(sin(x),cos(x))
>254 そもそも>246みたいなデカイ値の時点で(ry
>>253 誤差については引算繰り返しと同等の筈だよ。
もともと浮動小数点で桁数の大きいものだと少数点以下の有効桁が減少してる事に注意すべきだ。
この誤差が気に入らないというなら、最初から浮動小数点を使わない事だ。
たとえば、$80000000〜$7FFFFFFFを-π〜πにするとか
>258 誤差が見えなくなるだけで、無くなる訳ではない。
>>259 言ってるのは、浮動小数点を使う為に、桁数の大きい時とそうじゃない時で有効桁数が違うという点について
改善出来るという事だ。
0.001 は誤差を持ってるけど 1万倍して 記録しておけば浮動小数点でも 誤差なく記録できるのと同じだ
まぁ、ラジアンの誤差が気になるような所ならdouble使わないで多倍長使うだろうし、 ゲームなんかなら速度優先で気にしない。 なんで 15439054.2345 なんつうデカイ値になるのかわからないけど、 そんな値になる前の段階でこまめに正規化するべきだと思うけどね。
確かに気になるね. 15439054.2345 って何回転だよ!!
そういう問題かよ…
>>258 >たとえば、$80000000〜$7FFFFFFFを-π〜πにするとか
その程度の範囲しか取れないなら浮動小数点数使った方がマシ
関係ない話だが変換したらいきなり「不動小数点数」と出やがった orz
>264 ところが、 log2(15439054)≒23.88 64bit浮動小数点だと仮数部52bitで、29bitぶんくらいしか小数に割り当てられない。
そんな議論をするよりも、15439054.2345ラジアンなんて値が出てくる
>>246 のプログラムを見直した方が早いような気がする。
最初から 32bit整数の最大最小を -π〜π に 割り当てておけば足し算引き算で桁あふれを考慮しないだけで自動的にモジュラ演算になる
>>267 >そんな議論をするよりも、15439054.2345ラジアンなんて値が出てくる
>
>>246 のプログラムを見直した方が早いような気がする。
15439054.2345 は外部からいきなり入力されて来るのでは?
>268 加減算だけなら。良い方法だね。 オーバーフロー検知する処理系も有るから注意。 そういう処理系では、回避する方法も普通ある。
>271 自己主張の強い奴だな(藁 せっかくだから、精度がどんなもん出てるか比較してみた。 x = 15439054.2345 多倍精度で x - 2 * PI * floor( x / ( PI * 2 ) ) = -1.268224314194249899401256 多倍精度で atan2( sin( x ), cos( x ) )←試算の結果これが一番正解に近い = -1.268672294250273768493362 64bit float精度で x - 2 * PI * floor( x / ( PI * 2 ) ) = -1.5027243141942499 64bit float精度で atan2( sin( x ), cos( x ) ) = -1.268672293997 超越関数3つも呼んでるから速度遅いだけかと思ったら、 こんだけ精度出るなら、CPUによるけど>247の式よりいい感じ。
それでshell sortの計算量はいったいいくつなんだ?
>272 ありがとうございました。 あと調べてみたらfmod()とかremainder()とかいう関数も見つかった。 fmod(x, 2 * pi) 5.0145130137844731 (一回転ずれてるだけ) remainder(x, 2 * pi) -1.2686722933951131 (ともに倍精度) ヘッダファイルから見つけただけで詳しい仕様は分からないけど 今回の目的そのものの関数みたい。
みなさん、ラジアンの正規化の件ありがとうございました。
>>274 fmodはまさにそのものですね。おそらく内部的には
x - 2 * PI * floor( x / ( PI * 2 ) )
と似た事をやっているんだと思いますけど。
これでテストしてみます。ありがとうございました。
244 :デフォルトの名無しさん :04/07/29 23:46
カーナビにて
斜め上からの視点の地図を表示できるんだけど、
あれって2次元のノーマルな地図に何らかの処理をしてるんだよね?
その「何らか」がわかる人いたら教えて。
車に乗っててかなり気になった。
245 :デフォルトの名無しさん :04/07/29 23:48
>>244 さんかくかんすうってしってますか?
...三角関数は関係ないだろ?
画面の下の幅よりも画面の上の幅に広い距離が表示されれば良いだけなんだから
>>276 その 「何らか」 が、
>>277 の投影変換なら、割と基本なので
知っている人はたくさんいると思うが。
そうではなくて
2次元の地図データから、どうやって3次元データを推定しているか?
って質問なら答えは
もともと3次元データを持っている。
ってことで。
ごめん。わかりにくかった。
別に
>>277 が間違っていると言ってる訳じゃないです。
>>276 の質問の意味が別のところにある可能性も
考えただけです。
見てる位置(真上から、斜めから)が必要なんだからその時点で3次元だとおもうが。
>>280 そのへんは、F-ZERO式に処理することもできるけどね。
>>280 そんなことを質問しないだろ。
最近のカーナビではビルや立体交差がそれなりに
立体っぽく表示されるから、それをきいてんだと思う。
おまえら違うぞ。
>>276 は コピペで、
>>244 の質問に
>>245 が関係無いこと言ってると思うがどうよ?
ってことだな。
回転のところで三角関数は使うが、3D→2D写像では使わん。
確かに関係無いな。
>>284 2次元の地図を斜めに表示してるだけってことじゃないの?
>>1 この板の香具師はハードウェア(一般的にはCPU)の上で
物事実現してるだけなのに、さもゼロから全て考えたかのような
錯覚してる香具師が多い。おまいが考えたいことはズバリ
ハードウェアの設計に絡む事柄。よって板違い。でも数学板に
逝けという意味じゃないぞ。電子板へ逝けということ。
でもあっちはあっちで、この板とは別の数学アレルギーが
あるからな。注意しろw
また凄いのが湧いたな。 いかにも「夏ッ!」って感じのが。
2つの整数の、整数比を求めるにはどうしたらいいんでしょうか。 (たとえば800と600なら4:3という整数比を求めたいんです)
ユークリッドの互助法で 最大公約数を求めて割ってやればいいのか。
291 :
FeaturesOfTheGod ◆UdoWOLrsDM :04/09/20 20:11:10
Re:>289 ぶっちゃけ、整数m,nの整数比はm:nなんだけどね。
292 :
デフォルトの名無しさん :04/09/21 01:00:10
多倍長整数や多倍長浮動小数点数とかそれらの複素数化とか いろんな数値クラスを作って勉強しています。ちなみにC++使っています。 それらの数値クラスに対して三角関数を始めとして いろんな数学的関数を用意してあげたいと思っています。 全ての関数を全ての数値クラスに対して個別に用意するのは手間なので、 最初は計算アルゴリズム用の抽象クラスで多くをカバーしたいと思います。 パフォーマンスは落ちると思いますが 高速化については必要に応じて後から特殊化したいと思っています。 三角関数そのものについては良くある話らしく 様々なアルゴリズムの書籍で紹介されていました。 しかしそれ以外となると見付けるのが大変です。 この手の情報を分かりやすく紹介しているサイトはありませんでしょうか? あと、もし何か面白いアルゴリズムがあれば教えてください。 よろしくお願いします。
『Javaによるアルゴリズム事典』 とか。
>>292 あなたの作ったライブラリで e^(iπ) = -1 を証明してください。
296 :
デフォルトの名無しさん :04/09/21 08:57:51
>>294 それって証明じゃなくて検算じゃねーの?
四則演算を正確に行えるライブラリで pow(e,i*PI)==-1を失敗する可能性は極めて低い。 複素数対応の pow(a,b) は、exp(log(a)*b) に置き換えられる。 複素数対応のexpは、実数だけ対応したexpとsinとcosに置き換えられる。 pow(e,i*PI)は exp(log(e)*i*PI) で計算される。 log(e)は当然1でありこの計算が失敗する可能性は低い。 exp(i*PI) は実数のみ対応する関数だけを使い 実数部は exp(0)*cos(PI) 虚数部は exp(0)*sin(PI) で計算される。 exp(0)==1、cos(PI)==-1、sin(PI)==0の計算方法は 知名度が高く確立された枯れた技術のためそれを採用すれば失敗する可能性は低い。 そのためライブラリの中のどこかに分かりにくいバグが潜んでいたとしても 途中の計算は『元々バグが入りにくい関数に都合の良い値を与える』ことになるため pow(e,i*PI)==-1はそのバグに触れることなく計算が終ってしまう。 pow(e,i*PI)はとても都合の良い計算のため ライブラリの動作確認用として使ってもあまり意味がない。 しかし-1が表示されたときの充足感は貴重なので一度は計算してみることをおすすめする。
--------------- めでたく終了 ---------------
300 :
FeaturesOfTheGod ◆UdoWOLrsDM :04/09/27 08:27:43
Re:>299 何が終了した?
302 :
FeaturesOfTheGod ◆UdoWOLrsDM :04/09/30 08:40:25
Re:>301 お前に何が分かるというのか?
304 :
FeaturesOfTheGod ◆UdoWOLrsDM :04/10/01 22:35:40
Re:>303 要するに、お前は私の能力を理解できないわけだ。
>>304 このスレお前のコテで検索したけど、
基本情報レベルのことしかいってないじゃん。
>303-304 >183, >237-238 証明終了。
308 :
FeaturesOfTheGod ◆UdoWOLrsDM :04/10/02 15:06:27
Re:>307 お前日本語は分かるか?
>>308 I'm exactly a nature English speaker.
What do you have a question?
まったりいこーやー、世の中色んな人がいるって。 人に自分の正義を強要しだすと進む話も進まなくなるわな。 ちなみにこのスレの目的は? そんなに気合入れてち盛り上がるトピックではないと 思うんでゆっくり進めていけばいいと思うんですけど。
311 :
FeaturesOfTheGod ◆UdoWOLrsDM :04/10/02 19:58:41
Re:>309 I guess I'm the greatist mathematician.
>>311 No.
I assure you are certainly a better mathematican.
But you have no new ideas.
In addition you are noting but changing very easy things into
very difficult things.
So you are seemed a silly person.
>>311 Don't up to the thread.
You must write 'sage' to E-mail cell.
自作自演おつ
don't make this thread upじゃねーかなぁ
/ / ,. '´ ,. ---`,r=、 ヽ
,:' / // / i `丶、 ヽ
/ / / , ' / / l! 、ヽ ',
/ / / / ,イ / /|| ', ヽヽ !
! i l i / // /, ' l '、 ', ヽ', |
! | ! l| ! // ,ィ´∠∠',,,,,,,_', ヽ ヽ ',! |
! l !''7|!',´i`!/'//'´_,,......._ ヾ`ヽヽ l!| !
| ', !ノ''ラ∀、、 '´ ,r'''ラ""''ヽヽ、 ヾ、 リ / |
', ヽ{i {_)::::::i !_)::::::::!ヽヽ }__// !
', !ヾ、 !:::::::::} |::::::::::::} ノ、 !', ヽ !
', | | ! ゝ--' ゝ---'、 ノ l ノ ノ /
',', ',', // ,ィ´ /
',', ',丶、 r--、 /'  ̄/ {
',ヽ', `丶、 ` ´ _,.. ィ´'´ i ! ヽ
ノ ヽ | }`T;ーr '´ // /! ', '
┌/)/)/)/)/)/)/)/)/)/)l . . .l l:. l-、 . i. .i
|(/(/(/(/(/(/(/(/(/(/│. . | i:. l \ .:i
r'´ ̄ヽ. | | | .| i: .l \
/  ̄`ア
>>311 は | | | /| i: .l 入
〉  ̄二).とんでもない | | |./ .| i: |
〈! ,. -'勘違いを | | ヽ,r| i. l---', '´ ',
| \| | していたようだ
317 :
FeaturesOfTheGod ◆UdoWOLrsDM :04/10/02 20:39:13
Re:>312 If you feel my documents difficult, you are a silly person. Re:>316 お前に何が分かるというのか?
>>317 Your articles are michy-mouse(w
What can you know about us?
320 :
FeaturesOfTheGod ◆UdoWOLrsDM :04/10/02 22:15:19
Re:>319 I cannot understand what you are saying.
>>316 じゃないけど、アホなFeaturesOfTheGodのために
>>316 を解説してやると
>>309 では
>What do you have a question?
と言われているのに、
>I guess I'm the greatist mathematician.
と関係のない(questionでない)ことを言っているので
>>316 から
>
>>311 はとんでもない勘違いをしていたようだ
と言われるわけだ。わかった?
なんだ。FeaturesOfTheGodって、ただの荒らしじゃん。 アルゴリズムを期待してたのに。
> ただの荒し < 馬鹿で異常性格者
324 :
デフォルトの名無しさん :04/10/02 23:32:41
英語が下手だな。
が→も
>>320 Your English speaking skill is very poor.
I think your article is no use.
King Mathematican cannot image mathematical concepts. So he(she?) has written postings using abstract discriptions. The most important thing for learning Mathematics is to make original understandings without other person's help.
328 :
デフォルトの名無しさん :04/10/03 00:57:50
恥ずかしい英語晒すな せめて書き込む前に辞書引いて確認しろ image は名詞だし(書くなら imagine だろ。それでもまだ変だが)
imageでもいいんだけど、そういう場合には普通imagineを使う。 音の流れがいいんだろう。ついでに、he(she?)はhe/she/itと 書いてやるとアレっぽくてナイス。その後はグダグダなので書き直し。
レス書いてるうちに書かれた
>>328 残念ながらimageにはimagineの意を持つ動詞用法もある。辞書を引いて確認してね。
スレ違い
Most King's postings are directly written on books.
King ran away(w
>>1 は数学板でも嫌われている本人は自覚していない荒らしです。
非常にたちが悪いです。
>>320 Can you tell your friend about your contribution in 2ch?
Not ashamed?
336 :
FeaturesOfTheGod ◆UdoWOLrsDM :04/10/03 16:57:24
Re:>332 Merely that's a superstition.
>>336 You're wrong. They are exact.
>334 だな。 自分で立てたスレすらスレ違いの英文で荒らしたり、 程度の低い煽りにのせられてるし。 >336 お前が居ない時の方がこのスレまともに機能してるんで、 スルー出来ないなら鬱陶しいから消えてくれ。
>>338 ちょっとまて消えたら俺らの保父さんは?バブーもっと遊んでー。
まぁなんだ、英語力を誇るのは恥ずかしいな。
英語力がないのを恥じるのは分かるんだがあるのを自慢されても・・・
ガイジンさんが日本語能力を自慢しているところを想像してみなさい!
I can't quite get over the fact that Inhabitants of this board cannot make out English.
>>339 本人は英語力があるのを自慢しているつもりでも
周りから見れば度素人の糞文だからいいんだよ
七誌のほうは腐りすぎてて読む気も失せるんだがな
Enginner needs speaking English.
>>341 Why don't you retort in ENGLISH?
You seem look bad because of your soliloquy.
345 :
デフォルトの名無しさん :04/10/03 22:19:31
>>342 たった4つの単語で間違いまくってる。。。
engineer の綴間違ってるし、冠詞ないし、
というかそもそも主語は複数じゃないといかんし、
need speaking じゃなくて need to speak だし、、、
これでも英語で書き続けるのかねえ。
今のKingって何代目?
Version 3.14159
最近のKingタン、害虫に似てきて鬱
350 :
LettersOfLiberty ◆rCz1Zr6hLw :04/10/06 12:06:11
速い計算方法は、既に今持っているソフトに入っていたりして?
荒らしが自分の名を騙られたからという事で名前を変えたようです。
King ありえないよ King
うんこ食べたい
また、名前変えてみましたづら
355 :
LettersOfLiberty ◆rCz1Zr6hLw :04/10/12 16:55:58
Re:>352 また何を言い出すのか? Re:>353 お前こんなところにまで出張すんな!それにお前誰だよ? Re:>354 お前何を企んでいる?
Re:>355 そっちこそオラのスレで何をするづら!
358 :
LettersOfLiberty ◆rCz1Zr6hLw :04/10/13 12:37:23
Re:>356 これお前のスレだったのか。それじゃあ、exp,sin,cos,tan,cot,sec,cosec,lnの速い計算方法を説明してくれ。
359 :
デフォルトの名無しさん :04/10/13 21:53:41
三角関数(circular function)を定義します。。 xy平面上に於いて、始線をx軸の正方向にとり xy平面上の点Pと原点との距離をr 点Pを通る動径が始線となす角度をθとすると θの値に対して6つの関数を定義できる。すなわち: sinθ=y/r(sine:正弦) cosθ=x/r(cosine:余弦) tanθ=y/x(tangent:正接) cotθ=x/y(cotangent:余接) secθ=r/x(secant:正割) cosecθ=r/y(cosecant:余割)この6つの関数を三角関数と総称する。 y | | | .P | (動径OPのなす角θ、OP=r) | | ------------------------------x O (原点)
>>359 sin(x) = Σx^k / k! (k ∈ odd)
cos(x) = Σx^k / k! (k ∈ even)
でいいだろ。
361 :
LettersOfLiberty ◆rCz1Zr6hLw :04/10/14 16:32:20
Re:>360 Hyperbolic sine, hyperbolic cosine か。何やってんだよ?
量子コンピューターが出来たらみんな解決だね!by小柴さんw
>>362 量子アルゴリズムを考えなくちゃいけない。
別の仕組みのコンピュータで最適なアルゴリズムを考える必要があるから
一般にそう簡単に解決できない。
量子コンピュータで魅力的なのはいまのところ素因数分解やデータベース検索以外に何があるの?
shorからいったいどれだけ進んでるの?
364 :
Conscientious Irrationalist ◆ZETA.aMskA :04/11/26 20:50:15
FoG (若しくは LoL)、貴様は何を知りたいのだ?
365 :
BlackLightOfStar ◆ifsBJ/KedU :04/11/26 22:31:34
Re:>364 速いexp,log,sin,cos,tan,sqrt,atan.
367 :
Conscientious Irrationalist ◆ZETA.aMskA :04/11/26 22:36:26
>>365 君のメールアドレスを俺に教えろ。
気分がのればいくつかのアルゴリズムを送ってやる。
368 :
デフォルトの名無しさん :04/11/27 00:19:22
要素が19万個存在するデータが2つありその差分をとりたいのですが、 LCSをメモリをあまり使用せず実装する方法ご存知ありませんか? 現在だと16000ぐらいでメモリを使い果たしてしまって困ってます
1要素はどんなデータ?
最長共通部分列は英語では、 longest common subsequence と呼ばれ、頭文字をとってLCSという。
371 :
デフォルトの名無しさん :04/11/27 22:21:10
char だったらその程度で破綻しないと思うが
372 :
368 :04/11/28 01:55:53
要素はですね、 1ページ20kb程度のメモリダンプのログがあって 最長で19万ステップ分のダンプログの比較とかをしたいのですが、 比較するときの良いアルゴリズムを知らないせいで16000ぐらいで、 メモリを512MBも消費してしまうため、何か良い手法を探しています。
>>372 ファイルに書き出せばよい、という問題でもないのですよね。
もうちょっと具体的に問題設定が欲しいかも。
ステップとページの関係がよくわからないです。
ブロック単位での処理でいいのならハッシュ取っておくとか。
近似アルゴリズムでいい? ページのハッシュ列でLCSを計算して終了。
CRC
378 :
デフォルトの名無しさん :04/11/28 10:10:53
「珠玉のプログラミング」に出てきそうなネタだね 要素数が違う場合もあるんだよな? 差分を取るって事は、大部分は同じで極一部だけが違ってて、その違いを知りたいって事だよな? orz‥頭のいい人ヨロ
両方ソートしてからマージっぽく比較していけば? メモリを消費してしまうというのがよく分からんが。
わからんのでググった
ttp://docs.hp.com/ja/B2355-60104-01/bdiff.1.html >bdiff ― ラージファイルのdiff
>bdiff は2つのファイルを比べて、 diff ( diff(1) 参照)によって生成される出力と同じ出力を作成し、
>ファイルを同一にするための変更を指定します。 bdiff は diff には大きすぎるファイルを処理するために
>設計されていますが、任意の長さのファイルに使用できます。
>
>bdiff はファイルを次のように処理します。
>
>両方のファイルの先頭に共通な行を無視します。
>
>指定した各ファイルの残りを n-line セグメントに分割し、次に 対応するセグメントに対して diff を実行します。
> n のデフォルト値は3500です。
(略)
>ただし、どこでファイルが分割されるかに応じて、 bdiff が必要最小限の
>ファイル相違を探し出せる場合と探し出せない場合があります。
やっぱ駄目かもw
>372 すべてのファイルで一致する最長のバイナリ列を求めればいいんでしょ? 1.1件目と2件目を比較して、一致する部分の配列を新たに作成。 >[バイト数, 抽出したバッファ] * 一致した個所の個数だけ 2.比較結果の配列と3件目を比較して、配列を再構成。 >この時、3件目と一致しない要素は削除出来るので計算量は減っていく 3.以後4件目、5件目・・・と繰り返し。 LZ法みたいに「位置と長さ」だけ残しといて、 データの比較をする時は1件目とn件目、とかでもいいけど。
382 :
tokoro :04/11/28 19:48:21
二分検索より速い検索アルゴリズムってあるのですか?
計算量の話ですか?
385 :
tokoro :04/11/28 20:25:13
条件は、検索される対称がソートされているとした場合です。 例えば、1,2,3,4,5,6,7,8,9,10,.......の中で、ある数字を検索する、といったものです。
386 :
tokoro :04/11/28 20:28:36
計算量というのは、よくわからないですが、この場合に利用できる 私が知っている検索方法として線形検索と二分検索があり、検索対象がソートされているという条件のものでは 二分検索の方が一般的に速く検索できる、.... この意味での『速い』です。
4を探したければ、4つめを見ればいい。
389 :
tokoro :04/11/28 20:37:15
>>387 すいません、検索対象がところどころ飛んでいたら..としてみて下さい。
例えば、3,100,2000,1555555,364256787, ....
の中から 1555555 を探す場合です。
>>389 一般的には二分法を元にした方が速いけど、データの量や質、構造によっては
ハッシュ値を元に探したほうが速いかもしれないし、
二分法で探したほうが速いかもしれないし、
素直に先頭から探していったほうが速いかもしれない。
複数の探査方法を組み合わせることもある。
ただ二分探索と線形探索以外の探索アルゴリズム知りたいだけなんじゃ
392 :
tokoro :04/11/28 20:57:02
>>391 二分探索と線形探索以外 でかつそれより速いものを知りたいのです。
データの偏り方によっては(ry
対象が飛んでても関係ないよ メモリを馬鹿食いするだけ
396 :
tokoro :04/11/28 21:41:32
>>394 >>387 の方法では、1555555が何番目にあるかわからないので、
それが何番目にあるのかを調べる方法が知りたいわけです。
397 :
デフォルトの名無しさん :04/11/28 22:27:42
90 という要素を x という配列から探しているとき 検索途中で x[50] = 10, x[100] = 110 と分かったとき 次は、真中の x[75] でなく、x[50] と x[100] を 4:1 に分ける x[90] を調べるとかいう方法をどっかで見た気がします。 一般には遅くなるけどソート列のデータが比較的均等な間隔で 並んでいる場合はちょっと速いとか。。。。 でも自信ありません。うろ覚えですみません。
398 :
デフォルトの名無しさん :04/11/28 22:32:58
基数ソート書いてもらえませんか?
アルゴリズム事典読んどけ。
>一般には遅くなるけどソート列のデータが比較的均等な間隔で >並んでいる場合はちょっと速いとか。。。。 というかそういう場合にしか使えないだろうと。。。
>>397 内挿探索だな。二分探索よりも計算量の上でも速いらしい。
>>396 table[n] = -1;
table[3] = 0;
table[100] = 1;
table[2000] = 2;
table[1555555] = 3;
:
1555555は3番ですね
>402 ワロタ(藁 まぁでもそういう話だよな。 連想配列使うにしても、内部の実装は良くて二分探査、 下手したら線形探査だろうし。 データの偏りとそれに対するアルゴリズムの向き不向きくらいは考えられないと、 プログラマとして生きてる価値無いと思われ。
連想配列ならハッシュだろ
うーん、結構多くの実装は赤黒木じゃない?
VC++とかlibstdc++とか
ハッシュは振る舞いが安定的じゃないから。
amortizeしないとinsertの計算量がO(n)になっちゃうし。
>>403 君も結構やばいかも(w
>>405 perl は連想配列のことをハッシュって呼ぶくらいだし、ハッシュでの実装じゃないの?
あと、C++ の STL も、非標準だけど、hash_map ってのがあるよ。
ハッシュもバランス探索木も両方良く使われるよ。 > ハッシュは振る舞いが安定的じゃないから。 これは実装かハッシュ関数が悪い。 > amortizeしないとinsertの計算量がO(n)になっちゃうし。 そんなこたあない。(というか最悪と平均とamortizeの違いを理解してないんだろう)
408 :
デフォルトの名無しさん :04/12/10 16:51:35
ある個数の整数列が存在するとします。例えば、2から17までの16個の整数があるとし、 このとき、この整数列を2グループに分け、一方のグループに属する数の平方根の和と もう一方のグループに属する数の平方根の和との間の差が最も小さくなるような、グループ分けの 方法を発見する。このようなことを行なうにはどうしたら良いですかねえ。
>>408 ナップサック問題 or ナップザック問題でクグる。
>>408 グループの数の和が小さい方のグループに元の数列から降順に追加していく。
和は平方根のでもどちらでもいいと思う。
>>408 平方根の和が平方根の合計の半分に近い選び方を適当に選べばいいんじゃない?
>>408 の16個の例だと、全検索でも32768パターンだな。
>>410 残念だがこれは0-1 knapsackなので、そういう
greedyなやり方では最適解を見逃してしまうよ。
>>412 問題のサイズが固定だから、そういうアプローチも確かに一つの見識だな。
>>412 ん?もっとパターンあるのでは?
8個と8個に分けるとは限らないだろ。
2グループとしか言ってないんだから。
ここまでのレスでは数列が「整数」列という条件はまだ誰も使ってないな。 実はこの条件を使えば魔法のように解けるんだよ。 平方根ってのにも気づいてるか?これ幾何的解法の存在の隠喩なのさ。 まあ、オマエらのような馬鹿にはこの程度のヒントじゃどうにもならんだろうが。 と、まっっったく何の見通しもなく言って orz 休日の釣りを楽しむテスト
416 :
デフォルトの名無しさん :04/12/11 16:18:44
>>408 差が最も小さくならないと死んでしまうこたあないだろう。
文句言うにもそれ以上の計算時間掛けなきゃいけないから
俺は忙しいんだと言って適当に打ち切れよ。
>>414 > 2グループとしか言ってないんだから。
単純な数え上げもできないやつは黙ってるように。
32767通りだと思います。
>>417 > 15bitの整数は32768個では?
16bit目を0か1に固定してるから、00...0か11...1かのどっちかは含めることができないんだよ。
>>416 > 差が最も小さくならないと死んでしまうこたあないだろう。
ワラ
応用編:
・全部順番に並んでないと死んでしまうこたあないだろう。
・誤差ε内に収まらないと死んでしまうこたあないだろう。
>421 その程度出来ないとクビは切られそうだがな。
423 :
デフォルトの名無しさん :04/12/12 16:44:13
・この程度のプログラムも書けないと死んでしまうこたあないだろう。
424 :
デフォルトの名無しさん :04/12/12 20:00:25
100!の100!乗-1は素数です。
AMDのPDFにあったサンプルを見よう見まねで 平方根を求めるプログラムを書きました。見てください。 #include <stdio.h> #include <mm3dnow.h> // vc toolkit2003 float mysqrt(float r) { __m64 a, b, c, d; a = _m_from_float(r); b = a; c = _m_pfrsqrt(b); d = c; c = _m_pfmul(c, c); b = _m_punpckldq(b, b); c = _m_pfrsqit1(c, b); c = _m_pfrcpit2(c, d); b = _m_pfmul(b, c); _m_femms(); r = _m_to_float(b); return r; } int main(void) { for(float i = 2; i < 10; i++) printf("√%f = %f\n", i, mysqrt(i)); return 0; }
ねたですか?
露出狂なんだろう
428 :
デフォルトの名無しさん :04/12/13 13:59:51
4×4のフリップゲーム ・白と黒。どれか一つを選ぶと、それとその周りの色が逆転する。 例 0 1 2 3(y) +--+--+--+--+ 0 |●|○|●|○| +--+--+--+--+ 1 |○|●|●|●| +--+--+--+--+ 2 |●|●|○|●| +--+--+--+--+ 3 |○|○|○|●| (x)+--+--+--+--+ (x,y)=(2,1)を選ぶと、 0 1 2 3(y) +--+--+--+--+ 0 |●|○|●|○| +--+--+--+--+ 1 |○|○|●|●| +--+--+--+--+ 2 |○|○|●|●| +--+--+--+--+ 3 |○|●|○|●| (x)+--+--+--+--+ となります。 初期配置はランダム。 すべてを白、または黒にするのに必要な最小回数を求める。(求まらない時もある)
429 :
428 :04/12/13 14:00:22
総当たりでいくしかないという結論に至ったのですが、どれだけの数があるのか 検討がつきません。人に聞いたところ2の16乗あると言われたのですが もっとあるような・・・。 何かアイデアや質問とかあったらお願いします。
>430 ありがとうございました!! すごい感動。
済みません一部間違えました。 >例えば文字数が1000ならば、2^1000=1606938044258990275541962092341162602522202993782792835301376 ↓↓ >例えば文字数が200ならば2^200=1606938044258990275541962092341162602522202993782792835301376 でした。
434 :
デフォルトの名無しさん :04/12/13 23:06:03
>>432 片方の文字列を一文字ずつ回転させて比較し最長の一致文字数を探すからN^2かN^3かな。
王(長島)
>>434 >片方の文字列を一文字ずつ回転させて比較し最長の一致文字数を探すから
というのは具体的にはどのようなことでしょうか?
私は次のようなものだと思っていました。
比較元がABCDEの5文字だとすると、
00001→A
00010→B
00011→AB
00100→C
...
11101→ACDE
11110→BCDE
11111→ABCDE
といったような文字列を作成して比較するのだとばっかり...
437 :
デフォルトの名無しさん :04/12/15 00:28:43
>>432 しらみ潰し法の話をしてる?それなら君の考えで合ってる。
2^N回ループを繰り返さなければならない。当然終わらないだろう。
計算量が指数時間かかるアルゴリズムは、一般的に終わらないアルゴリズム
(N=100超えると人間の生きている内には終わらない)と言われているので
もっとよいアルゴリズムを考える必要がある。
そのアルゴリズムとして、動的計画法としてそのページでは書いてあるようだ。
指摘する場所検討違いならスマン。
訂正 ×そのアルゴリズムとして、動的計画法として ○そのアルゴリズムとして、動的計画法が
>>437 あ、やっぱり私の理解は合ってましたか。
漸くスッキリしました。
その後、動的計画法についてもいろいろ調べたので、他の方法は理解していたのですが、
このしらみつぶし法だけが非効率過ぎて納得できていませんでした。
これで頭を悩ませなくて済みそうです。
どうもありがとうございました。
440 :
デフォルトの名無しさん :04/12/15 00:52:33
>>439 一応言っておくと,これはLCSといってDPの中でも有名な問題.
大学のC言語演習でわからない問題があったのでおしえてくれませんか? <問題> 文字列s1、s2を引数で受け取り、s1に文字列s2が含まれているかどうかを調べる関数searchを作成しなさい。 実行結果は、含まれているならば1を、含まれていないならば0をそれぞれ返すようにしなさい。 文字列検索関数strcmpなどは使用しないこと。 あと、string.hのインクルードも禁止らしいです。
>>441 そうか。それはよい問題を出してもらったね。
でも教えてあげない。
>>441 てか、宿題スレで答えてもらってたじゃん
わからなければ質問すればいいってのは見事に能無し養成教育の賜物だなあ。 それにしてもこれしきも自分でやろうとしない奴が大学生とは聞いてあきれる。 どこの大学よ。
>>441 どッかで答えた記憶があるぞ
たしか"abc"が入っているかどうかってやつ
446 :
デフォルトの名無しさん :04/12/15 22:19:37
447 :
デフォルトの名無しさん :04/12/16 00:14:13
>>441 system関数でgrepコマンドを呼び出して、s1, s2をコマンドライン引数に当てる。
strcmp関数は使用してないし、string.hのインクルードもしてない。
これで君のレポートは0点確実だ。
マルチに仕立て上げて宿題答えさせないためのコピペ厨だろ、どうせ。
>>448 こんな問題を自力で解けないのに単位もらってちゃいくらなんでもまずいだろ。
450 :
デフォルトの名無しさん :04/12/16 01:24:57
>>441 問題の答えです。
#include <stdlib.h>
int search(char *s1, char *s2)
{
char *str;
int retval;
str = malloc(sizeof(s1) + sizeof(s2) + 20);
sprintf(str, "echo %s | grep -e %s", s1, s2);
printf("%s\n", s3);
retval = system(s3);
free(s3);
if (retval != 0)
return 1;
else
return 0;
}
451 :
450 :04/12/16 01:27:44
おっとミスった。
#include <stdlib.h>
int search(char *s1, char *s2)
{
char *str;
int retval;
str = malloc(sizeof(s1) + sizeof(s2) + 20);
sprintf(str, "echo %s | grep -e %s", s1, s2);
retval = system(str);
free(str);
if (retval != 0)
return 1;
else
return 0;
}
これで
>>441 のレポートも満点だ。(w
正規表現でマッチしてしまうのと、標準出力に出てくるので 仕様に反しており0点です
grep -sだなって…板違いやんか!
456 :
450 :04/12/16 15:44:26
fgrep -s だったらええんちゃうか?
正規表現は使えんし、 /dev/null へリダイレクトしてくれるから
>>454 の課題はクリアしてるけど。(w
457 :
450 :04/12/16 15:46:45
まあ、
>>441 は grep のソースコードでもじっくり読んで勉強せぇや。
458 :
450 :04/12/16 15:52:45
>>457 じゃあ450は441のためにFAをさくっと解説してやってくれや。
その程度の問題が解らない大学生がバカなのか、 車輪の再発明をさせるような問題出しちゃう 教授だか講師だかがバカなのかは知らんが、 スレタイ読めない>441がメクラだってーのは理解した。
おまえら、それ以前に sizeof(s1) とかって気にならんのか? それでええのんか?
450も厨なのは自明なのでどうでもいい。
すげえ >>450得意気
車輪は大いに再発明されるべきだと思っちゃうな。 漸次良い車輪が生き残るだろうし。
再発明だったらいいけれど、再発見は必要無し。
教えてないのにBM法考えついて実装する学生がいたら 先生やめたくなるだろうな
それでも車輪の歳発明なんだけどな。
>>461 は初心者が次々新発見しないと講師が馬鹿だと思うらしい馬鹿だが。
作ってみるのはいいんじゃないの? うまく回すためにはいろんなことを考えないといけないんだし。
BM法なんて大学まで来て教わるまでもなくどっかで見て知ってるだろ。 数式がいるわけでもないから小学生でも実装できる。
471 :
デフォルトの名無しさん :04/12/18 00:15:12
スレタイ見てうきうきして来たらずいぶんレベルが低くなってるじゃぁないか. 1はどこいった?
>>472 マジスカ?
アマゾンでは見つけられなかったよ
> 本物のプログラマはいかにして問題を解くか FORTRANで
Pascalでなく
>>10 見てマジ!?と思ったけど、
>>12 見て笑った。
やっぱ2chは2chだな。
481 :
デフォルトの名無しさん :04/12/23 08:35:41
Knuthは面白いけど、必読とは思いません。 いまやバイブルでもないし。 よいこはセジかコルメン他にしておきましょう。
乙
486 :
デフォルトの名無しさん :05/01/01 18:29:09
質問です。重み付きの有向グラフにおいて、最長の一筆書きを得る アルゴリズムをご存知の方がいらっしゃれば、ご教示ください。よろしく お願い致します。
最長の一筆書き?
東大の鉄道研究会に聞けや
よくわからないけど一筆書きだったらすべての辺を通るんじゃないの?
全て通るのは辺じゃなくて節だろ
491 :
486 ◆ALxfxYDG9M :05/01/02 01:16:47
申し訳ありません、「最長の一筆書き」では言葉がおかしいですね。 「重み付きの有向グラフにおいて、《すべての辺を通る必要はなく、 同じ辺は一度しか通ることができない》という前提を満たす経路のうち、 重みの和が最大となるものを求める」という問題です。
プログラムで全パターン試行錯誤してください。
そうですか…お手数をおかけしました。ありがとうございました。
>>491 一筆書きじゃなくてハミルトン閉路といいます。
ハミルトン閉路とか巡回セールスマンでググれば出てくると思います。
496 :
デフォルトの名無しさん :05/01/02 08:21:32
499 :
デフォルトの名無しさん :05/01/03 01:38:30
ドラゴンブックとかコンパイラの本読んでたんですが、 DAGってどうやって作るんでしょうか。 「閉路のない有行グラフ」 といわれてもさっぱりです。 持ってるどの本も概念的な説明だけで実装については 詳しくされてませんでした。 もうちょっと簡単なサンプルみたいなのが欲しいです。 例えば d = b + c; e = b + c; a = e + d; とかの式で b + cが共有されるのはわかるのですが、 プログラムとして表現しようとするとどうなるのかが想像つきません。 DAGの作成と、作成したDAGからコードに出力する簡単なサンプルや アルゴリズムをご存知の方がいらっしゃれば、ご教示ください。
アルゴリズムは本に出てるよな? 要するに、構文木を作る時に一手間掛けるって事だよ 漏れは作った事無いけどw
501 :
デフォルトの名無しさん :05/01/03 19:00:58
d = b + c で d ↓ + b c まずこうなるよな ここまでは問題ないとする んで、e = b + cについて + b c の部分が合同だから d, e ↓ + b c と共有することになる 最後のa = e + dで a ↓ d, e ↓ + b c になるんじゃないかなあ。 ↓矢印が依存関係。 これがDAGか自信ないけど。
502 :
デフォルトの名無しさん :05/01/03 19:04:47
あ、間違えた a ↓ + d e と d, e ↓ + b c の2つになる。 aからぶら下がるdとeは同じ木を共有するということになるな。 ・・・おれもわからん。
503 :
デフォルトの名無しさん :05/01/03 19:08:21
で、この木からコードを生成となると 木を左から辿っていきながらやるんだろう まず + b c から t1 = b + c が得られると思う t1というのは一時記憶とか、そんなやつ その後は d = t1 e = t1 となるな 最後に t2 = d + e a = t2 となる まとめると t1 = b + c d = t1 e = t1 t2 = d + e a = t2 こんなもんかな
504 :
デフォルトの名無しさん :05/01/03 19:12:25
t1 = b + c を生成した段階で、 この式は共有されてるわけだから、生成フラグみたいなのを用意して 二重に出力しない工夫をする必要がある
>>499 >「閉路のない有行グラフ」
>といわれてもさっぱりです。
下手に "DAG" などとという数学的な言い回しに
囚われるから、抜け出せなくなる。
所詮プログラミングはエンジニアリングなのだから、
その「目的」と「効用」だけに注目すればよい。
c = a[i+4] + b[i+4] という、よくある配列の例 これはi+4が共有できるのがわかる 配列参照をrefと定義すると c ↓ + a b a, b ↓ ref ↓ + i 4 出力コード t1 = i + 4 t2 = a ref t1 t3 = b ref t1 c = t2 + t3 副作用とか考えると難しいかもな
巡回セールスマンのオーダーっていくつなんですか? O(n!)? O(n^n)?
総当りだといくつですか?
それぐらい計算せえよ。高校生でも計算できるはず。
総当たりってのは 全部の経路の長さを計算して一番短いものをみつけるわけで 全部の経路数はn! でもさ じゃ全部の経路をどう探索するのか? データ構造をどうするのか?
>>511 ノード数が n なら、辺の数もたかだか n(n-1)
必要メモリ量も O(n^2)
514 :
デフォルトの名無しさん :05/01/09 13:33:42
質問です。 参加者数が変動する大会のトーナメント表を作りたいと考えています。 参加者数が変動するため、シードが一定数出るのですが、できるだけバラバラにシードを割り付けたいと考えています。 例えば以下のように割り付けたいのです。 12345678(試合目) 10000000:15人参加の場合 10001000:14人参加の場合 10101000:13人参加の場合 10101010:12人参加の場合 11101010:11人参加の場合 11101110:10人参加の場合 11111110: 9人参加の場合 (1がシードの試合) この場合はどのようなアルゴリズムを用いれば良いのでしょうか? (こちらは計算アルゴリズムに関してのスレッドですが、他に適当なスレッドが見当たりませんでしたのでこちらに書き込ませていただきました。 スレッド違いの場合は誘導願います。)
言ってる意味がわかんね
見たまんまじゃないの? シード一人目が1、2人目が5‥になるようなプログラムを書くだけ
>>514 //参加者n人の時の(一回戦の)試合数を求める。
int siaisu(int n){
int s=1;
while(s*2<n) s *= 2;
return s;
}
//n回の試合に seed人を配置する。
void haichi(int n, int seed, char *siai){
int ss, nn;
if(seed <= 0) return;
if(n == 1) {*siai = '1'; return;}
ss = seed/2; nn = (n+1)/2;
haichi(nn, seed-ss, siai);
haichi(n-nn, ss, siai+nn);
return;
}
続く
main(){ int game, seed, sanka, i; char siai[99]; //(テスト)参加者1人〜20人の場合を計算する。 for(sanka=1; sanka<=20; sanka++){ game=siaisu(sanka); //試合数 seed=game * 2 - sanka; //seed人数 for(i=0; i<game; i++) siai[i]='0'; //配置テーブル初期化 siai[i]='\0'; haichi(game, seed, siai); //配置を求める printf("%2d,%2d,%2d, %s\n", sanka, game, seed, siai); //結果表示 } }
実行結果。左から、参加者数、(一回戦の)試合数、seed数、配置。 1, 1, 1, 1 2, 1, 0, 0 3, 2, 1, 10 4, 2, 0, 00 5, 4, 3, 1110 6, 4, 2, 1010 7, 4, 1, 1000 8, 4, 0, 0000 9, 8, 7, 11111110 10, 8, 6, 11101110 11, 8, 5, 11101010 12, 8, 4, 10101010 13, 8, 3, 10101000 14, 8, 2, 10001000 15, 8, 1, 10000000 16, 8, 0, 00000000 17,16,15, 1111111111111110 18,16,14, 1111111011111110 19,16,13, 1111111011101110 20,16,12, 1110111011101110
自明な試合
>>514 微妙に仕様を読み間違った。コメントが変なところあるけど、
プログラムはこのままで大丈夫だと思う。
>>520 決勝戦が不戦勝ということでお許しを。
シード選手の場所、BYEの場所、試合順序は各競技団体のルールで定義されていたりする。 その辺りは大丈夫なんだろうか。
524 :
デフォルトの名無しさん :05/01/16 21:29:14
六角形の敷き詰められたマップの距離を計算したいんですが 何かいい参考サイトはありますか?
ランダムに並んでいる要素があるときに、昇順で最長の組み合わせを求めたいと思っているのですが、いいアイデアが浮かびません。 例えば 1 8 9 10 3 4 2 5 6 という要素がある場合には 1 8 9 10 1 3 4 5 6 1 2 5 6 という組み合わせが考えられますが、この中の 1 3 4 5 6 を容易に求める方法はないでしょうか? 連続する部分を1ブロックとして全ての組み合わせを求める方法は思いついたのですが、これだと要素数が100とかの場合にはものすごく遅くなってしまいます。 いいアルゴリズムをご存知の方は教えてください。
>>525 ナップサック問題に帰着。
NP完全です。
>>526 そうなのですか...
諦めることにします。
どうもありがとうございました。
あっさり騙される方もどうかしてるけどな。もともとやる気ナシと見た。
計算量についてなら、O(n^2)。
532 :
デフォルトの名無しさん :05/01/17 11:31:04
O(n!) かと思った・・・
で、いいアルゴリズムはないの?
O(n^2)のアルゴリズム。
長さだけなら下のプログラムで簡単に見つけれます。 #define N 100 int data[N]; int length[N+1]; int search(void) { int i, len, longest = 0; for (i = N-1; i >= 0; i--) { for (len = longest; len > 0 && length[len] <= data[i]; len--) ; if (++len > longest) { longest = len; length[len] = data[i]; } else if (length[len] < data[i]) length[len] = data[i]; } return longest; }
ヒントとしては、先頭からi番目までの要素を見た場合の最長系列は i-1番目までの結果を元に求まる。 もうちょっというと、その最長系列はi番目の要素a_iを含むものであるか 含まないものであるかのどちらかである(当たり前)。 含むならば、i-1番目までにおいてa_i未満のものしか持たない系列で最長のものに a_iを追加したものである。 含まない場合の最長系列は、i-1番目までの最長系列である。 つまりi番目の要素をみたとき、最長系列の候補はi個しかない。 だから計算量としては 1+2+3+...+n = n(n-1)/2 → O(n^2)。
マージソート風の分割統治で O(n・log n) になるのかな。
また適当かよ。 ところで「適当」って2通りの解釈があるよな。 文脈でも判断できない場合がある。 ここが日本語解析の困難な所でもある。
>>536 の補足と改善。
計算量は
>>536 で述べた長さiの最長系列候補をi個つくるための計算量の他に
a_iを含む最長系列を作る計算量があって、共にO(n^2)だ。
ところが考えてみると、a_iを含まない最長系列候補を毎回律儀に延長せずともよく、
そうすると計算が必要なのは実は後者の処理だけだ。
後者の処理ではi個の候補の中から最大値 < a_iで長さ最長のものを選ぶわけだが、
最長系列候補を常にソートした状態で持っておけばこの計算量を減らせる。
具体的には、最長系列候補を単にリストや配列で持つのではなしに
系列長でソートして持ち、さらにその中で最大値でソートするようにする。
これにRed-Blackツリーを使えば一回のオーダーはほぼO(log n)にできる。
こうして計算量はO(n log n)となる。
問題が、np完全かそうじゃないかを判断できるのは経験? それとも何か判断基準があるもんなの?
>>541 ある証明済みのNP完全問題に多項式時間で帰着するという証明をすればよい。
あるいはもっと直接的な証明
>>541 計算論とかTuringMachineとか勉強し直せ。
531って、計算量とかオーダーの記号とかはきちんと使ってるのに、 アルゴリズムの入門のコースは取ったことないの? やったことがあれば一目瞭然のすげー有名な問題なんだが。 宿題とか試験にも良く出るよね、これ。
546 :
低大生 :05/01/18 03:41:22
誰か中学生でも理解できそうな割り算のアルゴリズム教えてください。
547 :
デフォルトの名無しさん :05/01/18 05:36:36
>546 引き算を繰り返す
>>545 > アルゴリズムの入門のコースは取ったことないの?
ないんですよ。この問題も恥ずかしながら未見です。
よろしければ適当なw 資料(英文可、web上のURL希望)のポインタを頂けまいか。
ついでに540の方針で実装した例を貼っておきます。至らぬ点があれば指摘願いたい。
なお系列長が同じものでは最大値が最小のもののみを持てばいいことに気付いたので
そのように修正しています。
Ruby 1.8.2とRuby/RBTree(
http://www.geocities.co.jp/SiliconValley-PaloAlto/3388/rbtree/README.html )を使用。
require 'rbtree'
class Sequence
def initialize(prev, max)
@prev = prev
@len = prev ? prev.len + 1 : 1
@max = max
end
attr_reader :prev, :len, :max
def result()
r = []
seq = self
while seq
r << seq.max
seq = seq.prev
end
r.reverse
end
end
def longest_seq_with(sequences, x) sequences.reverse_each { |len,seq| return Sequence.new(seq,x) if seq.max < x } Sequence.new(nil, x) end def find_longest(ary) sequences = RBTree.new # lenをキーとするRBTree (Integer->Sequence) ary.each { |x| seq = longest_seq_with(sequences, x) s = sequences[seq.len] sequences[seq.len] = seq unless s and s.max <= seq.max } sequences.last[1].result end
系列長が同じものでは最大値が最小のもののみを持てばいい点を押し進めると、 RBTreeの必要はまったくなくなっていることに気付きました。 class Sequence def initialize(prev, max) @prev = prev @max = max end attr_reader :prev, :max def result() # 省略 end end def find_longest(ary) sequences = Array.new(ary.length+1) maxlen = 0 ary.each { |x| j = maxlen j -= 1 while j > 0 and sequences[j] and sequences[j].max >= x len = j+1 maxlen = len if maxlen < len s = sequences[len] next if s and s.max < x sequences[len] = Sequence.new(sequences[j], x) } sequences[maxlen].result end
数学系の人? 食えなくなったら是非プログラマに 物足りないかもしれないけどw
552 :
デフォルトの名無しさん :05/01/18 16:31:54
>>525 再帰を使え。
あと、最長の組み合わせが見つからなくとも死にはしない。
え、俺は氏ねって言うけど?
漏れも初見だけどこれってO(n)じゃない? 一番長いのと二番目に長いリストのペアを返す関数。 (define (search l) (if (null? l) '(() . ()) (let ((a (search (cdr l)))) (cond ((null? (car a)) (cons (list (car l)) '())) ((< (car l) (car (car a))) (cons (cons (car l) (car a)) (car a))) ((null? (cdr a)) a) ((< (car l) (car (cdr a))) (cons (cons (car l) (cdr a)) (cdr a))) ((null? (cdr (cdr a))) a) ((< (car l) (cadr (cdr a))) (cons (car a) (cons (car l) (cdr (cdr a))))) (else a)))))
ごめん上の間違ってた。 最悪の場合(すでに昇順の場合) O(2^n)になりそうだけど、こんなのとか。 (define (search n l) (cond ((null? l) (cons 0 '())) ((< (car l) n) (search n (cdr l))) (else (let ((a (search (car l) (cdr l))) (b (search n (cdr l)))) (if (>= (car a) (car b)) (cons (+ (car a) 1) (cons (car l) (cdr a))) b)))))
>>555 やっぱこういうアルゴリズムはLISP系だなあ。
とか思って試してみたけど
>(search 0 '(1 8 9 10 3 4 2 5 6))
=>(5 1 3 4 5 6)
頭の5は何?
あ、五個ってことか。 さすがw
今度は大丈夫だと思います。updateは可読性のため末尾再帰にしてません。 それぞれの長さのリストを返します。たぶん 535と同じアルゴリズムだと思います。 550 は計算量 O(nlogn)なんでしょうか? (define (update a ll) (cond ((null? (cadr ll)) (if (> a (car (car ll))) (cons (cons a '()) '(())) ll)) ((<= a (car (cadr ll))) (cons (cons a (cadr ll)) (cdr ll))) (else (cons (car ll) (update a (cdr ll)))))) (define (search6 l) (cond ((null? l) '(())) ((null? (cdr l)) (cons (cons (car l) '()) '(()))) (else (let ((ll (search6 (cdr l)))) (let ((r (update (car l) (cons '() ll)))) (if (null? (car r)) (cdr r) r))))))
>>558 > 550 は計算量 O(nlogn)なんでしょうか?
550はn^2でしょ。あなたのもn^2。
updateの中のifが要らなくて、それにともなって search6の二番目の cond節も要らないです。
>>559 O(nlogn)にするのは無理なんですかね?
分割統治法も使えそうにないし。
1. リストに最初から順番に番号を付けるのにO(n) 2. 値1>値2 && 番号1>番号2 でソートするのにO(nlogn) 3. 値1>値2 && 番号1>番号2 で連続になっている(安定なソートなら値の比較だけでいい?)最長の領域を捜すのにO(n) でO(nlogn)でできるのかな?
ocamlで書いたらもっとすっきりしちゃった。見たい?
別に。 そろそろ別の話題よろ。
話題が無いから引っ張ってるのに。ひどいわ。
じゃ、ハノイの塔を解くアルゴリズムを1tapeTMで定義してよー
Cプリプロセッサで解くやつならあるけどなー
>>565 結構でかくなった
レスにすると7,8レスくらい
出題者として責任もって合ってるかどうか確認しろよ
emacsじゃないの?
くだらん。ばかじゃねーの。
>>572 なんでよー
夢がないこといわないでよー にゃんにゃん
ごめん。いいすぎた。
575 :
デフォルトの名無しさん :05/01/20 04:24:33
ローパスフィルターのアルゴリズムについて教えてください
フーリエ変換して 周波数成分の中から 高周波領域部分の係数をカットして 逆フーリエ変換する
RとCを適当に入れた回路を作って、微分方程式を解く
振幅特性と位相特性の離散的なリストを用意して、そいつを逆フーリエ変換したやつで畳み込みをかける。
>>575 バターワースフィルタ とか チェビシェフフィルタ とか 楕円フィルタ でぐぐれ。
581 :
デフォルトの名無しさん :05/01/21 19:53:09
0からある数値(例として3とします)までの間の組合せを列挙する アルゴリズムでいいのありましたら教えてください。。 (キーワードだけでも。。) 例の場合: 0 1 2 3 01 02 03 12 13 23 012 013 023 123
582 :
デフォルトの名無しさん :05/01/21 20:00:05
>581 三進数、繰り上がり、ビット演算、ぉっぱぉ
>>581 n個の数字があるから x を1〜(2^n-2)までループさせる。
その x においてビット0が1ならば'0'、ビット1が1ならば'1'・・・ビット(n-1)が1ならば'n-1'を
表示する。
で、どうですかね?
>>582 >>583 ありがとうございます。1から順にn進数に変換して・・・ってやろうと
してたんですけど、ビット演算でやったほうがスマートそうですね。
どうもです。
カバンに同じ品物を複数詰めることができないように実装すればいいでしょう?
>>585 ナップザック問題はNP完全だから、要素が多くなると、厳密解は求まらないよ。
近似解を求めるのに、遺伝的アルゴリズムでも使えば?
>>586 いや厳密解求めるならそれでもいいかもしれないけど、
動的計画法の中に埋め込む制約としては厳しいんじゃないの?
>>587 NP問題だって厳密解は求まるだろ。計算量がすごくなるというだけで。
>>589 NP問題というか、さらにNP完全だし。
厳密解は、理論的には求まるが、計算時間が現実的ではないから、彼は計算途中で
計算機を止めてしまうだろうという推定が入っている。
>>588 > 動的計画法の中に埋め込む制約としては厳しいんじゃないの?
厳しいも何も、NP完全として知られるのは0-1ナップザック問題と言って正に
>>586 の言っている形なのだが。
計算途中で息絶えてしまうだろう
NP完全ではあるものの、実際には品物1万個でも0.1秒以内で解けてたりする。
594 :
デフォルトの名無しさん :05/01/29 18:07:53
行列のexpはどうやって計算しますか?
>>594 1. 普通に Σ(1/n!)A^n を逐次計算
2. 対角化 → 固有値の exp を使って求める
awe
597 :
デフォルトの名無しさん :05/02/02 14:48:58
C言語での除法のアルゴリズムを教えてください
>>597 除法という演算の定義を与えてもらわないと
600 :
597 :05/02/02 15:52:44
>>598 商と余りを導出するものです。
整数x,yについて、y=ax+b (a,bは非負整数で、0≦b<|x|)
ときのaを商、bを余りとして、(a,b)を導出する演算をx/y
(除法)とします。
これでお願いします。
>>600 正直
>>599 で正解で終わりと言いたいところだが、それを聞きたいわけ
じゃないだろう?エスパーしてみるが…
1. 「C言語で割り算をする場合、中の人はどんな処理をしているのか?」
⇒コンパイラを通した後の機械語によってCPUに依存。
2. 「C言語で'/'を使わずに割り算を実装するにはどうしたらいいのか?」
⇒解1:定義通りに引き算を繰り返す。(比較的小さな数の場合)
⇒解2:割る数の逆数をニュートン法で求めて乗算を行う。(数万桁以上
など、大きな数の場合)
>>600 これでどう?
void mod(int x, int y, int* a, int* b)
{
if (y < x) { *a = 0; *b = y; return; }
mod(x*2, y, a, b);
*a *= 2;
if (b >= x) { (*a)++: b -= x;}
}
2進数の割り算を自分で筆算でやれるか? やれるなら、シフト演算と引き算と足し算でなんとでもなる。
604 :
597=600 :05/02/03 00:38:54
重ね重ねすいません。 二進数の除法のアルゴリズムが知りたいのです。 「/」は10進数演算子だから、二進数の除法はこれではダメだと きいたので…
ちょっと前どっかのスレで同じ様な質問した奴と同一人物かな
C言語スレだったか忘れたけど
>>604 2進数だったら & 取ればいいだけじゃないの?
> 「/」は10進数演算子だから 誰だよ、そんなこと言うやつ
>>604 整数の除算に10進も2進もねえよ。
中学レベルから数学をおさらいした方が身につくんじゃない?
でた、2chお決まりの煽り文句w どうせなら小学校からやり直したいです
お決まりっていうか、N進数だとかって中学あたりでやるだろ? 整数除算が基数ごとに異なるとか思ってるのはかなり重症だと思うが。
中学ではやらない
私立ならやるだろう。
1101101010111101010 / 10 = 110110101011110101
>>613 > でも、最近のCPUは殆ど除算命令を持っているよ。
Z80を思い出した…
>>614 ゴメン。 四則だと掛け算割り算を含んでるね。
足し算引き算と、左右シフトだけの事ね
漏れが
>>602 で既に答えてるのに皆さん華麗にスルーですか。
バグでもあるのかな。
>>609 > N進数だとかって中学あたりでやるだろ?
爺キタ━━━━━━(゚∀゚)━━━━━━ !!!!!
初期のsparcは除算命令が複数に分かれていたね。
619 :
デフォルトの名無しさん :05/02/03 13:07:24
3 6 12 20 30 という数値配列があって、例えば「7」って入力されると「7は添え字番号1と2の間にある」 っていう風に検出する一番最適な方法を教えてください。
621 :
デフォルトの名無しさん :05/02/03 13:18:20
お前ら難しい話するな。
>>619 ヘボソース
#include <stdio.h>
#include <stdlib.h>
#define SIZE 5
int main(void)
{
int line[SIZE] = {3, 6, 10, 20, 30};
int i, num;
char str[BUFSIZ];
puts("数値を入力してください");
if(fgets(str, sizeof(str), stdin) == NULL) exit(1);
if(sscanf(str, "%d", &num) != 1) exit(1);
for(i=0; i<SIZE; i++)
{
if(line[i] > num)
{printf("%dは、添え字番号%dと%dの間にある\n", num, i-1, i); break;}
else if(line[i] == num)
{printf("%dは、添え字番号%dの値と等しい\n", num, i); break;}
}
return 0;
}
>>617 突込み所が無い程完璧なソース出すと誰もコメント出来ないからスルーになる。
2ch住人……なんて性格悪いんだ…
いやこことプログラマー板の住人が性格悪いの多い気がする
ヲタが多いからさ ヲタの価値基準は「知ってる奴は偉い」だからな すぐ聞いても無いのに説明はじめたりするだろ
と、「オレはオマエラとは違う」と思っている人がおっしゃっています
人の説明が少しばかり偉そうでもそこは我慢したらどうですか? そういうことを指摘すると荒れる原因になりますし… 注意するにしてももっと思慮のある言い方にすべきと思います。 人に説明しようとしている人に悪意があるとは考え辛いです。 それよりもその人に対し自慢げだ、ヲタだなどと意味のない叩き 書き込みをするほうがよっぽど質が悪いし、無駄な書き込みでは ありませんか?
すみません、ここに書き込むべきでない低レベルな質問をしてしまいました。 大変失礼ですが質問を取り下げさせてください。
631 :
デフォルトの名無しさん :05/02/04 06:51:08
フレッシュマンに送る言葉 聞きやすい人は知らない。 聞きにくい人が知っている。
>633 わかりにくい質問をしてしまった上に、何度も聞きなおすのもどうかと思い、 一度質問を取り下げて他スレで聞き直すことにしたのです。もし気分を悪く されたのなら誤ります。申し訳ありません。
635 :
デフォルトの名無しさん :05/02/04 15:41:37
>>634 質問取り下げなくても素直にあやまったら
みんな答えてくれると思うよ
そうか? 宿題丸投げすんなとか、スレ違いとか、 筆算もできんのかとか、煽られて終わりそう
>>637 どう見てもネタスレにしか見えないんだが
639 :
デフォルトの名無しさん :05/02/05 05:27:03
やっぱサザンは神だな
640 :
デフォルトの名無しさん :05/02/05 09:24:24
>>637 多倍長計算は
openssl/bn.h
を使え。
641 :
BlackLightOfStar ◆ifsBJ/KedU :05/02/06 21:44:34
√の計算はニュートン法でできるのは当然だけど、 CALCなどでやるとニュートン法よりもずっと計算が速い。 その計算方法は誰かが知っている、あるいは過去に知っている人が居たはずなんだけど、 計算の高速化の技術が今ひとつ身に付かない。 こういうのはどういう分野の研究者がやるんだろう? さて、次から選択。 プロに任せる。 何とかして計算の高速化の技術を習得する。 量子コンピュータの発明。
トウシツクサイゾ
「プロに任せる」。具体的に言うと「既存のコードを利用する」。
644 :
デフォルトの名無しさん :05/02/11 00:48:09
平方根を計算するハードに任せる。
645 :
デフォルトの名無しさん :05/02/11 02:43:54
>>641 √はニュートン法でやるより、より単純で誰でも思いつく二分法が速いだろ。
二進法だから、二分法のネックである試行錯誤に時間を取られない。実質的に筆算による
平方根を求める手法の二進法版だ。
SINやCOSなどの初等関数は、STL法が速い。これは、SINやCOSを加減と2倍や1/2倍など
のコンピュータが無茶得意とする演算(数表との加減とビットシフト)だけに限定して、高速化
をはかったものだ。
SINなら引数の範囲を-π/2〜π/2に限定できれば、小数の乗算1回程度の速度でSINを
計算できてしまう。つまり、元々の引数を2πで割って余りをだし、さらにその範囲を考えて
SINやCOSどちらに引き渡し結果の符号を変えるか判断する…こっちの時間の方が、関数
計算の核心部分より遅いわけだ。
SSEに4ついっぺんにsqrtを計算できる機能があるけど それより速く出来るの?
647 :
デフォルトの名無しさん :05/02/11 03:27:24
>>646 それは無理。√もSINもCOSもLOGも、
>>645 に書いたような練りに練られたアルゴリズムがまずあって、
それをハードで実現したのだろう。だから、当然同じ精度ならハードでやっちゃう方が速い。
ただ、多倍長精度演算をやろうとして、ごりごりアセンブラなどで記述するような場合なら、上記の方法は
当然有効だろう。ハードで計算できる精度以上の数値を求めようとするなら、ソフトで計算するしかない
わけだしね。
2分法は、1回のループで1ビット精度が増える ニュートン法は、1回のループで桁数が2倍になる ある程度の精度を必要とするとニュートン法の方が当然良い。 ただ、平方根の場合、32ビット整数の平方根は16ビットに収まるわけで、 整数に限るような事をすればループ内が単純な2分法が速いという結果にもなる。 100迄の整数平方根なんてのに限れば 1+3+5+7+... 奇数列を加算してオーバーするかどうかの方が速いだろうしね
>>645 そういうのHacker's Delightに山ほど載ってるよ。
>>647 ありがとう。
物理シミュでルートの計算を膨大に使用するつもりだったから
SSEかそれ以外のものを使うか迷ってたんですよ。
物理で平方は大量に出るだけろうけど平方根は出る? 距離なら√(x^2+y^2+z^2)だろうし
平方根出てるじゃん。
653 :
デフォルトの名無しさん :05/02/12 11:49:45
>>648 普通の浮動小数点実数の場合は、コンピュータ内部で
a×2^b のような形になっているわけだ。ここで仮にbが奇数なら
2a×2^(b−1) のような形にするとして…√を求めるには…
√(a×2^b)=√a×2^(b/2)
となるから、結局問題になるのは√aの部分だ。
この部分は固定小数点と考えることができるので、結局整数と同じ手法で
√を求めることができる。
要するに、浮動小数点の場合にもニュートン法より二分法の方が速い。
>>653 見て思ったんだけどさ。
単精度だと仮数部(23bit)の組み合わせは2^23=8388608しかないじゃん。
これの√を全部テーブルにしても、2^23 * 23(bit) / 8 = 24,117,248(bytes)。
あと数年したら、テーブルによる実装も現実になったりしないかな。
メモリにアクセスするより、内部でまわした方が速そうだ。
>>652 距離は、たとえば引力なら距離の2乗に反比例するので、
平方根を出す必要は普通は無い筈。
たとえば、一定の距離に近づいたら というような条件でも、やっぱり2乗した状態で比較すればいいんだし
>>656 いや、その程度の簡略化したとしても
そういうシーン以外で多用するんだけど。
STLとかCORDICを使っていたのは 乗算もマイクロプログラムの時代 乗算がハードワイヤドロジックの今時は マイクロプログラムのSTLやCORDICより 近似式のほうが速いのは常識だ
>>657 俺は物理計算で距離が実際に必要になるケースというのが実在するというのは疑問だけど
キミが実際に必要だというなら、そうなんだろう。
でも、出来ればどういう計算に必要なのか知りたい希望はある。
661 :
デフォルトの名無しさん :05/02/12 12:59:30
>>658 というか…SINやLOGなどの初等関数は全てFPU内部で演算できるから、
わざわざプログラムで最速を求める意義は、高精度の数値を求めたりする
場合だろ。その場合には乗除もアセンブラ等でプログラムしなきゃならなく
なるから当然STLの出番がまわってくるわな。
多倍長なら桁数によってある程度桁数が増えれば、 乗算はアセンブラでカリカリに書くより素直にFFT方式にした方が早くなるよ。 そこらへんになると精度のコントロールが難しいからSTL作る方が難しいんじゃない?
663 :
デフォルトの名無しさん :05/02/12 13:49:08
>>662 FFTってフーリエ級数にするの?それよりなら単純にマクローニン展開やテイラー展開の方がいいだろ。
多倍長でも桁数が変動するやつなら、それらの級数展開に頼るしかないだろうね。
桁数が固定されてて、多倍長演算が高速で求められているなら、STLでいいだろ。演算に求められる
テーブルを計算するのは単純に桁数少ない奴のアルゴリズムを流用すれば良いだけ。
>>663 えと、掛け算を FFTでした方が と書いてるのですが?
中国剰余定理だと、それこそ桁数が変動するのに耐えられないと思いますし・・・・
マク浪人
666 :
デフォルトの名無しさん :05/02/12 14:01:58
>>664 すまん…どうやったら、乗法をFFTでより速く計算できるんだ?わからんw
ははー降参しますw!
参考になるURLなどあったら教えて欲しい。
668 :
デフォルトの名無しさん :05/02/12 14:16:47
うわ、ロッパーユーザーかよ。 ところでルートの逆数を求めるのに、 inline float rsqrtf(float v){ float v_half = v * 0.5f; int i = *(int *) &v; i = 0x5f3759df - (i >> 1); v = *(float *) &i; return v * (1.5f - v_half * v * v); } なんてのがあるんだな。精度は低いけど。
>>670 バネだから、力は近似的に距離 L に比例するから、平方根が必要という事だね。
それなら必要じゃないの?
ただ、そのプログラムだと
double dis = sqrt(dx * dx + dy * dy);
double d = (10 - dis) * 0.2;
px[i] -= dx / dis * d;
て部分は、何か適当な計算をしてるだけのように見えるんだけど・・・・・2乗のままでもそれなりに動くんじゃない?
ようするに物理計算じゃなくて、長さLが10に近づくように その部分の長さを 1- ((10 - L) * 0.2)/L*2 倍してるだけみたいだよ。 だから 1- ((10 - L) * 0.2)/10*2 でも似た感じになるだろうし (L+dL)^2= L^2 *2*dL+dL^2 だから そこを 1- ((100 - L^2) * 0.1)/100*2 でもいけるんじゃない?
で、ホントの物理計算としてのバネの場合も、 力が比例するのは L じゃなくて L+dLのdLの 微少な部分に比例するのだから L^2のまま使っても、 (L+dL)^2= L^2 *2*dL+dL^2 と、dL^2は十分小さいから無視して、2*dLの効果として使えるから やっぱり平方根は必要ないと思うよ。
× L^2 *2*dL+dL^2 ○ L^2 +2*dL+dL^2 ね。 どうしても、平方根が必要な事があっても、こんな感じのDDA処理をするなら、 微少差の場合はニュートン法的な逐次演算に変換する事も一つの方法だしね
>>670 47氏じゃないか。
あのひとはほんといろいろ作ってるな。
>>673 あのページからソースを落としてVC6で動かしたんだけど、
// ワイヤp[i]とp[i+1]間の距離は常にdr
for (i = 0; i < PMAX - 1; i++) {
static CVector3 dp;
dp = p[i + 1] - p[i];
double dis = dp.abs();
double d = (dr - dis) * 0.2;
p[i] -= dp / dis * d;
p[i + 1] += dp / dis * d;
}
この部分をどう変えたらいいんですか?
実際やってみるので改変後のソースを示して欲しいんだけど。
本当に平方根なしで動きに問題が出ないのか確認したいので。
>>656 >
>>652 > 距離は、たとえば引力なら距離の2乗に反比例するので、
> 平方根を出す必要は普通は無い筈。
引力でも、そのベクトルを出そうと思ったら平方根がいるのでは?
まあ、惑星のシミュレーションなんかで使われるハミルトン系専用の
数値計算法ではいらなくなるのかも。
>>676 試すだけなら
{
double dr2 = dr*dr;
for (i = 0; i < PMAX - 1; i++) {
static CVector3 dp;
dp = p[i + 1] - p[i];
double dis = dp.abs();
double d2 = dis*dis;
double d = (dr2 - d2) * 0.2/2 / dr2;
p[i] -= dp * d;
p[i + 1] += dp * d;
}
}
ごめん。 こうしてみて。 { double dr2 = dr*dr; for (i = 0; i < PMAX - 1; i++) { static CVector3 dp; dp = p[i + 1] - p[i]; double d2 = dp.abs2(); double d = (dr2 - d2) * 0.2/2 / d2; p[i] -= dp * d; p[i + 1] += dp * d; } } abs2というのが、2乗和の事みたい。
おお、ちゃんと動いてますよー! バネモデルはいろんなところで使ってたからこれで高速化が 期待できそうです。 本当に平方根がいらなくなるとは恐れ入りました。
681 :
デフォルトの名無しさん :05/02/12 22:14:40
>>673 ん?
(L+dL)^2= L^2 *2*dL+dL^2 じゃなく…
(L+dL)^2= L^2 *2*dL・L+dL^2
だし… やはり平方根ひつようなんじゃ…
682 :
デフォルトの名無しさん :05/02/12 22:27:23
>>681 (L+dL)^2= L^2 *2*dL+dL^2 じゃなく…
(L+dL)^2= L^2 +2*dL・L+dL^2
なんじゃ…
683 :
デフォルトの名無しさん :05/02/13 01:34:44
>>680 そりゃ動くとは思うが…精度的に問題出てこないのかあ?
確かに。実際に平方根の元のアルゴリズムと
>>679 のアルゴリズムで
誤差を見て見たらかなり誤差が大きかった。
理想を言えば平方根のバージョンと近い値を期待したいところだけど
ここまで誤差があるなら別の手法として割り切って使えばいいのかなぁ。
例えばワイヤーとして破綻のない動きであるならコレでもいいって感じ。
>>683 もともと、物理計算じゃなくて、偏差に比例するような速度で戻るという仕掛けで動かしてるだけだから
最初から物理計算からは精度外れまくりでは?
よ〜し、パパ、マジメに変換しちゃうぞ。
>>676 double d = (dr - dis) * 0.2;
p[i] -= dp / dis * d; ⇒ e = (dr - dis)/dis *0.2 とすれば p[i] -= dp *e; と置き換えられる
dr^2-dis^2 =(dr+dis)*(dr-dis) だから
e = (dr - dis)/dis *0.2 = (dr^2-dis^2)/ ( (dr+dis)*dis) *0.2 = (dr^2-dis^2)/ ( dr*dis + dis*dis) *0.2
ここまでは誤差のない変換だ。
で、drとdis は、そもそもdisをdrに近づける為なんでループの結果同じ値に近づく筈
だから同じとみなして dr*dis ≒ dis*dis とすると
>>679 に化けるわけだ。
誤差の部分はここにあるけど、そもそもの計算方法がマジメな計算じゃないから、似た結果になりゃいいじゃんてことだな。
という事で、少しだけ元の値に近づけるなら
dr*dis + dis*dis と 2*dis^2 の比率を (dr^2-dis^2)/dr^2 から補正してやればいい。
単純な1次の線形近似
>>659 から
double dr2 = dr*dr;
for (i = 0; i < PMAX - 1; i++) {
static CVector3 dp;
dp = p[i + 1] - p[i];
double d2 = dp.abs2();
double e2 = (dr2-d2);
double e = 0.2*e2/(d2*(2 -e2/dr2*0.4 ));// <--- 0.3〜0.5の範囲で適当に
p[i] -= dp * e;
p[i + 1] += dp * e;
}
使ってる環境によっては、平方根どころか除算でさえネックになるから 似た結果でいいなら、どんどん変換しちゃうわけね。 さらに昔は、掛算さえ嫌って、変数追加してDDA方式でゴチャゴチャやったよな
スマン、符号を間違っていた。 ところが、符号を正しくすると、異常な領域に飛んでいってしまうと逆に精度が悪くなる。 といって、途中に判断が必要になるのも、あんまり好ましくない。 で、誤魔化す方法を考えた結果、近似計算として for (i = 0; i < PMAX - 1; i++) { static CVector3 dp; dp = p[i + 1] - p[i]; double d2 = dp.abs2(); double e2 = (dr2-d2); double e; // if(e2>0) e = 0.2*e2/(d2*(2 + e2/dr2*0.4 )); // else e = 0.2*e2/(d2*(2 + e2/d2 *0.4 )); e = 0.2*e2/(d2*(2 + e2/(d2+dr2))); p[i] -= dp * e; p[i + 1] += dp * e; }
どれくらい誤差が小さくなるかだけど dis/dr = 1.1 の時 4.7 % ⇒ -0.2% dis/dr = 10 の時 82 % ⇒ -0.8% dis/dr = 0.9 の時 -5 % ⇒ 0.3% dis/dr = 0.3 の時 -51 % ⇒ -34% dis/dr = 0.1 の時 -81 % ⇒ -72% disが極端に小さい方にはあんまり効果ないね。 やっぱり、小さい方には別の近似関数を用意する必要がありそう
小さい方に精度を上げるには
if(e2>0) e = 0.2*e2/(d2*(2 +0.50 * e2/(d2+dr )));//disが小さい
else e = 0.2*e2/(d2*(2 +0.93 * e2/(d2+dr2)));//disが大きい
のようにすれば緩和出来るけど、
ただ、どうしても、disが小さくなるほど、誤差は-100%に近づいてしまう。
誤差100%というと大きいようだけど、ようは2倍という事、
それと、disが小さいと逆数で効くので、そもそもeが1以上になってしまう。
そんな条件だと本来の物理計算としてメチャクチャな所にあるんで、
>>689 あたりの近似で十分じゃないかな
あと、
>>678 がダメで
>>679 がOKなのも、結構面白い。
この計算式が本当のバネを計算してるなら、いつまでも振動は収まらない筈。
なのに、適当に振動が収まるのは、このチョットとした工夫が抵抗項として
働いてるんだろうね。
>>688 似た結果というのは、ちょっと違うかな。
DDAを使えば、一般的に微少な2次の項を省略しても、必要なだけ細分化すれば誤差は必要なだけ抑え込める。
たとえば
a+b*dx+c*dx^2
てな感じだと、
処理分解数を2倍にすれば dxは半分になる。
dxが1/2になれば dx^2は 1/4になる。
だから2次以上の項目は必要なだけ小さく出来る。
フックの法則はここに持ち出すのは正しくない。 dが力だとすると、力*質量に加速度が比例して、加速度を積分して速度になり、速度が積分されて位置になるけど ここでは、dをいきなり積分している。だからdは力ではない。 擬似的にそれなりの表現が出来ているのだから面白いという事でいいのだと思う。
正しくないは言い過ぎたな。 強い摩擦が働いていて、その時間分解能の中では 速度が力にほぼ比例する特殊な状況のシミュレートと考える事は出来る。 だから、バネ係数であり摩擦係数でもあるわけだ
698 :
デフォルトの名無しさん :05/02/14 18:48:43
はさみうち法のC言語でのプログラムを教えてください。
701 :
デフォルトの名無しさん :05/02/14 20:46:55
わざわざありがとうございました。参考にしてみます。
>>198 わたしは部外者だけど、あなたはキモいと思う。
半年も経ってからご苦労様。
704 :
デフォルトの名無しさん :05/02/24 00:40:24
「C/C++の宿題を片付けます」スレからこちらを奨められました。 よろしくお願いします。 重点サンプリング法の質問はここで良いでしょうか? プログラムを組もうと思っているのですが、重点サンプリング報じたいがよく判らないので、 『解を得るまでのフロー』があっているチェックしてください。 『問題』 P[R<S]を求めるのが最終目的です。(RとSは互いに独立) fr,fsはS,Rの確率密度関数(それぞれWeibull,Frechet) I(R<S)はR≦Sなら1を、R>Sなら0を返す関数 重点サンプリング関数は互いに独立な2次元正規分布で平均、標準偏差は共に(18,4.5) 『解を得るまでのフロー』 1. 正規分布(18,4.5)に従う乱数を2つ生成し、(r,s)とする。 2. I(r<s)を計算する。 3.fr(r)*fs(s)を計算する。 4.φ((r-18)/4.5)*φ((s-18)/4.5)を計算する。(φ(●)は標準正規密度関数) 5.(2の結果)*(3の結果)/(4の結果)を計算する。 6.1−5を繰り返し、平均値を取る。 よろしくお願いします。
705 :
デフォルトの名無しさん :05/03/04 00:30:37
longest common subsequence使用して行単位差分を取ろうと思ったのですが、 トップダウンだと計算量が指数的に増えるし、 ボトムアップだと、LCSは求まるが、経路求めようとするとでかいメモリが 必要でどうしたいいものなのでしょうか?
706 :
デフォルトの名無しさん :05/03/04 00:53:40
708 :
デフォルトの名無しさん :05/03/05 02:06:47
SuffixTreeでパターンマッチングして最適解探せってことか....
> SuffixTreeでパターンマッチングして最適解探せってことか.... 違うだろーが
710 :
デフォルトの名無しさん :05/03/05 17:48:30
違うのが、Gusfieldの本手元にないからわかんね
712 :
デフォルトの名無しさん :05/03/13 08:06:05
組み合わせについて教えてください。 自然数の配列 int[N] のなかから、任意の組み合わせを 抜き出し、その要素の合計がXを超えない最も大きい組み合わせ を求める。 という問題なんですが、Nが大きくなると、計算量が爆発的 大きくなります。 どうにかならないものでしょうか? なお各要素はXを超えないとします。
モンテカルロ法。
>>713 すいません。モンテカルロ法ということは、
要するに、全部の組み合わせを考えないで、適当に選んだ
物の中から、最善なのを選べばよい、ってことでしょうか?
715 :
デフォルトの名無しさん :05/03/13 11:35:41
行列の固有値を求めるには?
>>712 それってNP完全のナップザック問題でしょう?
ヒューリスティックな解法やらいろいろな近似解法が考えられているから調べてみなよ。
ヒステリックな解決法ですか。 調べてみます。
718 :
デフォルトの名無しさん :05/03/13 22:03:04
円周率を11進数で求めてみたいのですが参考になるサイトはありますか?
719 :
デフォルトの名無しさん :05/03/14 00:27:08
>>718 2進数で求めた小数部を次々と11倍しては整数部を引いていくのはいかんのけ?
>>717 テメー それわざとか?わざとなんだろ?あやまれよ、あやまれ!!!!!
>>717 /::::::/::::::::::::::::\/ |:::::/|:::::| |::::::| |::::|::::::::|:::::::::::::|::::::::::\:::::::::::::::
:::::::/::::::::::::::::::/ ヽ、 |::/ |::::| |::::::| |::::ト、:::::|、:::::::::::|:::::::::::::::ヽ:::::::::::
:::::/::::::::/::::::/ ,==>ト{_, |:::| |::::::| |::::| \|\::::::::|::::::::::::::::::|::::::::::
/|::::::/|:::::::| イ /( )、ヽ |:::| l`'十┼┼-----‐<「:::::::::::|:::::|::::::::::
|:::/::o::::::| | {::::::l|l|::!| V |:::::! レ/´,ィ´ ̄`ヽ::::ト、::::::::|:::::|::::::::::
レ'.:::::|::o::! ヽヾ、:::ノノ ヾ、| | /::ヽ、_ノレ' ヽ:::::::|:::::|::::::::::
/.:::゚:::∧:::::|(__)ニ==ニ | |::::::l|l|l:::::::| ト、::::!::::。:::::::::
.::::::::::/::::ハ:::| ´ ̄ ̄` ヽヾ、;;;;;;;;;;ノ O::::o::::::::::::::::
::::::::/::::/ .:ヾ、 .::: ´ ̄ ==‐- 二つ /::::::::::::::::::::::::::: あやまれ!!
:::::/::::/ .::::∧ ` /::::::::/::::::::|:::::::::
>>716 さんにあやまれ!!
::/::::/ .:::::/::∧ ヽ`'ー--- 、 /.::::/:::::::::::|:::::::::
/:::/ .:::::/.::/.::.ヽ |:::::::::; -‐::::.ヽ /.::::/:::::::::::::::::|:::::::::
::::;' .:::::/ .::i:::::::::.\ !:::/7:::::::::::::::::i /.::::/:::::::::::::::::::::::|:::::::::
.:::! .:::/ .:::::!:::::::::::::/\ V〈::::::::::::::::::::| ∠:::::/:::::::::::::/.:::/::::::|:::::::::
::::|:::/ .:::::::l::::::::::::/.::::::.\ \ヽ、_// /::::::::::::::::/::::/|:::::::|:::::::::
::::レ' .::::::::/::::::::::/.::::::::::::::.\ `'ー--‐' _,. ‐'"/.::::::::::::/.::::/::|:::::::l\::::
:::::::::::::/.::::::/.::::::::::::::::::::::.`'ー--‐''"´ヽ /.:::::::::/.:::::/::::|:::::::| \
SEX
723 :
デフォルトの名無しさん :05/03/17 23:35:40
>>718 10進数で求めるプログラムの10を11に変えればいいんでは?
ヒステリックな苗木野そら
725 :
デフォルトの名無しさん :2005/03/26(土) 12:22:01
不定な連立一次方程式の解を求める手法希望 Az = 0 N : >= 2 の整数 A : size NxN, rank(A) = N-1 の行列 z : size N [zの要素の和は1] の条件を加えて制約条件 Nつで。 よろしく。
シンプレックス法
727 :
725 :2005/03/26(土) 22:55:02
まだ試してないけれど道が広がった。ありがと。
>>726 ついでと言っちゃなんだけれど、
>>725 のAのN行の中から、
不要な条件(行)を求めるにはどういう方法があるかどなたか知りません?
728 :
725 :2005/03/26(土) 23:00:03
あとシンプレックス法って、 条件数N=10000くらいでも速く(できればLU分解程度)解を求められる?
固定小数に関する質問ですが、 例えば、 小数部に16Bit幅、整数部に16Bit(合計32Bit)を持つ固定小数を求める場合、 25.6を固定小数に直す方法は u16 KoteiShousu = 25.6 * (1<<16); で合ってますか? 調べたサイトに 25.6 * 0xffff のようなやり方を使ってたので、 こちらが正しいのか、それとも、 このやり方は別の表現方法(固定小数の)なのか、分別付かない。
>>729 >で合ってますか?
合っている。
>このやり方は別の表現方法(固定小数の)なのか、分別付かない。
そこだけ書かれても、なんとも言えない。
ところで25.6は無限小数だから正確には表わせない事は理解してる?
>>730 thanks
勉強不足でした。質問忘れてください。スミマセン。
有向であれ無向であれ、節と節を重み付き枝で結ばれたグラフの 最長経路を導く問題は、最短経路のアルゴリズムの内、「最小をみつけたら更新」 みたいな部分を単に「最大を見つけたら更新」に変更するだけで実現できるものな のでしょうか?んなこたないのでしょうか?
ループの検出を加える必要がある。 「最小選択」にはループの検出の機能がある。
734 :
732 :2005/04/29(金) 15:19:29
>>733 ループの検出・・・ですか。ありがとうございます。
そんな簡単にはいかない。何か他にも問題があったはず。
>>732 最短経路を導出するアルゴリズムは、
注目する道を順次伸ばしていくアルゴリズムだから、
ある時点で注目している道の中で最短の道より
短い道がそれ以後現れることはない。
(もちろん距離が負の辺はないとして)
でも、ある時点で注目している道の中で最長の道より
長い道は、それ以後いくらでも現れうる。
だから
>>732 みたいに単純にはいかない。
単一パスのコストc_{n}の最大値Mが分かっていれば、 c'_{n} ← M - c_{n}として最短経路を求めれば、 それは最長経路となっている。
もちろん嘘です(w
最長経路の定義によっては、更に厄介になる悪寒。 仮に、閉ループが形成されない限り経路が重複してもいいとしたら?
740 :
732 :2005/05/01(日) 13:01:28
>>736 >でも、ある時点で注目している道の中で最長の道より
>長い道は、それ以後いくらでも現れうる。
そうなんですよね・・・。ここに苦しんでおります。
>>737 この方法も考えてみました。
(頭の中でシミュレートした結果、上手くないなと思い実行はしていませんが)
>>738 やはり嘘なのですか?
>>739 >最長経路の定義によっては、更に厄介になる悪寒。
今のところは、閉路であることが前提としたものを作っています。
>>740 > >最長経路の定義によっては、更に厄介になる悪寒。
> 今のところは、閉路であることが前提としたものを作っています。
意味がわかんねえ。
ノードの重複通過は許容するのか?
する場合、
パスの逆方向通過は許容するのか?
パスの同方向重複通過は許容するのか?
とっとと書け。全然難易度が違う。
最短経路問題と違って上の条件設定があり得ることを理解してないのか?
742 :
732 :2005/05/01(日) 13:41:11
>>741 ノードの重複通過は許容しません。
(閉路であれば)重複通過を許容しないものが基本だと決め付けていたので、
過去のレスには書きませんでした。
じゃあ、総パス探索してから、最長を選択して終了。
入力:有向グラフG=(V,A)、枝の重みw:A->R 出力:Σ{ w(a) | a ∈ P } が最大である単純な道P (注)同じ点を重複通過しない道を単純な道と呼んでます っていう問題ならNP困難(さらに近似困難)だよ。
FX = lnX0 - 2 '解こうとする関数FX DF = '関数FXの微分式 X1 = X0 - (FX / DF) 'ニュートン法の基礎式よりX1を計算 DX = Abs((X1 - X0) / X0) 'X1とX0との隔たりを調べる変数DXを計算 N1 = N1 + 1 '繰り返しの回数N1をカウント 誘導されてきました。このVBコードの一部を書き換えて√2の近似値を求めるプログラムを作成したいのですが 分からないです。どなたか教えてください
747 :
デフォルトの名無しさん :2005/06/02(木) 15:28:47
age
>>746 ニュートン法でしょ?
特に書き換えず、そのまま適用してよいと思いますよ。
749 :
デフォルトの名無しさん :2005/06/03(金) 09:42:37
メディアンフィルターについて教えてくだすれ
>>749 2次元なら、周囲9ブロックの値をソートして5番目の値を使う。
25ブロックとか49ブロックにしてもよい。
>>750 そうすると、メディアンフィルターはボケ効果ですよね。
3x3の平均を取るフィルターでもボケると思うのですが、較べるとどう違いますかね。
753 :
751 :2005/06/04(土) 22:09:15
>>750 なるほど、ぼかしと言うよりノイズ除去ね。THX
754 :
751 :2005/06/04(土) 22:09:42
囲碁のプログラムを組んでるんですが、 強さを表すのにレートを使おうと思ってます。 条件として 1 レートの高い人(強い人)がレートの低い人(弱い人)をボコってもレートが殆ど上がらない。 2 逆の場合はレートがグンと上がる。 3 同じ位のレートなら一律+1とかちょっとだけ上がる。 以上の条件を満たすような計算アルゴリズムで何かいいのありませんかね?
>>755 例えば、√(相手のレート/自分のレート)とか?
つまりレートが同じなら1、相手のレートが自分の9倍なら3、相手のレートが自分の1/4なら1/2って計算。
この数値だと、レート9倍の相手となら5連勝すれば追いつけるね。
#って、負けた方は下げないのかな?
>>756 負けた方は下げます。なるほど√か、いいかも。
1 と 3 が矛盾しているように思いますが
>>758 そうそこの境界が曖昧なんだよなぁ。
今のところ何戦かして標準偏差出してって境目を作ろうと思ってるんだが・・・。
レートが整数であるならば、 「殆ど上がらない。」 は +1 または +0 という意味かな? 「+1とかちょっとだけ上がる。」 は +1 または 2〜3 程度上がるという意味かな? 漏れは同じ位のレート同士の対戦でももっとレートの変動があっていいと思うべな
762 :
デフォルトの名無しさん :2005/06/14(火) 01:02:52
Aをn次正方行列、x,bをn次ベクトル、0をn次ゼロベクトルとしたとき、 Ax=0のトリビアルで無い解を解くロジックってあるのでしょうか。 巷の本はすべてAx=bでAは正則行列としているので、 一意の解を求める方法しかありません。
ある
そんな意地悪しないで、せめて書籍ぐらい教えてあげなよ。。。
ニューメリカルレシピとかいう本に載ってなかったか? 最小ノルム解でぐぐるとか
766 :
デフォルトの名無しさん :2005/06/14(火) 12:38:33
>>762 馬鹿かおまえは
Gauss の消去法でも使えよ
固有値がわかっていて、固有ベクトルを求めるルーチンと同じにならないか。
じょるだん標準形はどうやって求めるのでせう。
先ず、最小多項式を計算汁。
771 :
デフォルトの名無しさん :2005/06/16(木) 15:32:04
レポート課題(2回目)
上記のアプレットを用いて、次の1, 2 のどちらかのプログラムを作成せよ。
1. data[0] (データ用メモリの 0 番地) に置かれた値の階乗を計算して出力す
るプログラム。
2. 面白い問題を自分で考えて、そのプログラム。
プログラムは、上記のアプレットのページで実行しているところを、プリント
アウトせよ。1. の場合、10 の階乗を計算しているところをプリントアウト
すること。それに、説明(どのメモリアドレスが何に用いられているかなど)
を書き加えること。
http://www.i.h.kyoto-u.ac.jp/~tsuiki/lecture/jouka/3.html 1を誰か教えてください。どこに何を記入すればいいのか。
まじおねがいします。
772 :
デフォルトの名無しさん :2005/06/16(木) 15:34:54
>>771 しかし幼稚なことやってんな
大学ならもっと理論的なことやればいいのに
こんなもんアビバでやるべきことだよ
アビバってプログラミング教えているの?
浴び場はc言語やd言語、vbにじゃ場やでるふぁいとか教えてるだろ
マジですか?
指針は、 とりあえずdata[1]にデータコピーして、 data[1]==2なら終了 そうでないなら、1減らす。 data[0]とmulを取る。 store、loadしてから繰り返し。
777 :
初心者 :2005/06/17(金) 04:16:44
Hirschberg Algorithmの実装したソースコード てどこかでダウンロードできないでしょうか?
どなたかラスターオペレーションコードから計算式を求める方法をご存知でしょうか ? Destination, Source, Pattern, Mask の 4 項からなるラスターオペレーションコードは 16bit 値になり, それぞれの項は, Destination: 0xaaaa Source: 0xcccc Pattern: 0xf0f0 Mask: 0xff00 という値になります. 演算子は, AND, OR, XOR, NOT の 4 種類になります. ラスターオペレーションコードは, これの演算結果が値となっていることまでは理解しました. たとえば, Source と Pattern を AND したものを Destination に OR する場合, D | (P & S) -> 0xaaaa | (0xf0f0 & 0xcccc) -> 0xeaea となり, D | (P & S) のラスターオペレーションコードは 0xeaea になります. ですが, 逆に 0xeaea から 0xaaaa | (0xf0f0 & 0xcccc) という計算式を求める方法が 分かりません. Windows と X で, ラスターオペレーションに同様のコードを用いるので, 一般的な アルゴリズムのように思うのですが, 検索でもこれを解く方法を見つけられませんでした. 最悪, すべてのラスターオペレーションコードと計算式を関連付けた 65536 個のテーブルを 持つという方法も考えたのですが, あまりにバカなコードになってしまうので, なんとか 計算で求めたいと思っています. どなたかご存知の方がいらしたら, 知恵を貸してください.
>>780 まず、8ビットを分解して2進化する。
0xff = 0x80 | 0x40 | 0x20 | 0x10 | 0x8 | 0x4 | 0x2 | 0x1
= 0x80 & 1 | 0x40 & 1 | 0x20 & 1 | 0x10 & 1 | 0x8 & 1 | 0x4 & 1 | 0x2 & 1 | 0x1 & 1
つまり、
0xff = 0b11111111
これを0xeaに当て嵌める。
0xea = 0b11101010
さて、それぞれのビットの重みはd, p, sの演算によって作られる。
0b10000000 → p & s & d
0b01000000 → p & s & ~d
...
つまり、
0xff → p & s & d | p & s & ~d | p & ~s & d | p & ~s & ~d | ~p & s & d | ~p & s & ~d | ~p & ~s & d | ~p & ~s & ~d
0xea → p & s & d | p & s & ~d | p & ~s & d | ~p & s & d | ~p & ~s & d
となるのでビットごとにp, s, dの(反転と)&演算を行なうかどうかの判断をすればいい。
尚、これを整理すると、
0xff → p & s | p & ~s | ~p & s | ~p & ~s = p | ~p = 1
0xea → p & s | p & d | ~p & d = p & s | d
となるので意味が変わっていないことが判る。
ラスターオペレーションコードから演算式を作りだしてコードを動的に作って高速処理させようって事? ハードウエアで処理しちゃうから、あんまり流行らないと思うけど
784 :
780 :2005/06/22(水) 18:08:04
>>781 >>783 ありがとうございました !
おかげでロジックが見えてきました.
>>782 あまり詳しくは言えないのですが, 特殊な組み込みのフレームバッファボードで
ラスタオペレーションの描画をすることになりまして・・・
私も今更ソフトでこんなことするハメになるとは思っていませんでした.
与えられた平面上の二線分の交差判定ってどうやるのがシンプルですか? なお、交差には二線分がぴったり重なってる場合も含めます。 重なってるのを交差と見なさない場合は外積ふたつ計算してやればいいんですが、 重なってるかどうかで分岐したりするとプログラムが冗長になってしまいます。 ぜんぶで5〜6行に収まるシンプルな方針があれば教えてください.
ここで聞いていいことなのかわからないけど、 学校の問題でこんな問題が出たんですけど なんて答えればいいと思いますか? 「次の専門用語を解釈せよ」って問題に 「アルゴリズムの正当性と停止性」ってのがあるんですけど、 言葉で表すならどうしたらいいのかわかりません。
間違った答えを返さないかどうか>正当性 永久ループに陥る事がありえるかどうか>停止性
ゲーム木を探索する時に最も評価の高い葉を保存しておきたいのですが、定石的なものはありますか? 最大値というのはαβ戦略にそった根の値です。 最大値かどうかは探索が終了するまで分かりません。 ですから、可能性のある葉を全て保存していては効率が悪いような気がします。 枝でもいいです。(葉までのパス)
ありがとうございます。参考にしてみます。
非線形方程式を解くものにニュートン法がありますが、これは除算が含まれているため、 0に近い解を出す場合などにオーバーフローを起こしてしまいますよね。 この問題が(ニュートン法よりも)解決されているアルゴリズムはあるのでしょうか?
>>793 ニュートン法でも、除算の分子と分母の両方をxの累乗であらかじめ割った式に変形しておくと、
オーバーフローしないよ。
795 :
793 :2005/07/16(土) 12:26:28
ax^3+bx^2+cx+d=0の3次方程式を解く方法教えて下さい。 取りあえずaで割って x^3+Bx^2+Cx+D=0とするかな?とおもってます
>>796 4次までの代数方程式には解の公式が存在する。
ニュートン法を使うまでも無い。
799 :
デフォルトの名無しさん :2005/07/20(水) 23:21:54
>>797 ,798
ただ単なる3次方程式じゃあつまらないから、
虚数解まで出す、っていう条件をつけたらどうだろう?
800 :
799 :2005/07/20(水) 23:22:42
ageてしまったorz スマソ そして800ゲト
801 :
799 :2005/07/20(水) 23:24:55
ていうか、解析的に出てるんだから虚数解だって簡単だってね。 何言ってるんだろ俺orz じゃあ一般的にn次方程式だったらどんなアルゴリズムがありますか?
>>797 3次の場合は、
- 解の公式使うと複素計算になる&精度が微妙
- 1つは必ず実数解
という性質から、
1つの実数解をニュートン法使って求めてから、
その1個を因数分解して、残り2個は2次の解の公式で解くことが多いみたいよ。
4次の場合、1つは必ず実数解ってところが成り立たないから微妙だけど、
精度考えると多分、こっちもニュートン法使う方が確実。
スレ違いだったらごめんなさい。やりたいことはこうです。 1. 32ビットのポインタではなく、16ビットのハンドルを返す mymalloc() を実装したい。 2. myfree() されたハンドルは、なるべく遅く再利用する。 これを実装するために、mymalloc() と myfree() を以下のように実装しました。 unsigned short mymalloc(size_t size) { p = malloc(size); h = obtain(); btree_insert(h, p); return h; } void free(unsigned short h) { p = btree_search(h); btree_remove(h); lose(h); free(p); } 続く…
805 :
804 :2005/07/21(木) 16:34:42
>804 の続き これで基本的にはうまく動いているのですが、obtain() と lose() の実装をどうするか、悩んでいます。これらの仕様は以下です。 1. obtain() は 1〜65535 の間の数字を返す。使用済みの数字は破棄されるまで返さない。 2. lose() はすでに使われている数字を破棄する。 3. obtain() は、破棄された数字をなるべく「遅く」再利用する。 コードで書くと、 for (i=0; i<65535; i++) { n = obtain(); lose(n); } この n ができる限り一つも重複しないで、 for (i=0; i<65535; i++) obtain(); lose(30000); lose(65535); n = obtain(); // たぶん 30000 を返す n = obtain(); // たぶん 65535 を返す この最後の二行が十分速く実行できるアルゴリズムを考えています。 現在は、65535ビットのマップを使って、つまり unsigned char bitmap[8192] とやって使用済み番号を管理しているのですが、実際に obtain() が利用される 回数が 100回くらいしかない場合でも 8Kb も消費するのが気に入りません。 未使用のハンドルを探すのに btree が使えたらいいのですが… いい方法、ヒントがあったら教えてください。よろしくおねがいします。orz
#16ビット環境のエミュレートに使うんだろうか。 自分ならセマフォかプロセスレベルで最初に一回だけmalloc(65536)して 先頭アドレス、サイズの構造体をリストで管理。myreallocのような実装や デフラグな機能を考慮する。
(;´∀`)うわぁ
>806 ビットマップを使う方式で 8Kb 消費すれば 十分高速なものがすで作れていますので malloc(65535) はちょっと… >808 うーむ
>>805 static uint16_t last = 0;
uint16_t obtain(void) {
uint16_t x = last;
while (btree_search(x)) {
x++;
}
last = x + 1;
return x;
}
>811 それ、ただ実装しただけです。ぜんぜん速くないです。 >805が書いてるビットマップという方式の方が遥かに 速い。だから、8kbくらいけちけちすんなっつー話かと。
>>811 1,3,2と開放されたら1,3,2と返さんといかんのやないの?
>>813 逆やろ。1,3,2はなるべく遅く再利用。
>>814 813 で言いたいのはそういうことやない。
1,2.3,...,65535 全部使われた後に 1,3,2 の順で開放されたら
三つ空きが出来るやろ。
そこから三つ要求したら 1,3,2 の順で割り当てられんといかんのやないの?
という話や。
空きブロック ⇒ 空きブロック をリストで管理して、 末尾⇒先頭に連結した リングバッファ形にしたら速そうな気はする が、断片化が激しいと 8kb 超えるかもしれない。
>815 必ず遅くじゃなくて、なるべく遅くだから、べつに 1,2,3 と割り当てられて も問題ないでしょう。ようは、開放されたばかりのやつを使うんじゃなくて まずは、空きが他にあるならそっちからってことだと思われ。 >816 全部使われた後に全部開放されたら、その時の空きブロックリストは 軽く 8kb 越えてしまわない?結局、空きブロックを 1ビットで表せる ビットマップ方式が一番メモリ消費も少なくて、かつ、速度も十分かと。 リストは速度は最速でもメモリ消費がかなり酷いことになりそうな悪寒。
>>817 空きブロックの表現をランレングス的に表現すれば…
[先頭ID + 長さ] で1つの管理体にすると。
そも32ビット環境で16をエミュレートするのにこのようなことをしても報われるような気がしない。
いったん65535をリニアに確保した方がエリアを利用する側にとって速いような。
>>811 でいいんじゃないの?
ビットマップが嫌なくらいだから、あまり確保されないんでしょう?
822 :
1 :2005/07/25(月) 01:37:06
SECDという、λ計算をする仮想機械をCかJavaで設計したいのですが、 どこかにいい情報のあるサイトはないでしょうか? あと設計上のヒントなど知っていたら教えてください。 作りたいのは以下の計算をするプログラムです。 S,E,C,Dの4つのスタックから構成されています。 Sはそれぞれの要素が式の評価の中間結果を保持するために使用される。 Eは展開中の式の環境を積み上げるスタック。 Cは制御用に各要素を保持。 Dはダンプ用のスタックとして、処理順を制御した場合に それぞれのスタックの要素を一時的に保持するために用いられる。
823 :
2 :2005/07/25(月) 01:37:48
具体的な計算です。 1.Cが空、でDが(S',E',C',D')であるなら、現在の状態(S,E,C,D)は(Sの先頭:S',E',C',D')に置きかえられる。 2.Cが空でない時 1.Cの先頭がidentifierである時、 Sの先頭に、Cの先頭をEで評価した値を置く。 Cの先頭を消す。 2.Cの先頭が関数抽象Xの時 EとXからclosureをつくり、それをSの先頭に置く。 Cの先頭を消す。 3.Cの先頭がapの時 1.Sの先頭がE'とlmv.Mから構成されるclosureの場合 Sを空とする Eに(v2ndS)を付け加える。 CをMで置きかえる。 Dを(Sの2番目以降,E,Cの先頭を除いたもの,D)で置きかえる。 2.Sの先頭がclosureではない時 Sに(Sの先頭Sの2番目)を先頭と2番目を取り除いた上で積む。 Cの先頭を消す。 4.Cの先頭が関数適用(MN)の時 Cの先頭にap,M,Nの順で積む。
825 :
822 :2005/07/25(月) 02:08:19
>>824 あ、ありがとうございます。
けど、そこも含めてだいぶいろんなサイトを探し回ったんです・・。
プロログという初めて聞いた言語で作ったSECDを見つけたのですが、
当然理解不能でした。
同じサイトのC言語版はまだ作成中でした。
おもろいスレ見っけ。数値解析結構興味ある。 ルンゲ食ったほうを使って卒論に使う計算用のプログラム作ったんだが 実はいまだにあまり理論をよくわかっていないw
まじで。数値計算法は卒論のときはじめて勉強したので。 てかそれまでプログラムしたこと無かった
大学行ってないけどルンゲクッタは知ってた漏れが来ましたよ。 プログラム電卓で利用してたのは内緒。
アルゴリズムの宿題とかわからないのですが、どこかで教えてもらえませんかね〜??
宿題スレって言うのがあるよ。検索してみな。
834 :
デフォルトの名無しさん :2005/08/10(水) 00:37:50
Bスプラインからベジェに変換するのは分かりますが、逆はどうやるのか 分かりません。どこか参考になるサイトはありませんでしょうか。
そりゃ、片方は2次式、片方は3次なんだから逆は単純にはいかんわな どうしてもやるなら分割してゆくしかないだろ
>>834 いってることが分からん
Bスプラインはベジエの完全上位互換だ
君の言ってることは逆としか思えん
サイトはあったら俺が教えてほしいぐらいだな
俺は会社で勉強しただけだし
>>835 どっちも、次数は任意(0以上なら可)かと
837 :
835 :2005/08/10(水) 09:29:15
そりゃ次数を合わせるなら、数式も係数も同じものだ 悩みようがないから、 一般的にはBスプラインは2次、ベジェは3次だからそこで悩んでるんだろうと推量したんだが?
3次のベジエを2次のBスプラインにしたいってか? そりゃ無理だ、近似しろ
単純にZ座標を無視して無理やり2次にしたらどんな惨状になるのか見てみたい
?
???
2次元, 3次元じゃなくて、2次式, 3次式のことだが・・・
>>833 アルゴリズムの宿題であって、決まった言語の宿題とは書いてないよ
844 :
834 :2005/08/11(木) 00:24:07
答え書くのスゲー面倒だし こういう面倒なのに答え書いても 経験上、感謝の一言も無いから 書くのイヤだ 最小自乗近似しろとだけ言っとく
これだけじゃあんまりだから、少し書くか・・・甘いな俺 Bスプライン関数をBs(x), ベジエ関数をBz(x)とし、 x = xs〜xeの範囲でBs(x)≒Bz(x)としたいとする まずBs(x)の次数とノットベクターを決める この辺は知らなかったら調べてくれ 教えるには面倒くさい 次数とノットベクターが決まると、 自動的にコントロールポイントの個数と基底関数が決まる この辺も知らなかったら(以下略 コントロールポイントの個数をNとし、 各コントロールポイントをC1〜CNとする(コントロールポイントは未知) 基底関数も同じくN個あるからそれをB1(x)〜BN(x)とする(こっちは既知) Bs(x) = Ci * Bi(x) (i = 1 .. N)だ、これは定義 行列を使って、以下のようにも書ける
Bs(x) = ( B1(x) B2(x) ... BN(x) ) ( C1 ) ( C2 ) ( | ) ( CN ) 次に近似に使うサンプル点を決める、xs〜xeを2Nで等分割とかが妥当か サンプル点のxの値をx1〜xMと置き Bs(x1)=Bz(x1), Bs(x2)=Bz(x2), ... Bs(xM)=Bz(xM)を最小自乗近似する この式を行列を使って書いて ( Bs(x1) ) ( B1(x1) B2(x1) ... BN(x1) ) ( C1 ) ( Bz(x1) ) ( Bs(x2) ) = ( B1(x2) B2(x2) ... BN(x2) ) ( C2 ) = ( Bz(x2) ) ( | ) ( | ) ( | ) ( | ) ( Bs(xM) ) ( B1(xM) B2(xM) ... BN(xM) ) ( CN ) ( Bz(xM) )
( B1(x1) B2(x1) ... BN(x1) ) ( C1 ) ( Bz(x1) ) ( B1(x2) B2(x2) ... BN(x2) ) ( C2 ) = ( Bz(x2) ) ( | ) ( | ) ( | ) ( B1(xM) B2(xM) ... BN(xM) ) ( CN ) ( Bz(xM) ) ↑の式は、A X = B という形の線形方程式になっている 未知数はN個あるコントロールポイント A の転置行列を tA と置いて A X ≒ B ↓ tA A X ≒ tA B ↓ inv(tA A) tA A X ≒ inv(tA A) tA B ↓ X ≒ inv(tA A) tA B とでもしとけ、invは逆行列 Bz(x)がベジエであるという事実を全く利用してないが、まあいいだろ
849 :
834 :2005/08/11(木) 21:17:49
意外に謙虚な奴だな 実際にやるとなると 基底関数を求めるトコで詰まるかもしれんな まあ、Bスプラインを扱っている以上 基底関数はどこかで必ず求めるルーチンがあると思うが 簡単に利用できるとは限らんしな そういう場合に、多分うまくいく方法が無いこともない C1 = 1, C2〜CN = 0 となるBスプラインデータを無理やり作ると Bs(x) = Ci * Bi(x) (i = 1 .. N)だから そのデータでは、Bs(x) = B1(x)となるので、B1(x)の値が求められる B2(x)なら、C1 = 0, C2 = 1, C3〜CN = 0だ Bスプラインが多次元関数の場合は、 C1 = (1, 1, 1), C2〜CN = (0, 0, 0)といった具合にして x,y,zどれかの成分の値をB1(x)として利用な (どの成分も同じ値だから)
851 :
834 :2005/08/12(金) 01:22:01
>>850 まだコーディングまで行っていないのであまり大きなことは言えませんが、
方針は何とか分かりそうな感じです。
わざわざ詰まりそうなところまで御指摘頂き本当に感謝します。
852 :
835 :2005/08/12(金) 06:54:18
単純にN分割して、誤差をチェックするのでいいと思うが? 誤差が希望範囲を超えてたら分割数を増やすというので。 分割した曲線を2次で表現すると パラメータは3点、そのうち2点は、分割点で拘束しないといけないから、残りは1個 残りの1個を ・さらに中点で拘束する ・中点の微分で拘束する でどちらが良いかだろうな。
853 :
デフォルトの名無しさん :2005/09/18(日) 20:48:19
ダウンヒープが途中で止まることってないの?
>>854 ビット列のうち見る対象を絞るフィルターだよ
log関数のアルゴリズム(fortran)を教えてください。
859 :
デフォルトの名無しさん :2005/09/21(水) 14:50:03
2つのビット列の類似度を求める方法はありませんか?
ルイージ度だったら n%2==0の時
>>859 XOR して1と0のビット数の比率を表示すればいいんじゃないの?
ビット数を数えるのはシフトとAND と加算した面白い例が、どっかのスレにもあるし
やねうらおさんの所にもあったように思うよ
863 :
デフォルトの名無しさん :2005/09/21(水) 15:03:12
>>861 ハミング距離じゃなくてAに何回演算をしたらBになるかみたいなことですが。
>>863 どういう演算? その規定が無けりゃどうしようもないだろ。
どなたかクラフチック法のアルゴリズムについて教えていただけないでしょうか。
866 :
デフォルトの名無しさん :2005/09/23(金) 04:07:52
マジでオレのほうが大仁田より根性も信念もあるね。 冷静な判断力や常識もオレのほうがずっと優れてる。 大仁田、あんた議員辞めるべきだよ。 これ以上、生き恥晒すな。 腕っ節が強ければ己が通る時代はとっくの昔に去った。 いまだに勘違いしてるから困ったもんだ。
マジで漏れの方が>866より紺青も新年もあるね。 レスがあがれば己が通る時代はとっくの昔に去った。 いまだにスレ違いしてるから困ったもんだ。
868 :
デフォルトの名無しさん :2005/09/23(金) 14:44:30
アルゴリズムのクラスでプレゼンやらされるんですが 内容をよく読まずにハフマン符号選んだ俺の運命は一体どうなるんですか?
有名なの選んでよかったじゃん 関係ないけど誰かDoubleArrayについて解説してほしい。 なんとなく検索速いのはわかったけど、何してるのかわからんかった。
ハフマン符号なんて難しい話はないから中学生でも理解できるよ。 早い話が、全ての文字を同じビット数で表すのではなく、 値のうちよく使うものから順に少ないビット数による表し方を割り当てていく。
> 早い話が、全ての文字を同じビット数で表すのではなく、 > 値のうちよく使うものから順に少ないビット数による表し方を割り当てていく。 そりゃ、中学生レベルの理解だ。
ヒント:エントロピー
874 :
デフォルトの名無しさん :2005/09/23(金) 22:32:54
>>870 そこ知ってるサイトだったけど、
また2時間ぐらい眺めてみました。
が、やっぱりよくわかりませんでした。
簡単な擬似コードで示してくれるとありがたいんだけど。
midatrieはコード汚くて読む気なくなるし・・
875 :
デフォルトの名無しさん :2005/09/23(金) 22:47:57
あー、でもソース読むのがいいかなやっぱ・・ なんとなく全体像が見えてきた。 ディレクトリ深いの読むの苦手意識あるかも。
876 :
デフォルトの名無しさん :2005/09/23(金) 23:04:23
いきなりですが挿入ソートの計算量を教えてください。
気になるあの子へそーっと挿入
878 :
デフォルトの名無しさん :2005/09/23(金) 23:07:44
いや、変な想像はどっかいってやって。
879 :
デフォルトの名無しさん :2005/09/23(金) 23:08:40
最良、平均、最悪の計算量をお願いします。
宿題スレにいけ
O(N^2)
うわ〜、最小自乗でBSPLINE近似とか昔おれもやったわ。なつかしー。 しかしこんなところで部分的な説明するより書籍などを教えてやったほうが 基礎から学べて良いと思った。原理さえ分かれば色々な数式で近似できるしね。
>876 >879 その程度、コードをテメェで実装すりゃ一目瞭然だろうが。
球が瓶に何個入るか計算できないのは何故ですか?
つまんね
886 :
デフォルトの名無しさん :2005/09/24(土) 08:18:23
>>884 やってみないと判らないからさ。
この個数は間違いなく入るというのは計算出来るけどね。
仕事の見積もりなんかもそうだろ?
実際やってみないとホントの所は判らない。
887 :
868 :2005/09/24(土) 09:15:53
>>869 ども。一応教科書に載ってるのから選べ、ってことだったんで有名なのは確かだけど
実はもっと簡単なの(B-treeとか)でも良かったんだよね。
>>870 前回書き込んだときは教科書の内容さえも読む時間がなかったんだよね。
全部英語で書かれてるし。
今はいろんなサイトを見つけたから少し安心してる。
>>871 そうそう、モールス信号も同じ観点から創案された、と今読んだところ。
ハフマン賢い。当時の教授ファノンよりも賢い。しかも特許いらず。
結構良いトピック選んだかも。
B-treeは意外と難しいよ。 アイデアは簡単なんだけれど、 他の木構造と比べないと特徴がはっきりしない。(外部ソートということ以外は) だから他の木構造についても調べることになる。 それから実装も結構手間がかかる。 ハフマン符号は自己完結的なトッピックだから、勉強しやすい。 上に出ているtrieにもつながっていくし。
ハフマン符号化は足し算さえできりゃ理解できるんじゃまいか
ハーフマン = 半分男 うふぉ!
891 :
868 :2005/09/24(土) 11:13:19
>>888 ありがd。
確かにB-treeと他の木構造との比較となるとかなり('A`)マンドクセーことになってたかも。
ますますハフマン符号選んどいて良かった。
>>889 何を隠そう、それが教科書の内容を読まずに図だけ見てハフマン符号に決めた理由だったりする。
>>890 昔「半分少女」っていうキョンキョンの曲があったね…って俺いくつだ?
892 :
デフォルトの名無しさん :2005/09/24(土) 17:00:27
このスレの内容程度だと10年位前のOh!MZとかOh!Xでやってたような気なするが気のせいか?
ハフマン符号化なんて、50年以上前のものだしな。
算術符号の特許はもう切れたの?
>>892 君はジジイで頭も固くなってきているけれど、世の中には若い人もいるんだよ。
>>895 まあ、どっかでちょっとバックナンバーなり探してみ
あの本なぜかこういうのだけはやたらと解りやすく書いてあったから
正直、大学時代の物理の講義よりOh!Xの方が解りやすかった
Oh! X|MZ世代てことは少なくとも30以上だな おっさんよ? ちなみに全盛は10年以上前の気がするが
バックナンバー探すより、ぐぐった方が早い。
>892 >気のせいか? このへん耄碌してる感じが出ててサイコーに笑える。 Oh!Xで記事にされた内容はこのスレで語るな、と?
Oh!なんとか持ち出さなくてもCマガで毎年のように似た話題やってそうだが
「『Oh!X』 最高〜!」(ワラ
お前ら低レベルだな。 もうちょっとましな質問してくるやつはいないのか。 ム板から離れてもう5年経つが、話の程度が前と何も変わらないな。
>902 お前のその発言は、小学生に向かって 「俺様が小学校卒業して5年経つが、頭の程度が前と変わらんな」 つってるのと同じ。 住人が5年間も同じなわけねぇだろカス。 お前みたいな短絡的なバカが居るから、この業界後が育ちにくいんだよ。
>>903 わかったよ「俺が中学生のときに勉強してたのとおんなじ事やってるな。おまえら中学生か?」
これなら許してくれるか?
>>904 俺が小学生の頃言っていたことと同じ事言ってるな。お前小学生か?
906 :
デフォルトの名無しさん :2005/09/25(日) 13:09:34
でも、まあ、アレだ。 こういう業界って後から入ると、既にあるものばっかりで厳しいだろうね。 結果、創造的な部分はなくなるばかりで、労働的な部分の割合が増えるばかりと。 既に陳腐化したような部分はさっさと通過出来るような方法論も必要かな
>>906 いいや、既にあるものよりも無いものの方が多い。
>>903 2chは学校と違って、コミュニティなんだがなぁ。
>>906 そんなことはないだろう。
今でも計算機関連の論文は数多く発表されている。
応用も広がっているしね。
「ハフマン」と「多倍長整数の四則演算」どちらが楽な課題でしょうか?
ハフマンだな。
913 :
デフォルトの名無しさん :2005/10/01(土) 11:44:15
行列をコレスキー分解する前に非零要素の位置を知るというのはどうやったらいいんですか? その後、ツリー状にデータを保管したいんですが・・・
915 :
913 :2005/10/03(月) 18:12:50
>>914 対称行列用のLU分解です。
A=LLt
>>915 対角成分と、下三角行列じゃないの?あ、それはコレスキー分解した後か。
917 :
913 :2005/10/05(水) 16:57:23
>>916 分解する前に零要素が非零要素に変化する要素の位置だけ知りたいんです。
一意的に決まっているものなんでしょうか?
>>917 決まらない.偶然退化するケースとかあって一般には上三角になることまでしかわからん.
だからこそ,多少要素の追加削除があっても大丈夫なようにリスト使うんでしょ.
919 :
デフォルトの名無しさん :2005/10/10(月) 19:02:48
良くわからんけど、零要素が非零要素に変化する要素の位置を 知るために分解するんじゃないの? 1+1の答えを、計算する前に2とわかる方法は無いですか? っていう質問に見えて仕方が無いのですが。 素人でスマソ
>>917 非零要素の位置って?
正方行列Lの各要素がゼロで無い行と列のインデクスのこと?
921 :
デフォルトの名無しさん :2005/10/12(水) 13:33:25
線分(X,Y座標を2つ)を2つ入力したら、 角度を教えてくれるアルゴリズムかライブラリがあれば、 教えて下さいでつ。
線と線との角度? つまり、片方を水平線に一致するように回転変換した時の角度の事? 普通に計算すればいいと思うが?
923 :
デフォルトの名無しさん :2005/10/12(水) 13:58:00
>つまり、片方を水平線に一致するように回転変換した時の角度の事? Yes. 初心者質問ですが、回転変換ライブラリがあるんですか?
>>924 多分それであってるんだと思いますが、
初心者なので、どのライブラリを使えば、逆正接できるのかわかりません。
926 :
921 :2005/10/12(水) 14:04:55
X,Y座標をインプットすると、各種計算結果が出てくるライブラリはネットに転がってたりしないんでしょうか?
927 :
924 :2005/10/12(水) 14:06:53
#include<math.h> typedef struct {double x, double y} Point; getDegree(Point p1, Point p2){ return (atan2(abs(p1.y-p2.y), abs(p1.x-p2.x))); }
928 :
924 :2005/10/12(水) 14:09:55
>>926 逆正接(逆タンジェント)はC/C++の標準ライブラリにあります。
最近のC++なら先頭2行は:
#include<cmath>
struct {double x, double y} Point;
929 :
921 :2005/10/12(水) 14:13:23
>>927-928 ご回答=解答有難うございました。
C++を使ってるので、そのままコピペ致します。
930 :
924 :2005/10/12(水) 14:13:35
関数の返値書き忘れた。doubleね。
931 :
924 :2005/10/12(水) 14:16:37
>>929 別にコピーしてもいいけど、意味ちゃんとわかった?
あと、うっかりgetDegreeって書いちゃったけど結果は「度」じゃなくてラジアン単位ね。
932 :
921 :2005/10/12(水) 14:19:41
>>930-931 実は結構理解していません。
でも、C++は普通に出来るので、動かしてみて〜直してみて、を繰り返そうと思いまつ。
あとよく思い返したらCだとabsじゃなくてfabsだなぁ。 C++ならabsでいいんだが。 あとあの按配だとリンカのフラグ指定もわからなかったりしてなぁ。
>>927 absはイランだろ 問題は2つの直線のなす角だから、
1、2つの直線の水平との角度をそれぞれ求めて差を出す(必要なら差の結果のモジュラ演算)
2、ArcCos(2つのベクトルの内積÷(abs(a)*abs(b))
935 :
921 :2005/10/12(水) 14:30:31
やっぱ、回答が2種類になったら、 どちらを取ると見やすくてバグが出難くなるか検討しないといけないから、 図形的な理解すべきかも知れませんね。 別に性能は求めてないので、どちらでも問題は無いのですが。
>>932 数値計算で理解せずに「動かしてみて」なんてやってるとキリがないぞ?
正接tan(x)は高校で習ったろ?
atan(x)はtan()の逆関数つまり
x==atan(tan(x))、y==tan(atan(y))だ。
でatan2(y,x)==atan(y/x)だ。
(ただし実際の計算では誤差があるので==ではない)
>>921 は線分の傾き(入力は座標2つであらわされる線分が一本)かとオモていタが。
2つの線分のなす角度か。だったら
>>934 だな。
938 :
921 :2005/10/12(水) 15:04:14
実は、結構934の内容理解できません。 >1、2つの直線の水平との角度をそれぞれ求めて差を出す(必要なら差の結果のモジュラ演算) モジュラ演算は無視して良いですか? >2、ArcCos(2つのベクトルの内積÷(abs(a)*abs(b)) ベクトルの内積とは、x1*x2 + y1*y2、で良いですか? absのaとbは何を表すのでしょうか?
とするとまぁ、線分は方向ベクトルであらわしておいて内積とるのが無難だね。 いろいろポカがあったんで極力ちゃんと書いてみた。 #include<cmath> struct Point2D { double x; double y; Point2D(x, y) : x(x), y(y) {;} }; struct Vector2D { double x; double y; Vector2D(const Point2D& p) : x(p.x), y(p.y) {;} Vector2D(const Point2D& p1, const Point2D& p2) : x(p1.x-p2.x), y(p1.y-p2.y) {;} Vector2D getUnitVector(void) const; };
inline double innerProduct(const Vector2D& v1, const Vector2D& v2){ return(v1.x*v2.x+v1.y*v2.y); } inline double norm(const Vector2D& v){ return(innerProduct(v,v)); } inline double abs(const Vector2D& v){ return(sqrt(norm(v,v))); } inline Vector2D Vector2D::getUnitVector(void) const { double absv = abs(*this); return(Vector2D(x/absv, y/absv)); } inline double getRadian(const Vector2D& v1, const Vector2D& v2) { return (acos(innerProduct(v1.getUnitVector(), v2.getUnitVector())); }
941 :
938 :2005/10/12(水) 15:11:06
>>939 有難うございます。それを動かします。(動くまで自分で直してみます)
>モジュラ演算は無視して良いですか? 結果が-300度とかになっても問題なければ無視してもいい +90度と-90度も 線分の場合は区別する場合と、区別しない場合もあるしね >ベクトルの内積とは、x1*x2 + y1*y2、で良いですか? >absのaとbは何を表すのでしょうか? a,bが判らないのと同じく x1 x2も判らんけど、座標っぽい雰囲気があるなあ 座標じゃなくて方向ベクトルだから線分の終点-始点 でなければいけないよ。 でabsはその方向ベクトルの絶対値 sqr( x2^2+y2^2 )* abs( x1^2+x1^2)
× でabsはその方向ベクトルの絶対値 sqr( x2^2+y2^2 )* abs( x1^2+x1^2) ○ でabsはその方向ベクトルの絶対値 sqr( x1^2+y1^2 ) と sqr( x2^2+y2^2 )
944 :
921 :2005/10/12(水) 15:29:23
>>942 有難うございました。
>>モジュラ演算は無視して良いですか?
> 結果が-300度とかになっても問題なければ無視してもいい
> +90度と-90度も 線分の場合は区別する場合と、区別しない場合もあるしね
あ、これは重要ですね。
C/C++標準ライブラリにあるかどうか知りたいです。
(自分でググりますが、「モジュラ演算とは」だと0件ですた)
よーだ:ルーキー、fmod()をつかえ。
>>944
次スレは950が建てるの?
948 :
デフォルトの名無しさん :2005/10/12(水) 16:19:11
2点間の距離を出すC/C++標準ライブラリとかあるんでしょうか?
950 :
949 :2005/10/12(水) 16:43:38
ちなみに正確な距離を出したいのではなく遠い近いを比較したいだけならnorm()で十分。
hypotを使った方がいいよ sqr(dx^2+dy^2) == hypot(dx,dy)
952 :
950 :2005/10/12(水) 16:46:45
>>951 C/C++の標準ライブラリにはないXe(希ガス)。
954 :
デフォルトの名無しさん :2005/10/12(水) 16:53:11
>>950 なんか、
[C++ Error] : E2268 Call to undefined function 'norm'
みたいでつ。
955 :
デフォルトの名無しさん :2005/10/12(水) 16:54:22
>>955 #include <math.h> で hypot( dx, dy)が使えると思うよ。 ダメだったら諦める
958 :
955 :2005/10/12(水) 17:10:57
959 :
949 :2005/10/12(水) 17:11:20
960 :
955 :2005/10/12(水) 17:12:30
>>957-958 ANSI C/C++、POSIXなどの標準規格では<cmath>や<math.h>には含まれないが
UNIX環境では割とあることが多いらしいそうな。System V系にはあるそうな。
後は処理系によってあったりなかったり。
>>961 Blitz++
MTL
POOMA
A++/P++
・・・なんてのがあるらしいよ。あとはこのキーワードでググってみて管祭。
>>963 >>964 ダウンロードしたり、演算リンク集なんか見てみましたが、
巨大だし、ドキュメントは英語ですね。
自作するよりは良いんでしょうが、大変そう。
>>965 自作するよりはよいどころではなく多分割と劇的に性能が違うと思うよ。
特にある程度以上の大きさの行列では。
968 :
965 :2005/10/12(水) 17:56:03
劇的に良いわけですか。 質問ばかりですみませんが、座標系(言い方変ですか?)のライブラリのデファクトはどうなんでしょう? やりたい事は、座標変換や面積計算やトポロジー的なことです。2次元、将来3次元かもです。
数学的な問題を解くのが目的か、グラフィックスとかの応用が目的か、
問題の規模や、リアルタイム・アプリケーションなのかそうでないかとか
あるいは単に宿題や趣味プログラミングかとか
その辺が分からないとなんともいえないよね。
例えば
>>966 で紹介したライブラリ群とかは
概ね浮動小数点演算で大規模な問題を効率よく解くのには向いているが、
3次元で展開するリアルタイムゲームのエンジン部分とか
小さな行列をリアルタイムで解くような問題にはあまり向いてない。
また3Dグラフィックスならむしろグラフィック・ハードウェアの
演算機能を生かす必要があるから一般的な行列ライブラリより
OpenGLとかDirectXとか考えたほうがいいわけだろうし。
グラフィックスとかの応用が目的で、リアルタイムじゃないものお願いします。
グラフィックへの応用が目的なら、勉強がてらそこらへん自作するのも手だよ。 結局、応用するには基礎が出来てないとどうしようもない。 基礎を勉強するには、一度は苦労しないとね
>>961 >>964 >966
用途によっては
Boost::numeric::ublas
も使えるかも。Boost準標準だし。
しかし、2直線が挟む角度を求めるだけで、 こんなに話を膨らませられる君たちは天才だね。
なんなら、2直線が平行に近い場合の ArcCos内積 を使う場合の精度問題について膨らませてもいいぞ。