計算アルゴリズム

このエントリーをはてなブックマークに追加
246デフォルトの名無しさん
任意のラジアンを、[-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π)かなあ?
>>251
アフォですか?
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
>>262
周波数カウンタで測定した結果とか
>264
ところが、
log2(15439054)≒23.88
64bit浮動小数点だと仮数部52bitで、29bitぶんくらいしか小数に割り当てられない。
そんな議論をするよりも、15439054.2345ラジアンなんて値が出てくる
>>246のプログラムを見直した方が早いような気がする。
最初から 32bit整数の最大最小を -π〜π に
割り当てておけば足し算引き算で桁あふれを考慮しないだけで自動的にモジュラ演算になる


>>267
>そんな議論をするよりも、15439054.2345ラジアンなんて値が出てくる
> >>246 のプログラムを見直した方が早いような気がする。

15439054.2345 は外部からいきなり入力されて来るのでは?
>268
加減算だけなら。良い方法だね。
オーバーフロー検知する処理系も有るから注意。
そういう処理系では、回避する方法も普通ある。
271256:04/08/02 06:27
あのお、>>256はいかがでしょう。
>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の計算量はいったいいくつなんだ?
274256:04/08/02 20:55
>272
ありがとうございました。


あと調べてみたらfmod()とかremainder()とかいう関数も見つかった。
fmod(x, 2 * pi)
5.0145130137844731  (一回転ずれてるだけ)
remainder(x, 2 * pi)
-1.2686722933951131
(ともに倍精度)

ヘッダファイルから見つけただけで詳しい仕様は分からないけど
今回の目的そのものの関数みたい。
275246:04/08/03 10:03
みなさん、ラジアンの正規化の件ありがとうございました。
>>274
fmodはまさにそのものですね。おそらく内部的には
x - 2 * PI * floor( x / ( PI * 2 ) )
と似た事をやっているんだと思いますけど。
これでテストしてみます。ありがとうございました。
244 :デフォルトの名無しさん :04/07/29 23:46
カーナビにて
斜め上からの視点の地図を表示できるんだけど、
あれって2次元のノーマルな地図に何らかの処理をしてるんだよね?
その「何らか」がわかる人いたら教えて。
車に乗っててかなり気になった。


245 :デフォルトの名無しさん :04/07/29 23:48
>>244
さんかくかんすうってしってますか?


...三角関数は関係ないだろ?
画面の下の幅よりも画面の上の幅に広い距離が表示されれば良いだけなんだから
>>276
投影変換で
>>276
その 「何らか」 が、>>277 の投影変換なら、割と基本なので
知っている人はたくさんいると思うが。

そうではなくて
 2次元の地図データから、どうやって3次元データを推定しているか?
って質問なら答えは
 もともと3次元データを持っている。
ってことで。
ごめん。わかりにくかった。
別に >>277 が間違っていると言ってる訳じゃないです。
>>276 の質問の意味が別のところにある可能性も
考えただけです。
見てる位置(真上から、斜めから)が必要なんだからその時点で3次元だとおもうが。
>>280
そのへんは、F-ZERO式に処理することもできるけどね。
>>280
そんなことを質問しないだろ。
最近のカーナビではビルや立体交差がそれなりに
立体っぽく表示されるから、それをきいてんだと思う。
おまえら違うぞ。
>>276 は コピペで、
>>244 の質問に >>245 が関係無いこと言ってると思うがどうよ?
ってことだな。

回転のところで三角関数は使うが、3D→2D写像では使わん。
確かに関係無いな。
>>244が何を知りたいのか曖昧だから>>245が関係ないのかどうかもわからん。
>>284
2次元の地図を斜めに表示してるだけってことじゃないの?
>>1
この板の香具師はハードウェア(一般的にはCPU)の上で
物事実現してるだけなのに、さもゼロから全て考えたかのような
錯覚してる香具師が多い。おまいが考えたいことはズバリ
ハードウェアの設計に絡む事柄。よって板違い。でも数学板に
逝けという意味じゃないぞ。電子板へ逝けということ。
でもあっちはあっちで、この板とは別の数学アレルギーが
あるからな。注意しろw
>>286
自治厨ワラタ
また凄いのが湧いたな。
いかにも「夏ッ!」って感じのが。
289デフォルトの名無しさん:04/09/20 17:04:59
2つの整数の、整数比を求めるにはどうしたらいいんでしょうか。
(たとえば800と600なら4:3という整数比を求めたいんです)
290289:04/09/20 17:10:04
ユークリッドの互助法で
最大公約数を求めて割ってやればいいのか。
291FeaturesOfTheGod ◆UdoWOLrsDM :04/09/20 20:11:10
Re:>289 ぶっちゃけ、整数m,nの整数比はm:nなんだけどね。
292デフォルトの名無しさん:04/09/21 01:00:10
多倍長整数や多倍長浮動小数点数とかそれらの複素数化とか
いろんな数値クラスを作って勉強しています。ちなみにC++使っています。

それらの数値クラスに対して三角関数を始めとして
いろんな数学的関数を用意してあげたいと思っています。
全ての関数を全ての数値クラスに対して個別に用意するのは手間なので、
最初は計算アルゴリズム用の抽象クラスで多くをカバーしたいと思います。
パフォーマンスは落ちると思いますが
高速化については必要に応じて後から特殊化したいと思っています。

三角関数そのものについては良くある話らしく
様々なアルゴリズムの書籍で紹介されていました。
しかしそれ以外となると見付けるのが大変です。
この手の情報を分かりやすく紹介しているサイトはありませんでしょうか?
あと、もし何か面白いアルゴリズムがあれば教えてください。
よろしくお願いします。
293デフォルトの名無しさん:04/09/21 01:05:13
『Javaによるアルゴリズム事典』
とか。
294 ◆FIcNi4f8js :04/09/21 03:20:09
>>292
あなたの作ったライブラリで e^(iπ) = -1 を証明してください。
295デフォルトの名無しさん:04/09/21 03:27:02
296デフォルトの名無しさん:04/09/21 08:57:51
>>294
それって証明じゃなくて検算じゃねーの?
297デフォルトの名無しさん:04/09/21 13:34:45
298デフォルトの名無しさん:04/09/25 04:17:33
四則演算を正確に行えるライブラリで
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が表示されたときの充足感は貴重なので一度は計算してみることをおすすめする。
299デフォルトの名無しさん:04/09/27 00:55:02
--------------- めでたく終了 ---------------
300FeaturesOfTheGod ◆UdoWOLrsDM :04/09/27 08:27:43
Re:>299 何が終了した?
301デフォルトの名無しさん:04/09/30 02:02:09
302FeaturesOfTheGod ◆UdoWOLrsDM :04/09/30 08:40:25
Re:>301 お前に何が分かるというのか?
303デフォルトの名無しさん:04/10/01 21:26:02
>>302
おまえがばかってこと
304FeaturesOfTheGod ◆UdoWOLrsDM :04/10/01 22:35:40
Re:>303 要するに、お前は私の能力を理解できないわけだ。
305デフォルトの名無しさん:04/10/02 00:00:44
>>304
このスレお前のコテで検索したけど、
基本情報レベルのことしかいってないじゃん。
306デフォルトの名無しさん:04/10/02 00:01:11
>>304
あといちいち挙げんな低脳
307デフォルトの名無しさん:04/10/02 01:11:34
>303-304

>183, >237-238
証明終了。
308FeaturesOfTheGod ◆UdoWOLrsDM :04/10/02 15:06:27
Re:>307 お前日本語は分かるか?
309デフォルトの名無しさん:04/10/02 15:25:20
>>308
I'm exactly a nature English speaker.
What do you have a question?
310デフォルトの名無しさん:04/10/02 19:04:29
まったりいこーやー、世の中色んな人がいるって。
人に自分の正義を強要しだすと進む話も進まなくなるわな。

ちなみにこのスレの目的は?
そんなに気合入れてち盛り上がるトピックではないと
思うんでゆっくり進めていけばいいと思うんですけど。
311FeaturesOfTheGod ◆UdoWOLrsDM :04/10/02 19:58:41
Re:>309 I guess I'm the greatist mathematician.
312デフォルトの名無しさん:04/10/02 20:07:29
>>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.
313デフォルトの名無しさん:04/10/02 20:13:35
>>311
Don't up to the thread.
You must write 'sage' to E-mail cell.
314デフォルトの名無しさん:04/10/02 20:24:20
自作自演おつ
315デフォルトの名無しさん:04/10/02 20:25:01
don't make this thread upじゃねーかなぁ
316デフォルトの名無しさん:04/10/02 20:25:33
        / /  ,. '´   ,. ---`,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---', '´    ',
  | \| |  していたようだ         
317FeaturesOfTheGod ◆UdoWOLrsDM :04/10/02 20:39:13
Re:>312
If you feel my documents difficult, you are a silly person.

Re:>316
お前に何が分かるというのか?
318デフォルトの名無しさん:04/10/02 21:14:23
319デフォルトの名無しさん:04/10/02 21:40:28
>>317
Your articles are michy-mouse(w
What can you know about us?
320FeaturesOfTheGod ◆UdoWOLrsDM :04/10/02 22:15:19
Re:>319 I cannot understand what you are saying.
321デフォルトの名無しさん:04/10/02 22:56:48
>>316じゃないけど、アホなFeaturesOfTheGodのために>>316を解説してやると
>>309では
>What do you have a question?
と言われているのに、
>I guess I'm the greatist mathematician.
と関係のない(questionでない)ことを言っているので>>316から
>>311はとんでもない勘違いをしていたようだ
と言われるわけだ。わかった?
322デフォルトの名無しさん:04/10/02 23:11:03
なんだ。FeaturesOfTheGodって、ただの荒らしじゃん。
アルゴリズムを期待してたのに。
323デフォルトの名無しさん:04/10/02 23:22:14
> ただの荒し
< 馬鹿で異常性格者
324デフォルトの名無しさん:04/10/02 23:32:41
英語が下手だな。
325デフォルトの名無しさん:04/10/03 00:38:40
が→も
326デフォルトの名無しさん:04/10/03 00:44:34
>>320
Your English speaking skill is very poor.
I think your article is no use.
327デフォルトの名無しさん:04/10/03 00:50:36
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 だろ。それでもまだ変だが)
329デフォルトの名無しさん:04/10/03 00:59:23
imageでもいいんだけど、そういう場合には普通imagineを使う。
音の流れがいいんだろう。ついでに、he(she?)はhe/she/itと
書いてやるとアレっぽくてナイス。その後はグダグダなので書き直し。
330デフォルトの名無しさん:04/10/03 01:00:18
レス書いてるうちに書かれた

>>328
残念ながらimageにはimagineの意を持つ動詞用法もある。辞書を引いて確認してね。
331デフォルトの名無しさん:04/10/03 01:01:21
スレ違い
332デフォルトの名無しさん:04/10/03 01:21:42
Most King's postings are directly written on books.
333デフォルトの名無しさん:04/10/03 13:25:10
King ran away(w
334デフォルトの名無しさん:04/10/03 14:09:49
>>1は数学板でも嫌われている本人は自覚していない荒らしです。
非常にたちが悪いです。
335デフォルトの名無しさん:04/10/03 15:34:00
>>320
Can you tell your friend about your contribution in 2ch?
Not ashamed?
336FeaturesOfTheGod ◆UdoWOLrsDM :04/10/03 16:57:24
Re:>332 Merely that's a superstition.
337デフォルトの名無しさん:04/10/03 18:59:28
>>336
You're wrong. They are exact.
338デフォルトの名無しさん:04/10/03 19:03:08
>334
だな。
自分で立てたスレすらスレ違いの英文で荒らしたり、
程度の低い煽りにのせられてるし。

>336
お前が居ない時の方がこのスレまともに機能してるんで、
スルー出来ないなら鬱陶しいから消えてくれ。
339デフォルトの名無しさん:04/10/03 19:19:13
>>338
ちょっとまて消えたら俺らの保父さんは?バブーもっと遊んでー。

まぁなんだ、英語力を誇るのは恥ずかしいな。
英語力がないのを恥じるのは分かるんだがあるのを自慢されても・・・
ガイジンさんが日本語能力を自慢しているところを想像してみなさい!
340デフォルトの名無しさん:04/10/03 20:57:45
I can't quite get over the fact that Inhabitants of this board
cannot make out English.
341デフォルトの名無しさん:04/10/03 21:55:42
>>339
本人は英語力があるのを自慢しているつもりでも
周りから見れば度素人の糞文だからいいんだよ

七誌のほうは腐りすぎてて読む気も失せるんだがな
342デフォルトの名無しさん:04/10/03 21:59:04
Enginner needs speaking English.
343デフォルトの名無しさん:04/10/03 22:05:03
>>341
しー
344デフォルトの名無しさん:04/10/03 22:11:23
>>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 だし、、、
これでも英語で書き続けるのかねえ。
346デフォルトの名無しさん:04/10/03 22:36:35
347デフォルトの名無しさん:04/10/06 08:09:10
今のKingって何代目?
348デフォルトの名無しさん:04/10/06 09:10:15
Version 3.14159
349デフォルトの名無しさん:04/10/06 09:24:34
最近のKingタン、害虫に似てきて鬱
350LettersOfLiberty ◆rCz1Zr6hLw :04/10/06 12:06:11
速い計算方法は、既に今持っているソフトに入っていたりして?
351デフォルトの名無しさん:04/10/06 17:16:59
荒らしが自分の名を騙られたからという事で名前を変えたようです。
352デフォルトの名無しさん:04/10/11 19:03:12
King ありえないよ King
353LettersOfLiberty:04/10/11 20:11:23
うんこ食べたい
また、名前変えてみましたづら
355LettersOfLiberty ◆rCz1Zr6hLw :04/10/12 16:55:58
Re:>352 また何を言い出すのか?
Re:>353 お前こんなところにまで出張すんな!それにお前誰だよ?
Re:>354 お前何を企んでいる?
Re:>355 そっちこそオラのスレで何をするづら!
357LoL ◆WBRXcNtpf. :04/10/13 03:09:11
>>354-356
面倒なので省略しました
358LettersOfLiberty ◆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
     (原点)
360デフォルトの名無しさん:04/10/13 22:43:38
>>359
sin(x) = Σx^k / k!  (k ∈ odd)
cos(x) = Σx^k / k! (k ∈ even)
でいいだろ。
361LettersOfLiberty ◆rCz1Zr6hLw :04/10/14 16:32:20
Re:>360 Hyperbolic sine, hyperbolic cosine か。何やってんだよ?
362デフォルトの名無しさん:04/11/05 23:37:54
量子コンピューターが出来たらみんな解決だね!by小柴さんw
363デフォルトの名無しさん:04/11/05 23:50:45
>>362
量子アルゴリズムを考えなくちゃいけない。
別の仕組みのコンピュータで最適なアルゴリズムを考える必要があるから
一般にそう簡単に解決できない。
量子コンピュータで魅力的なのはいまのところ素因数分解やデータベース検索以外に何があるの?
shorからいったいどれだけ進んでるの?
364Conscientious Irrationalist ◆ZETA.aMskA :04/11/26 20:50:15

         FoG (若しくは LoL)、貴様は何を知りたいのだ?
365BlackLightOfStar ◆ifsBJ/KedU :04/11/26 22:31:34
Re:>364 速いexp,log,sin,cos,tan,sqrt,atan.
366デフォルトの名無しさん:04/11/26 22:32:29
>>362-363
計算しても結果を取り出す方法がない。
367Conscientious Irrationalist ◆ZETA.aMskA :04/11/26 22:36:26

>>365
君のメールアドレスを俺に教えろ。
気分がのればいくつかのアルゴリズムを送ってやる。
368デフォルトの名無しさん:04/11/27 00:19:22
要素が19万個存在するデータが2つありその差分をとりたいのですが、
LCSをメモリをあまり使用せず実装する方法ご存知ありませんか?
現在だと16000ぐらいでメモリを使い果たしてしまって困ってます
369デフォルトの名無しさん:04/11/27 03:19:15
1要素はどんなデータ?
370デフォルトの名無しさん:04/11/27 16:14:33
最長共通部分列は英語では、 longest common subsequence と呼ばれ、頭文字をとってLCSという。
371デフォルトの名無しさん:04/11/27 22:21:10
char だったらその程度で破綻しないと思うが
372368:04/11/28 01:55:53
要素はですね、
1ページ20kb程度のメモリダンプのログがあって
最長で19万ステップ分のダンプログの比較とかをしたいのですが、
比較するときの良いアルゴリズムを知らないせいで16000ぐらいで、
メモリを512MBも消費してしまうため、何か良い手法を探しています。
373デフォルトの名無しさん:04/11/28 02:00:49
>>372

ファイルに書き出せばよい、という問題でもないのですよね。
もうちょっと具体的に問題設定が欲しいかも。
ステップとページの関係がよくわからないです。
374デフォルトの名無しさん:04/11/28 02:02:48
ブロック単位での処理でいいのならハッシュ取っておくとか。
375デフォルトの名無しさん:04/11/28 02:03:15
近似アルゴリズムでいい?
ページのハッシュ列でLCSを計算して終了。
376375:04/11/28 02:03:49
>>374
ケコーン
377デフォルトの名無しさん:04/11/28 02:04:53
CRC
378デフォルトの名無しさん:04/11/28 10:10:53
「珠玉のプログラミング」に出てきそうなネタだね

要素数が違う場合もあるんだよな?
差分を取るって事は、大部分は同じで極一部だけが違ってて、その違いを知りたいって事だよな?

orz‥頭のいい人ヨロ
379デフォルトの名無しさん:04/11/28 10:33:01
両方ソートしてからマージっぽく比較していけば?
メモリを消費してしまうというのがよく分からんが。
380デフォルトの名無しさん:04/11/28 10:34:00
わからんのでググった

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
381デフォルトの名無しさん:04/11/28 16:25:24
>372
すべてのファイルで一致する最長のバイナリ列を求めればいいんでしょ?

1.1件目と2件目を比較して、一致する部分の配列を新たに作成。
  >[バイト数, 抽出したバッファ] * 一致した個所の個数だけ
2.比較結果の配列と3件目を比較して、配列を再構成。
  >この時、3件目と一致しない要素は削除出来るので計算量は減っていく
3.以後4件目、5件目・・・と繰り返し。

LZ法みたいに「位置と長さ」だけ残しといて、
データの比較をする時は1件目とn件目、とかでもいいけど。
382tokoro:04/11/28 19:48:21
二分検索より速い検索アルゴリズムってあるのですか?
383デフォルトの名無しさん:04/11/28 19:52:07
計算量の話ですか?
384デフォルトの名無しさん:04/11/28 20:02:04
>>382
条件による。
385tokoro:04/11/28 20:25:13
条件は、検索される対称がソートされているとした場合です。
例えば、1,2,3,4,5,6,7,8,9,10,.......の中で、ある数字を検索する、といったものです。
386tokoro:04/11/28 20:28:36
計算量というのは、よくわからないですが、この場合に利用できる
私が知っている検索方法として線形検索と二分検索があり、検索対象がソートされているという条件のものでは
二分検索の方が一般的に速く検索できる、....
この意味での『速い』です。
387デフォルトの名無しさん:04/11/28 20:29:26
4を探したければ、4つめを見ればいい。
388デフォルトの名無しさん:04/11/28 20:36:49
>>387
radix searchだな。
389tokoro:04/11/28 20:37:15
>>387
すいません、検索対象がところどころ飛んでいたら..としてみて下さい。
例えば、3,100,2000,1555555,364256787, ....
の中から 1555555 を探す場合です。
390デフォルトの名無しさん:04/11/28 20:53:05
>>389
一般的には二分法を元にした方が速いけど、データの量や質、構造によっては
ハッシュ値を元に探したほうが速いかもしれないし、
二分法で探したほうが速いかもしれないし、
素直に先頭から探していったほうが速いかもしれない。
複数の探査方法を組み合わせることもある。
391デフォルトの名無しさん:04/11/28 20:53:09
ただ二分探索と線形探索以外の探索アルゴリズム知りたいだけなんじゃ
392tokoro:04/11/28 20:57:02
>>391
二分探索と線形探索以外 でかつそれより速いものを知りたいのです。
393デフォルトの名無しさん:04/11/28 20:57:56
データの偏り方によっては(ry
394デフォルトの名無しさん:04/11/28 21:27:15
>>392
検索しないのが一番速い
例えば>>387みたいなやつ
395デフォルトの名無しさん:04/11/28 21:29:03
対象が飛んでても関係ないよ
メモリを馬鹿食いするだけ
396tokoro: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
基数ソート書いてもらえませんか?
399デフォルトの名無しさん:04/11/28 23:53:57
アルゴリズム事典読んどけ。
400デフォルトの名無しさん:04/11/29 02:33:38
>一般には遅くなるけどソート列のデータが比較的均等な間隔で
>並んでいる場合はちょっと速いとか。。。。

というかそういう場合にしか使えないだろうと。。。
401デフォルトの名無しさん:04/11/29 03:24:43
>>397
内挿探索だな。二分探索よりも計算量の上でも速いらしい。
402デフォルトの名無しさん:04/11/29 08:50:43
>>396
table[n] = -1;

table[3] = 0;
table[100] = 1;
table[2000] = 2;
table[1555555] = 3;
 :

1555555は3番ですね
403デフォルトの名無しさん:04/12/08 01:12:58
>402
ワロタ(藁

まぁでもそういう話だよな。
連想配列使うにしても、内部の実装は良くて二分探査、
下手したら線形探査だろうし。

データの偏りとそれに対するアルゴリズムの向き不向きくらいは考えられないと、
プログラマとして生きてる価値無いと思われ。
404デフォルトの名無しさん:04/12/08 08:15:35
連想配列ならハッシュだろ
405デフォルトの名無しさん:04/12/08 09:19:12
うーん、結構多くの実装は赤黒木じゃない?
VC++とかlibstdc++とか

ハッシュは振る舞いが安定的じゃないから。
amortizeしないとinsertの計算量がO(n)になっちゃうし。

>>403
君も結構やばいかも(w
406デフォルトの名無しさん:04/12/08 13:00:03
>>405
perl は連想配列のことをハッシュって呼ぶくらいだし、ハッシュでの実装じゃないの?
あと、C++ の STL も、非標準だけど、hash_map ってのがあるよ。
407デフォルトの名無しさん:04/12/08 13:32:05
ハッシュもバランス探索木も両方良く使われるよ。

> ハッシュは振る舞いが安定的じゃないから。
これは実装かハッシュ関数が悪い。

> amortizeしないとinsertの計算量がO(n)になっちゃうし。
そんなこたあない。(というか最悪と平均とamortizeの違いを理解してないんだろう)
408デフォルトの名無しさん:04/12/10 16:51:35
ある個数の整数列が存在するとします。例えば、2から17までの16個の整数があるとし、
このとき、この整数列を2グループに分け、一方のグループに属する数の平方根の和と
もう一方のグループに属する数の平方根の和との間の差が最も小さくなるような、グループ分けの
方法を発見する。このようなことを行なうにはどうしたら良いですかねえ。
409デフォルトの名無しさん:04/12/10 17:45:29
>>408
ナップサック問題 or ナップザック問題でクグる。
410デフォルトの名無しさん:04/12/10 18:23:55
>>408
グループの数の和が小さい方のグループに元の数列から降順に追加していく。
和は平方根のでもどちらでもいいと思う。
411デフォルトの名無しさん:04/12/11 02:51:41
>>408
平方根の和が平方根の合計の半分に近い選び方を適当に選べばいいんじゃない?
412デフォルトの名無しさん:04/12/11 03:06:55
>>408の16個の例だと、全検索でも32768パターンだな。
413デフォルトの名無しさん:04/12/11 03:50:28
>>410
残念だがこれは0-1 knapsackなので、そういう
greedyなやり方では最適解を見逃してしまうよ。

>>412
問題のサイズが固定だから、そういうアプローチも確かに一つの見識だな。
414デフォルトの名無しさん:04/12/11 15:49:46
>>412
ん?もっとパターンあるのでは?
8個と8個に分けるとは限らないだろ。
2グループとしか言ってないんだから。
415デフォルトの名無しさん:04/12/11 16:12:04
ここまでのレスでは数列が「整数」列という条件はまだ誰も使ってないな。
実はこの条件を使えば魔法のように解けるんだよ。

平方根ってのにも気づいてるか?これ幾何的解法の存在の隠喩なのさ。

まあ、オマエらのような馬鹿にはこの程度のヒントじゃどうにもならんだろうが。

と、まっっったく何の見通しもなく言って orz 休日の釣りを楽しむテスト
416デフォルトの名無しさん:04/12/11 16:18:44
>>408
差が最も小さくならないと死んでしまうこたあないだろう。
文句言うにもそれ以上の計算時間掛けなきゃいけないから
俺は忙しいんだと言って適当に打ち切れよ。
417デフォルトの名無しさん:04/12/11 16:20:00
>>414
15bitの整数は32768個では?
418デフォルトの名無しさん:04/12/11 16:48:49
>>414
> 2グループとしか言ってないんだから。
単純な数え上げもできないやつは黙ってるように。
419デフォルトの名無しさん:04/12/11 17:19:27
32767通りだと思います。
420デフォルトの名無しさん:04/12/11 17:48:42
>>417
> 15bitの整数は32768個では?
16bit目を0か1に固定してるから、00...0か11...1かのどっちかは含めることができないんだよ。
421デフォルトの名無しさん:04/12/11 22:58:03
>>416
> 差が最も小さくならないと死んでしまうこたあないだろう。

ワラ

応用編:
・全部順番に並んでないと死んでしまうこたあないだろう。
・誤差ε内に収まらないと死んでしまうこたあないだろう。
422デフォルトの名無しさん:04/12/12 09:51:49
>421
その程度出来ないとクビは切られそうだがな。
423デフォルトの名無しさん:04/12/12 16:44:13
・この程度のプログラムも書けないと死んでしまうこたあないだろう。
424デフォルトの名無しさん:04/12/12 20:00:25
100!の100!乗-1は素数です。
425デフォルトの名無しさん:04/12/12 21:52:15
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;
}
426デフォルトの名無しさん:04/12/12 22:33:21
ねたですか?
427デフォルトの名無しさん:04/12/13 00:11:39
露出狂なんだろう
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)+--+--+--+--+
となります。
初期配置はランダム。
すべてを白、または黒にするのに必要な最小回数を求める。(求まらない時もある)
429428:04/12/13 14:00:22
総当たりでいくしかないという結論に至ったのですが、どれだけの数があるのか
検討がつきません。人に聞いたところ2の16乗あると言われたのですが
もっとあるような・・・。
何かアイデアや質問とかあったらお願いします。
430デフォルトの名無しさん:04/12/13 14:50:17
431428:04/12/13 19:20:11
>430
ありがとうございました!!
すごい感動。
432デフォルトの名無しさん:04/12/13 22:34:54
ここでいいかわからないけど、質問させてください。

アルゴリズム関係のWEBを探していたら、次のような所が見つけました。

ttp://tcslab.csce.kyushu-u.ac.jp/~u1/algo/report2.html
ttp://tcslab.csce.kyushu-u.ac.jp/~u1/algo/report3.html

個人的に結構興味深かったから何度も読んでみたのですが、いまいち理解できないんです。

理解した範囲では、文字数をNとすると2^Nのループ回処理を行うというように思えます。
例えば文字数が1000ならば、2^1000=1606938044258990275541962092341162602522202993782792835301376回のループの処理を行うという判断でいいのでしょうか?

それだと全然終わらないと思えるのですが、問題では2000文字以上の文字数だから、そんな問題出すとは思えないし...

何か理解が間違っているようでしたら、指摘ください。
433432:04/12/13 22:37:18
済みません一部間違えました。

>例えば文字数が1000ならば、2^1000=1606938044258990275541962092341162602522202993782792835301376
↓↓
>例えば文字数が200ならば2^200=1606938044258990275541962092341162602522202993782792835301376

でした。
434デフォルトの名無しさん:04/12/13 23:06:03
>>432
片方の文字列を一文字ずつ回転させて比較し最長の一致文字数を探すからN^2かN^3かな。
435デフォルトの名無しさん:04/12/14 00:04:53
王(長島)
436432:04/12/15 00:01:27
>>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超えると人間の生きている内には終わらない)と言われているので
もっとよいアルゴリズムを考える必要がある。
そのアルゴリズムとして、動的計画法としてそのページでは書いてあるようだ。
指摘する場所検討違いならスマン。
438デフォルトの名無しさん:04/12/15 00:30:07
訂正
×そのアルゴリズムとして、動的計画法として
○そのアルゴリズムとして、動的計画法が
439432:04/12/15 00:48:39
>>437
あ、やっぱり私の理解は合ってましたか。
漸くスッキリしました。

その後、動的計画法についてもいろいろ調べたので、他の方法は理解していたのですが、
このしらみつぶし法だけが非効率過ぎて納得できていませんでした。
これで頭を悩ませなくて済みそうです。
どうもありがとうございました。
440デフォルトの名無しさん:04/12/15 00:52:33
>>439
一応言っておくと,これはLCSといってDPの中でも有名な問題.
441デフォルトの名無しさん:04/12/15 18:38:41
大学のC言語演習でわからない問題があったのでおしえてくれませんか?

<問題>
文字列s1、s2を引数で受け取り、s1に文字列s2が含まれているかどうかを調べる関数searchを作成しなさい。
実行結果は、含まれているならば1を、含まれていないならば0をそれぞれ返すようにしなさい。
文字列検索関数strcmpなどは使用しないこと。

あと、string.hのインクルードも禁止らしいです。
442デフォルトの名無しさん:04/12/15 19:58:14
>>441
そうか。それはよい問題を出してもらったね。
でも教えてあげない。
443デフォルトの名無しさん:04/12/15 20:30:28
>>441
てか、宿題スレで答えてもらってたじゃん
444デフォルトの名無しさん:04/12/15 20:50:15
わからなければ質問すればいいってのは見事に能無し養成教育の賜物だなあ。

それにしてもこれしきも自分でやろうとしない奴が大学生とは聞いてあきれる。
どこの大学よ。
445デフォルトの名無しさん:04/12/15 21:04:07
>>441
どッかで答えた記憶があるぞ
たしか"abc"が入っているかどうかってやつ
446デフォルトの名無しさん:04/12/15 22:19:37
>>432
パクリチェックに使えませんか。
447デフォルトの名無しさん:04/12/16 00:14:13
>>441
system関数でgrepコマンドを呼び出して、s1, s2をコマンドライン引数に当てる。
strcmp関数は使用してないし、string.hのインクルードもしてない。









これで君のレポートは0点確実だ。
448デフォルトの名無しさん:04/12/16 00:19:50
マルチに仕立て上げて宿題答えさせないためのコピペ厨だろ、どうせ。
449デフォルトの名無しさん:04/12/16 00:25:20
>>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;
}
451450: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
452デフォルトの名無しさん:04/12/16 01:44:46
>>448
なにか問題が?
453デフォルトの名無しさん:04/12/16 02:47:39
>>451
ワラタ
454デフォルトの名無しさん:04/12/16 08:06:47
正規表現でマッチしてしまうのと、標準出力に出てくるので
仕様に反しており0点です
455デフォルトの名無しさん:04/12/16 08:18:12
grep -sだなって…板違いやんか!
456450:04/12/16 15:44:26
fgrep -s だったらええんちゃうか?
正規表現は使えんし、 /dev/null へリダイレクトしてくれるから >>454の課題はクリアしてるけど。(w
457450:04/12/16 15:46:45
まあ、>>441は grep のソースコードでもじっくり読んで勉強せぇや。
458450:04/12/16 15:52:45
>>456
-q もいるのかな?
459デフォルトの名無しさん:04/12/16 16:25:01
>>457
じゃあ450は441のためにFAをさくっと解説してやってくれや。


460デフォルトの名無しさん:04/12/16 16:32:59
s1やs2にスペースが入ったら>>456も0点
461デフォルトの名無しさん:04/12/17 00:31:41
その程度の問題が解らない大学生がバカなのか、
車輪の再発明をさせるような問題出しちゃう
教授だか講師だかがバカなのかは知らんが、
スレタイ読めない>441がメクラだってーのは理解した。
462デフォルトの名無しさん:04/12/17 02:41:20
おまえら、それ以前に sizeof(s1) とかって気にならんのか?

それでええのんか?
463デフォルトの名無しさん:04/12/17 02:53:06
450も厨なのは自明なのでどうでもいい。
464デフォルトの名無しさん:04/12/17 03:09:34
すげえ
>>450得意気
465デフォルトの名無しさん:04/12/17 03:54:56
車輪は大いに再発明されるべきだと思っちゃうな。
漸次良い車輪が生き残るだろうし。
466デフォルトの名無しさん:04/12/17 03:56:36
再発明だったらいいけれど、再発見は必要無し。
467デフォルトの名無しさん:04/12/17 08:56:36
教えてないのにBM法考えついて実装する学生がいたら
先生やめたくなるだろうな
468デフォルトの名無しさん:04/12/17 09:02:07
それでも車輪の歳発明なんだけどな。
>>461は初心者が次々新発見しないと講師が馬鹿だと思うらしい馬鹿だが。
469デフォルトの名無しさん:04/12/17 09:09:45
作ってみるのはいいんじゃないの?
うまく回すためにはいろんなことを考えないといけないんだし。
470デフォルトの名無しさん:04/12/17 10:36:17
BM法なんて大学まで来て教わるまでもなくどっかで見て知ってるだろ。
数式がいるわけでもないから小学生でも実装できる。
471デフォルトの名無しさん:04/12/18 00:15:12
スレタイ見てうきうきして来たらずいぶんレベルが低くなってるじゃぁないか.
1はどこいった?
472デフォルトの名無しさん:04/12/18 01:57:55
>>235=>>124です。
http://www.hackersdelight.org/ ←この本翻訳出たよ。
473デフォルトの名無しさん:04/12/18 07:59:52
>>471
数学板で昔からあばれてる香具師だろ
474デフォルトの名無しさん:04/12/20 00:51:16
>>472
マジスカ?
アマゾンでは見つけられなかったよ
475デフォルトの名無しさん:04/12/20 07:01:33
476デフォルトの名無しさん:04/12/20 09:55:33
http://www.amazon.co.jp/exec/obidos/ASIN/4434046683/
ハッカーのたのしみ―本物のプログラマはいかにして問題を解くか

ありますた!
477デフォルトの名無しさん:04/12/21 19:59:33
> 本物のプログラマはいかにして問題を解くか
FORTRANで
478デフォルトの名無しさん:04/12/21 22:09:30
Pascalでなく
479デフォルトの名無しさん:04/12/22 01:00:05
>>10 見てマジ!?と思ったけど、
>>12 見て笑った。

やっぱ2chは2chだな。
480デフォルトの名無しさん:04/12/23 02:12:55
テンプレ

The Art of Computer Programming Volume 1 Fundamental Algorithms Third Edition
著:Donald E.Knuth
http://www.amazon.co.jp/exec/obidos/ASIN/475614411X/

The Art of Computer Programming Volume 2 Seminumerical Algorithms Third Edition
著:Donald E.Knuth
http://www.amazon.co.jp/exec/obidos/ASIN/475614411X/

岩波講座 ソフトウェア科学(3) アルゴリズムとデータ構造
著:石畑 清
http://www.amazon.co.jp/exec/obidos/ASIN/4000103431/

アルゴリズムC・新版―基礎・データ構造・整列・探索
著:Robert Sedgewick
http://www.amazon.co.jp/exec/obidos/ASIN/4764903091/
481デフォルトの名無しさん:04/12/23 08:35:41
>>480
クヌース
482デフォルトの名無しさん:04/12/23 23:19:03
The Art of Computer Programming, Volumes 1-3 Boxed Set
著:Donald E.Knuth
http://www.amazon.co.jp/exec/obidos/ASIN/0201485419/
バイブル。必読の書。枕。

Algorithms in C++
著:Robert Sedgewick
http://www.amazon.co.jp/exec/obidos/ASIN/020172684X/
そこそこ。

岩波講座 ソフトウェア科学(3) アルゴリズムとデータ構造
著:石畑 清
http://www.amazon.co.jp/exec/obidos/ASIN/4000103431/
日本語の中では良書。

差し替え。補充よろしく。
483デフォルトの名無しさん:04/12/23 23:42:39
Knuthは面白いけど、必読とは思いません。
いまやバイブルでもないし。

よいこはセジかコルメン他にしておきましょう。
484デフォルトの名無しさん:04/12/24 00:04:25
ご要望にお答えして

Introduction to Algorithms
著:Thomas H. Cormen, Charles E. Leiserson, Ronald L. Rivest, Clifford Stein
http://www.amazon.co.jp/exec/obidos/ASIN/0262032937/
485デフォルトの名無しさん:04/12/24 00:30:38
486デフォルトの名無しさん:05/01/01 18:29:09
質問です。重み付きの有向グラフにおいて、最長の一筆書きを得る
アルゴリズムをご存知の方がいらっしゃれば、ご教示ください。よろしく
お願い致します。
487デフォルトの名無しさん:05/01/01 23:29:55
最長の一筆書き?
488デフォルトの名無しさん:05/01/01 23:40:49
東大の鉄道研究会に聞けや
489デフォルトの名無しさん:05/01/02 00:33:38
よくわからないけど一筆書きだったらすべての辺を通るんじゃないの?
490デフォルトの名無しさん:05/01/02 00:43:29
全て通るのは辺じゃなくて節だろ
491486 ◆ALxfxYDG9M :05/01/02 01:16:47
申し訳ありません、「最長の一筆書き」では言葉がおかしいですね。
「重み付きの有向グラフにおいて、《すべての辺を通る必要はなく、
同じ辺は一度しか通ることができない》という前提を満たす経路のうち、
重みの和が最大となるものを求める」という問題です。
492デフォルトの名無しさん:05/01/02 01:18:30
プログラムで全パターン試行錯誤してください。
493486 ◆ALxfxYDG9M :05/01/02 01:26:58
そうですか…お手数をおかけしました。ありがとうございました。
494デフォルトの名無しさん:05/01/02 01:33:48
>>491
一筆書きじゃなくてハミルトン閉路といいます。
ハミルトン閉路とか巡回セールスマンでググれば出てくると思います。
495486 ◆ALxfxYDG9M :05/01/02 02:03:15
>>494
ありがとうございます。調べてみます。
496デフォルトの名無しさん:05/01/02 08:21:32
>>486
最長でなくとも死ぬことはない。
497デフォルトの名無しさん:05/01/03 00:41:44
>>495
http://www.swa.gr.jp/lop/

たぶんおまいさんのやりたい事の
そのものずばり答えがあるぞ。

もう遅いかもしれないけど。
498486 ◆ALxfxYDG9M :05/01/03 00:50:38
>>497
ご協力本当に感謝いたします。
499デフォルトの名無しさん:05/01/03 01:38:30
ドラゴンブックとかコンパイラの本読んでたんですが、
DAGってどうやって作るんでしょうか。
「閉路のない有行グラフ」
といわれてもさっぱりです。
持ってるどの本も概念的な説明だけで実装については
詳しくされてませんでした。

もうちょっと簡単なサンプルみたいなのが欲しいです。
例えば

d = b + c;
e = b + c;
a = e + d;

とかの式で b + cが共有されるのはわかるのですが、
プログラムとして表現しようとするとどうなるのかが想像つきません。
DAGの作成と、作成したDAGからコードに出力する簡単なサンプルや
アルゴリズムをご存知の方がいらっしゃれば、ご教示ください。
500デフォルトの名無しさん:05/01/03 18:36:12
アルゴリズムは本に出てるよな?
要するに、構文木を作る時に一手間掛けるって事だよ

漏れは作った事無いけど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 を生成した段階で、
この式は共有されてるわけだから、生成フラグみたいなのを用意して
二重に出力しない工夫をする必要がある
505デフォルトの名無しさん:05/01/03 19:20:45
>>499
>「閉路のない有行グラフ」
>といわれてもさっぱりです。

下手に "DAG" などとという数学的な言い回しに
囚われるから、抜け出せなくなる。
所詮プログラミングはエンジニアリングなのだから、
その「目的」と「効用」だけに注目すればよい。
506デフォルトの名無しさん:05/01/03 19:25:05
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

副作用とか考えると難しいかもな
507デフォルトの名無しさん:05/01/03 21:06:55
巡回セールスマンのオーダーっていくつなんですか?
O(n!)?
O(n^n)?
508デフォルトの名無しさん:05/01/03 21:11:09
>>507
アルゴリズムによる。
509507:05/01/03 21:25:25
総当りだといくつですか?
510デフォルトの名無しさん:05/01/03 21:38:50
それぐらい計算せえよ。高校生でも計算できるはず。
511デフォルトの名無しさん:05/01/04 07:55:02
総当たりってのは
 全部の経路の長さを計算して一番短いものをみつけるわけで
 全部の経路数はn! でもさ

じゃ全部の経路をどう探索するのか? データ構造をどうするのか?
512デフォルトの名無しさん:05/01/04 19:31:36
>>511
ノード数が n なら、辺の数もたかだか n(n-1)
必要メモリ量も O(n^2)
513デフォルトの名無しさん:05/01/06 10:14:45
>>499
> 「閉路のない有行グラフ」
> といわれてもさっぱりです。

形式言語と有限オートマトン入門―例題を中心とした情報の離散数学
http://www.amazon.co.jp/exec/obidos/ASIN/4339023396/
離散数学―コンピュータサイエンスの基礎数学 マグロウヒル大学演習
http://www.amazon.co.jp/exec/obidos/ASIN/4274130053/

この辺りを読めば?
独学最初には丁度いい難度だよ。
514デフォルトの名無しさん:05/01/09 13:33:42
質問です。
参加者数が変動する大会のトーナメント表を作りたいと考えています。
参加者数が変動するため、シードが一定数出るのですが、できるだけバラバラにシードを割り付けたいと考えています。

例えば以下のように割り付けたいのです。

12345678(試合目)
10000000:15人参加の場合
10001000:14人参加の場合
10101000:13人参加の場合
10101010:12人参加の場合
11101010:11人参加の場合
11101110:10人参加の場合
11111110: 9人参加の場合

(1がシードの試合)

この場合はどのようなアルゴリズムを用いれば良いのでしょうか?

(こちらは計算アルゴリズムに関してのスレッドですが、他に適当なスレッドが見当たりませんでしたのでこちらに書き込ませていただきました。
スレッド違いの場合は誘導願います。)
515デフォルトの名無しさん:05/01/09 14:21:52
言ってる意味がわかんね
516デフォルトの名無しさん:05/01/09 15:30:16
見たまんまじゃないの?
シード一人目が1、2人目が5‥になるようなプログラムを書くだけ
517デフォルトの名無しさん:05/01/10 12:56:02
>>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;
}

続く
518517:05/01/10 12:56:59
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); //結果表示
}
}
519517:05/01/10 13:00:49
実行結果。左から、参加者数、(一回戦の)試合数、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
520デフォルトの名無しさん:05/01/10 16:25:25
>>519
参加者が一人の時も、試合をやるのか?
521トリビア:05/01/10 16:28:22
自明な試合
522517:05/01/10 18:33:59
>>514
微妙に仕様を読み間違った。コメントが変なところあるけど、
プログラムはこのままで大丈夫だと思う。

>>520
決勝戦が不戦勝ということでお許しを。
523デフォルトの名無しさん:05/01/12 13:24:45
シード選手の場所、BYEの場所、試合順序は各競技団体のルールで定義されていたりする。
その辺りは大丈夫なんだろうか。
524デフォルトの名無しさん:05/01/16 21:29:14
六角形の敷き詰められたマップの距離を計算したいんですが
何かいい参考サイトはありますか?
525デフォルトの名無しさん:05/01/17 02:13:04
ランダムに並んでいる要素があるときに、昇順で最長の組み合わせを求めたいと思っているのですが、いいアイデアが浮かびません。

例えば

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とかの場合にはものすごく遅くなってしまいます。

いいアルゴリズムをご存知の方は教えてください。
526デフォルトの名無しさん:05/01/17 02:16:34
>>525
ナップサック問題に帰着。
NP完全です。
527525:05/01/17 02:25:25
>>526
そうなのですか...
諦めることにします。
どうもありがとうございました。
528デフォルトの名無しさん:05/01/17 02:33:48
>>526
おいおい、適当なことをいうなよ。
529デフォルトの名無しさん:05/01/17 03:23:15
あっさり騙される方もどうかしてるけどな。もともとやる気ナシと見た。

530デフォルトの名無しさん:05/01/17 03:57:58
>>528
正解は何?
531デフォルトの名無しさん:05/01/17 04:24:46
計算量についてなら、O(n^2)。


532デフォルトの名無しさん:05/01/17 11:31:04
O(n!) かと思った・・・
533デフォルトの名無しさん:05/01/17 11:40:05
で、いいアルゴリズムはないの?
534デフォルトの名無しさん:05/01/17 11:51:39
O(n^2)のアルゴリズム。
535デフォルトの名無しさん:05/01/17 12:02:39
長さだけなら下のプログラムで簡単に見つけれます。

#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;
}
536531:05/01/17 12:48:24
ヒントとしては、先頭から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)。
537デフォルトの名無しさん:05/01/17 12:57:17
マージソート風の分割統治で O(n・log n) になるのかな。
538デフォルトの名無しさん:05/01/17 14:19:06
>>537
おいおい、適当なことをいうなよ。
539デフォルトの名無しさん:05/01/17 14:23:53
また適当かよ。

ところで「適当」って2通りの解釈があるよな。
文脈でも判断できない場合がある。
ここが日本語解析の困難な所でもある。
540531:05/01/17 15:30:49
>>536の補足と改善。

計算量は >>536 で述べた長さiの最長系列候補をi個つくるための計算量の他に
a_iを含む最長系列を作る計算量があって、共にO(n^2)だ。

ところが考えてみると、a_iを含まない最長系列候補を毎回律儀に延長せずともよく、
そうすると計算が必要なのは実は後者の処理だけだ。
後者の処理ではi個の候補の中から最大値 < a_iで長さ最長のものを選ぶわけだが、
最長系列候補を常にソートした状態で持っておけばこの計算量を減らせる。

具体的には、最長系列候補を単にリストや配列で持つのではなしに
系列長でソートして持ち、さらにその中で最大値でソートするようにする。
これにRed-Blackツリーを使えば一回のオーダーはほぼO(log n)にできる。

こうして計算量はO(n log n)となる。
541デフォルトの名無しさん:05/01/17 15:49:21
問題が、np完全かそうじゃないかを判断できるのは経験?
それとも何か判断基準があるもんなの?
542デフォルトの名無しさん:05/01/17 16:20:06
>>541
適当です
543デフォルトの名無しさん:05/01/17 17:38:13
>>541
ある証明済みのNP完全問題に多項式時間で帰着するという証明をすればよい。
あるいはもっと直接的な証明
544デフォルトの名無しさん:05/01/17 20:39:20
>>541
計算論とかTuringMachineとか勉強し直せ。
545デフォルトの名無しさん:05/01/18 02:15:57
531って、計算量とかオーダーの記号とかはきちんと使ってるのに、
アルゴリズムの入門のコースは取ったことないの?
やったことがあれば一目瞭然のすげー有名な問題なんだが。
宿題とか試験にも良く出るよね、これ。
546低大生:05/01/18 03:41:22
誰か中学生でも理解できそうな割り算のアルゴリズム教えてください。
547デフォルトの名無しさん:05/01/18 05:36:36
>546
引き算を繰り返す
548531:05/01/18 05:41:51
>>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
549531:05/01/18 05:43:00
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
550531:05/01/18 08:24:15
系列長が同じものでは最大値が最小のもののみを持てばいい点を押し進めると、
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
551デフォルトの名無しさん:05/01/18 16:03:10
数学系の人?
食えなくなったら是非プログラマに
物足りないかもしれないけどw
552デフォルトの名無しさん:05/01/18 16:31:54
>>525
再帰を使え。

あと、最長の組み合わせが見つからなくとも死にはしない。
553デフォルトの名無しさん:05/01/18 16:48:52
え、俺は氏ねって言うけど?
554デフォルトの名無しさん:05/01/18 17:26:58
漏れも初見だけどこれって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)))))
555554:05/01/18 17:34:33
ごめん上の間違ってた。
最悪の場合(すでに昇順の場合) 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)))))
556デフォルトの名無しさん:05/01/18 17:56:40
>>555
やっぱこういうアルゴリズムはLISP系だなあ。
とか思って試してみたけど

>(search 0 '(1 8 9 10 3 4 2 5 6))
=>(5 1 3 4 5 6)

頭の5は何?
557デフォルトの名無しさん:05/01/18 17:57:42
あ、五個ってことか。
さすがw
558デフォルトの名無しさん:05/01/18 20:04:00
今度は大丈夫だと思います。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))))))
559デフォルトの名無しさん:05/01/18 21:19:33
>>558
> 550 は計算量 O(nlogn)なんでしょうか?
550はn^2でしょ。あなたのもn^2。
560デフォルトの名無しさん:05/01/19 09:29:05
updateの中のifが要らなくて、それにともなって search6の二番目の cond節も要らないです。

>>559
O(nlogn)にするのは無理なんですかね?
分割統治法も使えそうにないし。
561560:05/01/19 10:10:03
1. リストに最初から順番に番号を付けるのにO(n)
2. 値1>値2 && 番号1>番号2 でソートするのにO(nlogn)
3. 値1>値2 && 番号1>番号2 で連続になっている(安定なソートなら値の比較だけでいい?)最長の領域を捜すのにO(n)

でO(nlogn)でできるのかな?
562デフォルトの名無しさん:05/01/19 11:48:43
ocamlで書いたらもっとすっきりしちゃった。見たい?
563デフォルトの名無しさん:05/01/19 11:57:23
別に。
そろそろ別の話題よろ。

564デフォルトの名無しさん:05/01/19 12:10:25
話題が無いから引っ張ってるのに。ひどいわ。
565デフォルトの名無しさん:05/01/19 12:11:30
じゃ、ハノイの塔を解くアルゴリズムを1tapeTMで定義してよー
566デフォルトの名無しさん:05/01/19 14:35:37
Cプリプロセッサで解くやつならあるけどなー
567デフォルトの名無しさん:05/01/19 22:33:05
>>565
結構でかくなった
レスにすると7,8レスくらい
出題者として責任もって合ってるかどうか確認しろよ
568デフォルトの名無しさん:05/01/19 23:22:49
>>565
viで表示しながら解く奴があったな。
569デフォルトの名無しさん:05/01/19 23:23:48
emacsじゃないの?
570デフォルトの名無しさん:05/01/19 23:37:30
>>568
emacs -f hanoi
571デフォルトの名無しさん:05/01/19 23:41:41
http://www.kernelthread.com/hanoi/
100個以上の言語で書かれたハノイの塔を解くプログラム集。
良くこれだけの言語で書いたものだ。すごいね。
572デフォルトの名無しさん:05/01/19 23:44:22
くだらん。ばかじゃねーの。
573デフォルトの名無しさん:05/01/19 23:50:02
>>572
なんでよー
夢がないこといわないでよー にゃんにゃん
574デフォルトの名無しさん:05/01/19 23:52:49
ごめん。いいすぎた。
575デフォルトの名無しさん:05/01/20 04:24:33
ローパスフィルターのアルゴリズムについて教えてください
576デフォルトの名無しさん:05/01/20 04:27:20
フーリエ変換して
周波数成分の中から
高周波領域部分の係数をカットして
逆フーリエ変換する
577デフォルトの名無しさん:05/01/20 08:48:51
RとCを適当に入れた回路を作って、微分方程式を解く
578デフォルトの名無しさん:05/01/20 09:00:05
振幅特性と位相特性の離散的なリストを用意して、そいつを逆フーリエ変換したやつで畳み込みをかける。
579デフォルトの名無しさん:05/01/20 09:01:28
>>575
ここで大原ゆきが解答しているぞ。
http://pc5.2ch.net/test/read.cgi/tech/1091054082/
580デフォルトの名無しさん:05/01/20 23:05:11
>>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
三進数、繰り上がり、ビット演算、ぉっぱぉ
583デフォルトの名無しさん:05/01/21 21:29:57
>>581
n個の数字があるから x を1〜(2^n-2)までループさせる。
その x においてビット0が1ならば'0'、ビット1が1ならば'1'・・・ビット(n-1)が1ならば'n-1'を
表示する。

で、どうですかね?
584デフォルトの名無しさん:05/01/21 21:59:20
>>582
>>583
ありがとうございます。1から順にn進数に変換して・・・ってやろうと
してたんですけど、ビット演算でやったほうがスマートそうですね。
どうもです。
585デフォルトの名無しさん:05/01/23 11:49:31
http://www.na.cse.nagoya-u.ac.jp/~reiji/lect/alg99/sec9-1.html
ここにあるような方法にならって、動的計画法を用いてナップザック問題を解きたいんですが、
一般的なナップザック問題は、品物A,B,Cがあった時にカバンにAを3つBを2つといった感じで
同じ品物を複数詰め込むことができますよね。じゃなくて、カバンに同じ
品物を複数詰めることができないような場合を取り扱いたいんですが、
どういう風に実装すればいいでしょうか?
586デフォルトの名無しさん:05/01/24 13:16:59
カバンに同じ品物を複数詰めることができないように実装すればいいでしょう?
587デフォルトの名無しさん:05/01/24 13:19:17
>>585
ナップザック問題はNP完全だから、要素が多くなると、厳密解は求まらないよ。
近似解を求めるのに、遺伝的アルゴリズムでも使えば?
588デフォルトの名無しさん:05/01/24 16:47:34
>>586
いや厳密解求めるならそれでもいいかもしれないけど、
動的計画法の中に埋め込む制約としては厳しいんじゃないの?
589デフォルトの名無しさん:05/01/24 16:58:25
>>587
NP問題だって厳密解は求まるだろ。計算量がすごくなるというだけで。
590デフォルトの名無しさん:05/01/24 17:02:10
>>589
NP問題というか、さらにNP完全だし。
厳密解は、理論的には求まるが、計算時間が現実的ではないから、彼は計算途中で
計算機を止めてしまうだろうという推定が入っている。
591デフォルトの名無しさん:05/01/24 17:15:27
>>588
> 動的計画法の中に埋め込む制約としては厳しいんじゃないの?
厳しいも何も、NP完全として知られるのは0-1ナップザック問題と言って正に
>>586の言っている形なのだが。
592デフォルトの名無しさん:05/01/24 19:50:41
計算途中で息絶えてしまうだろう
593デフォルトの名無しさん:05/01/24 21:58:57
NP完全ではあるものの、実際には品物1万個でも0.1秒以内で解けてたりする。
594デフォルトの名無しさん:05/01/29 18:07:53
行列のexpはどうやって計算しますか?
595デフォルトの名無しさん:05/01/30 00:13:54
>>594
1. 普通に Σ(1/n!)A^n を逐次計算
2. 対角化 → 固有値の exp を使って求める
596デフォルトの名無しさん:05/01/30 18:06:53
awe
597デフォルトの名無しさん:05/02/02 14:48:58
C言語での除法のアルゴリズムを教えてください
598デフォルトの名無しさん:05/02/02 15:03:55
>>597
除法という演算の定義を与えてもらわないと
599デフォルトの名無しさん:05/02/02 15:45:53
>>597
a / b;
600597:05/02/02 15:52:44
>>598
商と余りを導出するものです。

整数x,yについて、y=ax+b (a,bは非負整数で、0≦b<|x|)
ときのaを商、bを余りとして、(a,b)を導出する演算をx/y
(除法)とします。
これでお願いします。
601デフォルトの名無しさん:05/02/02 16:07:33
>>600
正直>>599で正解で終わりと言いたいところだが、それを聞きたいわけ
じゃないだろう?エスパーしてみるが…

1. 「C言語で割り算をする場合、中の人はどんな処理をしているのか?」
 ⇒コンパイラを通した後の機械語によってCPUに依存。
2. 「C言語で'/'を使わずに割り算を実装するにはどうしたらいいのか?」
 ⇒解1:定義通りに引き算を繰り返す。(比較的小さな数の場合)
 ⇒解2:割る数の逆数をニュートン法で求めて乗算を行う。(数万桁以上
     など、大きな数の場合)
602デフォルトの名無しさん:05/02/02 16:18:57
>>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;}
}
603デフォルトの名無しさん:05/02/02 16:20:29
2進数の割り算を自分で筆算でやれるか?
やれるなら、シフト演算と引き算と足し算でなんとでもなる。
604597=600:05/02/03 00:38:54
重ね重ねすいません。
二進数の除法のアルゴリズムが知りたいのです。
「/」は10進数演算子だから、二進数の除法はこれではダメだと
きいたので…
605デフォルトの名無しさん:05/02/03 00:47:53
ちょっと前どっかのスレで同じ様な質問した奴と同一人物かな
C言語スレだったか忘れたけど

>>604
2進数だったら & 取ればいいだけじゃないの?
606デフォルトの名無しさん:05/02/03 00:49:40
> 「/」は10進数演算子だから
誰だよ、そんなこと言うやつ
607デフォルトの名無しさん:05/02/03 01:11:53
>>604
整数の除算に10進も2進もねえよ。
中学レベルから数学をおさらいした方が身につくんじゃない?
608デフォルトの名無しさん:05/02/03 01:15:15
でた、2chお決まりの煽り文句w
どうせなら小学校からやり直したいです
609デフォルトの名無しさん:05/02/03 01:22:47
お決まりっていうか、N進数だとかって中学あたりでやるだろ?
整数除算が基数ごとに異なるとか思ってるのはかなり重症だと思うが。
610デフォルトの名無しさん:05/02/03 02:49:20
中学ではやらない
611デフォルトの名無しさん:05/02/03 02:54:40
私立ならやるだろう。
612デフォルトの名無しさん:05/02/03 05:43:21
1101101010111101010 / 10 = 110110101011110101
613デフォルトの名無しさん:05/02/03 07:52:14
>>604
四則演算だけでやるコードが見たいという事?
なら、ここの除算の所にある
http://www.tensyo.com/urame/prog/ALGO.HTM

でも、最近のCPUは殆ど除算命令を持っているよ。
そのアルゴリズムはこれと似た方法のものもあるけど(その場合は遅い)
もっと高速のものもあったり
高速な掛算命令を持ってる機種では、
最初の数桁が出てきて、あとはニュートン法で計算させたりと色々だよ
614デフォルトの名無しさん:05/02/03 08:58:00
>>613
>四則演算だけで
は?
>>613
> でも、最近のCPUは殆ど除算命令を持っているよ。
Z80を思い出した…
616613:05/02/03 11:11:08
>>614
ゴメン。 四則だと掛け算割り算を含んでるね。
足し算引き算と、左右シフトだけの事ね
617デフォルトの名無しさん:05/02/03 12:53:04
漏れが >>602 で既に答えてるのに皆さん華麗にスルーですか。
バグでもあるのかな。
618デフォルトの名無しさん:05/02/03 12:53:27
>>609
> N進数だとかって中学あたりでやるだろ?

爺キタ━━━━━━(゚∀゚)━━━━━━ !!!!!

初期のsparcは除算命令が複数に分かれていたね。
619デフォルトの名無しさん:05/02/03 13:07:24
3
6
12
20
30

という数値配列があって、例えば「7」って入力されると「7は添え字番号1と2の間にある」
っていう風に検出する一番最適な方法を教えてください。
620デフォルトの名無しさん:05/02/03 13:15:01
621デフォルトの名無しさん:05/02/03 13:18:20
お前ら難しい話するな。
622デフォルトの名無しさん:05/02/03 13:45:59
>>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;
}
623デフォルトの名無しさん:05/02/03 13:49:02
>>622
それスレタイに全然合ってないよ!
624デフォルトの名無しさん:05/02/03 16:56:20
>>617
突込み所が無い程完璧なソース出すと誰もコメント出来ないからスルーになる。
625デフォルトの名無しさん:05/02/03 16:57:36
2ch住人……なんて性格悪いんだ…
626デフォルトの名無しさん:05/02/03 17:38:36
いやこことプログラマー板の住人が性格悪いの多い気がする
627デフォルトの名無しさん:05/02/03 18:50:56
ヲタが多いからさ
ヲタの価値基準は「知ってる奴は偉い」だからな
すぐ聞いても無いのに説明はじめたりするだろ
628デフォルトの名無しさん:05/02/03 23:02:06
と、「オレはオマエラとは違う」と思っている人がおっしゃっています
629デフォルトの名無しさん:05/02/04 00:24:48
人の説明が少しばかり偉そうでもそこは我慢したらどうですか?
そういうことを指摘すると荒れる原因になりますし…
注意するにしてももっと思慮のある言い方にすべきと思います。
人に説明しようとしている人に悪意があるとは考え辛いです。
それよりもその人に対し自慢げだ、ヲタだなどと意味のない叩き
書き込みをするほうがよっぽど質が悪いし、無駄な書き込みでは
ありませんか?
630597=600:05/02/04 00:47:49
すみません、ここに書き込むべきでない低レベルな質問をしてしまいました。
大変失礼ですが質問を取り下げさせてください。
631デフォルトの名無しさん:05/02/04 06:51:08
フレッシュマンに送る言葉
聞きやすい人は知らない。
聞きにくい人が知っている。
632デフォルトの名無しさん:05/02/04 06:54:37
>>631
おお、なかなか含蓄のある言葉だな。
633デフォルトの名無しさん:05/02/04 07:40:20
>>630 == >>600 == >>597
おまえここで質問してた香具師か?
http://pc5.2ch.net/test/read.cgi/tech/1106406806/344-347
http://pc5.2ch.net/test/read.cgi/tech/1106650397/891-892

>>597 >>600 のような聞き方では何言ってるのか分からんかったぞ。

最初から多倍長計算のアルゴリズムの話だと書けば
ここで答えてくれた人もかなりいただろうに。
634デフォルトの名無しさん:05/02/04 11:11:43
>633
わかりにくい質問をしてしまった上に、何度も聞きなおすのもどうかと思い、
一度質問を取り下げて他スレで聞き直すことにしたのです。もし気分を悪く
されたのなら誤ります。申し訳ありません。
635デフォルトの名無しさん:05/02/04 15:41:37
>>634
質問取り下げなくても素直にあやまったら
みんな答えてくれると思うよ
636デフォルトの名無しさん:05/02/04 16:01:56
そうか?
宿題丸投げすんなとか、スレ違いとか、
筆算もできんのかとか、煽られて終わりそう
637デフォルトの名無しさん:05/02/04 23:08:18
一応多倍長計算の専門スレがあるらしいのだけれども。
C++の機能だけで多倍長計算を考えるスレ
http://pc5.2ch.net/test/read.cgi/tech/1033797624/
638デフォルトの名無しさん:05/02/05 02:04:13
>>637
どう見てもネタスレにしか見えないんだが
639デフォルトの名無しさん:05/02/05 05:27:03
やっぱサザンは神だな
640デフォルトの名無しさん:05/02/05 09:24:24
>>637
多倍長計算は
openssl/bn.h
を使え。
641BlackLightOfStar ◆ifsBJ/KedU :05/02/06 21:44:34
√の計算はニュートン法でできるのは当然だけど、
CALCなどでやるとニュートン法よりもずっと計算が速い。
その計算方法は誰かが知っている、あるいは過去に知っている人が居たはずなんだけど、
計算の高速化の技術が今ひとつ身に付かない。
こういうのはどういう分野の研究者がやるんだろう?
さて、次から選択。
プロに任せる。
何とかして計算の高速化の技術を習得する。
量子コンピュータの発明。
642デフォルトの名無しさん:05/02/06 21:50:38
トウシツクサイゾ
643デフォルトの名無しさん:05/02/06 21:51:07
「プロに任せる」。具体的に言うと「既存のコードを利用する」。
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どちらに引き渡し結果の符号を変えるか判断する…こっちの時間の方が、関数
計算の核心部分より遅いわけだ。
646デフォルトの名無しさん:05/02/11 03:17:59
SSEに4ついっぺんにsqrtを計算できる機能があるけど
それより速く出来るの?
647デフォルトの名無しさん:05/02/11 03:27:24
>>646
それは無理。√もSINもCOSもLOGも、>>645に書いたような練りに練られたアルゴリズムがまずあって、
それをハードで実現したのだろう。だから、当然同じ精度ならハードでやっちゃう方が速い。

ただ、多倍長精度演算をやろうとして、ごりごりアセンブラなどで記述するような場合なら、上記の方法は
当然有効だろう。ハードで計算できる精度以上の数値を求めようとするなら、ソフトで計算するしかない
わけだしね。
648デフォルトの名無しさん:05/02/11 08:14:55
2分法は、1回のループで1ビット精度が増える
ニュートン法は、1回のループで桁数が2倍になる

ある程度の精度を必要とするとニュートン法の方が当然良い。
ただ、平方根の場合、32ビット整数の平方根は16ビットに収まるわけで、
整数に限るような事をすればループ内が単純な2分法が速いという結果にもなる。

100迄の整数平方根なんてのに限れば
1+3+5+7+...
奇数列を加算してオーバーするかどうかの方が速いだろうしね
649デフォルトの名無しさん:05/02/11 16:45:51
>>645
そういうのHacker's Delightに山ほど載ってるよ。
650デフォルトの名無しさん:05/02/11 20:15:34
>>647
ありがとう。
物理シミュでルートの計算を膨大に使用するつもりだったから
SSEかそれ以外のものを使うか迷ってたんですよ。
651デフォルトの名無しさん:05/02/12 07:03:31
物理で平方は大量に出るだけろうけど平方根は出る?
距離なら√(x^2+y^2+z^2)だろうし
652デフォルトの名無しさん:05/02/12 11:19:05
平方根出てるじゃん。
653デフォルトの名無しさん:05/02/12 11:49:45
>>648
普通の浮動小数点実数の場合は、コンピュータ内部で

a×2^b  のような形になっているわけだ。ここで仮にbが奇数なら
2a×2^(b−1) のような形にするとして…√を求めるには…

√(a×2^b)=√a×2^(b/2)

となるから、結局問題になるのは√aの部分だ。
この部分は固定小数点と考えることができるので、結局整数と同じ手法で
√を求めることができる。

要するに、浮動小数点の場合にもニュートン法より二分法の方が速い。
654デフォルトの名無しさん:05/02/12 12:13:07
>>653 見て思ったんだけどさ。

単精度だと仮数部(23bit)の組み合わせは2^23=8388608しかないじゃん。
これの√を全部テーブルにしても、2^23 * 23(bit) / 8 = 24,117,248(bytes)。
あと数年したら、テーブルによる実装も現実になったりしないかな。
655デフォルトの名無しさん:05/02/12 12:21:12
メモリにアクセスするより、内部でまわした方が速そうだ。
656デフォルトの名無しさん:05/02/12 12:32:28
>>652
距離は、たとえば引力なら距離の2乗に反比例するので、
平方根を出す必要は普通は無い筈。

たとえば、一定の距離に近づいたら というような条件でも、やっぱり2乗した状態で比較すればいいんだし
657デフォルトの名無しさん:05/02/12 12:43:47
>>656
いや、その程度の簡略化したとしても
そういうシーン以外で多用するんだけど。
658デフォルトの名無しさん:05/02/12 12:44:23
STLとかCORDICを使っていたのは
乗算もマイクロプログラムの時代
乗算がハードワイヤドロジックの今時は
マイクロプログラムのSTLやCORDICより
近似式のほうが速いのは常識だ

659デフォルトの名無しさん:05/02/12 12:46:51
>>655
実際、8ビット程度の荒い結果がテーブルで出てくる命令を持ってたりするチップはあるね。
残りはニュートン法一発で精度が2倍になってゆくから。


>>655
√(x)= √(1-y) =1- 1/2*y -1/8*y^2 - 1/16*y^3 - 5/128*y^3  出:http://www.tensyo.com/urame/prog/ALGO.HTM

だから、超並列化がすすめば、多項式近似の方が早くなる可能性もあるかもね。
ニュートン法やバイナリ-法はループが必要だから。
660デフォルトの名無しさん:05/02/12 12:48:57
>>657
俺は物理計算で距離が実際に必要になるケースというのが実在するというのは疑問だけど

キミが実際に必要だというなら、そうなんだろう。

でも、出来ればどういう計算に必要なのか知りたい希望はある。
661デフォルトの名無しさん:05/02/12 12:59:30
>>658
というか…SINやLOGなどの初等関数は全てFPU内部で演算できるから、
わざわざプログラムで最速を求める意義は、高精度の数値を求めたりする
場合だろ。その場合には乗除もアセンブラ等でプログラムしなきゃならなく
なるから当然STLの出番がまわってくるわな。
662デフォルトの名無しさん:05/02/12 13:34:06
多倍長なら桁数によってある程度桁数が増えれば、
乗算はアセンブラでカリカリに書くより素直にFFT方式にした方が早くなるよ。

そこらへんになると精度のコントロールが難しいからSTL作る方が難しいんじゃない?
663デフォルトの名無しさん:05/02/12 13:49:08
>>662
FFTってフーリエ級数にするの?それよりなら単純にマクローニン展開やテイラー展開の方がいいだろ。
多倍長でも桁数が変動するやつなら、それらの級数展開に頼るしかないだろうね。
桁数が固定されてて、多倍長演算が高速で求められているなら、STLでいいだろ。演算に求められる
テーブルを計算するのは単純に桁数少ない奴のアルゴリズムを流用すれば良いだけ。
664デフォルトの名無しさん:05/02/12 13:55:32
>>663
えと、掛け算を FFTでした方が と書いてるのですが?

中国剰余定理だと、それこそ桁数が変動するのに耐えられないと思いますし・・・・
665デフォルトの名無しさん:05/02/12 14:00:42
マク浪人
666デフォルトの名無しさん:05/02/12 14:01:58
>>664
すまん…どうやったら、乗法をFFTでより速く計算できるんだ?わからんw
ははー降参しますw!
参考になるURLなどあったら教えて欲しい。
667デフォルトの名無しさん:05/02/12 14:04:40
つまり、多倍長演算で、基本演算の四則演算中

足算引算はN のオーダで出来ますが、
掛け算は筆算方式だとN^2となります。これは分割統治法を使えば緩和しますが
FFT方式ならN*log(N) で可能となります。

この板にも、昔、素数スレでFFTで掛け算を大幅に高速化したコードが実際にあったのですが・・・
と、検索したらありました。
http://pc.2ch.net/tech/kako/993/993457354.html


668デフォルトの名無しさん:05/02/12 14:16:47
>>667
なるほど…
http://homepage2.nifty.com/m_kamada/docs/fftmul.htm
↑とかね。

そいやオレ、「電脳倶楽部」とってたから以前これ目にしたことあったはず…
すっかりわすれてた。
669デフォルトの名無しさん:05/02/12 15:50:48
うわ、ロッパーユーザーかよ。
ところでルートの逆数を求めるのに、

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デフォルトの名無しさん:05/02/12 16:21:52
>>660
>でも、出来ればどういう計算に必要なのか知りたい希望はある。

657じゃないけど、
http://homepage1.nifty.com/kaneko/wire.htm
↑。ワイヤーをバネモデルで動かしてるけどそこで使う計算で
距離を求めている。バネモデルを距離で計算しなくて済むように
出来るの?
671デフォルトの名無しさん:05/02/12 17:09:12
>>670
バネだから、力は近似的に距離 L に比例するから、平方根が必要という事だね。
それなら必要じゃないの?  

ただ、そのプログラムだと
   double dis = sqrt(dx * dx + dy * dy);
   double d = (10 - dis) * 0.2;
   px[i] -= dx / dis * d;

て部分は、何か適当な計算をしてるだけのように見えるんだけど・・・・・2乗のままでもそれなりに動くんじゃない?
672デフォルトの名無しさん:05/02/12 17:22:10
ようするに物理計算じゃなくて、長さ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 でもいけるんじゃない?
673デフォルトの名無しさん:05/02/12 17:24:58
で、ホントの物理計算としてのバネの場合も、
力が比例するのは L じゃなくて L+dLのdLの 微少な部分に比例するのだから

L^2のまま使っても、
(L+dL)^2= L^2 *2*dL+dL^2 と、dL^2は十分小さいから無視して、2*dLの効果として使えるから

やっぱり平方根は必要ないと思うよ。
674デフォルトの名無しさん:05/02/12 17:28:03
× L^2 *2*dL+dL^2
○ L^2 +2*dL+dL^2

ね。 


どうしても、平方根が必要な事があっても、こんな感じのDDA処理をするなら、
微少差の場合はニュートン法的な逐次演算に変換する事も一つの方法だしね
675デフォルトの名無しさん:05/02/12 17:31:21
>>670
47氏じゃないか。
あのひとはほんといろいろ作ってるな。
676デフォルトの名無しさん:05/02/12 17:51:58
>>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;
}
この部分をどう変えたらいいんですか?
実際やってみるので改変後のソースを示して欲しいんだけど。
本当に平方根なしで動きに問題が出ないのか確認したいので。
677デフォルトの名無しさん:05/02/12 18:07:39
>>656
> >>652
> 距離は、たとえば引力なら距離の2乗に反比例するので、
> 平方根を出す必要は普通は無い筈。

引力でも、そのベクトルを出そうと思ったら平方根がいるのでは?
まあ、惑星のシミュレーションなんかで使われるハミルトン系専用の
数値計算法ではいらなくなるのかも。
678デフォルトの名無しさん:05/02/12 19:37:53
>>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;
}

}
679デフォルトの名無しさん:05/02/12 19:53:20
ごめん。 こうしてみて。

{
 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乗和の事みたい。
680デフォルトの名無しさん:05/02/12 21:30:11
おお、ちゃんと動いてますよー!
バネモデルはいろんなところで使ってたからこれで高速化が
期待できそうです。
本当に平方根がいらなくなるとは恐れ入りました。
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
そりゃ動くとは思うが…精度的に問題出てこないのかあ?
684デフォルトの名無しさん:05/02/13 02:02:41
確かに。実際に平方根の元のアルゴリズムと>>679のアルゴリズムで
誤差を見て見たらかなり誤差が大きかった。
理想を言えば平方根のバージョンと近い値を期待したいところだけど
ここまで誤差があるなら別の手法として割り切って使えばいいのかなぁ。
例えばワイヤーとして破綻のない動きであるならコレでもいいって感じ。
685デフォルトの名無しさん:05/02/13 07:01:23
>>683
もともと、物理計算じゃなくて、偏差に比例するような速度で戻るという仕掛けで動かしてるだけだから
最初から物理計算からは精度外れまくりでは?
686デフォルトの名無しさん:05/02/13 07:40:45
よ〜し、パパ、マジメに変換しちゃうぞ。

>>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に化けるわけだ。

誤差の部分はここにあるけど、そもそもの計算方法がマジメな計算じゃないから、似た結果になりゃいいじゃんてことだな。
687デフォルトの名無しさん:05/02/13 08:46:45
という事で、少しだけ元の値に近づけるなら
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;
}
688デフォルトの名無しさん:05/02/13 09:06:21
使ってる環境によっては、平方根どころか除算でさえネックになるから
似た結果でいいなら、どんどん変換しちゃうわけね。

さらに昔は、掛算さえ嫌って、変数追加してDDA方式でゴチャゴチャやったよな
689デフォルトの名無しさん:05/02/13 09:33:42
スマン、符号を間違っていた。
ところが、符号を正しくすると、異常な領域に飛んでいってしまうと逆に精度が悪くなる。
といって、途中に判断が必要になるのも、あんまり好ましくない。
で、誤魔化す方法を考えた結果、近似計算として

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;
}
690デフォルトの名無しさん:05/02/13 10:11:30
どれくらい誤差が小さくなるかだけど
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が極端に小さい方にはあんまり効果ないね。
やっぱり、小さい方には別の近似関数を用意する必要がありそう
691デフォルトの名無しさん:05/02/13 11:01:24
小さい方に精度を上げるには
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あたりの近似で十分じゃないかな
692デフォルトの名無しさん:05/02/13 11:06:28
あと、>>678がダメで >>679がOKなのも、結構面白い。

この計算式が本当のバネを計算してるなら、いつまでも振動は収まらない筈。
なのに、適当に振動が収まるのは、このチョットとした工夫が抵抗項として
働いてるんだろうね。
693デフォルトの名無しさん:05/02/13 11:24:37
>>688
似た結果というのは、ちょっと違うかな。

DDAを使えば、一般的に微少な2次の項を省略しても、必要なだけ細分化すれば誤差は必要なだけ抑え込める。

たとえば
 a+b*dx+c*dx^2
てな感じだと、
処理分解数を2倍にすれば dxは半分になる。
  dxが1/2になれば dx^2は 1/4になる。

だから2次以上の項目は必要なだけ小さく出来る。
694デフォルトの名無しさん:05/02/13 12:00:33
>>692

工夫というより、巧夫だね
695デフォルトの名無しさん:05/02/13 16:03:35
>double d = (dr - dis) * 0.2;

この0.2を適当と呼んでるけど物理の本でフックの法則をみてると
上の式が出てきて0.2の部分はバネ係数として定義されてます。
なのでこの係数を変える事で硬めややわらかめと言った調整が可能です。
http://homepage1.nifty.com/kaneko/abodyp.htm
もう一度上のページを読んで見てもちゃんとバネ係数と言っているようです。
696デフォルトの名無しさん:05/02/13 16:39:43
フックの法則はここに持ち出すのは正しくない。

dが力だとすると、力*質量に加速度が比例して、加速度を積分して速度になり、速度が積分されて位置になるけど

ここでは、dをいきなり積分している。だからdは力ではない。
擬似的にそれなりの表現が出来ているのだから面白いという事でいいのだと思う。
697デフォルトの名無しさん:05/02/13 16:55:51
正しくないは言い過ぎたな。

強い摩擦が働いていて、その時間分解能の中では
速度が力にほぼ比例する特殊な状況のシミュレートと考える事は出来る。

だから、バネ係数であり摩擦係数でもあるわけだ
698デフォルトの名無しさん:05/02/14 18:48:43
はさみうち法のC言語でのプログラムを教えてください。
699デフォルトの名無しさん:05/02/14 18:56:32
>>698
マルチポストには教えられません。
700デフォルトの名無しさん:05/02/14 19:01:27
>>698
いわゆる2分法と同じものですよ。
たとえば、このスレで言ってた平方根なら、
http://ayusya.hp.infoseek.co.jp/ProgramAlgorithm.html#Sqrt
701デフォルトの名無しさん:05/02/14 20:46:55
わざわざありがとうございました。参考にしてみます。
702デフォルトの名無しさん:05/02/23 13:31:05
>>198
わたしは部外者だけど、あなたはキモいと思う。
703デフォルトの名無しさん:05/02/23 13:45:20
半年も経ってからご苦労様。
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
MMO製作企画を立ち上げました。協力できる人はこちら
http://www112.sakura.ne.jp/~kaientai-project/creategame.htm

2chスレ
http://game10.2ch.net/test/read.cgi/mmominor/1108379282/l50

ただ今職人(プログラマ、グラフィッカー)はげしく募集中!
707デフォルトの名無しさん:05/03/04 01:07:35
>>705
Gusfieldの本でも読みなさい
708デフォルトの名無しさん:05/03/05 02:06:47
SuffixTreeでパターンマッチングして最適解探せってことか....
709デフォルトの名無しさん:05/03/05 14:35:13
> SuffixTreeでパターンマッチングして最適解探せってことか....
違うだろーが
710デフォルトの名無しさん:05/03/05 17:48:30
違うのが、Gusfieldの本手元にないからわかんね
711デフォルトの名無しさん:05/03/07 01:18:05
ttp://www.xmailserver.org/diff2.pdf
これ、全部理解できる人いますか(自分6ページ目から解らない)
712デフォルトの名無しさん:05/03/13 08:06:05
組み合わせについて教えてください。
自然数の配列 int[N] のなかから、任意の組み合わせを
抜き出し、その要素の合計がXを超えない最も大きい組み合わせ
を求める。
という問題なんですが、Nが大きくなると、計算量が爆発的
大きくなります。
どうにかならないものでしょうか?

なお各要素はXを超えないとします。
713デフォルトの名無しさん:05/03/13 08:43:34
モンテカルロ法。
714デフォルトの名無しさん:05/03/13 09:13:42
>>713
すいません。モンテカルロ法ということは、
要するに、全部の組み合わせを考えないで、適当に選んだ
物の中から、最善なのを選べばよい、ってことでしょうか?
715デフォルトの名無しさん:05/03/13 11:35:41
行列の固有値を求めるには?
716デフォルトの名無しさん:05/03/13 20:43:47
>>712
それってNP完全のナップザック問題でしょう?
ヒューリスティックな解法やらいろいろな近似解法が考えられているから調べてみなよ。
717デフォルトの名無しさん:05/03/13 21:08:47
ヒステリックな解決法ですか。
調べてみます。
718デフォルトの名無しさん:05/03/13 22:03:04
円周率を11進数で求めてみたいのですが参考になるサイトはありますか?
719デフォルトの名無しさん:05/03/14 00:27:08
>>718
2進数で求めた小数部を次々と11倍しては整数部を引いていくのはいかんのけ?
720デフォルトの名無しさん:05/03/14 00:34:39
>>717
テメー それわざとか?わざとなんだろ?あやまれよ、あやまれ!!!!!
721デフォルトの名無しさん:05/03/14 02:49:44
>>717
/::::::/::::::::::::::::\/   |:::::/|:::::| |::::::| |::::|::::::::|:::::::::::::|::::::::::\:::::::::::::::
:::::::/::::::::::::::::::/ ヽ、  |::/ |::::| |::::::| |::::ト、:::::|、:::::::::::|:::::::::::::::ヽ:::::::::::
:::::/::::::::/::::::/  ,==>ト{_, |:::| |::::::| |::::| \|\::::::::|::::::::::::::::::|::::::::::
/|::::::/|:::::::| イ /( )、ヽ  |:::| l`'十┼┼-----‐<「:::::::::::|:::::|::::::::::
  |:::/::o::::::| | {::::::l|l|::!|  V  |:::::! レ/´,ィ´ ̄`ヽ::::ト、::::::::|:::::|::::::::::
  レ'.:::::|::o::! ヽヾ、:::ノノ      ヾ、|   | /::ヽ、_ノレ' ヽ:::::::|:::::|::::::::::
/.:::゚:::∧:::::|(__)ニ==ニ             | |::::::l|l|l:::::::|   ト、::::!::::。:::::::::
.::::::::::/::::ハ:::| ´ ̄ ̄`             ヽヾ、;;;;;;;;;;ノ  O::::o::::::::::::::::
::::::::/::::/ .:ヾ、      .:::     ´ ̄ ==‐- 二つ /:::::::::::::::::::::::::::     あやまれ!!
:::::/::::/ .::::∧       `                   /::::::::/::::::::|::::::::: >>716さんにあやまれ!!
::/::::/ .:::::/::∧       ヽ`'ー--- 、           /.::::/:::::::::::|:::::::::
/:::/ .:::::/.::/.::.ヽ       |:::::::::; -‐::::.ヽ       /.::::/:::::::::::::::::|:::::::::
::::;' .:::::/ .::i:::::::::.\    !:::/7:::::::::::::::::i    /.::::/:::::::::::::::::::::::|:::::::::
.:::! .:::/ .:::::!:::::::::::::/\  V〈::::::::::::::::::::|   ∠:::::/:::::::::::::/.:::/::::::|:::::::::
::::|:::/ .:::::::l::::::::::::/.::::::.\ \ヽ、_//    /::::::::::::::::/::::/|:::::::|:::::::::
::::レ' .::::::::/::::::::::/.::::::::::::::.\ `'ー--‐' _,. ‐'"/.::::::::::::/.::::/::|:::::::l\::::
:::::::::::::/.::::::/.::::::::::::::::::::::.`'ー--‐''"´ヽ /.:::::::::/.:::::/::::|:::::::|  \
722デフォルトの名無しさん:05/03/14 03:12:21
SEX
723デフォルトの名無しさん:05/03/17 23:35:40
>>718
10進数で求めるプログラムの10を11に変えればいいんでは?
724デフォルトの名無しさん:05/03/18 12:30:50
ヒステリックな苗木野そら
725デフォルトの名無しさん:2005/03/26(土) 12:22:01
不定な連立一次方程式の解を求める手法希望

Az = 0

N : >= 2 の整数
A : size NxN, rank(A) = N-1 の行列
z : size N

[zの要素の和は1] の条件を加えて制約条件 Nつで。
よろしく。
726デフォルトの名無しさん:2005/03/26(土) 12:43:21
シンプレックス法
727725:2005/03/26(土) 22:55:02
まだ試してないけれど道が広がった。ありがと。>>726

ついでと言っちゃなんだけれど、>>725 のAのN行の中から、
不要な条件(行)を求めるにはどういう方法があるかどなたか知りません?
728725:2005/03/26(土) 23:00:03
あとシンプレックス法って、
条件数N=10000くらいでも速く(できればLU分解程度)解を求められる?
729デフォルトの名無しさん:2005/03/28(月) 15:54:55
固定小数に関する質問ですが、
例えば、
小数部に16Bit幅、整数部に16Bit(合計32Bit)を持つ固定小数を求める場合、
25.6を固定小数に直す方法は
 u16 KoteiShousu = 25.6 * (1<<16);
で合ってますか?

調べたサイトに 25.6 * 0xffff のようなやり方を使ってたので、
こちらが正しいのか、それとも、
このやり方は別の表現方法(固定小数の)なのか、分別付かない。
730デフォルトの名無しさん:2005/03/28(月) 18:35:26
>>729
>で合ってますか?
合っている。

>このやり方は別の表現方法(固定小数の)なのか、分別付かない。
そこだけ書かれても、なんとも言えない。


ところで25.6は無限小数だから正確には表わせない事は理解してる?
731デフォルトの名無しさん:2005/03/29(火) 21:43:20
>>730
thanks
勉強不足でした。質問忘れてください。スミマセン。
732デフォルトの名無しさん:2005/04/29(金) 02:18:00
有向であれ無向であれ、節と節を重み付き枝で結ばれたグラフの
最長経路を導く問題は、最短経路のアルゴリズムの内、「最小をみつけたら更新」
みたいな部分を単に「最大を見つけたら更新」に変更するだけで実現できるものな
のでしょうか?んなこたないのでしょうか?
733デフォルトの名無しさん:2005/04/29(金) 02:35:10
ループの検出を加える必要がある。
「最小選択」にはループの検出の機能がある。
734732:2005/04/29(金) 15:19:29
>>733
ループの検出・・・ですか。ありがとうございます。
735デフォルトの名無しさん:2005/04/29(金) 17:55:19
そんな簡単にはいかない。何か他にも問題があったはず。
736デフォルトの名無しさん:2005/04/30(土) 17:04:08
>>732
最短経路を導出するアルゴリズムは、
注目する道を順次伸ばしていくアルゴリズムだから、
ある時点で注目している道の中で最短の道より
短い道がそれ以後現れることはない。
(もちろん距離が負の辺はないとして)

でも、ある時点で注目している道の中で最長の道より
長い道は、それ以後いくらでも現れうる。
だから>>732みたいに単純にはいかない。
737デフォルトの名無しさん:2005/04/30(土) 17:28:30
単一パスのコストc_{n}の最大値Mが分かっていれば、
c'_{n} ← M - c_{n}として最短経路を求めれば、
それは最長経路となっている。
738デフォルトの名無しさん:2005/04/30(土) 17:28:50
もちろん嘘です(w
739デフォルトの名無しさん:2005/04/30(土) 18:33:46
最長経路の定義によっては、更に厄介になる悪寒。
仮に、閉ループが形成されない限り経路が重複してもいいとしたら?
740732:2005/05/01(日) 13:01:28
>>736
>でも、ある時点で注目している道の中で最長の道より
>長い道は、それ以後いくらでも現れうる。
そうなんですよね・・・。ここに苦しんでおります。

>>737
この方法も考えてみました。
(頭の中でシミュレートした結果、上手くないなと思い実行はしていませんが)

>>738
やはり嘘なのですか?

>>739
>最長経路の定義によっては、更に厄介になる悪寒。
今のところは、閉路であることが前提としたものを作っています。
741デフォルトの名無しさん:2005/05/01(日) 13:22:45
>>740
> >最長経路の定義によっては、更に厄介になる悪寒。
> 今のところは、閉路であることが前提としたものを作っています。

意味がわかんねえ。

ノードの重複通過は許容するのか?
する場合、
パスの逆方向通過は許容するのか?
パスの同方向重複通過は許容するのか?

とっとと書け。全然難易度が違う。
最短経路問題と違って上の条件設定があり得ることを理解してないのか?
742732:2005/05/01(日) 13:41:11
>>741
ノードの重複通過は許容しません。
(閉路であれば)重複通過を許容しないものが基本だと決め付けていたので、
過去のレスには書きませんでした。
743デフォルトの名無しさん:2005/05/01(日) 13:53:23
じゃあ、総パス探索してから、最長を選択して終了。
744デフォルトの名無しさん:2005/05/01(日) 14:00:41
>>732では閉路なんて言ってないじゃん。(w
745デフォルトの名無しさん:2005/05/03(火) 23:42:22
入力:有向グラフG=(V,A)、枝の重みw:A->R
出力:Σ{ w(a) | a ∈ P } が最大である単純な道P

(注)同じ点を重複通過しない道を単純な道と呼んでます

っていう問題ならNP困難(さらに近似困難)だよ。
746デフォルトの名無しさん:2005/06/02(木) 13:57:57
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
748デフォルトの名無しさん:2005/06/02(木) 16:26:33
>>746
ニュートン法でしょ?
特に書き換えず、そのまま適用してよいと思いますよ。
749デフォルトの名無しさん:2005/06/03(金) 09:42:37
メディアンフィルターについて教えてくだすれ
750デフォルトの名無しさん:2005/06/04(土) 00:16:13
>>749
2次元なら、周囲9ブロックの値をソートして5番目の値を使う。
25ブロックとか49ブロックにしてもよい。
751≠749:2005/06/04(土) 20:45:08
>>750
そうすると、メディアンフィルターはボケ効果ですよね。
3x3の平均を取るフィルターでもボケると思うのですが、較べるとどう違いますかね。
752デフォルトの名無しさん:2005/06/04(土) 21:21:18
753751:2005/06/04(土) 22:09:15
>>750
なるほど、ぼかしと言うよりノイズ除去ね。THX
754751:2005/06/04(土) 22:09:42
×>>750
>>752
755デフォルトの名無しさん:2005/06/07(火) 16:35:50
囲碁のプログラムを組んでるんですが、
強さを表すのにレートを使おうと思ってます。
条件として

1 レートの高い人(強い人)がレートの低い人(弱い人)をボコってもレートが殆ど上がらない。
2 逆の場合はレートがグンと上がる。
3 同じ位のレートなら一律+1とかちょっとだけ上がる。

以上の条件を満たすような計算アルゴリズムで何かいいのありませんかね?
756デフォルトの名無しさん:2005/06/07(火) 19:08:12
>>755
例えば、√(相手のレート/自分のレート)とか?
つまりレートが同じなら1、相手のレートが自分の9倍なら3、相手のレートが自分の1/4なら1/2って計算。
この数値だと、レート9倍の相手となら5連勝すれば追いつけるね。
#って、負けた方は下げないのかな?

757デフォルトの名無しさん:2005/06/07(火) 20:04:14
>>756
負けた方は下げます。なるほど√か、いいかも。
758デフォルトの名無しさん:2005/06/07(火) 23:53:21
1 と 3 が矛盾しているように思いますが
759デフォルトの名無しさん:2005/06/08(水) 02:36:46
>>758
そうそこの境界が曖昧なんだよなぁ。
今のところ何戦かして標準偏差出してって境目を作ろうと思ってるんだが・・・。
760デフォルトの名無しさん:2005/06/08(水) 08:30:31
レートが整数であるならば、

「殆ど上がらない。」
は +1 または +0 という意味かな?

「+1とかちょっとだけ上がる。」
は +1 または 2〜3 程度上がるという意味かな?

漏れは同じ位のレート同士の対戦でももっとレートの変動があっていいと思うべな
761デフォルトの名無しさん:2005/06/09(木) 01:23:31
http://game10.2ch.net/test/read.cgi/gameama/1116492510/5
稼動しているゲームでのレーティングなのですが、結構うまく機能してるように思います。
762デフォルトの名無しさん:2005/06/14(火) 01:02:52
Aをn次正方行列、x,bをn次ベクトル、0をn次ゼロベクトルとしたとき、
Ax=0のトリビアルで無い解を解くロジックってあるのでしょうか。
巷の本はすべてAx=bでAは正則行列としているので、
一意の解を求める方法しかありません。
763デフォルトの名無しさん:2005/06/14(火) 01:08:33
ある
764デフォルトの名無しさん:2005/06/14(火) 02:05:47
そんな意地悪しないで、せめて書籍ぐらい教えてあげなよ。。。
765デフォルトの名無しさん:2005/06/14(火) 02:55:47
ニューメリカルレシピとかいう本に載ってなかったか?
最小ノルム解でぐぐるとか
766デフォルトの名無しさん:2005/06/14(火) 12:38:33
>>762
馬鹿かおまえは

Gauss の消去法でも使えよ
767デフォルトの名無しさん:2005/06/14(火) 23:38:26
>>766
ここにも馬鹿
768デフォルトの名無しさん:2005/06/15(水) 00:48:21
固有値がわかっていて、固有ベクトルを求めるルーチンと同じにならないか。
769デフォルトの名無しさん:2005/06/15(水) 03:20:10
じょるだん標準形はどうやって求めるのでせう。
770デフォルトの名無しさん:2005/06/15(水) 03:21:01
先ず、最小多項式を計算汁。
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
しかし幼稚なことやってんな
大学ならもっと理論的なことやればいいのに

こんなもんアビバでやるべきことだよ
773デフォルトの名無しさん:2005/06/16(木) 15:42:19
アビバってプログラミング教えているの?
774デフォルトの名無しさん:2005/06/16(木) 18:27:12
浴び場はc言語やd言語、vbにじゃ場やでるふぁいとか教えてるだろ
775デフォルトの名無しさん:2005/06/16(木) 18:51:37
マジですか?
776デフォルトの名無しさん:2005/06/16(木) 21:34:54
指針は、
とりあえずdata[1]にデータコピーして、
data[1]==2なら終了
そうでないなら、1減らす。
data[0]とmulを取る。
store、loadしてから繰り返し。
777初心者:2005/06/17(金) 04:16:44
>>776
すいませんね。大変参考になりました。
778デフォルトの名無しさん:2005/06/18(土) 01:35:15
Hirschberg Algorithmの実装したソースコード
てどこかでダウンロードできないでしょうか?
779デフォルトの名無しさん:2005/06/18(土) 14:10:13
780デフォルトの名無しさん:2005/06/21(火) 19:02:23
どなたかラスターオペレーションコードから計算式を求める方法をご存知でしょうか ?

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 個のテーブルを
持つという方法も考えたのですが, あまりにバカなコードになってしまうので, なんとか
計算で求めたいと思っています.

どなたかご存知の方がいらしたら, 知恵を貸してください.
781デフォルトの名無しさん:2005/06/22(水) 00:09:28
>>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
となるので意味が変わっていないことが判る。
782デフォルトの名無しさん:2005/06/22(水) 07:47:18
ラスターオペレーションコードから演算式を作りだしてコードを動的に作って高速処理させようって事?
ハードウエアで処理しちゃうから、あんまり流行らないと思うけど
783デフォルトの名無しさん:2005/06/22(水) 08:07:53
>>780
16ビットそれぞれに、 チップセレクタ
http://www9.wind.ne.jp/pakoton/HOSPITAL/kimo1/a_dec.gif
がついてると思えばいい。

つまり、16個の 4入力ANDで 入出力にインバータがついてるかどうかの回路にいったん置き換えて
あとは変換してゆく
784780:2005/06/22(水) 18:08:04
>>781
>>783
ありがとうございました !
おかげでロジックが見えてきました.

>>782
あまり詳しくは言えないのですが, 特殊な組み込みのフレームバッファボードで
ラスタオペレーションの描画をすることになりまして・・・
私も今更ソフトでこんなことするハメになるとは思っていませんでした.
785デフォルトの名無しさん:2005/06/23(木) 00:10:28
与えられた平面上の二線分の交差判定ってどうやるのがシンプルですか?
なお、交差には二線分がぴったり重なってる場合も含めます。

重なってるのを交差と見なさない場合は外積ふたつ計算してやればいいんですが、
重なってるかどうかで分岐したりするとプログラムが冗長になってしまいます。

ぜんぶで5〜6行に収まるシンプルな方針があれば教えてください.
786デフォルトの名無しさん:2005/06/23(木) 15:21:40
>>785
外積を計算するという事は、回転変換しているとも考えられる
ttp://www.tensyo.com/urame/prog/linealgo.htm
 ここの ”線分が交わるか?”を参照

だから、回転変換して
787デフォルトの名無しさん:2005/07/13(水) 22:13:37
ここで聞いていいことなのかわからないけど、
学校の問題でこんな問題が出たんですけど
なんて答えればいいと思いますか?

「次の専門用語を解釈せよ」って問題に
「アルゴリズムの正当性と停止性」ってのがあるんですけど、
言葉で表すならどうしたらいいのかわかりません。
788デフォルトの名無しさん:2005/07/13(水) 22:32:54
間違った答えを返さないかどうか>正当性
永久ループに陥る事がありえるかどうか>停止性
789デフォルトの名無しさん:2005/07/13(水) 23:39:56
>>788
ありがとうございます!助かりました!
790デフォルトの名無しさん:2005/07/14(木) 13:52:23
ゲーム木を探索する時に最も評価の高い葉を保存しておきたいのですが、定石的なものはありますか?

最大値というのはαβ戦略にそった根の値です。
最大値かどうかは探索が終了するまで分かりません。
ですから、可能性のある葉を全て保存していては効率が悪いような気がします。
枝でもいいです。(葉までのパス)
791デフォルトの名無しさん:2005/07/14(木) 13:57:36
>>790
priority queue
792デフォルトの名無しさん:2005/07/14(木) 20:13:07
ありがとうございます。参考にしてみます。
793デフォルトの名無しさん:2005/07/16(土) 10:58:52
非線形方程式を解くものにニュートン法がありますが、これは除算が含まれているため、
0に近い解を出す場合などにオーバーフローを起こしてしまいますよね。
この問題が(ニュートン法よりも)解決されているアルゴリズムはあるのでしょうか?
794デフォルトの名無しさん:2005/07/16(土) 11:57:20
>>793
ニュートン法でも、除算の分子と分母の両方をxの累乗であらかじめ割った式に変形しておくと、
オーバーフローしないよ。
795793:2005/07/16(土) 12:26:28
>>794
むむ、確かに!ありがとうございます。
796デフォルトの名無しさん:2005/07/20(水) 21:55:45
ax^3+bx^2+cx+d=0の3次方程式を解く方法教えて下さい。
取りあえずaで割って
x^3+Bx^2+Cx+D=0とするかな?とおもってます
797デフォルトの名無しさん:2005/07/20(水) 22:15:11
>>796
4次までの代数方程式には解の公式が存在する。
ニュートン法を使うまでも無い。
798デフォルトの名無しさん:2005/07/20(水) 22:27:45
799デフォルトの名無しさん:2005/07/20(水) 23:21:54
>>797,798
ただ単なる3次方程式じゃあつまらないから、
虚数解まで出す、っていう条件をつけたらどうだろう?
800799:2005/07/20(水) 23:22:42
ageてしまったorz
スマソ

そして800ゲト
801799:2005/07/20(水) 23:24:55
ていうか、解析的に出てるんだから虚数解だって簡単だってね。
何言ってるんだろ俺orz

じゃあ一般的にn次方程式だったらどんなアルゴリズムがありますか?
802デフォルトの名無しさん:2005/07/20(水) 23:28:38
>>801
C言語なら俺に聞け! Part 111
http://pc8.2ch.net/test/read.cgi/tech/1121657911/138
803デフォルトの名無しさん:2005/07/21(木) 08:50:52
>>797
3次の場合は、
- 解の公式使うと複素計算になる&精度が微妙
- 1つは必ず実数解
という性質から、
1つの実数解をニュートン法使って求めてから、
その1個を因数分解して、残り2個は2次の解の公式で解くことが多いみたいよ。

4次の場合、1つは必ず実数解ってところが成り立たないから微妙だけど、
精度考えると多分、こっちもニュートン法使う方が確実。
804デフォルトの名無しさん:2005/07/21(木) 16:33:28
スレ違いだったらごめんなさい。やりたいことはこうです。

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);
}
続く…
805804: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
806デフォルトの名無しさん:2005/07/21(木) 17:32:47
#16ビット環境のエミュレートに使うんだろうか。

自分ならセマフォかプロセスレベルで最初に一回だけmalloc(65536)して
先頭アドレス、サイズの構造体をリストで管理。myreallocのような実装や
デフラグな機能を考慮する。
807デフォルトの名無しさん:2005/07/21(木) 20:35:23
>>796
激しくマルチ、ハゲシク(・A ・)イクナイ!

ぼるじょあがC/C++の宿題を片づけますYO! 48代目
http://pc8.2ch.net/test/read.cgi/tech/1121471445/207

C言語なら俺に聞け! Part 111
http://pc8.2ch.net/test/read.cgi/tech/1121657911/128-138
808デフォルトの名無しさん:2005/07/22(金) 01:40:49
>>805
8k バイトぐらい気にするな

809デフォルトの名無しさん:2005/07/22(金) 01:54:24

(;´∀`)うわぁ
810デフォルトの名無しさん:2005/07/22(金) 04:23:12
>806
ビットマップを使う方式で 8Kb 消費すれば
十分高速なものがすで作れていますので
malloc(65535) はちょっと…

>808
うーむ
811デフォルトの名無しさん:2005/07/22(金) 07:49:01
>>805
 static uint16_t last = 0;
 uint16_t obtain(void) {
  uint16_t x = last;
  while (btree_search(x)) {
   x++;
  }
  last = x + 1;
  return x;
 }
812デフォルトの名無しさん:2005/07/22(金) 16:36:41
>811
それ、ただ実装しただけです。ぜんぜん速くないです。
>805が書いてるビットマップという方式の方が遥かに
速い。だから、8kbくらいけちけちすんなっつー話かと。
813デフォルトの名無しさん:2005/07/22(金) 17:17:37
>>811
1,3,2と開放されたら1,3,2と返さんといかんのやないの?
814デフォルトの名無しさん:2005/07/22(金) 18:44:03
>>813
逆やろ。1,3,2はなるべく遅く再利用。
815デフォルトの名無しさん:2005/07/22(金) 18:59:59
>>814
813 で言いたいのはそういうことやない。

1,2.3,...,65535 全部使われた後に 1,3,2 の順で開放されたら
三つ空きが出来るやろ。

そこから三つ要求したら 1,3,2 の順で割り当てられんといかんのやないの?

という話や。
816デフォルトの名無しさん:2005/07/22(金) 20:57:48
空きブロック ⇒ 空きブロック をリストで管理して、
末尾⇒先頭に連結した リングバッファ形にしたら速そうな気はする
が、断片化が激しいと 8kb 超えるかもしれない。
817デフォルトの名無しさん:2005/07/23(土) 09:14:52
>815
必ず遅くじゃなくて、なるべく遅くだから、べつに 1,2,3 と割り当てられて
も問題ないでしょう。ようは、開放されたばかりのやつを使うんじゃなくて
まずは、空きが他にあるならそっちからってことだと思われ。

>816
全部使われた後に全部開放されたら、その時の空きブロックリストは
軽く 8kb 越えてしまわない?結局、空きブロックを 1ビットで表せる
ビットマップ方式が一番メモリ消費も少なくて、かつ、速度も十分かと。
リストは速度は最速でもメモリ消費がかなり酷いことになりそうな悪寒。
818デフォルトの名無しさん:2005/07/23(土) 09:47:24
>>817
空きブロックの表現をランレングス的に表現すれば…
[先頭ID + 長さ] で1つの管理体にすると。
819デフォルトの名無しさん:2005/07/23(土) 20:53:12
そも32ビット環境で16をエミュレートするのにこのようなことをしても報われるような気がしない。
820デフォルトの名無しさん:2005/07/23(土) 20:55:34
いったん65535をリニアに確保した方がエリアを利用する側にとって速いような。
821デフォルトの名無しさん:2005/07/23(土) 21:23:58
>>811でいいんじゃないの?
ビットマップが嫌なくらいだから、あまり確保されないんでしょう?
822:2005/07/25(月) 01:37:06
SECDという、λ計算をする仮想機械をCかJavaで設計したいのですが、
どこかにいい情報のあるサイトはないでしょうか?
あと設計上のヒントなど知っていたら教えてください。

作りたいのは以下の計算をするプログラムです。


S,E,C,Dの4つのスタックから構成されています。
Sはそれぞれの要素が式の評価の中間結果を保持するために使用される。
Eは展開中の式の環境を積み上げるスタック。
Cは制御用に各要素を保持。
Dはダンプ用のスタックとして、処理順を制御した場合に
 それぞれのスタックの要素を一時的に保持するために用いられる。
823: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の順で積む。
824デフォルトの名無しさん:2005/07/25(月) 01:53:54
SECDとは懐かしいのう。
↓から辿れ!
http://en.wikipedia.org/wiki/SECD_machine
825822:2005/07/25(月) 02:08:19
>>824
あ、ありがとうございます。
けど、そこも含めてだいぶいろんなサイトを探し回ったんです・・。
プロログという初めて聞いた言語で作ったSECDを見つけたのですが、
当然理解不能でした。
同じサイトのC言語版はまだ作成中でした。
826デフォルトの名無しさん:2005/07/25(月) 02:16:09
おもろいスレ見っけ。数値解析結構興味ある。
ルンゲ食ったほうを使って卒論に使う計算用のプログラム作ったんだが
実はいまだにあまり理論をよくわかっていないw
827デフォルトの名無しさん:2005/07/25(月) 02:17:11
>>826
大学1年生でも知ってる。
828デフォルトの名無しさん:2005/07/25(月) 02:18:42
まじで。数値計算法は卒論のときはじめて勉強したので。
てかそれまでプログラムしたこと無かった
829デフォルトの名無しさん:2005/07/25(月) 14:51:12
>>826
つ「数値計算の常識」(伊理・藤野)
830デフォルトの名無しさん:2005/07/25(月) 15:16:30
大学行ってないけどルンゲクッタは知ってた漏れが来ましたよ。
プログラム電卓で利用してたのは内緒。
831デフォルトの名無しさん:2005/08/08(月) 15:34:10
アルゴリズムの宿題とかわからないのですが、どこかで教えてもらえませんかね〜??
832デフォルトの名無しさん:2005/08/08(月) 17:15:57
>>831
聞いてやるから質問してみろ。
833デフォルトの名無しさん:2005/08/08(月) 18:16:40
宿題スレって言うのがあるよ。検索してみな。
834デフォルトの名無しさん:2005/08/10(水) 00:37:50
Bスプラインからベジェに変換するのは分かりますが、逆はどうやるのか
分かりません。どこか参考になるサイトはありませんでしょうか。
835デフォルトの名無しさん:2005/08/10(水) 06:29:59
そりゃ、片方は2次式、片方は3次なんだから逆は単純にはいかんわな

どうしてもやるなら分割してゆくしかないだろ
836デフォルトの名無しさん:2005/08/10(水) 09:17:13
>>834
いってることが分からん

Bスプラインはベジエの完全上位互換だ
君の言ってることは逆としか思えん

サイトはあったら俺が教えてほしいぐらいだな
俺は会社で勉強しただけだし

>>835
どっちも、次数は任意(0以上なら可)かと
837835:2005/08/10(水) 09:29:15
そりゃ次数を合わせるなら、数式も係数も同じものだ
悩みようがないから、
一般的にはBスプラインは2次、ベジェは3次だからそこで悩んでるんだろうと推量したんだが?
838デフォルトの名無しさん:2005/08/10(水) 22:14:52
3次のベジエを2次のBスプラインにしたいってか?
そりゃ無理だ、近似しろ
839デフォルトの名無しさん:2005/08/10(水) 22:23:55
単純にZ座標を無視して無理やり2次にしたらどんな惨状になるのか見てみたい
840デフォルトの名無しさん:2005/08/10(水) 22:25:14
841デフォルトの名無しさん:2005/08/10(水) 22:27:46
???
842デフォルトの名無しさん:2005/08/10(水) 23:24:55
2次元, 3次元じゃなくて、2次式, 3次式のことだが・・・
843デフォルトの名無しさん:2005/08/10(水) 23:26:26
>>833
アルゴリズムの宿題であって、決まった言語の宿題とは書いてないよ
844834:2005/08/11(木) 00:24:07
>>835
その通りです。

>>838
その近似方法が知りたいのです。
845デフォルトの名無しさん:2005/08/11(木) 04:00:08
答え書くのスゲー面倒だし
こういう面倒なのに答え書いても
経験上、感謝の一言も無いから
書くのイヤだ

最小自乗近似しろとだけ言っとく
846デフォルトの名無しさん:2005/08/11(木) 04:55:26
これだけじゃあんまりだから、少し書くか・・・甘いな俺

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)だ、これは定義

行列を使って、以下のようにも書ける
847デフォルトの名無しさん:2005/08/11(木) 04:59:50
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) )
848デフォルトの名無しさん:2005/08/11(木) 05:02:44
( 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)がベジエであるという事実を全く利用してないが、まあいいだろ
849834:2005/08/11(木) 21:17:49
>>845-848
必死で読んで調べて勉強してみます。ありがとうございました。
850デフォルトの名無しさん:2005/08/12(金) 00:21:18
意外に謙虚な奴だな

実際にやるとなると
基底関数を求めるトコで詰まるかもしれんな

まあ、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)として利用な
(どの成分も同じ値だから)
851834:2005/08/12(金) 01:22:01
>>850
まだコーディングまで行っていないのであまり大きなことは言えませんが、
方針は何とか分かりそうな感じです。
わざわざ詰まりそうなところまで御指摘頂き本当に感謝します。
852835:2005/08/12(金) 06:54:18
 単純にN分割して、誤差をチェックするのでいいと思うが?
 誤差が希望範囲を超えてたら分割数を増やすというので。

 分割した曲線を2次で表現すると
 パラメータは3点、そのうち2点は、分割点で拘束しないといけないから、残りは1個
  残りの1個を
    ・さらに中点で拘束する
    ・中点の微分で拘束する
  でどちらが良いかだろうな。
853デフォルトの名無しさん:2005/09/18(日) 20:48:19
ダウンヒープが途中で止まることってないの?
854デフォルトの名無しさん:2005/09/20(火) 23:40:22
Re:>9
帰れ。
http://tv6.2ch.net/ainotane/

Re:>10
ようやく話の出来そうな人が現れてくれた。
ちなみに、ビットマスクって何ですか?
855デフォルトの名無しさん:2005/09/21(水) 08:49:14
>>854
ビット列のうち見る対象を絞るフィルターだよ
856デフォルトの名無しさん:2005/09/21(水) 10:47:44
857デフォルトの名無しさん:2005/09/21(水) 12:31:53
log関数のアルゴリズム(fortran)を教えてください。
858デフォルトの名無しさん:2005/09/21(水) 12:44:00
859デフォルトの名無しさん:2005/09/21(水) 14:50:03
2つのビット列の類似度を求める方法はありませんか?
860デフォルトの名無しさん:2005/09/21(水) 14:52:36
ルイージ度だったら n%2==0の時
861デフォルトの名無しさん:2005/09/21(水) 14:55:42
>>859
XOR して1と0のビット数の比率を表示すればいいんじゃないの?

ビット数を数えるのはシフトとAND と加算した面白い例が、どっかのスレにもあるし
やねうらおさんの所にもあったように思うよ
862デフォルトの名無しさん:2005/09/21(水) 14:57:16
>>859
XORを取って、bit反転して、bit数のカウント。

bit数のカウントは↓に速い方法が。
http://www.amazon.co.jp/exec/obidos/ASIN/4434046683/
863デフォルトの名無しさん:2005/09/21(水) 15:03:12
>>861
ハミング距離じゃなくてAに何回演算をしたらBになるかみたいなことですが。
864デフォルトの名無しさん:2005/09/21(水) 15:09:34
>>863
どういう演算? その規定が無けりゃどうしようもないだろ。
865デフォルトの名無しさん:2005/09/21(水) 15:58:27
どなたかクラフチック法のアルゴリズムについて教えていただけないでしょうか。
866デフォルトの名無しさん:2005/09/23(金) 04:07:52
マジでオレのほうが大仁田より根性も信念もあるね。
冷静な判断力や常識もオレのほうがずっと優れてる。
大仁田、あんた議員辞めるべきだよ。
これ以上、生き恥晒すな。
腕っ節が強ければ己が通る時代はとっくの昔に去った。
いまだに勘違いしてるから困ったもんだ。
867デフォルトの名無しさん:2005/09/23(金) 11:06:38
マジで漏れの方が>866より紺青も新年もあるね。
レスがあがれば己が通る時代はとっくの昔に去った。
いまだにスレ違いしてるから困ったもんだ。
868デフォルトの名無しさん:2005/09/23(金) 14:44:30
アルゴリズムのクラスでプレゼンやらされるんですが
内容をよく読まずにハフマン符号選んだ俺の運命は一体どうなるんですか?
869デフォルトの名無しさん:2005/09/23(金) 14:46:45
有名なの選んでよかったじゃん

関係ないけど誰かDoubleArrayについて解説してほしい。
なんとなく検索速いのはわかったけど、何してるのかわからんかった。
870デフォルトの名無しさん:2005/09/23(金) 15:18:49
>>868
そんなの分からないようじゃ大学卒業する資格ないって。
図書館に行けば詳しく説明した本どれだけでもあるよ。

Double-Arry Trie?
http://linux.thai.net/~thep/datrie/datrie.html
読めば分かるでしょ?
Tripleも説明してあるから、doubleでの工夫も分かりやすい。
871デフォルトの名無しさん:2005/09/23(金) 15:32:13
ハフマン符号なんて難しい話はないから中学生でも理解できるよ。
早い話が、全ての文字を同じビット数で表すのではなく、
値のうちよく使うものから順に少ないビット数による表し方を割り当てていく。
872デフォルトの名無しさん:2005/09/23(金) 21:07:39
> 早い話が、全ての文字を同じビット数で表すのではなく、
> 値のうちよく使うものから順に少ないビット数による表し方を割り当てていく。
そりゃ、中学生レベルの理解だ。
873デフォルトの名無しさん:2005/09/23(金) 21:59:57
ヒント:エントロピー
874デフォルトの名無しさん:2005/09/23(金) 22:32:54
>>870
そこ知ってるサイトだったけど、
また2時間ぐらい眺めてみました。
が、やっぱりよくわかりませんでした。

簡単な擬似コードで示してくれるとありがたいんだけど。
midatrieはコード汚くて読む気なくなるし・・
875デフォルトの名無しさん:2005/09/23(金) 22:47:57
あー、でもソース読むのがいいかなやっぱ・・
なんとなく全体像が見えてきた。
ディレクトリ深いの読むの苦手意識あるかも。
876デフォルトの名無しさん:2005/09/23(金) 23:04:23
いきなりですが挿入ソートの計算量を教えてください。
877デフォルトの名無しさん:2005/09/23(金) 23:06:28
気になるあの子へそーっと挿入
878デフォルトの名無しさん:2005/09/23(金) 23:07:44
いや、変な想像はどっかいってやって。
879デフォルトの名無しさん:2005/09/23(金) 23:08:40
最良、平均、最悪の計算量をお願いします。
880デフォルトの名無しさん:2005/09/23(金) 23:18:28
宿題スレにいけ
881デフォルトの名無しさん:2005/09/23(金) 23:26:06
O(N^2)
882デフォルトの名無しさん:2005/09/24(土) 02:58:47
うわ〜、最小自乗でBSPLINE近似とか昔おれもやったわ。なつかしー。
しかしこんなところで部分的な説明するより書籍などを教えてやったほうが
基礎から学べて良いと思った。原理さえ分かれば色々な数式で近似できるしね。
883デフォルトの名無しさん:2005/09/24(土) 03:38:52
>876 >879
その程度、コードをテメェで実装すりゃ一目瞭然だろうが。
884デフォルトの名無しさん:2005/09/24(土) 07:53:11
球が瓶に何個入るか計算できないのは何故ですか?
885デフォルトの名無しさん:2005/09/24(土) 08:14:33
つまんね
886デフォルトの名無しさん:2005/09/24(土) 08:18:23
>>884
やってみないと判らないからさ。
この個数は間違いなく入るというのは計算出来るけどね。

仕事の見積もりなんかもそうだろ?
実際やってみないとホントの所は判らない。 
887868:2005/09/24(土) 09:15:53
>>869
ども。一応教科書に載ってるのから選べ、ってことだったんで有名なのは確かだけど
実はもっと簡単なの(B-treeとか)でも良かったんだよね。

>>870
前回書き込んだときは教科書の内容さえも読む時間がなかったんだよね。
全部英語で書かれてるし。
今はいろんなサイトを見つけたから少し安心してる。

>>871
そうそう、モールス信号も同じ観点から創案された、と今読んだところ。
ハフマン賢い。当時の教授ファノンよりも賢い。しかも特許いらず。
結構良いトピック選んだかも。
888デフォルトの名無しさん:2005/09/24(土) 10:06:44
B-treeは意外と難しいよ。
アイデアは簡単なんだけれど、
他の木構造と比べないと特徴がはっきりしない。(外部ソートということ以外は)
だから他の木構造についても調べることになる。
それから実装も結構手間がかかる。

ハフマン符号は自己完結的なトッピックだから、勉強しやすい。
上に出ているtrieにもつながっていくし。
889デフォルトの名無しさん:2005/09/24(土) 10:28:36
ハフマン符号化は足し算さえできりゃ理解できるんじゃまいか
890デフォルトの名無しさん:2005/09/24(土) 10:40:29
ハーフマン = 半分男 うふぉ!
891868: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でやってたような気なするが気のせいか?
893デフォルトの名無しさん:2005/09/24(土) 17:45:49
ハフマン符号化なんて、50年以上前のものだしな。
894デフォルトの名無しさん:2005/09/24(土) 19:00:32
算術符号の特許はもう切れたの?
895デフォルトの名無しさん:2005/09/24(土) 19:48:41
>>892
君はジジイで頭も固くなってきているけれど、世の中には若い人もいるんだよ。
896デフォルトの名無しさん:2005/09/24(土) 23:39:42
>>895
まあ、どっかでちょっとバックナンバーなり探してみ
あの本なぜかこういうのだけはやたらと解りやすく書いてあったから
正直、大学時代の物理の講義よりOh!Xの方が解りやすかった
897デフォルトの名無しさん:2005/09/25(日) 00:24:43
Oh! X|MZ世代てことは少なくとも30以上だな
おっさんよ?
ちなみに全盛は10年以上前の気がするが
898デフォルトの名無しさん:2005/09/25(日) 01:35:21
バックナンバー探すより、ぐぐった方が早い。
899デフォルトの名無しさん:2005/09/25(日) 03:30:18
>892
>気のせいか?
このへん耄碌してる感じが出ててサイコーに笑える。

Oh!Xで記事にされた内容はこのスレで語るな、と?
900デフォルトの名無しさん:2005/09/25(日) 04:04:23
Oh!なんとか持ち出さなくてもCマガで毎年のように似た話題やってそうだが
901デフォルトの名無しさん:2005/09/25(日) 06:04:08
「『Oh!X』 最高〜!」(ワラ
902デフォルトの名無しさん:2005/09/25(日) 11:43:37
お前ら低レベルだな。
もうちょっとましな質問してくるやつはいないのか。
ム板から離れてもう5年経つが、話の程度が前と何も変わらないな。
903デフォルトの名無しさん:2005/09/25(日) 12:11:21
>902
お前のその発言は、小学生に向かって
「俺様が小学校卒業して5年経つが、頭の程度が前と変わらんな」
つってるのと同じ。
住人が5年間も同じなわけねぇだろカス。
お前みたいな短絡的なバカが居るから、この業界後が育ちにくいんだよ。
904デフォルトの名無しさん:2005/09/25(日) 12:29:19
>>903
わかったよ「俺が中学生のときに勉強してたのとおんなじ事やってるな。おまえら中学生か?」
これなら許してくれるか?
905デフォルトの名無しさん:2005/09/25(日) 13:03:53
>>904
俺が小学生の頃言っていたことと同じ事言ってるな。お前小学生か?
906デフォルトの名無しさん:2005/09/25(日) 13:09:34
でも、まあ、アレだ。

こういう業界って後から入ると、既にあるものばっかりで厳しいだろうね。
結果、創造的な部分はなくなるばかりで、労働的な部分の割合が増えるばかりと。

既に陳腐化したような部分はさっさと通過出来るような方法論も必要かな
907デフォルトの名無しさん:2005/09/25(日) 17:51:04
>>906
いいや、既にあるものよりも無いものの方が多い。
908デフォルトの名無しさん:2005/09/25(日) 18:02:48
>>903
2chは学校と違って、コミュニティなんだがなぁ。
909デフォルトの名無しさん:2005/09/25(日) 18:03:53
>>906
そんなことはないだろう。
今でも計算機関連の論文は数多く発表されている。
910デフォルトの名無しさん:2005/09/25(日) 19:18:06
応用も広がっているしね。
911デフォルトの名無しさん:2005/09/29(木) 10:45:08
「ハフマン」と「多倍長整数の四則演算」どちらが楽な課題でしょうか?
912デフォルトの名無しさん:2005/09/29(木) 13:17:00
ハフマンだな。
913デフォルトの名無しさん:2005/10/01(土) 11:44:15
行列をコレスキー分解する前に非零要素の位置を知るというのはどうやったらいいんですか?
その後、ツリー状にデータを保管したいんですが・・・
914デフォルトの名無しさん:2005/10/01(土) 11:49:51
>>913 先にコレスキー分解の解説をよろしく
915913:2005/10/03(月) 18:12:50
>>914
対称行列用のLU分解です。
A=LLt
916デフォルトの名無しさん:2005/10/03(月) 18:33:03
>>915
対角成分と、下三角行列じゃないの?あ、それはコレスキー分解した後か。
917913:2005/10/05(水) 16:57:23
>>916
分解する前に零要素が非零要素に変化する要素の位置だけ知りたいんです。
一意的に決まっているものなんでしょうか?
918デフォルトの名無しさん:2005/10/07(金) 07:19:24
>>917
決まらない.偶然退化するケースとかあって一般には上三角になることまでしかわからん.
だからこそ,多少要素の追加削除があっても大丈夫なようにリスト使うんでしょ.
919デフォルトの名無しさん:2005/10/10(月) 19:02:48
良くわからんけど、零要素が非零要素に変化する要素の位置を
知るために分解するんじゃないの?
1+1の答えを、計算する前に2とわかる方法は無いですか?
っていう質問に見えて仕方が無いのですが。
素人でスマソ
920デフォルトの名無しさん:2005/10/10(月) 19:08:28
>>917
非零要素の位置って?
正方行列Lの各要素がゼロで無い行と列のインデクスのこと?
921デフォルトの名無しさん:2005/10/12(水) 13:33:25
線分(X,Y座標を2つ)を2つ入力したら、
角度を教えてくれるアルゴリズムかライブラリがあれば、
教えて下さいでつ。
922デフォルトの名無しさん:2005/10/12(水) 13:45:18
線と線との角度?
つまり、片方を水平線に一致するように回転変換した時の角度の事?

普通に計算すればいいと思うが?
923デフォルトの名無しさん:2005/10/12(水) 13:58:00
>つまり、片方を水平線に一致するように回転変換した時の角度の事?

Yes.

初心者質問ですが、回転変換ライブラリがあるんですか?
924デフォルトの名無しさん:2005/10/12(水) 14:00:20
>>921
2点の差を取って逆正接じゃいかんの?
925デフォルトの名無しさん:2005/10/12(水) 14:02:16
>>924

多分それであってるんだと思いますが、
初心者なので、どのライブラリを使えば、逆正接できるのかわかりません。
926921:2005/10/12(水) 14:04:55
X,Y座標をインプットすると、各種計算結果が出てくるライブラリはネットに転がってたりしないんでしょうか?
927924: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)));
}
928924:2005/10/12(水) 14:09:55
>>926
逆正接(逆タンジェント)はC/C++の標準ライブラリにあります。

最近のC++なら先頭2行は:
#include<cmath>
struct {double x, double y} Point;
929921:2005/10/12(水) 14:13:23
>>927-928
ご回答=解答有難うございました。
C++を使ってるので、そのままコピペ致します。
930924:2005/10/12(水) 14:13:35
関数の返値書き忘れた。doubleね。
931924:2005/10/12(水) 14:16:37
>>929
別にコピーしてもいいけど、意味ちゃんとわかった?
あと、うっかりgetDegreeって書いちゃったけど結果は「度」じゃなくてラジアン単位ね。
932921:2005/10/12(水) 14:19:41
>>930-931

実は結構理解していません。

でも、C++は普通に出来るので、動かしてみて〜直してみて、を繰り返そうと思いまつ。
933ポカの多い924:2005/10/12(水) 14:23:30
あとよく思い返したらCだとabsじゃなくてfabsだなぁ。
C++ならabsでいいんだが。
あとあの按配だとリンカのフラグ指定もわからなかったりしてなぁ。
934デフォルトの名無しさん:2005/10/12(水) 14:25:01
>>927 absはイランだろ 問題は2つの直線のなす角だから、

1、2つの直線の水平との角度をそれぞれ求めて差を出す(必要なら差の結果のモジュラ演算)
2、ArcCos(2つのベクトルの内積÷(abs(a)*abs(b))

935921:2005/10/12(水) 14:30:31
やっぱ、回答が2種類になったら、
どちらを取ると見やすくてバグが出難くなるか検討しないといけないから、
図形的な理解すべきかも知れませんね。

別に性能は求めてないので、どちらでも問題は無いのですが。
936& ◆49i8jszFnA :2005/10/12(水) 14:32:31
>>932
数値計算で理解せずに「動かしてみて」なんてやってるとキリがないぞ?

正接tan(x)は高校で習ったろ?
atan(x)はtan()の逆関数つまり
x==atan(tan(x))、y==tan(atan(y))だ。
でatan2(y,x)==atan(y/x)だ。
(ただし実際の計算では誤差があるので==ではない)
937デフォルトの名無しさん:2005/10/12(水) 14:36:23
>>921は線分の傾き(入力は座標2つであらわされる線分が一本)かとオモていタが。
2つの線分のなす角度か。だったら>>934だな。
938921:2005/10/12(水) 15:04:14
実は、結構934の内容理解できません。

>1、2つの直線の水平との角度をそれぞれ求めて差を出す(必要なら差の結果のモジュラ演算)

モジュラ演算は無視して良いですか?

>2、ArcCos(2つのベクトルの内積÷(abs(a)*abs(b))

ベクトルの内積とは、x1*x2 + y1*y2、で良いですか?

absのaとbは何を表すのでしょうか?


939& ◆YJ.BPNLN7E :2005/10/12(水) 15:08:48
とするとまぁ、線分は方向ベクトルであらわしておいて内積とるのが無難だね。
いろいろポカがあったんで極力ちゃんと書いてみた。

#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;
};
940子供の頃から忘れ物の多い924:2005/10/12(水) 15:10:14
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()));
}
941938:2005/10/12(水) 15:11:06
>>939
有難うございます。それを動かします。(動くまで自分で直してみます)
942デフォルトの名無しさん:2005/10/12(水) 15:25:08
>モジュラ演算は無視して良いですか?
 結果が-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)

943デフォルトの名無しさん:2005/10/12(水) 15:27:00
× でabsはその方向ベクトルの絶対値 sqr( x2^2+y2^2 )* abs( x1^2+x1^2)
○ でabsはその方向ベクトルの絶対値 sqr( x1^2+y1^2 ) と sqr( x2^2+y2^2 )
944921:2005/10/12(水) 15:29:23
>>942

有難うございました。


>>モジュラ演算は無視して良いですか?
> 結果が-300度とかになっても問題なければ無視してもいい
> +90度と-90度も 線分の場合は区別する場合と、区別しない場合もあるしね

あ、これは重要ですね。




C/C++標準ライブラリにあるかどうか知りたいです。
(自分でググりますが、「モジュラ演算とは」だと0件ですた)
945デフォルトの名無しさん:2005/10/12(水) 15:37:12
よーだ:ルーキー、fmod()をつかえ。>>944
946デフォルトの名無しさん:2005/10/12(水) 15:38:20
次スレは950が建てるの?
947デフォルトの名無しさん:2005/10/12(水) 15:48:26
出来れば・・・・もう1のネタは尽きたようだから

プログラミングの為の数学と算数 vol.2
http://pc8.2ch.net/test/read.cgi/tech/1094368921/

に合流してくれ
948デフォルトの名無しさん:2005/10/12(水) 16:19:11
2点間の距離を出すC/C++標準ライブラリとかあるんでしょうか?
949デフォルトの名無しさん:2005/10/12(水) 16:39:45
>>948
>>939-940のabs(const Vector2D&)を使うかそれと同等な計算をすれば出る。
950949:2005/10/12(水) 16:43:38
ちなみに正確な距離を出したいのではなく遠い近いを比較したいだけならnorm()で十分。
951デフォルトの名無しさん:2005/10/12(水) 16:45:04
hypotを使った方がいいよ
sqr(dx^2+dy^2) == hypot(dx,dy)
952950:2005/10/12(水) 16:46:45
なんかここよりあっちの方が
若干Lv高くて敷居高そうな感じもあるが、
まぁ次スレは建てず続きは

プログラミングの為の数学と算数 vol.2
http://pc8.2ch.net/test/read.cgi/tech/1094368921/

で。
953デフォルトの名無しさん:2005/10/12(水) 16:50:17
>>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
>>951
>>953

ライブラリ足せば良いのでしょうか?
956デフォルトの名無しさん:2005/10/12(水) 16:55:33
>>952
 新スレたてても、ネタ士が居ないと維持は難しいです。

>>953 え? そうなの?
http://www12.plala.or.jp/ksp/prog/c/c_function.html とはでは標準ライブラリ扱いなんだけど


957デフォルトの名無しさん:2005/10/12(水) 17:07:11
>>955
#include <math.h> で hypot( dx, dy)が使えると思うよ。 ダメだったら諦める
958955:2005/10/12(水) 17:10:57
>>957
hypotはコンパイル通りますた。

normは >>954 の通りなんですよね。
959949:2005/10/12(水) 17:11:20
>>950のnorm()は>>939-940のnorm(const Vector2D&)のことな。
960955:2005/10/12(水) 17:12:30
>>959
あ、了解。
961デフォルトの名無しさん:2005/10/12(水) 17:15:40
ポータブル テンプレート 行列クラスライブラリ

ttp://sklab-www.pi.titech.ac.jp/~hase/soft/ptm/PTM.html

 ↑
このTMatrixとか、TVectorって便利ですか?
それとも行列クラスライブラリは別にデファクトモノがあったりするのかな?
962デフォルトの名無しさん:2005/10/12(水) 17:18:43
>>957-958
ANSI C/C++、POSIXなどの標準規格では<cmath>や<math.h>には含まれないが
UNIX環境では割とあることが多いらしいそうな。System V系にはあるそうな。
後は処理系によってあったりなかったり。
963デフォルトの名無しさん:2005/10/12(水) 17:20:02
MTLが有名。数値計算で使っている人も多い。
http://www.osl.iu.edu/research/mtl/
964デフォルトの名無しさん:2005/10/12(水) 17:27:38
>>961

Blitz++
MTL
POOMA
A++/P++

・・・なんてのがあるらしいよ。あとはこのキーワードでググってみて管祭。
965デフォルトの名無しさん:2005/10/12(水) 17:32:42
>>963 >>964

ダウンロードしたり、演算リンク集なんか見てみましたが、
巨大だし、ドキュメントは英語ですね。

自作するよりは良いんでしょうが、大変そう。
966デフォルトの名無しさん:2005/10/12(水) 17:33:52
Blitz++ :テンプレート・メタプログラミングを使った最初のC++線形計算パッケージ
http://www.oonumerics.org/blitz/
MTL :割とメジャー
http://www.osl.iu.edu/research/mtl/
POOMA :並列計算を主に考えているらしい
http://acts.nersc.gov/pooma/
A++/P++ :Fortran90と同等の配列処理をC++で行う
http://www.sai.msu.su/sal/B/2/A++P++.html

・・・なのか?
967デフォルトの名無しさん:2005/10/12(水) 17:42:46
>>965
自作するよりはよいどころではなく多分割と劇的に性能が違うと思うよ。
特にある程度以上の大きさの行列では。
968965:2005/10/12(水) 17:56:03
劇的に良いわけですか。

質問ばかりですみませんが、座標系(言い方変ですか?)のライブラリのデファクトはどうなんでしょう?

やりたい事は、座標変換や面積計算やトポロジー的なことです。2次元、将来3次元かもです。
969デフォルトの名無しさん:2005/10/12(水) 18:42:35
数学的な問題を解くのが目的か、グラフィックスとかの応用が目的か、
問題の規模や、リアルタイム・アプリケーションなのかそうでないかとか
あるいは単に宿題や趣味プログラミングかとか
その辺が分からないとなんともいえないよね。

例えば>>966で紹介したライブラリ群とかは
概ね浮動小数点演算で大規模な問題を効率よく解くのには向いているが、
3次元で展開するリアルタイムゲームのエンジン部分とか
小さな行列をリアルタイムで解くような問題にはあまり向いてない。
また3Dグラフィックスならむしろグラフィック・ハードウェアの
演算機能を生かす必要があるから一般的な行列ライブラリより
OpenGLとかDirectXとか考えたほうがいいわけだろうし。
970デフォルトの名無しさん:2005/10/12(水) 18:45:00
グラフィックスとかの応用が目的で、リアルタイムじゃないものお願いします。
971デフォルトの名無しさん:2005/10/12(水) 19:02:50
グラフィックへの応用が目的なら、勉強がてらそこらへん自作するのも手だよ。
結局、応用するには基礎が出来てないとどうしようもない。
基礎を勉強するには、一度は苦労しないとね
972デフォルトの名無しさん:2005/10/13(木) 01:25:59
>>961 >>964 >966
用途によっては
Boost::numeric::ublas
も使えるかも。Boost準標準だし。
973デフォルトの名無しさん:2005/10/13(木) 08:04:23
しかし、2直線が挟む角度を求めるだけで、
こんなに話を膨らませられる君たちは天才だね。
974デフォルトの名無しさん
なんなら、2直線が平行に近い場合の
ArcCos内積 を使う場合の精度問題について膨らませてもいいぞ。