Maxima导引

来自Ubuntu中文
Bones7456留言 | 贡献2008年1月25日 (五) 17:36的版本
跳到导航跳到搜索

来源:http://blog.chinaunix.net/u/20/showart_172159.html

作者:win_hate

Maxima: http://wiki.ubuntu.org.cn/Maxima

函数

定义函数

注意函数使用的符号是 :=

一元函数

f(x):=expr;

例子:

(%i1) f(x):= 1+x;
(%o1)                            f(x) := 1 + x
(%i2) f(2);
(%o2)                                  3

多元函数

f(x,y):=expr;

例子:

(%i3) f(x,y):=y^2+x^2;
                                         2    2
(%o3)                         f(x, y) := y  + x
(%i4) f(2,3);
(%o4)                                 13

初等函数

幂函数: x^2, x^(-1/2),...
指数函数:2^x, (1/2)^x, exp(x), %e^x...
在 maxima 中,常数e=2.718281828459045被记为:%e. 所以指数函数 e^x 在 maxima 中被表示为:%e^x

由于这个函数的重要性,它有一个专门的记法:exp(x).

(%i2)f(x) := %e^x;
                                            x
(%o2)                             f(x) := %e
(%i3)g(x) := exp(x);
(%o3)                           g(x) := exp(x)
(%i4)expand(f(x) - g(x));
(%o4)                                  0
对数函数:log(x)
在 maxima 中,log(x) 就是自然对数,即以 e 为底的对数,数学上常记为 ln(x)。maxima 没有其它形式的对数,要使用以 10 或 2 为底的对数,只能使用换底公式。如果把下面的代码放到 ~/.maxima/maxima-init.mac 中,则 maxima 在运行时会加载自定义函数 log10、log2,并把 ln 定义为 log。这样就可以使用 log10、log2 和 ln 了。
log10(x):=log(x)/log(10);
log2(x):=log(x)/log(2);
ln:log; 
三角函数:sin, cos, tan, cot, sec, csc
在 maxima 中,pi=3.141592653589793 被记为 %pi.
反三角函数:asin, acos, atan, acot, asec, acsc

分段函数

f(x)= x-1, x<0
      0,   x=0
      x+1, x>0
(%i2) f(x) := if x < 0 then x - 1 else (if x = 0 then 0 else 1 + x);
(%o2)    f(x) := if x < 0 then x - 1 else (if x = 0 then 0 else 1 + x)
(%i3) f(- 1);
(%o3)                                 - 2
(%i4) f(0)
(%o4)                                  0
(%i5) f(1)
(%o5)                                  2

极限

求极限的命令为:

limit (expr, var, val, direction);


expr 是要求极限的表达式; var 是变量名; val 指定在何处取极限;direction 是方向,可以是 plus 和 miuns,分别指右极限和左极限。


例子:

(%i2)limit (sin(x)/x, x, 0);
(%o2)                           1
(%i3)limit (tan(x), x, %pi/2);
(%o3)                          und
(%i4)f:diff(abs(x), x);
(%i5)limit(f, x, 0, plus);
(%o5)                           1
(%i6)limit(f, x, 0, minus);
(%o6)                          -1


其中 und 表示极限不存在。

如果要取无穷处的极限,可以用常数 inf, minf。前者表示正无穷,后者表示负无穷。

(%i1) limit (1/x, x, inf);
(%o1)                           0
(%i2) limit (atan(x), x, inf);
(%o2)                         %pi/2
(%i3) limit (atan(x), x, minf);
(%o3)                         -%pi/2

导数

求导数:

diff(expr, var)

例子:
 (%i1) diff(sin(x),x);
 (%o1) cos(x)
 (%i2) diff(f(x)*g(x),x);
             d                  d
 (%o2) f(x) (-- (g(x))) + g(x) (-- (f(x)))
             dx                 dx

求高阶导数:

diff(expr, var, n) 


例子:

(%i3)diff(sin(x),x, 2);
(%o3) - sin(x)
(%i4) diff(f(x)*g(x),x,3);
            3                            2
           d                d           d

(%o4) f(x) (--- (g(x))) + 3 (-- (f(x))) (--- (g(x)))

             3              dx            2
           dx                           dx
                                     2                               3
                                    d            d                  d
                               + 3 (--- (f(x))) (-- (g(x))) + g(x) (--- (f(x)))
                                      2          dx                   3
                                    dx                              dx

集合

集合定义

maxima 似乎只支持有限集。建立集合的方式是列举。 ;set(a_1, ..., a_n) :n 个元素的集合 ;{a_1, ..., a_n} :同上 ;setify(foo):list->set :把列表 foo 转换为集合 ;fullsetify(foo) :把列表 foo 转换为集合, 对列表的列表元素递归调用 fullsetify。列表的列表元素指的是:列表的一个元素,本身又是一个列表。 例子: (%i2) A : set(1, 2, 3) (%o2) {1, 2, 3} (%i3) B : {a, b, c} (%o3) {a, b, c} (%i4) C : {} (%o4) {} (%i2) setify([a, b, c]) (%o2) {a, b, c} (%i3) setify([a, b, [1, 2], [a, b, c]]) (%o3) {[1, 2], a, [a, b, c], b} (%i2) fullsetify([a, b, [1, 2], [a, b, c]]) (%o2) {{1, 2}, a, {a, b, c}, b}

元素与集合

;elementp(x,y) :判断 x 是否集合 S 的元素 ;adjoin(x, S) :返回集合 {t | (t in S) or t = x} 即返回把 x 添加到 S 中得到的集合,但 S 本身并不改变。 ;disjoin(x, S) :返回把 x 从集合 S 中去除后的集合,S 本身并不改变。 例子: (%i2) A : {a, b, c} (%o2) {a, b, c} (%i3) elementp(a, A) (%o3) true (%i4) elementp(d, A) (%o4) false # 把 d 添加到 A 中 (%i5) adjoin(d, A) (%o5) {a, b, c, d} # A 并未改变,d 不是 A 的元素 (%i6) elementp(d, A) (%o6) false # 把 d 添加到 A 中,并把得到的集合赋值给 A (%i7) A : adjoin(d, A) (%o7) {a, b, c, d} (%i8) elementp(d, A) (%o8) true (%i9) A : disjoin(a, A) (%o9) {b, c, d} (%i10) elementp(a, A) (%o10) false

集合运算

;emptyp(S) :判断 S 是否空集 ;intersection(A, B) :交 ;intersect(A, B) :同上,似乎无任何区别 ;union (A, B) :并 ;setdifference(A, B) :差,余。 A\B ;symmdifference(A,B) :对称差 ;subsetp(A,B) :判断 A 是否 B 的子集 ;subset(A, f) :返回集合 {x | (x in A) and (f(x)=true)} f 必须是谓词函数,也即其值域为 {true, false}。 ;subset (A, f): 返回一个 A 的一个子集合,由 A 中满足 f 的元素全体组成。 ;powerset(A) :返回 A 的全部子集合构成的集合。 ;powerset(A,n) :返回 A 的大小为 n 的子集构成的集合。 ;cartesian_product(A,B) :返回 A, B 的笛卡尔积(直积)。 ;cardinality :返回集合 A 的大小|A|。 ;disjointp(A,B) :若集合 A, B 相交,则返回 false,否则返回 true。 例子: (%i2) A : {a, b, c} (%o2) {a, b, c} (%i3) B : {b, c, d} (%o3) {b, c, d} (%i4) intersection(A, B) (%o4) {b, c} (%i5) intersect(A, B) (%o5) {b, c} (%i6) setdifference(A, B) (%o6) {a} (%i7) symmdifference(A, B) (%o7) {a, d} (%i8) subsetp(A, B) (%o8) false (%i9) subsetp(setdifference(B, A), B) (%o9) true (%i10) powerset(A) (%o10) {{}, {a}, {a, b}, {a, b, c}, {a, c}, {b}, {b, c}, {c}} (%i11) powerset(A, 2) (%o11) {{a, b}, {a, c}, {b, c}} (%i12) cartesian_product(A, B) (%o12) {[a, b], [a, c], [a, d], [b, b], [b, c], [b, d], [c, b], [c, c], [c, d]} # 在 Maxima 中,用 % 表示上一条命令的输出,在这里,就是 A 与 B 的直积。 (%i13) cardinality(%) (%o13) 9