[petsc-users] KSP Solver giving inf's

Matthew Knepley knepley at gmail.com
Sat Apr 8 08:31:40 CDT 2017


On Sat, Apr 8, 2017 at 8:26 AM, Kaushik Kulkarni <kaushikggg at gmail.com>
wrote:

> I guess there is a miscalculation:
> 2*row1 + row2 = (4, 0, 0)
>

You are right here, but I think it is still rank deficient.

  Thanks,

    Matt


> Thanks,
> Kaushik
>
> On Apr 8, 2017 6:52 PM, "Matthew Knepley" <knepley at gmail.com> wrote:
>
> On Sat, Apr 8, 2017 at 6:54 AM, Kaushik Kulkarni <kaushikggg at gmail.com>
> wrote:
>
>> Hello,
>> I just started with PETSc and was trying the KSP Solvers. I was trying
>> for the problem -
>>
>> int main(int argc, char *argv[])
>> {
>>     /// matrix creation variables.
>>     PetscInt    *idxm = new PetscInt[3];
>>     PetscInt    *idxn = new PetscInt[3];
>>
>
> Note that the problem below is rank deficient (2 * row 1 + row 2 = 0). Its
> not clear to me whether b is
> in the range space of the operator.
>
>   Thanks,
>
>     Matt
>
>
>>     PetscReal   loc[]  = { 1.0, -2.0, -6.0,
>>                                    2.0,  4.0, 12.0,
>>                                    1.0, -4.0,-12.0};
>>     PetscReal   b_array[] = {  12.0,
>>                               -17.0,
>>                                22.0};
>>     PetscInt i;
>>     KSP      ksp;
>>
>>     /// Declaring the vectors
>>     Vec     x, b;
>>
>>     // Declaring matrices
>>     Mat A;
>>
>>     PetscInitialize(&argc,&argv,(char*)0,help);
>>     // Creating vectors
>>     VecCreateSeq(PETSC_COMM_SELF, 3, &x);
>>     VecCreateSeq(PETSC_COMM_SELF, 3, &b);
>>     // Creating matrix
>>     MatCreateSeqAIJ(PETSC_COMM_SELF, 3, 3, 3, NULL, &A);
>>     // Creating the indices
>>     for(i=0; i<3; i++) {
>>         idxm[i] = i;
>>         idxn[i] = i;
>>     }
>>     // Assembling the vector b and x
>>     VecSetValues(b, 3, idxm, b_array, INSERT_VALUES);
>>     VecAssemblyBegin(b);
>>     VecAssemblyEnd(b);
>>
>>     //Assembling the Matrix
>>     MatSetValues(A, 3, idxm, 3, idxn, loc, INSERT_VALUES);
>>     MatAssemblyBegin(A, MAT_FINAL_ASSEMBLY);
>>     MatAssemblyEnd(A, MAT_FINAL_ASSEMBLY);
>>
>>     // KSP related operations
>>     KSPCreate(PETSC_COMM_SELF, &ksp);
>>     KSPSetType(ksp, KSPGMRES);
>>     KSPSetOperators(ksp, A, A);
>>     KSPSetFromOptions(ksp);
>>     KSPSolve(ksp,b,x);
>>     KSPDestroy(&ksp);
>>
>>     VecView(x, PETSC_VIEWER_STDOUT_SELF);
>>
>>     PetscFinalize();
>>     return 0;
>> }
>>
>> But the obtained solution is found out to be- (inf, inf, inf).
>>
>> I wanted to know whether I am doing something wrong or is the problem
>> inherently not solvable using GMRES. Currently I am running the code in a
>> sequential manner(no parallelism intended).
>>
>> Thank you.
>>
>
>
>
> --
> What most experimenters take for granted before they begin their
> experiments is infinitely more interesting than any results to which their
> experiments lead.
> -- Norbert Wiener
>
>
>


-- 
What most experimenters take for granted before they begin their
experiments is infinitely more interesting than any results to which their
experiments lead.
-- Norbert Wiener
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.mcs.anl.gov/pipermail/petsc-users/attachments/20170408/f1245c03/attachment.html>


More information about the petsc-users mailing list