[petsc-users] VecPow clarification

Barry Smith bsmith at petsc.dev
Thu Nov 14 09:14:13 CST 2024


   Good question. Looking at the commit logs from 2014 I see 

move tao vector operations over to Vec directory, fix a couple names and calling sequences


 So previously, the function was  problem-specific for Tao (which did not support complex numbers) used inside the semi-smooth methods where roots of negative numbers should be mapped to infinity (indicating a "bad" domain point).

 When we merged the Tao and PETSc source code base  just blindly copied over the code without realizing it was not a general-purpose VecPow() and that it did not make sense for complex numbers.

 I should rework it for general use without breaking the use in Tao.

 Thanks for pointing out the problem.

  Barry





> On Nov 14, 2024, at 9:39 AM, Peder Jørgensgaard Olesen via petsc-users <petsc-users at mcs.anl.gov> wrote:
> 
> Given a vector containing roots of unity, v[i] = exp(i*k*x[i]) I wanted to compute the vector u[i]=exp(i*n*k*x[i]), for some real number n. From the face of it this should be easily achieved with VecPow, as u[i] = v[i]^n.
> 
> That didn't work as expected, though I got around it using VecGetArray() and a loop with PetscPowComplex(). The source designated in the docs (src/vec/vec/utils/projection.c) reveals that VecPow() maps v[i] to PETSC_INFINITY when the PetscRealPart(v[i]) < 0, unless the power is any of 0, ±0.5, ±1 or ±2. Even in the simple case of a purely real vector (with negative entries) raised to any other integer power, the results would not be what one might  reasonably expect from the description of VecPow().
> 
> While I do have a solution suiting my need, I'm left wondering what might be the rationale for VecPow working the way it does.
> 
> Best,
> Peder

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.mcs.anl.gov/pipermail/petsc-users/attachments/20241114/00bccd17/attachment.html>


More information about the petsc-users mailing list