<div dir="ltr"><span style="font-size:12.8px;text-decoration-style:initial;text-decoration-color:initial;float:none;display:inline">[Bruce Leban]<br></span><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><span style="font-size:12.8px;text-decoration-style:initial;text-decoration-color:initial;float:none;display:inline">Lambda calculus IS computer science.</span></blockquote><div>It's a foundation of computer science. That doesn't mean it "IS" computer science. Set theory is a foundation of computer science. It's still it's own discipline.<br><br> <span style="font-size:12.8px;background-color:rgb(255,255,255);text-decoration-style:initial;text-decoration-color:initial;float:none;display:inline">[Bruce Leban]</span></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><span style="font-size:12.8px;background-color:rgb(255,255,255);text-decoration-style:initial;text-decoration-color:initial;float:none;display:inline"><span style="text-decoration-style:initial;text-decoration-color:initial;float:none;display:inline">Rejecting lambda as CS is as bad as rejecting the + operator because that's mathematics.</span></span></blockquote><div>This is a complete misunderstanding of my argument.<br><br>Not all programmers are computer scientists. In fact, not all programmers are professional. Many, including myself, came from engineering. Many came from other scientific fields. Many came from finance and all sorts of fields. Many are teenagers who just want to build a cool website or a video game or scrape song lyrics for their favorite bands.<br><br>The whole point of a programming language is to bridge the gap between machine code and natural language (in Python's case English, as with most other languages). It's to make reading and writing code easier through abstraction, not to create ivory towers through the use of esoteric jargon. It's not supposed to make a cool kids club for people privileged enough to study CS in college. At least that's not my goal.<br><br><span style="text-decoration-style:initial;text-decoration-color:initial;font-size:12.8px;background-color:rgb(255,255,255);float:none;display:inline">[Bruce Leban]</span><br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><span style="font-size:12.8px;background-color:rgb(255,255,255);text-decoration-style:initial;text-decoration-color:initial;float:none;display:inline">Lambda calculus is a model of computation. It was invented about 30 years before the name "computer science" but is nonetheless foundational computer science.<span> </span></span></blockquote><div><br>Yes. I know.<br><br><span style="font-size:12.8px;background-color:rgb(255,255,255);text-decoration-style:initial;text-decoration-color:initial;float:none;display:inline">[Bruce Leban]<br></span><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><span style="font-size:12.8px;background-color:rgb(255,255,255);text-decoration-style:initial;text-decoration-color:initial;float:none;display:inline">If using lambda as a keyword leads people to go and learn about lambda calculus that is a good thing.</span></blockquote><div><br>I don't think the point of Python is to force people to eat their vegetables. You might think it's a good thing if everyone learns about Turing machines and the Halting problem and Kolmogorov Complexity and X86 machine code, etc. but that's not what Python is for. I may think that everyone should learn what I learned in college about electromagnetics and semiconductor physics, etc. But I'm not arrogant enough to force that on people who just want to use abstract tools to get some job done.<br><br>I didn't realize that my distaste for 'lambda' was such an unheard-of opinion. I could have sworn that the likes of Guido Van Rossum and Raymond Hetinger also found the term at least a little troublesome.<br><br>As someone who has taught Python professionally, I can say that there is a strange mental block regarding lambda expressions. Pretty much every student I've had has struggled with lambda expressions, even those who grasp similarly complex constructs like decorators with ease. This includes students who learned english as a second language. I can only attribute that to the word 'lambda' being confusing as hell.<br><br><span style="font-size:12.8px;background-color:rgb(255,255,255);text-decoration-style:initial;text-decoration-color:initial;float:none;display:inline">[Bruce Leban]</span><br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><span style="font-size:12.8px;background-color:rgb(255,255,255);text-decoration-style:initial;text-decoration-color:initial;float:none;display:inline">And as to saying a lambda function is an "anonymous function": the anonymity is not a property of the function.</span></blockquote><div><br>Yes, It is:<br><br>>>> def func(x): return x*x<br>>>> func.__name__<br>'func'<br>>>> func = lambda x: x*x<br>>>> func.__name__<br>'<lambda>'<br><br><span style="font-size:12.8px;background-color:rgb(255,255,255);text-decoration-style:initial;text-decoration-color:initial;float:none;display:inline">[Bruce Leban]<br></span><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><span style="font-size:12.8px;background-color:rgb(255,255,255);text-decoration-style:initial;text-decoration-color:initial;float:none;display:inline">If I assign it to a name, it's no longer anonymous.</span></blockquote><br>That's not how variable assignment works in Python. The name of the variable doesn't become an attribute of the object assigned to the variable.<br><br><span style="font-size:12.8px;background-color:rgb(255,255,255);text-decoration-style:initial;text-decoration-color:initial;float:none;display:inline">[Bruce Leban]</span><br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><span style="font-size:12.8px;background-color:rgb(255,255,255);text-decoration-style:initial;text-decoration-color:initial;float:none;display:inline">I can legitimately argue that + in Python is not the + in mathematics because the Python mathematical operators operate on integers and floats, not real numbers. Therefore we should use a different word like "floatadd". Of course not.</span></blockquote><div><br>My whole point was to be less pedantic, not more pedantic. Pragmatism should prevail over pedantry. This is why, as I've stated earlier, I know that lambda expressions aren't going to change any time soon and I'm fine with that. I consider it a bit of a wart, but whatever. I'm getting really tired of having to defend this opinion.<br><br>Also, this argument makes no sense. Just because there isn't a way to represent all real numbers in a computer, doesn't mean that integer, floating point, and fractional addition become different kinds of addition.</div></div></div></div></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Mon, Aug 13, 2018 at 1:09 PM, Chris Angelico <span dir="ltr"><<a href="mailto:rosuav@gmail.com" target="_blank">rosuav@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span class="">On Tue, Aug 14, 2018 at 4:00 AM, Bruce Leban <<a href="mailto:bruce@leban.us">bruce@leban.us</a>> wrote:<br>
> And as to saying a lambda function is an "anonymous function": the anonymity<br>
> is not a property of the function. If I assign it to a name, it's no longer<br>
> anonymous. Really a "lambda" or "lambda function" is just a function, but<br>
> "lambda" is a synecdoche for "function created with a lambda expression".<br>
<br>
</span>True, but at that point, you get into hairy points of definitions.<br>
Which of these functions is anonymous?<br>
<br>
def do_stuff(callback): ...<br>
<br>
do_stuff(do_stuff)<br>
do_stuff(lambda: 42)<br>
do_stuff(callback=lambda: 42)<br>
<br>
Obviously do_stuff itself has a name. When you pass it a parameter, it<br>
can access that as "callback", which means the function has been<br>
assigned to a name. Does it cease to be anonymous? What if you use a<br>
keyword argument?<br>
<br>
Within Python, there's a fairly clear definition: if there is<br>
something in the source code which sets the function's __name__<br>
attribute, it's not an anonymous function. So anonymous functions come<br>
from:<br>
<br>
* Lambda expressions, always called "<lambda>"<br>
* Comprehensions/genexps, always called "<listcomp>" etc<br>
* Callable objects that aren't functions (or classes, since those have names)<br>
* Maybe something else that I've forgotten.<br>
<br>
You're absolutely right that a "lambda function" isn't really a thing,<br>
in the same way that Python doesn't have "raw strings" (only "raw<br>
string literals", which are literals which result in perfectly<br>
ordinary strings). But the anonymity of them is a somewhat measurable<br>
feature, even if it isn't very important. The distinction between<br>
"lambda functions" and "def functions" is important to style guides,<br>
but otherwise shouldn't matter.<br>
<br>
ChrisA<br>
<div class="HOEnZb"><div class="h5">______________________________<wbr>_________________<br>
Python-ideas mailing list<br>
<a href="mailto:Python-ideas@python.org">Python-ideas@python.org</a><br>
<a href="https://mail.python.org/mailman/listinfo/python-ideas" rel="noreferrer" target="_blank">https://mail.python.org/<wbr>mailman/listinfo/python-ideas</a><br>
Code of Conduct: <a href="http://python.org/psf/codeofconduct/" rel="noreferrer" target="_blank">http://python.org/psf/<wbr>codeofconduct/</a><br>
</div></div></blockquote></div><br></div>