<div dir="auto">I think the best solution is to have mattranspose, matnormal and similar to be subclasses of matshell</div><br><div class="gmail_quote"><div dir="ltr">Il giorno Dom 2 Dic 2018, 02:23 Smith, Barry F. via petsc-dev <<a href="mailto:petsc-dev@mcs.anl.gov">petsc-dev@mcs.anl.gov</a>> ha scritto:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><br>
I am fine with you giving this a try. I fear it mostly just moves the complications from one (several :-)) places to a different place but.<br>
<br>
Barry<br>
<br>
<br>
> On Dec 1, 2018, at 2:47 PM, Hapla Vaclav <<a href="mailto:vaclav.hapla@erdw.ethz.ch" target="_blank" rel="noreferrer">vaclav.hapla@erdw.ethz.ch</a>> wrote:<br>
> <br>
> Yes, that means that a significant part of MatShell logic would become default implementations. But I would now do that only with MatDiagonalScale as a proof-of-concept - then we can progressively do the same with the others. At some point it could happen even with axpy - I think it would be cool although more a complex task as you say.<br>
> <br>
> Vaclav<br>
> <br>
>> 1. 12. 2018 v 21:31, Smith, Barry F. <<a href="mailto:bsmith@mcs.anl.gov" target="_blank" rel="noreferrer">bsmith@mcs.anl.gov</a>>:<br>
>> <br>
>> <br>
>> So basically hoist most of the data structure <br>
>> <br>
>> typedef struct {<br>
>> struct _MatShellOps ops[1];<br>
>> <br>
>> PetscScalar vscale,vshift;<br>
>> Vec dshift;<br>
>> Vec left,right;<br>
>> Vec left_work,right_work;<br>
>> Vec left_add_work,right_add_work;<br>
>> Mat axpy;<br>
>> PetscScalar axpy_vscale;<br>
>> PetscBool managescalingshifts; /* The user will manage the scaling and shifts for the MATSHELL, not the default */<br>
>> void *ctx;<br>
>> } Mat_Shell;<br>
>> <br>
>> into Mat? MatShell handles the axpy (which is nasty), would you handle that as well, if not then you still have code duplication between the MatShell implementations and the Mat___Basic implementations. If it wasn't for the axpy I would say it is worth trying but including correctly the axpy (I am not sure if it is always handled correctly for MatShell) requires complex code.<br>
>> <br>
>> <br>
>> Barry<br>
>> <br>
>> <br>
>>> On Dec 1, 2018, at 1:49 PM, Hapla Vaclav <<a href="mailto:vaclav.hapla@erdw.ethz.ch" target="_blank" rel="noreferrer">vaclav.hapla@erdw.ethz.ch</a>> wrote:<br>
>>> <br>
>>> MatDiagonalScale_Shell, MatDiagonalScale_Normal, MatDiagonalScaleHermitian_Normal and perhaps some others are essentially the same.<br>
>>> <br>
>>> What about converting them into one MatDiagonalScale_Basic which would be the default implementation if no type-specific implementation is provided?<br>
>>> <br>
>>> I'm asking because I wanted to add the same to MATTRANSPOSE. But with my proposal, this redundancy would be removed and additionally MatDiagonalScale() would work for any current or future MatType while it doesn't prevent providing an optimised version for explicit matrix types.<br>
>>> <br>
>>> Note the same could be done for MatScale, MatShift, MatDiagonalSet and maybe some others.<br>
>>> <br>
>>> I also think such approach would promote using such high-level API functions in higher PETSc layers and user codes because one wouldn't have to be afraid those methods might not be implemented in input matrices.<br>
>>> <br>
>>> Thanks for opinions<br>
>>> <br>
>>> Vaclav<br>
>> <br>
> <br>
<br>
</blockquote></div>