On 04/12/2014 06:10 PM, Barry Smith wrote:
    Patrick,

      Currently it is supported for MatSetValues_SeqAIJ() and 
MatSetValues_MPIAIJ(). It is not handled for BAIJ and SBAIJ, the code while 
crash with segv in those cases (since we don’t check for a valid v pointer 
before use :-).   But support could easily be added for BAIJ and SBAIJ with 
just a few lines of code.

      MatSetValuesBlocked() does not have this kind of support and adding it 
would be cumbersome.

      So I guess the question is does this “feature” add useful functionality 
that makes the slightly more complex code worthwhile? Or is it an oddball thing 
that should be removed? As the cool kids would say “what is the use case for 
this feature?”.

       I’m fine with adding support for BAIJ and SBAIJ and documenting it but 
then I am also fine with removing it though I suspect it is used somewhere in 
PETSc and thus that code would need to be located and changed if it is removed.
Hi Barry,

I was writing (new) code which do the firsts MatSetValues after the MatXAIJSetPreallocation. We have to do this because the "real" non-zeros will be added later by a mix of ADD_VALUES and INSERT_VALUES... which would prevent us to "lock" the matrix (MatSetOption(aMatricePETSc, MAT_NEW_NONZERO_LOCATION_ERR, PETSC_TRUE) because this option must be passed after the first MatAssemblyEnd()... but all the non-zeros are "triggered" only after this "mixed" assembly...

In other words, we have to do a "fake" assembly with all "0" to cover all non-zeros that will be in fact added later... So we have to create many "fake" elementary matrices to pass for assembly... that is why Patrick was asking if the feature was supported... It would save us from creating the fake matrices... Or maybe there is a better solution?...

Thanks,

Eric


    Barry



On Apr 11, 2014, at 12:51 PM, Patrick Lacasse <[email protected]> 
wrote:

Hi,

    I see that implementation of MatSetValues handles a special case when one 
passes a null pointer v=0.
In this case, it is considered that all values are 0.
But the documentation doesn't seems to talk about it :
http://www.mcs.anl.gov/petsc/petsc-current/docs/manualpages/Mat/MatSetValues.html

Is it a feature that we can use?
Should it be added to the doc?

Patrick Lacasse

Reply via email to