Uiua creator here. I'm glad Conor is enjoying the language so much! This is a nice solution to a LeetCode-type problem, which Uiua is very good for, but it can do much more! The website's editor has built-in functionality for generating audio and images from arrays. The native interpreter has support for file IO, TCP sockets, and more, so you can write Real Programs™. Have fun!
@user-ui8my9zs7o Жыл бұрын
What's your plan for editor support. I saw you have vs code support but what about emacs?
@kaikalii Жыл бұрын
@@user-ui8my9zs7o The native interpreter has a built-in language server, so any editor with a language client should be able to hook into it. I know some people have gotten emacs and neovim set up, in their own configs at least.
@daviidon Жыл бұрын
Loving it, where can I find examples of file i/o?
@daviidon Жыл бұрын
A mode that switches the symbols to words would be useful in the playground. Hovering is a little cumbersome
@kaikalii Жыл бұрын
@@daviidon You can go to the site's documentation page and scroll down to the system functions. Hover them for their names.
@daviidon Жыл бұрын
The stack is definitely the killer feature. This is the first array language that "clicked" for me
@red13emerald Жыл бұрын
Yeah, I feel the same. The stack makes it so much easier to understand what's going on an where the data lives.
@FraktalLogik Жыл бұрын
I have been playing with J for over 10 years, APL for 5 or 6 years, and I started to check out BQN, but the symbols threw me subjectively. I love stack languages, so now I am jumping on uiua. The audio/pixel stuff grabbed me immediately, since I play with generative sound design, and this looks very promising. Amazing work!!
@darrylkid210 Жыл бұрын
Keep the Uiua videos coming!
@austinflynt Жыл бұрын
I solved the sum_of_squares using Excel's LAMBDA functions like this: =LAMBDA(xs, LET( f, phi( b( is_zero, phi( tally, modulo, bbb(add_1,TR,range,tally) ) ), mult, square ), res, SUM(f(xs)), res )) Excel is kind of an array language with array addressing like A1#.
@__CS Жыл бұрын
I truly can’t thank you enough for all your videos. You’ve seriously made me so excited about learning different programming languages & paradigms. Out of curiosity, will you be at the next CPP North? I would love to see one of your talks in person !!!
@code_report Жыл бұрын
Glad that you are as excited as I am! I hope to be there but won't know until some time in 2024. I am hoping to present on my research that I have been working on at NVIDIA at some point in 2024 at some conference. Whether that is at @cppnorth or another conference is TBD
@0LoneTech Жыл бұрын
Point free doesn't refer to some symbol, it refers to points in the argument domain, i.e. individual values. So instead of talking about how to transform one point x into another f x, we talk of how the space itself is transformed, equally applicable to all points; f, which is a function.
@Cmanorange Жыл бұрын
I found your other BQN vs Uiua video and instantly fell in love with Uiua
@yash1152 Жыл бұрын
11:43 > _"no need to learn combinators"_ yeah - what more, i would say that the stack operations: duplicate, flip, etc make communicating about (& hence teaching & learning) the combinators far more easiers
@andrewdunbar828 Жыл бұрын
All of these videos make these array languages look interesting but also make it look like they're only toys for solving little code problems.
@nunzioturtulici9636 Жыл бұрын
I guess that once you give names to your little functions you can divide a big problem in its parts much like in procedural languages. I don't see really a big difference.
@maxime22000b Жыл бұрын
moar uiua please ! 😍 (thank you for your videos, they are perfect for my little routine of watching youtube before going to bed ^^)
@YoshikoJanai Жыл бұрын
I love the concept of using the multiplication by zero with the mask as a bitwise AND operation to nuke unwanted data. Really appeals to the Computer Engineer in me. It also mirrors how you'd represent working with a Logical AND in Boolean Algebra, as a multiplication operation. I wish I could've found this appreciation for more purer forms of math while I was still a student, but this'll do in lieu of a time machine.
@KnightMirkoYo Жыл бұрын
Looks insanely powerful and equally insanely hard to apply to real problems, even abstract like comp programming or coding interviews
@Андрей-ю2р6л Жыл бұрын
I believe it could be really powerful if accelerated on GPU. Imagine writing a few lines in Uiua instead of hundreds of lines in OpenCL and getting the same or even better performance
@encapsulatio Жыл бұрын
In your Function Composition in Programming Languages talk you said you won't be talking about Forth or Joy. Well I really want to hear your take on both and what you think they bring to the table that many are underestimating, including array languages.
@TheMrVoidslime Жыл бұрын
I would love to see one of these doing the long form of an established algorithm with many use cases like Fourier transforms or linear regression. These videos have already been wonderful! I've never seen matrix languages before and I'm so happy that you break it down into a way I can understand.
@acelaox6836 Жыл бұрын
Episode one got me started with Uiua. I will master this language.
@r4fa3l59 Жыл бұрын
Would you make a video comparing J, APL, BQN and Uiua?
@code_report Жыл бұрын
I will definitely do that in the future. Kind of what I was trying to do with the "revisiting" the APL vs J vs BQN vs etc video.
@r4fa3l59 Жыл бұрын
@@code_report Wow that's great! I will definitely be waiting
@ivanjermakov Жыл бұрын
The problem with stack-orientation is that in long expressions it's an additional mental load to remember stack state in every position. I much prefer using binds to extract calculations into named variables.
@wliaputs Жыл бұрын
Yea stacked language is more procedural than declarative, which makes understanding the solution from a top-level difficult, but it could be that I have not obtained the ability to decipher a stackful solution without stepping through. However, it’s really good for visualization
@meneereenhoorn Жыл бұрын
I guess it is nice that Uiua supports both stack-based programming and bindings. E.g. write with bindings first, then (possibly) compress.
@nunzioturtulici9636 Жыл бұрын
Actually I think Uiua is great. Yes, there's a stack, but you can look at it abstractly as a way to define the computational graph under the algorithms (i.e. functions). It is in my opinion more clear than using many combinators.
@IWasAlison Жыл бұрын
Understanable sir.
@garthgoldwater5256 Жыл бұрын
have you seen the talk (here on youtube) concatenative programming: from ivory to metal? i think you’d love it (topics: stack-based languages as the combinator calculus, implementing stuff fast, linear types, a little apl from backus’s turing speech, continuations)
@encapsulatio Жыл бұрын
Yeah that talk is what he needs to see and why I think a lot more should be interested in what concatenative programming as described in that talk can bring to other paradigms, including array languages. Maybe have Jon Purdy invited on Arraycast since he is familiar with programming language design and could update us on what other things he was not able to cover in that talk that we might be missing out.
@mccGoNZooo Жыл бұрын
I feel like we're seeing a new chapter in The Life of Conor Hoekstra where stack-based languages are now the new friend. :D
@yash1152 Жыл бұрын
9:34 why ain't the mod given the `%` glyph?
@red13emerald Жыл бұрын
I'm not the language designer, but I think this has to do with the visual approach to reading and typing glyphs. ◿ to me represents a partial graph of the modulus function. For y=(x mod a), it rises linearly until y reaches a and then jumps down to zero again. % is not a great candidate for modulo, because you have /, \ and ∧ for reduce, scan and fold, which makes clear they are very related and even visualises the difference in their application. For the numerical operators, you don't have * and / as in other languages, but × and ÷, which I would argue is actually easier to read for anyone not used to programming. But now the visual relationship you have in other languages between / for division and % for the remainder is broken, so considering a completely new glyph makes sense. % also has the issue of being visually bigger and thus appearing more significant than the other numeric operators, which it isn't.
@pluieuwu Жыл бұрын
uiua is ngl so much more intuitive 😂 love the new content ❤
@yash1152 Жыл бұрын
this whole combination (given below) finally made me understand what was being done here: this sound suuuper obvious, to the point of being dumb. but what can i say, i was lost in glyphs & concepts & combinator names & didn't really catch what the output was corresponding to. * function (fxn) is being defined up top - those operators/combinators will work on the parameter(s) * parameters in definition: can be formal, or in case of tacit, be implicit. * thereafter, fxn is called with actual parameters (the input array) being supplied already * result shown live at bottom as the function definition is being updated THINGS which helped: * 1:53 2:02 _"These are 2 test cases, Answer to the first is 21, to the second is 63"_ * answer written in source, * the "Show" keyword * Reading "Friendly glyphs" section of uiua website * 5:17 5:32 _"This sol is mentioning our args: x, & x again"_ * 8:24 8:42 _"in uiua pad ... we gonna call length:_ returns 6; _then range:_ returns [0..5] _"_
@larionov999 Жыл бұрын
I wonder which language will be the favorite one
@brendanhansknecht4650 Жыл бұрын
I wonder how this effects pronouncability? As in, generally in apl, you can read from left to right to describe algorithms in a human inderstandble form. The blank of the blank of the blank....not sure that works when you have to track the stack.
@red13emerald Жыл бұрын
I'm not sure, to me it's easier to talk about it in blocks of pseudocode from right to left: Duplicate the input, get length, duplicate length, create a range, add one, modulus length, check if 0, multiply input with that mask, power of 2, reduce add. Reading from left to right it would be: The sum reduction of the list of squares of the result of applying a mask of the elements where modulus of the length of the input over the index of each element is 0, but that doesn't quite fit the evaluation order or the naming of the operations.
@brendanhansknecht4650 Жыл бұрын
@@red13emerald the big issues is that if you get a large chain of blocks and want to understand them, you have to track the entire stack in your head. Also, normal array languages tend to be quite readable once you learn the rules. But I do agree that this is probably easier to understand without learning anything new. Programmers already understand stacks and don't have to learn trains.
@lionbryce10101 Жыл бұрын
"It does make it hard to read" yeah you're telling me, lol
@kibels894 Жыл бұрын
Stack, BASED
@brendanhansknecht4650 Жыл бұрын
So is this essentially a battle of combinators/trains vs stack for tacit and operation ordering?
@red13emerald Жыл бұрын
There is no battle, stack-based is easier to write, read and reason about and thus 100% better in every regard 😇
@brendanhansknecht4650 Жыл бұрын
@@red13emerald I'm definitely not convinced. Tracking a stack of values is much more overhead than tracking a train (only 2 live values at a time) or named variables.
@jamesfenn6249 Жыл бұрын
good forth programmers keep the stack shallow within their word definitions.
@MrAbrazildo Жыл бұрын
8:00, here you had 18, but here 8:23, 19. I didn't get why 7 was approved.
@ferdynandkiepski5026 Жыл бұрын
Is UIUA compiled or interpreted? How is its performance compared to other programming languages?
@NikolajLepka Жыл бұрын
Connor; as much as you love your combinators, I think you've gone a bit too far into the deep end of combinator speak. I have no idea what a sigma combinator does, so using more laymany terms would probably be better for people watching your videos who aren't as far into the combinator deep end as you are
@darrylkid210 Жыл бұрын
Agreed. It's a niche academic area akin to talking about lambda calculus. It's more likely that a viewer has little background in combinators than someone who is an expert at them. It would be great to briefly explain what the combinator does after he mentions it. At least we would be able to catch on with it.
@CatsFerLife6 ай бұрын
I know this video is uber old comparatively but I wanted to point out that in the BQN solution, you theoretically could’ve also used an after instead of right tack multiplies.. it doesn’t end up saving characters but I do love the symmetry of having both before and after (or Σ and S) in the same solution
@japedr Жыл бұрын
Interesting, so there is no need to learn tons of combinator patterns to use it. I'm sold on this. I'll probably learn about combinators one of these decades when I find the spare time to do so 😂
@seethruhead7119 Жыл бұрын
the combinators are my favourite part! but Uiua is objectively brilliant
@brettknoss486 Жыл бұрын
Would an array language be useful for developing vector databases?
@alkeryn1700 Жыл бұрын
you are pretty much smashing keywords in your comment, could you do it, yes, does it make sense, probably not for many reasons. 1) you wouldn't be using tons of good libraries that already exist in many languages. 2) the community of people that could contribute would be very small 3) a database is a lot more than just computation, you'd also need to interact with the os, manage memory, etc. 4) there are definitely a whole load of other reasons. anyway, that would not be practical to do at all, and anytthing that can be done with an array language can be done without, that's quite a lot out of their scope, they can be very useful for numerical work but a vector database is a lot more than that.
@torarinvik4920 Жыл бұрын
How do they make these beautiful glyphs?
@red13emerald Жыл бұрын
Unicode, and a well-designed font. While you can copy uiua code to basically anywhere (for example: ▽¬⍜⇌\×∊,) and it will display "correctly", the website specifically recommends the font "DejaVu Sans Mono", which the code looks a lot better in.
@nunzioturtulici9636 Жыл бұрын
I guess in uiua you can replace "=0" with "not". Thanks for your wonderful videos.
@firstname91506 ай бұрын
Loving Uiua 👍🏻
@wargreymon2024 Жыл бұрын
astonishing
@arshamshayan Жыл бұрын
Man, how do you even type these symbols💀
@bzboii Жыл бұрын
we wa
@DanelonNicolas Жыл бұрын
Chesus Christ!
@librarygangster9108 Жыл бұрын
haskell : sumOfSquares = length >>= flip execState 0 .* g where g = flip zipWithM [1..] . f f n i a = when (n `mod` i == 0) $ modify (+ a * a)
@librarygangster9108 Жыл бұрын
or: sumOfSquares = length >>= getSum .* f where f n = ifoldMap $ \i a -> if n `mod` (i + 1) == 0 then Sum (a * a) else mempty