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