ฉันเป็นเพียงการทดสอบตัวอย่างจากวิธีเชิงตัวเลขในงานวิศวกรรมกับงูหลาม
from numpy import zeros, array
from math import sin, log
from newtonRaphson2 import *
def f(x):
f = zeros(len(x))
f[0] = sin(x[0]) + x[1]**2 + log(x[2]) - 7.0
f[1] = 3.0*x[0] + 2.0**x[1] - x[2]**3 + 1.0
f[2] = x[0] + x[1] + x[2] -5.0
return f
x = array([1.0, 1.0, 1.0])
print newtonRaphson2(f,x)
เมื่อฉันรันมันแสดงข้อผิดพลาดต่อไปนี้:
File "example NR2method.py", line 8, in f
f[0] = sin(x[0]) + x[1]**2 + log(x[2]) - 7.0
ValueError: math domain error
ฉันได้ จำกัด มันให้แคบลงในบันทึกเมื่อฉันลบบันทึกและเพิ่มฟังก์ชันอื่นมันใช้งานได้ ฉันคิดว่ามันเป็นเพราะการรบกวนบางอย่างกับฐานฉันไม่สามารถเข้าใจได้ว่าเป็นอย่างไร ใครช่วยแนะนำวิธีแก้ไข