← Back to team overview

dolfin team mailing list archive

Re: copying functions

 

On Tue, Jul 01, 2008 at 04:59:54PM +0200, Andy Ray Terrel wrote:
> Okay so I am trying to get the Scott Vogelius Stokes algorithm working
> again, but I've hit a bit of a wall with the copying 4th ordered
> functions. In the algorithm there is a term that gets updated every
> iteration (w = w + r * u).  So I could do this with a form as Anders
> has suggested before, but it seems silly to use the 10K lines to do
> what essentially is a vector axpy.  Since some people at simula are
> working on the function classes, I pose the question: Should we be
> able to do this with functions? For example something like:
> 
> ...
> 1   Function w;
> 2   w = Function(mesh, 0.0);
> 3   BilinearForm a(-1e3);
> 4   for (...) {
> 5     LinearForm L(f,w);
> 6     LinearPDE pde(a,L,mesh,bcs);
> 7     pde.solve(u);
> 8     w += 1e3 * u;
> ...
> 9   }
> ...

I think this should be possible. There could be a simple check to see
whether or not the involved Functions are defined on the same mesh
with the same element and in that case perform the operation on the
underlying Vectors (and otherwise give an error message).

We're about to start reworking the DofMap and Function classes. We
recently came to some kind of conlusion on the linear algebra classes
so this is up next.

> Okay so assignment doesn't work for Constant functions (simple fix I
> put in my local repo).  Okay operaters +, +=, * are not defined, so I
> expand line 8 to:
> 
> w.vector().axpy(1e3,u.vector());
> 
> Okay then line 8 won't work because w was previously a constant
> function.  I tried adding something like:
> 
> if (iter == 0) w = u;
> 
> but that didn't work because it is 4th order and the ElementLibrary
> doesn't define it.
> 
> I have tried monkeying around with creating a better assignment
> operator and copy constructor but then I run into other problems.  For
> example who owns the finite_element and DOF, in my current code they
> are getting destroyed with the form and that kills later preprocessing
> I do.
> 
> I have some hacks that basically work, but I wanted to poll the list
> to see what is being planned and put my two cents in about it.

What if you just start with a discrete function which is zero?

The following would work in Python:

  w = Function(element, mesh, Vector())

Or start by projecting whatever your initial data is to a discrete
function:

  w = project(u0, element)

where u0 is some user-defined function (overloading eval) and
returning for example sin(x[0]).

-- 
Anders

Attachment: signature.asc
Description: Digital signature


Follow ups

References