You are such a great professor, can you tell us you name, or Email?
@jazzyBit2 ай бұрын
😮
@aliysher4 ай бұрын
Thank you
@Simple_Guy-2475 ай бұрын
Hello, I have been watching your videos and find them helpful. I am teaching myself all this stuff and you make the topic easy to understand. You have a great channel, and I will be watching more of your videos from the beginning. I am disappointed that KZbin’s algorithm did not recommend your channel sooner. Please keep up the good work!
@zastre7 ай бұрын
Funny -- I use a black background for my macOS terminal and for my Obsidian client, but the white background looks better for your slides. Dunno if that it just me always using default PowerPoint backgrounds in my own work. 🤔
@zastre8 ай бұрын
It feels is little disorienting to me to frame a generator as a stream, but the way `next()` behaves whether on a generator or an actual input stream helps to unify it all in my head. I hadn't made that connection before. Thanks!
@zastre8 ай бұрын
Very clever. I hadn't known about `sys.getrecursionlimit()` and `sys.setrecursionlimit()` let alone `RecursionError`. This kinda/sort metaprogramming in Python is fascinating.
@zastre8 ай бұрын
That's was a helpful overview of the feature, along with the gotchas. You also motivated me to finally figure out how to switch between Python versions on my macOS laptop so I can go back and forth between `3.9` and `3.11` (and any others) without tearing out my hair. I know that `match` isn't a `switch`, but it's close enough to eliminate that weird Guido-asserted absence in the language. I should try to teach pattern matching this fall in CSC 110...
@bzboii9 ай бұрын
idk why but i much prefer the "full" syntax for creating a named tuple class ```python class Foo(typing.NamedTuple): ""Foo class""" bar: float = 0.0 baz: string ```
@ale_on_unix9 ай бұрын
amazing bro!
@ksw85149 ай бұрын
Lazy computation may be a widespread feature of functional languages, but it's definitely not one of the principles of functional programming.
@julians.25978 ай бұрын
It is a direct consequence of the core FP principle of referential transparency, though. the temporal context of function execution is irrelevant, so you can avoid evaluating everything until it's strictly necessary. Or you can precompute it at compile time, whatever floats the boat.
@ksw85148 ай бұрын
@@julians.2597 Exactly, that's why it's a widespread feature, but a consequence is the exact opposite of a principle ;) FP enables lazy computation, but not using it doesn't make it less FP.
@jackbarrett359910 ай бұрын
the dark background is nice!
@glenospace10 ай бұрын
As a KTH student from 2004, Kattis is still alive! Whoho
@dmgerman10 ай бұрын
and the number of its problems keep growing. Great resource. Thanks for your comment.
@CrYpt00110 ай бұрын
print(next(iter(sorted([ {'value':x,'name':y} for x,y in zip(sys.stdin,['Monnei' , 'Fjee','Dolladollabilljoll'])],key = lambda i : i.get('value')))).get('name')) . Joking aside , very nice video
@dmgerman10 ай бұрын
I used to write code like that. Then I could never read it again ;). Thanks for the comment.
@PowderedBonuts10 ай бұрын
I really have enjoyed this series! Thank you for the time and thought you’ve put into it! Question for you: do you find yourself using comprehensions or map/filter/etc more in your projects and why? I appreciated your honesty in the comprehensions video, stating directly that they are the “pythonic” way of doing functional programming. I can’t stop myself from liking map/filter more though. It feels simpler and more powerful somehow.
@dmgerman10 ай бұрын
I came from a Functional programming background, thus I use filter and map. But they are relatively equivalent. For python people, generator comprehensions are more pythonic than filter and map though. Personally, I think it does not matter much, as long as you are using a generator comprehension. I think the difficult part is to get into the habit of stop instantiating lists when it is not necessary. thanks for the comment.
@PowderedBonuts9 ай бұрын
@@dmgerman I had some other thoughts while implementing some of your ideas in a project. I noticed you don’t use type hinting in your videos, any reason for this? I try to use them as much as I can. I noticed the python type system doesn’t really work very well with map/filter. It’s useable, but definitely does not work as seamlessly as my limited experience with Haskell has proven it can be. Another was an observation that you can’t clone generators. I found this while trying to make a function that filters any exceptions from valid objects in a map and returns two separate generators. You can only consume either the valid objects or the errors since the generator is destroyed and they actually point to the same object in memory. It’s made me consider rerouting to list comprehensions so I can keep both. There may be another way that I haven’t found yet to keep both though, just noting a limitation.
@CrYpt00110 ай бұрын
By far the best python feature
@calvinkhor89010 ай бұрын
thoughts on EntilZha/PyFunctional and kachayev/fn.py for nicer notation?
@dmgerman10 ай бұрын
I think both are good projects with different goals in mind. For instance, EntilZha/PyFunctional is very Scala-like (which I like very much). I haven't used either one, but I think there is always a small risk of bringing new non-standard dependencies to a project. But if you (and others maintaining your code) like one of them, why not? I might dedicate a video in the future to each library (kind of intermediate level). thank you for your comment.
@VincentSchumaker10 ай бұрын
Dark theme, yes!
@dmgerman10 ай бұрын
While I prefer to write code in white background, I can see the appeal to have a dark one while watching a video. Thanks for the comment.
@airatvaliullin842010 ай бұрын
and also you can run recursive fibonacci using lambdas and a valrus operator :)
@dmgerman10 ай бұрын
The idea, correct me if I am wrong, would be to create a lambda inside the lambda and give the inside lambda a name (so it is no longer anonymous) and then call this lambda. Probably very unreadable code.It might be an interesting video to try to understand how closures work.
@airatvaliullin842010 ай бұрын
@@dmgerman not exactly, but you're completely right that it would be unreadable. So, you give a name to the outer lambda function and then use this name inside of that same lambda: >>>(fib:=(lambda n: n if n in {1, 2} else fib(n-1) + fib(n-2)))(9) 55
@dmgerman10 ай бұрын
wow. I really need to read the semantics of :=. It means that fib is created _before_ the right hand side is computed, which is very different than a typical assignment (e.g. fib= ...) , where the left side exists only after the right hand side is evaluated. I appreciate you took the time to share it.
@airatvaliullin842010 ай бұрын
@@dmgerman indeed, quite a peculiar sematic. sure, thanks for your content!
@jen2449910 ай бұрын
And you actually can create variables in lambdas using valrus like this -> 'x = lambda: (c:= 22) and (lambda: c * 20)' and then run it like x()() or 'x = lambda: (c:= 22) and (lambda inp: inp * 20)(c)' and then run like x()
@dmgerman10 ай бұрын
this made me laugh 😂 a lambda within a lambda! Thanks for sharing.
@zastre10 ай бұрын
I luuuuuuuuuv named tuples.
@hriscuvalerica481410 ай бұрын
Looks nice ! When you are a bit further in the series i would like a video where you solve a couple of problems using the functional approach .
@dmgerman10 ай бұрын
Yes, that is the idea. If you have any suggestions for problems to solve, let me know.
@julians.259710 ай бұрын
@@dmgermansomething like a small webserver with sqlite or a text file transformation CLI, maybe CSV -> JSON
@_iltax440010 ай бұрын
Great video, straight to the point and easy to follow. Keep it up!
@dmgerman10 ай бұрын
thank you for the feedback.
@luckyluc997210 ай бұрын
Are tuples with 3 values always called tuplets? That was my first time hearing it, and it was adorable
@dmgerman10 ай бұрын
Yeah, I keep making those mistakes. Thank you for the comment.
@luckyluc997210 ай бұрын
@@dmgerman I will forever call tuples with 3 values a tuplet.
@hriscuvalerica481410 ай бұрын
Yeah . Using recursion is kind of a pain in python . Basically i only use it to traverse shallow trees where i know the depth beforehand .
@mcuria10 ай бұрын
1000 of depth is not a shallow tree, consider using a balanced tree for such cases.
@hriscuvalerica481410 ай бұрын
I never said it was . The important this is knowing the depth because raising the limit is a hack
@VincentSchumaker10 ай бұрын
Love the use of org-mode; not a huge fan of the light theme, though.
@dmgerman10 ай бұрын
Thank you for the feedback. I have been considering using a dark mode. I just need to find one that I like.
@Pastellsdj10 ай бұрын
Interesting series. Keep it up!
@hriscuvalerica481410 ай бұрын
This is excellent . I appreciate this very much .
@ilan05410 ай бұрын
Sounds awesome, thank you!
@TheBambooooooooo10 ай бұрын
Dicts not matching exactly arguments is not necessary if function itself has something like **kwargs
@dmgerman10 ай бұрын
True. I'll leave that for the advanced videos. Thanks for pointing that out.
@vorsprungdurchhektik117010 ай бұрын
looking forward to this
@TheBambooooooooo10 ай бұрын
Same
@randomsearches36910 ай бұрын
wonderful man!
@HarrisMiller-hl5lc11 ай бұрын
I was following until the part you created fill or ask to go to bright space, I have prelude working but not sml, please help
@Xboyplays Жыл бұрын
After watching this video, I still do not understand what is good about 3NF
@Xboyplays Жыл бұрын
Is it just for error prevention?
@Xboyplays Жыл бұрын
3NF & BCNF help reduce updating errors. BCNF does so at a lower duplication cost than 3NF
@alyssafoglia6352 Жыл бұрын
this is so helpful thank you
@Xboyplays Жыл бұрын
At 8:42, what is a doable ?
@Xboyplays Жыл бұрын
First
@willing_to_learn Жыл бұрын
Are you planning to support multiple dicts, and in particular support loading yomichan-style dicts? Probably not that difficult given than yomichan-import exists but idk for sure since I haven't tried. There are just so many very useful yomichan dicts that basically any future JP dict program is going to have to support at least parsing them to see much adoption tbh.
@dmgerman Жыл бұрын
Currently Yomikun only has basic definitions for words (at most one line) that are used for the automatic popups. For the actual dictionary lookups, it uses an external program (currently myougiden); such program is the one that needs to be able to use other dictionaries. It would be easy to add support for other programs (having more than one dictionary backend), but so far, myougiden has been good enough.
@moongihong2794 Жыл бұрын
impressive
@cameroncarter33322 жыл бұрын
Thank you. I can't believe I downloaded a file randomly from a youtuber online but it worked. Lets hope its not a virus. What do you do for a living?
@yesitskush2 жыл бұрын
He is our professor at University of Victoria! Very intelligent ofc.
@DefinitelyNotAMachineCultist3 жыл бұрын
Wonder how stuff like org-roam and emacs-jupyter might fit into a framework like this.