<div dir="ltr">I think we're all agreed that this change would be a good thing.<div><br></div><div>What we're not agreed on is how much risk we take by breaking legacy code that relied on argument order.</div><div><br></div><div>I'd argue that we've often already broken such code, and that at least now it will break with a TypeError rather than silent misbehaviour.</div><div><br></div><div>And yet Sebastian's comment implies that there may be a whole raft of former MATLAB users writing code without kwargs. Is that a problem if now they get a TypeError?</div></div><br><div class="gmail_quote"><div dir="ltr">On Fri, 16 Nov 2018 at 16:23, Sebastian Raschka <<a href="mailto:mail@sebastianraschka.com">mail@sebastianraschka.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Also want to say that I really welcome this decision/change. Personally, as far as I am aware, I've trying been using keyword arguments consistently for years, except for cases where it is really obvious, like .fit(X_train, y_train), and I believe that it really helped me regarding writing less error-prone code/analyses.<br>
<br>
Thinking back of the times where I was using MATLAB, it was really clunky and error-prone to import functions and being careful about the argument order. <br>
<br>
Besides, keynote arguments definitely make code and documentation much more readable (within and esp. across different package versions) despite (or maybe because) being more verbose.<br>
<br>
Best,<br>
Sebastian<br>
<br>
<br>
<br>
> On Nov 15, 2018, at 10:18 PM, Brown J.B. via scikit-learn <<a href="mailto:scikit-learn@python.org" target="_blank">scikit-learn@python.org</a>> wrote:<br>
> <br>
> As an end-user, I would strongly support the idea of future enforcement of keyword arguments for new parameters.<br>
> In my group, we hold a standard that we develop APIs where _all_ arguments must be given by keyword (slightly pedantic style, but has shown to have benefits).<br>
> Initialization/call-time state checks are done by a class' internal methods.<br>
> <br>
> As Andy said, one could consider leaving prototypical X,y as positional, but one benefit my group has seen with full keyword parameterization is the ability to write code for small investigations where we are more concerned with effects from parameters rather than the data (e.g., a fixed problem to model, and one wants to first see on the code line what the estimators and their parameterizations were). <br>
> If one could shift the sklearn X,y to the back of a function call, it would enable all participants in a face-to-face code review session to quickly see the emphasis/context of the discussion and move to the conclusion faster.<br>
> <br>
> To satisfy keyword X,y as well, I would presume that the BaseEstimator would need to have a sanity check for error-raising default X,y values -- though does it not have many checks on X,y already?<br>
> <br>
> Not sure if everyone else agrees about keyword X and y, but just a thought for consideration.<br>
> <br>
> Kind regards,<br>
> J.B.<br>
> <br>
> 2018年11月15日(木) 18:34 Gael Varoquaux <<a href="mailto:gael.varoquaux@normalesup.org" target="_blank">gael.varoquaux@normalesup.org</a>>:<br>
> I am really in favor of the general idea: it is much better to use named<br>
> arguments for everybody (for readability, and to be less depend on<br>
> parameter ordering).<br>
> <br>
> However, I would maintain that we need to move slowly with backward<br>
> compatibility: changing in a backward-incompatible way a library brings<br>
> much more loss than benefit to our users.<br>
> <br>
> So +1 for enforcing the change on all new arguments, but -1 for changing<br>
> orders in the existing arguments any time soon.<br>
> <br>
> I agree that it would be good to push this change in existing models. We<br>
> should probably announce it strongly well in advance, make sure that all<br>
> our examples are changed (people copy-paste), wait a lot, and find a<br>
> moment to squeeze this in.<br>
> <br>
> Gaël<br>
> <br>
> On Thu, Nov 15, 2018 at 06:12:35PM +1100, Joel Nothman wrote:<br>
> > We could just announce that we will be making this a syntactic constraint from<br>
> > version X and make the change wholesale then. It would be less formal backwards<br>
> > compatibility than we usually hold by, but we already are loose with parameter<br>
> > ordering when adding new ones.<br>
> <br>
> > It would be great if after this change we could then reorder parameters to make<br>
> > some sense!<br>
> <br>
> > _______________________________________________<br>
> > scikit-learn mailing list<br>
> > <a href="mailto:scikit-learn@python.org" target="_blank">scikit-learn@python.org</a><br>
> > <a href="https://mail.python.org/mailman/listinfo/scikit-learn" rel="noreferrer" target="_blank">https://mail.python.org/mailman/listinfo/scikit-learn</a><br>
> <br>
> <br>
> -- <br>
> Gael Varoquaux<br>
> Senior Researcher, INRIA Parietal<br>
> NeuroSpin/CEA Saclay , Bat 145, 91191 Gif-sur-Yvette France<br>
> Phone: ++ 33-1-69-08-79-68<br>
> <a href="http://gael-varoquaux.info" rel="noreferrer" target="_blank">http://gael-varoquaux.info</a> <a href="http://twitter.com/GaelVaroquaux" rel="noreferrer" target="_blank">http://twitter.com/GaelVaroquaux</a><br>
> _______________________________________________<br>
> scikit-learn mailing list<br>
> <a href="mailto:scikit-learn@python.org" target="_blank">scikit-learn@python.org</a><br>
> <a href="https://mail.python.org/mailman/listinfo/scikit-learn" rel="noreferrer" target="_blank">https://mail.python.org/mailman/listinfo/scikit-learn</a><br>
> _______________________________________________<br>
> scikit-learn mailing list<br>
> <a href="mailto:scikit-learn@python.org" target="_blank">scikit-learn@python.org</a><br>
> <a href="https://mail.python.org/mailman/listinfo/scikit-learn" rel="noreferrer" target="_blank">https://mail.python.org/mailman/listinfo/scikit-learn</a><br>
<br>
_______________________________________________<br>
scikit-learn mailing list<br>
<a href="mailto:scikit-learn@python.org" target="_blank">scikit-learn@python.org</a><br>
<a href="https://mail.python.org/mailman/listinfo/scikit-learn" rel="noreferrer" target="_blank">https://mail.python.org/mailman/listinfo/scikit-learn</a><br>
</blockquote></div>