裏 RjpWiki

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

算額(その1557)

2025年01月25日 | Julia

算額(その1557)

四十九 岩手県一関市弥栄 弥栄長安寺 明治20年(1887)
山村善夫:現存 岩手の算額,昭和52年1月30日,熊谷印刷,盛岡市.

http://www.wasan.jp/yamamura/yamamura.html
キーワード:円3個,外円
#Julia, #SymPy, #算額, #和算, #数学

大円の中に弦を隔てて中円,小円を容れる。「弦の半分の二乗」と「(中円の直径)と(小円の直径の2倍)の和(注)」が等しく,大円,中円,小円の直径が無奇零数(整数)になる解を求めよ。

注:算額には,「外円径与中円二段相併」とあるが,そもそも外円は図にないし,ほかのところでは大円,中円,小円と呼んでいる。山村も「外円は大円の誤記」と指摘しているが,根本的におかしい。「大円径与中円二段相併」が条件のとき,無奇零数の解はない。山村はこれらの条件を無視して,「(4/2)^2=8」などとむちゃくちゃに数字をいじり,「大円径与中円二段相併」の条件を無視して,怪我の功名で「大円径=6,中円径=4,小円径=2」を出している。困ったものだ。

「(中円の直径)と(小円の直径の2倍)の和」の誤記だとすれば,唯一の無奇零数の解が得られる。

大円の半径と中心座標を R, (0, 0)
中円の半径と中心座標を r1, (0, r1 - R)
小円の半径と中心座標を r2, (0, R - r1)
とおき,以下の連立方程式を解く。

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

using SymPy
@syms R::positive, r1::positive, r2::positive;
# eq1 = (R^2 - (R - 2r2)^2) - (2R + 4r1)  # 算額通り
eq1 = (R^2 - (R - 2r2)^2) - (2r1 + 4r2)   # 算額は誤記であると解釈
eq2 = (r1 + r2) - R
res = solve([eq1, eq2], (r1, r2))[2]  # 2 of 2

    (R/2 + sqrt(4*R^2 - 12*R + 1)/4 + 1/4, R/2 - sqrt(4*R^2 - 12*R + 1)/4 - 1/4)

# r1: 中円の半径
res[1](R => 6//2) |> println

    2

# r2: 小円の半径
res[2](R => 6//2) |> println

    1

検算: (弦/2)^2 = 8;  中円の直径 + 2*小円の直径 = 8

大円,中円,小円の直径はそれぞれ,6,4,2 である。

function draw(R, more)
    pyplot(size=(500, 500), grid=false, aspectratio=1, label="", fontfamily="IPAMincho")
    (r1, r2) = (R/2 + sqrt(4*R^2 - 12*R + 1)/4 + 1/4, R/2 - sqrt(4*R^2 - 12*R + 1)/4 - 1/4)
    @printf("(弦/2)^2 = %g;  中円の直径 + 2*小円の直径 = %g\n", R^2 - (R - 2r2)^2, 2r1 + 4r2)
    @printf("R = %g;  r1 = %g;  r2 = %g\n", R, r1, r2)

    plot()
    circle(0, 0, R)
    circle(0, R - r2, r2, :blue)
    circle(0, r1 - R, r1, :green)
    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, 0, "大円:R,(0,0)", :red, :center, delta=-delta/2)
        point(0, r1 - R, "中円:r1,(0,r1-R)", :green, :center, delta=-delta/2)
        point(0, R - r2, "小円:r2,(0,R-r2)", :blue, :center, delta=-delta/2)
    end  
end;

draw(6/2, true)


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

コメントを投稿

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

Julia」カテゴリの最新記事