Have you tried SNESVINEWTONRSLS? In my experience, I seem to have slightly
better luck with that one instead of SNESVINEWTONSSLS

On Sat, Aug 18, 2018 at 12:56 AM Amir <[email protected]> wrote:

> Hi
> I need to apply constraint to primitive variables. I am troubling to set
> up SNESVI. After running the code, I feel SNES is not actually solving.
> After one iteration of SNES, I got DIVERGED_LINESEARCH, with NO changing in
> function norm.
> I think the way I set VI maybe wrong. Sorry for my simple explanation.
> Very thankful for your time.
> Amir
> SNESCreate(PETSC_COMM_WORLD,&snes);
> SNESSetApplicationContext(snes,&user);
> SNESSetDM(snes,user.dm);
> SNESSetFunction(snes,NULL,FormFunction,&user);
> FormInitialSolution(user.X,&user);
> SNESSetSolution(snes,user.X);
> SNESMonitorSet(snes,MySNESMonitor,&user,NULL);
> SNESSetType(snes,SNESVINEWTONSSLS);
> SNESSetNormSchedule(snes, SNES_NORM_ALWAYS);
> SNESVISetVariableBounds(snes,user.XLOWER,user.XUPPER);
> SNESGetLineSearch(snes,&linesearch);
> SNESLineSearchSetType(linesearch,SNESLINESEARCHBT);
> SNESLineSearchSetVIFunctions(linesearch, NULL, SNESNormFunction);
> SNESSetFromOptions(snes);
> SNESSolve(snes,NULL,user.X);
> [image: Open Tracking]

Reply via email to