裏 RjpWiki

Julia ときどき R, Python によるコンピュータプログラム,コンピュータ・サイエンス,統計学

算額(その1494)

2024年12月25日 | Julia

算額(その1494)

参考文献

1).  二 岩手県花巻市大田 音羽山清水観世音堂 明治25年(1892)
山村善夫:現存 岩手の算額,昭和52年1月30日,熊谷印刷,盛岡市.

http://www.wasan.jp/yamamura/yamamura.html

2).  今有如図 03076
https://w.atwiki.jp/sangaku/pages/137.html

キーワード:円5個,外円,直角三角形2個
#Julia, #SymPy, #算額, #和算

外円内に交差する直角三角形を 2 個容れ,隙間に大円 1 個,中円 2 個,小円 1 個を容れる。小円の直径が与えられたとき,外円の直径を求める術を述べよ。

注:直角三角形の斜辺は外円の直径である(外円の中心を通る)。

外円の半径と中心座標を R, (0, 0)
大円の半径と中心座標を r1, (0, r1 - R)
中円の半径と中心座標を r2, (x2, y2)
小円の半径と中心座標を r3, (0, R - r3)
直角三角形の円周上にある頂点の座標を (x01, y01), (-x01, -y01), (x02, y02)
とおき,以下の連立方程式を解き (R, r1, r2, x2, y2, x01, x02) を求める。

include("julia-source.txt");
# julia-source.txt ソース https://blog.goo.ne.jp/r-de-r/e/ad3a427b84bb416c4f5b73089ae813cf

using SymPy

@syms R, r1, r2, x2, y2, r3, x01, y01, x02, y02
# y01 = sqrt(R^2 - x01^2)
# y02 = sqrt(R^2 - x02^2)
eq1 = dist2(-x01, -y01, x02, y02, 0, R - r3, r3)
eq2 = dist2(-x01, -y01, x02, y02, x2, y2, r2)
eq3 = dist2(-x01, -y01, x01, y01, x2, y2, r2)
eq4 = dist2(-x01, -y01, x01, y01, 0, r1 - R, r1)
eq5 = dist2(x01, y01, x02, y02, x2, y2, r2)
eq6 = (x01 - x02)^2 + (y02 - y01)^2 + (x02 + x01)^2 + (y02 + y01)^2 - 4R^2
eq7 = sqrt((x01 - x02)^2 + (y02 - y01)^2) + sqrt((x02 + x01)^2 + (y02 + y01)^2) - 2R - 2r2;
# res = solve([eq1, eq2, eq3, eq4, eq5, eq6, eq7], (R, r1, r2, x2, y2, x01, x02))

function H(u)
    (R, r1, r2, x2, y2, x01, x02) = u
    y01 = sqrt(R^2 - x01^2)
    y02 = sqrt(R^2 - x02^2)
    return [
        R^2*x01^2 + 2*R^2*x01*x02 + R^2*x02^2 - 2*R*r3*x01^2 - 4*R*r3*x01*x02 - 2*R*r3*x02^2 - 2*R*x01^2*y02 + 2*R*x01*x02*y01 - 2*R*x01*x02*y02 + 2*R*x02^2*y01 - r3^2*y01^2 - 2*r3^2*y01*y02 - r3^2*y02^2 + 2*r3*x01^2*y02 - 2*r3*x01*x02*y01 + 2*r3*x01*x02*y02 - 2*r3*x02^2*y01 + x01^2*y02^2 - 2*x01*x02*y01*y02 + x02^2*y01^2,  # eq1
        -r2^2*x01^2 - 2*r2^2*x01*x02 - r2^2*x02^2 - r2^2*y01^2 - 2*r2^2*y01*y02 - r2^2*y02^2 + x01^2*y02^2 - 2*x01^2*y02*y2 + x01^2*y2^2 - 2*x01*x02*y01*y02 + 2*x01*x02*y01*y2 - 2*x01*x02*y02*y2 + 2*x01*x02*y2^2 + 2*x01*x2*y01*y02 - 2*x01*x2*y01*y2 + 2*x01*x2*y02^2 - 2*x01*x2*y02*y2 + x02^2*y01^2 + 2*x02^2*y01*y2 + x02^2*y2^2 - 2*x02*x2*y01^2 - 2*x02*x2*y01*y02 - 2*x02*x2*y01*y2 - 2*x02*x2*y02*y2 + x2^2*y01^2 + 2*x2^2*y01*y02 + x2^2*y02^2,  # eq2
        -r2^2*x01^2 - r2^2*y01^2 + x01^2*y2^2 - 2*x01*x2*y01*y2 + x2^2*y01^2,  # eq3
        R^2*x01^2 - 2*R*r1*x01^2 - r1^2*y01^2,  # eq4
        -r2^2*x01^2 + 2*r2^2*x01*x02 - r2^2*x02^2 - r2^2*y01^2 + 2*r2^2*y01*y02 - r2^2*y02^2 + x01^2*y02^2 - 2*x01^2*y02*y2 + x01^2*y2^2 - 2*x01*x02*y01*y02 + 2*x01*x02*y01*y2 + 2*x01*x02*y02*y2 - 2*x01*x02*y2^2 + 2*x01*x2*y01*y02 - 2*x01*x2*y01*y2 - 2*x01*x2*y02^2 + 2*x01*x2*y02*y2 + x02^2*y01^2 - 2*x02^2*y01*y2 + x02^2*y2^2 - 2*x02*x2*y01^2 + 2*x02*x2*y01*y02 + 2*x02*x2*y01*y2 - 2*x02*x2*y02*y2 + x2^2*y01^2 - 2*x2^2*y01*y02 + x2^2*y02^2,  # eq5
        -4*R^2 + (x01 - x02)^2 + (x01 + x02)^2 + (-y01 + y02)^2 + (y01 + y02)^2,  # eq6
        -2*R - 2*r2 + sqrt((x01 - x02)^2 + (-y01 + y02)^2) + sqrt((x01 + x02)^2 + (y01 + y02)^2),  # eq7
    ]
end;
r3 = 1.3
iniv = BigFloat[5, 2.38148, 1.38386, 2.19015, 2.52282, 4.54737, 2.22096]
res = nls(H, ini=iniv)

    ([5.245405918341268, 2.494544851553091, 1.3500234539411795, 2.5099962534726905, 2.655439704703816, 4.756656192448811, 2.5869506037665375], true)

例えば,小円の直径が 2.6 のとき,外円の直径は 10.4908 である。
小円の直径と外円の直径は直線関係ではない(定数倍ではない)。

全てのパラメータは以下のとおりである。
r3 = 1.3;  R = 5.24541;  r1 = 2.49454;  r2 = 1.35002;  x2 = 2.51;  y2 = 2.65544;  x01 = 4.75666;  y01 = 2.211;  x02 = 2.58695;  y02 = 4.56311

術は判読できない部分があるようであるが,山村は最終的に 「外円径 = 2.905×小円径」としている。
しかし,例に挙げた図では,小円の直径が 2.6 のとき,外円の直径は 2.905*2.6 = 7.553 になってしまい,上の数値解と合わない。

function draw(more=false)
    pyplot(size=(500, 500), grid=false, aspectratio=1, label="", fontfamily="IPAMincho")
    (R, r1, r2, x2, y2, x01, x02) = res[1]
    y01 = sqrt(R^2 - x01^2)
    y02 = sqrt(R^2 - x02^2)
    @printf("小円の直径が %g のとき,外円の直径は %g である。\n", 2r3, 2R)
    @printf("r3 = %g;  R = %g;  r1 = %g;  r2 = %g;  x2 = %g;  y2 = %g;  x01 = %g;  y01 = %g;  x02 = %g;  y02 = %g\n",
        r3, R, r1, r2, x2, y2, x01, y01, x02, y02)
    plot([x01, -x02, -x01, x01], [-y01, y02, y01, -y01], color=:green, lw=0.5)
    plot!([-x01, x02, x01, -x01], [-y01, y02, y01, -y01], color=:palevioletred, lw=0.5)
    circle(0, 0, R, :firebrick)
    circle(0, r1 - R, r1, :magenta)
    circle2(x2, y2, r2)
    circle(0, R - r3, r3, :blue)
    if more
        delta = (fontheight = (ylims()[2]- ylims()[1]) / 500 * 10 * 2) /3  # size[2] * fontsize * 2
        hline!([0], color=:gray80, lw=0.5)
        vline!([0], color=:gray80, lw=0.5)
        point(0, r1 - R, "大円:r1,(0,r1-R)", :magenta, :center, delta=-delta/2)
        point(x2, y2, "中円:r2,(x2,y2)", :red, :center, delta=-delta/2)
        point(0, R - r3, "小円:r3\n(0,R-r3)", :blue, :center, :bottom, delta=delta/2)
        point(x02, y02, "(x02,y02)", :palevioletred, :left, :bottom, delta=delta/2)
        point(x01, y01, " (x01,y01)", :palevioletred, :left, :vcenter)
        point(-x01, -y01, "(-x01,-y01) ", :palevioletred, :right, :vcenter)
        point(-x02, y02, "(-x02,y02)", :green, :right, :bottom, delta=delta/2)
        point(x01, -y01, " (x01,-y01)", :green, :left, :vcenter)
        point(-x01, y01, "(-x01,y01) ", :green, :right, :vcenter)
        point(0, R, "R", :firebrick, :center, :bottom, delta=delta)
        plot!(xlims=(-R - 15delta, R + 15delta))
    end
end;

draw(true)


コメント    この記事についてブログを書く
  • X
  • Facebookでシェアする
  • はてなブックマークに追加する
  • LINEでシェアする
« 算額(その51)改訂版 | トップ | 算額(その1495) »
最新の画像もっと見る

コメントを投稿

ブログ作成者から承認されるまでコメントは反映されません。

Julia」カテゴリの最新記事