ฉันจะหาเกณฑ์สำหรับพหุนามที่จะมีและมีเพียงรากคู่ได้อย่างไร

Aug 19 2020

ในเอกสารวิธีใช้ของฟังก์ชันSolveAlwaysฉันเห็นเงื่อนไขว่าพหุนามมีรากสามตัว

(*Find a condition for a cubic polynomial to have a triple root:*)
f[x_] := x^3 + a x^2 + b x + c;
SolveAlways[Implies[f[x] == 0 && f[y] == 0, x == y], {x, y}]

ตอนนี้ฉันต้องการเลียนแบบตัวอย่างนี้เพื่อค้นหาเงื่อนไขที่พหุนามมีเพียงรากคู่ (ไม่มีหลายรากที่สูงกว่ากำลังสอง)

A = {{1, 2, -3}, {-1, 4, -3}, {1, a, 5}};
f[λ_] := CharacteristicPolynomial[A, λ]
Reduce[Exists[{x, y}, Implies[f[x] == 0 && f[y] == 0, x == y]], {a}]
Solve[(f[x] /. a -> -2) == 0, x]

SolveAlways[Implies[(f[x] == f'[x] == 0), f''[x] != 0], x]

แต่ผลลัพธ์ของโค้ดข้างต้นไม่ใช่เงื่อนไขการตัดสิน ฉันจะทำอย่างไรเพื่อแก้ปัญหานี้

คำตอบ

7 DanielLichtblau Aug 19 2020 at 22:46

คุณต้องการให้การเลือกปฏิบัติหายไปและการเลือกปฏิบัติของอนุพันธ์ไม่หายไป

mat = {{1, 2, -3}, {-1, 4, -3}, {1, a, 5}};
cpoly = CharacteristicPolynomial[mat, x];
disc1 = Discriminant[cpoly, x]
disc2 = Discriminant[D[cpoly, x], x]

(* Out[616]= -288 - 720 a - 504 a^2 - 108 a^3

Out[617]= -4 (2 + 9 a) *)

ตอนนี้จัดเรียงสิ่งเหล่านี้ออก

Reduce[disc1 == 0 && disc2 != 0]

(* Out[618]= a == -2 || a == -(2/3) *)
7 user64494 Aug 19 2020 at 23:47

การใช้นิยามของรากของทวีคูณ 2 หนึ่งได้รับ

A = {{1, 2, -3},{-1, 4, -3},{1, a, 5}};f[\[Lambda]_]:= CharacteristicPolynomial[A,\[Lambda]]
Reduce[Exists[x, f[x] == 0 && f'[x] == 0 && f''[x] != 0], a, Reals]
(*a == -2 || a == -(2/3)*)

แนวทางดังกล่าวไม่เพียง แต่ใช้ได้ผลกับพหุนามเท่านั้น

6 J.M.'sennui Aug 19 2020 at 14:02

นี่คือสิ่งที่ผู้เลือกปฏิบัติสามารถใช้ได้สำหรับ:

Reduce[Discriminant[CharacteristicPolynomial[{{1, 2, -3},
                                              {-1, 4, -3},
                                              {1, a, 5}}, x], x] == 0, a]
   a == -2 || a == -2/3

ตรวจสอบ:

With[{a = -2/3}, Eigenvalues[{{1, 2, -3}, {-1, 4, -3}, {1, a, 5}}]]
   {4, 4, 2}

With[{a = -2}, Eigenvalues[{{1, 2, -3}, {-1, 4, -3}, {1, a, 5}}]]
   {6, 2, 2}