"Perfection is achieved not when there is nothing left to add, but when there is nothing left to take away." - Antoine de Saint-Exupery
@horusfalcon4 жыл бұрын
So that's why this Antoine guy was always taking things! Why, just the other day he stole my lunch! (Admittedly, my lunch was somewhat less than perfect.)
@nik45204 жыл бұрын
Time for assembly
@sorvex93 жыл бұрын
“If you achieve perfection, then something is wrong”
@zyansheep3 жыл бұрын
@@nik4520 assembly is a dsl
@chrisE8153 жыл бұрын
They clearly never designed a European automobile
@sandywyper4 жыл бұрын
This is the weirdest episode of Star Trek I've ever seen.
@QuadHealer4 жыл бұрын
LOL! I read your comment before seeing the whole video, and I was confused, but after having seen the video, I must agree :-) But does it not go beyond just Star Trek - I mean isn't it a sonic screwdriver from Doctor Who at one point? Or am I mistaken? In any case, thank you for making me laugh!
@EvenStarLoveAnanda4 жыл бұрын
I know, the ray-gun was a dead giveaway. ;0)
@shawno664 жыл бұрын
This is the funniest YT post I've even seen. I now just say that randomly.
@Skeeve-Magick4 жыл бұрын
@@QuadHealer isn't there also Indiana Jones and Dallas referenced?
@blahuhm67824 жыл бұрын
*best episode of Star Trek
@Pariatech4 жыл бұрын
17min in and still engaged! You have a nice way to entertain and inform that is pretty rare in the IT field.
@anthonyb91472 жыл бұрын
went through the whole hour and didnt even notice it went by. He is great at public speaking.
@spookypen4 жыл бұрын
The YT algorithm brought me here, staying for the whole thing. I don't know how to program a computer at all.
@diamondtroller12534 жыл бұрын
rip
@excitedbox57054 жыл бұрын
Never too late to better yourself ;D
@adamnealis4 жыл бұрын
Before I watched this, I thought I had at least a basic idea as to how to programme a computer.
@dewinchy4 жыл бұрын
That is what I call a tough guy!
@jomar_macedo4 жыл бұрын
Almost same thing here, but i've already done some poorly executed working software in college. Not that it made me understand anything here any better, but i'm going for the whole thing.
@makinggreatbread4 жыл бұрын
Entertaining. I started programming in 73 (Cobol, Fortran, RPG, Assembly, machine) and haven't given those days much thought until watching this. A trip back in time. Loved it!
@idiosinkrazijske.rutine4 жыл бұрын
Damn, guys from the '50s were smart.
@franciscogerardohernandezr47884 жыл бұрын
They had dreams of time travel and spaceships, but then the 70s drugs and the left relegated all these goals to fiction.
@normanhenderson73004 жыл бұрын
francisco gerardo hernandez rivera , we’re not some of them under the influence, and were practicing leftist- or actual leftist? This did not necessarily negate the power of analysis in these matters. Although I would not suggest being under the influence of LSD, weed(lab grown especially), and such things. Cocaine, methamphetamines.
@franciscogerardohernandezr47884 жыл бұрын
@@normanhenderson7300 Not only drugs, but day to day financial stress steer people's mind away from noble ventures.
@PflanzenChirurg4 жыл бұрын
@@franciscogerardohernandezr4788 it turns out what u own, owns u :)
@winstonsmith774 жыл бұрын
Not all Boomers are bad
@joerogers42274 жыл бұрын
I am now almost 80. I have a 4 year degree from San Diego State University in Office automation. During my time from 1981 to 1989 when I graduated at age 47 I studied through Jr. College and SDSU many languages. Basic, Cobol 2 semesters, Fortran, Prolog which at the time was called a fuzzy language, RPG II also. My biggest project was programming in Dbase III and iv. I wrote a labor accounting program for Public Works Department on Miramar Naval air station. (NAS). We compiled with clipper and it could go onto a floppy disk. I like that program because it had clear steps and modules I created to do the job. I did my best to not use what we called spaghetti code or jumps all over the place. Through my career I met people who were involved in the computer world as Pioneer's. One was Dr. Hershey and his specialty was fortran and he developed the Hershey fonts. I also meet Dr. Hamming the developer of the hamming code for forward correction of transmitted data. Dr. Hershey was retired from Naval postgraduate School, the Dr. Hamming was a professor there. I like programming in Dbase IV but diskiked working with Prolog as it was not as structured. I remember when I was at Mesa jr. College in San Diego I got one night at 2:00 am and worked remotely on my Cobol program and I got a return message from a tech there asking if I ever Slept.
@ericpmoss4 жыл бұрын
Grumpy Lisp programmer here... Common Lisp "won't die" because it's extensible and multi-paradigm, and not driven by super-cool, super-pure solutions to toy problems. There should be a way to (a) write a leveled Lisp where things like garbage collection are optional, and layered on top of simpler layers, (b) make a processing architecture that lends itself to it, such as cdr-coded caching; (c) pull some of the commercially driven, non-Lispy clutter out of it, and (d) put some big-time effort into improving the compilers and interpreters. For the price of a single stealth bomber, we could do some beautiful things.
@derekfrost89914 жыл бұрын
I love lisp, I use it for my personal accounts etc.. :)
@UNR3S74 жыл бұрын
lisp is eternal for the same reason as emacs. You put all the things into one thing, and have a good foundation at the very core of the thing. And you let people do whatever they want with it. If you have a good foundation all customization leads to realizing the good way. I think that the biggest mistake is assuming that people are not smart enough to realize the good. "you shall not rebind because our bindings are good" well, if you rebind and the original bindings were good then you will realize your mistake eventually. "you shall not assign because it is not pure" well, let them assign and suffer the consequences. Lack of confidence in the foundation is what leads people to restrict branching. (and some business reasons, but business will ruin everything)
@dejohnny24 жыл бұрын
I like Dr Racket.
@rmsci40024 жыл бұрын
Clojure already exists, runs on JVM, CLR. Can be compiled to JavaScript via ClojureScript. Next step is it running on LLVM. GRAAL compiler can help this. Common Lisp is missing this independence/interdependence, VM, etc.
@vinapocalypse5 ай бұрын
@@rmsci4002 Common Lisp does not prescribe which platform it should be implemented on. If you want CL on the JVM there's Armed Bear Common Lisp, but the implementations which compile to machine code are extremely effective at doing so. SBCL compiles forms directly to machine code so you can incrementally develop and compile a function at a time and come out at the end with very fast dynamic Common Lisp Common Lisp is out there and being used, it's just waiting for the rest of the world to catch up
@bjornkihlberg21034 жыл бұрын
If we decide to choose "one language", we're going to find ourselves stuck with the popular option, not the right option.
@rubenb86534 жыл бұрын
ooof this comment needs likes. this is totally true.
@insertoyouroemail4 жыл бұрын
Mr. Martin thinks it's going to be Clojure. It's not going to be Clojure. Sorry but if I'm told I have to use an untyped language, me (and many others) will simply take our ball and go home. The idea of the previous generation having picked a language for me to use today is frankly repulsive. I wouldn't want to impose my ideals on future generations like that.
@rubenb86534 жыл бұрын
@@insertoyouroemail yahh but its probably going to be very subjective anyway. I like C for example. gets a lot of hate.
@excitedbox57054 жыл бұрын
@@rubenb8653 C is a great language from the syntax but the feature set is very limited. If C++ had C syntax I would be soooo happy. I hate :: I think it ruins the look and conveys 0 meaning. Like -> or > or even . give you a hint at these things being related. Function syntax with (arg1, arg2) conveys meaning. In C# < > looks aggressive and is pointing away from your objects. _Keyword conveys that there is something that belongs to that. These types of syntax structures are important to make sense even when you know the language so you don't have to think and it makes the code flow much easier. If I told you from now on ? was to be used as a comma and = as a period every time you used them you would have to dedicate thought to that just like a door that you instinctively want to open the wrong way.
@paulzheng76634 жыл бұрын
@@insertoyouroemail You use fiat currency, drive a car on roads, work a job for fiat, go to your doctor to be prescribed poisons, eat food that lacks nutrition, believe what the goverenment wants you to believe .... We have been imposed on. what should we do? WHat will you do?
@CubOfJudahsLion4 жыл бұрын
Aside from constraints, some paradigms *did* add something. The functional, for example, came with pattern matching and unification, lambdas (aka anonymous functions) and functions as first-class citizens. The logical paradigm (aside from using matching and unification as well) also adds backtracking and domain-constrained searches. While non-imperative languages may seem academical, the truth is that some of those features of other languages have found a place in mainstream programming, and there are plenty of books about programming "functionally" in C#, JavaScript, Python, etc. It's more likely that we'll build an eclectic future rather than a strictly-imperative one.
@aoeu256 Жыл бұрын
I can think of many more paradigms that delete things: total functions (functions must terminate), reversable programming (all functions must be reversable via always returning their input as well as their output), concurrency paradigms, linear types preventing you from duplicating vars, constraint based programming, etc...
@RayDrouillard4 жыл бұрын
Twenty-two orders of magnitude more power. What did we do with that power? Argue with strangers, look at pictures of cats, and pr0n.
@qwerty133804 жыл бұрын
Have you been looking in my windows?
@puppetsock4 жыл бұрын
That is true. Also, much that is plainly trivial or drab. Every episode of Giligan's Island, The Love Boat, MASH, and uncountable hours of discussion of them. Makeup tutorials. ASMR. But also there are: - Google maps - Many many thousands of hours of university lectures on line - Many many thousands of hours of quality entertainment such as symphonies, Shakespeare, etc., on line - Live web-cams of a family of falcolns that lives on an office tower in downtown Toronto - Computer language translation that, while laughably imperfect, can be useful to language learners - Downloadable classic books for free - Downloadable new books as cheap as reasonably achievable and fast - The possibility of learn at home and work at home for a significant fraction of the population Humans do a wide range of activities from the horrible to the exemplary, from the drab to the intense, from the forgettable to the unforgettable. And we starting to do this all on line.
@mihailmilev99094 жыл бұрын
@@puppetsock well said fellow human
@clieding4 жыл бұрын
This is painfully funny as I am also guilty of often squandering this awesome resource by: “arguing with strangers, sharing pictures of cats, and looking at porn.” - trained computer programmer.
@ShainAndrews4 жыл бұрын
Adding pet raccoons and foxes. Your comment is two weeks old, we acquired additional resources since then to support it.
@Ed644 жыл бұрын
I love the Commodore 64 showing up at minute “42”. Awesome talk as usual, Uncle Bob!
@ww15934 жыл бұрын
If this guy was my teacher in High School, I would've chosen a career in Computer Science 12 years ago ! Better late than never.
@nick183034 жыл бұрын
Misael d.w I’m 32 and just started learning this year and I too would have loved him as a teacher but atleast we have him now
@ww15934 жыл бұрын
@@nick18303 the power of the internet and youtube !
@terrythompson75354 жыл бұрын
You gotta love the way this guy talks. He's so excited and optimistic. You can tell he's very passionate
@terrythompson75354 жыл бұрын
@Peter Mortensen The science does not back that up. Now people who understand the release of dopamine and how it aids memory are saying that making the learning more entertaining results in people learning faster.
@ww15934 жыл бұрын
@Peter Mortensen I agree with you but the reason why I made this comment is also becaude of his breath of knowledge. He is the perfect balance in my opinion. Most CS channels are simply career youtubers that what to be celebrities.
@tomrkba46854 жыл бұрын
"What have we done with that power?" CAT VIDEOS!
@TheNortonio4 жыл бұрын
Grand Theft Auto, Minecraft, Fortnite... sad to say. The cat videos are pretty cool though. Have you seen the cat vs cucumber videos? Awesome!
@arnox45544 жыл бұрын
A worthy use of power.
@strictnonconformist73694 жыл бұрын
According to a Seagate CEO, you forgot porn.
@TheNortonio4 жыл бұрын
Strict NonConformist anathema!!!
@lkledu24 жыл бұрын
whole data center and infra structure of google to put nyancat 10h (i believe in the day we can do a live for a month only with it)
@MotiviqueStudio4 жыл бұрын
Zen and the art of disdain for everything. Sometimes "we" want a proprietary language for "our" own reasons. So there's a lot that has to happen to get to where a last language is a discussion. Goto line 1
@monkfoobar4 жыл бұрын
I met a guy who fixed his motorcycle using the pull top from a beer can.
@jakykong4 жыл бұрын
Yeah, I think his argument is fundamentally based on the flawed premise that any general purpose language actually could encompass everything in real life (as opposed to theoretically). Even if you look in the algol-inspired family (of which C is a member - for someone going as far back as PDP-11's, I'm surprised he didn't mention algol. :P ), they express different concepts preferentially. For example, if the problem you're solving is in a domain that is cleanly solved by arrays, you're way better off writing it in Python than in Java. On the other hand, if the problem you're trying to solve is large-scale collaboration, Java has the rigorous type system to enforce contracts, so even though you'll be doing more array fiddling by hand (instead of being expressive with comprehensions and slicing), you can coordinate more developers since the boundaries and interfaces are less fuzzy. Clojure is interesting, for much the same reason most Lisp-family languages are (I'm pretty fluent in Common Lisp); they're good at metaprogramming. That is _why_ they are capable of doing pretty much everything: Nobody writes code in "pure" unadulterated Lisp. They write macros that write code in "pure" Lisp. And those macros are used to define subset languages much more akin to each of the various paradigm languages.
@absalomdraconis3 жыл бұрын
@@jakykong : You arguably could make his "last programming language", but you'd have to reject his own rejection of assembly. Ultimately, the "last language" that he speaks of would be more naturally a derivative of Forth than of Lisp.
@billbez74654 жыл бұрын
Wow, this is classic. I've been a language junkie for years (actually, a couple decades), and Bob describes this more informative and interesting than I've heard for a long time.
@brawndo87264 жыл бұрын
43:29 The Dark Knight Falls
@PatriceStoessel4 жыл бұрын
seems to fall asleep
@brawndo87264 жыл бұрын
@@PatriceStoessel lol
@mikhailpopovic17054 жыл бұрын
his central nervous system has capitulated ... I feel suddenly to be a flying rodent
@Rebel1014 жыл бұрын
Lol
@darnell88974 жыл бұрын
Why do we fall, Bruce?
@this-abledtheextravertedhe52994 жыл бұрын
I’m 50 years old and learning something other than DOS for the first time since 1989 🤣 I choose Python for many of the reasons you listed. I’m off to explore Lisp and Closure. Thank you 😊
@Evan490BC4 жыл бұрын
*Clojure
@Collaborologist2 жыл бұрын
how you getting along with Clj?
@lfmtube4 жыл бұрын
I watched you video with great interest. Thank you for posting it. I used to work in Argentina with a PDP 11/04 with RT11 operating system. The CPU had 4K memory, an LA34 teleprinter with paper tape and a vt100 terminal. Over 40 years later, I still remember those great days. :) I was 19 years old and working reading magnetic tapes from mainframes and converting into Microfiches as a replacement for the huges printed lists that were generated in those days. All this at an speed of 36 thousand records per minute. It still amazes me how we could do all of that with such limited resources.
@alastairbowie4 жыл бұрын
I've had a growing interest in Common Lisp as of late. The metaprogramming aspects of Lisp is quite interesting to me. I also like the minimal syntax and how it feels like quite an expressive language. I've been writing a text based game using a Common Lisp REPL smartphone app I found which has been pretty enjoyable. Cool vid.
@karenparker30864 жыл бұрын
A lot of this reminds me of physics circa-1880 or so. Physicists were seriously discussing the possibility that there was no more new physics to discover, just applications of existing stuff and engineering. Then along about 1890-95 X-rays and radioactivity were discovered, setting off a wild ride of new discovery that we’re still on to this day. Don’t be too quick to assert that there’s nothing new under the sun, in any field.
@dontworrybehappy51394 жыл бұрын
The new stuff, in my opinion, will be the computer programs doing the programming.
@normanhenderson73004 жыл бұрын
Don't Worry Be Happy , I dabbled in that idea, when I was introduced to the art. I am sure the more sophisticated programmers can accomplish that.
@rmsci40024 жыл бұрын
Those were part of it, but it was the ultraviolet catastrophe leading up to quantum physics that pushed the envelope.
@rmsci40024 жыл бұрын
@@dontworrybehappy5139 that is an old idea... from Lisp.
@dontworrybehappy51394 жыл бұрын
@@rmsci4002 It is a problem that just hasn't been attacked with vigor yet. I've worked in the field of computer programming for decades, and I would guess that 95% of the code being written today could easily be generated by intelligent software created in the very near future. The hardest part of the software would be the interface code that had to interface with and gather the requirements from the project managers (ha ha).
@TuringTest374 жыл бұрын
Check out Julia. It has light-weight syntax, is fully homoiconic, compiles on the fly using LLVM down to optimal machine code, interfaces easily with C, Java, R, Fortran and others. And speed? Within 10-20% of compiled C. Often 20 times faster than python for the same numerical problem.
@galtbarber26402 жыл бұрын
Python is way slow, even perl is much faster that python while still being slow.
@robrick93614 жыл бұрын
This is like the opposite of dementia.
@larrydillard81634 жыл бұрын
My thought exactly. If you are short on time, he takes the gloves off at 33:20 - and it gets more fun.
@reallylordofnothing9 ай бұрын
This comment is gold
@shableep4 жыл бұрын
44:11 WebAssembly and WASI are the thin layer virtual machine that abstracts the hardware layer (or, "host" as they put it), and almost any language can be compiled to it. All the languages can communicate to each other via WASI. It's a thin virtual machine that invites whatever language that compiles to it to bring their own runtime code if needed. Though it was designed for the web, it was the web that created the excuse for multiple mega corporations to cooperate with each other to agree on a standard language to compile to that would bring more native-like processing power to web apps. That technology is now getting adopted server side, and for many other environments outside of the web browser. It's really exciting technology and I think you should look into it if you haven't already.
@RuslanKovtun10 ай бұрын
Yeah, I'm also waiting for WebAssembly to mature. But I really sold on the point that the code is the data and the data is the code. We should definitely be able to modify the code on the fly (you can remember all sorts of macros running at compile time in rust, jai, nim, etc.). The problem is that programs aren't compilers and they can't produce code other than at compile time. Although, I guess Uncle Bob did logical mistake when he was talking about permissive languages and how unpopular they are and then assumed that the perfect language is permissive.
@Dmytro-kt3fr2 жыл бұрын
Astonishing video, terrific analysis on the programming, definitely went to a saved videos. Most of us did lost a track of what paradigms and languages are, drowning in the frameworks and tech choice but forgetting the basic ideas behind everything. Will need to prep a "ted talk" in my company covering the things cover by Robert
@benjaminmelikant34604 жыл бұрын
Warning: text wall incoming Reflecting on the idea that we "need to pick a language and all decide to use it across the entire domain", I ended up with a few thoughts. Bob mentions biology, chemistry, mathematics, and others as domains where representation of information was eventually boiled down to a single representation rather than many representations. I see two issues with this. The first is that, even within these disciplines, I don't believe that to be 100% true. I can't speak much of most of these domains, but mathematics is an interesting case in my opinion. Certainly the notation of information for calculus is much different than the notation for basic arithmetic. Yes, calculus builds on basic arithmetic, but most people wouldn't understand a geometric, algebraic, trigonometric, or calculus formula simply by knowing the basic arithmetic operations. There are different representations in each sub-domain because each sub-domain has a unique goal in mind. And this is where my second point comes in. There are so many languages within the sphere of computer science because there are so many different things to express. I have seen it in other comments already, but I think most software developers will realize that the base language requirements for something like a game engine or a real-time embedded OS are much different than the requirements for a web UI. They are all within the domain of software development / computer science of course, but they are all unique sub-domains within that domain. I would argue that there is no such thing as a true "general-purpose" language; that is, that no single language is perfect for all programming tasks; rather, most langauges are, to one degree or another, domain-specific or specialized languages. If we all sat down and decided "okay, our one and only programming language is going to be a virtual machine language" for instance, in what language do we write the virtual machine? We would, at best, need two implementations of the same language; one targeting bare metal so that we could write a VM layer on top of the hardware (or at least a bootstrapper of sorts), then the language itself with its runtime within the virtual machine. The option would exist to move the virtual machine into hardware, but that only moves the problem of needing a "bare-metal" language to the domain of hardware development, it doesn't eliminate the issue. Furthermore, hardware-based language abstraction makes it impossible to harness the raw power of the hardware when you need it; you are throwing out the potential to utilize hardware to its fullest, unless your language does allow bare access to the hardware, in which case I would ask what differentiates this language from something like C, which can be used to write high-level software, but can be mixed with assembly to access hardware features that you may not otherwise be able to access? True, it isn't exactly the same, but I feel like it violates the concept you are going for. Certainly you couldn't do this in an ultra simplistic syntax language. I understand where you are coming from; if we could worry less about such and such language playing nice with this other language and reading source code would be simple because we all just know the same language, we could in some way eliminate issues with compatibility and such, but this is how I see the other side of that coin I guess. I enjoyed the talk a great deal and don't want to take anything away from it. This is just my "other side of the fence" perspective on this issue.
@bertvanbrakel4 жыл бұрын
I think we need to make it easier to be more compatible. Our toolchains should probably align more. Look at the state of dependency management. There are so many different tools to do it, and so many ways it's implemented, however at it's core it's a rather simple problem. Either we can come up with a single component to do this and have it customisable per problem requirement, or we break it down into smaller parts and allow easier ways to interface multiple dependency tools in a sane way After decades of programming, I'm still finding one has to cobble together a bunch of random stuff and scripts to make things work together. It shouldn't be such a PITA. There are common themes across all the languages and tools I've come across, and it's always seemed stupid different software tribes just end up reinventing the wheel
@absalomdraconis3 жыл бұрын
@@bertvanbrakel : The problem with dependency management is that you need to embrace the idea of multiple sources providing the same resource, which you then have to score so that you can choose between them, and potentially even cause a recompilation storm as your newly installed program or code provides some component that allows the other components which it depends on to themselves provide additional components- people rarely want to deal with this, including the people that should be writing the supporting tools. Among other things, it's naturally a logic language field, and the only things folks are normally aware of in that field are the oft-neglected Make and Prolog.
@absalomdraconis3 жыл бұрын
A "last language" could probably be created, but it would fundamentally go against his rejection of machine code. In fact, at the end of the day it would probably be more of a Forth than his beloved Lisp variants.
@0xggbrnr4 жыл бұрын
“But, the materials we manipulate with our hands, the code, is virtually the same...” *Uncle Bob enters the Matrix suddenly and starts listing programming languages* 😂
@qualia7654 жыл бұрын
After a bit of though, _I think_ that: 0) This is a very good video that I enjoyed a lot 1) I'm not so sure it will conform on one, but if it does then it will be a very big language in the sense that it can both handle the fine details and complicated stuff as well as assembly, but also the big overview of things as well as python 2) I think that the future is heading in more of a direction of increased usage of multithreading, not as a limit, but as something that is already needed. Due to the increase in neural networks and 3d graphics and undoubtedly others. 3) The syntax will be straight forward, it will run very fast, and running modification. 4) Maily most of the things mentioned in the video should be true, except they can be bypassed so that more hardware-level stuff can happen. So very very hybrid of all things. 5) It will be a textual language. (Although I will still advocate for the graphical programming of textual language.) So thos're my opinions with my limited knowledge.
@solidstate03 жыл бұрын
22 orders of magnitude and humans still urinate in telephone boxes
@m.p.jallan21724 жыл бұрын
Fascinating thanks. Prof D.Brailsford on the Computerfile series once said that the current low level binary/instruction set design is not likely to change much, already being the smallest way to convey information.
@homelessrobot4 жыл бұрын
The observation that paradigms are subtractive does not suggest that new paradigms are always subtracting from the semantic space of the immediately previous generation. You can always go as far back in the stack of historical restrictions as you want to establish a new set. And construction is entirely subtractive anyhow. Constructing a mathematical theorem, you are eliminating all other possible/valid constructions in the theory to say/prove something specific. Constucting a theory, you start with axioms/suppositions who's function is to 'subtract possible preconditions'. When you write a program, you are subtracting from 'the set of all possible programs'.
@kevinfredericks23354 жыл бұрын
"time runs in a single direction" Quantum Engineers: hold my beer
@Dystisis4 жыл бұрын
The idea of time having a direction is a confusion based on a metaphor. Time is also not a dimension or a medium.
@cybervigilante4 жыл бұрын
The purpose of time is to make sure you can't unscramble eggs.
@Kasas904 жыл бұрын
S = k ln ( Omega ). Here you go
@stefanhensel86114 жыл бұрын
@@cybervigilante Time is the way of the universe to make sure not everything happens at once. And space is the way of the universe to make sure not everything happens to you.
@LaughingOrange4 жыл бұрын
He said dimension, which to my understanding is true even in quantum mechanics.
@DieterGribnitz4 жыл бұрын
Wow, this is the first time I ever heard the specs of a macbook read aloud that seems impressive with a reasonable price point. Turns out the trick is to compare it to a 3 or 4 decades old machine.
@BattousaiHBr4 жыл бұрын
also, he VASTLY underweighted the CPU performance since he assumed the same IPC (instructions per clock). modern hardware is leaps and bounds faster than decades old hardware even when running at the same frequency.
@Joel-mp2oo4 жыл бұрын
One main thing I take away from this, is I really need to start learning LISP... Oh and we all need to unite ! 😁
@AndersJackson4 жыл бұрын
Start using Emacs, and you are running a REPL with lisp, that have an editor you can configure with Lisp. Then take a look at Magit and Org-mode with literal programming with Babel-mode (extension of Org-mode).
@Collaborologist4 жыл бұрын
Clojure
@Evan490BC4 жыл бұрын
@@Collaborologist Or Scheme/Racket.
@horusfalcon4 жыл бұрын
A great deal of the programming done to control real-world inputs and outputs is symbolic in nature, built in the form of a ladder logic diagram that uses symbols geared originally to be understandable by electricians and instrument technicians. A lot of these symbols are graphical, and their interconnect is very often expressed graphically. This was an interesting "keynote".
@DanielBos4 жыл бұрын
Yay Forth! I've worked with a lot of niche language, but Forth was the one that blew my mind.
@Mark.Brindle4 жыл бұрын
Used it commercially from 82 to 85. Loved it. These days, I would treat it as a high level assembler.
@DaveRoberts3084 жыл бұрын
Every programmer needs to wrap their head around both Forth and Lisp. Once you do, you’ll really understand some profound truths about the nature of computation.
@DanielBos4 жыл бұрын
@@DaveRoberts308 Haven't used Lisp itself much, but I did write in a Scheme dialect commercially for a few years. call/cc (call-with-current-continuation) is another eye-opener that can fundamentally change your understanding, once you grasp what it does.
@DaveRoberts3084 жыл бұрын
@@DanielBos Yep, agreed.
@ThePandaGuitar4 жыл бұрын
Dave Roberts Used LISP for years. what profound truths, stop circle jerking. It’s just a stack snapshot. Heck even Ruby has continuations.
@Blink_____4 жыл бұрын
The point of the "hot new thing" being decades old is kind of striking, when you consider other aspects of our culture. For the past decade "retro" has been a big boom. Movies and Vinyl especially. To a lesser extent fashion has been coming around too, and I'm pretty sure we are gonna start seeing coke bottle glasses again before the 2030s hits.
@rmsci40024 жыл бұрын
Has nothing to do with it being retro. It is because it was based on solid mathematical principles. Those don't wear out.
@rudyardkipling45174 жыл бұрын
sounds about right, the hot new thing would be in her 20s :p
@espenskeys4 жыл бұрын
The code is the data - the data is the code - we used to call that "speed programming" in the Scandinavian Demoscene back in the day
@mattsimon41674 жыл бұрын
For a good example of graphical/module there is Verilog and VHDL and it can program FPGAs. though they are both electronic and domain specific, and progress there is being focused on abstracting the graphical to traditional text language.
@jrherita Жыл бұрын
I’m more of a hardware guy with some bouts of programming since the early 1980s.. this is an amazing video and take on languages!
@Radioposting4 жыл бұрын
The fly in the ointment of language theory and practicality could be GTP-3 (Open AI). GTP-3 boasts to write code based on natural language explanations fed to the AI by non-programmers. Do we really want mid-level corporate managers writing code? In the words of Lt. Uhura (Star Trek III), "Be careful what you wish for... You may get it."
@lfmtube4 жыл бұрын
I think the path will be in the direction of business specialists writing their own procedures using low-code based services. And true high-level developers are going to write the microservices or modules to use as the basis for those procedures.
@Radioposting4 жыл бұрын
@@lfmtube Maybe the new model will be similar to airline pilots. Other than takeoff and landing, they really don't do much other than supervising the flight computer.
@johnaweiss4 жыл бұрын
"Do we really want mid-level corporate managers writing code?" No, we want all humans writing code.
@Rfc13943 жыл бұрын
At about 8:30 is the statement, "I'm not at all convinced that there are any more surprising languages out there." Reminds me of the (probably apocryphal) story of the U.S. Commissioner of Patents who thought there won't be a need for the Patent Office in the future because everything that could be invented has already been, back in the 1890s. We have no idea what revolutionary change we can't even imagine is coming along that will completely blindside us (in a good way.)
@jondor6549 ай бұрын
Perhaps ironic. , notice the playdough .
@bloguetronica4 жыл бұрын
Props to this man. Thanks to his lecture on clean code, I managed to review a code I've written, break every long function into its components, and now my program improved substantially. I'll apply these principles in the future. They made the code far more readable and maintainable.
@nycfpv3 жыл бұрын
IMO single responsibility is the key to building good software. If you follow anything, follow this.
@abj1364 жыл бұрын
You missed a major paradigm, that of Excel. It removes the decision of what to update and keeps everything consistent for you. Many programming languages have been developed based on this, though nothing mainstream that I’m aware of.
@TAHeap2 жыл бұрын
@@Alex-wk1jv "Excel would be declarative functional logic programming" Weeel ... not really! At least not in a usable way. Now, if you were to add lambdas/binding and some explicit syntax for array formulae, then it might be getting there...
@josephmeditz79564 жыл бұрын
Great talk! Interesting, informative, clear and succinct. Who is this fellow?
@ffggddss4 жыл бұрын
The only language I've encountered that I didn't hear him mention, is Ada. Or did he, and I missed it? "Anybody remember core [memory]?" Yes! And while I can't say I remember this, my dad related to me a time *_before_* there was core memory! (He got to do some thesis work on Johnny von Neumann's computer, ca 1950-51. I was just a toddler.) Fred
@WilliamHostman4 жыл бұрын
I remember a number of odd things that are older than me... like rope memory and core memory. And the need to refresh them. I also remember typing punch cards for college students when in Jr. High, because the only time the thing was free was during their classes. I know that the average digital watch these days has a better CPU than my TS-1000....
@ffggddss4 жыл бұрын
@@WilliamHostman To be clear, I wasn't saying that I remember things that are older than me; core memory came into being when I was alive, but too small to know what a computer even was. The first computer my dad worked on, before core memory existed, had some way of using a grid of "pixels" (not a term that existed then) on a CRT screen as random-access memory. I never quite understood what he was describing, but one of its pitfalls was that when some part of that screen got "burned in," you had to write your program so as to avoid that region of memory! My own first use of a computer was in college, when you typed your program on punch (Hollerith) cards, submitted your "deck," and hoped your output, on 14"(or 17"?)-wide track-feed computer paper, would arrive for pickup outside the computer room in a day or two. Fred
@NUCLEARARMAMENT4 жыл бұрын
@@ffggddss It sounds like Williams Tubes to me.
@WilliamHostman4 жыл бұрын
@@ffggddss Most of us remeber things from before our birth - because we have this thing called language, which allows us to share experiences we weren't present for. Like remembering that George Washington was one of the first US general officers. Video has made that even better than language alone. Remembering those isn't abnormal... at least not since the 1930's.
@ffggddss4 жыл бұрын
@@WilliamHostman I adopt a narrower meaning of "memory." What you're describing, I would call a memory of hearing or reading or seeing a video or movie about it, not actually remembering the thing itself. Fred
@dukeofearl80784 жыл бұрын
I must disagree with forced garbage collection. Such a language would not meet the requirements of real time apps (and possibly not embedded apps). I also disagree that compiled languages bind us to the hardware. The ultimate language needs to be compiled to machine code to run efficiently on shared processors (eg containers). D and Rust are the best fits I’m aware of.
@emmetallen56854 жыл бұрын
Maybe something like a superset of rust? I think something like this would check off most of the boxes.
@hemangandhi45964 жыл бұрын
@@emmetallen5685 what would you add to Rust in the superset? A build target for the JVM?
@alienm00sehunter4 жыл бұрын
Something like rust might be the alternative for programs that can't handle a vm
@AndersJackson4 жыл бұрын
You are talking about OCaml now, you know. It compiles to native or virtual machine, and to JavaScript and much more. It is garbage collected, but run on small machines like Arduino's. It is also basis of operating system, or actually, the program IS the operating system. You boot into your program. It is functional programming language, and has Object oriented extension (but hardly ever used). It also have extensions to the syntax, so you can in a standard way hack in new syntax structures into it. Like a pre-processor, written in OCaml, which changes the AST with the pre processor, not the text.
@hemangandhi45964 жыл бұрын
@@AndersJackson Rust has all of that too. Also, when do you boot into OCaML? I've never seen heard of it. But welp, I guess you could tweak the OCaML compiler to stack allocate most things and ref-count to basically make it close to GC-free too, if that was necessary (I think the optimizations for math lead to something like this?)
@tiagoweber94384 жыл бұрын
Fascinating: entertaining and informative.
@valdisk35024 жыл бұрын
Some salient features missing from Bob's talk: delimited continuations (Scala), Communicating serial processes (Go), sparse memory (human brain). These are all great features that are not mere restrictions on the venerable omnipotent LISP. Sparse memory also manifests itself as content-addressable storage, just wait for my Web3 platform to see. Also, I have two meta-features up the sleeve, one for processors (microcode-level programming) and one for the language AUM, my last language candidate, which offers order-of-magnitude more freedom than ML. In AUM, you can define 2+3 to mean: take the character "+", repeat three times and call the duplication function (called "2") on it, producing the two-element list ("+++" "+++"). It is supposed to be as fast as C after compilation, but more compact, both the binaries and the source. There is still room to improve the syntax and functionality of current languages, I am willing to share my research with qualified partners.
@ElixirVitae Жыл бұрын
I’m very intrigued by your comment. Can you tell me more about what you are doing and where I can go to learn about your work?
@edoardocioffi71194 жыл бұрын
The truth is , it is an outstanding presentation, I liked it and enjoyed it. What do you think about Erlang/Elixir as an alternative to Clojure (which to me doesnt have a good garbage collector) ?
@handris994 жыл бұрын
I remember him saying elsewhere that "in the end we are all going to be programming in LISP" :) Edit: Just finished the thing. Looks like the apple didn't fell far from the tree xD Clojure it is for now. I should take a look at it.
@absalomdraconis3 жыл бұрын
I'll make a prediction now: in the end, even if what we program in acts similarly to LISP or Clojure (which it probably won't in important ways), it'll look like C. Some people say that syntax is a solved problem and not an issue, but it is quite clear that the solution in question does _not_ look like Lisp.
@dojcubic4 жыл бұрын
UML for JAVA programmers seems to be his favorite book. He has a copy in every room and the most unusual places.
@inxiti4 жыл бұрын
dojcubic I thought the same. I looked it up, and it turns out he wrote it.
@pqnet844 жыл бұрын
@@inxiti he has many unsold copies he uses to keep things from moving with wind inside his house :-D
@CaedmonWalters4 жыл бұрын
@@pqnet84 lol
@JohnSmith-ox3gy2 жыл бұрын
@@pqnet84 A "paperweight" made of paper. Amusing on two levels.
@thebutlah4 жыл бұрын
I wonder if Rusts notions of lifetimes and ownership baked into the language itself instead of as convention would count as a "new thing"
@driftonAloft4 жыл бұрын
not really, its a paradigm of rust an enforcement of rules
@duffahtolla4 жыл бұрын
It's core to the language and it's a severe constraint. So I would think yes. Just as capabilities are for Pony.
@TedSeeber4 жыл бұрын
I learned PDP-8 Assembly, emulated on a PDP-11, with our only attached printer an old teletype. Freshman Year of College. Long before OO, I was doing polymorphism in 6502 assembly on the Apple IIe. It was a neat way to get software sprites on a machine whose high resolution mode was just another memory space.
@richardgreen72254 жыл бұрын
Programming notations deal with different relationship concepts. A typical "language framework" contains at least 4 notations. > Procedure (steps to run when header is invoked) > Data (data-type, data-structure, sometimes meta-data) > input-output (mapping from storage [database] onto memory variables and vice-versa) > format (notation indicates how the programmer wants the data to be displayed) In addition, a framework might also include notations or conventions for: > Build (make) - How to assemble components. > Wiring - Identifies which actors will participate in a collaboration. > Dialog - Given a stimulus in a context, what is the response. (menu, chat-bot) > Plan tree nodes - Given a set of pre-conditions are true, what transitional code (if any) creates a post-condition. The "tree" has a root "goal". Many tree-leafs (threads) of a plan may be running simultaneously. - Almost all of these "notations" can be written in "simple English" - a notation that looks like written English with some structural conventions. Format requires a mark-up notation which allows the "fill-in-the-blank" convention to be expressed with minimal excursions from WYSIWYG.
@jerelull96294 жыл бұрын
LISP was SO fun within EMACS: the editor I never has to exit once I got logged in; compile, link, test & debug in one place. I could even do my email without exiting the editor. After all these years, I've realized that every language can do all the same things as other languages, albeit differently. a *REALLY* strange language was APL. very tight, difficult to analyze or debug, which is what I hated about it.
@dahdahditditditditditditda75364 жыл бұрын
Long live the EMACS. Does RMS still have anything to do with it? Been retired for a while ...
@jerelull96294 жыл бұрын
@@dahdahditditditditditditda7536 RMS would be a factor on VAX and possibly Alpha machines. A dozen year ago, before I retired, DEC had an editor as customizable as EMACS, and similarly self-documented, meaning we spent hours searching for features.
@NiktNobody4 жыл бұрын
We will need new paradigms and new programming languages for new computers. For example, for quantum computers.
@elcugo4 жыл бұрын
There is no evidence that quantum computers are more powerful than Turing machines. We will probably need DSL for them, however.
@eventhisidistaken4 жыл бұрын
Fundamentally, you need to be able to set the state of qubits, and read them. I view quantum computers in the same way I view graphics hardware. You have special code you write to run on the hardware, controlled by general purpose code. It might be kind of like cuda or a shading language - yes you need to write some parts in some special language, but a general purpose language is still in control.
@sebastianmestre89714 жыл бұрын
@@elcugo You are right in that there is no proof that quantum computability is different from regular old computability. But there are some problems for which we know linear time solutions in quantum computers, but only exponential time solutions on traditional computers. computers
@taragnor4 жыл бұрын
@@elcugo : The very nature of what quantum computers can do makes them more powerful than Turing machines. Shor's Algorithm is one good example of a quantum machine beating the hell out of a standard computer. Really the main limit of quantum programming is coming up with quantum algorithms to take advantage of all the amazing speed you can get, because programming things in quantum is far harder than writing a normal algorithm.
@rmsci40024 жыл бұрын
There are already people arguing that Lisp is the most suitable language for quantum computing.
@albertbatfinder52403 жыл бұрын
“The code is the data, the data is the code”. Wasn’t the very first great insight the realisation that the code and data could live side by side in the computer, and the second breakthrough (debugging at 3am after the first great insight was implemented) that the code should never be treated as data? Call me conservative, but I never want the code being executed to be different to the code I wrote down. You might as well ask me to feed my code through an Enigma Machine before compiling it. Turing loved to modify a bit of code on the fly. Yeah, and Turing couldn’t see the need for subroutines. Axiom: if you’re settling on a language that Turing would approve, you have definitely gone wrong because the rest of us ain’t Turings.
@absalomdraconis3 жыл бұрын
There is some actual value in what he's talking about (aka self-modifying code), but you tend to see it restricted to dynamically loaded libraries (which are so useful that they even existed in the DOS days, in the form of things like overlays) and things like Forth (which aren't really _languages,_ but instead _command interfaces_ that provide some specific language). Self-modifying code in real-world use is very rarified because it's rarely of value.
@zyansheep3 жыл бұрын
Sounds like lisp
@GeorgijTovarsen2 жыл бұрын
I think the problem with just using one language would be that there are mutually excluding feature that desirable for different application (a vary basic example is no-GC for building a kernel and GB for building a web server). I started to think that maybe we could start making a unified type sytem. Adding constraints to the type system it would be possible to make modules interchangable between different languages (not just any language though)
@alexmad69 Жыл бұрын
Scala is the best: strong functional support for immutability and functions as arguments, parallel collections, implicits, higher kinded types, powerful pattern matching, macros for metaprogramming
@KentHambrock4 жыл бұрын
I love how ADHD this keynote is. It makes great points while continuing to be very weird.
@nikthefix89182 жыл бұрын
Yeah he reminds me of Lewis Black the standup comic.
@ricardo.mazeto2 жыл бұрын
I have ADHD, and I just noticed after reading your comment how I paid attention to the whole video without getting distracted, which is a rare thing. 😅
@MarcoAntoniotti4 жыл бұрын
The favorite language of Italian programmers is "Monicelli". But there is NO way non-Italian programmers can grok its beauty :)
@rmsci40024 жыл бұрын
How is it generally beautiful then if it is limited to some natural language?
@Evan490BC4 жыл бұрын
@@rmsci4002 Because Italian is a beautiful language. (I'm not Italian by the way.)
@rickmisk4 жыл бұрын
Any Lisp will do. I prefer the minimalist approach with Scheme
@cstacy4 жыл бұрын
I could argue with a few things he said and didn't say, but in the end it would be a Lisp variant, yes.
@Collaborologist4 жыл бұрын
Clojure
@rmsci40024 жыл бұрын
Too limited. Clojure is much more practical.
@petermaquine81734 жыл бұрын
Hi to all colleagues. I remember auto-lisp (autocad) i use it to make script for plan for french Nuclear plants. I remember turbo-prolog, I used it to illustrate a project for a university. Good all times, because yes it's always the same things that we old dev. are seeing decade after decade. Who remember Fred?
@KpxUrz57453 жыл бұрын
With all that experience, clearly you are a man who wears many hats, which you changed 8 or 10 times here.
@andygolem55144 жыл бұрын
This is the best episode of Rick and Morty I've ever watched!
@michaeladair65574 жыл бұрын
Legit O.G. Nerd, I love this guy. Did you see the batman suit in the background! Subscribed!
@jorisherry4 жыл бұрын
The last programming language will come around the same time as the last spoken language.
@clickrick4 жыл бұрын
Pretty much true!
@1crazypj4 жыл бұрын
@Deep Throat Personally I've always thought a Mandarin/English hybrid far more likely.(for at least the last 40+ years) Historically, China has been forced to open borders for 'trade' but has always closed them again after throwing out foreigners . Today, they have too much of everything and the technology to do pretty much whatever they really want to, there is already speculation if US could take on a re-armed China (plus, China is where bureaucracy was invented and look how worldwide that is.)
@frankgerlach446711 ай бұрын
If you look for a "standard language" to document algorithms, I suggest Algol, Pascal or Ada for imperative. LISP for functional. Prolog for logic.
@dale116dot74 жыл бұрын
My favourite programming language is assembly. Grew up on 6502 assembly. Moved to 68HC11 and 68HC08. Still program lots of assembly on MC9S08 and MC9S12.
@teeesen4 жыл бұрын
Talking about syntax is missing the point. The really important issues are semantic and pragmatic. But, since Uncle Bob brought up graphical languages and argued that, since programming is sequential, programs should be textual, let me ask you all this: Do you really think of your programs as being fundamentally sequence of characters? (Or as sequences of lines, each of which is a sequence of characters, if you don’t think of newlines as characters. Or as a collection of files, each of which is a sequence of lines of characters, if you want to bring separate compilation units into it.) Please reply: I’m genuinely interested. When I write a program, I think of it as a tree of declarations, expressions, and commands that is (awkwardly) encoded as a sequence of characters. Scratch and similar languages may seem like they for beginners only, but I think they may point the way to more effective syntax in the future. If you truly think of your program as a sequence, why do you indent your code? [By the way, Uncle Bob: thanks for mentioning Prograph. I worked on an early implementation. Unfortunately, I never got to use the commercial version, since I didn’t have a Mac at the time. I think if they had come out with a Windows version early enough, it would have lasted longer and had more influence.]
@hardlyb4 жыл бұрын
I think of my program first as a collection of operations, which happen to be expressed in whatever language I'm using. (I once worked on a project where I was simultaneously programming in Smallltalk, C/C++, and a dialect of Lisp, for different parts of the project, and I would occasionally get confused about which language I was using at the moment.) To me, the semantics of what I'm doing are far more important than the language, but I do get frustrated with how verbose and clunky some languages are while I'm coding (e.g. Java, which I'm using at the moment), and then how inefficiently they compile when I'm trying to get things to perform as I wish (e.g., Python, Javascript). Overall, I prefer various Lisps that I've used, but only because of the incomparable power of the macro facility in those languages. (I'm on the fence about functional vs object-oriented languages, and I dislike languages with a lot of syntax, like C++ - I'd prefer to create my own syntax for the task at hand, rather than trying to deal with the idiosyncrasies of the language designer - e.g., Python, again).
@teeesen4 жыл бұрын
hardlyb thanks for your comment . Further thought on this. The idea that language paradigms take things away from us is an interesting one. Compared to assembler, Fortran took away the ability, for example, to make certain type errors. For example in Fortran it’s difficult to assign an Integer to a location that is meant to hold an address. (C made that easy again!) Graphical languages take away the ability to make syntax errors. That’s sort of a trivial example, but it’s hard to argue that we will miss syntax errors. Uncle Bob asked what’s left to take away? I would say semantic errors. There are languages now that won’t compile if the code contains semantic errors. Dafny is an example. Just like adding type decorations is the cost that we pay to avoid type errors you have to make semantic declarations In order to avoid semantic errors. But in certain application areas this is worth it.
@hardlyb4 жыл бұрын
@@teeesen There are still logical errors, which no language will prevent, so we won't have any shortage of errors to make.
@Alkis054 жыл бұрын
@@teeesen The idea of imposing a discipline to make life easier is all over engeneering. Take the lumped-matter discipline in eletronics for example. It allows for the simplification of maxwell equations into much simplier kirchhoff's laws for circuit analysis. Or LTI system in signal analysis and control theory. The understanding that comes from a simplier model often out weights the precision that comes from a more precise but complex one. One thing that he didn't take into account, though, is that these languages are good for general purpose computers. But we will see in the future the proliferation of embeded smart systems, ever more miniaturized that will be comunicating with each other. And we will be dealing again with hardware restrictions that we are not used to in desktops and servers. So low level languages like rust and C will continue to have a space, it's my guess. On the other hand the other hand, how are current computer languages far in quantum computing? I know that lisp is popular with this people because the language is pretty flexible and you can basically invent a new language with lisp.
@teeesen4 жыл бұрын
Alkis05 Good points. Abstraction has been around for a long time. Regarding networks of small computers: perhaps we need to think less about programming computers and more about programming networks of computers. Quantum computing is a whole other thing; our current mainstream languages are not suitable, I think. In the 70s and 80s there was a lot of research on automatic parallelization; the idea being to take code written for one computing paradigm (sequential code for sequential computers) and turn it into code for parallel machines. Perhaps it will be possible to have automatic quantumization which will allow people to write programs for the classical paradigm but execute them on quantum hardware. So far, I think we are nowhere near being able to do that.
@saf2718284 жыл бұрын
"BASIC ... slow." No. Full stop. I'm not particularly a fan of BASIC for other reasons, but even I'm smart enough to not confuse a language (syntax, semantics) with its implementation (Microsoft 8-bit and 16-bit implementations). The very first BASIC compilers to come out of Dartmouth were **compiled**, not interpreted, and were, bluntly, fast. If you think BASIC is slow, it's because you've grown up using Commodore or Apple II BASIC interpreters, which were utter tripe as interpreter technology goes. Someone who advocates for VM-based language implementations should already know this, and it was a staggering punch to the gut to see this error made.
@islandcave87384 жыл бұрын
QBasic was the first general purpose language I learned. Prior to that, I did have a little bit exposure to the domain specific language, CNC. And prior to that I had exposure to the syntax of Word Perfect 5.1 markup language (I don't know if it is called that, but for lack of a better name, I am calling it that).
@RBLevin4 жыл бұрын
Also, Python is BASIC 2020. Do people complain that Python is slow?
@rameynoodles1524 жыл бұрын
@@RBLevin Yes. They do complain that Python is slow. Python is INCREDIBLY slow. It's so slow that I don't even know how it's possible to make a language that slow.
@RBLevin4 жыл бұрын
Back in the DOS days, I used Microsoft BASIC PDS (Professional Development System). No IDE. Just a compiler. It was fast as hell. A C programmer at Unisys insisted that BASIC was too slow to do anything useful. I told him I could develop a telecom app with it that used Xmodem to transfer files. He laughed. We placed a gentlemen's bet on that. I won. Had it running in no time and it kept pace with the telecom apps of the time (Procomm, Telix, etc.). Doubt Visual Basic could do that today. Another incredibly fast BASIC was Borland's Turbo BASIC, which became Power BASIC. I think that's still around but it never made the transition to GUIs.
@newstar3464 жыл бұрын
@@RBLevin There is a GUI version of PowerBASIC.
@joaquinfabrega4 жыл бұрын
I am not involved in programming, however I found this video interesting.
@bhangrafan44804 жыл бұрын
For some decades I had understood that the next development in computing was going to be increasingly parallel architectures which would require some new innovations in programming for greatly parallel processing.
@matttrach3 жыл бұрын
I would love to know how he feels now, 1 decade later. Does golang satisfy all of these?
@Cowboy86254 жыл бұрын
I was wondering why Rust wasn’t mentioned or Zig but I then noticed it was made in 2011. I’d like to know what you think of these languages.
@CynHicks4 жыл бұрын
I was wondering how a guy that was coding in the 60s could look a decade younger than he is. Lol
@rmsci40024 жыл бұрын
Rust is just a safer C++ with functional possibilities, built on top of LLVM. All of these language eventually converge towards being some variant of a Lisp language.
@HermanWillems4 жыл бұрын
@@rmsci4002 Lisp is nice, but why the heck all these functional languages needs a fucking garbage collector. I hate that. We should NOT use garbage collectors, and if we want automatic memory for certain algorithms to be faster we should use arena's for those small usecases.
@RayDrouillard4 жыл бұрын
"Programming happens one step at a time." Very true, but a neural net pushes this concept -- particularly if it the net itself is enacted in hardware.
@adultlunchables4 жыл бұрын
Hate to disagree here but I think you mean that neural nets push the concept of what PROGRAMS can be... However, they do not push the concept of what PROGRAMMING can be.
@handris994 жыл бұрын
I've been thinking about this idea deeply for at least 2 years now. Uncle Bob is definitely right about this in the way that there are certainly elements of Computation that Require Sequential Processing (CRSP) (the result of a previous computation is required for the next step because of the laws of math) and quantum computing is going to turn this paradigm on it's head. But let's put quantum aside for a moment. What I've been thinking about deeply is weather there is a way to condense the parts of code that represent one step in a CRSP into one (or a limited number of) layer in a binary neural net. Then the full code would be basically clipped together from these parts, loaded into a neural processor then executed. The CRSP parts in connected layers while other parts just in parallel. The motivation behind this is that this would allow distributed computing in a mass scale with maximal code reuse, load optimization, auditing , verification and a bunch of things. Any opinions? Ray Drouillard neural nets are implemented in programming languages but more importantly their training algorithms certainly are.
@dougb704 жыл бұрын
49:47 Life is massively parallel. Biotech is developed in parity. CPUs have potentially thousands of cores. The next language should align with that goal. So the talk about linearity lacks foresight IMHO.
@davivify4 жыл бұрын
I think the biggest revolutionary leap in programming languages, imo, is object orientation. By far. It's helped me to do things that would be very difficult without it. I started out with classes as containers and that was very good in terms of statically organizing my code/data. Thence onto inheritance, though I never really did much with that until... polymorphism. That was the key that allowed me to code abstractions. And helped me hugely in creating code that told you what it was. Allowed me to do a complex undo/redo system by designing the underlying architecture separately from the constellation of operations, each with their mate. And the beauty is it's extensible. Allowed me to create a token list for a lexer/parser, where I create the list separately from the gazillion token types I use or could create in the future. When designing complex software it's crucial, imo, to understand the design paradigm *before* committing to code. How much time I've wasted, how much trouble I got myself into without a full and thorough understanding of the problem domain. And therefore writing garbage code. Of course, an OOP doesn't do this for you. You need to put in the time with whatever design tools are available. Employ Use-Case charts, state diagrams, flowcharts, interaction diagrams. Use whiteboards, crayon on glass, dinner napkins, backs of envelopes, etc. Have long discussions with your bloodhound - whatever works, but get that paradigm understood ! Then design using the OOP structures, and thankfully they're there for just that purpose !
@you24494 жыл бұрын
As a fiction writer (and non-programmer) I needed a programming language for a major plot point in a story. I chose Cobol w/out knowing anything about it. It just sounded right. And now your description of it's weirdness (and absurdity?) confirms it was the right, and only, choice. So glad. (Cuz I wasn't about to go back and change it.) Loved all the rest of this too.
@utubewatcher8064 жыл бұрын
of course, Cobol gets bashed--and, yet, every $ transaction; every flight booked, etc, etc goes through a line of Cobol code.
@you24494 жыл бұрын
@@utubewatcher806 That's pretty awesome! Thx., Yet It Lives!
@TheHeraldOfChange4 жыл бұрын
So the ultimate question out of all this is, if you had to choose one language, what would be your, "go to" language?" 😜😜😜
@tack31324 жыл бұрын
C would be mine.
@martinisdn5414 жыл бұрын
C
@monetize_this83304 жыл бұрын
a (simple) macro assembler that supports multiple cpu variants. I guess C is a better assembler, and far more portable than any language in existence. C++ is a joke.
@AnthonyDunk4 жыл бұрын
I've used a lot of languages over the years (including C, C++, C#, Java, Kotlin, Objective C, PHP, JavaScript). But if I had a to choose a single language it would probably be C#. It's the closest we have at the moment to an easy to learn and very productive language running on a virtual machine that can do it all. You can code applications for the desktop, mobile (using Xamarin), and web (.NET). It can even interface to old code (Interop to C DLLs is now pretty easy). The only real draw back is that's controlled (or at least driven) by Microsoft, and is somewhat Windows-centric. However there are open source projects like Mono that implement C# and can be run on Linux and Mac OSX.
@monetize_this83304 жыл бұрын
@@AnthonyDunk I was onboard with .Net from version 1.1 but since v3.5 I gave up because of the constant patching of the frameworks. I'd rather use C++ than .Net
@kevinleesmith4 жыл бұрын
Very nostalgic and forward looking at the same time. Just how I like it. My past started in 1970 on a pdp11/34 running rt11 and programming in Fortran. Ahhhh. Heady days. Happy days. Working 48 hours straight was common place because when u were in the groove, you just kept going. For me, C was as good as it got. Now I'm depressed and will have to drink a lot of whisky :-(
@Murph54564 жыл бұрын
Poor guy. You needed the whisky then. RSX11M was the place to be.
@petersuwara54324 жыл бұрын
Bob forgot about Swift replacing Objective-C...
@johnheaney33494 жыл бұрын
He also forgot about Objective-C getting garbage collection.
@ceedob4 жыл бұрын
This video is from 2011. Swift first came out in 2014
@petersuwara54324 жыл бұрын
@@ceedob it is indeed! I just looked at the Posted date. So much has changed since then.
@carsten_4 жыл бұрын
Objective-C never got GC. ARC is by definition not GC.
@PhilmannDark3 жыл бұрын
The next step will be a language that allows to define your own paradigms and where in the code they should apply. Almost any code would benefit from a way to concisely define what you want, so we want simple and tight integration of DSL for specific tasks like code transformation/generation. The compiler/parser and linker will need to be a toolbox where we can pick and chose. Refactoring needs to be built in at the language level so I can deliver a new version of a module or even a core syntax and tell you "to upgrade from v1.1, change the code in the following way". The last one would also allow to migrate between frameworks/libraries. Lastly, I was wondering whether we can replace dependency management by unit tests: "I need something that can do REST requests using the following types" and then, the compiler runs those tests on suitable artifacts (like those which export the required types) until it finds one that fits the bill. That way, framework developers would also see how their code is used and I would know whether it's safe to upgrade to the new version. Oh, and it should be trivial to say "return this when someone calls the method foo on Bar" to make it easier to write unit tests.
@antonnym2143 жыл бұрын
Thank you! Bob, you are a national treasure! I started on the TRS-80 in 1977 with BASIC, Z80 and APL. (Yes, APL on the TRS-80!) then I wrote a language called R-code to control multiple "warbots" fighting each other in a virtual maze). Then I wrote a simplified Structured BASIC-like language called L.I.M. (Limited Instruction Model OR Less Is More). I'm convinced simple is best, even if it is less impressive to coders and their friends.
@brawndo87264 жыл бұрын
6:51 It was only logical to end the list of programming languages with Prolog
@Evan490BC4 жыл бұрын
But you have "cut" in Prolog, which ruins everything, as it is extra-logic...
@squashtomato4 жыл бұрын
Getting a "we live in a society" vibe from this guy.
@IMANGHAFOORI4 жыл бұрын
The v-lang would be the last one. As far as C, as Modern as Go, and lots of other amazing stuff
@rameynoodles1524 жыл бұрын
Jesus, thank you for mentioning this language. This is pretty incredible.
@mrspock2al4 жыл бұрын
Boy do you bring back memories... I'm a new subscriber and a retired programmer. I learned on a PDP 8 writing assembler and something called "Focus". Absolutely hated Cobol. Had to translate it to assembler to understand it. I've written assembler, Fortran, Snobol, Cobol, PL1 (liked it), IBM EDL, Pascal, Perl, Powershell, Basic, C and an assortment of shell languages. Got out of programming about the time "oo" became the rage - and never looked back. My career went into sysadmin, networking and virtualization and loved it. You've got the coolest toys... sonic screwdriver, phaser, communicator and a copy of Forbidden Planet.
@davisgloff4 жыл бұрын
I'm not a programmer (at all,) but I was fascinated by this.. I kept hoping there would be something I understood. There wasn't, and just that fact kept me watching and interested... By the way, regardless of my ignorance, I LOVE your presentation!!
@SimGunther4 жыл бұрын
44:04 I'm with the crowd on this one. The "write once, run everywhere" philosophy is ironically antiquated given that we're supposed to "run away from the hardware". GC without a large amount of lag or spike in compute time they has a smaller footprint than manually managed memory is a noble goal, but I'll stick with play in my pointer garden without a VM, thx. :) P.S. you still can get memory leaks in a garbage collected language, like WTF??
@homelessrobot4 жыл бұрын
and even if you could completely eliminate memory leaks, memory is just a special case of resource management. there is no general strategy for automatic resource management. its basically the halting problem.
@oysteinsoreide43234 жыл бұрын
C# has a big advantage since it is compiled to intermediate language, and compiled to native machine code on the machine running the code.
@oysteinsoreide43234 жыл бұрын
SimGunther Garbage collection saves also things. But there are ways to optimize garbage collection.
@oysteinsoreide43234 жыл бұрын
SimGunther Yes GC is not a way to say that you don't have to think about resources. GC don't save bad code.
@homelessrobot4 жыл бұрын
@@oysteinsoreide4323 the problem comes when you write a thing that is isomorphic to dynamic memory allocation, but its too abstracted from memory primitives for the garbage collector to infer this. Or, when something about your memory usage patterns prevents the freeing of memory from actually leading to being able to use the memory again later (memory fragmentation, generally). GC is /supposed/ to be a way to say that you don't have to think about memory management; but even this isn't really true.
@ProgrammingMadeEZ4 жыл бұрын
Glad to see you posting more stuff Uncle Bob!
@Amipotsophspond4 жыл бұрын
this feels like one of those in the future year of 2010 mail men will deliver mail by jet pack, and your wife will cook your roast by radioactivity decay, with the help of your robot slave. good history but too much authority.
@mrright10684 жыл бұрын
What a fun trip down memory lane. Always enjoy your talks.
@yapdog2 жыл бұрын
Great video. First time viewer, but I just had to subscribe; I love your insights and we're of similar mind. I look forward to checking out your previous vids. This video really hit home because I'm in the middle of developing a platform that will make new language creation and integration very easy. So, if there are new language classes that can be discovered (I believe there are) they will likely be discovered on my platform since it will be accessible to many different kinds of programmers. Yeah, I know, big claims, no verifiable data. However, I actually *do* have some new classes that I intend to develop on it, but *anyone* will be able to create their own. When it's ready to roll, I'll contact you privately. Until then, wish me luck 😁
@Peregringlk4 жыл бұрын
Gargabe collection is not the only way to completely get rid of memory leaks.
@ftraple4 жыл бұрын
Yes, modern C++ does this very well.
@harrybarrow62224 жыл бұрын
You can use (automatic) reference counting, but it is still possible to lose data structures in ways that confuse a simple reference counter.
@Peregringlk4 жыл бұрын
@@harrybarrow6222 Or make sure all your objects follows RAII patterns extensively and you're done.
@harrybarrow62224 жыл бұрын
@@Peregringlk Sorry, that seems a little naive. If people were good at manually managing resource allocation and deallocation we would never have memory leaks. 😀
@Peregringlk4 жыл бұрын
@@harrybarrow6222 Constructors and destructors should manage resource allocation, not people. As you say, people is very bad on that; me too since I'm people. So C++ tells all of us: don't put never ever new/malloc/delete/free out of these two and you are basically done. There's always exceptions of course because not every single object can be tied or bounded to a scope or other object's live, but the impact is crazingly minified, and without loss of performance (unlike garbage collection).
@unforgive2n4 жыл бұрын
Rust seems to introduce a new way for getting rid of GC, by concepts of "Ownership" & "Borrowing".. and its pretty fast.. although it's a bit syntax-heavey
@Peregringlk4 жыл бұрын
I don't know rust but ownership and borrowing seems a reinvention of RAII and smart pointers respectively.
@unforgive2n4 жыл бұрын
@@Peregringlk in Rust, memory is managed through a system of ownership with a set of rules that the compiler checks at compile time. None of the ownership features slow down your program while it’s running.
@donjindra4 жыл бұрын
That "ownership" concept is one reason I hate Rust.
@unforgive2n4 жыл бұрын
@@donjindra then probably you don understand it well. Because it amazed me
@donjindra4 жыл бұрын
@@unforgive2n True, I don't understand the language well. But it shouldn't be hard to understand a programming language well. There are too many quirks. Too many things to remember. Too many things that just get in the way of writing a program. No language is self-documenting. But Rust fails miserably on that front, imo. I see no benefit to it whatsoever. The 'ownership' concept itself is simple to understand. Any good programmer already uses the concept to a degree.
@kevinleesmith4 жыл бұрын
EMACS - Eight Megabytes And Continuously Swapping.
@utubewatcher8064 жыл бұрын
Eight-k Memory and Continuously Swapping..
@ryanlyle92014 жыл бұрын
I'm not sure why I'm here and I don't understand all of it but the personality of this channel is highly infectious. You are a fun guy to watch.
@jamiesaunders34414 жыл бұрын
I know absolutely nothing about programming but somehow I sat through the entire thing, riveted. Nice view from underneath as it flew straight over my head.