SymPy - คลาสฟังก์ชัน
แพ็คเกจ Sympy มีคลาสฟังก์ชันซึ่งกำหนดไว้ในโมดูล sympy.core.function เป็นคลาสพื้นฐานสำหรับฟังก์ชันทางคณิตศาสตร์ประยุกต์ทั้งหมดเช่นเดียวกับตัวสร้างสำหรับคลาสฟังก์ชันที่ไม่ได้กำหนด
ประเภทของฟังก์ชันต่อไปนี้สืบทอดมาจากคลาสฟังก์ชัน -
- ฟังก์ชันสำหรับจำนวนเชิงซ้อน
- ฟังก์ชันตรีโกณมิติ
- ฟังก์ชันสำหรับจำนวนเต็ม
- ฟังก์ชัน Combinatorial
- ฟังก์ชันเบ็ดเตล็ดอื่น ๆ
ฟังก์ชันสำหรับจำนวนเชิงซ้อน
ชุดของฟังก์ชันนี้กำหนดไว้ใน sympy.functions.elementary.complexes โมดูล.
re
ฟังก์ชันนี้ส่งคืนส่วนจริงของนิพจน์ -
>>> from sympy import *
>>> re(5+3*I)
ผลลัพธ์สำหรับข้อมูลโค้ดด้านบนแสดงไว้ด้านล่าง -
5
>>> re(I)
ผลลัพธ์สำหรับข้อมูลโค้ดด้านบนคือ -
0
Im
ฟังก์ชันนี้ส่งคืนส่วนจินตภาพของนิพจน์ -
>>> im(5+3*I)
ผลลัพธ์สำหรับข้อมูลโค้ดด้านบนแสดงไว้ด้านล่าง -
3
>>> im(I)
ผลลัพธ์สำหรับข้อมูลโค้ดด้านบนแสดงไว้ด้านล่าง -
1
sign
ฟังก์ชันนี้ส่งคืนเครื่องหมายที่ซับซ้อนของนิพจน์
สำหรับการแสดงออกจริงเครื่องหมายจะเป็น -
- 1 ถ้านิพจน์เป็นบวก
- 0 ถ้านิพจน์เท่ากับศูนย์
- -1 ถ้านิพจน์เป็นลบ
หากนิพจน์เป็นจินตภาพเครื่องหมายที่ส่งกลับคือ -
- ฉันถ้าฉัน (แสดงออก) เป็นบวก
- - ฉันถ้าฉัน (นิพจน์) เป็นลบ
>>> sign(1.55), sign(-1), sign(S.Zero)
ผลลัพธ์สำหรับข้อมูลโค้ดด้านบนแสดงไว้ด้านล่าง -
(1, -1, 0)
>>> sign (-3*I), sign(I*2)
ผลลัพธ์สำหรับข้อมูลโค้ดด้านบนแสดงไว้ด้านล่าง -
(-I, I)
Abs
ฟังก์ชันนี้ส่งคืนค่าสัมบูรณ์ของจำนวนเชิงซ้อน กำหนดเป็นระยะห่างระหว่างจุดกำเนิด (0,0) กับจุด (a, b) ในระนาบเชิงซ้อน ฟังก์ชันนี้เป็นส่วนเสริมของฟังก์ชัน abs ในตัว () เพื่อยอมรับค่าสัญลักษณ์
>>> Abs(2+3*I)
ผลลัพธ์สำหรับข้อมูลโค้ดด้านบนแสดงไว้ด้านล่าง -
$\sqrt13$
conjugate
ฟังก์ชันนี้จะคืนค่าคอนจูเกตของจำนวนเชิงซ้อน ในการหาคอนจูเกตที่ซับซ้อนเราเปลี่ยนสัญลักษณ์ของส่วนจินตภาพ
>>> conjugate(4+7*I)
คุณจะได้รับผลลัพธ์ต่อไปนี้หลังจากเรียกใช้ข้อมูลโค้ดด้านบน -
4 - 7i
ฟังก์ชันตรีโกณมิติ
SymPy มีข้อกำหนดสำหรับอัตราส่วนตรีโกณมิติทั้งหมด - sin cos, tan และอื่น ๆ รวมทั้งส่วนที่ผกผันเช่น asin, acos, atan เป็นต้นฟังก์ชันเหล่านี้คำนวณค่าตามลำดับสำหรับมุมที่กำหนดซึ่งแสดงเป็นเรเดียน
>>> sin(pi/2), cos(pi/4), tan(pi/6)
ผลลัพธ์สำหรับข้อมูลโค้ดด้านบนแสดงไว้ด้านล่าง -
(1, sqrt(2)/2, sqrt(3)/3)
>>> asin(1), acos(sqrt(2)/2), atan(sqrt(3)/3)
ผลลัพธ์สำหรับข้อมูลโค้ดด้านบนแสดงไว้ด้านล่าง -
(pi/2, pi/4, pi/6)
ฟังก์ชันเกี่ยวกับจำนวนเต็ม
นี่คือชุดของฟังก์ชันเพื่อดำเนินการต่างๆกับจำนวนเต็ม
ceiling
นี่คือฟังก์ชันที่ไม่แปรผันซึ่งส่งกลับค่าจำนวนเต็มที่น้อยที่สุดไม่น้อยกว่าอาร์กิวเมนต์ ในกรณีที่มีจำนวนเชิงซ้อนเพดานของส่วนจริงและส่วนจินตภาพแยกกัน
>>> ceiling(pi), ceiling(Rational(20,3)), ceiling(2.6+3.3*I)
ผลลัพธ์สำหรับข้อมูลโค้ดด้านบนแสดงไว้ด้านล่าง -
(4, 7, 3 + 4*I)
floor
ฟังก์ชันนี้ส่งคืนค่าจำนวนเต็มมากที่สุดไม่เกินอาร์กิวเมนต์ ในกรณีของจำนวนเชิงซ้อนฟังก์ชันนี้จะใช้พื้นของส่วนจริงและส่วนจินตภาพแยกจากกัน
>>> floor(pi), floor(Rational(100,6)), floor(6.3-5.9*I)
ผลลัพธ์สำหรับข้อมูลโค้ดด้านบนแสดงไว้ด้านล่าง -
(3, 16, 6 - 6*I)
frac
ฟังก์ชันนี้แทนส่วนเศษส่วนของ x
>>> frac(3.99), frac(Rational(10,3)), frac(10)
ผลลัพธ์สำหรับข้อมูลโค้ดด้านบนแสดงไว้ด้านล่าง -
(0.990000000000000, 1/3, 0)
ฟังก์ชัน Combinatorial
Combinatorics เป็นสาขาวิชาคณิตศาสตร์ที่เกี่ยวข้องกับปัญหาของการเลือกการจัดเรียงและการดำเนินการภายในระบบที่ จำกัด หรือไม่ต่อเนื่อง
factorial
แฟกทอเรียลมีความสำคัญมากในการรวมกันของวัตถุที่ให้จำนวนวิธีที่สามารถเปลี่ยนวัตถุ n ได้ เป็นสัญลักษณ์แทน! ฟังก์ชันนี้เป็นการนำฟังก์ชันแฟกทอเรียลไปใช้กับจำนวนเต็มที่ไม่เป็นค่าลบแฟกทอเรียลของจำนวนเต็มลบเป็นอินฟินิตี้ที่ซับซ้อน
>>> x=Symbol('x')
>>> factorial(x)
ผลลัพธ์สำหรับข้อมูลโค้ดด้านบนแสดงไว้ด้านล่าง -
x!
>>> factorial(5)
ผลลัพธ์สำหรับข้อมูลโค้ดด้านบนแสดงไว้ด้านล่าง -
120
>>> factorial(-1)
ผลลัพธ์สำหรับข้อมูลโค้ดด้านบนแสดงไว้ด้านล่าง -
$\infty\backsim$
ทวินาม
ฟังก์ชันนี้เป็นจำนวนวิธีที่เราสามารถเลือกองค์ประกอบ k จากชุดขององค์ประกอบ n
>>> x,y=symbols('x y')
>>> binomial(x,y)
ผลลัพธ์สำหรับข้อมูลโค้ดด้านบนแสดงไว้ด้านล่าง -
$(\frac{x}{y})$
>>> binomial(4,2)
ผลลัพธ์สำหรับข้อมูลโค้ดด้านบนแสดงไว้ด้านล่าง -
6
แถวของรูปสามเหลี่ยมของ Pascal สามารถสร้างได้ด้วยฟังก์ชันทวินาม
>>> for i in range(5): print ([binomial(i,j) for j in range(i+1)])
คุณจะได้รับผลลัพธ์ต่อไปนี้หลังจากเรียกใช้ข้อมูลโค้ดด้านบน -
[1]
[1, 1]
[1, 2, 1]
[1, 3, 3, 1]
[1, 4, 6, 4, 1]
fibonacci
ตัวเลขฟีโบนักชีคือลำดับจำนวนเต็มที่กำหนดโดยเงื่อนไขเริ่มต้น F0 = 0, F1 = 1 และความสัมพันธ์การเกิดซ้ำสองระยะ Fn = Fn − 1 + Fn − 2
>>> [fibonacci(x) for x in range(10)]
ผลลัพธ์ต่อไปนี้จะได้รับหลังจากเรียกใช้ข้อมูลโค้ดด้านบน -
[0, 1, 1, 2, 3, 5, 8, 13, 21, 34]
tribonacci
ตัวเลข Tribonacci คือลำดับจำนวนเต็มที่กำหนดโดยเงื่อนไขเริ่มต้น F0 = 0, F1 = 1, F2 = 1 และความสัมพันธ์การเกิดซ้ำสามระยะ Fn = Fn-1 + Fn-2 + Fn-3
>>> tribonacci(5, Symbol('x'))
ข้อมูลโค้ดด้านบนให้เอาต์พุตเทียบเท่ากับนิพจน์ด้านล่าง -
$x^8 + 3x^5 + 3x^2$
>>> [tribonacci(x) for x in range(10)]
ผลลัพธ์ต่อไปนี้จะได้รับหลังจากเรียกใช้ข้อมูลโค้ดด้านบน -
[0, 1, 1, 2, 4, 7, 13, 24, 44, 81]
ฟังก์ชันเบ็ดเตล็ด
ต่อไปนี้เป็นรายการฟังก์ชันที่ใช้บ่อย -
Min- ส่งกลับค่าต่ำสุดของรายการ ชื่อ Min เพื่อหลีกเลี่ยงความขัดแย้งกับฟังก์ชัน min ในตัว
Max- ส่งกลับค่าสูงสุดของรายการ มีชื่อว่า Max เพื่อหลีกเลี่ยงความขัดแย้งกับฟังก์ชัน max ในตัว
root - ส่งคืนรูทที่ n ของ x
sqrt - ส่งกลับค่ารากที่สองหลักของ x
cbrt - ฟังก์ชันนี้คำนวณรูทคิวบ์หลักของ x, (ทางลัดสำหรับ x ++ Rational (1,3))
ต่อไปนี้เป็นตัวอย่างของฟังก์ชันเบ็ดเตล็ดข้างต้นและเอาต์พุตที่เกี่ยวข้อง -
>>> Min(pi,E)
e
>>> Max(5, Rational(11,2))
$\frac{11}{2}$
>>> root(7,Rational(1,2))
49
>>> sqrt(2)
$\sqrt2$
>>> cbrt(1000)
10