確かそういう名称だったと思う。
それに出ていた大学生がある問題をあまりに即答するので不思議がっていて、解法を教えてくれとの要請があったため調べることにした。
内容は次のような問題。
「年利3パーセントの金利が発生する預金で、何年預ければ2倍になるか」
これを頭の中で3秒程度で計算したという。つまり今回の要請は、答えを見つけることではなく、アルゴリズムの探求、ということだ.
問題を正確に述べると, ある自然数nでを満たす最小のものを選べということだ. pythonで
[code language=”python”]
math.log(2)/math.log(1.03) = 23.449772250437736
[/code]
と出るので, 答えは24年ということだが, これを暗算で求める方法などあるだろうか.
まず言えることは, シュナイダーの定理(正確にはGel’fond-Schneider’s theorem)によって, という数は超越数である, つまり任意のが, を満たす, あるいは有理数係数多項式の根にならない. 2と1.03は乗法独立であるから, これは正しい. ちなみに1でも0でもない代数的数a, bに対し,
が成り立つ. この証明は以下で一応示してある.
有限回の加減乗除で生成されない, もっと言えば有理関数で生成されないような数の大小を決定するようなことは, 代数的には難しいように思われる.
さて, 潔くテイラー展開しよう!
せいぜい2, 3回程度の加減乗除で判定可能にするためには(その大学生が暗算で解答したというから), まぁ近似法を使わざるを得まい.
まずは基本公式から分かることを調べる. 次のようにする.
関数は, 閉円盤上一様収束級数
に展開される. あるいは上一様収束級数
に展開される. これらは交代級数の収束条件を満たすので, zが円周上にあるときでも成立する. 今最初の展開を第n項で打ちきった部分和をと定義する.
好ましいのは, の商がnの若い段階で収束する場合である.
またはにかなり近いので, を使う. すると,
やはりこの程度ではなかなか不正確な値を出してくれる. 交代級数でない近似をしたい. から, 正級数
を得る. この第n項までの部分和を上と同様にと定義すると, それによる近似は
であり, 実に6項を要する. ちょっと有り得ない.
ところでいきなり結論だが, log2の下二桁が0.69であると知っていた場合は..
n ≧ log2/log1.03 > 0.69/0.03 = 23 (0.03>log1.03はによる)
から直ちに出る.
その可能性は高い.
————————————————–
(*)の証明
まず仮定のもと, ←を言う. そのためにa, bが乗法従属であることと, aとbの(複素数としての)偏角が共にπの有理数倍であることが同じであること, そしてそれが(logの適当な枝を定めた時)が成り立つことと同値であることを言う.
である. つまり. 従属性からm, lいずれか一方は0でないが, 今はmもlも両方非零を仮定する. πは有限回の整数の加減乗除で生成されないので, θとφはの中で0になることが必要. 一方θとφがの中で0になれば, の分母を払ってとなるよう(m,l)の組を任意に選ぶことができる.
これはとなる表示があるとき, またそのときに限ってa, bは乗法従属になるということである(r, m, lは非零. またp, p’, q, q’は0でない整数).
このとき
である. 途中のmodは, logの枝の違いを吸収する意味がある. 逆に言えば上のようにπやiを含む因子が割りきれるように枝を選べるということを言う必要があるが, それはここでは調べないことにする.
この考察により, →は簡単に示せる. つまりlogの商が有理数であることと, 非有理数因子が割りきれることは同値で, それにはどうしても上のような形を取らざるを得ない. 極形式の表示の一意性から結局a, bの乗法従属性が言える.