我正在使用的表達式太複雜了,無法在這裏完全輸入,但我已經包含了一個簡單的示例,突出顯示了我遇到的問題。我希望有人在那裏有足夠的編程能力來幫助我解決這個問題。讓我先說這個,說我在編程方面一般沒有什麼背景,但我知道Mathematica的基礎知識。任何和所有的幫助,不勝感激。假設我已經設置了以下功能:Mathematica評估控制和表達式
X[x_] := x Log[x]
X[0] := 0
Y[y_] := y Log[y]
Y[0] := 0
Z[z_] := z Log[z]
A[x_, y_, z_] := X[x] + Y[y] + Z[z]
In[7]:= A[x, y, z]
Out[7]= x Log[x] + y Log[y] + z Log[z]
In[8]:= B[x_, y_, z_] :=
Evaluate[A[x, y, z] - x*D[A[x, y, z], x] - y*D[A[x, y, z], y] -
z*D[A[x, y, z], z]]
In[9]:= B[x, y, z]
Out[9]= x Log[x] - x (1 + Log[x]) + y Log[y] - y (1 + Log[y]) +
z Log[z] - z (1 + Log[z])
我已經建立了A[x,y,z]
與X[x]
,Y[y]
規則,Z[z]
以便它可以處理時x == 0
我想在A[x,y,z]
所有表達式的情況下x,y,z == 0
,即與x
去零或被忽略,包括Log[x]
。我已經定義了一個函數B[x,y,z]
,它涉及到A[x,y,z]
的部分派生。現在,我想要的結果,這樣B[0,y,z]
產生
yLog[y]-y(1+Log[y])+zLog[z]-z(1+Log[z])
那就是基本上回去,讓A[x,y,z]:= Y[y]+Z[z]
而是我目前運行到下面的,可以理解的,錯誤:
Infinity::indet: Indeterminate expression 0 (-[Infinity]) encountered. >>
必須有用Mathematica解決這個問題,我想知道是否會涉及Hold函數或相關的東西。謝謝大家的幫助。
這是一個簡單的修復,謝謝! – CaptanFunkyFresh 2012-01-07 21:31:36