বৃত্ত-রেখা ছেদবিন্দু#
একটি বৃত্তের কেন্দ্রের স্থানাঙ্ক ও ব্যাসার্ধ, এবং একটি রেখার সমীকরণ দেওয়া আছে, আপনাকে ছেদবিন্দুগুলো খুঁজতে হবে।
সমাধান#
দুটি সমীকরণের ব্যবস্থা সমাধান করার বদলে, আমরা সমস্যাটি জ্যামিতিকভাবে সমাধান করব। এতে সাংখ্যিক স্থিতিশীলতার দিক থেকে আরো সঠিক সমাধান পাওয়া যায়।
সাধারণতা না হারিয়ে আমরা ধরে নিচ্ছি বৃত্তের কেন্দ্র মূলবিন্দুতে। যদি না হয়, আমরা সেখানে সরাই এবং রেখার সমীকরণে $C$ ধ্রুবক সংশোধন করি। তাই আমাদের $(0,0)$ কেন্দ্র ও $r$ ব্যাসার্ধের একটি বৃত্ত এবং $Ax+By+C=0$ সমীকরণের একটি রেখা আছে।
আসুন রেখার উপর মূলবিন্দুর নিকটতম বিন্দু $(x_0, y_0)$ খুঁজি। প্রথমত, এটি মূলবিন্দু থেকে নিম্নলিখিত দূরত্বে থাকতে হবে
$$ d_0 = \frac{|C|}{\sqrt{A^2+B^2}} $$দ্বিতীয়ত, যেহেতু ভেক্টর $(A, B)$ রেখার সাথে লম্ব, বিন্দুর স্থানাঙ্ক এই ভেক্টরের স্থানাঙ্কের সমানুপাতিক হবে। যেহেতু আমরা মূলবিন্দু থেকে বিন্দুর দূরত্ব জানি, আমাদের কেবল $(A, B)$ ভেক্টরকে এই দৈর্ঘ্যে স্কেল করতে হবে, এবং আমরা পাব:
$$\begin{align} x_0 &= - \frac{AC}{A^2 + B^2} \\ y_0 &= - \frac{BC}{A^2 + B^2} \end{align}$$ঋণাত্মক চিহ্নগুলো স্পষ্ট নয়, কিন্তু রেখার সমীকরণে $x_0$ ও $y_0$ প্রতিস্থাপন করে সহজেই যাচাই করা যায়।
এই পর্যায়ে আমরা ছেদবিন্দুর সংখ্যা নির্ণয় করতে পারি, এবং এমনকি এক বা শূন্য বিন্দু হলে সমাধানও খুঁজতে পারি। আসলে, $(x_0, y_0)$ থেকে মূলবিন্দুর দূরত্ব $d_0$ যদি ব্যাসার্ধ $r$-র চেয়ে বড় হয়, উত্তর শূন্য বিন্দু। যদি $d_0=r$, উত্তর একটি বিন্দু $(x_0, y_0)$। যদি $d_0 তাহলে, আমরা জানি $(x_0, y_0)$ বিন্দুটি বৃত্তের ভিতরে। দুটি ছেদবিন্দু, $(a_x, a_y)$ ও $(b_x, b_y)$, অবশ্যই রেখা $Ax+By+C=0$-র উপর থাকবে এবং $(x_0, y_0)$ থেকে সমান দূরত্ব $d$-এ থাকবে, এবং এই দূরত্ব সহজেই বের করা যায়: লক্ষ্য করুন ভেক্টর $(-B, A)$ রেখার সাথে সমরেখ, এবং তাই $(x_0, y_0)$ বিন্দুতে $d$ দৈর্ঘ্যে স্কেল করা ভেক্টর $(-B,A)$ যোগ ও বিয়োগ করে প্রশ্নোক্ত বিন্দুগুলো খুঁজতে পারি। সবশেষে, দুটি ছেদবিন্দুর সমীকরণ: আমরা যদি মূল সমীকরণ ব্যবস্থা বীজগণিতিক পদ্ধতিতে সমাধান করতাম, সম্ভবত ভিন্ন আকারে বড় ত্রুটিসহ উত্তর পেতাম। এখানে বর্ণিত জ্যামিতিক পদ্ধতিটি আরো দৃষ্টিগ্রাহ্য এবং আরো সঠিক। শুরুতে যেমন বলা হয়েছে, আমরা ধরে নিচ্ছি বৃত্তের কেন্দ্র মূলবিন্দুতে, এবং তাই প্রোগ্রামের ইনপুট হলো বৃত্তের ব্যাসার্ধ $r$ এবং রেখার সমীকরণের প্যারামিটার $A$, $B$ ও $C$।ইমপ্লিমেন্টেশন#
double r, a, b, c; // given as input
double x0 = -a*c/(a*a+b*b), y0 = -b*c/(a*a+b*b);
if (c*c > r*r*(a*a+b*b)+EPS)
puts ("no points");
else if (abs (c*c - r*r*(a*a+b*b)) < EPS) {
puts ("1 point");
cout << x0 << ' ' << y0 << '\n';
}
else {
double d = r*r - c*c/(a*a+b*b);
double mult = sqrt (d / (a*a+b*b));
double ax, ay, bx, by;
ax = x0 + b * mult;
bx = x0 - b * mult;
ay = y0 - a * mult;
by = y0 + a * mult;
puts ("2 points");
cout << ax << ' ' << ay << '\n' << bx << ' ' << by << '\n';
}অনুশীলন সমস্যা#