algorithm - Maxima- 以更多算法方式进行符号变量替换

标签 algorithm substitution maxima

expJ:listarray(J);

(expJ)  ["-(l[1]*l[3]*m[3]*('diff(r[3](t),t,1))^2*sin(r[3](t)-r[1](t))+(2*l[1]*l[2]*m[3]+l[1]*l[2]*m[2])*('diff(r[2](t),t,1))^2*sin(r[2](t)-r[1](t))-l[1]*m[1]*g*cos(r[1](t)))/2","-(l[2]*l[3]*m[3]*('diff(r[3](t),t,1))^2*sin(r[3](t)-r[2](t))+((-2*l[1]*l[2]*m[3])-l[1]*l[2]*m[2])*('diff(r[1](t),t,1))^2*sin(r[2](t)-r[1](t))-2*l[2]*m[2]*g*cos(r[2](t)))/2","(l[2]*l[3]*m[3]*('diff(r[2](t),t,1))^2*sin(r[3](t)-r[2](t))+l[1]*l[3]*m[3]*('diff(r[1](t),t,1))^2*sin(r[3](t)-r[1](t))+3*l[3]*m[3]*g*cos(r[3](t)))/2"]
for i:1 thru 3 do(
    for k:1 thru 3 do(
J[i,1]:ssubst("m3","m[3]",J[i,1])
));

我想用算法替换 m 前面的数字,因为它们是 1,2,3,但是当我输入 mi 时,它会将其识别为不同的变量,因此我需要以某种方式指示 ssubs("mi","m[ i]",J[i,1]) 因为 i 与 m 是分开的。 有什么建议吗?

最佳答案

好的,这是用v(k)代替v[k]的方法。我相信这没关系,因为 Matlab 可以识别数组下标的括号。

%o5 是您在上面提供的输入(作为字符串)。我已经解析了 %o7 中的字符串并提取了 %o10 中的下标变量列表(通过 sublistsubvarp)。我从那里在 %o14 中创建了一个列表 v(k) = v[k],然后将它们替换回 %o15 中的解析表达式。

我希望这会朝着对您有所帮助的方向发展。您可能仍需要修改此方法以获得您想要的结果,但无论如何,我将重申我反对字符串处理的非常强烈的建议。如果还有更多事情要做,那么使用表达式比使用字符串几乎可以肯定更好。

(%o5) [-(l[1]*l[3]*m[3]*('diff(r[3](t),t,1))^2*sin(r[3](t)-r[1](t))+(2*l[1]*l[\
2]*m[3]+l[1]*l[2]*m[2])*('diff(r[2](t),t,1))^2*sin(r[2](t)-r[1](t))-l[1]*m[1]*\
g*cos(r[1](t)))/2, -(l[2]*l[3]*m[3]*('diff(r[3](t),t,1))^2*sin(r[3](t)-r[2](t)\
)+((-2*l[1]*l[2]*m[3])-l[1]*l[2]*m[2])*('diff(r[1](t),t,1))^2*sin(r[2](t)-r[1]\
(t))-2*l[2]*m[2]*g*cos(r[2](t)))/2, (l[2]*l[3]*m[3]*('diff(r[2](t),t,1))^2*sin\
(r[3](t)-r[2](t))+l[1]*l[3]*m[3]*('diff(r[1](t),t,1))^2*sin(r[3](t)-r[1](t))+3\
*l[3]*m[3]*g*cos(r[3](t)))/2]
(%i6) linel:65;
(%o6)                          65
(%i7) map (parse_string, %o5);
                     d          2
(%o7) [((- l  l  m  (-- (r (t)))  sin(r (t) - r (t)))
            1  3  3  dt   3            3       1
                            d          2
 - (2 l  l  m  + l  l  m ) (-- (r (t)))  sin(r (t) - r (t))
       1  2  3    1  2  2   dt   2            2       1
                                        d          2
 + l  m  g cos(r (t)))/2, ((- l  l  m  (-- (r (t)))
    1  1        1              2  3  3  dt   3
                                                    d          2
 sin(r (t) - r (t))) - ((- 2 l  l  m ) - l  l  m ) (-- (r (t)))
      3       2               1  2  3     1  2  2   dt   1
 sin(r (t) - r (t)) + 2 l  m  g cos(r (t)))/2, 
      2       1          2  2        2
           d          2
(l  l  m  (-- (r (t)))  sin(r (t) - r (t))
  2  3  3  dt   2            3       2
             d          2
 + l  l  m  (-- (r (t)))  sin(r (t) - r (t))
    1  3  3  dt   1            3       1
 + 3 l  m  g cos(r (t)))/2]
      3  3        3
(%i8) grind (%);

[((-l[1]*l[3]*m[3]*('diff(r[3](t),t,1))^2*sin(r[3](t)-r[1](t)))
  -(2*l[1]*l[2]*m[3]+l[1]*l[2]*m[2])
   *('diff(r[2](t),t,1))^2*sin(r[2](t)-r[1](t))
  +l[1]*m[1]*g*cos(r[1](t)))
  /2,
 ((-l[2]*l[3]*m[3]*('diff(r[3](t),t,1))^2*sin(r[3](t)-r[2](t)))
  -((-2*l[1]*l[2]*m[3])-l[1]*l[2]*m[2])
   *('diff(r[1](t),t,1))^2*sin(r[2](t)-r[1](t))
  +2*l[2]*m[2]*g*cos(r[2](t)))
  /2,
 (l[2]*l[3]*m[3]*('diff(r[2](t),t,1))^2*sin(r[3](t)-r[2](t))
  +l[1]*l[3]*m[3]*('diff(r[1](t),t,1))^2*sin(r[3](t)-r[1](t))
  +3*l[3]*m[3]*g*cos(r[3](t)))
  /2]$
(%o8)                         done
(%i9) listofvars (%o7);
(%o9)            [l , m , g, t, l , m , m , l ]
                   1   1         2   2   3   3
(%i10) sublist (%, subvarp);
(%o10)              [l , m , l , m , m , l ]
                      1   1   2   2   3   3
(%i11) map (op, %o10);
(%o11)                 [l, m, l, m, m, l]
(%i12) map (args, %o10);
(%o12)           [[1], [1], [2], [2], [3], [3]]
(%i13) map (lambda ([v], apply (op(v), args(v))), %o10);
(%o13)        [l(1), m(1), l(2), m(2), m(3), l(3)]
(%i14) map (lambda ([v1, v2], v1=v2), %o10, %o13);
(%o14) [l  = l(1), m  = m(1), l  = l(2), m  = m(2), m  = m(3), 
         1          1          2          2          3
                                                       l  = l(3)]
                                                        3
(%i15) subst (%, %o7);
                            d          2
(%o15) [((- l(1) l(3) m(3) (-- (r (t)))  sin(r (t) - r (t)))
                            dt   3            3       1
                                        d          2
 - (2 l(1) l(2) m(3) + l(1) l(2) m(2)) (-- (r (t)))
                                        dt   2
 sin(r (t) - r (t)) + l(1) m(1) g cos(r (t)))/2, 
      2       1                        1
                    d          2
((- l(2) l(3) m(3) (-- (r (t)))  sin(r (t) - r (t)))
                    dt   3            3       2
                                            d          2
 - ((- 2 l(1) l(2) m(3)) - l(1) l(2) m(2)) (-- (r (t)))
                                            dt   1
 sin(r (t) - r (t)) + 2 l(2) m(2) g cos(r (t)))/2, 
      2       1                          2
                 d          2
(l(2) l(3) m(3) (-- (r (t)))  sin(r (t) - r (t))
                 dt   2            3       2
                   d          2
 + l(1) l(3) m(3) (-- (r (t)))  sin(r (t) - r (t))
                   dt   1            3       1
 + 3 l(3) m(3) g cos(r (t)))/2]
                      3
(%i16) grind (%);

[((-l(1)*l(3)*m(3)*('diff(r[3](t),t,1))^2*sin(r[3](t)-r[1](t)))
  -(2*l(1)*l(2)*m(3)+l(1)*l(2)*m(2))
   *('diff(r[2](t),t,1))^2*sin(r[2](t)-r[1](t))
  +l(1)*m(1)*g*cos(r[1](t)))
  /2,
 ((-l(2)*l(3)*m(3)*('diff(r[3](t),t,1))^2*sin(r[3](t)-r[2](t)))
  -((-2*l(1)*l(2)*m(3))-l(1)*l(2)*m(2))
   *('diff(r[1](t),t,1))^2*sin(r[2](t)-r[1](t))
  +2*l(2)*m(2)*g*cos(r[2](t)))
  /2,
 (l(2)*l(3)*m(3)*('diff(r[2](t),t,1))^2*sin(r[3](t)-r[2](t))
  +l(1)*l(3)*m(3)*('diff(r[1](t),t,1))^2*sin(r[3](t)-r[1](t))
  +3*l(3)*m(3)*g*cos(r[3](t)))
  /2]$
(%o16)                        done
(%i17) listofvars (%o15);
(%o17)                       [g, t]

关于algorithm - Maxima- 以更多算法方式进行符号变量替换,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51852093/

相关文章:

algorithm - 以下等式的时间复杂度是多少

python - 字符串替换的无错误版本

python - "GenerateMatrix"SymPy 中的等效命令

maxima - 在 Maxima 中堆叠矩阵的列

algorithm - 计算 N 个事件中 M 个出现的概率

algorithm - 如何判断一条边是否在某条路径上

c++ - 在大型阵列上查找编辑距离的更有效方法

linux - Bash 脚本变量替换

python - 原子替换多个字符