Computer Science ∩ Mathematics (Type Theory) - Computerphile

Поделиться
HTML-код
  • Опубликовано: 22 янв 2025

Комментарии • 502

  • @tzimmermann
    @tzimmermann 8 лет назад +365

    The guy Gérard Huet behind Coq also wrote some data structure he called The Zipper. Apparently he said in conference during a demonstration: "Now I'm gonna open the Zipper and show you my Coq".
    Source: someone at INRIA who knew Huet told me.

    • @kevinpacheco8169
      @kevinpacheco8169 8 лет назад +10

      Terrence Zimmermann Now that you can't make up.

    • @tzimmermann
      @tzimmermann 8 лет назад +30

      Kevin Pacheco I didn't. I assume the guy wasn't trying to troll us when he told the story during a dinner (with mainly scientists and engineers), because well, he wasn't the trolling type. And you can check that Huet actually invented the Zipper (a kind of tree data structure).
      Of course, what I said doesn't constitute a proof, but that's all I have.

    • @Foagik
      @Foagik 8 лет назад +3

      A Huet Zipper isn't necessarily a tree-like structure, but you can make a Huet Zipper of a tree. A zipper is more or less a structure that gives the notion of a cursor on an underlying structure such that there's O(1) operations on whatever's underneath the cursor, and it has several operations for moving that cursor around said structure.
      If you want to see some trolling, try out McBridge's presentation to the Haskell Implementors Meeting, '09 about the Haskell Preprocessor.

    • @tzimmermann
      @tzimmermann 8 лет назад

      +Foagik Thanks a lot for the info, I am undoubtedly uninformed about that kind of structure as I never needed to use one. That seems quite powerful, I've downloaded Huet's paper for further understanding.
      Conor McBride, right? I don't seem able to find this presentation, is it on yt?

    • @attrapehareng
      @attrapehareng 8 лет назад +11

      I've worked with people at the INRIA and that's totally the kind of humour they have! I have no problem believing this story!

  • @yepperdeedooda
    @yepperdeedooda 8 лет назад +551

    I'm starting realize that just because I come here, it doesn't mean I'm smart.

    • @kevinpacheco8169
      @kevinpacheco8169 8 лет назад +2

      Ксения Ковалевская lolz...

    • @wereNeverToBeSeenAgain
      @wereNeverToBeSeenAgain 8 лет назад +16

      You're wandering into the trolls' dungeon, you might find yourself getting too much attention from those who are smart.

    • @IllumTheMessage
      @IllumTheMessage 8 лет назад +24

      It's just learning the terminology. You are smart.

    • @yepperdeedooda
      @yepperdeedooda 8 лет назад +8

      Zod 'kneel before Zod.' You were awesome.

    • @yepperdeedooda
      @yepperdeedooda 8 лет назад +2

      ***** I wish it applied to me in class. I'm horrible at math.

  • @Ikkarson
    @Ikkarson 8 лет назад +509

    Mathematicians should wear robes and pointy hats and be interviewed in front of some copper plated bubbling apparatuses (apparati?). Then replace "theorem" by "curse", objects by "demons", and demonstrations by "invocation". "First evoke a local Riemann-integrable demon. the Fundamental Curse of Analysis allows you make sure you can restore that demon when you observe its growth." Cedric Vilani is the headmaster of the Lyon School of Wizardry and professor of Implicit Demons Taming.

    • @mduckernz
      @mduckernz 8 лет назад +5

      Antonin Caors haha, yeah 😌 Master of Demon Invocations

    • @mduckernz
      @mduckernz 8 лет назад +13

      Amandeep Kumar Come now, there's not even any DnD references yet! 😅

    • @garetclaborn
      @garetclaborn 7 лет назад +2

      what? they are. wait where do you guys live?

    • @jeongheonlee4556
      @jeongheonlee4556 7 лет назад +4

      New name for mathematics: demons taming

    • @EpicFishStudio
      @EpicFishStudio 7 лет назад +1

      this sounds just so cool.

  • @gulllars4620
    @gulllars4620 7 лет назад +80

    As a programmer, this makes so much sense. I was in a weird situation where i learned algebra first, and then learned programming (and algorithms and data structures), and then more maths, and i couldn't help but think how i could represent the concepts i learned in computer code, but the notation used in maths was set theory, which was slightly confusing some times. Then i noted to a lecturer that a definition he wrote of something could be expressed as a short recursive function, and turns out he knew (among other things) haskell and he agreed that the recursive notation was correct, but pointed out that you can solve some such functions which may be noted recursively using transformations that allow you to do it as one computation instead of a series of computations (iterative), which can dramatically impact the time they take to run, and he had done work on that. Using maths to speed up some heavy logic functions by transforming them.
    Anyways, my big take-away is i'm fairly decent at maths, but i'm a bad calculator, and i strongly prefer computer science notation over set theory notation. If i had been taught maths through programming the concepts, i would have done MUCH better, and it would also have allowed running the functions and (automatically through code) visualizing the output to gain a better "feel" for it.

    • @SuperDrdoof
      @SuperDrdoof 3 года назад +8

      As a unsuccessful student of mathematics who went to computer science I think, it's because computer scientists care much more about the style of notation and are better trying to find the right language which describes their current problems.

    • @allenx6309
      @allenx6309 3 года назад +1

      Wow, this is soo true.

    • @dabrownone
      @dabrownone 3 года назад

      But you can also tail call optimize at the compiler level.

    • @lawrencedoliveiro9104
      @lawrencedoliveiro9104 3 года назад

      John McCarthy, the father of LI

    • @lawrencedoliveiro9104
      @lawrencedoliveiro9104 3 года назад

      SP, relates how he tried to suggest to mathematicians that functional LI

  • @peanut1110
    @peanut1110 8 лет назад +545

    Didn't know Thor was into maths

    • @ToastiLP
      @ToastiLP 8 лет назад +16

      Hehehehe...get it? Because his name is Thorsten

    • @Kram1032
      @Kram1032 8 лет назад +1

      lol red

    • @AndersJackson
      @AndersJackson 8 лет назад +2

      Thors stone...

    • @nm18996
      @nm18996 8 лет назад +3

      math*

    • @arturmizuno
      @arturmizuno 8 лет назад

      it's maths, not math, stop omitting words

  • @unvergebeneid
    @unvergebeneid 8 лет назад +437

    Drink a shot every time he says "ja".

  • @eightrice
    @eightrice 4 года назад +91

    "A function which doesn't function shouldn't be called a function"
    Real-life James Bond Villain - 2017

    • @aperson4051
      @aperson4051 4 года назад +3

      I will die a happy man when the producers of James Bond finally hire this man to be their evil genius.

    • @Triantalex
      @Triantalex Месяц назад

      false.

  • @MaxPicAxe
    @MaxPicAxe 3 года назад +1

    RUclips is great at suggesting videos. I am starting college and covering set theory, and I realized that there are multiple encodings for natural numbers and that implementation details were being exposed. And then I find this video which mentions the same thing. Amazing.

  • @Aaku13
    @Aaku13 8 лет назад +9

    Man, this dude is so intelligent. He just pulls all this theory history out of his head; its awesome.

  • @jamma246
    @jamma246 5 лет назад +6

    Thorsten is a great explainer and talks about some really subjects - liked this video!
    You guys should also track down Kevin Buzzard. He's a great speaker, interesting guy, and he's recently been working on proof formalisation in a language called Lean. He and students have been writing up a whole bunch of definitions/theorems/proofs, and is planning to do his whole department's curriculum.

  • @ShubhamBhushanCC
    @ShubhamBhushanCC 8 лет назад +268

    Mathematical Poofs! I love this guy

    • @GilesBathgate
      @GilesBathgate 8 лет назад +28

      He uses the coq system for his poofs!

    • @polishal9061
      @polishal9061 8 лет назад +4

      Shubham Bhushan is this about Alan Touring :D ?

    • @nazgullinux6601
      @nazgullinux6601 8 лет назад +6

      *Alan Giedrojc*
      "...Alan Turing"

    • @rajshrisukhdeve9200
      @rajshrisukhdeve9200 4 года назад

      @@GilesBathgate bun

    • @kviknayt
      @kviknayt 4 года назад

      War is Peace - Freedom is Slavery - Ignorance is Strength.

  • @MaceOjala
    @MaceOjala 8 лет назад +3

    That was really fascinating. I have heard of type theory but didn't know much more that it resembles types in programming. He contrasts it to set theory which helps a lot and makes sense. What we seem to have here, as he is saying, a potential, qualitative (of course partial) transformation of a field, mathematics, because new tools, computers, bring new paradigms. Fascinating, thank you so much. I would be happy to see some more of this, and maybe some examples from this style of math.

  • @kimchikoalaa714
    @kimchikoalaa714 8 лет назад +3

    I recently signed up for CS in school, and math class is doing set notation. A youtube title has never been so relatable.

  • @ElagabalusRex
    @ElagabalusRex 8 лет назад +101

    I think this would have been more clear if we had examples of some useful types that propositions and their proofs could take.

    • @Bratjuuc
      @Bratjuuc 4 года назад +3

      I could provide some really simple examples in Idris or Agda, if you're still interested, but it takes a bit of knowledge Haskell-like syntax.

    • @gileee
      @gileee 3 года назад +1

      This was more like a history lesson than an explanatory video

    • @bimbumbamdolievori
      @bimbumbamdolievori 3 года назад +2

      Still this is very interesting stuff

    • @ivanpiri8982
      @ivanpiri8982 2 года назад +1

      @@Bratjuuc are u still willing to provide examples in agda? I'm currently studying this subject and the lack of examples is killing me

    • @Bratjuuc
      @Bratjuuc 2 года назад +1

      @@ivanpiri8982 Oof, that was pretty long ago. I forgot what I wanted to provide as examples back then.
      I'm going to need some time revising, but I'm still willing to provide examples. I would prefer to provide them in Idris purely for syntax reasons.
      So far I can illustrate the following:
      *) Boolean logic.
      *) maybe Existential quantifications
      I'll probably update the list in a short amount of time.

  • @eliastandel
    @eliastandel 8 лет назад +78

    So it seems our galactic president Beeblebrox is into type theory.
    BTW, great video! Love this more theoretical approach to Computerphile!

    • @JonathanWinterflood
      @JonathanWinterflood 8 лет назад +1

      He must have painted his seond head Pink, too

    • @RiRiDingetjes
      @RiRiDingetjes 8 лет назад +3

      Yeah totally agree! Altough I wish he would have written down something

    • @Triantalex
      @Triantalex Месяц назад

      false.

  • @filipkralj2618
    @filipkralj2618 8 лет назад +254

    "coq could upset english speakers" LOL
    and they say Germans dont have a sense of humor

    • @steliostoulis1875
      @steliostoulis1875 6 лет назад +2

      cofi 41 French*

    • @badradish2116
      @badradish2116 6 лет назад +2

      i think he meant the speaker, but isnt he like dutch or something?

    • @roy04
      @roy04 4 года назад +1

      @@steliostoulis1875 I think that was intentional

    • @Triantalex
      @Triantalex Месяц назад

      false.

  • @VoltzLiveYT
    @VoltzLiveYT 8 лет назад +20

    The jist of the curry-howard correspondence is:
    In a well-typed programming language (such as Coq, Agda, Idris etc.)
    Types correspond to theorems
    Programs correspond to proofs.
    You write the type, then you prove it by writing a body to that function.

  • @suorm-net
    @suorm-net 8 лет назад +1

    Underneath Type Theory there is a more foundational mathematical approach called Category Theory, which seems to unify all areas of mathematics. Unsuprisingly, Types form a Category. Just as there is a connection between Homotopy Theory and Type Theory, there is a connection between eg. Set Theory and Topology Theory via Category Theory and the theorems of one theory correspond to theorems of the other. I suggest you look into that.

  • @lorenzvo5284
    @lorenzvo5284 8 лет назад +180

    Proof theorems ja. samsing wrong wis se pruuf.

  • @2Cerealbox
    @2Cerealbox 8 лет назад +30

    I think the guy behind this saw us complain about the 404 video and is now giving us some meatier content. I'm happy. :)

  • @Nim2
    @Nim2 Год назад

    I know I'm late but props to the one(s) who made the subtitles. Very creative with using the relevant symbols.

  • @uberobserver
    @uberobserver 8 лет назад +31

    More vids on Haskell and functional programming would be great!

  • @jayjeckel
    @jayjeckel 8 лет назад +1

    We are happy to welcome you mathematicians into the programming world, but there is one thing you need to learn fast and constantly repeat to yourselves if necessary: Single character identifiers are not acceptable! Use full words and clear and consistent naming conventions. Learn it, live it, love it.

  • @jimamsden
    @jimamsden 2 года назад +1

    I think of mathematical proofs as a mechanism for problem-solving and gaining understanding while producing useful outcomes. Consider machine learning vs. algorithms. Machine learning can develop a function based on a training set that we can use to predict results from other inputs. That's great, but it doesn't necessarily lead to expanding our understanding of the underlying principles, things that we can use to help solve other more general problems.

  • @honkatatonka
    @honkatatonka 8 лет назад +6

    Ok, the comments have spoken: "Dr. Thor" it is
    Edit: very interesting! Thanks for doing these!

  • @avibank
    @avibank 6 лет назад +1

    This is exciting.
    Just finished Group Theory and this seems like something I can learn from a text book now.

  • @rogierbrussee3460
    @rogierbrussee3460 Год назад +1

    Surprising as this may seem, Mathematicians seldom bother with sets in practice. In fact they already use mathematical constructions pretty much exactly like how it is described with types.
    For example the natural numbers N, defined as a set together with a preferred element 0 and a function s:N ->N that gives the successor (programmers would call it next) which is "universal" with this property (in the precise technical sense below), is enough to define N unique up to _unique_ isomorphism (= bijection), and that is perfectly good enough to work with it and ignore any implementation details and it nicely avoids asking silly questions like whether 2 \in 3 because they are not preserved under these isomorphisms.
    Here a set of natural numbers (N, 0 , s) is _universal_ if it has the following property: for any set X, element x \in X and any function T:X->X, there is a unique function f: N->X such that f(0) = x and f(s(n)) = Tf(n) (from which it easily flows: f(n) = T^n(x)). Of course one now has to prove that such a set exists (surprise surprise, it does).

    • @AndreiGeorgescu-j9p
      @AndreiGeorgescu-j9p Год назад

      This is still an implementation detail. Type theory and category theory abstract away all of this and just have the type N.
      What you're describing is a declarative but iterative way of describing a set, which really isn't any better from my perspective than set builder notation, which is also declarative and how the highest abstraction of iteration is expressed in functional languages.
      In fact what you're describing is two levels of abstraction lower than set builder notation which is considered implicit iteration while the iterator you're describing here is external iteration

  • @ChrisHinton42
    @ChrisHinton42 8 лет назад +4

    It will be interesting to see if a type theory is developed in which univalence is a theorem rather than an axiom

    • @ThorstenAltenkirch
      @ThorstenAltenkirch 8 лет назад +2

      Check out the cubical system made at Chalmers university.

  • @FreeScience
    @FreeScience 8 лет назад +45

    I was surprised that he managed to talked about set, type and homotopy theory, abstract mathematics and new foundations of mathematics without mentioning category theory.

    • @mdmenzel
      @mdmenzel 8 лет назад +8

      Calle Silver-Granhall I think because category theory is more difficult to explain to a general audience than the other three. Also, previous videos have alluded to type theory and set theory.

    • @mikidep_old
      @mikidep_old 8 лет назад +3

      There is some on the whiteboard on its back...

    • @AnarchoAmericium
      @AnarchoAmericium 8 лет назад +2

      I doubt it.
      Category Theory isn't hard.

    • @abenezerfetsum3632
      @abenezerfetsum3632 Год назад +1

      Literally every thing he mentioned would have been way easier if he did a quick recap of category theory and what it is. I mean basically everything he talked about was under category theory.

    • @Triantalex
      @Triantalex Месяц назад

      ok?

  • @worldboy9684
    @worldboy9684 4 года назад +2

    This is awesome, my mind is blown and I feel much better

  • @illustriouschin
    @illustriouschin 8 лет назад +60

    I'm pretty sure the only people who understood what he was saying already understood everything beforehand.

    • @MonkeyboyGoku
      @MonkeyboyGoku 7 лет назад

      Gordon Chin roughly

    • @grn1
      @grn1 3 года назад

      I had to rewatch it but I think I got it down. Abstract math isn't exactly my forte though.

    • @dailydoseofcyr2823
      @dailydoseofcyr2823 3 года назад +2

      I think if you have a first year discrete math class or even maybe a high school computer engineering class under your belt, you should be able to follow along

    • @astroid-ws4py
      @astroid-ws4py Год назад +1

      First year Discrete Math couse is enough

    • @AndreiGeorgescu-j9p
      @AndreiGeorgescu-j9p Год назад

      Having a degree in CS should be enough to understand what he's saying

  • @OwenPrescott
    @OwenPrescott 8 лет назад +39

    Need a proof? Bring on the COQ.

  • @StarLink149
    @StarLink149 8 лет назад +9

    For those who don't know, "coq" means "rooster" in french.

  • @isaacdavid2491
    @isaacdavid2491 8 лет назад +2

    gotta love the category theory diagrams on the back

  • @DavidVaughan00
    @DavidVaughan00 8 лет назад +6

    Eyyy funny stuff, I just used Coq a month ago for researching a class project. I was writing a paper on using recurrent neural nets to automatically write proofs in a Coq-like language. I was not successful - turns out it's pretty hard to do, lol

  • @uberobserver
    @uberobserver 8 лет назад +1

    Excellent video on a relatively new field of study with a real future!

  • @josnardstorm
    @josnardstorm 8 лет назад +2

    Wow. Brady's really bringing in the big bucks. He brought in the scientist from Independence Day.

  • @hankigoe829
    @hankigoe829 5 лет назад +6

    Top 10 programming languages to learn in 2020: 1. Type theory 2. Type theory 3. (wait for it) Type theory ...

  • @0lifinz
    @0lifinz 8 лет назад +6

    can someone explain what this math on the whiteboard behind him is about?

    • @kovacsandras
      @kovacsandras 8 лет назад +16

      It's about his research for formalizing type theory inside type theory. Basically, if lots of math can be expressed in TT, why not try TT itself as well? Since proofs in TT are executable programs, modeling TT inside TT is also a way of doing metaprogramming and proving properties of metaprograms in the same system.

    • @anttikarttunen1126
      @anttikarttunen1126 8 лет назад +1

      Until a latter day Gödel arrives. (this is a reply to András Kovács's comment below).

  • @macchiato_1881
    @macchiato_1881 Год назад

    I have been studying formal mathematics for my Computer Science thesis for a little while now. And looking back on it, I think Set Theory has its priority backwards. Set Theory tries to take two Sets of elements, and tries to evaluate whether a function definition exists as a pathway between these two sets. Type Theory takes a set and a function definition, and uses it to generate elements of another set, which can be used as proofs for the other set.
    How I understand it is that: Set Theory is like a funky subset of Type Theory because Set Theory deals with concrete definitions generated from abstract ideas, whereas Type Theory works the other way around. In a way, this is more useful and powerful than Set Theory because you can easily create various definitions of a set of elements that would otherwise be hard to do using Set Theory. It's not impossible. It's just hard...

  • @matrixstuff3512
    @matrixstuff3512 6 лет назад +1

    I like to think that I know quite a lot about both mathematics and computer science, but this goes way over my head

  • @orlinzer123
    @orlinzer123 8 лет назад +20

    Please do video on backpropagation algorithm in neural networks

    • @JohnnyDoeDoeDoe
      @JohnnyDoeDoeDoe 8 лет назад +2

      or linzer computerphile, don't be afraid to get a bit technical!

    • @mrnarason
      @mrnarason 7 лет назад

      or linzer 3blue1brown did that video recently

    • @Triantalex
      @Triantalex Месяц назад

      ??

  • @Zero0exe
    @Zero0exe 8 лет назад +8

    6:43 or as Mr. Numberphile would call it: The Parker Function.

  • @animowany111
    @animowany111 8 лет назад +19

    Could you talk about the Haskell type system?

    • @Bratjuuc
      @Bratjuuc 4 года назад +1

      Not as rich as COQ, Agda or Idris ones

    • @Triantalex
      @Triantalex Месяц назад

      ??

  • @ConnorwithanO
    @ConnorwithanO 8 лет назад +5

    So would Type Theory make it possible to compile abstract math into executable code? I ask because that is basically what I dream about.

    • @kovacsandras
      @kovacsandras 8 лет назад +1

      Yes.

    • @ConnorwithanO
      @ConnorwithanO 8 лет назад +1

      Cool!

    • @i.donthaveanameanymore
      @i.donthaveanameanymore 8 лет назад +2

      Kind of... although in general when you compile type theory it's more along the lines of interpreting it. For example, for a Coq proof to be "proven," all you have to do is compile it and there's nothing left to execute. So in a sense, executing the abstract math happens as your proof gets verified. As a result, it doesn't feature many tools for writing executable code (although it does allow you to "extract" the code into another language that can provide the tools for writing useful programs). You can also use some other languages to compile type theory programs into executable programs (Idris and ATS, for example).

    • @xybersurfer
      @xybersurfer 8 лет назад +2

      no. you would have to create a proof to have a program (proofs are programs). and proving in Coq is much harder than conventional programming

  • @EDYMOT4991
    @EDYMOT4991 8 лет назад +2

    can you make videos explaining type theory and how math ideas can be proven with it?

  • @SSJHF
    @SSJHF 7 лет назад

    Dr Thorsten Altenkirch
    At 13:50, you talk about the Univalence Principal, where it is stated that if two things are equivalent, then they are equal.
    I have interpreted this as "If two things are logically equivalent, then they have the same properties.
    I shall show by example that this is not always the case:
    From the premises "forall x (Sx implies Px)", it can be proved that "Exists x (Sx & Px) iff Exists x(Sx)
    Using this example, I shall prove that if two logical expressions are equivalent, they don't necessarily have the same properties. In this example the property they don't have in common will be truth value.
    Take both Sx and Px to be "x=x". Substitution gives (1):
    "forall x (x=x implies x=x)"
    can prove
    "Exists x (x=x and x=x) iff Exists x (x=x)" (1)
    However, by the principal of transposition, it will also be true that (2):
    "forall x (not (x=x) implies (not x=x))"
    can prove
    "Exists x (not x=x) and (not x=x)) iff Exists x (not x=x)" (2)
    Example (1) has a truth value of true, however that of (2) is false. (x=x is always true, likewise (not x=x) is always false.)
    Thus if two statements are logically equivalent, they do not always have the same properties. Using transposition again, this means that if two statements have the same properties, they are not always the same statement.

    • @ThorstenAltenkirch
      @ThorstenAltenkirch 7 лет назад +1

      I didn't mean "logical equivalence" but logical equivalence is a special case. Indeed all operations on propositions in type theory are "truth functional". I don't understand your counterexample in particular I don't know what the principle of transposition is. I have no idea how you justify the step form (1) to (2).

    • @SSJHF
      @SSJHF 7 лет назад +1

      It turns out I made a mistake in the proof. I found out that I had used a universal specification rule on a negated universal statement. Because it was negated it was existentially quantified and the rule couldn't be used. Sorry about that. (Thanks for the reply though)

    • @ThorstenAltenkirch
      @ThorstenAltenkirch 7 лет назад

      Alex Armstrong no problem. And cheers to you for experimenting and dis overnight your own flaw.

  • @thesam723
    @thesam723 8 лет назад +3

    I super enjoyed this video

  • @OwenPrescott
    @OwenPrescott 8 лет назад +38

    This guy takes no.3 spot after the Klien bottle and Japanese guy.

    • @patrickwienhoft7987
      @patrickwienhoft7987 8 лет назад +5

      No way. Matt and James come before him by a long shot.

    • @Ludix147
      @Ludix147 8 лет назад +1

      Patrick Wienhöft but they are over on numberphile ;)

    • @OwenPrescott
      @OwenPrescott 8 лет назад +1

      Patrick Wienhöft
      I'm talking on the "looks like science/math" scale. Although I think James could compete with this guy. Oh I forgot the Chemistry guy too!

    • @AlRoderick
      @AlRoderick 8 лет назад +3

      I was going to say, no one looks more like science than Prof. Sir Martyn Poliakoff.

    • @patrickwienhoft7987
      @patrickwienhoft7987 8 лет назад +1

      Well, then Tadashi shouldn't be there. He just looks like an ordinary Japanses.
      The chemistry guy obviously belongs in there then, yes ^^

  • @davidgillies620
    @davidgillies620 7 лет назад +1

    Formal methods are getting more and more important as systems grow. For things like blockchain processing one approach to proving correctness is Hoare's Communicating Sequential Processes. Then there's Predicate Transformer Semantics etc.. It all gets very complicated.

  • @guy12343456
    @guy12343456 8 лет назад +5

    Is Computer Science consider a subfiled of Mathematics? It has its origins rooted in Set Theory, Graph Theory, and other mathematical fields, so wouldn't it be redundant to say "Computer Science union Math" when describing Type Theory?

    • @guy12343456
      @guy12343456 8 лет назад

      My bad, "Computer Science intersection Math"

    • @binarycat1237
      @binarycat1237 8 лет назад

      computer science is applied maths

    • @Vulcapyro
      @Vulcapyro 8 лет назад +2

      There are subjects in Computer Science unrelated to Mathematics. There are subjects in Mathematics unrelated to Computer Science. The symmetric difference is going to be nonempty.

    • @htmlguy88
      @htmlguy88 8 лет назад

      +Vulcapyro like ?

    • @JohnDoe-qx3zs
      @JohnDoe-qx3zs 8 лет назад +3

      +htmlguy88 Computer science includes a lot of subjects related to the physical and practical aspects of computing, such as real world efficiency, caching, representation of human language text, issues with human-machine interaction, making the work less error prone etc. Mathematics includes subjects that cannot be accurately represented in computers, such as infinitely precise numbers, infinitely large sets, the entire field of mathematical analysis (differential and integral calculus) etc.

  • @joses.5943
    @joses.5943 8 лет назад +1

    could we have a second video perhaps going more into detail of type theory maybe xsome examples of its uses. pls

  • @m13m
    @m13m 8 лет назад +3

    What are the axiom of mathematics which can be used to derive entire mathematics?

    • @Kram1032
      @Kram1032 8 лет назад +9

      there isn't just one set of axioms you can use and how you choose changes what you can show.

    • @matekon2
      @matekon2 8 лет назад +8

      Kram1032 the most popular i would say are the zermelo fraenkel axioms, which are essentially rules you can follow to built sets

    • @m13m
      @m13m 8 лет назад

      Kram1032 it's weird that i was playing with lean yesterday.

    • @IchBinKeinBaum
      @IchBinKeinBaum 8 лет назад +12

      While there are several sets of axioms which you can use as base for most of your math there is actually no set of axioms which
      - you can derive all maths from
      - is complete (i.e. every true statement can be proven to be true), and
      - is free of contradictions (i.e. no statement can be proven true and false).
      This is known as Gödel's incompleteness theorem.

    • @davidwuhrer6704
      @davidwuhrer6704 8 лет назад +6

      The Peano axioms mentioned in the video are probably the easiest to get started with.
      However, mathematics wouldn't be what it is if you could not devise your own systems. Bill Gosper famously delivered a proof about polynomial division just by optimising working code.
      Besides, mathematics is proven to never be complete. Deriving its entirety is an absurd idea. Some things are simply true, even though they cannot be constructed. DeMorgan's rules, for example, are proven true by exhaustion, but are not deduced.
      And some things are neither true nor false. And there is proven to be no end to such things, no matter how many you define axiomatically.

  • @dukeradwardthe5th843
    @dukeradwardthe5th843 8 лет назад +3

    Is there a technical limitation for the 50fps?

    • @RalphInRalphWorld
      @RalphInRalphWorld 8 лет назад +2

      Brix Zigelstein It's because they're Britons and they grew up with PAL.

    • @KuraIthys
      @KuraIthys 8 лет назад +6

      Brix Zigelstein Yes, it's PAL equipment, and also reduces the risk of light flickering effects when filming in areas with 50 hz mains power.

  • @kithsakhai
    @kithsakhai 8 лет назад

    great video hope to see more abstract discussions like this for more computerphile videos! or at least a numberphile video on this but more from the other guys' perspective.

  • @mazed363
    @mazed363 3 года назад +1

    I've always struggled with gaining intuition in abstract mathematical theories because of the set theoretic foundations, (set theoretic definition of topology, for instance)

  • @Luxcium
    @Luxcium Год назад

    I did not find the other part of the video on numberphile maybe someone can pass me the link

  • @jandobbelsteen8953
    @jandobbelsteen8953 8 лет назад

    I just watched this video and to my understanding using HOTT you would be able to show that in fact two different proofs have the same outcome and thus are the same.
    So you would be able to first create a proof and then verify that in fact it is an improvement (more elegant, easier, whatever) to an already existing older proof... ?
    Or, the other way around, you would be able to show that a proof is really different from another proof...?

  • @stevecummins324
    @stevecummins324 4 года назад

    Set theory has the concept of universal set on which a choice function to extract a particular set can be applied....
    Like moving from from everything towards being specific.
    Does universal set include everything that might be constructed?

  • @arnetrautmann9783
    @arnetrautmann9783 5 лет назад

    A function that does not function should not be called a "function". Makes sense on so many levels!

  • @Gooberpatrol66
    @Gooberpatrol66 8 лет назад +1

    Are there any programming languages that deal heavily with type theory?

    • @eideticex
      @eideticex 8 лет назад

      If I understand the gist of type theory correctly. C# seems to fit the bill. Everything in C# has a type and types have well defined interactions. Even type casts are validated against the type hierarchies. As much as I love the language for it's strict adherence to types, I also hate it for that reason. It takes a lot of weird but commonly accepted workarounds to make a functioning program from such a strongly typed language.

    • @xybersurfer
      @xybersurfer 8 лет назад +1

      c# deals with types. but it does not directly deal with type theory. c# is weakly typed because because it is possible to get type errors at runtime. languages like haskell are strongly typed but they don't deal completely with type theory. languages like Coq and Agda deal directly with type theory

    • @jsus159
      @jsus159 8 лет назад

      Nathan Dehnel Haskell or Agda are the language you are looking for.

    • @LukusCannon
      @LukusCannon 8 лет назад

      I second Haskell, check out Lambda calculus before you jump in tho

    • @xybersurfer
      @xybersurfer 4 года назад

      ​@FichDich InDemArschInvalidCastException comes to mind (you can write code that casts an object to anything). NullReferenceException also comes to mind, although that is more of a design flaw where strings and objects are always nullable, that i last heard they would be fixing. it's not as bad as dynamic languages like JavaScript though. i use .NET languages like C# regularly

  • @johnjordan3552
    @johnjordan3552 3 года назад

    11:32
    "It's true that 2 is an element of 3, doesn't really make any sense, right?"
    I mean, isn't 3 basically == | | |
    And 2 == | |
    so there indeed is a *| |* inside 3.
    So 2 is indeed an element of the set called 3

  • @amberstiefel9748
    @amberstiefel9748 Год назад

    10:49 he is onto something imo
    Aesthetics and genres and psychology and visual mediums paired with endless user data

  • @matthewmann8969
    @matthewmann8969 8 лет назад

    Computers along with there parts be it Monitors, Screens, Keyboards, Mouses, Remotes, Modems, Scanners, Printers, Floppy Discs, SD Cards, CPU's, and other devices can go hand in hand whether they are desktops, laptops, I pads, kindles, smart phones, cell phones, palm pilots, and other electronic devices and can serve well if they do not over heat or run out of storage space.

  • @reactiveland3111
    @reactiveland3111 10 месяцев назад

    Where does category theory sit here in relation to type theory and rest?

    • @Gordy-io8sb
      @Gordy-io8sb 8 месяцев назад

      Another freshman university student who thinks he's a genius because he knows CT. Lol.

  • @karlkastor
    @karlkastor 8 лет назад +1

    I actually once used 2 (element) 3 in a Discrete Maths homework where we couldn't use

  • @shamrockfrost1856
    @shamrockfrost1856 8 лет назад +5

    This makes me feel guilty about not having read TAPL for two weeks...

  • @DeoMachina
    @DeoMachina 8 лет назад +54

    I like listening to Dr Thor here
    But I'm gonna be honest, I got lost about 5 minutes in :(

    • @platosrepublic6965
      @platosrepublic6965 8 лет назад +9

      DeoMachina I was lost in his "ja"s.

    • @AlexaDeWit
      @AlexaDeWit 8 лет назад +1

      His name is Dr. Altenkirch. He's not nordic either.

    • @heimdall1973
      @heimdall1973 8 лет назад +1

      Mark, that's because the implementation and representation don't matter. As Dr Thor said, you have 1+1+... or binary or decimal... It also doesn't matter what shape the symbols are.
      I was surprised to find out that the Predators use decimal system the same way as we do, just that symbols for 0, 1, ..., 9 are those funny patterns.

    • @rcookie5128
      @rcookie5128 8 лет назад +1

      haha "Dr Thor", really like it, esecially when i read its an abbeviation of his real name..

    • @Triantalex
      @Triantalex Месяц назад

      ok?

  • @MrAyokunle01
    @MrAyokunle01 8 лет назад +1

    isn't Formal Programming a way of proofing mathematical theorems?

  • @sammclennan3661
    @sammclennan3661 8 лет назад

    More videos of this guy please. I have no idea what he's talking about but... more videos please.

  • @dominiquegibeau2856
    @dominiquegibeau2856 8 лет назад +10

    This video is really abstract to me compared to the other. In some videos the most basic concepts (to me) are explained but this one is really hard to follow, so much stuff is considered to be known and there doesn't seem to be much concrete stuff to relate to. It would have helped if it had been a bit more scripted, may be with examples or something. It's quite hard to get into Dr Thorsten Altenkirch's head for this topic!

    • @AndreiGeorgescu-j9p
      @AndreiGeorgescu-j9p Год назад

      The entire topic is abstract and you'd basically be learning math from scratch to understand it.

    • @Triantalex
      @Triantalex Месяц назад

      ok?

  • @insidioso4304
    @insidioso4304 8 лет назад +1

    We are talking about a type of logic that has to be necessarily less expressive than First Order Logic (that is used for mathematical proofs) otherwise computers cannot help that much.

    • @timh.6872
      @timh.6872 8 лет назад +4

      insidioso The trick is that constructive mathematics works well with the termination requirements for programs and physical computation. To derive equivalence, you simply have to inhabit the type representing the equivalence. The first order logic is derivable from the theory, which is something set theory cannot do.

    • @kovacsandras
      @kovacsandras 8 лет назад +1

      No, ZFC itself can be modeled inside Homotopy TT, for example.

  • @TheodoreWard
    @TheodoreWard 3 года назад

    If it is unable to distinguish between different representations of numbers, is it impossible to do boolean algebra? Is it possible to calculate the result of 42 AND 69 for instance without representing the numbers in binary?

  • @McMurchie
    @McMurchie 8 лет назад

    The biggest problem will be when dealing with infinities, other than memory constraints some of the concepts become quite abstract.

    • @XetXetable
      @XetXetable 8 лет назад

      It's not actually that much of a problem since we can use codata. Consider, for example, if we wanted to represent an infinite sequence of binary digits. We can do this by defining a function from the natural numbers onto the booleans, so that if we want the nth digit, we just issue it into the function defining the sequence. Since the function's algorithm is finite, we can represent the full infinite sequence using finite data.
      Generally speaking, so long as we can define something in finite terms (which is everything we can define in practice, including the concept of infinity itself), we can represent it on a computer using those exact terms.

  • @RandallStephens397
    @RandallStephens397 8 лет назад +2

    Is it wrong that I love the sound of this man's voice more than what he's talking about?

  • @jakejakeboom
    @jakejakeboom 8 лет назад +4

    such a great thumbnail

  • @aperson4051
    @aperson4051 4 года назад +2

    I will die a happy man when the producers of James Bond finally hire this man to be their evil genius.

    • @vincentkubicki1626
      @vincentkubicki1626 3 года назад

      Spelling out a rational plan that works in the end :)

  • @astroid-ws4py
    @astroid-ws4py Год назад

    Nice explantions but I doubt many will understand, I learned Measure Theory and thus can understand the general outline but those unfamiliar will be lost.

  • @mzg147
    @mzg147 8 лет назад +1

    For me, it always been that the sign ∩ was turned 90 degrees anticlockwise in this statement. :)

  • @Ludix147
    @Ludix147 8 лет назад

    this is really awesome and interesting, I will check out set and type theories!

  • @GeorgeLabuschagne
    @GeorgeLabuschagne 7 лет назад

    Could this be used to assist with the verification of the proof to the ABC conjecture?

  • @GordonjSmith1
    @GordonjSmith1 2 года назад

    Really informative and 'enlightening'. My thanks.

  • @kawrno5396
    @kawrno5396 8 лет назад

    I was taught that it is never embarrassing if you prove something and it get established and afterwards someone else proves it to be wrong, because this is how the whole research process works. You prove with what knowledge is available to you; if it gets established that means smart brains in your time can't prove that wrong, they agree with it. And it is alright. 00:30

    • @ThorstenAltenkirch
      @ThorstenAltenkirch 8 лет назад

      It is as embarrassing as designing a phone which goes up in flames.

  • @Arthur0000100
    @Arthur0000100 8 лет назад

    How would you check the infinitude of number of primes via computing??

  • @danielescotece7144
    @danielescotece7144 8 лет назад

    Peano arithmetic is a way of defining natural numbers via induction, I don't understand how it can be use to encode the natural set.

    • @jpratt8676
      @jpratt8676 8 лет назад

      Daniele Scotece Pretty sure what he means is that you represent the natural numbers as the set of things that can be produced from peano's successor function and 0. I.e. {0, 0+1, 0+1+1...}.
      So you define the set by induction. Not sure how to use that efficiently but there's probably some very smart maths for doing it.

    • @danielescotece7144
      @danielescotece7144 8 лет назад +1

      Oh I see that now, thanks sir, always a pleasure to see thoughtful comments on yt!
      Have a nice day

  • @garetclaborn
    @garetclaborn 7 лет назад

    So this may be way off, but is SFINAE (in C++ templates) for type deduction basically using the same relationship to encode logical statements?

  • @user-vq5nz6yk1h
    @user-vq5nz6yk1h 6 лет назад

    What about whitehead and russell? I guess they came up with such an idea way earlier...
    And the problem with a constructibility is that very important theorems couldn't be proven f.e. that every vectorspace has a basis or if you like non-standard analysis or even normal analysis you would loose many theorems that are quite crucial.

  • @pid8307
    @pid8307 8 лет назад

    Did I get this correctly?
    - Set theory is like a declarative programming language and a set may not be enumerable or infinite (termination problem);
    - Type theory is more constructive much like an imperative programming language.

    • @XetXetable
      @XetXetable 8 лет назад

      No, if anything, it's the opposite, as type theories tend to be functional languages.
      Set theory isn't like programming at all. It's a completely static logical system which, by default, has no computational interpretation.
      Type theory exists so that a computer can internalize the semantics of what a program is meant to do. If you want a program to sort a list, you can use type theory to define what it means to sort a list, then a type checker verifies that the program meets that specification within that type. What's significant is that, at the extreme ends of expressiveness, this is sufficient to act as a foundation for mathematics.

  • @1000animeboy
    @1000animeboy 8 лет назад +49

    This guy looks like the scientist from Independence Day!!!

  • @Swiftclaw123
    @Swiftclaw123 8 лет назад

    Where are the helpful pictures :(

  • @prathameshausekar
    @prathameshausekar 4 года назад

    Can anybody relate this with typescript, babel and how types(shapes) are identified and are considered to be interpreted into another types. Like replacing a type instance with another equivalent instance which do the work.

  • @ClassicPass_
    @ClassicPass_ 8 лет назад

    But is the Coq Homotropic?

  • @jeongheonlee4556
    @jeongheonlee4556 7 лет назад

    I was watching with subtitle, and i saw he was gonna have to pronounce Coq, and couldnt wait to hear that.

  • @AlvaroALorite
    @AlvaroALorite 3 года назад

    11:35 I'd say that DOES make sense. In order for a set of 3 things to exist, a set of two has to exist in it, and so on. I think pure abstraction in mathematics is a covert Form of idealism. So the definition that you said makes no sense, seems to me that does makes sense if you have a materialist view of the world by wich Mathe matics are done ON the world and not outside of it. This definition in set theory makes sense because numbers are based on perception, by which we can assimilate to distinct objects as Bein the same thing (equality) and grouping them together, which is counting them.

  • @zubmit700
    @zubmit700 8 лет назад +1

    Thanks! Very interesting.

  • @BlackHermit
    @BlackHermit 8 лет назад +2

    I'm a Swedish mathematician as well.

  • @justinward3679
    @justinward3679 8 лет назад

    How do I get coq?

  • @lovaaaa2451
    @lovaaaa2451 6 лет назад

    Seems weird not to mention that HTT is not a developed field and the idea of it functioning as a new foundation for mathematics is only a hypothesis, there are many theorems left to prove before one can conclude that the theory is powerful enough to be able to build all mathematics from it like one can do with set theory. Still a really fun prospect for research though.

  • @snippletrap
    @snippletrap 4 года назад +1

    2 as an element of 3 doesn't seem silly to me.

  • @LIB3RTARIAN1337
    @LIB3RTARIAN1337 7 лет назад

    This is hardly a new development in Computer Science or Mathematics. Coq itself has been around for nearly 30 years. The foundations for this come from the Curry-Howard correspondence (completed by Howard in 1969) and Intuitionistic type theory (created in 1972), so in other words almost 50 years ago. The original type theory that was created by Russell was published all the way back in the 1910s in Principia (as a side note, his motivation were the paradoxes in naive set theory that he discovered).
    So proof assistants may be getting more use now due to recent developments such as the proof of the four colors theorem, but they have been around for what is considered an eternity in these fields (and pretty much every other field).
    Anyway, most mathematicians don't work with formalized set theory. An exception is those who are obsessed with mathematical foundations or working in areas closely related to it (mathematical logic, category theory). The rest just throw out the constructions that lead to paradoxes (ie, by defining collections or families of sets differently than sets), but they don't work with an axiomatic set theory like ZFC. There are even problems that can't be formalized in ZFC (or any other formalism using higher than first order logic thanks to Godel's incompleteness theorems).
    Edit: Well I just watched the rest of the video and I guess it turns out that Dr. Altenkirch pointed some of this stuff out himself. He has a very obscure definition of the phrase "new development"
    Edit 2: It is worth pointing out that the proofs these assistants help make do so by checking the type of the program, not running it. The correspondence is between the type of the program and a proposition in the logic. As such, it is static. Most efforts in Computer Science go towards what is useful at run time (and the type system is meant to aid in writing a program for the purpose of running it, not type checking it, it just helps out that we can reduce runtime errors by catching type errors before running the program). Most stuff in Computer Science cannot even be proven formally (this is actually true of math in general, but mathematicians aren't interested in those areas, whereas Computer Scientists are). In other words, Computer Scientists are studying computation, not static analysis (though that is an important part of theoretical CS, it is a small part handled by PLT). To be blunt, a program in Coq and a program in Idris, though similar in structure, have 100% orthogonal purposes. One is meant to be type checked and the other to be ran. I would go so far as to say that proof assistants are very marginally a part of Computer Science and mostly just pure math that got an implementation on a computer.
    Edit 3: It would be interesting to see what a functor between the category of types with functions as morphisms in (I'm assuming Intuitionistic) type theory and the category of surfaces with paths as morphisms (don't know if this is correct) in homotopy theory looks like. Perhaps that is what that mathematician discovered. In other words, category theory is awesome.