Toon -- if you have time, please upload them to github, then we can
easily pull it.

Ondrej

On Wed, Jul 14, 2010 at 9:16 AM, Andy Ray Terrel <andy.ter...@gmail.com> wrote:
> Øyvind,
>
> Have these patches been added to a repo somewhere so I can push them
> in?  I'm not sure which goes where.
>
> -- Andy
>
> On Sat, Jul 10, 2010 at 10:35 AM, Øyvind Jensen <jensen.oyv...@gmail.com> 
> wrote:
>> Hi Toon,
>>
>> Thanks for your patches/suggestions and for looking over my work!
>>
>> lø., 10.07.2010 kl. 09.09 +0200, skrev Toon Verstraelen:
>>> Hi,
>>>
>>> I've been looking into the fcode and codegen implementation. Sorry for
>>> the delay. First of all: I'm really happy with the work being done. I
>>> wish I could dedicate more time to the reviewing.
>>>
>>> I have a few small patches, but consider them as suggestions. (See
>>> attachments.)
>>>
>>>
>>> 0001-just-call-fcode-and-derivation-friendly-settings.patch
>>>
>>> I'm more in favor of calling fcode directly. Then there is no need to
>>> write set_some_setting methods in the printers, which is much cleaner
>>> API-wise. The overhaed should be small, but I don't know what the actual
>>> reason was to have a self._printer atribute in FCodeGen? I also added a
>>> test to make sure that the settings are handled in an
>>> inheritance-friendly way.
>>
>> I agree that the set_assign_to method is ugly, and in retrospect I see
>> how this could be avoided by sticking with fcode instead of
>> self._printer.  The reason I changed to self._printer, was because I
>> wanted to ensure that the printer had identical settings in every call
>> from the FCodeGen object.  In the end, it turned out that the printer is
>> called only at one place, so self._printer is not really necessary.
>>
>> I propose a slight simplification of you patch:
>>
>> +        assign_to = self._settings['assign_to']
>> +        if isinstance(assign_to, basestring):
>> +            self._settings['assign_to'] = Symbol(assign_to)
>> +        elif isinstance(assign_to, (Basic, type(None))):
>> +            self._settings['assign_to'] = assign_to
>>         else:
>>             raise TypeError("FCodePrinter cannot assign to object of
>> type %s"%
>> -                    type(result_variable))
>> +                    type(assign_to))
>>
>>
>> The elif clause doesn't do anything.  This would be better:
>>
>> +        assign_to = self._settings['assign_to']
>> +        if isinstance(assign_to, basestring):
>> +            self._settings['assign_to'] = Symbol(assign_to)
>> +        elif not isinstance(assign_to, (Basic, type(None))):
>>             raise TypeError("FCodePrinter cannot assign to object of
>>
>>
>> This is also implemented in the attachment.
>>
>>>
>>>
>>> 0002-Fixed-missing-comma-in-__all__-in-codegen.py.patch
>>>
>>> This seems futile, but it is probably something that happens easily. Is
>>> it possible to add a code quality test that checks of 'from mod import
>>> *' works for every module?
>>>
>>
>> The patch is fine, and the test you propose would be useful, but I don't
>> know how to implement it.
>>
>>>
>>> 0003-Fixed-return-value-assignment-in-FCodeGen.patch
>>>
>>> Just a small bug fix.
>>>
>> Thanks, the patch is fine.  The test reveals that the logic to determine
>> if initialization is needed, is far from perfect.  But that's another
>> issue.
>>
>>
>>>
>>> Some more suggestions that came to mind:
>>>
>>> - Rename FCodeGen to F95CodeGen (also use .f95 then). In the long run it
>>> would be interesting to have an F77CodeGen too. I guess it will be
>>> different enough to justify two classes.
>>
>> Good idea.
>>
>>>
>>> - The expr argument of the Routine constructor was one of the next
>>> things I wanted to modify before I stopped working on codegen. Now the
>>> constructor tries to figure out which expression is a return variable,
>>> and so on. It would be more convenient to replace expr by results, i.e.
>>> a list of ResultBase instances. This gives some more freedom to the user
>>> and it makes the implementation way easier. The current trick with the
>>> Equality class is rather counterintuitive.
>>
>> I like the simple user interface where you just supply the expression
>> and let the constructor figure out something that works.  This is also
>> very useful for automatic compilation[0].  But I realize that more
>> control could be useful, and I think we can easily have both.
>>
>> Given that the constructor should accept Expr instances, I don't agree
>> that the *treatment* of the Equality class is counter-intuitive.  But if
>> your concern is about the Equality class being the only user interface
>> for obtaining code with output arguments, I see what you mean.
>>
>> Again, thanks a lot for the patches.  They are all +1 with the slight
>> modification of the first.
>>
>> Cheers,
>> Øyvind
>>
>>
>> [0]:
>> http://github.com/jegerjensen/sympy/commit/f4d917def699f6b78a404cd89dba1248491a766f
>>
>>>
>>> cheers,
>>>
>>> Toon
>>>
>>
>> --
>> You received this message because you are subscribed to the Google Groups 
>> "sympy-patches" group.
>> To post to this group, send email to sympy-patc...@googlegroups.com.
>> To unsubscribe from this group, send email to 
>> sympy-patches+unsubscr...@googlegroups.com.
>> For more options, visit this group at 
>> http://groups.google.com/group/sympy-patches?hl=en.
>>
>>
>
> --
> You received this message because you are subscribed to the Google Groups 
> "sympy-patches" group.
> To post to this group, send email to sympy-patc...@googlegroups.com.
> To unsubscribe from this group, send email to 
> sympy-patches+unsubscr...@googlegroups.com.
> For more options, visit this group at 
> http://groups.google.com/group/sympy-patches?hl=en.
>
>

-- 
You received this message because you are subscribed to the Google Groups 
"sympy-patches" group.
To post to this group, send email to sympy-patc...@googlegroups.com.
To unsubscribe from this group, send email to 
sympy-patches+unsubscr...@googlegroups.com.
For more options, visit this group at 
http://groups.google.com/group/sympy-patches?hl=en.

Reply via email to