以下の内容はhttps://sangaku0418.hatenablog.com/entry/2024/02/16/210552より取得しました。


算額(その0699)

千葉県君津市鹿野山 鹿野山神野寺 万延二年(1861)

山口正義: やまぶき4,第58号,2018/12/06.
https://yamabukiwasan.sakura.ne.jp/ymbk58.pdf
山口正義:やまぶき,和算と歴史随想 からリンク
https://yamabukiwasan.sakura.ne.jp/page3.html
キーワード:楕円,正三角形
#Julia #SymPy #算額 #和算 #数学


高さ 64 寸の正三角形内に,短径 6 寸の甲楕円,長径 48 寸の乙楕円が入っている。
甲楕円の長径,乙楕円の短径を求めよ。

正三角形の一辺の長さを \(2a\)
甲楕円の長半径,短半径,中心座標を \(a_1,\ b_1,\ (0,\ 2b_2 + b_1)\)
乙楕円の長半径,短半径,中心座標を \(a_2,\ b_2,\ (0,\ b_2)\)
正三角形の斜辺と甲楕円,乙楕円との接点座標を \( (x_1,\ y_1),\ (x_2,\ y_2)\)
とおき,以下の連立方程式を解く。

include("julia-source.txt");  # julia-source.txt ソース

using SymPy
@syms a1::positive, b1::positive, x1::positive, y1::positive,
     a2::positive, b2::positive, x2::positive, y2::positive
@syms a::positive

s3 = sqrt(Sym(3))
(a1, a2) = (6, 48) .// 2
a = 64/s3
y1 = (a - x1)*s3
y2 = (a - x2)*s3
eq1 = x1^2/a1^2 + (y1 - (2b2 + b1))^2/b1^2 - 1
eq3 = x2^2/a2^2 + (y2 - b2)^2/b2^2 - 1
eq2 = -b1^2*x1/(a1^2*(y1 - (2b2 + b1))) + s3
eq4 = -b2^2*x2/(a2^2*(y2 - b2)) + s3
res = solve([eq1, eq2, eq3, eq4], (b1, x1, b2, x2))[1]

    (13, 9*sqrt(3)/14, 37/2, 1152*sqrt(3)/91)

甲楕円の長径は 26 寸,乙楕円の短径は 37 寸である。

描画関数プログラムのソースを見る

function draw(more=false)
   pyplot(size=(500, 500), grid=false, aspectratio=1, label="", fontfamily="IPAMincho")
   s3 = sqrt(3)
   h = 64
   a = h/s3
   (a1, a2) = (6, 48) .// 2
   (b1, x1, b2, x2) = (13, 9*sqrt(3)/14, 37/2, 1152*sqrt(3)/91)
   @printf("甲楕円の長径 = %g;  乙楕円の短径 = %g\n", 2b1, 2b2)
   y1 = (a - x1)*s3
   y2 = (a - x2)*s3
   plot([a, 0, -a, a], [0, h, 0, 0], color=:magenta, lw=0.5)
   ellipse(0, b2, a2, b2, color=:blue)
   ellipse(0, b1 + 2b2, a1, b1, color=:red)
   if more
       delta = (fontheight = (ylims()[2]- ylims()[1]) / 500 * 10 * 2) /3  # size[2] * fontsize * 2
       hline!([0], color=:black, lw=0.5)
       vline!([0], color=:black, lw=0.5)
       point(0, b1 + 2b2, " 甲楕円:a1,b1,(0,2b2+b1)", :black, :left, :vcenter)
       point(0, b2, " 乙楕円:a2,b2,(0,b2)", :black, :left, :vcenter)
       point(x1, y1, " (x1,y1)", :green, :left, :vcenter)
       point(x2, y2, " (x2,y2)", :green, :left, :vcenter)
   end
end;


以下のアイコンをクリックして応援してください




以上の内容はhttps://sangaku0418.hatenablog.com/entry/2024/02/16/210552より取得しました。
このページはhttp://font.textar.tv/のウェブフォントを使用してます

不具合報告/要望等はこちらへお願いします。
モバイルやる夫Viewer Ver0.14