自己常用的Mathematica代码


理论力学辅助:

Lf[tt_, vv_, var__, t_] := 
 Module[{l = Simplify[tt - vv], n = Length[var], i = 0},
  Table[D[D[l, D[var[[i]], t]], t] - D[l, var[[i]]], {i, 1, n}]
  ]

例子:

In[1]:= Lf[1/2 m x1'[t]^2 + 1/2 m x2'[t]^2, 
 1/2 k (x1[t]^2 + x2[t]^2), {x1[t], x2[t]}, t]

Out[1]= {k x1[t] + m (x1^\[Prime]\[Prime])[t], 
 k x2[t] + m (x2^\[Prime]\[Prime])[t]}

大物实验助手:

处理数据:

FixData[list_List, f_Function] := 
 Module[{l = Length[list]}, Table[f[list[[i]]], {i, 1, l}]]

离散函数频谱分析:

注:正在完善之中

FuL[l_List, \[Omega]_, \[Delta]t_, {a_, b_}] := 
 1/Abs[b - a] Total@
   Table[l[[i]] \[Delta]t E^(I \[Omega] i \[Delta]t), {i, 1, 
     Length[l]}]

(*使用示例*)
ls = Table[Evaluate[x[t] /. s], {t, 0, 200, 0.1}];(*s是一个混沌方程的解*)

PL = Flatten@
   Table[FuL[ls, \[Omega], 0.1, {0, 200}], {\[Omega], 0.1, 4, 0.002}];
频谱图
函数名称 用途 格式
FuL 计算频谱,输出列表 FuL[离散列表, 角频率, 间隔时间, {起始, 结束}]

复变函数绘图好帮手:

TransComplexPlot[w_, f_, {x_, xf_, xz_}, {y_, yf_, yz_}, 
  PlotPoints -> n_, PlotRange -> {{l_, r_}, {d_, u_}}] :=
 ParametricPlot[{Re[w[f]], Im[w[f]]}, {x, xf, xz}, {y, yf, yz}, 
  PlotPoints -> n, PlotRange -> {{l, r}, {d, u}}]

使用示例:


使用示例
可使用选项 用途 格式
PlotPoints 控制细致程度 PlotPoints->n
PlotRange 绘图范围 PlotRange -> {{l, r}, {d, u}}

波动光学绘图

Len = Compile[{{x, _Real}, {y, _Real}, {z, _Real}, {x2, _Real}, {y2, \
_Real}, {z2, _Real}}, 
  If[{x, y, z} != {x2, y2, z2}, Sqrt[
   N[(x - x2)^2 + (y - y2)^2 + (z - z2)^2]], 1.0]]

PutDot = Compile[{{x, _Real}, {y, _Real}, {z, _Real}, {\[CurlyPhi], \
_Real}, {\[Omega], _Real}, {W, _Real}, {b, _Real}, {L, _Integer}},
  Table[N[
    W/(b*Len[x, y, z, i, j, 0])*
     E^(-I (\[Omega] b*Len[x, y, z, i, j, 0] + \[CurlyPhi]))], {i, 1, 
    L}, {j, 1, L}]
  ]

LightDotQ[n_, \[Omega]_, b_, DList_] := Module[
  {x = Length[DList], LightPx = Table[0, {i, 1, n}, {j, 1, n}]},
  LightPx = 
   Abs[Sum[PutDot[DList[[k]][[1]], DList[[k]][[2]], 0, 
      DList[[k]][[3]], \[Omega], DList[[k]][[4]], b, n], {k, 1, x}]];
  ArrayPlot[LightPx, ColorFunction -> "Rainbow"]
  ]

LightDot3DQ[n_, \[Omega]_, b_, DList_, z_] :=
 Module[
  {x = Length[DList], LightPx = Table[0, {i, 1, n}, {j, 1, n}]},
  LightPx = 
   Abs[Sum[PutDot[DList[[k]][[1]], DList[[k]][[2]], z, 
      DList[[k]][[3]], \[Omega], DList[[k]][[4]], b, n], {k, 1, x}]];
  ArrayPlot[LightPx, ColorFunction -> "Rainbow"]
  ]

使用示例:

模拟平面上的有源相控阵光场
模拟三维空间中的光场

使用说明:

函数/变量名称 用途 格式
LightDotQ 绘制二维空间的光场 LightDotQ[图像大小, 光的频率, 空间密度, 光点序列]
LightDot3DQ 绘制三维空间的光场投到二维平面上的光强分布 LightDot3DQ[图像大小, 光的频率, 空间密度, 光点序列, 光点高度]
光点序列 描述一个光点 {x,y,初相位,光强}

遗传算法程序包(不完整)

1.建立种群:

MakeGroup[Num_Integer, f_Function] := Table[f[i], {i, 1, Num}]

示例:

In[1]  = MakeGroup[10, Sin[#/2] &]

Out[1] = {Sin[1/2], Sin[1], Sin[3/2], Sin[2], Sin[5/2], Sin[3], Sin[7/2], 
 Sin[4], Sin[9/2], Sin[5]}
函数名称 用途 格式
MakeGroup 建立种群 MakeGroup[种群规模, 生成函数]

2.基因交换

基础模式:

Swap[List1_List, List2_List, {S_Integer, T_Integer}] :=
 (*基因一,基因二,{开始交换点,终止交换点}*)
 Block[
  {Len = Length[List1], Len2 = Length[List2]},
  If[Len != Len2, Null,(*若长度不等,返回Null*)
   (*Table[If[S\[LessEqual]i\[LessEqual]T,
   List2\[LeftDoubleBracket]i\[RightDoubleBracket],
   List1\[LeftDoubleBracket]i\[RightDoubleBracket]],{i,1,Len}]交换*)
   List1[[1 ;; S - 1]]~Join~List2[[S ;; T]]~Join~List1[[T + 1 ;; Len]]
   ]
  ]
函数名称 用途 格式
Swap 基因交换 Swap[基因1, 基因2, {起始点, 终止点}]
基因突变:

Changex[GeList_List, Pc_Integer, {f_Function, Kind_String}] := Block[
  {GeCopy = GeList},
  Switch[(*考虑多种变化选项*)
   Kind,
   "Change", GeCopy[[Pc]] = f[GeCopy[[Pc]]],
   "Add", GeCopy[[Pc]] += f[GeCopy[[Pc]]]]; GeCopy
  ]

GeChange[p_Real, GeList_List, n_Integer, {f_Function, Kind_String}] :=
 (*突变概率,基因序列,突变n次,{突变函数,突变模式}*)
 Block[
  {Len = Length[GeList],
   Pc = 0,
   GeCopy = 0
   },
  If[RandomReal[] < p,
   GeCopy = GeList;
   Nest[Changex[#, RandomInteger[{1, Len}], {f, Kind}] &, GeCopy, n](*n次迭代*)
   , GeList]
  ]

GeChangeList[GeList_List, pList_List, {f_Function, Kind_String}] :=
 (*基因序列,突变序列,{突变函数,突变模式}*)
 Block[
  {Len = Length[GeList],
   Pc = 0,
   GeCopy = GeList
   },
  Do[GeCopy = Changex[GeCopy, pList[[i]], {f, Kind}];, {i, 1, Length[pList]}];
  GeCopy
  ]

GePMC[GeList_List, {S_Integer, T_Integer}] :=(*部分重排序*)
 (*需要突变的基因,{开始位,结束位}*)
 Module[{GeCopy = GeList,
   head = GeList[[1 ;; S - 1]],
   body = GeList[[S ;; T]],
   foot = GeList[[T + 1 ;; Length[GeList]]]
   },
  head~Join~Reverse[body]~Join~foot
  ]

示例:

随机变异一个基因:


随机变异一个基因

基因倒位:

基因倒位
函数名称 用途 格式
GeChange 基因随机变异 GeChange[突变概率,基因序列,突变n次,{突变函数,突变模式}]
GePMC 基因倒位 GePMC[需要突变的基因,{开始位,结束位}]

第二次更新于2014年11月20日

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,393评论 5 467
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,790评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,391评论 0 330
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,703评论 1 270
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,613评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,003评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,507评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,158评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,300评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,256评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,274评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,984评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,569评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,662评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,899评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,268评论 2 345
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,840评论 2 339

推荐阅读更多精彩内容