公告:本站正式转型为非交互式静态网站!
转型:本站将通过笔记和博客的形式继续为大家服务,关于 Mathematica 问答服务请移步至QQ群:365716997
联系:如有问题请联系QQ群管理员,或发送邮件至:lixuan.xyz@qq.com。
感谢:最后非常感谢大家多年来的支持与帮助!
参考《互联网跟帖评论服务管理规定》《中华人民共和国网络安全法》《网络信息内容生态治理规定》《互联网用户账号信息管理规定》

—— 2022-11-27

欢迎来到 Mathematica 问答社区

提问时请贴上文本代码

语法高亮:在编辑器中点击

被禁止的话题:广告破解

请阅读:《提问的智慧》

备用域名:mma.ooo

支持LaTex数学公式
行内公式标识符:\$ 或“$\backslash ($”+“$\backslash )$”,
行间公式标识符:\$\$ 或 “$\backslash [$”+“$\backslash ]$”

社区建议QQ群:365716997

分类

0 投票
639 浏览

一直是没有搞明白函数的选项是如何定义的。现在有以下这些情况:

1.所调用的下一级自定义函数有和本级函数同名的选项,但是需要要分开处置(ParallelTable)

2.所调用的下一级自定义函数有多个不同种类的选项

fn = x + y + z(*此处随手瞎编的不要在意*)
test0[xmin_, xmax_, ymin_, ymax_, step_, opts : OptionsPattern[]] :=
 Show[Graphics[RasterArray[
    ParallelTable[
     Hue[(Arg[fn] + \[Pi])/(2 \[Pi]),
       1/(1 + 0.3 Log[Abs[fn] + 1]),
       1 - 1/(1.1 + 5 Log[Abs[fn] + 1]), 1]
      {y, ymin + 0.0012, ymax, step},
     {x, xmin + 0.0012, xmax, step},
     Evaluate[FilterRules[{opts}, Options[ParallelTable]]]]]], 
  ImageSize -> (20 + (xmax - xmin)/step),
  Evaluate[FilterRules[{opts}, Options[Graphics]]]]
test1[xmin_, xmax_, ymin_, ymax_, step_, zmin_, zmax_, ymin_, ymax_, 
  step_, zstep_(*然后应该咋写呢?*)] :=
 ListAnimate[ParallelTable[
   test0[xmin, xmax, ymin, ymax, step,(*传送给下一层的选项*)],
   {z, zmin, zmax, (zmax - zmin)/zstep},
   Evaluate[FilterRules[{opts}, Options[ParallelTable]]]],
  Evaluate[FilterRules[{opts}, Options[ListAnimate]]]]

 

分类:函数 | 用户: EmberEdison (806 分)

1个回答

+3 投票
 
已采纳

第一个问题没法区分,因为这并不是mma的问题,是你在设计函数的时候自己没考虑到的问题。简化问题为:

Options[g] = {"a" -> 1};
Options[h] = {"a" -> 2};
f[x_, opts : OptionsPattern[]] := g[x, h[x, opts], opts]

g和h的选项一样,那么显然使用f[1,"a"->3]时mma无法猜测出你心中的想法,"a"到底是给g还是给h。
一种解决方法是,请主动告诉程序区分点是什么。

Options[g] = {a -> 1};
Options[h] = {a -> 2};
Options[f] = {a1 -> 1, a2 -> 2};

f[x_, opts : OptionsPattern[]] := 
 Module[{opts1, opts2, classifyOption},
  classifyOption[opt_, val_] := 
   Cases[opt, ((a_?(StringTake[ToString@#, -1] == val &)) -> 
       b_) :> (ToExpression@StringDrop[ToString@a, -1] -> b)];
  {opts1, opts2} = classifyOption[{opts}, #] & /@ {"1", "2"};
  g[x, h[x, opts1], opts2]
  ]
  
f[1, a1 -> 1, a2 -> 2]
f[1, a1 -> 1]
f[1, a2 -> 1]

 

用户: 苹果 (2.2k 分)
采纳于 用户:EmberEdison
...