All notable changes to this project will be documented in this file.
-
FreeFEM can now run Markdown (.md) files as well as .edp files. Markdown can be used to document your FreeFEM scripts (see for example the .md files in the examples/examples directory). When running a .md file, FreeFEM will execute the code contained in the FreeFEM code blocks, delimited by
```freefem [freefem code] ```
Documented Markdown examples in the distribution can be viewed on the documentation website (toggle Search in examples). Markdown can be previewed with e.g Visual Studio Code, with the FreeFEM VS Code extension providing syntax highlighting for FreeFEM code blocks.
-
add command
md2edp
to extract freefem code form Markdown file. -
add read binary file with short number in bfstream plugin
-
add 3d case in ClosePoints plugin : function Voisinage3, ClosePoints3
-
add
real[int,int] at=A';
-
Powell Sabin
splitmesh6PowellSabin(Th)
splitting for Scott–Vogelius lowest Stokes Element in 2D in plugin/seq/splitmesh6.cpp -
Worsey Farin
splitmesh12WorseyFarin(Th3)
splitting for Scott–Vogelius lowest Stokes Element in 3D in plugin/seq/splitmesh12.cpp -
interface with functional interface with
fgmres
(Linear and affine) in real and complex case see tutorial/algo.edp -
Finite element
BDM2
andBDM2ortho
in test, Bug in BDM2ortho corrected the 4 sept 2023 in version: v4.13-130-g1af52457 -
Conversion of matrix or transpose of matrix in
int[int][int]
array to get the structure of sparse matrix. see tutorial/sparse-matrix.edp example at endmatrix A = va(Ph,Vh); int[int][int] a = A, at= A';// only the sparsity pattern of matrix
-
a meshL finite element function can be seen as a real function with 1, or 2 parameters:
meshL ThL = segment(10); fespace VhL(ThL,P1); VhL u= x; cout << u(0.5) << endl; cout << u(0.5,0) << endl;
-
Example to code convolution of two functions with one with a small support to be not too expensive, see tutorial/Convolution-Sample.edp example
-
Support for dense blocks in PETSc matrices
-
GenEO for saddle-point examples with PCHPDDM in PETSc
-
Distributed ParaView output on
meshS
-
Interface to
mmg2d
for two-dimensionalmesh
-
Support for Mmg parameters
-localParameter
,-nosizreq
,-hgradreq
- PETSc 3.22.2
- move the plugin msh3 in kernel , so remove all
load "msh3"
in all examples and .idp files
-
try to fix orientation of internal edges in 2d.
-
fix missing break and continue in for [ i,ai:a] loop
-
line number in macro error (thank to P-H Tournier)
-
fix problem in integration of moving test or unknown function in 2d mesh:
varf ab([u],[v]) = int2d(Th,mapu=[Xo,Yo])(u*v); matrix AB = ab(Zh,Rh);
we remove code a piece of code.
-
fix problem in mesh of a ring from a square (missing option to remove duplicate vertices) example:
mesh Th2=square(19,5,[(1+y)*cos(2*pi*x),(1+y)*sin(x*pi*2)],removeduplicate=1) ;
-
Segmentation fault problem in Write_hdf5 (problem of allocation in the stack not on the heap). if the mesh2 is too large.
-
fix
(A'+A)
where funcA =[[0,1],[0,0]] ;
-
correct integer overflow (in rare case) when calling INTER_SEG1d use in interpolation on Th3,ThS, ThL thanks to G. Sadaka for finding the bug.
-
correct hidden faces on surface mesh (ffglut)
-
remove optimisation flag ppm2rnm.cpp in macOS (load trap)
-
correct abcisse curviline on reparametrage function (setcurveabcisse) in load "Curvature"
-
correct compilation on ARM sonoma xcode 15.2
-
correct mpi essai.edp MPI_ANY_SOURCE Pb.
-
bug in P3pnc3d in vectorial case (thank to [email protected] )
-
in
segment(10,region=1,label=ll);
region is now used.
- Finite element BDM2 and BDM2ortho in test, Bug in BDM2ortho corrected the 4 sept 2014 in version: v4.13-130-g1af52457
- Conversion of matrix or transpose of matrix in
int[int][int]
array to get the structure of sparse matrix. see tutorial/sparse-matrix.edp example at endmatrix A = va(Ph,Vh); int[int] a = A, at= A';
- a meshL finite function can be see as real function with 1, or 2 parameters
meshL ThL = segment(10); fespace VhL(ThL,P1); VhL u= x; cout << u(0.5) << endl; cout << u(0.5,0) << endl;
- Exemple to code convolution of 2 function with one with a small support too be not to expanxive see tutorial/Convolution-Sample.edp example
- Support for dense blocks in PETSc matrices
- GenEO for saddle-point examples with PCHPDDM in PETSc
- Distributed ParaView output on
meshS
- Interface to
mmg2d
for two-dimensionalmesh
- Support for Mmg parameters
localParameter
,-nosizreq
, -hgradreq`
- PETSc 3.20.2
- bug in P3pnc3d in vectorial case (thank to [email protected] )
- in segment(10,region=1,label=ll); region is now used..
-
Composite FE spaces and variational forms for coupled problems:
-
can now define composite FE spaces with different meshes/mesh types as
fespace Uh(Th1,[P2,P2]); fespace Ph(Th2,P1); fespace Vh=Uh*Ph;
-
can define coupled problems using composite FE spaces, or directly with
<
>
syntax:fespace Uh(Th1,[P2,P2]); fespace Ph(Th2,P1); Uh [u1,u2],[v1,v2]; Ph p,q; solve Pb (<[u1,u2],[p]>, <[v1,v2],[q]>) = ...
see
examples/examples/stokes_composite.edp
andexamples/examples/stokes_periodic_composite.edp
-
this new type of composite problem can be used for FEM-BEM coupling and also benefits from automatic parallel assembly (in test) and can be easily solved using the distributed solver MUMPS, see
examples/bem/Helmholtz-2d-FEM-BEM-coupling-MUMPS-composite.edp
-
composite problems can also be solved using PETSc (in test), see
examples/hpddm/Helmholtz-2d-FEM-BEM-coupling-PETSc-composite.edp
-
-
remove spurious cout in Curve/Line DG definition.
-
add New Finite element 2d on mesh : RT0dc (discontinios RT0 ) in plugin Element_Mixte see example plugin/RT0dc.edp and P1nc (Crouziex-Raviart) + bulle : name P1bnc in plugin Element_P1ncdc and P1nc totaly discontinous + bulle ; name P1bdcnc in plugin Element_P1ncdc see example plugin/example testp1dcnc.edp for [email protected]
-
add New finite element: P4S P^4 on meshS , P3pnc3d in Element_P3pnc_3d (Couziex-Raviart with P3 ) see [email protected] for more information.
-
add new interface for metis (see examples/plugin/metis.edp)
-
Correct jump, mean, otherside of finite element function on mesh3, meshS, meshL (add missing code in method: MeshPoint::SetAdj() thanks to [email protected])
-
try to build dmg install mac version
-
add file script to build meshS from boundary meshL TL if the boundary is the graph of function from mean plane. see example in examples/3dSurf/buildmeshS.edp meshS Ts=buildmeshSminsurf(TL,1);// minimal surface meshS Tsl=buildmeshSLap(TL,1);// Laplace Surface .. meshS Tsl=buildmesh(TL,1,op);// op = 0 Lap and op =1 => minsurf.
-
add sparse block to sparse matrix matrix A = va(Vh,Vh); matrix B(A.n5,A.n5); int i=2; B.add(1.+10i,A,indof,i*ndof);
- change isoline to do the job for meshS, see example plugin/isoline.edp
- change Curve function to be with 3 components to use the isoline data.
- change Curvature plugin to compatible with new isoline data for 3 d case.
- change some sprintf in snprint to remove warning
- bug in all P0face, P0edge, P0VF on mesh3,meshS, MeshL and also discontinous version (missing initialisation)
- bug in plot function and ffglut with parameter pdf="file.pdf" , because shift in plot named parameter not change in ffglut.
- genere a bug if zero size element in read MeshL from file.
- remove mistake when the border is badly defined , remove empty element in buildmeshL function.
- bug in array quadrature FE.
-
add new finite Element P2pnc3d of Stokes problem like Crouzeix-Raviard in 3d of P2 pylynome (see G. Allaire or [email protected] for detail )
-
add pdfPLOT form [email protected] [http://www-an.acs.i.kyoto-u.ac.jp/~fujiwara/ff++-programs/] usage: plot( ..., pdf="filename.pdf", svg="filename.svg" );
-
add missing code for Discontinous Galerkin in 3d for RHS ( see [problem-in-3d-discontinuous-galerkin-computation][https://community.freefem.org/t/problem-in-3d-discontinuous-galerkin-computation/2015/6] )
-
add in examples/mpi/chamonix.edp : radiative transfer (use new plugin plugin/mpi/RadiativeTransfer_htool.cpp, illustrates the use of htool for compression of user defined matrix operator)
-
transform a surface meshS in 2d mesh (warning with overloaping, no test) with movemesh:
meshS Ths = square3(10,10,[x,y,square(2x-1)+square(2y-1)]); real[int] gzz; mesh Th2 = movemesh(Ths,transfo=[x,y,z],getZ=gzz);// get flat 2d mesh form meshS
-
New 1d finite element P3 hermite (C1) finite element in plugin
Element_P3
meshL Th=segment(1,[x*L,0,0]); fespace Vh(Th,P3HL); see example end of example plugin/testFE-P3 -
missing new 1d finite element P4 in plugin
Elemnt_P4
-
plugin
plugin/seq/MatrixMarket.cpp
to read and save matrix in MatrixMarket and add also a binary form (see examples/plugin/MatrixMarket.edp test) -
add ILU on complex matrix in plugin IncompleteCholesky remark:the IncompleteCholesky is writen but not tested
-
add test of functionnal interface of complex eigen value problem in
examples/eigen/LapEigenValueFuncComplex.edp
- correct some old code with old version of K.facePermutation() function in plugin/seq/Element_Mixte3d.cpp and plugin/seq/Element_P2bulle3.cpp (not tested)
- fixe in A.RemoveHalf (alway return a new matrix)
- add computation scalar product of R3 example : ( N'*Tl)
- add tools to do compution with R3 vector see tutorial/calculus.edp
- add an example tutorial/tgv-test.edp see see what tgv do on matrix build.
- add R3 Th.be(k).N to get the normal of boundary element (in all mesh type)
- add R3 Th.be(k)[i].P to get the point (R3) of boundary vertices
- add R3 Th.be(k).measure to get the measure of the boundary elment
- add projection function to a mesh , meshL, MeshS or mesh3 with return a R3 point
- see new example dist-projection.edp example in examples
- add dxx, dyy, dzz, dxy, .. on P2L finite element
- add tools to compute solid angle : let R3 O; a given point, Th3 a mesh3 and ThS a meshS. solidangle(O,Th3.be(ke)) // triangular face is the boundary face solidangle(O,Th3[k],nuface) // triangular face is face nuface of tet Th3[k] solidangle(O,ThS[k]) // triangular face is ThS[k] solidangle(O,A,B,C) // triangular face i (A,B,C) Volume(O,Th3.be(ke)) // O, triangular face is the boundary face Volume(O,Th3[k],nuface) // O, triangular face is face nuface of tet Th3[k] Volume(O,ThS[k]) // O, triangular face is ThS[k] Volume(O,A,B,C) // (O,A,B,C) tet ..
- in bem pluging add array of HMatrix
- examples/3d/Connectivite-3d.edp or /3dSurf/Connectivite-S.edp of test.
- 3 function mapk, mapkk, mapkk to set a function in fourier space with k parametre R3 K; // le fourier variable allway 3d (sorry) int n1=16,n2=8, n3=4; real[int] tab1(nx,tab2(nxny),tab3(nxny*nz); mapk(tab1,K,sqr(K.x)); mapkk(tab2,ny,K,K.norm2); mapkkk(tab3,ny,nz,K,K.norm2); // Remark you can change K by P (current point)
- in SurfaceMesh.ipd fonction to build a Isocaedron and a Sphere from this Isocaedron
- new finite element on MeshS this finite element is the ortogonal of RT0 on surface, or Nelelec Finite Element on triangle with one DoF per mesh edge and where the DoF is the current on Edge in orientate edge by number of vertices.
- plugin Element_P3pnc for new 2d finite element P3pnc (P3 + 2 bulles) nonconforming (continuite of P2 mod)
and add 2 examples with this new finite element examples/plugin/cavityNewtowP3pnc.edp examples/plugin/testFE-P3pnc.edp - plugin Element_P3nc for new 2d finite element P3pnc (P3 ) nonconforming (continuite of P2 mod)
and add examples with this new finite element examples/plugin/testFE-P3pnc.edp - function to set dirichlet Boundary conditon on matrix A (real ou compex) trought an real[int] (if none zero => set BC ) setBC(A,au1[],-2); and the example examples/3d/Elasticity-simple-support-BC.edp
- the beaviour of linear solver UMFPACK, CHOLMOD in case of error , now FreeFEm exit on ExecError like in MUMPS
- PETSc 3.17.0
- map function in plugin dfft
- pow(int,int) now call int version not complex version..
- correct the normal the N implicite variable on meshL case
- correct version dump in banner FreeFem++ - version 4.10 (V ...
- correct in CPU time on big mesh due to do bad HCode in HashTable.hpp
- bug in array of finite element on meshhS, meshL (ie.
fespace Vh(ThS,[P1,P1]);
)
- ridgeangle named parameter in ExtractMeshL in msh3 plugin
- DG formulation in 1d :
add integral of all border of element :
intallBE(ThL)
and unified the notation by addingintallBE(ThS)
,intallBE(Th2)
,intallBE(Th3)
nuVertex
of now the vertex number of element in intallBE0d integralBoundaryBE
,InternalBE
to know if border element (BE) is on true boundary of not. updatenElementonB
in case on no manifold data (value greater > 2) in meshL, MeshS case .. add code to use jump, mean, otherside of test function on MeshL case. ( not in mesh3 ) to compute RHS. - add getcwd() function in shell plugin to get the current working dir
- add nuVertex to get the vextex on element in some int?
- PETSc 3.16.1
- SLEPc and SLEPc-complex have been part of PETSc and PETSc-complex for multiple releases and are now deprecated
- examples/potential.edp correct problem in times loops and BC
- tutorial/mortar-DN-4.edp correct problem of region number in meshL
- fix problem in Curve mesh and intallBE , vertex number is wrong
- portability issue on arm64-apple with
make petsc-slepc
- fix assertion failure with
transfer
andtransferMat
with some finite elements
- add P3 lagrange finite element on meshS and meshS
- add new plugin
meshtool
to add tool to compute the number of connected components of a all kind of mesh (mesh,mesh3,meshS,meshL) with 2 kind of connected components ones on interior part of the mesh (default) ans secondly on the closure of the mesh (seeexamples/hpddm/bConnectedComponents.edp
) add functions int[int] In=iminP1K(Th,u) or int[int] Ix=imaxP1K(Th,u) get the array min/max of value u[i]
where i is vertex number on each element k, so we have u[Im[k]] = min u[i]/ i in k; - add in plugin
bfstream
to to read binary int (4 bytes) to read fortran file and try to pull tools to share the endiannes in progress - add gluemesh of array of MeshL and MeshS type
- interface to
PC_MG_GALERKIN_BOTH
- Kronecker product of two sparse matrices
matrix C = kron(A, B)
- add lot of finite element on Mesh3, MeshS, MeshL of Discontinous Galerling Element in 3d : P1dc3d, P2dc3d, P3dc3d, P4dc3d , P0edge3d ,P0edgedc3d , P0face3d ,P0facedc3d , P0VF3d ,P0VFdc3d , on Surface : P1dcS, P2dcS, P3dcS, P4dcS , P0edgeS ,P0edgedcS , P0VFS ,P0VFdcS, on Curve : P1dcL, P2dcL, P3dcL, P4dcL , P0VFL ,P0VFdcL remark; the associated generic name existe of P1dc, P2dc, P0edge, P0VF and all dc finite element corresponding to no continuity across element.
- add code of intallfaces to do Discontinous Galerkin formulation in 3d (in test FH.)
- add dist function to a mesh , meshL, MeshS or mesh3
- signeddistfunction to a meshL or meshS
- add buildmesh functon to build a 2d mesh from a meshL (same as buildmesh see examples/3dCurve/border.edp)
- Now the order to find MPI in configure is first if you have PETSC then take MPI from PETSc otherwise use previous method
- on MeshL defined with buildmeshL now the default label are 2k-1 (resp. 2k) for the begin (resp. end) of curve where k is the order of curve use in buildmeshL. So if you have one curve the labels are 1 and 2. And new the element label are te region number not the label. This element are not really test so be carfull.
- PETSc 3.15.0
- bug in Find triangle contening point in 2d (border case),
int Mesh::DataFindBoundary::Find(R2 PP,R *l,int & outside) const
the parameter l not correclty return due to local variable. - set CFLAGS=-Wno-implicit-function-declaration to complie with Apple clang version 12.0.0 (clang-1200.0.32.29)
to remove following error: implicit declaration of function
correct
3dCurve/basicGlue.edp
and add missing test - bugs in SLEPc
SVDSolve()
with a rectangularMat
- bugs in nElementonB for DG 3d formulation.
- Bilaplacian example using Morley FE with PETSc, see
examples/hpddm/bilaplacian-2d-PETSc.edp
- Oseen problem preconditioned by PCD, see
examples/hpddm/oseen-2d-PETSc.edp
- SLEPc polynomial eigenvalue solver
PEPSolve()
- add trivial example to check periodic boundary condition on meshS , meshL , mesh3 examples/3d/periodic3.edp examples/3dSurf/periodicS.edp examples/3dCurve/periodicL.edp
- PETSc version 3.14.2
- Mmg version 5.5.2
- link of ffglut so change in configure.ac and Makefile.am LIBS -> FF_LIBS and LIBS become empty to remove default libs
- change number of save plot in ffglut from 10 to 20 for O. Pironneau
- some memory leaks
- the periodic boundary condition have wrong before first a sementic level of MeshS and MeshL case. the new syntexe is for example: meshL Tl=segment(10); fespace Vl(Tl,P1,periodic=[[1],[2]]); meshS Th=square3(10,10,[x2pi,y2pi]); fespace Vh2(Th,P1,periodic=[[1,x],[3,x],[2,y],[4,y]]);
- fixed '*' keyboard trick, to keep the viewpoint in ffglut or not.
- change the language definition to use type as a construction function with named arguments for bem plugin
- PETSc version 3.14.0
- ARPACK compiled by SLEPc
- Mmg version 5.5.0
- -std=c++14 instead of -std=c++11 when possible
- plugins thresholdings, symmetrizeCSR, and fflapack and associed example
- problem compilation with gfortran-10 of arpack and mumps (add -fallow-argument-mismatch flags)
- new way to build matrix between 2d Finite element 2d and Curve finite element to do mortar (Thank to Axel ) , see first example
examples/tutorial/mortar-DN-4-v4.5.edp
- add
Ns
normal vector in R^3 on meshS (normal of the surface) of current point (to day Ns of [x,y,0] plan is [0,0,-1]) no be compatible to exterior normal. - add
Tl
tangent vector in R^3 on meshL (tangent vector of the line/curve) of current point - compile ffmaster / ffslave example under windows (thanks to [email protected])
- Boolean parameter
spiltpbedge
inbuildmesh
to split in to edge with two boundary vertices - interface to PETSc DMPlex, see
examples/hpddm/DMPlex-PETSc.edp
- function
MatDestroy
- function
MatPtAP
andtransferMat
for parallel interpolation between non-matching grids, seeexamples/hpddm/PtAP-2d-PETSc.edp
orexamples/hpddm/diffusion-mg-2d-PETSc.edp
- preliminary interface to
SVDSolve
from SLEPc to compute singular value decompositions, seeexamples/hpddm/mf-2d-SLEPc.edp
orexamples/hpddm/helmholtz-2d-SLEPc-complex.edp
- preliminary interface to
NEPSolve
from SLEPc to solve nonlinear eigenvalue problems, seeexamples/hpddm/nonlinear-2d-SLEPc-complex.edp
transpose
parameter when constructing aMat
for defining a matrix-free transposed operation- interface to
PetscMemoryGetCurrentUsage
- add P2b, RT0, RT1 surface FE (P2bS, RT0S, RT1S))
- add operator interpolate (2d->3d surface)
- add operator x = A'*b; where x, b are array and A 2 dim array (full matrix) and generate an error in case of b'*A or b'*A expression
- function
MatLoad
to load a PETScMat
from disk, seeexamples/hpddm/MatLoad-PETSc.edp
- possibility to assemble a symmetric
HMatrix<complex>
and to densify aHMatrix<complex>
into aMat<complex>
- moved Htool to its new GitHub location
- ScaLAPACK and MUMPS are not compiled by PETSc anymore if there is no Fortran compiler
- MPICH is compiled by PETSc if no MPI is detected during configure, see https://community.freefem.org/t/feature-request-use-download-mpich-on-ubuntu/407
- PETSc version 3.13.5
- force
--with-cudac=0
inmake petsc-slepc
, see #141 - change DSL keyword P1dc3dL->P1dcL and P1dc3dS->P1dcS
- rename
view
,hasType
,changeSchur
to respectivelyObjectView
,HasType
, andChangeSchur
- rename
changeNumbering
,globalNumbering
,originalNumbering
,changeOperator
,destroyRecycling
, andattachCoarseOperator
to respectivelyChangeNumbering
,GlobalNumbering
,OriginalNumbering
,ChangeOperator
,DestroyRecycling
, andAttachCoarseOperator
Nt
the normal vector of the current (wrong on meshL) useNs
orTl
augmentation
routine from the PETSc pluginMPIF77
variable
- lot of mistake in MeshL element add a example o check lot of thing
tutomesh1d.edp
- fixed problem of change of mesh when rebuild 2d mesh with buildmesh, .... (Thank to P. Jovilet to points this problem)
- missing METIS library when using SuiteSparse compiled by PETSc
- missing
-fno-stack-protector
when building PETSc on Windows, see https://community.freefem.org/t/error-loading-complex-petsc-slepc-library/370 - fixed ffglut for the plotting of FE array solution
- fixed ffglut bug on MacOS Catalina , draw inn only half windows screen (Apple Bug ???)
- correct P0VF finite element
abs
function of array
- new search algorithm for the element containing a point (more safe) in mesh of type mesh3, meshS, or meshL.
- new function
hasType
to know if a PETSc component has been installed, e.g.,hasType("PC", "hypre")
- eigenvalue problems on linear elements, cf.
examples/eigen/LapEigen1DBeltrami.edp
orexamples/hpddm/laplace-beltrami-3d-line-SLEPc.edp
--download-cmake
in PETSc configure if there is no CMake available- flags
--with-[slepc|slepccomplex]-include
and--with-[slepc|slepccomplex]-ldflags
for when SLEPc has been built outside of FreeFEM or PETSc - interface to
KSPSetResidualHistory
andKSPGetIterationNumber
- interface to
mpiWaitAll
- new function extract, allows to build a curve mesh from a 2d mesh (can extract a labeled boundary, apply a geometric transformation)
- ffglut can plot a vectorial FE function in surface 3d
- distributed ParMmg interface, cf.
examples/hpddm/distributed-parmmg.edp
orexamples/hpddm/laplace-adapt-dist-3d-PETSc.edp
- new parallel interpolator on non-matching meshes, cf.
examples/hpddm/transfer.edp
- ability to solve problems in single precision or with 64 bit integers
- tool to read data form vtk file only in 3d (cf. plugin iovtk a first example
examples/plugin/iovtk.edp
) - tool to read/wrile ply file of meshL, mesh3, MeshS : Polygon File Format / Stanford Triangle Format do
load "ioply"
seeexamples//3dSurf/operatorsOnMeshS.edp
- new
tgv
values: -10 => zero row, -20 => zero row/column - Windows binary now shipped with PETSc/SLEPc
- BEM examples are now in
examples/mpi
- plot border type is now in 3d (border 2d and 3d)
- PETSc version 3.13.0
--enable-download_package
may now be used to download a single package, e.g.,--enable-download_metis
- compilation of PETSc under Windows
- compilation of plugins when using static libraries
- correct detection problem in FE type when use a vectorial FE
- macro concatenation with spaces in arguments
- correct bug in
plugin/seq/Schur-Complement.cpp
- correct ambiguity bug in
plugin/seq/bfstream.cpp
(reading real or integer) - compilation of plugin libff-mmap-semaphore.c under windows
- for windows version: rename under mpi
MUMPS
inMUMPS_mpi
and in sequentiel inMUMPS_seq
due to conflict between seq. and mpi version so all MUMPS load becomeMUMPS_seq
orMUMPS_mpi
in all examples - correct link edition with fortran mpi under windows juste use the msmpi (just use
libmsmpi.dll
) - new
mmg
andparmmg
(parallel mmg) plugins interfacing mmg5 and parmmg libraries, to replacemmg3d-v4.0
andfreeyams
(Thanks to P-H Tournier) - a true 3d anisotropic mesh adaptation
examples/3d/Laplace-Adapt-aniso-3d.edp
- an example to extract surface mesh from isovalue in
examples/3dSurf/Pinochio.edp
- function
f.eatspace
to reach eof on istream file which return false in case of EOF. - function
f.length
to get the istream file length - Interface to
PetscLogStagePush()
/PetscLogStagePop()
- Ability to directly assemble a
Mat
using avarf
- New
bem
plugin for the Boundary Element Method (using htool and BemTool libraries) - New DSL for BEM (varfbem see examples/bem)
- add int0d to apply Neumann BC (curve FE), differential operators (dx,dy,...), compute an 1d integral
- add P1dc FE for Border FEM (possible to define a new FE with plugin)
- PETSc as a subdomain solver for HPDDM
- correct ffglut (bug in case of changing number of nb isovalue)
- PETSc version 3.12.4
- Change the point search triangle algorithm to be sure in any case (in test)
- Sline operator renamed to segment
- In square3, segment, movemesh functions: geometry transformation can now be [X] or [X,Y] or [X,Y,Z] according to the minimal shape element dim
- PETSc now download OpenBLAS if there is no BLAS found by FreeFEM configure
- freeyams plugin
- mmg3d-v4.0 plugin
- fix plot for curve mesh
- Preliminary support for symmetric distributed PETSc matrices (MATMPISBAIJ instead of MATMPIAIJ)
- Interface to AMS, Hiptmair--Xu preconditioner for problems in H(curl), see maxwell-3d-PETSc.edp
- FEM on curve 3D (in test)
- P0, P1, P2 curve 3D FE (scalar for the moment)
- i/o medit and vtk format for curve FE
- checkMesh() function, allow to remove multiple vertices, elements and border elements (argument: precisvertice(double),removeduplicate(bool))
- possible to build a curve mesh from a surface, ThS = buildBdMesh(ThS) and define this new mesh by meshL ThL= ThS.Gamma
- can extract a border part of a meshL (meshL ThL = extract(ThL,label=llabs))
- Support for optimized boundary conditions with PETSc, see helmholtz-2d-PETSc-complex.edp
- buildmeshL() function: build meshL from borders
mpiCommSelf
keyword
- function buildSurface(...) renamed by buildBdMesh(...)
- line3(...) renamed by SLine(...)
- FFTW is not compiled by PETSc anymore
- Spurious outputs in TetGen plugin
- curve3 type -> border
- hypre examples since it is not downloaded by FreeFEM for many months (use PETSc instead)
dscalprod
routine from HPDDM and PETSc plugins, useA(u, v)
withA
aMat
or aschwarz
objectexport
function formacro_ddm.idp
, usesavevtk
as in the sequential iovtk plugin
- plotMPI function for plotting 3D solutions, problem with serialize
- variable mes in clean_mesh function
- correct bug verflow in plugin iohdf5
- correct problem with buffer iostream function (buffer must be out of range )
- correct i/o vtk and by defaut write at binary format
- fix an overflow in RT13d FE
- problem with auto-build of border mesh
- add matrix and array tools (FH)
matrix A=eye(10); real[int,int] af = eye(10,10); real[int,int] a(10,10); int[int] I=[1,3,6]; real[int] d = a.diag ; // get the diag of full matrix (no copy) real[int] dI= d(I); // init a array from renumbering array real[int] c= a(:,1)(I); // init a array from renumbering array real[int] aa= a.asarray; // view full the matrice as an array (no copy) a(2:5,3:7).diag= 200; a.diag += 100;
- adding of a global variable
lockOrientation
to allows the building of mesh without checking the orientation elements (AF) - add plugin tool to build matrix edge/P1 with sign
mat_edgeP1
(FH) - new examples
diffusion-2d-mg.edp
andhelmholtz-2d-mg.edp
showing how to use user-defined coarse corrections - support for nonzero scalars in PETSc block matrices
- simpler constructor for sequential HPDDM matrices (no need for the restriction array and the partition of unity)
- array of
Mat
andschwarz
types - add mpi meshS (serialize object)
- correct mistake in mpirank in case of broadcast with comm (thank tp PHT)
- update fftw to v3.3.8 and openblas v0.3.6
- in movemesh23 correct the argument label -> region to change label
- new implementation for the moving mesh functions, new arguments: boolean cleanmesh, removemultiple, rebuildborder
- new PETSc version 3.12
- templatize movemesh, setMesh functions
- add conditional tests in make check
- spurious output in PARDISO
- fix problem in ffglut (AF)
- detect hdf5 and gsl if no enable-download
- interface to
TSSolve
, DAE/ODE solvers from PETSc - interface to
TaoSolve
, Toolkit for Advance Optimization from PETSc - simpler constructor for sequential PETSc matrices (no need for the restriction array and the partition of unity)
- some unit tests
- PETSc version 3.11.3
- replaced custom implementations (
RNM::real
,RNM::norm2
, andFem2D::norm
) by C++11 functions - API of the macro
plotMPI
- switched to inexact coarse operators in HPDDM by default
- RHS and solution vectors permuted in
IterativeMethod
andDDM
.mesh
are now saved using version 2 (which stores floating-point scalars in double precision)
- legacy linear solver interfaces using the old matrix type
- dot products using CBLAS because of errors at link time
- Newtow function (bad name)
- assertion failure with some 3D meshes when doing
trunc(Th, true)
(thanks to F. Feppon) - compile error when plotting arrays of vectorial functions
- nested fieldsplit example
examples/hpddm/natural-convection-2d-PETSc-fieldsplit.edp
int[int][int] array;
is now supported (a size was previously needed, i.e.,array(0);
)- check selectivity during
make check
, depending on available 3rd party librairies - new CI/CD tools for
develop
branch - new gestion of mesh3 - meshS coupling
- square3, buildSurface... operators for meshS
- SLEPc is now directly downloaded by PETSc with
--download-slepc
- HPDDM and PETSc API have been simplified, instead of an
int[int]
and anint[int][int]
, only a singleint[int][int]
is now needed build
macros for HPDDM and PETSc have been simplified to follow the above API change, two parameters have been permuted as well to match the HPDDM and PETSc constructors- PETSc version 3.11.2 and HPDDM with multilevel GenEO
- old interfaces that were not maintained anymore (pARMS, PaStiX, hips) and that are available through PETSc
- spurious outputs when destroying some meshes
- old surface msh3 type, replaced by meshS
- multiple segmentation faults when using unitialized values (thanks to G. Sadaka)
- nested fieldsplits in the PETSc interface
- memory leaks in
SNESSolve
(nonlinear PETSc solvers) - bug fix of
Cofactor
function - various bug fixes on surface mesh
- missing conj operation is some hermitian operation on complex sparse matrix like A+cB', AB' thanks to P-H Tournier
- writing CheckAllEdp to be compatible with new tree
- fix eps in trunc in case of very anisotrope mesh, Thank G. Sadaka
- CMake, thanks to https://github.com/cdoucet
- Surface finite element, thanks to AFourmont
- AppImage generation, thanks to Alexander Sashnov
- PETSc/SLEPc version 3.11
- correct bug in RT1Ortho and RT2Ortho 2d in the computation of derivative (2018-01-30, Thank to [email protected])
- uniformize 2d/3d in element, method EdgeOrientation(e) now return +1/-1
- change all the sparse matrix structure
- remove all map matrix jan 2019
- surface finite element (in progress)
- nElementonB (version 2d and 3d of nTonEge)
- area ( same the lenEdge) in 3d
- add function labels to get the array of label of a mesh
- add function regions to get the array of label of a mesh
- correct big bug in toRarray,toZarray, toCarray transform [ ... ] array to int[int], real[int], complex[int]
3.62 - 2018-08-31
- add x0=true/false, add veps=eps in solver parameters to initialazed of not the the CG , GMRES algo with 0 or previous value and veps is to get the absolue tolerance
- A tool of solve adjoint matrix A with only one single LU decomposition with LU, UMFPACK, GMRES
u[]=A'^-1*b;
- Add plugin to save matrix in Harwell-Boeing format (see Harwell-Boeing format)
- Fix bug in
trunc
(2d) in case of very fine mesh (eps too small)
3.61 - 2018-06-20
- Add name parameter
kerneln=
,kernelt=
,kerneldim=
for dissection solver - Add option in method
toClose
function infquatree
to get the nearst point (for intersect meshes) - Add missing file
curvature.edp
- Add
imax
,jmax
,imin
,jmin
to get index of row or column of the min or max coefficient
We have:A(A.imin,A.jmin) = A.min
- Add cosmetics in macro (macro name, macro line...)
- Pass to PETSc/SLEPc version 3.8.4/3.8.3
- Fix launchff.exe bug under windows 64 to choose a filescrip if no parameter
- Fix the label definition in case of
intalledges
in 2d - Fix mpi_comm with MUMPS (very rare)
- The main distribution is now on Github