I'll put them up.  Running tests now...

Øyvind


on., 14.07.2010 kl. 10.10 -0700, skrev Ondrej Certik:
> 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