将表达式差异的结果添加到字符串变量

时间:2018-11-20 17:24:42

标签: wolfram-mathematica

我需要创建一个表达式差异列表(一阶,二阶等等),然后将结果打印到网格中。

我正在尝试使用下一个代码(以及许多其他变体,但是都错了)。我认为问题仅在于:ToString[D[z[x, y], {x, i - j}, {y, j}]]

MyFunction2[z_] := Block[ {x, y},
 arr = {{1, 1}, {1, 2, 1}, {1, 3, 3, 1}, {1, 4, 6, 4, 1}};
 result = {};
 For[i = 1, i <= 4, i++,
  res = "";
  For[j = 0, j <= i , j++,
   res = StringJoin[
    res,
    If[res == "", "", " + "], 
    If[arr[[i]][[j + 1]] > 1, 
    StringJoin[ToString[arr[[i]][[j + 1]]], "*"], ""],
    ToString[D[z[x, y], {x, i - j}, {y, j}]], 
    If[i - j > 0, "dx", ""],
    If[i - j > 1, StringJoin["^", ToString[ i - j]], ""], 
    If[j > 0, "dy", ""],
    If[j > 1, StringJoin["^", ToString[j]], ""]
   ];
  ];
  AppendTo[result, { StringJoin["d", If[i > 1, StringJoin["^", ToString[i]], ""], "z" ], res }];
   ];
  Grid[result, Frame -> All]
];
MyFunction2[Sin[x*y]]

我期望得到这样的结果:

| dz | *yCos(xy)dx + xCos(xy)dy* |

但是我得到的结果是: image with grid

您能建议我如何以人类可读的格式打印结果吗?

1 个答案:

答案 0 :(得分:0)

可能与您所寻找的不完全相同,但应该易于修改。

derivativeGrid[f_Function, xmax_Integer, ymax_Integer] := 
 Module[{derivatives, rowHeader, columnHeader, grid},
  derivatives = 
   Table[D[f[x, y], {x, i}, {y, j}], {i, 0, xmax}, {j, 0, ymax}];
  columnHeader = Table["dx"^x, {x, 0, xmax}];
  rowHeader = Join[{""}, Table["dy"^y, {y, 0, ymax}]];
  grid = MapThread[Prepend, {Prepend[derivatives, columnHeader], rowHeader}];
  Grid[grid, ItemStyle -> {{1 -> Bold}, {1 -> Bold}}, 
   Background -> {{LightYellow, None}, {LightYellow, None}}, 
   Frame -> All]]

由于它计算两个自变量f[x, y]的函数的导数,因此需要将其传递给两个自变量的函数。

derivativeGrid[Sin[#1*#2] &, 3, 3]

enter image description here