- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 FiPy 解决受生物学启发的问题。
本质上,我想表示一个 2D 平面,其中在不同的点上有源和汇。源以固定速率发射底物(不同的源可以有不同的速率),汇以固定的速率消耗底物(不同的汇可以有不同的速率)。我的代码:
import numpy.matlib
from fipy import CellVariable, Grid2D, Viewer, TransientTerm, DiffusionTerm, ImplicitSourceTerm, ExplicitDiffusionTerm
from fipy.tools import numerix
from time import *
nx = 10
ny = nx
dx = 1.
dy = dx
L = dx*nx
mesh = Grid2D(dx=dx, dy=dy, nx=nx, ny=ny)
arr_grid = numerix.array((
0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,),'d')
arr_source = numerix.array((
0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0.5,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,),'d')
arr_sink = numerix.array((
0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0,
0,0,0,0,0,0,0,0,0,0.5,),'d')
source = CellVariable(mesh=mesh, value = arr_source)
sink = CellVariable(mesh=mesh, value = arr_sink)
phi = CellVariable(name = "solution variable", mesh = mesh, value = arr_grid)
X,Y = mesh.cellCenters
phi.setValue(3.0, where=(X < 2.0) & (X > 1.0))
phi.setValue(-1.0, where=(X < 6.0) & (X > 5.0))
D = 1.
eq = TransientTerm() == DiffusionTerm(coeff=D)
viewer = Viewer(vars=phi, datamin=0., datamax=1.)
steadyState = False
if(steadyState):
print("SteadyState")
DiffusionTerm().solve(var=phi)
viewer.plot()
sleep(20)
else:
print("ByStep")
timeStepDuration = 10 * 0.9 * dx**2 / (2 * D)
steps = 500
for step in range(steps):
print(step)
eq.solve(var=phi,
dt=timeStepDuration)
if __name__ == '__main__':
viewer.plot()
这很有效,但 FiPy 将资源视为“不可再生”,最终我在整个空间中得到了预期的均匀集中。另一种方法是删除:
X,Y = mesh.cellCenters
phi.setValue(3.0, where=(X < 2.0) & (X > 1.0))
phi.setValue(-1.0, where=(X < 6.0) & (X > 5.0))
并将等式更改为:
eq = TransientTerm() == DiffusionTerm(coeff=D) + source - sink
鉴于源和汇永远不会改变,这提供了“无限”的源和汇。但是,当我尝试使用
解决稳态问题时eq = TransientTerm() == DiffusionTerm(coeff=D) + source - sink
我得到:
C:\Python27\python.exe C:/Users/dario_000/PycharmProjects/mesa-test/mesher.py
SteadyState
C:\Python27\lib\site-packages\fipy-3.1.dev134+g64f7866-py2.7.egg\fipy\solvers\scipy\linearLUSolver.py:71: RuntimeWarning: invalid value encountered in double_scalars
if (numerix.sqrt(numerix.sum(errorVector**2)) / error0) <= self.tolerance:
方程式没有解。但是,如果我再次使用“逐步”解决它:
eq = TransientTerm() == DiffusionTerm(coeff=D) + source - sink
我得到了一张与我期望的相似的漂亮照片:
关于如何指定源/汇在不同空间位置的初始设置,每个源/汇具有不同的发射/消耗率,以便我可以获得稳态解决方案,有什么建议吗?
谢谢!
最佳答案
请注意,正如 wd15 在评论中提到的,在邮件列表中有更深入的讨论和跟进。
首先,初始条件和源都可以使用 where
逻辑来创建。
source = CellVariable(mesh=mesh, value = arr_source, where=(2 < X) & (X < 3))
这避免了数组的显式构造。
其次,初始条件和来源之间存在一个关键区别。在原始公式中,您在字段变量 phi
上使用 SetValue
方法,您正在为 transient 解提供初始条件(或直接稳态的初始猜测)状态解决)而不是实际来源。所以正确的方法是你的第二种方法,你实际上直接将源/汇项添加到等式中:
eq = TransientTerm() == DiffusionTerm(coeff=D) + source - sink
此外,要尝试直接稳态求解,您可以在不使用 TransientTerm
的情况下编写方程式,
eq = 0 == DiffusionTerm(coeff=D) + source - sink
然后使用 eq.solve()
求解,这将求解码合的 DiffusionTerm
和源/汇。
但是,从直接到稳定的方法值得提醒几句。首先,没有真正好的数值方法来直接计算一般系统的稳态解。通常,您最好的选择实际上是通过从某个初始条件到达到稳态的时间步长来求解 transient 方程,因为这实际上可能是求解稳态曲线的最稳健的算法。在某些情况下,您甚至可以用一个大的时间步长来做到这一点,如“完全隐式解决方案并非没有陷阱”一节中所述here .其次,你确定你的系统承认稳定状态吗?您没有通量边界条件(暗示是因为您没有指定任何其他边界条件),但是您有内部源/汇。除非这些源/汇以完全相同的速率生产/消耗场变量,否则您将在系统中获得净积累。 R
= 常量、统一且非零的简单示例:
dc/dt = R
没有通量边界条件是一个不允许任何稳态的方程。添加扩散项不会改变这一点。如果您要添加任何狄利克雷(指定值)边界条件,这将实现稳定的解决方案,因为系统内的净生产/消耗可以通过系统边界离开/进入。可以找到关于边界条件以及如何应用它们的讨论 here .
最后,还有一点要注意。如所写,源/汇项是“零阶”,这将导致,例如如果汇项足够大和/或离源足够远,浓度将变为负值。如果发生这种情况,显然需要修改模型,例如,使汇成为一阶,
eq = TransientTerm() == DiffusionTerm(coeff=D) + source - sink*phi
这将确保汇在 phi 变为零时“关闭”,但这也可以通过修改以耦合到其他场变量,如局部细胞密度。
关于python - 在 Python 中使用源代码求解 PDE,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36385367/
我正在编写一个 Java 应用程序,该应用程序检查网页的源代码,并在满足源代码中的条件时在我的默认浏览器中向我显示该网页。我通过以下方式获取源代码: String source = getUrlSou
数周以来,我一直在为 Android 上的蓝牙项目而苦苦挣扎。有谁知道我可以去哪里查看 Google 用于使其蓝牙配对和连接逻辑正常工作的实际代码? 我浏览了所有的文档、BluetoothChat 应
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 4 年前。
Android 源代码有多个目录,其中包含针对不同设备的代码。此外,在特定目录中,存在显示不同分支和标签的路径。举个例子,在“android/platform/external/iptables”目录
在哪里可以找到 SQLMembershipProvider (.NET2.0) 的源代码? 是可用的么? 最佳答案 源代码已经发布。 See ScottGu's blog for further de
我只想知道如何下载特定版本的 Android 源代码。我已经尝试过以下命令 repo init -u https://android.googlesource.com/platform/manifes
我想看看OpenCL框架是如何实现的。我发现的只是已经编译好的可供下载的库。 当然,OpenCL 可以有许多不同的实现,但我想看看其中的一个来了解它是如何完成的。 为了确保我自己清楚,OpenCL 框
latex 源代码列表应该是什么样子才能产生像已知书籍中那样的输出,例如 Spring 框架的输出?我尝试过使用 latex 列表包,但无法生成看起来像下面一样好的东西。因此,我主要对生成类似以下示例
PHP 是用 C 语言编写的吗?我在哪里可以在线找到 PHP 源代码而无需下载全部内容? 最佳答案 PHP 函数是用 C 编写的 - 您可以在 lxr.php.net 找到可浏览的源代码. 例如:ht
我正在使用Elasticsearch OSS的官方Docker镜像(docker.elastic.co/elasticsearch/elasticsearch-oss:6.2.4),似乎完全无法使用s
我试图在Cython中同时编译C和C++源代码。这是我当前的设置: -setup.py from distutils.core import setup from Cython.Build impor
好吧,事情是这样的:你们所有人可能都在想同样的事情:您可以使用 driver.getPageSource(); 这部分是正确的。唯一的问题是源代码以一种相当奇怪的方式编译,所有代码都在其中 \&quo
由于 TwoLineListItem 自 API 17 起已被弃用,因此我已采取措施将其替换为自定义 XML 和 ViewHolder。但是,我真的希望我的应用程序看起来与使用 TwoLineList
要从 HttpURLConnection 获取 InputStream,我们的代码如下 urlConnection.getInputStream(); 如果InputStream是一个Abstract
我刚刚开始学习更多关于 C/C++ 的知识,我正在使用 Visual Studio 2013 来管理代码。 我正在使用 Tobii EyeX 眼睛注视系统的项目要求我能够稍微调整此代码,但是我不明白如
我在按钮上有一个IBAction,其中包含以下代码,我尝试使用它来检索 UIWebView 的源代码: - (IBAction)loadInAWebView:(id)sender { [self
我正在 asp.net 中创建一个网站,我只是想知道有什么方法可以使用 JavaScript 从图像生成调色板吗?类似于 1) http://www.cssdrive.com/imagepalette
有人可以分享 WinKill() from AutoIt 的源代码吗? ? 我想知道它如何处理消息(是/否/取消)以确保它得到正确处理。我想用它来清理桌面上的意外弹出窗口。 最佳答案 正如我们在下面的
我的问题与 Opencv 的源代码有关。在我看来不同的平台the Opencv website提供不同的代码结构。我只是想知道是否有可能为所有不同的平台提供一个源代码。使用相同的源代码,我可以针对不同
这个问题在这里已经有了答案: Convert Python program to C/C++ code? [closed] (8 个答案) 关闭 3 年前。 我一直在努力寻找一种方法将 .py 源文
我是一名优秀的程序员,十分优秀!