[petsc-users] Ignore command line arguments with fortran code using PETSc

Barry Smith bsmith at mcs.anl.gov
Fri Jul 29 09:49:29 CDT 2016


> On Jul 28, 2016, at 2:35 AM, Tim Steinhoff <kandanovian at gmail.com> wrote:
> 
> 2016-07-27 21:42 GMT+02:00 Barry Smith <bsmith at mcs.anl.gov>:
>> 
>>  Actually there is currently no way to PetscInitialize from Fortran without adding the command line options to the database. In the middle
>> of petscinitialize_() is the code fragment
>> 
>>  PETScParseFortranArgs_Private(&PetscGlobalArgc,&PetscGlobalArgs);
>>  FIXCHAR(filename,len,t1);
>>  *ierr = PetscOptionsInsert(NULL,&PetscGlobalArgc,&PetscGlobalArgs,t1);
>> 
>>  We'll need to do a bit of code refactoring to provide a Fortran petscinitializenoarguments_(). The simplest way to refactor would be to change the name of petscinitialize_ to say PetscInitializeFortran_Internal() and add a bool argument whether to process the arguments and then write two trivial routines petscinitialize_ that calls the new routine with PETSC_TRUE and petscinitializenoarguments_() that calls it with PETSC_FALSE.
> 
> Thanks Barry. It would be really nice if PETSc comes with that feature
> in future, because I would prefer not to make any changes to the PETSc
> code that disappear with every new PETSc release.

   Understood. You could make a pull request with your changes https://bitbucket.org/petsc/petsc/wiki/pull-request-instructions-git otherwise I will add it but it will take a few days since I am backlogged.

   Barry

> 
>> 
>>   Barry
>> 
>>  Of course you can have a C/C++ main routine that calls PetscInitializeNoArguments(); followed by PetscInitializeFortran() and then have the bulk of your code in Fortran.
> That would work, but we have a rather large fortran code without any
> C. So, for now we will probably stick to your first approach and keep
> our code fotran only.
> 
> Thanks again,
> Volker
> 
> 
>> 
>> 
>>> On Jul 27, 2016, at 10:55 AM, Tim Steinhoff <kandanovian at gmail.com> wrote:
>>> 
>>> 2016-07-27 16:04 GMT+02:00 Matthew Knepley <knepley at gmail.com>:
>>>> On Wed, Jul 27, 2016 at 4:59 AM, Tim Steinhoff <kandanovian at gmail.com>
>>>> wrote:
>>>>> 
>>>>> Hi all,
>>>>> 
>>>>> we coupled PETSc with our fortran code. Is there any way to let PETSc
>>>>> (PetscInitialize) ignore all arguments passed by the command line?
>>>>> Since our code is controlled by command line arguements as well, it
>>>>> leads to a mess, when those arguments are read twice.
>>>> 
>>>> 
>>>> 1) You can use PetscInitializeNoArguments()
>>> 
>>> Thanks! I thought that function was for C/C++ only.
>>> 
>>>> 
>>>> 2) What goes wrong? PETSc should just ignore any options it does not
>>>> recognize.
>>> 
>>> 
>>> The problem is that our code uses the same or similar argument names
>>> as PETSc does and our end user should not have access to all petsc
>>> options.
>>> 
>>> 
>>>> 
>>>> Thanks,
>>>> 
>>>>   Matt
>>>> 
>>>>> 
>>>>> Thanks and kind regards,
>>>>> 
>>>>> Volker
>>>> 
>>>> 
>>>> 
>>>> 
>>>> --
>>>> 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
>> 



More information about the petsc-users mailing list