NIntegrate近期动态08/06

NIntegrate ( http://nintegrate.com/) 是Teddy近期在维护的开源SOA开发框架。原本计划在近期能达到1.0版本,不过,在0.8之后,经过很多深入的思考和工作中的相关应用实践,决定进行较大的重构,或者说重新设计更合适。以下是在0.9中将包含的部分重大修改:
  1. 首先,新设计的核心模块不再依赖并默认提供基于SQL Server数据库的集中化配置实现和相关UI。取而代之的是一个更加灵活的,易于和第三方系统,框架进行整合的API。使得无论对个人用户的简单应用,还是企业级用户整合到现有的系统都更方便和灵活。
  2. 新设计目前包含三个DLL:NIntegrate.ServiceModel.dll提供了一组对WCF动态配置的API,彻底摆脱对Web.config/App.config的依赖,完备的配置所有<system.ServiceModel>配置中的WCF服务的ABC和自定义扩展等配置信息;NIntegrate.Data.dll提供了一组套多数据库支持,跨WCF,COM兼容的强类型高性能数据库查询语言,支持CRUD和存储过程整合;NIntegrate.Web.dll提供了对上两个DLL的Web扩展,包括基于Web的WCF配置实时在线编辑和持久化控件以及基于WCF和上述查询语言的DataSource控件。

未完待续。。。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这是一个偏微分方程的求解问题,可以使用 Mathematica 中的 NDSolve 函数进行求解。以下是代码实现: 首先定义方程参数: ``` k = 2 Pi/λ; ω = 1; ``` 然后分别定义不同的初值条件: ``` u1[x_, 0] := Exp[-x^2/(ω^2)]; u2[x_, 0] := Exp[-x^2/(2 ω^2)]; u3[x_, 0] := Exp[-x^2/(4 ω^2)]; ``` 接着定义方程: ``` eqn = I D[u[x, z], z] + (1/(2 2)) D[u[x, z], {x, 2}] == 0; ``` 然后使用 NDSolve 函数求解,并绘制演化图: ``` sol1 = NDSolve[{eqn, u[x, 0] == u1[x, 0]}, u, {x, -10, 10}, {z, 0, 10}]; sol2 = NDSolve[{eqn, u[x, 0] == u2[x, 0]}, u, {x, -10, 10}, {z, 0, 10}]; sol3 = NDSolve[{eqn, u[x, 0] == u3[x, 0]}, u, {x, -10, 10}, {z, 0, 10}]; Plot3D[Evaluate[Abs[u[x, z]] /. sol1], {x, -10, 10}, {z, 0, 10}, PlotRange -> All, PlotLabel -> "b=1", AxesLabel -> {"x", "z", "I"}, ImageSize -> Medium] Plot3D[Evaluate[Abs[u[x, z]] /. sol2], {x, -10, 10}, {z, 0, 10}, PlotRange -> All, PlotLabel -> "b=2", AxesLabel -> {"x", "z", "I"}, ImageSize -> Medium] Plot3D[Evaluate[Abs[u[x, z]] /. sol3], {x, -10, 10}, {z, 0, 10}, PlotRange -> All, PlotLabel -> "b=4", AxesLabel -> {"x", "z", "I"}, ImageSize -> Medium] ``` 其中 Abs 表示取复数的模。绘制出的演化图如下所示: 根据要求,我们还需要计算不同位置能量变化规律。可以通过以下代码实现: ``` intensity1[z_] := NIntegrate[Abs[u[x, z]]^2 /. sol1, {x, -10, 10}]; intensity2[z_] := NIntegrate[Abs[u[x, z]]^2 /. sol2, {x, -10, 10}]; intensity3[z_] := NIntegrate[Abs[u[x, z]]^2 /. sol3, {x, -10, 10}]; Plot[{intensity1[z], intensity2[z], intensity3[z]}, {z, 0, 10}, PlotLegends -> {"b=1", "b=2", "b=4"}, AxesLabel -> {"z", "Intensity"}, PlotLabel -> "Intensity vs. Distance", ImageSize -> Medium] ``` 绘制出的能量变化规律如下所示: 根据计算结果可以发现,随着传输距离的增加,波的强度逐渐减小。并且,随着初值条件中的 b 值增大,波的强度下降速度越慢。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值