- 235
- 236 372
Eric Normand
United States
เข้าร่วมเมื่อ 13 ก.ย. 2015
My name is Eric Normand and welcome to my TH-cam channel. I help people learn Clojure and Functional Programming. I have been programming functionally since 2000. Since then, I’ve watched the software industry slowly take notice of Functional Programming. Now it is entering the mainstream through technologies like React, Scala, Clojure, and Elixir. Programmers are discovering it and liking what they find.
CONTACT ME:
Email: eric@lispcast.com
blog: lispcast.com
Business: purelyfunctional.tv
Twitter: @ericnormand
GitHub: @ericnormand
CONTACT ME:
Email: eric@lispcast.com
blog: lispcast.com
Business: purelyfunctional.tv
Twitter: @ericnormand
GitHub: @ericnormand
What, me worry? or Should We Fear Intelligent Machines? - Gerald Jay Sussman
What, me worry? or Should We Fear Intelligent Machines? - Gerald Jay Sussman
มุมมอง: 2 627
วีดีโอ
Code Hibernation and Survivability - George Kierstein
มุมมอง 1622 ปีที่แล้ว
Code Hibernation and Survivability - George Kierstein
apt-get install leiningen - Elana Hashman
มุมมอง 2862 ปีที่แล้ว
apt-get install leiningen - Elana Hashman
Building a World Class (Clojure) Team - Rebecca Kinsella
มุมมอง 3002 ปีที่แล้ว
Building a World Class (Clojure) Team - Rebecca Kinsella
How to Survive the Robots: Professional Development 2.0: A Business Strategy - Kim Crayton
มุมมอง 1302 ปีที่แล้ว
How to Survive the Robots: Professional Development 2.0: A Business Strategy - Kim Crayton
Revenge of the Pragmatists - Baishampayan Ghose
มุมมอง 6122 ปีที่แล้ว
Revenge of the Pragmatists - Baishampayan Ghose
Personal Data Preservation, Inspired by Ancient Writing - Will Byrd
มุมมอง 3172 ปีที่แล้ว
Personal Data Preservation, Inspired by Ancient Writing - Will Byrd
7 Falsehoods Programmers Believe about Place & Time - Emily Ashley
มุมมอง 3212 ปีที่แล้ว
7 Falsehoods Programmers Believe about Place & Time - Emily Ashley
My feelings about static vs dynamic typing
มุมมอง 2.6K2 ปีที่แล้ว
My feelings about static vs dynamic typing
Computer Science as Empirical Inquiry: Symbols and Search
มุมมอง 8773 ปีที่แล้ว
Computer Science as Empirical Inquiry: Symbols and Search
What's the relationship between abstraction and generality?
มุมมอง 7823 ปีที่แล้ว
What's the relationship between abstraction and generality?
On the criteria to be used in decomposing systems into modules
มุมมอง 1.5K3 ปีที่แล้ว
On the criteria to be used in decomposing systems into modules
What is missing from Stratified Design?
มุมมอง 6293 ปีที่แล้ว
What is missing from Stratified Design?
Don't overcomplicate the onion architecture
มุมมอง 2.1K3 ปีที่แล้ว
Don't overcomplicate the onion architecture
Is Haskell the best procedural language?
มุมมอง 2K3 ปีที่แล้ว
Is Haskell the best procedural language?
Could we build Newtonian mechanics on purpose?
มุมมอง 2373 ปีที่แล้ว
Could we build Newtonian mechanics on purpose?
How is domain modeling related to Starbucks?
มุมมอง 3973 ปีที่แล้ว
How is domain modeling related to Starbucks?
You may enjoy The Interconnectedness of Reality: A Hypergraph Model of Downward Causation and Emergence published on Medium.
I have primarily been a Clojure developer for the last 10 years and love the language. That said, the excitement I feel over this version that took 3 years indicates what I have known for 6 years: Clojure is dying. Am sadly using more and more Rust. I think one of the potential revitalizes of Clojure could be ClojureDart, actually. To be smile to create an actual mobile app as well as quite speedy and small executables for Lambdas etc. Is a relief.
Good! i love u! bro this good review!
Comedy!!!
I'm always chuckling at those types of questions: "What is the language good for?" Ha! Somebody wrote a roller coaster simulator in Excel. So, anything is what can be written in the language...
Perfectly relaxing tone, perfect podcast for dog walking and before going to bed. Very good takes btw. I fully agree!
Great book, really enjoying it.
I have a information system project development class and got this assignment, tysm for the explanation.
Its not a problem, it is what it is. You dont complain to a wizard about how they write their spellbook. Imagine a world that every wizard now has to write their spell in a particular way
@Eric. Your videos cover a lot of the questions I have about functional programming. Thanks so much for making these videos
I can't understand the books being recommended. Does anyone understand the names?
The audio is quite bad.
One thing I should have focused more on is how well-designed the new features are. They fit right in. It's a great sign that the Clojure core team values design so much!
At around 17:00 on being able to pass Java methods as functions directly. I think it’s a big deal for beginners. I remember tripping on it and having to ask about it. This new way is much more intuitive.
You might be right! At least the feature is well-designed!
Why would they put so much emphasis on how to write java from clojure? If someone wants to write java he can use java.
@@GerhardM13 That's precisely the why of this. Rich Hickey created Clojure because he didn't like to write Java. Yet the JVM is a wonderful thing and now we have a language to target it that is a joy to use. I can recommend the presentation A History of Clojure to hear Rich Hickey explain this and a lot more of the rationale. th-cam.com/video/nD-QHbRWcoM/w-d-xo.htmlsi=a0C4TGFWmxIquYkd
Thanks. Is it possible then to use new features like "virtual threads" for example from clojure or the language maintainers need to reimplement async package?
Impressive you can do this in one take while driving. You sound just like me talking to my dictation app, but fewer pauses and less rambling.
As soon as you give up the ability to handle time, the language becomes a pain in the ass for practical applications generally. There were Lisp machines and Lisp operating systems with tagged memory.... but x86 and windows just kind of steam rolled because Intel way better at making transistors.
A maintenance disaster is what it is. It has the side effect of deferring naming things, making the code rdundant long chains of copy/pasted transformations. Tacit programming locally is OK but in the large it leads to code that is often missing the "what". Heavy de-structuring and threading macros can destroy Clojure programs quickly. It's a tool, not a religion. The greatest power we have as programmers is linguistic abstraction such that we don't need to keep rewriting the same transformations over and over but can call them by name and recreate their effects in a single line.
Sorry, Eric! Almost unwatchable because of audio cuts repeatedly!
Hi
Very impressive how you reformulated my question much clearer than I asked it. Thank you for answering!
The idea is cool. I’d add a blacklist for known VPN services. Otherwise there will be individuals who will access your site from cheapest countries. If you plan on commercializing this idea, the VPN issue might be a dealbreaker.
If a user is using a VPN can they spoof their actual country? If so, is there a way to detect this? I've seen tv.youtube.com do this kind of detection.
Your audio cuts in and out quite a bit. Seems like your microphone isn't always picking up your voice when first speaking.
Thank you
Thanks again for today!
"And you know how I know how I know that I'll prosper? 'Cause I stand here beside you today" - Ren (from Hi Ren)... about something quite different, but might be relevant here. Lisp is still around some 66 years after its initial creation... will it ever become comparatively popular? I don't know... but I kinda hope it does, and I certainly hope that people (including myself) put time in to collaborating on well-documented, welcoming, rich libraries, etc...
Tune into an exclusive interview with Binance's CEO for a sneak peek into future developments
I appreciate the video but honestly preferring a dynamically typed language is absurd. All of your complaints are that it's not a dependent total type system. So basically if you can't have a Lamborghini you don't buy a car? And for most cases quick check and quickspec get you nearly all the way there. Algebra Driven Design is a book that goes into exactly what you're talking about in haskell. Only accessible book I'm aware of that does and it relies heavily on static typing
Mark Normands brother!
That was such an awesome refactoring. Wonderful that you think out aloud so naturally.
There's a command in Calva for creating a Getting Started Project. It is branded a bit as Getting Started with Clojure, which is the main focus, but it starts with an intro to Calva. FYI.
There's a Paredit “Expand Selection” command which is good for selecting forms in a controlled manner. (Even if you do a good jib with the mouse there, it is much, much quicker to use Expand Selection.) That Getting Started Project has brief intro to Paredit too, even if geared towards people who are not familiar with structural editing at all.
I'd be super happy to jump into a screen sharing with you, Eric, and I can give you a crash course. We could even stream it. =) You know where to find me! /PEZ
At 28:20 you seem to have to fight the editor. You say something about that enter doesn't go to the next line. I've not seen that before. It may be that I have some config that avoids it, but to know that I need to know a bit more about how to reproduce the issue. Not fully following in the video...
I really do not understand what is going on with :item-name coming back all the time. Calva has no keystroke like that. So weird!
Now watched further. Seems it was something about from where the test runner was triggered? I'd love me a copy of that project so I can try reproduce.
What are those things on the walls.
acoustic mufflers. _zero_echo. radio studio quality sound.
thank you for doing these! always useful to see how other people do it. (the tooltip was infuriating me the whole way haha)
Those hovers popping up are driving me nuts!
You can disable the hover popup in VSCode by setting "editor.hover.enabled": false in User Settings JSON.
There's also editor.hover.delay which is set to 300 ms by default. I have set mine to 1300 and it makes things much calmer.
really enjoy watching these 👍
but did the recording cut short for some reason?
regarding degradation, I would remember quality of an item before update, and after update. and if it's decreased after all rules applied, amplify the difference by 2 for conjured items and 1 for normal items.
8:21 - No, ANTLR is NOT a 100% solution to parsing. The fact that it's hard to use is because of all the stuff it leaves unsolved. The complexity of doing that stuff is dumped into every single application that uses ANTLR, making those applications more complex, which reinforces the need to have a giant team to maintain it. Most big frameworks in mainstream languages are 80% solutions or less. True 100% solutoins require a lot of knowledge. You have to know what problems others are running into, and your language has to allow you to solve _all_ the problems, even the ones that users unconsciously just endure without complaining. An example of a 100% solution would be CLOS with the MOP included. Or Common Lisp's condition system. A ton of research went into those. Mainstream solutions are just built ad-hoc using the easiest approach given the tools already available. Then the inevitable limitations are addressed if it's easy to do so. The real curse of Lisp is that since Lisp is so powerful and you only need a few developers, those developers end up being critical to an organization, because they're the equivalent of a big team. Therefore, firing and replacing one of those developers is like laying off an entire department and rebuilding it from the ground up. Clojure escaped the "Curse of Lisp" by being an 80% Lisp. The reason you need all those Java libraries is because Clojure is relatively weak. Common Lisp has pretty good C interop, but it's not used anywhere near as frequently as Java is in Clojure programs.
Are you going to have office hours on the 4th?
I think you make a good point. People seem to (want to) misunderstand what you are actually trying to say.
But it is a silly point. The first part could be true, it might help the compiler to optimize better, though in C you can make cache friendly data structures more easily. Second point seems to forget that there are decades worth of libraries written for C, I would say that every data structure has C library written for it and could be used and the developer wouldn't need to write one himself. This doesn't hold true for Haskell, and mid level developer probably cannot implement random new data structure/algorithm optimally. C probably is harder to write safely than Haskell, but in many ways, it is easier. Also Haskell probably won't be faster on embedded systems etc where you don't have resources to copy stuff. Actually don't know how Haskell would handle things if there is not enough memory and it cannot mutate the data in place. Or if it can, then it really isn't functionally pure language :)
I love Lisp, but it suffers from the same types of problems that Python does. As it scales, it's just too easy to break things with mismatched types, number of arguments, etc... you have to exercise all code paths at runtime to have confidence in it. Compare that to Rust where if it compiles, it typically just works. If I was starting a company that needed to innovate very quickly, I'd use Lisp. But if I was a company that had mission critical systems that must work, but could take a little more time to get there, I'd likely use Rust.
Mission Critical.. ITA Flight scheduling software is written is Common Lisp. JPL uses Lisp extensively.
Thank you for the string concatenation e.g. So much easier to see the motivation behind the distinction between commutativity and associativity with a simple case where one applies and the other doesn’t.
"monoids kick monads' butt" :facepalm:. Does true kick false's butt? Does 42 kick 41's butt? Is > greater-than <?
Hi Eric, FYI, the audio level is quite low compared to other TH-cam content
What’s the link to submit a question? I hope to join soon but have an ongoing scheduling conflict.
It is not part of the video description, but it is mentioned at 6:15 and in the email newsletter:
ericnormand DOT me SLASH office-hours
Clojure is for IQ 130 ppl, Haskell is for IQ 150 ppl...
I am 146, so still in the Clojure bucket. :)
Re: formalizing a domain. That's one of the reason's Ken Iverson created APL. He wanted to use it as a new, more regular notation to teach math. Bonus points that it is executable.
7 months late to the party, this is such a weak argument I figured I’d leave a comment anyways. Comparing Haskell to a university 100 level understanding of C is such a weak argument because the people who write C don’t only have this level of understanding. I don’t know what a monad is but that doesn’t mean I can cast doubt on the fact that serious Haskell users understand monads and when to use them. The same argument can and should be made about C. This guy doesn’t roll his own data structures or import libraries, and just assumed everyone else was doing the same. Either this person is attempting to deceive people who don’t know any better, or they truly don’t understand C development, but either option shows why not to trust this line of thinking.
All the ppl coming from Prime's video apparently can't understand what is being said. Quite literally every single comment by these guys misses the point by a fucking lightyear.
Exactly! Same as Prime in that video. :)