裏 RjpWiki

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

算額(その1441)

2024年12月02日 | Julia

算額(その1441)

二本松亀谷町坂 観世音 天保10年(1839)
『諸流算額起原一』(佐久間庸軒)

街角の数学 Street Wasan ~落書き帳「○△□」~  81. 佐久間文庫
http://streetwasan.web.fc2.com/math15.9.5.html
キーワード:円3個,正三角形,接線
#Julia, #SymPy, #算額, #和算

正三角形内に内接円と甲円,乙円を容れ,3円の共通接線を引く。内接円の直径が 675 寸,甲円の直径が 81 寸のとき,乙円の直径はいかほどか。

最初は,後半に示すような全ての描画パラメータを求める方法で解いた。かなり複雑な7元連立方程式になったので,数値解しか求められなかった。
それでも,乙円は内接円の 1/27 倍の大きさであることは分かった。

その後で,「落書き帳」の著者が「三角関数の加法定理を用いてすんなり?解けます」というヒントを与えていたので,以下のように「簡単に」解けた。図を描くのは別として。

1. 乙円の直径のみを得る

内接円,甲円,乙円の半径を r0, r1, r2 とおく。
甲円の中心 A,内接円の中心 O,内接円と正三角形の斜辺との接点 B を結ぶ直角三角形において,∠AOB = θ1
乙円の中心 C,内接円の中心 O,内接円と正三角形の斜辺との接点 D を結ぶ直角三角形において,∠COD = θ2
とすれば θ1 + θ2 = 60°なので,以下の連立方程式を解く。

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

using SymPy
@syms r0, r1, r2, θ1, θ2
θ2 = PI/3 - θ1
eq1 = (r0 + r1)*cos(θ1) - (r0 - r1)
eq2 = (r0 + r2)*cos(θ2) - (r0 - r2)
res = solve([eq1, eq2], (r2, θ1))[2]  # 2 of 2

    (-r0*(sqrt(3)*r0*sqrt(-((r0 - r1)^2 - (r0 + r1)^2)/(r0 + r1)^2) - r0 + sqrt(3)*r1*sqrt(-((r0 - r1)^2 - (r0 + r1)^2)/(r0 + r1)^2) - 3*r1)/(sqrt(3)*r0*sqrt(-((r0 - r1)^2 - (r0 + r1)^2)/(r0 + r1)^2) + 3*r0 + sqrt(3)*r1*sqrt(-((r0 - r1)^2 - (r0 + r1)^2)/(r0 + r1)^2) + r1), acos((r0 - r1)/(r0 + r1)))

res[1](r0 => 675, r1 => 81).evalf() |> println
res[2](r0 => 675, r1 => 81).evalf() |> println


    25.0000000000000
    0.666946344503664

内接円,甲円の直径がそれぞれ 675 寸,81 寸のとき,乙円の直径は 25 寸である。

2. 全ての描画パラメータを得る

内接円の半径と中心座標を r0, (0, r0)
正三角形の一辺の長さを 2a; a = √3r0
甲円の半径と中心座標を r1, (x1, y1)
乙円の半径と中心座標を r2, (x2, y2)
内接円,甲円,乙円の共通接線と正三角形の斜辺との交点座標を (cx, cy), (dx, dy)
cy = √3(a + cx), dy = √3(a - dx)
とおき,以下の連立方程式を解く。

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

using SymPy
@syms a::positive, r0::positive,
      r1::positive, x1::positive, y1::positive,
      r2::positive, x2::positive, y2::positive,
      cx::negative, cy::positive, dx::positive, dy::positive
a = r0*√Sym(3)
cy = √Sym(3)*(a + cx)
dy = √Sym(3)*(a - dx)

eq1 = x1^2 + (y1 -  r0)^2 - (r0 + r1)^2
eq2 = x2^2 + (y2 -  r0)^2 - (r0 + r2)^2
eq3 = dist2(cx, cy, dx, dy, x1, y1, r1)
eq4 = dist2(cx, cy, dx, dy, x2, y2, r2)
eq5 = dist2(cx, cy, dx, dy, 0, a/√Sym(3), r0)
eq6 = dist2(a, 0, 0, √Sym(3)a, x1, y1, r1)
eq7 = dist2(-a, 0, 0, √Sym(3)a, x2, y2, r2);

using NLsolve

function nls(func, params...; ini = [0.0])
    if typeof(ini) <: Number
        r = nlsolve((vout, vin) -> vout[1] = func(vin[1], params..., [ini]), ftol=big"1e-40")
        v = r.zero[1]
    else
        r = nlsolve((vout, vin)->vout .= func(vin, params...), ini, ftol=big"1e-40")
        v = r.zero
    end
    return Float64.(v), r.f_converged
end;

function H(u)
    (x1, y1, r2, x2, y2, cx, dx) = u
    return [
        x1^2 + (-r0 + y1)^2 - (r0 + r1)^2,  # eq1
        x2^2 + (-r0 + y2)^2 - (r0 + r2)^2,  # eq2
        (12*cx^2*dx^2 - 12*sqrt(3)*cx^2*dx*r0 - 12*cx^2*dx*x1 + 4*sqrt(3)*cx^2*dx*y1 + 9*cx^2*r0^2 + 6*sqrt(3)*cx^2*r0*x1 - 6*cx^2*r0*y1 - 4*cx^2*r1^2 + 3*cx^2*x1^2 - 2*sqrt(3)*cx^2*x1*y1 + cx^2*y1^2 + 12*sqrt(3)*cx*dx^2*r0 - 12*cx*dx^2*x1 - 4*sqrt(3)*cx*dx^2*y1 - 18*cx*dx*r0^2 + 12*cx*dx*r0*y1 - 4*cx*dx*r1^2 + 6*cx*dx*x1^2 - 2*cx*dx*y1^2 + 9*dx^2*r0^2 - 6*sqrt(3)*dx^2*r0*x1 - 6*dx^2*r0*y1 - 4*dx^2*r1^2 + 3*dx^2*x1^2 + 2*sqrt(3)*dx^2*x1*y1 + dx^2*y1^2)/(4*(cx^2 + cx*dx + dx^2)),  # eq3
        (12*cx^2*dx^2 - 12*sqrt(3)*cx^2*dx*r0 - 12*cx^2*dx*x2 + 4*sqrt(3)*cx^2*dx*y2 + 9*cx^2*r0^2 + 6*sqrt(3)*cx^2*r0*x2 - 6*cx^2*r0*y2 - 4*cx^2*r2^2 + 3*cx^2*x2^2 - 2*sqrt(3)*cx^2*x2*y2 + cx^2*y2^2 + 12*sqrt(3)*cx*dx^2*r0 - 12*cx*dx^2*x2 - 4*sqrt(3)*cx*dx^2*y2 - 18*cx*dx*r0^2 + 12*cx*dx*r0*y2 - 4*cx*dx*r2^2 + 6*cx*dx*x2^2 - 2*cx*dx*y2^2 + 9*dx^2*r0^2 - 6*sqrt(3)*dx^2*r0*x2 - 6*dx^2*r0*y2 - 4*dx^2*r2^2 + 3*dx^2*x2^2 + 2*sqrt(3)*dx^2*x2*y2 + dx^2*y2^2)/(4*(cx^2 + cx*dx + dx^2)),  # eq4
        cx*dx*(3*cx*dx - 2*sqrt(3)*cx*r0 + 2*sqrt(3)*dx*r0 - 3*r0^2)/(cx^2 + cx*dx + dx^2),  # eq5
        9*r0^2/4 - 3*sqrt(3)*r0*x1/2 - 3*r0*y1/2 - r1^2 + 3*x1^2/4 + sqrt(3)*x1*y1/2 + y1^2/4,  # eq6
        9*r0^2/4 + 3*sqrt(3)*r0*x2/2 - 3*r0*y2/2 - r2^2 + 3*x2^2/4 - sqrt(3)*x2*y2/2 + y2^2/4,  # eq7
    ]
end;

r0 = 675/2
r1 = 81/2
iniv = BigFloat[140, 689, 12, -217, 612, -225, 159]
res = nls(H, ini=iniv)

    ([140.29611541307898, 688.5, 12.499999999999389, -216.5063509461113, 612.499999999998, -224.83351829019105, 159.42740387849864], true)

内接円,甲円の直径が 675 寸,81 寸のとき,乙円の直径は 25 寸である。
2r2 = 25,2r0 = 675 なので,乙円の直径は内接円の直径の 1/27 倍である。
ちなみに,甲円の直径は内接円の直径の 3/25 倍になっている。

function draw(more)
    pyplot(size=(500, 500), grid=false, aspectratio=1, label="", fontfamily="IPAMincho")
    r0 = 675/2
    r1 = 081/2
    (x1, y1, r2, x2, y2, cx, dx) = [140.29611541307898, 688.5, 12.499999999999389, -216.5063509461113, 612.499999999998, -224.83351829019105, 159.42740387849864]
    a =  √3r0
    cy = √3(a + cx)
    dy = √3(a - dx)
    plot([a, 0, -a, a], [0, √3a, 0, 0], color=:brown, lw=0.5)
    circle(0, a/√3, a/√3, :orange)
    circle(x1, y1, r1, :blue)
    circle(x2, y2, r2)
    segment(cx, cy, dx, dy, :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(a, 0, "a", :brown, :left, :bottom, delta=delta)
        point(0, r0, "O", :red, :center, delta=-delta)
        point(x1, y1, "A", :blue, :center, :vcenter, deltax=5delta)
        point(x2, y2, "C", :red, :right, :vcenter, deltax=-2delta)
        (x01, y01) = foot(a, 0, 0, √3a, 0, r0)
        point(x01, y01, " B", :orange, :left, :vcenter)
        (x02, y02) = foot(-a, 0, 0, √3a, 0, r0)
        point(x02, y02, "D ", :orange, :right, :vcenter)
    end
end;

draw(true)

コメント
  • X
  • Facebookでシェアする
  • はてなブックマークに追加する
  • LINEでシェアする

PVアクセスランキング にほんブログ村

PVアクセスランキング にほんブログ村