How to scare a VIM user? Make them use their mouse 9:08
@creativecraving11 ай бұрын
❤ Real talk! It's a disorienting experience, sometimes. 😅
@thatmg11 ай бұрын
The struggle is real.
@crimsonmegumin11 ай бұрын
it would be funnier if he pressed ":q" lol
@mgord951811 ай бұрын
Brave of you to assume I have a mouse
@lezzbmm8 ай бұрын
dude was shook tbh
@CaptainOachkatzl11 ай бұрын
write bad code -> write optimized code in different language -> post article -> wait till prime posts it with clickbait title
@Navhkrin11 ай бұрын
1. Comparison to Rust is done aganist best lib that does same operation on Rust, not written by same author. 2. Both are pretty decently optimized and have extremely similar logic flows.
@J-Kimble11 ай бұрын
Yeah and who would have thought SIMD optimization makes processing faster.. the shock..
@zeratax11 ай бұрын
@@J-Kimblesure but if it is easy to write simd in mojo that’s pretty cool
@PeterKilian10 ай бұрын
@@zeratax don’t bother, yt comments are made by zombies.
@Dooezzz11 ай бұрын
'Tensor is one eigenvalue less than elevensor' 😂
@evian897611 ай бұрын
lol
@paladynee11 ай бұрын
monad is a monoid in the category of endofunctors
@monad_tcp11 ай бұрын
Tensor is just a jagged array with 3 or more levels. Why do physicists have to make their data structures sound fancy.
@johanngambolputty535111 ай бұрын
@@monad_tcp It really isn't just fanciness lol, tensors are not about the numbers required to represent them in a given coordinate system, they are about making sure that no matter what coordinate system is used, you end up expressing the same quantity.
@Michallote11 ай бұрын
@@monad_tcpyou know tensors where arround before computers even existed right? We are talking about 1800's or so mathematics.
@ragectl11 ай бұрын
No performance benchmark articles or claims should be taken seriously unless they provide the full code examples, environment details, and details of all optimizations applied. Saying x is faster than y is "trust me bro" level.
@mahakasem8109 ай бұрын
Oh man, go look at the embedded ML space. It's so littered with this exact problem.
@ferdynandkiepski502611 ай бұрын
If you're writing an article that mentions performance you have to provide all the compiler options that you used. If the rust implementation didn't have the target-cpu=native codegen flag set and the --release flag then it is an unfair comparison. And since he used a library for the rust implementation true lto would also probably improve performance. So a set of compiler flags for all languages used is needed to make it a fairer comparison.
@gilpo11 ай бұрын
Bioinformatician here (yes, it's a real field of science!). Most of us come from a bio or stats background and were then taught how to program and how to use analysis tools in grad school. Most of us are unfamiliar with low-level languages such as C or Rust because loads of us didn't have a solid CS background and the learning curve is just too steep for people whose main focus is solving biological issues and keeping up to date with literature and modern data analysis techniques. So most low-level tooling is actually made by CS people working in collaboration with bioinformaticians. I mean... think about it, low-level programming is as hard as it is for full-time computer scientists and requires loads of deep knowledge on how CPUs, memory and OSes work now couple that with also having to master the complex science which is biology, knowing how genes, transcription, translation, mutations, DNA/RNA works and large biochemical regulatory networks and you can see why Python and R are so popular in our field. The barrier of entry is much lower for people from hardcore biology backgrounds and it allows us to engineer performant enough complex data analysis pipelines without having to understand and worry about stuff like memory allocation and pointers...
@halneufmille11 ай бұрын
You may want to check Julia then. It was designed specifically to be as fast as C and Fortran, but as easy to write as Python, but with more modern syntax.
@gilpo11 ай бұрын
@@halneufmille I'm aware of Julia, though it seems more like a replacement to MATLAB than Python, it seems more geared towards engineering than data analysis
@kirillgimranov494311 ай бұрын
"Mojo is faster than rust" And the whole article contains just a sentence mentioning rust once that saying "I implemented it in rust and it was slower" Let's just make jokes about the author and say like he just compiled without a release flag or something
@halneufmille11 ай бұрын
The end of the blog post of viralinstruction about this benchmark sums up my thought about Mojo and Julia perfectly: To me, Julia seems like such an obvious solution to the two-language problem in bioinformatics (and in deep learning). All the hard problems with bridging speed and dynamism have essentially been solved in Julia. At the same time, the language remains niche, mostly because it still has too many rough edges and usability issues, such as latency, the inability to statically analyse Julia or compile executable binaries. But these issues are not fundamental to the language - they're rather in the category of ordinary engineering problems. Solving them is mostly "just" a matter of putting in tens of thousands of professional dev hours, which is a matter of getting tens of millions of euros to pay for hiring people to do the job. It does grate me then, when someone else manages to raise 100M dollars on the premise of reinventing the wheel [a.k.a. Mojo] to solve the exact same problem, but from a worse starting point because they start from zero and they want to retain Python compatibility. Think of what money like that could do to Julia!
@MrAbrazildo11 ай бұрын
So has Julia a smaller learning curve than Rust?
@RazgrizDuTTA11 ай бұрын
@@MrAbrazildo Julia is very easy to use. If you avoid a few common mistakes, you can quickly write fast programs. Squeezing the last drops of performance can be tough though.
@ck-dl4to11 ай бұрын
They want Python codes to run fast as C lol
@MrAbrazildo11 ай бұрын
@@ck-dl4toI guess it's easier to make C++ has efficient high-level features, like ranges.
@Navhkrin11 ай бұрын
This argument is mostly raised by Julia fans, but it really doesn't make sense. It is more of a wishful thinking from a Julia fan rather than a good argument. 1. Julia syntax sucks vs Mojo syntax. 2. Mojo is more than Julia. It isn't "just an alternative". Mojo solves far more problems than Julia ever aimed to solve. Some advantages that Mojo has over Julia: 1. Allows access to MLIR intrinsics directly, which makes adding support for fancy accelerators CONSIDERABLY easier. 2. Native GPU codegen allows un-before-seen heterogeneous compute abilities that is extremely simple to use. 3. Better syntax decisions 4. Supports both AOT and JIT. This makes compiler chain SIGNIFICANTLY more complex and advanced than a language that just supports 1. This is also what supercharges Mojo with dynamism of an interpreted language and performance of a AoT compiled language. At that point, it really wouldn't make to spend dev effort on enhancing Julia. Because Julia has achieved only 5% of what Mojo aims to achieve and it doesn't start on strong foundations to begin with. If we are going to have to engineer 95% anyways, much better to start fresh with better foundations instead.
@thatmg11 ай бұрын
What an idiomatic pythonic nascent article this was.
@ninocraft111 ай бұрын
real
@magfal11 ай бұрын
I taught a bioinformatician that he could run python or rust inside the database they were using: Postgres He took one of his jobs and moved it to the db to skip the overhead. It was a bit more than 100 times faster than how they had been doing that task.
@farrela.84611 ай бұрын
Care to elaborate or drop some keywords about this? I'm curious about how it works and what we can do with it. Thanks!
@magfal11 ай бұрын
@@farrela.846 you can run your code within the context of the database server rather than have your code fetch data and push it back over a high overhead connection. PGRX is the rust option pl/pythonu is the Python option
@magfal11 ай бұрын
@@farrela.846 pgrx pl/pythonu
@mateusvmv11 ай бұрын
@@farrela.846 Postgres Procedural Languages Reminds me of EVCXR, which can be used in jupyter, but I **think** PL/Rust compiles at creation time
@thedoctor547811 ай бұрын
Chapter 46. PL/Python - Python Procedural Language of the postgres docs, which is crazy that I didn't even know about until just now despite using both Python and postgres daily since like forever.@@farrela.846
@the_mastermage11 ай бұрын
Mojo won't be useable until it goes Open Source and until it fulfills its promise to be an actual python superset (it still calls the underlying python runtime for pure python code)
@SMorales85111 ай бұрын
What do you mean? Why does calling the python runtime makes it not a superset of python? If it's straight up python with some added things its a superset in the most literal way possible.
@hammerheadcorvette411 ай бұрын
Cython better?
@darkalleycomics402811 ай бұрын
I tried it it took me 1 min to hit that I can't create a "class" and I can't use f-strings. The "superset" of python at this time is all marketing. They shouldn't have released anything until python was fully implemented. Why not do that first, then add new features? I kind of feel like they are just taking advantage of every python developer's desire to have a faster python.
@onigurumaa11 ай бұрын
Open source enthusiast 🤓
@bobbymorelli976311 ай бұрын
lol
@djupstaten232811 ай бұрын
iterators/generators/coroutines are actually faster than traditional (while and for-in) loops in python because they are very thin c-wrappers under the hood (thinner than the original ones).
@nevokrien9511 ай бұрын
Yes but u r still stuck with dynamic typing and the gill So every single operation is a type check and the you preform it and on top of that you can't use ur 32 cores... If mojo solves this it could be nice but gill is actually a key thing for a lot of the c packages that ai uses. And u need to then compare to Julia and R and I doubt it would be much better. Cython existed for quite a while And it was used to write a lot of these packages. It also gives u low level control and other nice stuff. I think mojo can be basically tensor cython which would be really nice but not a take over everything very nice. It still has a compile step which is a bit to slow for my taste
@maksymiliank513511 ай бұрын
@@nevokrien95Mojo has static typing. It also has structs which are a static version of classes. No additional runtime checks if a field exists are needed. It supports simd parallelization and even running your code on the gpu in a pretty simple syntax if I remember correctly. You should check out the original Mojo demo/teaser video.
@DoomTobi11 ай бұрын
Is that true though? Aren't they "just" faster because they avoid appending to a dynamic array all the time?
@nevokrien9511 ай бұрын
@DoomTobi dynamic array appending is 100% fine even c++ does it. Sure usually they reserve it but like.. log(n) slowness is probably not it. Gens and maps are not that much faster in my exprince. U can use ThreadPoolExecutor and map on it then it's like 20x faster because it actually uses the god dam cores. In a regular python for loop here is all the operations I can think of: 1. Allocate a new heap object for the loop var and write to it. 2. Type check the loop var 3. Actually do the arithmetic 4. Decrement the var reference count 5. Figure out the var is our of scope later on. It's like 4 junk operations per actual thing. BTW 5 is actualy very slow it's a whole graph dependency thing and 1. Fucks ur cach locality. Now if u r using a generator and a sum u can change this to 1. Get the next pointer 2. Follow it to the object 3. Type check the object 4.do arithmetic Because u know build in generators don't get to bleed references out. And u know a + operation on an int or float does bot requite u to save the object. And you know because if the Gill no one is freeing those objects. So are they actually use this trick? Idk I bet pypy does and I would venture cython is doing so as well
@ck-dl4to11 ай бұрын
@@nevokrien95 Compiler does
@psychoinferno422711 ай бұрын
The rust crate is searching for both ' ' and ' ' while the Mojo function is only searching for one character which defaults to ' '. Is it any wonder the Mojo version is faster when the Rust version is doing twice the work?
@sammysheep11 ай бұрын
Bioinformatics often relies on CLI tools, embarrassingly parallel tasks, and pipelined data processing. I think Rust is positioned well for the CS/Bioinformatics methodologist, but maybe not with universal appeal given the learning curve, for data analysts.
@gristlelollygag11 ай бұрын
Sounds interesting, could you elaborate? (tag me/like the comment so i get a notification)
@mistdoyhta69611 ай бұрын
rust is the worst when it comes to GPU computing
@masterchief15206 ай бұрын
Rust would be good for cli tooling and setting up pipelines and use CUDA for interfacing 😂.
@nathanielsimard590811 ай бұрын
The best-case scenario isn't to have a fast programming language so that data scientists can write optimized versions of their algorithms; it's to have a high-level library that does all of those optimizations for free. Way faster experimentation speed this way.
@PeterFaria11 ай бұрын
I played around with Mojo after reading that article. The SIMD type doesn’t do any bounds-checking, and also doesn’t zero-out unset values. It sacrifices a lot of safety for the sake of performance.
@thedoctor547811 ай бұрын
it zeros-out deez nutz pretty gud
@Julian.u711 ай бұрын
And that is a good thing. Nothing more annoying than unsolicited safety
@thedoctor547811 ай бұрын
and unsolicited nutz@@Julian.u7
@isodoubIet11 ай бұрын
@@Julian.u7 Sure but the whole marketing spiel around this language was how it's literally python but Blazingly Fast™. In contrast, the code in this article would actually be much superior had it been written in C++.
@ryanlog8 ай бұрын
SIMDeez nuts
@marktaylor716211 ай бұрын
5:08 The term for idiomatic Rust should be 'Rustaceous'.
@iAmPyroglyph11 ай бұрын
Why not just "Rusty"?
@marktaylor716211 ай бұрын
@@iAmPyroglyph Because I think 'Rustaceous' sounds cooler, and also because it sounds more like it's related to 'Rustacean'.
@Luxalpa11 ай бұрын
Rustalicious!
@raffimolero6411 ай бұрын
Rustic
@mrpocock28 күн бұрын
Crabby
@Endelin11 ай бұрын
Watch Mojo be the name of some obscure snake species.
@SPeeSimon11 ай бұрын
No. It's the name of a big (music) concert promoter. :)
@johanngambolputty535111 ай бұрын
Watch WatchMojo make a video of the top ten comments accidentally mentioning WatchMojo.
@SciDiFuoco1311 ай бұрын
According to their Github page however their implementation and needtail have pretty much the same performance (sometimes one wins, sometimes the other). Unfortunately I can't reproduce them since Mojo on my PC (WSL) immediately segfaults due to issue 1260... Also, this is nothing particularly difficult to code: the benchmark is just measuring how fast you can read a file and split it into lines.
@humansaremortal380311 ай бұрын
Worked with some of the people doing "bio-informatics" for two years. They don't code, nor do they have desire to code. I was paid to code, while they were dealing with cells, sequencing, proteins and bunch of other things that I had zero interest in. Some of them are as autistic as average programmer, meaning some of them are decent company.
@sammysheep11 ай бұрын
This is not generally true. We are split between data analysts and methodologists. Most code the equivalent of a data science and data engineering level. Methodologists can be mathematicians and computer scientists, and code at a deeper level or more esoteric level. Hence the two language problem cited above.
@mattythebatty111 ай бұрын
Why don't they use a binary file format for such massive datasets?
@ErazerPT11 ай бұрын
Was wondering the same because especially field 2 has just 10 possibilities, ie, you could pack each element into a nibble and make it 2el/byte. Just that would shave 50% of field size (~25% of the file size)... field 4 is only 7bit (if my math didn't fail me) so, could also shave another 14% by packing 8char>7bytes (of the field), ~7% of file size. All in all, you could definitely gain a lot from just going binary, as just reading such huge files is a lot of I/O time. But truth be said, the whole thing is so repetitive it just screams COMPRESSION!!!!! :P
@minerscale11 ай бұрын
the real crime is reading in 4x the data than is required due to using plaintext...
@MI08SK11 ай бұрын
Right! It doesn't make sense Each letter could be represented in 2 bits! since the only possible letters are A,C,G,T They could reduce memory usage by 4x by switching from one byte letter representation to 2 bit letter representation
@VudrokWolf11 ай бұрын
@@ErazerPTwhile applying for a DNA sequencing company they only seek for differences from a normalized DNA sequence is kind of misleading think they sequence the whole DNA it takes 7 days to make the comparison and find differences. Maybe is faster now this was 6 months ago I did not make it as an bioinformatician. 😢
@ErazerPT11 ай бұрын
@@minerscale 4x is a bit hopeful, but credible. Just tried plain old lzma2 and it was 56>20MB (2.8x), and that's a compressor that knows NOTHING about the format. A proper binary representation could probably arrange things in a way that bitstream compression could exploit to at least 3x+. But yeah, s**t format. Just seeing stuff like start_time=2020-02-26T02:02:24Z makes me wanna scream.
@boccobadz11 ай бұрын
I call it BS, exactly like the guy from Reddit. As someone with MSc in Electronics & Computer Science in Medicine, I've done some stuff with bioinformatics algos in Cpp (even though it wasn't my main field of expertise) and I doubt that this mojo code can outperform highly optimized and battle-tested Cpp parsers (written by much smarter and better-paid people than this article's author). I feel it's the same as their example with mojo magic being faster than their hand-written Python code for matrix multiplication instead of benchmarking it against numpy (which has nothing to do with python because it's a wrapper on 40 yo Fortran lib). Again, it's an advertisement full of BS - if it was so great and magical, it would be open source already.
@thekwoka470711 ай бұрын
Not shwoing any of the Rust code makes this highly sus...
@adhalianna11 ай бұрын
I have a weird suspicion that they might have even done a debug compilation instead of the optimized one. The fact that we cannot check even for that typical mistake is very suspicious.
@RazgrizDuTTA11 ай бұрын
I switch from Python to Julia to do my PhD and it's amazing! I have a bad feeling Mojo will kill Julia and waste all that effort just for non-CS devs to avoid learning a new syntax.
@radumihaidiaconu4 ай бұрын
i did it for my master degree too
@VivBrodock10 ай бұрын
Prime: "idk what a tensor is" Me, a math major currently learning tensors: "idk what a tensor is either"
@apaz-cli11 ай бұрын
I work as a researcher, and I'm building these kinds of tooling and data pipelines, but have literally never heard of anyone using Mojo. The general consensus is that it's not even a contender until they open source it. I haven't even heard anybody talk about it for at least a few months, which in the machine learning world is an eternity. I legitimately forgot that they existed. Even if Modular does open source it, I doubt their ability to beat the Huggingface model serving ecosystem, which is all in Rust. I hope that Modular pivots before they burn the whole hundred million dollars they raised. I don't think they actually understand the problem they're trying to solve.
@jonnyso111 ай бұрын
Is this the one he forgot to compile in release mode ?
@jpratt867611 ай бұрын
Nooooo say it ain't so
@Exilum11 ай бұрын
0:45 This actually brought back a core memory. Back when I was in highschool, I used "learnt" a lot because it was how English was supposed to be. But I eventually figured out that few English speakers actually knew that, and used learned instead. Now, I intentionally use the incorrect learned form because it's just how the language evolved. Learn just isn't treated as the irregular verb it is.
@NibbleMeTwice11 ай бұрын
Good on you for having learned a second language.
@samarrowsmith272311 ай бұрын
Start calling people "my learned friend" where you voice the last 'e' and we can start a movement
@annoorange12311 ай бұрын
Go is an awful name, not search friendly at all. If we're talking about good names, Haskell comes to mind or Elixir.
@haniffaris89179 ай бұрын
You would expect a google-able name from a language developed by Google, but nope.
@WizardofWestmarch11 ай бұрын
I don't remember if they were able to leave it on but one thing to keep in mind on C vs Rust is, if LLVM works correctly now, Rust's aliasing rules allows avoiding rechecking memory to ensure the register and memory are still in sync since C lets you arbitrarily alias a block of memory infinite times with multiple of them being writeable.
@johanngambolputty535111 ай бұрын
I spent a lot of time in python and I'm very glad that I did, because it never needed to be fast, in fact it could have been 1000x slower and I still would have got the same experiments/prototypes done. I swapped when I started trying static analysis, which was just yelling about a bunch of my old code not adhering to stylistic standards or because it couldn't infer what I was doing with certain variables, at that point I might as well strongly type and get useful comments from the linting. I haven't really looked at Mojo, but Rust has some very tasty generics and meta-programming, which has the potential to let you get a lot more done with less code, which is what I've always loved.
@vatanak814611 ай бұрын
Python has type hints you know?
@johanngambolputty535111 ай бұрын
@@vatanak8146 I know, but when I tried it, it was hit and miss. It's funny though, because if you don't want random warnings (from rufflsp I think) everywhere you end up having to explicitly annotate more variables than in rust.
@flynn364911 ай бұрын
Bro dropping new words in his articles
@Carter900711 ай бұрын
Nascent looks to be nascent
@ninocraft111 ай бұрын
@jazzycoder r u retard?
@_zh3ro_11 ай бұрын
nascent comes from Latin, so if you speak any language other than English that happens to be Latin based, it suddenly becomes not that fancy
@michaelhildebrand-faust403911 ай бұрын
Python:Mojo :: JavaScript:Typescript. Look how Typescript has taken over from JS. Same thing will happen with Python -> Mojo.
@victorybhg11 ай бұрын
it’s hard to compare the same class of programming language on performance as any language of the same class ( gc, vm, etc ) can be optimized by their respective compilers to relatively the same performance as everything gets to machine code eventually, what does make the difference is whether the language is able to allow the dev to express the most performant set of algorithms that is allowed by the target hardware resources ( cpu, gpu, memory, disk, etc ). it seems mojo is able to expose these interfaces ( simd vectors etc ) more than other languages doesn’t mean that those other languages can’t also have these interfaces as well. it comes down to what provides the easiest path for the domain experts to do what they need to do.
@ruroruro11 ай бұрын
As a CV/ML Python developer, I despise Mojo's marketing. It's an interesting project with some good potential (especially if they end up opensourcing it), but their marketing is full of borderline lies and clickbait. If they think that this kind of publicity will help their project, they are sorely mistaken. All that they have done is train their potential users not to trust a single word coming out of their mouths. smh
@mrpocock28 күн бұрын
I was part of the core team that wrote biojava, back around 2000. I also coined the word bioinformatician. It was far more accessible to people than c, and the python libraries were much slower. Things have moved on, but due to multithreading, there are still a lot of very fast bioinformatics tools written for the jvm. These days I mostly write Rust.
@steffahn11 ай бұрын
1:07 no, you got that all wrong, it's "thousands of [...] machines"! The "thousands" is the number of machines, and "multi-million dollar" the price of each machine.
@yakocal11 ай бұрын
Which mounts up to billions of dollars worth of machines, and it's what he said...
@steffahn11 ай бұрын
@@yakocal No he said "most people say 'billions'" suggesting that the phrase could be simply re-worded to use the shorter "billon" somehow. I disagree with that statement and assume it has only come about by misunderstanding of the sentence structure. I mean, tell me, how WOULD you re-word this? You say "billions of dollars worth of machines". But that sounds weird, too, and loses informations, as in "billions of dollars worth of DNA-sequencing machines are working non-stop ...". Arguably the "thousands of machines" is the CORE information here, given the sentences around it focus not on economics ("how many dollars") but on scale ("how much data processed").
@Carter900711 ай бұрын
@@steffahnso we conclude that it's subjective...
@melodyogonna11 ай бұрын
Those writing Mojo off are very funny. Mojo is just a user interface for MLIR; Chris Lattner and his team wrote MLIR by hand and validated it can be just as fast as Assembly and so performant enough to handle workloads they intended to take. Mojo is just a user interface so they wouldn't have to write MLIR by hand anymore, they could have made it look like anything, they chose Python because that's what the ML community is familiar with. Speaking of Chris Lattner ... That is the same person that started LLVM, Clang, Swift, and MLIR. This isn't some random compiler guy claiming some things, there are track records.
@melodyogonna11 ай бұрын
@@anonymousalexander6005 Python isn't hard to implement, there are just 36 keywords, and straightforward semantics. The part that makes it a superset is what they're currently building, and that is the low-level parts Python doesn't have. Also, being a superset is a long-term goal.
@monad_tcp11 ай бұрын
I thought automatic vectorization was a solved problem. Turns out it isn't when you have heterogeneous architectures.
@lmnts55611 ай бұрын
This is true, Chris is a beast that cant be underestimated.
@UnidimensionalPropheticCatgirl11 ай бұрын
I mean LLVM succeeded despite being mismanaged mess, not because of it, swift didn’t get good until he got booted of the project and MLIR hasn’t been widely used yet, so as far I am concerned everything lattner touches is vapor ware until proven otherwise.
@melodyogonna11 ай бұрын
@@UnidimensionalPropheticCatgirl you must be a troll.
@tajkris11 ай бұрын
1:55 Write your critical path in a way that mostly uses primitives and you're good to forget about GC. In fact, most popular jvms have escape analysis implemented to allocate objects on the stack instead of heap, so if you're careful enough you can use classes too. Not that I am a fan of Java, but if they can write low latency algorithmic trading systems (tens of microseconds or lower to deserialize a price tick, make a decision, prepare an order, serialize and push it out to the network card), high throughput message processing system (Kafka), or highly optimized low latency, concurrent, lock-free queue (LMAX disruptor) then I'm sure it can handle bioinformatics too.
@bloody_albatross11 ай бұрын
As I understand it tensors are n-dimensional matrices with all kinds of matrix operations and "broadcasting" of other operations (think SIMD, but because n-dimensions more complex and you have to think about what is happening rows/columns wise). Good tensor libraries have multiple kernels, usually you use a GPU (CUDA) kernel where all the operations run in parallel on your GPU(s). Therefore your ML program can be written in Python, since the actual heavy operations are (JIT compiled? (dunno) and) run on the GPU. PS: Out of curiosity I started to write a small matrix (not tensor) library in Rust nightly. You can do fun optimizations in Rust because of the ownership model where you elide allocations. Think you do mtx1 + mtx2, but at least one of the parameters are passed as owned. You can impl the Add trait so that in that case you simply reuse the memory of that parameter and do a += instead. However, there are limitations. To make this all somewhat nice you need to use nightly for better const generics and it all gets really complex and redundant quickly and I managed to crash rustc.
@randomcubestuff342611 ай бұрын
a tensor is just an element of a tensor product of vector spaces :thumbsup
@isodoubIet11 ай бұрын
The "right" way to handle those kinds of optimizations is with expression templates (C++ name ofc, have no idea what the idea is called in Rust but from what I know it should be possible). The idea is that you build the computation graph in the type system. For example, instead of having the result of mat1 + mat2 be another matrix, you have it be a MatPlus. Then if you do (mat1 + mat2) * mat3, the type will be MatTimes, and so on. You only actually effect the computation when you actually want to store the result somewhere, at which point the whole thing can be optimized by SIMD, fused-multiply-adds, whatever makes it fastest while minimizing cache misses.
@mrpocock28 күн бұрын
In ml, you often need to keep all the intermediates about to calculate gradients. Sad face.
@dixaba11 ай бұрын
You can almost always write a faster version if you make some assumptions: "No, that format is outdated", "Nah, surely there will be no right-to-left languages used", "Of course every file will end with an empty line" and so on. And even if you write code in accordance to specifications, other widely used tools almost always will have quite a bit of QoL features, which can easily become dealbreakers for end users. As an example, GNU grep does support Perl-compatible regular expressions (using -P flag), while POSIX grep does not. If you write your blazingly 🔥fast 🔥Mojo 🔥grep 🔥that is only POSIX-compliant, it will work for some users, while many other users (including myself) won't even consider it.
@josefkaras751911 ай бұрын
mojo is not faster then rust, in the article he quiet literally said that he spotted a mistake/oversight and implemented it better. edit: not true, author didn't say that in the article
@josefkaras751911 ай бұрын
also in bioinformatics redundant checks can save a life. as i see it - DNA -> cancer -> therapy with radioactive elements -> if u screw up, u die
@weirdworld373411 ай бұрын
couldn't find that quote in article. Care to add it here?
@josefkaras751911 ай бұрын
@@weirdworld3734 so... i apparently cant read. i was talking about "In addition, I explored optimizations from C/C++ implementations ..." sry for that, as i read it for the second time, it really seems that the author of the article says that those implementations are equal (optimization-wise)
@aneeshprasobhan11 ай бұрын
@@josefkaras7519you actually admitted your mistake. That's rare on the internet these days. Kudos to you 😃
@HammytheSammy-ds2em11 ай бұрын
@@aneeshprasobhanI’m more surprised that someone who understands code admitted they were wrong. It’s a double whammy for me. Next thing he’s going to say is he reads documentation before starting a project, lol.
@vectoralphaSec10 ай бұрын
Mojo is the future of AI and ML fully replacing Python i believe.
@sweiscool11 ай бұрын
"Everybody I know who does Julia loves Julia" - Prime, 2024
@abinavravi106311 ай бұрын
Mojo seems like a movement towards rust while retaining python syntax to an extent, they have structs and traits over classes and OOP world.
@gabereiser11 ай бұрын
The whole article smells of GPT.
@bravethomasyt11 ай бұрын
This code has been heavily criticised in the Rust community, and it's expected that, done properly, rust will be faster. It's a clickbait article.
@enkiimuto104111 ай бұрын
This was the weirdest watch mojo I saw.
@sdi87hhk11 ай бұрын
that "cool story bro" sounded personal lol
@J0R1AN11 ай бұрын
9:08 Average VIM experience
@nitsanbh11 ай бұрын
0:39 Hey Prime, ya can’t have GREEN HAIR and a GREEN SCREEN at the same time
@anotherelvis5 ай бұрын
Mojo is faster than Rust in a specific benchmark involving tail calls.
@Turalcar11 ай бұрын
3:08 The most amusing to me is that there exists a class called "Wirth languages"
@griof11 ай бұрын
The truth is, Data scientist and researchers will use python... Nobody in this side of tech cares about perf. Or safety. You can always rent more cpu on the cloud. Also, Data scientist don't like to program, and we are very bad programmers actually.
@_MrKekovich10 ай бұрын
The truth is, new tools for python will be written in mojo instead of C/C++. Mojo does not aim to replace python.
@MichaelYoussef-kn8cy7 ай бұрын
Most ML research involves comparing different methods/algorithms, so the performance of a language is irrelevant - you just need to make sure everything is implemented in a consistent language. For companies, performance is crucial, and that’s where Mojo will shine
@9SMTM611 ай бұрын
hyperfine, which he used as benchmark tool, actually does a few runs under the hood, and calculates the standard deviation etc. for it. So it's not 'just one run'. Still, as others highlighted, there are a few other things where at the very least he did not prove that he did it right. Such as whether he used SIMD in Rust (likely not, and SIMD can easily be responsible for more than a 50% speedup). Whether SIMD in Rust is in an usable state is another question. I've never tried it myself (in Rust), that that could be a good motivation. But it's a less catchy title. Honestly Mojo as a language is very tempting to me. I love Rust, but really, getting others to use it, when it does take a decent bit of time to do properly, is difficult, and must be justified. Mojo promises me the ability to write similar code to Rust, while still being at least somewhat editable for others. The big issue with Mojo is licensing (and, underlying, the VC funding of Mojo). Frankly I don't see how they intend to make back their money without eventually doing things I'm not going to be happy with.
@binary_gaming11311 ай бұрын
I used SIMD and it was faster than not using SIMD: The article
@earx2311 ай бұрын
SIMD done in intrinsics in Rust will probably beat the pants off of that implementation. The beauty of Rust in this case is, even if it's just a kind of assembler without the explicit register bookkeeping, that its typing system makes you more aware of float to int type conversions, which are very expensive. Porting my intrinsics from C over to Rust yielded a nice speed boost.
@chigozie12311 ай бұрын
I'm pretty sure Julia was created to do exactly what Mojo 🔥 is now struggling to do. Julia syntax is intuitive and familiar to Python programmers. It has a thriving ecosystem of libraries and has seen massive adoption. It has an excellent C/C++ interop. Why do we keep reinventing Python?
@yldrmcs11 ай бұрын
because data scientists are so stupid that they can’t write code in languages other than python. fact.
@kinomonogatari11 ай бұрын
Julia just failed to find a company to invest in it
@RazgrizDuTTA11 ай бұрын
Mojo will kill Julia and waste all that effort just for lazy devs not to learn a new syntax. I hope time proves me wrong :(
@kinomonogatari11 ай бұрын
@@RazgrizDuTTA Well I quite like Julia as a language but at the end of the day I really do not care as a physicist who wins in between Julia and Mojo. I just want a performant modern language using which I can get my work done.
@RazgrizDuTTA11 ай бұрын
@@kinomonogatari I understand your point of vue. I wish I was that pragmatic. In my case, I do linear algebra for computational mechanics. I absolutely despise the Python Numpy and Scipy design and syntaxe so I hope Julia will survive along with all the great linear algebra packages developed by the Julia community.
@0xnika11 ай бұрын
Dude, you are breaking the green screen with your hair!
@uncrunch3987 ай бұрын
I like optimizing my speech. Will use the shortest words, fewest syllables and words I can think quickly to compact my message to giving a higher priority only to that it can't be taken to mean something it doesn't. I often fail at the higher priority intent.
@AggressivesnowmaN10 ай бұрын
Prime nailed this take regarding likelihood of adoption. Most in that field would find more use in a fast simple language. I’d be more curious how Mojo compares to things like GO and Cython than Rust. Just because they seem to be after a similar niche
@KyleHarrisonRedacted11 ай бұрын
Java, ya dude, big data infrastructure is all jvm’s. Hadoop is Java, Spark is Scala, Elastic is Java, etc etc Being honest when Machine Learning was all the rage I was surprised to see that the big language of choice was.. python.. Of all things, and not Java.
@nevokrien9511 ай бұрын
The reason for python is 2 things. 1 array are nicer to handle in python because list comprehension is useful. U would not belive how many times I print data that I list comprehend to get a picture kf what's going on. 2 Ai reaserch isn't production code its all dev which means it's VERY hacky. Like I would go and read private vars left and right just to get a grasp of what's going on. Or I would also overwrite forward with my_log(forward) to get an idea of what's actually happening under these abstructions In java such a thing would be impossible, which means some tasks I could solve in a hack way in python r unsovlble in java... Also python has better c integration and u gota remember that ai used to be done In c++ so porting that into python Is a much easier task. Also python code for ai tends to be more framework independent since u don't have static typing and TENSORs are the same thing of they r np array tensorfloe or pytorch for the most part
@vatanak814611 ай бұрын
Is it worth it to learn Scala as an aspirant to Data engineering and Big data field? Or just stick to Python and SQL?
@nevokrien9511 ай бұрын
Mojo is still a buggy mess... I tested it on their cloud it broke with very small changes to what they did It dosent boot on my machine at all like just crashes on install in very nasty ways Basically if it works it can be fast but it just breaks all the time
@elgalas11 ай бұрын
Mojo looks fun. Been doing Aoc with it, but it is still way too early for it! I ran into multiple bugs when using parallelism
@amansawhney331811 ай бұрын
The problem is that mojo is just using python as a front end for portable simd instrincs. You still need to understand cache coherence and vectorized instructions. Changing the syntax doesn’t just make the barrier to entry lower. I personal use Rust for all my ML and research work.
@vincentyan853111 ай бұрын
As a data scientist I can assure you that 90% of us do not care about tooling, at all. The majority of data scientist use Jupyter Notebook (not even Jupyter Lab) as their one and only IDE. AS THEIR **IDE**. It is pointless to assume they will ever learn a new language just for the better tooling.
@Indonesia_Emas_11 ай бұрын
i mean pure python implementation of ViT model for example needed huge resource for its computation. and then we try to modify the architecture to hope to make it more resource efficient. my thinking is why don't we implement ViT architecture in pure rust. it will become much more resource efficient compared with modify its architecture because it still get affected by python's less resource efficient.
@Indonesia_Emas_11 ай бұрын
but yeah, the rust data science framework shall be easy to use 😅😅😅😅
@Indonesia_Emas_11 ай бұрын
but the core python tensorflow for example, one of python ml framework, is written in fast language that is c++ and python as the frontend. so i wonder from where the bottleneck come from.
@bopcity578511 ай бұрын
As someone whos written a lot of python Mojo is so annoying, its literally a worse version of numpy. (Numpy arrays mostly are written in C and autogen SIMD operations)
@InfiniteQuest8611 ай бұрын
This already existed. It's called Julia. You'd have to get all those people to move over. It's too late.
@MichaelYoussef-kn8cy7 ай бұрын
Is Julia a superset of Python like Mojo?
@InfiniteQuest867 ай бұрын
@@MichaelYoussef-kn8cy Dude, youtube has been deleting like 50% of my replies to people. I had responded that Julia is as easy to learn as Python, but it is compiled and super optimized. It is it's own language. It is better then Python in almost every way. Hopefully this doesn't get deleted too.
@juancarlospizarromendez395411 ай бұрын
In Rust: A value of type char is a Unicode scalar value, represented as a 32-bit unsigned word ...; In C and probably in the propietary Mojo: 1 char = 1 byte unless another encodings are used. It's why, for 4 letters, ACGT, Rust is worst in speed managing pure ASCII characters.
@mytechnotalent11 ай бұрын
I live for Prime's thoughts. It is interesting such a claim to be faster than Rust. Single algorithms can't be taken in a vacuum. I would love to see a larger set of benchmarks.
@thekwoka470711 ай бұрын
Or even the Rust code used...
@SaHaRaSquad11 ай бұрын
@@thekwoka4707 And the Rust compiler flags. In the end Rust also uses LLVM as compiler backend so this 50% claim is difficult to take serious without more details.
@tobene11 ай бұрын
IMO mojo seems really promising, lets hope it will get open sourced soon. It seems like a great alternative to python or matlab for research
@KilgoreTroutAsf11 ай бұрын
As a seasoned HPC developer I have to confess the lack of scientific, mathematuc and engineering knowledge of the average FANG drone is as mindboggling as it is scary. I really have no idea what they teach you for four years of a CS degree at the uni. Fingerpainting, seemingly.
@stretch83906 ай бұрын
What?
@eliasboegel5 ай бұрын
Agree with this. It is mindboggling how different the thinking of HPC developers is compared to "traditional" software engineers.
@GamesmotionTV11 ай бұрын
Just wondering if the Rust Community could come up with an equally fast solution. Unfortunately the article did not show any code.
@AgainPsychoX11 ай бұрын
When I heard "Java" in context of "highly optimized tools" I had to take break and walk around to feel better...
@jerrygreenest8 ай бұрын
So, what should I use now? Rust? Zig? Odin? Mojo? Write my own language with OCaml?
@johanngambolputty535111 ай бұрын
I've always hated how the word tensor is used in ML to just describe a ndarray, but I guess you can't blame people being confused when the real definition often is "a tensor is something that transforms like a tensor".
@TurtleKwitty11 ай бұрын
My guess is that people will favor mojo heavily when doing initial parsing and tesintgo ut theories and when it gets cemented then it'll bee pushed voer to whoever was doing the super optimized versions befroe but now they can work on larger data sets while testing theories
@_tsu_11 ай бұрын
For such small programs, the progress bar is the thing that slows down the program the most. Looks pretty, very cool for writing heavy duty stuff, but unless your benchmark runs a minute or longer, you should disable the bar and then do it for fair results.
@PhilipAlexanderHassialis11 ай бұрын
The real takeaway of course is the fact that "having to learn just a bit more and achieve something much better will always beat having to learn something totally new". Which is, for me at least, why Next won the React SSR wars: it was React as you know it, with one opinionated thing (routing) and an extra function to have server processing before delivering the finished rendered stuff to the browser. You could literally take an existing small but actually in production React application and convert it to SSR within an afternoon. Remember: developers are users too. And when we get into "user" mode, woe and behold we are *far worst* than the users of the applications we create.
@thedelanyo11 ай бұрын
"Biggest takeaway" this keeps me coming back
@isodoubIet11 ай бұрын
It's nuts how python (and now mojo) with heavy type annotations looks about as verbose and cryptic as template-heavy C++, except that templated C++ is better because templates are structurally typed, which ironically would fit better with the python usual duck typing. Like just use C++ at that point, you're not really gaining anything by deleting the braces.
@thoughtsuponatime84723 күн бұрын
I'm fairly certain, Mojo will be my next language. This is exactly what I have been looking for.
@STChaosman11 ай бұрын
Bro, i’m no a native speaker, you’re the only KZbinr for which I put videos @ 0.75 speed
@uzbekistanplaystaion4BIOScrek11 ай бұрын
the more stuff i see from prime about new languages, the more i think c might just be the best tool for the job.
@martijn315111 ай бұрын
If anything is fast it’s me moving away from a language when it’s called Pythonic.
@georgerogers116611 ай бұрын
Julia is better.
@tychoides11 ай бұрын
I tested Julia a few months ago, to see if I could move my data analysis to it. It was bad. The JIT lag was 6 second for a runtime of 0.5 secs. I managed to compile the libraries to reduce the compilation time, but it was the most hideous and deranged compilation process I have ever seen. And the documentation regarding this was awful. And the dataframe library I tested (Dataframe.jl I think) was on par with pandas on merging and almost 2 times faster for some grouping operation. However, I tried polars and it was amazing. It was multithreaded by default and gave me an orden of magnitude improvement (10x) with half the memory consumption. And I still was using Python.
@omarruelas189711 ай бұрын
Julia Is not Mature enough, but its syntax is the most comfortable I've seen
@RazgrizDuTTA11 ай бұрын
@@omarruelas1897 Have you tried Julia in recent years? I have done 3 years of my PhD with it and it's great. The tooling is good too. I don't see what's not mature enough? It's for sure more mature than Mojo.
@gustavojambersi95698 ай бұрын
A lot of of people were already not changing from python to better performing languages. They DEFINITELY will not change if Mojo performs somewhat close to rust.
@MichaelYoussef-kn8cy7 ай бұрын
That’s because no other language (including Julia) has anything close to the vast ecosystem of libraries that Python has for ML, data science, and math, but Mojo is designed to be a superset of Python.
@sdsa0077 ай бұрын
I cannot imagine what its like to speed learn Rust for months, and then suddenly do an about face and learn Mojo! All because you were too Pythonic, and should not have switched in the first place! Stay on the right path wonderful people! Everything has a niche.
@lauraprates876411 ай бұрын
Wasn't mojo a GPU accelerated language? like it isn't a big surprise that a GPU outperformed a CPU in a SIMD context, actually it's quite impressive that it only outperformed by 50%
@Summersault66611 ай бұрын
Mojo outperforms even c running only on CPU. Mojo llama is 30% faster than llama.cpp. when it comes to GPU is another level
@lauraprates876411 ай бұрын
@@Summersault666 but is a state of the art C code, because there is so much of what an interpreter can do
@Summersault66611 ай бұрын
@@lauraprates8764 and it's impossible to access hardware optimizations without creating special semantic instructions to them. Mojo has Mlir, it's hardware abstraction to reach language structures. And not the opposite.
@hipsterJoe111 ай бұрын
+1 to "Zero to production in Rust" is one of the best Rust books!
@cbbcbb680311 ай бұрын
Wasn't there a MoJo something used to create the WebOS software for the Palm phone?
@Mouradif11 ай бұрын
"Thousands of multimillion dollar machines" is not the same as "one billion dollar machine". Each machine is a multimillion dollar machine, and there are thousands of them
@TonyAlvesDev11 ай бұрын
I'm always skeptical of these statements for speed. Especially from a closed source solution. Be very aware that the processor can only go so fast and memory access is only as fast as the hardware limitations. Mojo is a great idea. Rust is a fantastic language. Both will have their pros and cons. I like where it's all going!
@k98killer11 ай бұрын
Wild idea: ThePrimeagen may one day say "the name is or at least somewhat resembles ________". Not sure in what context, but it's theoretically plausible.
@piotrs4485 ай бұрын
Rust or Mojo for backend REST API?
@MeysamBelash10 ай бұрын
Can you make a comparison between rust and qbasic in which qbasic wins?
@Veptis11 ай бұрын
if pypy is better than Cython and Mojo better than both ... Why can't we get Cython to do the same? Mojo is a supposed superset, but you could already use python cffi or other ideas abstracted away in the heavy lifting libraries
@georgehelyar11 ай бұрын
If they cared about performance, they wouldn't be using python right now. They are never going to switch to rust for performance, if they haven't already switched to a more mainstream faster language.
@dbug6411 ай бұрын
Is it just me or does Mojo look like Rust without the {}'s and then people just claiming "Look, it's just like Python with a few types in it"??? If I was a Python coder, Mojo would look just as "complicated" as Rust to me. So weird that no one else seem to think this too.
@doigt659011 ай бұрын
I'm surprised you never saw it before, I've heard and seen pythonic many times when talking about languages that are pythonic like nim, lobster and mojo (and boo and genie, in days of yore)