python fipy_Python学习点滴

澹台展鹏
2023-12-01

安装gmsh,并设置环境变量

Delaunay使用

import numpy as np

from scipy.spatial import Delaunay

points = np.random.rand(30, 2) # 30 points in 2-d

tri = Delaunay(points)

# Make a list of line segments:

# edge_points = [ ((x1_1, y1_1), (x2_1, y2_1)),

# ((x1_2, y1_2), (x2_2, y2_2)),

# ... ]

edge_points = []

edges = set()

def add_edge(i, j):

"""Add a line between the i-th and j-th points, if not in the list already"""

if (i, j) in edges or (j, i) in edges:

# already added

return

edges.add( (i, j) )

edge_points.append(points[ [i, j] ])

# loop over triangles:

# ia, ib, ic = indices of corner points of the triangle

for ia, ib, ic in tri.vertices:

add_edge(ia, ib)

add_edge(ib, ic)

add_edge(ic, ia)

# plot it: the LineCollection is just a (maybe) faster way to plot lots of

# lines at once

import matplotlib.pyplot as plt

from matplotlib.collections import LineCollection

lines = LineCollection(edge_points)

plt.figure()

plt.title('Delaunay triangulation')

plt.gca().add_collection(lines)

plt.plot(points[:,0], points[:,1], 'o', hold=1)

plt.xlim(-1, 2)

plt.ylim(-1, 2)

# -- the same stuff for the convex hull

edges = set()

edge_points = []

for ia, ib in tri.convex_hull:

add_edge(ia, ib)

lines = LineCollection(edge_points)

plt.figure()

plt.title('Convex hull')

plt.gca().add_collection(lines)

plt.plot(points[:,0], points[:,1], 'o', hold=1)

plt.xlim(-1, 2)

plt.ylim(-1, 2)

plt.show()

python程序打包Install PyInstaller from PyPI:

pip install pyinstaller

Go to your program’s directory and run:

pyinstaller yourprogram.py

This will generate the bundle in a subdirectory called dist. For a more detailed walkthrough, see the安装jupyter lab

清除cache C:\Users\Administrator\AppData\Local\pip\cache

安装jupyter lab:

conda install -c conda-forge jupyterlab安装sublime的anaconda插件

管理员权限启动sublime 3,continuesfepy demo测试

安装运行时需要的库

conda install mayavi wxpython

conda install traits traitsui

vtk

运行库mayavi安装不顺利:

(C:\Anaconda2) C:\wxPython-master>conda install mayavi

Fetching package metadata ...........

Solving package specifications: .

UnsatisfiableError: The following specifications were found to be in conflict:

- mayavi

- sfepy

Use "conda info " to see the dependencies for each package.

(C:\Anaconda2) C:\wxPython-master>conda install -c menpo mayavi=4.5.0

Fetching package metadata .............

Solving package specifications: .

Package plan for installation in environment C:\Anaconda2:

The following NEW packages will be INSTALLED:

apptools: 4.4.0-py27_0 menpo

envisage: 4.5.1-py27_0 menpo

mayavi: 4.5.0-py27_0 menpo

The following packages will be UPDATED:

vtk: 5.10.1-py27_0 --> 7.0.0-py27_0 menpo

Proceed ([y]/n)? y

vtk-7.0.0-py27 100% |###############################| Time: 0:00:31 787.75 kB/s

apptools-4.4.0 100% |###############################| Time: 0:00:05 72.23 kB/s

envisage-4.5.1 100% |###############################| Time: 0:00:02 117.34 kB/s

mayavi-4.5.0-p 100% |###############################| Time: 0:00:14 882.55 kB/s

PowerShell计算命令行:

PSC:\sfepy> python simple.py examples/diffusion/poisson_short_syntax.py

sfepy: left over: ['verbose', '__builtins__', 'absolute_import', '__file__', '__doc__', '__name__', 'data_dir', '__package__', '_filename']

sfepy: reading mesh [line2, tri3, quad4, tetra4, hexa8] (C:\Anaconda2\lib\site-packages\sfepy\meshes\3d\cylinder.mesh)...

sfepy: ...done in 0.11 s

sfepy: creating regions...

sfepy: Gamma_Right

sfepy: Omega

sfepy: Gamma_Left

sfepy: ...done in 0.09 s

sfepy: equation "Temperature":

sfepy: dw_laplace.i.Omega( coef.val, s, t ) = 0

sfepy: using solvers:

ts: no ts

nls: newton

ls: lssfepy: updating variables...

sfepy: ...done

sfepy: setting up dof connectivities...

sfepy: ...done in 0.00 s

sfepy: matrix shape: (300, 300)

sfepy: assembling matrix graph...

sfepy: ...done in 0.00 s

sfepy: matrix structural nonzeros: 3538 (3.93e-02% fill)

sfepy: updating materials...

sfepy: coef

sfepy: ...done in 0.05 s

sfepy: nls: iter: 0, residual: 1.176265e-01 (rel: 1.000000e+00)

sfepy: rezidual: 0.05 [s]

sfepy: solve: 0.09 [s]

sfepy: matrix: 0.00 [s]

sfepy: nls: iter: 1, residual: 1.784271e-16 (rel: 1.516895e-15)

PSC:\sfepy> python postproc.py cylinder.vtk

anaconda默认安装pyQt5,需要强制安装pyQt4:

conda install -c anaconda pyqt=4.11.4

安装pandas

conda install pandas安装Fipy

1升级pip

python -m pip install --upgrade pip

2 安装Fipy

pip install fipy

conda install fipy #error

3 Test:

from fipy import Variable, FaceVariable, CellVariable, Grid1D, ExplicitDiffusionTerm, TransientTerm, DiffusionTerm, Viewer

from fipy.tools import numerix

%matplotlib inline

nx = 50

dx = 1.

mesh = Grid1D(nx=nx, dx=dx)

D = 1.

valueLeft = 1

valueRight = 0

phi = CellVariable(name="solution variable",mesh=mesh,value=0.)

phi.constrain(valueRight, mesh.facesRight)

phi.constrain(valueLeft, mesh.facesLeft)

eqX = TransientTerm() == ExplicitDiffusionTerm(coeff=D)

timeStepDuration = 0.9 * dx**2 / (2 * D)

steps = 100

for step in range(steps):

eqX.solve(var=phi,dt=timeStepDuration)

viewer = Viewer(vars=phi,datamin=0., datamax=1.)

viewer.plot()

 类似资料: