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@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

Reply via email to