back to index

John Carmack: Doom, Quake, VR, AGI, Programming, Video Games, and Rockets | Lex Fridman Podcast #309


small model | large model

link |
00:00:00.000
I remember the reaction where he had drawn these characters
link |
00:00:02.560
and he was slowly moving around
link |
00:00:04.200
and like people had no experience with 3D navigation.
link |
00:00:06.960
It was all still keyboard.
link |
00:00:07.920
We didn't even have mice set up at that time,
link |
00:00:10.960
but slowly moving, going up, picked up a key, go to a wall.
link |
00:00:14.740
The wall disappears in a little animation
link |
00:00:16.800
and there's a monster like right there.
link |
00:00:18.760
And he practically fell out of his chair.
link |
00:00:20.440
It was just like, ah, and games just didn't do that.
link |
00:00:24.680
You know, the games were the God's eye view.
link |
00:00:26.800
You were a little invested in your little guy.
link |
00:00:28.760
You can be like, you know, happy or sad when things happen,
link |
00:00:32.200
but you just did not get that kind of startled reaction.
link |
00:00:34.880
You weren't inside the game.
link |
00:00:36.360
Something in the back of your brain,
link |
00:00:38.000
some reptile brain thing is just going,
link |
00:00:40.200
oh shit, something just happened.
link |
00:00:42.400
And that was one of those early points where it's like,
link |
00:00:44.960
yeah, this is going to make a difference.
link |
00:00:47.240
This is going to be powerful and it's going to matter.
link |
00:00:52.300
The following is a conversation with John Carmack,
link |
00:00:55.140
widely considered to be one of the greatest programmers
link |
00:00:58.520
ever.
link |
00:00:59.520
He was the cofounder of id Software
link |
00:01:01.960
and the lead programmer on several games
link |
00:01:03.880
that revolutionized the technology, the experience,
link |
00:01:07.360
and the role of gaming in our society,
link |
00:01:09.800
including Commander Keen, Wolfenstein 3D, Doom, and Quake.
link |
00:01:15.800
He spent many years as the CTO of Oculus VR,
link |
00:01:19.960
helping to create portals into virtual worlds
link |
00:01:23.080
and to define the technological path
link |
00:01:25.480
to the metaverse and meta.
link |
00:01:28.120
And now he has been shifting some of his attention
link |
00:01:30.960
to the problem of artificial general intelligence.
link |
00:01:34.840
This was the longest conversation on this podcast
link |
00:01:38.400
at over five hours.
link |
00:01:40.080
And still, I could talk to John many, many more times,
link |
00:01:43.720
and we hope to do just that.
link |
00:01:46.440
This is the Lux Readman podcast.
link |
00:01:48.680
To support it, please check out our sponsors
link |
00:01:50.840
in the description.
link |
00:01:52.160
And now, dear friends, here's John Carmack.
link |
00:01:56.360
What was the first program you've ever written?
link |
00:02:00.040
Do you remember?
link |
00:02:01.200
Yeah, I do.
link |
00:02:02.040
So I remember being in a radio shack
link |
00:02:04.400
going up to the TRS 80 computers
link |
00:02:06.800
and learning just enough to be able to do
link |
00:02:09.840
10 print John Carmack.
link |
00:02:12.760
And it's kind of interesting how, of course,
link |
00:02:15.960
Carnegie and Ritchie kind of standardized Hello World
link |
00:02:19.040
as the first thing that you do
link |
00:02:20.040
in every computer programming language in every computer,
link |
00:02:22.720
but not having any interaction
link |
00:02:24.800
with the cultures of Unix or any other standardized things.
link |
00:02:28.200
It was just like, well, what am I gonna say?
link |
00:02:29.840
I'm gonna say my name.
link |
00:02:30.960
And then you learn how to do go to 10
link |
00:02:33.160
and have it scroll all off the screen.
link |
00:02:34.920
And that was definitely the first thing
link |
00:02:37.280
that I wound up doing on a computer.
link |
00:02:39.520
Can I ask you a programming advice?
link |
00:02:41.280
I was always told in the beginning
link |
00:02:42.680
that you're not allowed to use go to statements.
link |
00:02:44.360
That's really bad programming.
link |
00:02:45.520
Is this correct or not?
link |
00:02:46.920
Jumping around code, can we look at the philosophy
link |
00:02:50.280
and the technical aspects of the go to statement
link |
00:02:53.680
that seems so convenient,
link |
00:02:55.120
but it's supposed to be bad programming?
link |
00:02:55.960
Well, so certainly back in the day
link |
00:02:57.280
in basic programming languages,
link |
00:02:58.920
you didn't have proper loops.
link |
00:03:00.760
You didn't have four whiles and repeats.
link |
00:03:02.720
That was the land of Pascal for people
link |
00:03:04.840
that kind of generally had access to it back then.
link |
00:03:07.360
So you had no choice but to use go tos.
link |
00:03:10.360
And as you made what were big programs back then,
link |
00:03:13.440
which were a thousand line basic program
link |
00:03:15.560
is a really big program.
link |
00:03:16.720
They did tend to sort of degenerate into madness.
link |
00:03:19.960
You didn't have good editors or code exploration tools.
link |
00:03:23.360
So you would wind up fixing things in one place,
link |
00:03:26.160
add a little patch.
link |
00:03:27.120
And there's reasons why structured programming
link |
00:03:29.680
generally helps understanding,
link |
00:03:31.720
but go tos aren't poisonous.
link |
00:03:33.800
Sometimes they're the right thing to do.
link |
00:03:35.920
Usually it's because there's a language feature missing
link |
00:03:38.840
like nested breaks or something
link |
00:03:40.520
where it can sometimes be better to do a go to cleanup
link |
00:03:44.560
or go to error rather than having multiple flags,
link |
00:03:48.040
multiple if statements littered throughout things.
link |
00:03:50.440
But it is rare.
link |
00:03:51.800
I mean, if you gripped through all of my code right now,
link |
00:03:55.120
I don't think any of my current code bases
link |
00:03:57.520
would actually have a go to,
link |
00:03:58.960
but deep within sort of the technical underpinnings
link |
00:04:02.640
of a major game engine,
link |
00:04:03.720
you're gonna have some go tos in a couple of places probably.
link |
00:04:07.200
Yeah, the infrastructure on top of,
link |
00:04:09.160
like the closer you get to machine code,
link |
00:04:11.240
the more go tos you're gonna see,
link |
00:04:12.680
the more of these like hacks you're going to see
link |
00:04:15.640
because the set of features available to you
link |
00:04:18.240
in low level programming languages is not, is limited.
link |
00:04:22.360
So print John Carmack,
link |
00:04:25.920
when is the first time,
link |
00:04:28.360
if we could talk about love,
link |
00:04:30.000
that you fell in love with programming?
link |
00:04:31.680
You said like, this is really something special.
link |
00:04:34.640
It really was something
link |
00:04:36.040
that was one of those love at first sight things
link |
00:04:38.120
where just really from the time
link |
00:04:39.920
that I understood what a computer was even,
link |
00:04:42.720
I mean, I remember looking through old encyclopedias
link |
00:04:45.440
of the black and white photos of the IBM mainframes
link |
00:04:48.560
at the reel to reel tape decks.
link |
00:04:50.240
And for people nowadays,
link |
00:04:52.320
it can be a little hard to understand
link |
00:04:53.800
what the world was like then from information gathering
link |
00:04:56.280
where I would go to the libraries
link |
00:04:58.720
and there would be a couple books on the shelf
link |
00:05:01.080
about computers and they would be very out of date
link |
00:05:03.880
even at that point, just not a lot of information,
link |
00:05:06.640
but I would grab everything that I could find
link |
00:05:09.160
and devour everything.
link |
00:05:10.560
Whenever Time or Newsweek had some article about computers,
link |
00:05:14.200
I would like cut it out with scissors and put it somewhere.
link |
00:05:16.960
It just, it felt like this magical thing to me,
link |
00:05:19.960
this idea that the computer would just do exactly
link |
00:05:23.480
what you told it to.
link |
00:05:24.480
I mean, and there's a little bit of the genie monkey's paw
link |
00:05:26.640
sort of issues there where you'd better be really,
link |
00:05:28.960
really careful with what you're telling it to do,
link |
00:05:31.080
but it wasn't gonna back talk you.
link |
00:05:33.120
It wasn't gonna have a different point of view.
link |
00:05:34.720
It was gonna carry out what you told it to do.
link |
00:05:37.400
And if you had the right commands,
link |
00:05:39.840
you could make it do these pretty magical things.
link |
00:05:43.560
And so what kind of programs did you write at first?
link |
00:05:46.000
So beyond the print, John Carmack.
link |
00:05:48.280
So I can remember as going through the learning process
link |
00:05:51.800
where you find at the start,
link |
00:05:53.720
you're just learning how to do
link |
00:05:54.600
the most basic possible things.
link |
00:05:56.400
And I can remember stuff like a Superman comic
link |
00:05:59.840
that RadioShack commissioned to have,
link |
00:06:02.640
it's like Superman had lost some of his super brain
link |
00:06:04.840
and kids had to use RadioShack TRS 80 computers
link |
00:06:07.520
to do calculations for it to help him
link |
00:06:09.920
kind of complete his heroics.
link |
00:06:11.960
And I'd find little things like that
link |
00:06:15.240
and then get a few basic books
link |
00:06:17.320
to be able to kind of work my way up.
link |
00:06:20.120
And again, it was so precious back then.
link |
00:06:22.440
I had a couple of books
link |
00:06:23.640
that would teach me important things about it.
link |
00:06:25.920
I had one book that I could start to learn
link |
00:06:28.640
a little bit of assembly language from,
link |
00:06:30.320
and I'd have a few books on basic
link |
00:06:32.000
and some things that I could get from the libraries.
link |
00:06:34.560
But my goals in the early days
link |
00:06:37.160
was almost always making games of various kinds.
link |
00:06:40.000
I loved the arcade games and the early Atari 2600 games.
link |
00:06:44.880
And being able to do some of those things myself
link |
00:06:47.720
on the computers was very much what I aspired to.
link |
00:06:51.360
And it was a whole journey where
link |
00:06:53.000
if you learn normal basic,
link |
00:06:54.360
you can't do any kind of an action game.
link |
00:06:56.080
You can write an adventure game.
link |
00:06:57.400
You can write things where you say, what do you do here?
link |
00:07:00.360
I get sword attack troll, that type of thing.
link |
00:07:03.600
And that can be done in the context of basic.
link |
00:07:07.040
But to do things that had moving graphics,
link |
00:07:09.520
there were only the most limited things
link |
00:07:11.280
you could possibly do.
link |
00:07:12.240
You could maybe do breakout or pong
link |
00:07:14.040
or that sort of thing in low resolution graphics.
link |
00:07:16.920
And in fact, one of my first sort of major technical hacks
link |
00:07:20.720
that I was kind of fond of was on the Apple II computers,
link |
00:07:25.400
they had a mode called low resolution graphics
link |
00:07:28.800
where of course all graphics were low resolution back then,
link |
00:07:31.400
but regular low resolution graphics,
link |
00:07:34.080
it was a grid of 40 by 40 pixels normally,
link |
00:07:37.160
but they could have 16 different colors.
link |
00:07:39.480
And I wanted to make a game kind of like
link |
00:07:42.080
the arcade game Vanguard, just a scrolling game.
link |
00:07:44.920
And I wanted to just kind of have it scroll vertically up.
link |
00:07:47.400
And I could move a little ship around.
link |
00:07:49.240
You could manage to do that in basic,
link |
00:07:50.760
but there's no way you could redraw the whole screen.
link |
00:07:53.520
And I remember at the time just coming up
link |
00:07:56.000
with what felt like a brainstorm to me
link |
00:07:58.160
where I knew enough about the way the hardware was controlled
link |
00:08:02.000
where the text screen and the low resolution graphics screen
link |
00:08:05.120
were basically the same thing.
link |
00:08:06.880
And all those computers could scroll their text screen
link |
00:08:09.640
reasonably.
link |
00:08:10.240
You could do a listing and it would scroll things up.
link |
00:08:12.680
And I figured out that I could kind of tweak just a couple
link |
00:08:16.480
things that I barely understood to put it into a graphics mode
link |
00:08:19.640
and I could draw graphics and then I could just
link |
00:08:21.600
do a line feed at the very bottom of the screen.
link |
00:08:24.360
And then the system would scroll it all up
link |
00:08:26.320
using an assembly language routine
link |
00:08:28.080
that I didn't know how to write back then.
link |
00:08:30.200
So that was like this first great hack
link |
00:08:33.360
that sort of had analogs later on in my career
link |
00:08:36.040
for a lot of different things.
link |
00:08:37.240
So I found out that I could draw a screen.
link |
00:08:39.400
I could do a line feed at the bottom.
link |
00:08:40.920
It would scroll it up once.
link |
00:08:42.160
I could draw a couple more lines of stuff at the bottom.
link |
00:08:44.720
And that was my first way to kind of scroll
link |
00:08:47.240
the screen, which was interesting in that that played
link |
00:08:50.680
a big part later on in the id Software days as well.
link |
00:08:53.280
So do efficient drawing where you
link |
00:08:57.480
don't have to draw the whole screen,
link |
00:08:59.200
but you draw from the bottom using
link |
00:09:01.120
the thing that was designed in the hardware for text output.
link |
00:09:04.520
Yeah.
link |
00:09:05.160
Where so much of, until recently,
link |
00:09:08.960
game design was limited by what you could actually
link |
00:09:12.120
get the computer to do.
link |
00:09:13.200
Where it's easy to say, OK, I want to scroll the screen.
link |
00:09:16.000
You just redraw the entire screen at a slight offset.
link |
00:09:19.400
And nowadays, that works just fine.
link |
00:09:21.560
Computers are ludicrously fast.
link |
00:09:24.680
But up until a decade ago or so, there
link |
00:09:28.040
were all these things everybody wanted to do.
link |
00:09:30.120
But if they knew enough programming
link |
00:09:31.880
to be able to make it happen, it would happen too slow
link |
00:09:34.960
to be a good experience.
link |
00:09:36.440
Either just ridiculously slow or just slow enough
link |
00:09:39.320
that it wasn't fun to experience it like that.
link |
00:09:42.040
So much of the first couple of decades of the programming work
link |
00:09:45.600
that I did was largely figuring out
link |
00:09:47.760
how to do something that everybody
link |
00:09:49.200
knows how they want it to happen.
link |
00:09:51.520
It just has to happen 2 to 10 times faster
link |
00:09:54.240
than the straightforward way of doing things
link |
00:09:57.360
would make it happen.
link |
00:09:58.680
And it's different now because at this point, lots of things
link |
00:10:02.560
you can just do in the most naive possible way,
link |
00:10:05.000
and it still works out.
link |
00:10:06.520
You don't have nearly the creative limitations
link |
00:10:09.520
or the incentives for optimizing on that level.
link |
00:10:12.680
And there's a lot of pros and cons to that.
link |
00:10:14.520
But I do generally, I'm not going
link |
00:10:16.520
to do the angry old man shaking my fist at the clouds bit
link |
00:10:20.000
where back in my day, programmers
link |
00:10:21.560
had to do real programming.
link |
00:10:23.200
It's amazing that you can just pick an idea
link |
00:10:26.640
and go do it right now.
link |
00:10:27.840
And you don't have to be some assembly language wizard
link |
00:10:30.520
or deep GPU arcanist to be able to figure out
link |
00:10:33.840
how to make your wishes happen.
link |
00:10:35.160
Well, there's still, see, that's true.
link |
00:10:38.400
But let me put on my old man with a fist hat
link |
00:10:41.320
and say that probably the thing that will define the future
link |
00:10:45.200
still requires you to operate at the limits
link |
00:10:48.720
of the current system.
link |
00:10:49.720
So we'll probably talk about this.
link |
00:10:51.880
But if you talk about building the metaverse
link |
00:10:54.440
and building a VR experience that's compelling,
link |
00:10:57.120
it probably requires you to not, to go to assembly
link |
00:11:01.280
or maybe not literally, but sort of spiritually
link |
00:11:05.840
to go to the limits of what the system is capable of.
link |
00:11:08.360
And that really was why virtual reality
link |
00:11:10.840
was specifically interesting to me
link |
00:11:13.640
where it had all the ties to,
link |
00:11:15.000
you could say that even back in the early days,
link |
00:11:17.080
I have some old magazine articles
link |
00:11:19.160
that's talking about Doom as a virtual reality experience
link |
00:11:22.160
back when just seeing anything in 3D.
link |
00:11:25.200
So you could say that we've been trying to build
link |
00:11:27.320
those virtual experiences from the very beginning.
link |
00:11:29.640
And in the modern era of virtual reality,
link |
00:11:32.840
especially on the mobile side of things,
link |
00:11:34.800
when it's standalone and you're basically using
link |
00:11:36.680
a cell phone chip to be able to produce
link |
00:11:39.000
these very immersive experiences,
link |
00:11:41.800
it does require work.
link |
00:11:43.640
It's not at the level of what an old school
link |
00:11:45.720
console game programmer would have operated at
link |
00:11:48.480
where you're looking at hardware registers
link |
00:11:50.320
and you're scheduling all the DMA accesses,
link |
00:11:53.520
but it is still definitely a different level
link |
00:11:55.520
than what a web developer or even a PC Steam game developer
link |
00:12:00.160
usually has to work at.
link |
00:12:01.760
And again, it's great.
link |
00:12:02.840
There's opportunities for people that wanna operate
link |
00:12:04.920
at either end of that spectrum there
link |
00:12:06.400
and still provide a lot of value to the world.
link |
00:12:09.560
Let me ask you sort of a big question about preference.
link |
00:12:15.560
What would you say is the best programming language?
link |
00:12:19.920
Your favorite, but also the best.
link |
00:12:22.560
You've seen throughout your career,
link |
00:12:25.160
you're considered by many to be
link |
00:12:26.960
the greatest programmer ever.
link |
00:12:29.440
I mean, it's so difficult to place that label on anyone,
link |
00:12:32.320
but if you put it on anyone, it's you.
link |
00:12:34.000
So let me ask you these kind of ridiculous questions
link |
00:12:36.380
of what's the best band of all time,
link |
00:12:38.760
but in your case, what's the best programming language?
link |
00:12:41.520
Everything has all the caveats about it.
link |
00:12:43.520
But so what I use, so nowadays I do program
link |
00:12:47.480
a reasonable amount of Python for AI, ML sorts of work.
link |
00:12:52.800
I'm not a native Python programmer.
link |
00:12:54.440
It's something I came to very late in my career.
link |
00:12:57.000
I understand what it's good for.
link |
00:12:58.800
But you don't dream in Python.
link |
00:13:00.080
I do not.
link |
00:13:00.920
And it has some of those things
link |
00:13:02.380
where there's some amazing stats when you say,
link |
00:13:04.800
if you just start, if you make a loop,
link |
00:13:07.160
a triply nested loop and start doing operations in Python,
link |
00:13:10.980
you can be thousands to potentially a million times slower
link |
00:13:14.840
than a proper GPU tensor operation.
link |
00:13:17.600
And these are staggering numbers.
link |
00:13:19.800
You can be as much slower as we've almost gotten faster
link |
00:13:22.800
in our pace of progress and all this other miraculous stuff.
link |
00:13:26.920
So your intuitions about inefficiencies
link |
00:13:28.840
within the Python sort of...
link |
00:13:30.200
It keeps hitting me upside the face
link |
00:13:32.080
where it's gotten to the point now I understand.
link |
00:13:34.160
It's like, okay, you just can't do a loop
link |
00:13:35.840
if you care about performance in Python.
link |
00:13:38.480
You have to figure out how you can reformat this
link |
00:13:41.380
into some big vector operation
link |
00:13:43.100
or something that's going to be done completely
link |
00:13:44.920
within a C++ library.
link |
00:13:47.080
But the other hand is it's amazingly convenient
link |
00:13:49.920
and you just see stuff that people are able
link |
00:13:52.320
to cobble together by you just import
link |
00:13:54.560
a few different things and you can do stuff
link |
00:13:56.460
that nobody on earth could do 10 years ago.
link |
00:13:58.880
And you can do it in a little cookbook thing
link |
00:14:00.520
that you copy paste it out of a website.
link |
00:14:02.840
So that is really great.
link |
00:14:04.820
When I'm sitting down to do what I consider
link |
00:14:06.960
kind of serious programming, it's still in C++.
link |
00:14:10.440
And it's really kind of a C flavored C++ at that
link |
00:14:13.960
where I'm not big into the modern template
link |
00:14:17.160
metaprogramming sorts of things.
link |
00:14:18.780
I see a lot of train wrecks coming from
link |
00:14:21.280
some of that over abstraction.
link |
00:14:23.500
I spent a few years really going kind of deep
link |
00:14:26.800
into the kind of the historical Lisp work
link |
00:14:30.120
and Haskell and some of the functional programming
link |
00:14:32.320
sides of things.
link |
00:14:33.360
And there is a lot of value there
link |
00:14:37.040
in the way you think about things.
link |
00:14:38.700
And I changed a lot of the way I write my C and C++ code
link |
00:14:42.160
based on what I learned about the value
link |
00:14:44.960
that comes out of not having this random mutable state
link |
00:14:48.080
that you kind of lose track of.
link |
00:14:50.240
Because something that many people don't really appreciate
link |
00:14:53.640
till they've been at it for a long time
link |
00:14:55.500
is that it's not the writing of the program initially,
link |
00:14:58.240
it's the whole lifespan of the program.
link |
00:15:00.440
And that's when it's not necessarily just
link |
00:15:02.680
how fast you wrote it or how fast it operates,
link |
00:15:05.500
but it's how can it bend and adapt
link |
00:15:07.720
as situations change.
link |
00:15:09.240
And then the thing that I've really been learning
link |
00:15:11.160
in my time at Meta with the Oculus and VR work
link |
00:15:14.720
is it's also how well it hands off
link |
00:15:16.960
between the continuous kind of revolving door of programmers
link |
00:15:19.960
taking over maintenance and different things
link |
00:15:21.960
and how you get people up to speed in different areas.
link |
00:15:24.600
And there's all these other different aspects of it.
link |
00:15:27.140
So C++ is a good language for handover between engineers.
link |
00:15:32.520
Probably not the best.
link |
00:15:34.800
And there's some really interesting aspects to this
link |
00:15:36.900
where in some cases languages
link |
00:15:39.360
that are not generally thought well of for many reasons,
link |
00:15:43.460
like C is derided pretty broadly that yes,
link |
00:15:46.400
obviously all of these security flaws
link |
00:15:48.160
that happen with the memory and unsafeness
link |
00:15:50.400
and buffer overruns and the things that you've got there,
link |
00:15:53.920
but there is this underappreciated aspect
link |
00:15:56.680
to the language is so simple, anyone can go.
link |
00:15:59.560
And if you know C, you can generally jump in someplace
link |
00:16:03.080
and not have to learn what paradigms they're using
link |
00:16:06.140
because there just aren't that many available.
link |
00:16:08.320
I think there's some really, really well written C code.
link |
00:16:12.480
Like I find it great that if I'm messing around
link |
00:16:15.520
with something in open BSD say,
link |
00:16:17.120
I mean, I can be walking around in the kernel
link |
00:16:19.320
and I'm like, I understand everything that's going on here.
link |
00:16:22.160
It's not hard for me to figure out what I need to do
link |
00:16:25.960
to make whatever change that I need to
link |
00:16:29.760
while you can have more significant languages.
link |
00:16:32.820
Like it's a downside of Lisp
link |
00:16:34.800
where I don't regret the time that I spent with Lisp.
link |
00:16:37.320
I think that it did help my thinking
link |
00:16:40.880
about programming in some ways,
link |
00:16:42.780
but the people that are the biggest defenders of Lisp
link |
00:16:45.400
are saying how malleable of a language it is
link |
00:16:47.840
that if you write a huge Lisp program,
link |
00:16:50.080
you've basically invented your own kind of language
link |
00:16:53.120
and structure because it's not the primitives
link |
00:16:55.440
of the language you're using very much.
link |
00:16:57.000
It's all of the things you've built on top of that.
link |
00:16:59.480
And then a language like Racket,
link |
00:17:01.040
kind of one of the more modern Lisp versions,
link |
00:17:03.360
it's essentially touted as a language
link |
00:17:05.320
for building other languages.
link |
00:17:07.020
And I understand the value of that
link |
00:17:10.080
for a tiny little project,
link |
00:17:12.440
but the idea of that for one of these longterm
link |
00:17:14.800
supported by lots of people kind of horrifies me
link |
00:17:18.000
where all of those abstractions that you're like,
link |
00:17:20.480
okay, you can't touch this code till you educate yourself
link |
00:17:23.920
on all of these things that we've built on top of that.
link |
00:17:26.760
And it was interesting to see how when Google made Go,
link |
00:17:30.420
a lot of the criticisms of that are it's like,
link |
00:17:33.160
wow, this is not a state of the art language.
link |
00:17:35.040
This language is just so simple and almost crude.
link |
00:17:38.080
And you could see the programming language people
link |
00:17:40.480
just looking down at it.
link |
00:17:41.920
But it does seem to be quite popular as basically saying,
link |
00:17:45.360
this is the good things about C,
link |
00:17:47.240
everybody can just jump right in and use it.
link |
00:17:49.360
You don't need to restructure your brain
link |
00:17:52.060
to write good code in it.
link |
00:17:53.880
So I wish that I had more opportunity
link |
00:17:56.300
for doing some work in Go.
link |
00:17:59.000
Rust is the other modern language that everybody talks about
link |
00:18:02.160
that I'm not fit to pass judgment on.
link |
00:18:04.200
I've done a little bit beyond Hello World.
link |
00:18:06.620
I wrote some like video decompression work in Rust
link |
00:18:09.940
just as an exercise, but that was a few years ago
link |
00:18:12.720
and I haven't really used it since.
link |
00:18:15.040
The best programming language is the one that works generally
link |
00:18:17.640
that you're currently using.
link |
00:18:19.160
Because that's another trap is in almost every case
link |
00:18:22.280
I've seen when people mixed languages on a project,
link |
00:18:25.000
that's a mistake.
link |
00:18:26.060
I would rather stay just in one language
link |
00:18:29.000
so that everybody can work across the entire thing.
link |
00:18:31.680
And we have, I get meta, we have a lot of projects
link |
00:18:34.380
that use kind of React frameworks.
link |
00:18:36.400
So you've got JavaScript here
link |
00:18:37.900
and then you have C++ for real work.
link |
00:18:40.960
And then you may have Java interfacing
link |
00:18:42.720
with some other part of the Android system.
link |
00:18:44.680
And those are all kind of horrible things.
link |
00:18:47.000
And that was one thing that I remember talking
link |
00:18:51.320
with Boz at Facebook about it where like,
link |
00:18:54.640
man, I wish we could have just said,
link |
00:18:56.020
we're only hiring C++ programmers.
link |
00:18:59.000
And he just thought from the Facebook meta perspective,
link |
00:19:02.700
well, we just wouldn't be able to find enough.
link |
00:19:05.400
With the thousands of programmers they've got there,
link |
00:19:08.040
it is not necessarily a dying breed,
link |
00:19:10.780
but you can sure find a lot more Java
link |
00:19:12.880
or JavaScript programmers.
link |
00:19:14.960
And I kind of mentioned that to Elon one time
link |
00:19:17.860
and he was kind of flabbergasted about that.
link |
00:19:21.120
It's like, well, you just,
link |
00:19:22.160
you go out and you find those programmers
link |
00:19:23.960
and you don't hire the other programmers
link |
00:19:25.520
that don't do the languages that you wanna use.
link |
00:19:28.400
But right now, I guess, yeah,
link |
00:19:29.340
they're using JavaScript on a bunch of the SpaceX work
link |
00:19:32.360
for the UI side of things.
link |
00:19:33.760
When you go find UI programmers,
link |
00:19:35.420
they're JavaScript programmers.
link |
00:19:36.920
I wonder if that's because there's a lot
link |
00:19:38.380
of JavaScript programmers.
link |
00:19:39.720
Because I do think that great programmers are rare.
link |
00:19:44.720
That it's not, you know, if you just look at statistics
link |
00:19:48.360
of how many people are using different programming languages,
link |
00:19:51.220
that doesn't tell you the story
link |
00:19:53.280
of what the great programmers are using.
link |
00:19:55.760
And so you have to really look at what you were speaking to,
link |
00:19:59.160
which is the fundamentals of a language.
link |
00:20:00.820
What does it encourage?
link |
00:20:01.720
How does it encourage you to think?
link |
00:20:03.280
What kind of systems does it encourage you to build?
link |
00:20:05.700
There is something about C++
link |
00:20:08.780
that has elements of creativity,
link |
00:20:11.240
but forces you to be an adult about your programming.
link |
00:20:15.160
It expects you to be an adult.
link |
00:20:16.680
It does not force you to.
link |
00:20:18.720
And so it brings out people that are willing to be creative
link |
00:20:23.720
in terms of building large systems
link |
00:20:25.800
and coming up with interesting solutions,
link |
00:20:27.600
but at the same time have the sort of the good
link |
00:20:31.320
software engineering practices that amend themselves
link |
00:20:35.320
to real world systems.
link |
00:20:37.480
Let me ask you about this other language, JavaScript.
link |
00:20:41.760
So if we, you know, aliens visit in thousands of years,
link |
00:20:46.280
and humans are long gone, something tells me
link |
00:20:49.560
that most of the systems they find will be run by humans.
link |
00:20:53.560
Will be running JavaScript.
link |
00:20:55.000
I kind of think that if we're living in a simulation,
link |
00:20:58.600
it's written in JavaScript.
link |
00:21:01.600
You know, for the longest time, even still,
link |
00:21:05.540
JavaScript didn't get any respect,
link |
00:21:08.120
and yet it runs so much of the world,
link |
00:21:10.000
and an increasing number of the world.
link |
00:21:12.120
Is it possible that everything will be written
link |
00:21:15.160
in JavaScript one day?
link |
00:21:16.720
So the engineering under JavaScript
link |
00:21:18.800
is really pretty phenomenal.
link |
00:21:21.300
The systems that make JavaScript run as fast
link |
00:21:24.600
as it does right now are kind of miracles
link |
00:21:27.520
of modern engineering in many ways.
link |
00:21:29.960
It does feel like it is not an optimal language
link |
00:21:34.440
for all the things that it's being used for,
link |
00:21:36.360
or an optimal distribution system to build huge apps
link |
00:21:40.040
in something like this without type systems and so on.
link |
00:21:45.760
But I think for a lot of people,
link |
00:21:47.520
it does reasonably the necessary things.
link |
00:21:50.440
It's still a C flavored language.
link |
00:21:52.280
It's still a braces and semicolon language.
link |
00:21:55.840
It's not hard for people to be trained in JavaScript
link |
00:21:59.480
and then understand the roots of where it came from.
link |
00:22:02.560
I think garbage collection is unequivocally a good thing
link |
00:22:07.120
for most programs to be written in.
link |
00:22:08.840
It's funny that I still, just this morning,
link |
00:22:11.000
I was seeing a Twitter thread
link |
00:22:13.200
of a bunch of really senior game dev people
link |
00:22:15.560
arguing about the virtues and costs of garbage collection.
link |
00:22:18.880
You will run into some people that are top notch programmers
link |
00:22:21.740
that just say, no, this is literally not a good thing.
link |
00:22:24.640
Oh, because it makes you lazy?
link |
00:22:25.840
Yes, that it makes you not think about things.
link |
00:22:28.440
And I do disagree.
link |
00:22:29.640
I think that there is so much objective data
link |
00:22:33.320
on the vulnerabilities that have happened
link |
00:22:35.680
in C and C++ programs,
link |
00:22:37.800
sometimes written by the best programmers in the world.
link |
00:22:40.100
It's like nobody is good enough to avoid
link |
00:22:42.360
ever shooting themselves in the foot with that.
link |
00:22:44.200
You write enough C code,
link |
00:22:45.540
you're going to shoot yourself in the foot.
link |
00:22:47.620
And garbage collection is a very great thing
link |
00:22:50.000
for the vast majority of programs.
link |
00:22:51.740
It's only when you get into the tightest of real time things
link |
00:22:54.720
that you start saying, it's like, no,
link |
00:22:56.500
the garbage collection has more costs
link |
00:22:58.320
than it has benefits for me there,
link |
00:22:59.940
but that's not 99 plus percent
link |
00:23:02.560
of all the software in the world.
link |
00:23:04.840
So JavaScript is not terrible in those ways.
link |
00:23:09.360
And so much of programming is not the language itself.
link |
00:23:14.120
It's the infrastructure around that surrounds it.
link |
00:23:17.400
All the libraries that you can get
link |
00:23:19.040
and the different stuff that you can,
link |
00:23:20.480
ways you can deploy it,
link |
00:23:22.480
the portability that it gives you.
link |
00:23:24.200
And JavaScript is really strong on a lot of those things
link |
00:23:27.080
where for a long time, and it still does if I look at it,
link |
00:23:31.120
the web stack about everything that has to go
link |
00:23:34.020
when you do something really trivial in JavaScript
link |
00:23:36.460
and it shows up on a web browser
link |
00:23:38.420
to kind of X ray through that
link |
00:23:40.360
and see everything that has to happen
link |
00:23:42.280
for your one little JavaScript statement
link |
00:23:44.680
to turn into something visible in your web browser,
link |
00:23:48.280
it's very, very disquieting,
link |
00:23:51.160
just the depth of that stack
link |
00:23:53.360
and the fact that so few people can even comprehend
link |
00:23:56.840
all of the levels that are going on there.
link |
00:23:59.440
But it's again, I have to caution myself
link |
00:24:02.320
to not be the in the good old days old man about it
link |
00:24:05.540
because clearly there's enormous value here.
link |
00:24:08.760
The world does run on JavaScript
link |
00:24:11.180
to a pretty good approximation there
link |
00:24:13.280
and it's not falling apart.
link |
00:24:14.720
There's a bunch of scary stuff
link |
00:24:16.100
where you look at console logs
link |
00:24:18.400
and you just see all of these bad things that are happening
link |
00:24:20.940
but it's still kind of limping along
link |
00:24:22.560
and nobody really notices.
link |
00:24:24.760
But so much of my systems design
link |
00:24:28.440
and systems analysis goes around.
link |
00:24:30.720
You should understand what the speed of light is,
link |
00:24:32.920
like what would be the best you could possibly do here.
link |
00:24:36.120
And it sounds horrible, but in a lot of cases,
link |
00:24:39.400
you can be a thousand times off your speed of light,
link |
00:24:42.720
velocity for something and it's still be okay.
link |
00:24:45.520
And in fact, it can even sometimes still be
link |
00:24:48.360
the optimal thing in a larger system standpoint
link |
00:24:51.120
where there's a lot of things
link |
00:24:52.700
that you don't wanna have to parachute in someone like me
link |
00:24:55.640
to go in and say, make this webpage run
link |
00:24:59.880
a thousand times faster,
link |
00:25:01.560
make this web app into a hardcore native application
link |
00:25:05.320
that starts up in 37 milliseconds
link |
00:25:08.020
and everything responds in less than one frame latency.
link |
00:25:11.240
That's just not necessary.
link |
00:25:12.680
And if somebody wants to go pay me millions of dollars
link |
00:25:15.440
to do software like that,
link |
00:25:16.680
when they can take somebody right out of a bootcamp
link |
00:25:19.040
and say, spin up an application for this.
link |
00:25:21.960
Often being efficient is not really the best metric.
link |
00:25:26.960
And it's like, that applies in a lot of areas
link |
00:25:29.260
where it's kind of interesting how a lot of our appliances
link |
00:25:32.680
and everything are all built around energy efficiency,
link |
00:25:36.360
sometimes at the expense of robustness in some other ways
link |
00:25:39.400
or higher costs in other ways
link |
00:25:41.160
where there's interesting things
link |
00:25:42.960
where energy or electricity could become much cheaper
link |
00:25:46.080
in a future world.
link |
00:25:47.040
And that could change our engineering trade offs
link |
00:25:49.040
for the way we build certain things
link |
00:25:50.520
where you could throw away efficiency
link |
00:25:53.100
and actually get more benefits that actually matter.
link |
00:25:56.280
I mean, that's one of the directions
link |
00:25:59.320
I was considering swerving into was nuclear energy.
link |
00:26:02.760
When I was kind of like, what do I wanna do next?
link |
00:26:04.600
It was either gonna be cost effective nuclear fission
link |
00:26:08.120
or artificial general intelligence.
link |
00:26:10.520
And one of my pet ideas there is like,
link |
00:26:14.680
people don't understand how cheap nuclear fuel is.
link |
00:26:18.400
And there would be ways that,
link |
00:26:21.400
you could be a quarter of the efficiency or less,
link |
00:26:24.760
but if it wound up making your plant 10 times cheaper,
link |
00:26:27.720
that could be a radical innovation in something like that.
link |
00:26:31.240
So there's like some of these thoughts
link |
00:26:32.560
around like direct fission energy conversion,
link |
00:26:35.520
fission fragment conversion,
link |
00:26:36.760
that maybe you build something
link |
00:26:38.480
that doesn't require all the steam turbines and everything,
link |
00:26:40.920
even if it winds up being less efficient.
link |
00:26:42.720
So that applies a lot in programming
link |
00:26:45.060
where it's always good to know what you could do.
link |
00:26:49.180
If you really sat down and took it far,
link |
00:26:52.040
because sometimes there's discontinuities
link |
00:26:53.760
like around user reaction times,
link |
00:26:56.120
there are some points where the difference between
link |
00:26:59.200
operating in one second and 750 milliseconds,
link |
00:27:02.920
not that huge.
link |
00:27:03.920
You'll see it in webpage statistics,
link |
00:27:05.680
but most of the usability stuff, not that great.
link |
00:27:08.260
But if you get down to 50 milliseconds,
link |
00:27:11.000
then all of a sudden this just feels amazing.
link |
00:27:13.200
It's just like doing your bidding instantly
link |
00:27:15.480
rather than you're giving it a command,
link |
00:27:17.240
twiddling your thumbs, waiting for it to respond.
link |
00:27:19.760
So sometimes it's important to really crunch hard
link |
00:27:23.080
to get over some threshold,
link |
00:27:25.040
but there are broad basins in the value metric
link |
00:27:28.920
for lots of work where it just doesn't pay
link |
00:27:31.260
to even go that extra mile.
link |
00:27:33.000
And there are craftsmen that just don't wanna buy that
link |
00:27:36.320
and more power to them.
link |
00:27:37.880
If somebody just wants to say,
link |
00:27:39.120
no, I'm going to be, my pride is in my work,
link |
00:27:42.760
I'm never going to do something
link |
00:27:44.080
that's not as good as I could possibly make it,
link |
00:27:46.400
I respect that and sometimes I am that person,
link |
00:27:50.120
but I try to focus more on the larger value picture
link |
00:27:53.840
and you do pick your battles
link |
00:27:55.280
and you deploy your resources in the play
link |
00:27:57.400
that's going to give you the best user value in the end.
link |
00:28:00.720
Well, if you look at the evolution of life on Earth
link |
00:28:04.680
as a kind of programming effort,
link |
00:28:10.840
it seems like efficiency isn't the thing
link |
00:28:13.320
that's being optimized for.
link |
00:28:15.180
Like natural selection is very inefficient,
link |
00:28:17.220
but it kind of adapts and through the process
link |
00:28:21.580
of adaptations building more and more complex systems
link |
00:28:24.320
that are more and more intelligent,
link |
00:28:25.440
the final result is kind of pretty interesting.
link |
00:28:28.320
And so I think of JavaScript the same way.
link |
00:28:30.960
It's like this giant mess
link |
00:28:33.040
that things naturally die off if they don't work
link |
00:28:36.480
and if they become useful to people,
link |
00:28:39.440
they kind of naturally live
link |
00:28:40.900
and then you build this community,
link |
00:28:42.880
large community of people that are generating code
link |
00:28:45.940
and some code is sticky, some is not
link |
00:28:48.160
and nobody knows the inefficiencies or the efficiencies
link |
00:28:52.480
or the breaking points, like how reliable this code is
link |
00:28:54.920
and you kind of just run it, assume it works
link |
00:28:57.820
and then get unpleasantly surprised
link |
00:29:00.440
and then that's very kind of the evolutionary process.
link |
00:29:03.160
So that's a really good analogy
link |
00:29:04.980
and we can go a lot of places with that
link |
00:29:06.840
where in the earliest days of programming,
link |
00:29:09.540
when you had finite, you could count the bytes
link |
00:29:11.920
that you had to work on this,
link |
00:29:13.080
you had all the kind of hackers playing code golf
link |
00:29:15.980
to be one less instruction
link |
00:29:17.400
than the other person's multiply routine
link |
00:29:19.600
to kind of get through and it was so perfectly crafted.
link |
00:29:22.880
It was a crystal piece of artwork when you had a program
link |
00:29:26.500
because there just were not that many,
link |
00:29:28.460
you couldn't afford to be lazy in different ways
link |
00:29:31.320
and in many ways I see that as akin to the symbolic AI work
link |
00:29:34.760
where again, if you did not have the resources to just say,
link |
00:29:38.480
well, we're gonna do billions and billions
link |
00:29:40.600
of programmable weights here,
link |
00:29:42.680
you have to turn it down into something
link |
00:29:44.500
that is symbolic and crafted like that
link |
00:29:47.400
but that's definitely not the way DNA and life
link |
00:29:51.140
and biological evolution and things work.
link |
00:29:55.000
On the one hand, it's almost humbling
link |
00:29:58.360
how little programming code is in our bodies.
link |
00:30:00.920
We've got a couple of billion base pairs
link |
00:30:02.540
and it's like this all fits on a thumb drive for years now
link |
00:30:05.680
and then our brains are even a smaller section of that.
link |
00:30:08.380
You've got maybe 50 megabytes
link |
00:30:10.000
and this is not like Shannon Limit perfectly
link |
00:30:13.720
information dense conveyances here.
link |
00:30:17.480
It's like these are messy codes,
link |
00:30:19.480
they're broken up into amino acids.
link |
00:30:21.520
A lot of them don't do important things
link |
00:30:23.960
or they do things in very awkward ways
link |
00:30:26.360
but it is this process of just accumulation
link |
00:30:29.160
on top of things and you need scale,
link |
00:30:33.320
both you need scale for the population for that to work out
link |
00:30:36.880
and in the early days in the 50s and 60s,
link |
00:30:39.880
the kind of ancient era of computers
link |
00:30:42.660
where you could count when they say like
link |
00:30:44.560
when the internet started even in the 70s,
link |
00:30:46.240
there were like 18 hosts or something on it.
link |
00:30:48.180
It was this small finite number
link |
00:30:50.440
and you were still optimizing everything
link |
00:30:52.260
to be as good as you possibly could be
link |
00:30:54.560
but now it's billions and billions of devices
link |
00:30:57.760
and everything going on and you can have
link |
00:31:00.360
this very much natural evolution going on
link |
00:31:03.560
where lots of things are tried,
link |
00:31:06.000
lots of things are blowing up,
link |
00:31:07.360
venture capitalists lose their money
link |
00:31:09.440
when a startup invested in the wrong tech stack
link |
00:31:11.840
and things completely failed or failed the scale
link |
00:31:14.820
but good things do come out of it
link |
00:31:17.440
and it's interesting to see the mimetic evolution
link |
00:31:21.060
of the way different things happen
link |
00:31:22.680
like mentioning hello world at the beginning.
link |
00:31:24.440
It's funny how some little thing like that
link |
00:31:26.480
where everybody, every programmer knows hello world now
link |
00:31:29.640
and that was a completely arbitrary sort of decision
link |
00:31:32.140
that just came out of the dominance of Unix and C
link |
00:31:35.600
and early examples of things like that.
link |
00:31:38.440
So millions of experiments are going on all the time
link |
00:31:42.340
but some things do kind of rise to the top
link |
00:31:44.840
and win the fitness war for whether it's mind space
link |
00:31:48.240
or programming techniques or anything.
link |
00:31:50.400
Like there's a site on Stack Exchange called CodeGolf
link |
00:31:54.400
where people compete to write the shortest possible program
link |
00:31:57.960
for a particular task in all the different kinds
link |
00:32:00.320
of languages and it's really interesting to see
link |
00:32:04.880
folks kind of, they're masters of their craft,
link |
00:32:10.000
really play with the limits of programming languages.
link |
00:32:13.460
It's really beautiful to see
link |
00:32:14.600
and across all the different programming languages,
link |
00:32:17.040
you get to see some of these weird programming languages
link |
00:32:20.600
and mainstream ones, difference between Python 2 and 3,
link |
00:32:25.080
you get to see the difference between C and C++ and Java
link |
00:32:27.680
and you get to see JavaScript, all of that
link |
00:32:30.000
and it's kind of inspiring to see how much depth
link |
00:32:38.120
of possibility there is within programming languages
link |
00:32:41.040
that CodeGolf kind of tasks reveal.
link |
00:32:44.160
Most of us, if you do any kind of programming,
link |
00:32:46.560
you kind of do boring kind of very vanilla type of code.
link |
00:32:51.120
That's the way to build large systems
link |
00:32:52.840
but it's nice to see that the possibility
link |
00:32:54.700
of creative genius is still within those languages.
link |
00:32:57.600
It's laden within those languages.
link |
00:33:00.100
So given that you are once again,
link |
00:33:03.180
one of the greatest programmers ever,
link |
00:33:05.680
what do you think makes a good programmer?
link |
00:33:08.320
Maybe a good modern programmer.
link |
00:33:10.960
So I just gave a long rant slash lecture at Meta
link |
00:33:15.680
to the TPM organization and my biggest point was
link |
00:33:20.440
everything that we're doing really should flow
link |
00:33:23.280
from user value, all the good things that we're doing.
link |
00:33:26.120
It's like, we're not technical people.
link |
00:33:28.440
It's like, you shouldn't be taking pride
link |
00:33:30.960
just in the specific thing.
link |
00:33:32.080
Like CodeGolf is the sort of thing, it's a fun puzzle game
link |
00:33:34.880
but that really should not be a major motivator for you.
link |
00:33:38.160
It's like, we're solving problems for people
link |
00:33:40.260
or we're providing entertainment to people.
link |
00:33:41.960
We're doing something of value to people
link |
00:33:44.160
that's displacing something else in their life.
link |
00:33:46.240
So we wanna be providing a net value
link |
00:33:49.000
over what they could be doing
link |
00:33:51.360
but instead they're choosing to use our products.
link |
00:33:53.520
And that's where, I mean, it sounds trite or corny
link |
00:33:56.640
but I fundamentally do think that's how you make
link |
00:33:59.200
the world a better place.
link |
00:34:00.360
If you have given more value to people
link |
00:34:02.900
than it took you and your team to create,
link |
00:34:05.720
then the world's a better place.
link |
00:34:07.560
People have, they've gone from something of lesser value,
link |
00:34:10.500
chosen to use your product
link |
00:34:11.980
and their life feels better for that.
link |
00:34:13.880
And if you've produced that economically,
link |
00:34:16.280
that's a really good thing.
link |
00:34:19.480
On the other hand, if you spent ridiculous amounts of money
link |
00:34:22.800
you've just kind of shoveled a lot of cash
link |
00:34:24.340
into a wood chipper there
link |
00:34:25.720
and you should maybe not feel so good
link |
00:34:28.160
about what you're doing.
link |
00:34:29.720
So being proud about like a specific architecture
link |
00:34:33.560
or a specific technology or a specific code sequence
link |
00:34:36.440
that you've done, it's great to get a little smile
link |
00:34:39.160
like a tiny little dopamine hit for that
link |
00:34:41.140
but the top level metrics should be
link |
00:34:43.340
that you're building things of value.
link |
00:34:45.440
Now you can get into the argument about how you,
link |
00:34:48.040
what is user value?
link |
00:34:49.360
How do you actually quantify that?
link |
00:34:51.240
And there can be big arguments about that
link |
00:34:53.360
but it's easy to be able to say,
link |
00:34:55.120
okay, this pissed off user there is not getting value
link |
00:34:57.900
from what you're doing.
link |
00:34:59.080
This user over there with the big smile on their face,
link |
00:35:01.980
the moment of delight when something happened,
link |
00:35:04.240
there's a value that's happened there.
link |
00:35:05.900
I mean, you have to at least accept
link |
00:35:07.720
that there is a concept of user value
link |
00:35:09.840
even if you have trouble exactly quantifying it,
link |
00:35:12.880
you can usually make relative arguments about it.
link |
00:35:15.480
Well, this was better than this, we've improved things.
link |
00:35:18.860
So being a servant to the user is your job
link |
00:35:23.720
when you're a developer, you wanna be producing something
link |
00:35:26.680
that other people are gonna find valuable.
link |
00:35:30.000
And if you are technically inclined
link |
00:35:32.540
then finding the right levers to be able to pull
link |
00:35:35.760
to be able to make a design that's going to produce
link |
00:35:39.080
the most value for the least amount of effort.
link |
00:35:41.680
And it always has to be kind of divided,
link |
00:35:44.000
there's a ratio there where you,
link |
00:35:45.940
it's a problem at the big tech companies,
link |
00:35:48.080
whether it's Meta Google, Apple, Microsoft, Amazon,
link |
00:35:52.240
companies that have almost infinite money.
link |
00:35:55.320
I mean, I know their CFO will complain
link |
00:35:57.720
that it's not infinite money
link |
00:35:58.840
but from most developers standpoints
link |
00:36:00.640
it really does feel like it.
link |
00:36:02.680
And it's almost counterintuitive
link |
00:36:04.880
that if you're working hard as a developer on something,
link |
00:36:07.960
there's always this thought,
link |
00:36:08.820
if only I had more resources, more people, more RAM,
link |
00:36:12.360
more megahertz, then my product will be better.
link |
00:36:16.400
And that sense that at certain points, it's certainly true
link |
00:36:19.600
that if you are really hamstrung by this,
link |
00:36:22.080
removing an obstacle will make a better product,
link |
00:36:25.200
make more value.
link |
00:36:26.980
But if you're not making your core design decisions
link |
00:36:30.120
in this fiercely competitive way
link |
00:36:33.080
where you're saying feature A or feature B,
link |
00:36:35.780
you can't just say, let's do both.
link |
00:36:38.680
Because then you're not making a value judgment about them.
link |
00:36:41.160
You're just saying, well, they both seem good.
link |
00:36:43.000
I don't wanna necessarily have to pick out
link |
00:36:45.200
which one is better or how much better
link |
00:36:47.460
and tell team B that, sorry, we're not gonna do this
link |
00:36:51.020
because A is more important.
link |
00:36:53.160
But that notion of always having to really critically value
link |
00:36:57.120
what you're doing, your time, the resources you expend,
link |
00:36:59.720
even the opportunity cost of doing something else,
link |
00:37:02.620
that's super important.
link |
00:37:04.840
Well, let me ask you about the big debates
link |
00:37:07.600
that you're mentioning of how to measure value.
link |
00:37:12.120
Is it possible to measure it kind of numerically
link |
00:37:19.400
or can you do the sort of Johnny Ive,
link |
00:37:22.120
the designer route of imagining
link |
00:37:26.020
sort of somebody using a thing
link |
00:37:28.720
and imagining a smile on their face,
link |
00:37:30.840
imagining the experience of love and joy
link |
00:37:34.000
that you have when you use the thing.
link |
00:37:35.980
That's from a design perspective
link |
00:37:37.320
or if you're building more like a lower level thing
link |
00:37:40.440
for like Linux, you imagine a developer
link |
00:37:43.400
that might come across this and use it
link |
00:37:45.440
and become happy and better off because of it.
link |
00:37:50.440
So where do you land on those things?
link |
00:37:52.620
Is it measurable?
link |
00:37:53.680
So I imagine like Meta and Google
link |
00:37:57.280
will probably try to measure the thing.
link |
00:37:58.920
They'll try to, it's like you try to optimize engagement
link |
00:38:01.520
or something, let's measure engagement.
link |
00:38:03.240
And then I think there is a kind of,
link |
00:38:05.360
I mean, I admire the designer ethic of like,
link |
00:38:09.360
think of a future that's immeasurable
link |
00:38:13.000
and you try to make somebody in that future
link |
00:38:15.320
that's different from today happy.
link |
00:38:17.320
So I do usually favor,
link |
00:38:20.440
if you can get any kind of a metric that's good,
link |
00:38:23.800
by all means, listen to the data.
link |
00:38:25.840
But you can go too far there where we've had problems
link |
00:38:28.480
where it's like, hey, we had a performance regression
link |
00:38:30.640
because our fancy new telemetry system
link |
00:38:33.280
is doing a bazillion file writes
link |
00:38:36.000
to kind of archive this stuff
link |
00:38:37.200
because we needed to collect information
link |
00:38:38.740
to determine if we were doing,
link |
00:38:40.600
if our plans were good.
link |
00:38:42.600
So when information is available,
link |
00:38:45.540
you should never ignore it.
link |
00:38:46.720
I mean, all of it.
link |
00:38:47.560
For actual users using the thing,
link |
00:38:49.680
human beings using the thing,
link |
00:38:51.400
large number of human beings,
link |
00:38:52.880
and you get to see sort of a lot of large numbers.
link |
00:38:54.720
So there's the zero to one problem
link |
00:38:55.920
of when you're doing something really new,
link |
00:38:57.560
you do kind of have to make a guess.
link |
00:38:59.280
But one of the points that I've been making at Meta
link |
00:39:02.000
is we have more than enough users now
link |
00:39:05.120
that anything somebody wants to try in VR,
link |
00:39:08.440
we have users that will be interested in that.
link |
00:39:10.780
You do not get to make a completely
link |
00:39:13.080
greenfield blue sky pitch and say,
link |
00:39:15.820
I'm going to do this because I think it might be interesting.
link |
00:39:18.660
I challenge everyone.
link |
00:39:20.120
There are going to be people,
link |
00:39:21.640
whether it's working in VR on your,
link |
00:39:24.200
like on your desktop replacement
link |
00:39:26.880
or communicating with people in different ways
link |
00:39:29.560
or playing the games.
link |
00:39:31.640
There are going to be probably millions of people,
link |
00:39:35.120
or at least if you pick some tiny niche
link |
00:39:37.200
that we're not in right now,
link |
00:39:38.660
there's still going to be thousands of people out there
link |
00:39:40.820
that have the headsets that would be your target market.
link |
00:39:43.860
And I tell people, pay attention to them.
link |
00:39:46.060
Don't invent fictional users.
link |
00:39:47.680
Don't make an Alice Bob Charlie
link |
00:39:50.240
that fits whatever matrix of tendencies
link |
00:39:53.580
that you want to break the market down to,
link |
00:39:55.360
because it's a mistake to think about imaginary users
link |
00:39:58.320
when you've got real users that you could be working with.
link |
00:40:01.920
But on the other hand,
link |
00:40:03.080
there is value to having a kind of wholeness
link |
00:40:07.000
of vision for a product.
link |
00:40:09.520
And companies like Meta have,
link |
00:40:13.680
they understand the trade offs where you can have a company
link |
00:40:16.520
like SpaceX or Apple in the Steve Jobs era,
link |
00:40:20.240
where you have a very powerful leading personality
link |
00:40:23.360
that can micromanage at a very low level
link |
00:40:26.700
and can say it's like, no, that handle needs to be different
link |
00:40:29.360
or that icon needs to change the tint there.
link |
00:40:32.760
And they clearly get a lot of value out of it.
link |
00:40:34.960
They also burn through a lot of employees
link |
00:40:37.200
that have horror stories to tell
link |
00:40:39.000
about working there afterwards.
link |
00:40:41.680
My position is that you're at your best
link |
00:40:45.120
when you've got a leader that is at their limit
link |
00:40:48.120
of what they can kind of comprehend
link |
00:40:49.760
of everything below them.
link |
00:40:51.480
And they can have an informed opinion
link |
00:40:53.440
about everything that's going on.
link |
00:40:55.360
And you take somebody, you've got to believe
link |
00:40:57.480
that somebody that has 30, 40 years of experience,
link |
00:41:01.100
you would hope that they've got wisdom
link |
00:41:02.680
that the just out of bootcamp person contributing
link |
00:41:06.160
doesn't have.
link |
00:41:07.000
And that if they're like, well, that's wrong there,
link |
00:41:09.140
you probably shouldn't do it that way
link |
00:41:10.600
or even just don't do it that way, do it another way.
link |
00:41:14.120
So there's value there,
link |
00:41:15.500
but it can't go beyond a certain level.
link |
00:41:17.840
I mean, I have Steve Jobs stories of him saying things
link |
00:41:21.360
that are just wrong right in front of me
link |
00:41:23.060
about technical things because he was not operating
link |
00:41:25.840
at that level.
link |
00:41:28.460
But when it does work and you do get
link |
00:41:30.480
that kind of passionate leader
link |
00:41:32.020
that's thinking about the entire product
link |
00:41:34.120
and just really deeply cares
link |
00:41:35.840
about not letting anything slip through the cracks,
link |
00:41:39.060
I think that's got a lot of value.
link |
00:41:40.560
But the other side of that is the people saying that,
link |
00:41:42.520
well, we wanna have these independent teams
link |
00:41:44.520
that are bubbling up the ideas
link |
00:41:46.040
because it's almost it's anti capitalist
link |
00:41:49.480
or anti free market to say,
link |
00:41:50.940
it's like I want my grand, my great leader
link |
00:41:53.240
to go ahead and dictate all these points there
link |
00:41:55.240
where clearly free markets bring up things
link |
00:41:57.680
that you don't expect.
link |
00:41:59.360
Like in VR, we saw a bunch of things
link |
00:42:01.800
like it didn't turn out at all
link |
00:42:03.080
the way the early people thought
link |
00:42:04.320
were gonna be the key applications
link |
00:42:06.040
and things that would not have been approved
link |
00:42:08.800
by the dark cabal making the decisions
link |
00:42:12.260
about what gets into the store turn out
link |
00:42:14.680
to in some cases be extremely successful.
link |
00:42:17.640
So yeah, I definitely kind of wanted to be,
link |
00:42:20.460
there was a point where I did make a pitch.
link |
00:42:22.200
It's like, hey, make me VR dictator
link |
00:42:23.840
and I'll go in and get shit done.
link |
00:42:25.480
I am, and that's just, it's not in the culture at Meta.
link |
00:42:28.600
You know, and they understand the trade offs they,
link |
00:42:31.640
and that's just not the way,
link |
00:42:32.960
that's not the company that they want,
link |
00:42:34.500
the team that they wanna do.
link |
00:42:37.240
It's fascinating because VR and we'll talk about it more.
link |
00:42:40.120
It's still unclear to me
link |
00:42:44.260
in what way VR will change the world
link |
00:42:46.920
because it does seem clear that VR
link |
00:42:48.520
will somehow fundamentally transform this world
link |
00:42:51.720
and it's unclear to me how yet.
link |
00:42:54.840
Let me know when you wanna get into that.
link |
00:42:56.880
Who will?
link |
00:42:57.720
Well, hold on a second.
link |
00:42:58.540
So in the stick to the you being the best programmer ever.
link |
00:43:02.760
Okay, in the early days when you didn't have,
link |
00:43:05.200
when you didn't have adult responsibilities
link |
00:43:07.080
of leading teams and all that kind of stuff
link |
00:43:09.320
and you can focus on just being a programmer,
link |
00:43:13.200
what did the productive day in the life
link |
00:43:15.880
of John Carmack look like?
link |
00:43:17.760
How many hours is the keyboard?
link |
00:43:19.200
How much sleep?
link |
00:43:20.520
What was the source of calories that fueled the brain?
link |
00:43:24.280
What was it like?
link |
00:43:25.200
What times did you wake up?
link |
00:43:26.960
So I was able to be remarkably consistent
link |
00:43:29.500
about what was good working conditions for me
link |
00:43:32.100
for a very long time.
link |
00:43:34.800
I was never one of the programmers
link |
00:43:37.800
that would do all nighters going through work
link |
00:43:40.100
for 20 hours straight.
link |
00:43:41.220
It's like my brain generally starts turning to mush
link |
00:43:43.840
after 12 hours or so.
link |
00:43:45.860
But the hard work is really important
link |
00:43:48.940
and I would work for decades.
link |
00:43:51.180
I would work 60 hours a week.
link |
00:43:52.700
I would work a 10 hour day, six days a week
link |
00:43:55.260
and try to be productive at that.
link |
00:43:58.060
Now my schedule shifted around a fair amount
link |
00:44:00.100
when I was young without any kids
link |
00:44:02.260
and any other responsibilities.
link |
00:44:04.020
I was on one of those cycling schedules
link |
00:44:06.300
where I'd kind of get in an hour later each day
link |
00:44:08.620
and roll around through the entire time
link |
00:44:11.100
and I'd wind up kind of pulling in at two or three
link |
00:44:13.860
in the afternoon sometimes and then working again
link |
00:44:16.220
past midnight or two in the morning.
link |
00:44:19.100
And that was, when it was just me trying
link |
00:44:22.900
to make things happen and I was usually isolated off
link |
00:44:26.460
in my office, people generally didn't bother me much at in
link |
00:44:30.100
and I could get a lot of programming work done that way.
link |
00:44:34.100
I did settle into a more normal schedule
link |
00:44:36.380
when I was taking kids to school and things like that.
link |
00:44:39.500
So kids were the forcing function that got you to wake up
link |
00:44:42.020
at the same time each day.
link |
00:44:43.980
It's not clear to me that there was much of a difference
link |
00:44:46.740
in the productivity with that where I kind of feel,
link |
00:44:50.740
if I just get up when I feel like it,
link |
00:44:52.500
it's usually a little later each day
link |
00:44:54.420
but I just recently made the focusing decision
link |
00:44:57.620
to try to push my schedule back a little bit earlier
link |
00:44:59.980
to getting up at eight in the morning
link |
00:45:01.980
and trying to shift things around.
link |
00:45:04.220
Like I'm often doing experiments with myself
link |
00:45:07.340
about what should I be doing to be more productive
link |
00:45:10.260
and one of the things that I did realize was happening
link |
00:45:13.380
in recent months where I would go for a walk or a run.
link |
00:45:18.540
I cover like four miles a day and I would usually do that
link |
00:45:22.660
just as the sun's going down here in Texas now
link |
00:45:25.580
and it's still really damn hot but I'd go out
link |
00:45:27.820
at 8.30 or something and cover the time there
link |
00:45:31.300
and then the showering and it was putting a hold in my day
link |
00:45:34.100
where I would have still a couple hours after that
link |
00:45:36.980
and sometimes my best hours were at night
link |
00:45:38.860
when nobody else is around, nobody's bothering me
link |
00:45:41.300
but that hole in the day was a problem
link |
00:45:43.420
so just a couple weeks ago, I made the change
link |
00:45:46.780
to go ahead and say, all right,
link |
00:45:47.620
I'm gonna get up a little earlier,
link |
00:45:48.780
I'm gonna do a walk or get out there first
link |
00:45:51.180
so I can have more uninterrupted time.
link |
00:45:53.340
So I'm still playing with factors like this
link |
00:45:55.500
as I kind of optimize my work efforts
link |
00:45:59.340
but it's always been, it was 60 hours a week
link |
00:46:03.060
for a very long time.
link |
00:46:04.380
To some degree, I had a little thing in the back of my head
link |
00:46:06.660
where I was almost jealous of some of the programmers
link |
00:46:08.980
that would do these marathon sessions
link |
00:46:10.740
and I had like Dave Taylor, one of the guys that he had,
link |
00:46:13.420
he would be one of those people
link |
00:46:14.580
that would fall asleep under his desk sometimes
link |
00:46:16.580
and all the kind of classic hacker tropes about things
link |
00:46:19.500
and a part of me was like always a little bothered
link |
00:46:22.140
that that wasn't me, that I wouldn't go program
link |
00:46:25.460
20 hours straight because I'm falling apart
link |
00:46:28.300
and not being very effective after 12 hours.
link |
00:46:31.220
I mean, yeah, 12 hour programming,
link |
00:46:32.780
that's fine when you're doing that
link |
00:46:34.180
but it never, you're not doing smart work much after,
link |
00:46:38.060
at least I'm not, but there's a range of people.
link |
00:46:40.460
I mean, that's something that a lot of people
link |
00:46:41.980
don't really get in their gut
link |
00:46:43.860
where there are people that work on four hours of sleep
link |
00:46:46.740
and are smart and can continue to do good work
link |
00:46:48.980
but then there's a lot of people that just fall apart.
link |
00:46:51.580
So I do tell people that I always try
link |
00:46:54.620
to get eight hours of sleep.
link |
00:46:55.860
It's not this, you know, push yourself harder,
link |
00:46:58.380
get up earlier, I just do worse work
link |
00:47:00.980
where, you know, you can work a hundred hours a week
link |
00:47:04.140
and still get eight hours of sleep
link |
00:47:05.740
if you just kind of prioritize things correctly
link |
00:47:08.340
but I do believe in working hard, working a lot.
link |
00:47:12.380
There was a comment that a game dev made
link |
00:47:14.820
that I know there's a backlash against really hard work
link |
00:47:18.940
in a lot of cases and I get into online arguments
link |
00:47:21.620
about this all the time but he was basically saying,
link |
00:47:24.460
yeah, 40 hours a week, that's kind of a part time job
link |
00:47:27.340
and if you were really in it,
link |
00:47:29.340
you're doing what you think is important,
link |
00:47:31.300
what you're passionate about, working more gets more done
link |
00:47:34.940
and it's just really not possible to argue with that
link |
00:47:39.180
if you've been around the people
link |
00:47:40.500
that work with that level of intensity
link |
00:47:42.740
and just say, it's like, no, they should just stop.
link |
00:47:45.820
And we had, I kind of came back around to that
link |
00:47:49.060
a couple of years ago where I was using
link |
00:47:51.300
the fictional example of, all right, some people say,
link |
00:47:55.060
they'll say with a straight face, they think, no,
link |
00:47:57.340
you are less productive if you work
link |
00:47:59.300
more than 40 hours a week.
link |
00:48:01.140
And they're generally misinterpreting things
link |
00:48:03.060
where your marginal productivity for an hour
link |
00:48:05.860
after eight hours is less than in one of your peak hours
link |
00:48:08.940
but you're not literally getting less done.
link |
00:48:11.180
There is a point where you start breaking things
link |
00:48:13.260
and getting worse behavior and everything out of it
link |
00:48:16.580
where you're literally going backwards
link |
00:48:18.380
but it's not at eight or 10 or 12 hours.
link |
00:48:21.300
And the fictional example I would use was,
link |
00:48:23.660
imagine there's an asteroid coming to impact,
link |
00:48:27.140
to crash into Earth, destroy all of human life.
link |
00:48:30.420
Do you want Elon Musk or the people working at SpaceX
link |
00:48:34.180
that are building the interceptor
link |
00:48:35.620
that's going to deflect the asteroid,
link |
00:48:38.460
do you want them to clock out at five
link |
00:48:40.180
because damn it, they're just gonna go do worse work
link |
00:48:42.700
if they work another couple hours.
link |
00:48:44.780
And it seems absurd.
link |
00:48:47.100
And that's a hypothetical though
link |
00:48:48.580
and everyone can dismiss that.
link |
00:48:49.940
But then when coronavirus was hitting
link |
00:48:52.020
and you have all of these medical personnel
link |
00:48:54.580
that are clearly pushing themselves really, really hard
link |
00:48:58.060
and I'd say, it's like, okay,
link |
00:48:59.820
do you want all of these scientists working on treatments
link |
00:49:03.140
and vaccines and caring for all of these people?
link |
00:49:05.660
Are they really screwing everything up
link |
00:49:07.700
by working more than eight hours a day?
link |
00:49:09.780
And of course people say, I'm just an asshole
link |
00:49:11.420
to say something like that, but it's the truth.
link |
00:49:15.220
Working longer gets more done.
link |
00:49:17.540
Well, so that's kind of the layer one.
link |
00:49:20.540
But I'd like to also say that,
link |
00:49:22.540
at least I believe, depending on the person,
link |
00:49:25.940
depending on the task, working more and harder
link |
00:49:30.700
will make you better for the next week
link |
00:49:35.980
in those peak hours.
link |
00:49:37.660
So there's something about a deep dedication to a thing
link |
00:49:42.540
that kind of gets deep in you.
link |
00:49:44.820
So the hard work isn't just about the raw hours
link |
00:49:48.220
of productivity, it's the thing it does to you
link |
00:49:54.220
in the weeks and months after too.
link |
00:49:56.780
You're tempering yourself in some ways.
link |
00:49:59.100
And I think, it's like Jiro dreams of sushi.
link |
00:50:01.940
If you really dedicate yourself completely
link |
00:50:03.820
to making the sushi, to really putting in the long hours,
link |
00:50:08.020
day after day after day, you become a true craftsman
link |
00:50:12.540
of the thing you're doing.
link |
00:50:14.380
Now there's, of course, discussions about
link |
00:50:16.300
are you sacrificing a lot of personal relationships?
link |
00:50:18.940
Are you sacrificing a lot of other possible things
link |
00:50:21.740
you could do with that time?
link |
00:50:22.780
But if you're talking about purely being a master
link |
00:50:28.220
or a craftsman of your art,
link |
00:50:30.660
that more hours isn't just about doing more,
link |
00:50:34.980
it's about becoming better at the thing you're doing.
link |
00:50:37.300
Yeah, and I don't gainsay anybody
link |
00:50:38.780
that wants to work the minimum amount.
link |
00:50:41.180
They've got other priorities in their life.
link |
00:50:42.980
My only argument that I'm making,
link |
00:50:44.660
it's not that everybody should work hard,
link |
00:50:46.980
it's that if you want to accomplish something,
link |
00:50:49.380
working longer and harder
link |
00:50:50.820
is the path to getting it accomplished.
link |
00:50:53.340
Well, let me ask you about this then,
link |
00:50:56.180
the mythical work life balance.
link |
00:51:01.180
For an engineer, it seems like
link |
00:51:03.060
that's one of the professions for a programmer
link |
00:51:07.260
where working hard does lead to greater productivity in it.
link |
00:51:12.260
But it also raises the question of
link |
00:51:17.020
sort of personal relationships and all that kind of stuff,
link |
00:51:19.660
family, and how are you able to find work life balance?
link |
00:51:24.300
Is there advice you can give,
link |
00:51:25.740
maybe even outside of yourself?
link |
00:51:27.580
Have you been able to arrive at any wisdom
link |
00:51:29.900
on this part in your years of life?
link |
00:51:32.380
I do think that there's a wide range of people
link |
00:51:34.580
where different people have different needs.
link |
00:51:36.760
It's not a one size fits all.
link |
00:51:38.660
I am certainly what works for me.
link |
00:51:40.740
I can tell enough that I'm different
link |
00:51:45.140
than a typical average person
link |
00:51:46.620
in the way things impact me,
link |
00:51:48.620
the things that I want to do,
link |
00:51:50.300
my goals are different,
link |
00:51:51.540
and sort of the levers to impact things are different,
link |
00:51:55.160
where I have literally never felt burnout,
link |
00:51:59.540
and I know there's lots of brilliant, smart people
link |
00:52:02.060
that do world leading work that get burned out,
link |
00:52:05.340
and it's never hit me.
link |
00:52:08.060
I've never been at a point where I'm like,
link |
00:52:11.700
I just don't care about this.
link |
00:52:13.200
I don't want to do this anymore.
link |
00:52:14.780
But I've always had the flexibility
link |
00:52:16.420
to work on lots of interesting things.
link |
00:52:18.900
I can always just turn my gaze to something else
link |
00:52:21.480
and have a great time working on that.
link |
00:52:23.500
And so much of the ability to actually work hard
link |
00:52:27.140
is the ability to have multiple things to choose from
link |
00:52:29.620
and to use your time on the most appropriate thing.
link |
00:52:33.100
There are time periods where it's the best time
link |
00:52:36.940
for me to read a new research paper
link |
00:52:38.460
that I need to really be thinking hard about it.
link |
00:52:41.380
Then there's a time that maybe I should just scan
link |
00:52:43.420
and organize my old notes
link |
00:52:44.760
because I'm just not on top of things.
link |
00:52:47.160
Then there's the time that,
link |
00:52:48.420
all right, let's go bang out a few hundred lines of code
link |
00:52:51.520
for something.
link |
00:52:52.700
So switching between them has been real valuable.
link |
00:52:57.180
So you'll always have kind of joy in your heart
link |
00:52:59.780
for all the things you're doing,
link |
00:53:01.000
and that is a kind of work life balance
link |
00:53:03.260
as a first sort of step.
link |
00:53:04.820
Yeah, I do. So you're always happy.
link |
00:53:06.420
I do.
link |
00:53:07.260
Well, happy.
link |
00:53:08.460
Yeah, I mean, that's like a lot of people would say
link |
00:53:10.420
that often I look like kind of a grim person,
link |
00:53:12.580
you know, with just sitting there with a neutral expression
link |
00:53:15.100
or even like knitted brows and a frown on my face
link |
00:53:17.500
as I'm staring at something.
link |
00:53:18.980
That's what happiness looks like for you.
link |
00:53:20.660
Yeah, it's kind of true where that it's like,
link |
00:53:24.020
okay, I'm pushing through this, I'm making progress here.
link |
00:53:27.300
I know that doesn't work for everyone.
link |
00:53:30.140
I know it doesn't work for most people.
link |
00:53:33.100
But what I am always trying to do in those cases
link |
00:53:35.460
is I don't want to let somebody
link |
00:53:37.020
that might be a person like that be told by someone else
link |
00:53:40.500
that no, don't even try that out as an option
link |
00:53:44.180
where work life balance versus kind of your life's work
link |
00:53:48.740
where there's a small subset of the people
link |
00:53:51.740
that can be very happy being obsessive about things.
link |
00:53:55.540
And, you know, obsession can often get things done
link |
00:53:58.940
that just practical, prudent, pedestrian work won't
link |
00:54:03.180
or at least won't for a very long time.
link |
00:54:05.900
There's legends of your nutritional intake
link |
00:54:10.220
in the early days.
link |
00:54:11.500
What can you say about sort of as a, you know,
link |
00:54:15.580
being a programmer as a kind of athlete?
link |
00:54:17.900
So what was the nutrition that fueled?
link |
00:54:21.420
I have never been that great on really paying attention
link |
00:54:25.780
to it where I'm good enough that I don't eat a lot.
link |
00:54:29.380
You know, I've never been like a big heavy guy,
link |
00:54:31.620
but it was interesting where one of the things
link |
00:54:34.260
that I can remember being an unhappy teenager,
link |
00:54:36.660
not having enough money and like,
link |
00:54:38.540
one of the things that bothered me
link |
00:54:40.060
about not having enough money
link |
00:54:41.140
is I couldn't buy pizza whenever I wanted to.
link |
00:54:43.380
So I got rich and then I bought a whole lot of pizza.
link |
00:54:46.500
So that was defining, like, that's what being rich felt like.
link |
00:54:50.100
A lot of the little things, like I could buy all the pizza
link |
00:54:52.420
and comic books and video games that I wanted to.
link |
00:54:55.740
And it really didn't take that much,
link |
00:54:58.820
but the pizza was one of those things
link |
00:55:00.940
that it's absolutely true that for a long time
link |
00:55:03.420
at id Software, I had a pizza delivered every single day.
link |
00:55:06.460
You know, the delivery guy knew me by name
link |
00:55:09.020
and I didn't find out until years later
link |
00:55:11.620
that apparently I was such a good customer
link |
00:55:13.860
that they just never raised the price on me.
link |
00:55:15.780
And I was using this six year old price for the pizzas
link |
00:55:18.820
that they were still kind of sending my way every day.
link |
00:55:21.500
So you were doing eating once a day or were you?
link |
00:55:25.940
It would be spread out.
link |
00:55:26.820
You know, you have a few pieces of pizza,
link |
00:55:28.100
you have some more later on
link |
00:55:29.300
and I'd maybe have something at home.
link |
00:55:31.820
It was one of the nice things that Facebook Meta
link |
00:55:34.580
is they feed you quite well.
link |
00:55:36.820
You get a different, I guess now it's DoorDash
link |
00:55:39.460
sorts of things delivered,
link |
00:55:40.580
but they take care of making sure
link |
00:55:42.580
that everybody does get well fed.
link |
00:55:44.340
And I probably had better food those six years
link |
00:55:47.460
that I was working in the Meta office there
link |
00:55:49.540
than I used to before.
link |
00:55:51.620
But it's worked out okay for me.
link |
00:55:53.860
My health has always been good.
link |
00:55:55.220
I get a pretty good amount of exercise
link |
00:55:57.700
and I don't eat to excess
link |
00:55:59.940
and I avoid a lot of other kind of not so good
link |
00:56:02.660
for you things.
link |
00:56:03.660
So I'm still doing quite well at my age.
link |
00:56:05.620
Did you have a kind of, I don't know,
link |
00:56:10.140
spiritual experience with food or coffee
link |
00:56:13.620
or any of that kind of stuff?
link |
00:56:15.060
I mean, you know, the programming experience,
link |
00:56:17.500
you know, with music or like I listen to brown noise
link |
00:56:21.300
on a program or like creating an environment
link |
00:56:24.300
and the things you take into your body,
link |
00:56:26.100
just everything you construct
link |
00:56:27.940
can become a kind of ritual
link |
00:56:29.580
that empowers the whole process, the programming.
link |
00:56:32.180
Did you have that relationship with pizza or?
link |
00:56:34.620
It would really be with Diet Coke.
link |
00:56:35.940
I mean, there still is that sense of, you know,
link |
00:56:38.060
drop the can down, crack open the can of Diet Coke.
link |
00:56:40.500
All right, now I mean business.
link |
00:56:41.860
We're getting to work here.
link |
00:56:44.020
Still to this day?
link |
00:56:45.100
Yeah.
link |
00:56:45.940
Is Diet Coke still a part of it?
link |
00:56:46.860
Yeah, probably eight or nine a day.
link |
00:56:49.500
Nice.
link |
00:56:50.340
Okay, what about your setup?
link |
00:56:52.060
How many screens?
link |
00:56:53.980
What kind of keyboard?
link |
00:56:55.060
Is there something interesting?
link |
00:56:56.100
What kind of IDE, Emacs Vim or something modern?
link |
00:57:02.020
Linux, what operating system laptop
link |
00:57:04.100
or any interesting thing that brings you joy?
link |
00:57:06.980
So I kind of migrated cultures
link |
00:57:09.140
where early on through all of game dev,
link |
00:57:11.420
there was sort of one culture there,
link |
00:57:13.180
which was really quite distinct
link |
00:57:14.580
from the more the Silicon Valley venture,
link |
00:57:17.220
you know, culture for things.
link |
00:57:19.180
They're different groups
link |
00:57:20.140
and they have pretty different mores
link |
00:57:21.860
and the way they think about things where,
link |
00:57:24.540
and I still do think a lot of the big companies
link |
00:57:26.540
can learn things from the hardcore game development
link |
00:57:30.500
side of things where it still boggles my mind
link |
00:57:32.940
how hostile to debuggers and IDEs that so much of them,
link |
00:57:39.140
the kind of big money, get billions of dollars,
link |
00:57:41.660
Silicon Valley venture backed funds are.
link |
00:57:44.380
Oh, that's interesting.
link |
00:57:45.220
Sorry, so you're saying like big companies
link |
00:57:48.100
like Google and Meta are hostile to?
link |
00:57:50.180
They are not big on debuggers and IDEs.
link |
00:57:52.780
Like so much of it is like Emacs, Vim for things.
link |
00:57:55.740
And we just assume that debuggers don't work
link |
00:57:58.820
most of the time for the systems.
link |
00:58:01.060
And a lot of this comes from a sort of Linux bias
link |
00:58:03.780
on a lot of things where I did come up
link |
00:58:06.420
through the personal computers and then the DOS
link |
00:58:09.060
and then Windows and it was Borland tools
link |
00:58:14.020
and then Visual Studio and.
link |
00:58:16.740
Do you appreciate the buggers?
link |
00:58:18.500
Very much so.
link |
00:58:19.340
I mean, a debugger is how you get a view into a system
link |
00:58:22.020
that's too complicated to understand.
link |
00:58:23.860
I mean, anybody that thinks just read the code
link |
00:58:25.780
and think about it.
link |
00:58:26.780
That's an insane statement in the,
link |
00:58:28.620
you can't even read all the code on a big system.
link |
00:58:31.020
You have to do experiments on the system
link |
00:58:34.100
and doing that by adding log statements,
link |
00:58:36.900
recompiling and rerunning it
link |
00:58:39.060
is an incredibly inefficient way of doing it.
link |
00:58:41.140
I mean, yes, you can always get things done
link |
00:58:43.500
even if you're working with stone knives and bear skins.
link |
00:58:46.380
That is the mark of a good programmer
link |
00:58:48.780
is that given any tools,
link |
00:58:50.420
you will figure out a way to get it done,
link |
00:58:52.500
but it's amazing what you can do
link |
00:58:54.820
with sometimes much, much better tools
link |
00:58:57.140
where instead of just going through this iterative
link |
00:58:59.900
compile run debug cycle,
link |
00:59:02.100
you have the old Lisp direction of like,
link |
00:59:05.060
you've got a REPL and you're working interactively
link |
00:59:07.020
and doing amazing things there.
link |
00:59:08.340
But in many cases, a debugger
link |
00:59:10.380
as a very powerful user interface that can stop,
link |
00:59:13.380
examine all the different things in your program,
link |
00:59:15.500
set all of these different breakpoints.
link |
00:59:16.940
And of course you can do that with GDB or whatever there,
link |
00:59:20.180
but this is one of the user interface
link |
00:59:22.780
fundamental principles
link |
00:59:23.980
where when something is complicated to do,
link |
00:59:26.620
you won't use it very often.
link |
00:59:28.460
There's people that will break out GDB
link |
00:59:30.620
when they're at their wits end
link |
00:59:31.940
and they just have beat their head
link |
00:59:33.260
against a problem for so long.
link |
00:59:35.180
But for somebody that kind of grew up in game dev,
link |
00:59:37.860
it's like they were running into the debugger anyways
link |
00:59:40.060
before they even knew there was a problem.
link |
00:59:42.140
And you would just stop and see what was happening.
link |
00:59:44.820
And sometimes you could fix things
link |
00:59:46.340
even before you did one compile cycle.
link |
00:59:50.580
You could be in the debugger and you would say,
link |
00:59:52.160
well, I'm just going to change this right here.
link |
00:59:54.220
And yep, that did the job and fix it and go on.
link |
00:59:57.020
And for people who don't know,
link |
00:59:57.860
GDB is a sort of popular, I guess, Linux debugger
link |
01:00:03.060
primarily for C++.
link |
01:00:05.260
They handle most of the languages,
link |
01:00:06.660
but it's based on C as the original kind of Unix heritage.
link |
01:00:10.420
And it's kind of like command line.
link |
01:00:11.740
It's not user friendly.
link |
01:00:13.340
It doesn't allow for clean visualizations
link |
01:00:15.500
and you're exactly right.
link |
01:00:17.180
So that you're using this kind of debugger
link |
01:00:18.980
usually when you're at what's end
link |
01:00:21.020
and there's a problem that you can't figure out why
link |
01:00:23.380
by just looking at the codes, you have to find it.
link |
01:00:25.980
That's how I guess normal programmers use it.
link |
01:00:28.580
But you're saying there should be tools
link |
01:00:30.060
that kind of visualize and help you
link |
01:00:32.620
as part of the programming process,
link |
01:00:35.300
just the normal programming process
link |
01:00:37.460
to understand the code deeper.
link |
01:00:39.940
Yeah, when I'm working on like my C, C++ code,
link |
01:00:42.900
I'm always running it from the debugger.
link |
01:00:45.540
Just I type in the code, I run it many times.
link |
01:00:48.420
The first thing I do after writing code
link |
01:00:50.220
is set a break point and step through the function.
link |
01:00:53.020
Now other people will say, it's like,
link |
01:00:54.100
oh, I do that in my head.
link |
01:00:55.500
Well, your head is a faulty interpreter
link |
01:00:57.780
of all those things there.
link |
01:00:59.060
And I've written brand new code.
link |
01:01:01.020
I wanna step in there
link |
01:01:01.980
and I'm gonna single step through that,
link |
01:01:03.460
examine lots of things
link |
01:01:04.700
and see if it's actually doing what I expected it to.
link |
01:01:08.500
It is a kind of companion, the debugger.
link |
01:01:12.180
Like you're now coding in an interactive way
link |
01:01:14.860
with another being.
link |
01:01:17.700
The debugger is a kind of dumb being,
link |
01:01:19.420
but it's a reliable being.
link |
01:01:21.340
That is an interesting question
link |
01:01:22.500
of what role does AI play in that kind of,
link |
01:01:25.940
with codecs and these kind of ability to generate code,
link |
01:01:29.500
that might be, you might start having tools
link |
01:01:32.060
that understand the code in interesting deep ways
link |
01:01:35.900
that can work with you.
link |
01:01:37.780
There's a whole spectrum there
link |
01:01:39.020
from static code analyzers and various kind of dynamic tools
link |
01:01:43.100
there up to AI that can conceivably grok these programs
link |
01:01:46.660
that literally no human can understand.
link |
01:01:49.060
They're too big, too intertwined and too interconnected,
link |
01:01:51.940
but it's not beyond the possibility of understanding.
link |
01:01:54.940
It's just beyond what we can hold in our heads
link |
01:01:57.820
as kind of mutable state while we're working on things.
link |
01:02:00.860
And I'm a big proponent, again,
link |
01:02:03.260
of things like static analyzers and some of that stuff
link |
01:02:06.140
where you'll find some people that don't like being scolded
link |
01:02:10.420
by a program for how they've written something
link |
01:02:12.660
where it's like, oh, I know better.
link |
01:02:14.100
And sometimes you do, but that was something
link |
01:02:16.460
that it was very, very valuable for me
link |
01:02:20.580
when, and not too many people get an opportunity
link |
01:02:23.220
like this to have.
link |
01:02:24.060
This is almost one of those spiritual experiences
link |
01:02:26.060
as a programmer, an awakening to,
link |
01:02:28.900
the id software code bases
link |
01:02:30.300
were a couple of million lines of code.
link |
01:02:32.220
And at one point I had used a few
link |
01:02:34.660
of the different analysis tools,
link |
01:02:36.300
but I made a point to really go through
link |
01:02:39.580
and scrub the code base using every tool that I could find.
link |
01:02:43.260
And it was eyeopening where we had a reputation
link |
01:02:45.620
for having some of the most robust, strongest code,
link |
01:02:48.740
where there were some great things
link |
01:02:50.700
that I remember hearing from Microsoft
link |
01:02:52.940
telling us about crashes on Xbox.
link |
01:02:54.980
And we had this tiny number that they said
link |
01:02:56.780
were probably literally hardware errors.
link |
01:02:59.380
And then you have other significant titles
link |
01:03:01.380
that just have millions of faults
link |
01:03:03.380
that are getting recorded all the time.
link |
01:03:04.900
So I was proud of our code on a lot of levels,
link |
01:03:07.620
but when I took this code analysis squeegee
link |
01:03:10.700
through everything, it was shocking
link |
01:03:14.420
how many errors there were in there.
link |
01:03:16.740
Things that you can say, okay, this was a copy paste,
link |
01:03:19.780
not changing something right here.
link |
01:03:21.700
Lots of things that were, the most common problem
link |
01:03:25.220
was something in a printf format string
link |
01:03:27.780
that was the wrong data type that could cause crashes there.
link |
01:03:30.460
And you really want the warnings for things like that.
link |
01:03:33.340
Then the next most common was missing a check for null
link |
01:03:36.140
that could actually happen, that could blow things up.
link |
01:03:38.420
And those are obviously like top C, C++ things.
link |
01:03:41.580
Everybody has those problems.
link |
01:03:43.340
But the long tail of all of the different little things
link |
01:03:46.180
that could go wrong there, and we had good programmers
link |
01:03:49.100
and my own code, stuff that I'd be looking at,
link |
01:03:51.020
it's like, oh, I wrote that code, that's definitely wrong.
link |
01:03:53.700
We've been using this for a year
link |
01:03:56.100
and it's this submarine, this mine sitting there
link |
01:03:59.660
waiting for us to step on.
link |
01:04:01.660
And it was humbling.
link |
01:04:03.700
It was, and I reached the conclusion
link |
01:04:05.980
that anything that can be syntactically allowed
link |
01:04:09.380
in your language, if it's gonna show up eventually
link |
01:04:13.380
in a large enough code base,
link |
01:04:15.420
you're not gonna, good intentions
link |
01:04:16.900
aren't going to keep it from happening.
link |
01:04:18.740
You need automated tools and guardrails for things.
link |
01:04:21.820
And those start with things like static types
link |
01:04:24.060
and or even type hints in the more dynamic languages.
link |
01:04:26.980
But the people that rebel against that,
link |
01:04:30.180
that basically say that slows me down doing that.
link |
01:04:33.660
There's something to that, I get that.
link |
01:04:35.260
I've written, I've cobbled things together in a notebook.
link |
01:04:38.860
I'm like, wow, this is great that it just happened,
link |
01:04:41.020
but yeah, that's kind of sketchy,
link |
01:04:42.500
but it's working fine, I don't care.
link |
01:04:44.020
It does come back to that value analysis
link |
01:04:47.140
where sometimes it's right to not care.
link |
01:04:49.740
But when you do care, if it's going to be something
link |
01:04:52.460
that's going to live for years
link |
01:04:53.900
and it's gonna have other people working on it,
link |
01:04:56.300
and it's gonna be deployed to millions of people,
link |
01:04:59.060
then you wanna use all of these tools.
link |
01:05:01.180
You wanna be told it's like, no,
link |
01:05:02.780
you've screwed up here, here and here.
link |
01:05:04.340
And that does require kind of an ego check about things
link |
01:05:08.020
where you have to be open to the fact
link |
01:05:11.180
that everything that you're doing
link |
01:05:12.260
is just littered with flaws.
link |
01:05:14.020
It's not that, oh, you occasionally have a bad day.
link |
01:05:16.380
It's just whatever stream of code you output,
link |
01:05:19.180
there is going to be a statistical regularity of things
link |
01:05:21.780
that you just make mistakes on.
link |
01:05:24.140
And I do think there's the whole argument
link |
01:05:27.420
about test driven design and unit testing
link |
01:05:29.980
versus kind of analysis and different things.
link |
01:05:33.020
I am more in favor of the analysis and the stuff
link |
01:05:36.020
that just like you can't run your program
link |
01:05:37.660
until you fix this rather than you can run it
link |
01:05:40.220
and hopefully a unit test will catch it in some way.
link |
01:05:42.980
Yeah, in my private code, I have asserts everywhere.
link |
01:05:46.660
Yeah.
link |
01:05:48.420
There's something pleasant to me, pleasurable to me
link |
01:05:52.340
about sort of the dictatorial rule of like,
link |
01:05:55.300
this should be true at this point.
link |
01:05:58.340
And too many times I've made mistakes
link |
01:06:03.420
that shouldn't have been made.
link |
01:06:05.820
And I would assume I wouldn't be the kind of person
link |
01:06:08.500
that would make that mistake,
link |
01:06:09.340
but I keep making that mistake.
link |
01:06:10.580
Therefore, an assert really catches me,
link |
01:06:13.940
really helps all the time.
link |
01:06:15.340
So my code, I would say like 10 to 20% of my private code
link |
01:06:19.020
just for personal use is probably asserts.
link |
01:06:21.420
And they're active comments.
link |
01:06:22.540
That's one of those things that in theory,
link |
01:06:24.900
they don't make any difference to the program.
link |
01:06:27.220
And if it was all operating the way you expected
link |
01:06:29.540
it would be, then they will never fire.
link |
01:06:32.740
But even if you have it right
link |
01:06:34.660
and you wrote the code right initially,
link |
01:06:36.820
then circumstances change.
link |
01:06:38.380
The world outside your program changes.
link |
01:06:40.860
And in fact, that's one of the things
link |
01:06:42.900
where I'm kind of fond in a lot of cases
link |
01:06:45.460
of static array size declarations,
link |
01:06:47.580
where I went through this period where it's like,
link |
01:06:49.860
okay, now we have general collection classes.
link |
01:06:51.980
We should just make everything variable
link |
01:06:54.460
because I had this history of in the early days,
link |
01:06:57.540
you get doom, which had some fixed limits on it.
link |
01:07:00.020
Then everybody started making crazier and crazier things.
link |
01:07:02.580
And they kept bumping up the different limits,
link |
01:07:04.180
this many lines, this many sectors.
link |
01:07:06.820
And it seemed like a good idea,
link |
01:07:09.020
well, we should just make this completely generic.
link |
01:07:10.900
It can go kind of go up to whatever.
link |
01:07:13.780
And there's cases where that's the right thing to do,
link |
01:07:17.340
but it also, the other aspect of the world
link |
01:07:19.820
changing around you is it's good to be informed
link |
01:07:23.060
when the world has changed more than you thought it would.
link |
01:07:25.700
And if you've got a continuously growing collection,
link |
01:07:28.420
you're never gonna find out.
link |
01:07:29.580
You might have this quadratic slow down on something
link |
01:07:32.220
where you thought, oh, I'm only ever gonna have
link |
01:07:34.460
a handful of these, but something changes
link |
01:07:36.900
and there's a new design style.
link |
01:07:38.220
And all of a sudden you've got 10,000 of them.
link |
01:07:40.780
So I kind of like in many cases, picking a number,
link |
01:07:44.900
some nice brown power of two number
link |
01:07:47.580
and setting it up in there and having an assert saying,
link |
01:07:49.900
it's like, hey, you hit this limit.
link |
01:07:52.180
You should probably think are the choices
link |
01:07:54.340
that you've made around all of this still relevant
link |
01:07:56.940
if somebody's using 10 times more
link |
01:07:59.260
than you thought they would.
link |
01:08:00.340
Yeah, this code was originally written
link |
01:08:02.620
with this kind of worldview,
link |
01:08:04.420
with this kind of set of constraints.
link |
01:08:06.700
You were thinking of the world in this way.
link |
01:08:09.380
If something breaks, that means you gotta rethink
link |
01:08:11.740
the initial stuff.
link |
01:08:13.100
And it's nice for it to do that.
link |
01:08:16.500
Is there any stuff like a keyboard or monitors?
link |
01:08:21.500
I'm a fairly pedestrian on a lot of that
link |
01:08:23.780
where I did move to triple monitors
link |
01:08:26.140
like in the last several years ago.
link |
01:08:27.660
I had been dual monitor for a very long time.
link |
01:08:30.180
And it was one of those things where probably years later
link |
01:08:34.820
than I should have, I'm just like, well,
link |
01:08:36.140
the video cards now generally have three output ports.
link |
01:08:38.660
I should just put the third monitor up there.
link |
01:08:40.420
That's been a pure win.
link |
01:08:41.900
I've been very happy with that.
link |
01:08:44.380
But no, I don't have fancy keyboard or mouse
link |
01:08:47.140
or anything really going on.
link |
01:08:48.540
The key things is an IDE that has helpful debuggers,
link |
01:08:52.540
has helpful tools.
link |
01:08:54.100
So it's not the Emacs Vim route and then Dicode.
link |
01:08:56.980
Yeah, so I did spend,
link |
01:08:58.780
I spent one of my week long retreats where I'm like,
link |
01:09:01.940
okay, I'm gonna make myself use,
link |
01:09:04.260
it was actually classic VI,
link |
01:09:05.540
which I know people will say you should never have done that.
link |
01:09:07.380
You should have just used Vim directly.
link |
01:09:09.340
But I gave it the good try.
link |
01:09:11.340
It's like, okay, I'm being in kind of classic
link |
01:09:13.980
Unix developer mode here.
link |
01:09:15.740
And I worked for a week on it.
link |
01:09:18.580
I used Anki to like teach myself
link |
01:09:20.580
the different little key combinations
link |
01:09:22.860
for things like that.
link |
01:09:23.980
And in the end, it was just like, all right,
link |
01:09:26.020
this was kind of like my civil war reenactment phase.
link |
01:09:28.940
It's like, I'm going out there doing it
link |
01:09:30.380
like they used to in the old days.
link |
01:09:31.980
And it was kind of fun in that regard.
link |
01:09:34.060
So many people right now.
link |
01:09:35.300
They're screaming as they're listening to this.
link |
01:09:38.660
So again, the out is that this was not modern Vim,
link |
01:09:41.180
but still, yes, I was very happy to get back
link |
01:09:44.620
to my visual studio at the end.
link |
01:09:46.820
Yeah, I'm actually, I struggle with this a lot
link |
01:09:49.540
because I use a Kinesis keyboard
link |
01:09:52.100
and I use Emacs primarily.
link |
01:09:56.020
And I feel like I can, exactly as you said,
link |
01:09:59.140
I can understand the code.
link |
01:10:00.220
I can navigate the code.
link |
01:10:01.300
There's a lot of stuff you could build with an Emacs
link |
01:10:03.700
with using Lisp.
link |
01:10:04.820
You can customize a lot of things for yourself
link |
01:10:07.300
to help you introspect the code,
link |
01:10:09.900
like to help you understand the code
link |
01:10:11.620
and visualize different aspects of the code.
link |
01:10:13.060
You can even run debuggers,
link |
01:10:14.500
but it's work and the world moves past you
link |
01:10:18.940
and the better and better ideas are constantly being built.
link |
01:10:21.900
And that puts a kind of,
link |
01:10:25.420
I need to take the same kind of retreat
link |
01:10:27.220
as you're talking about,
link |
01:10:28.300
but now I'm still fighting the civil war.
link |
01:10:30.860
I need to kind of move into the 21st century.
link |
01:10:33.220
And it does seem like the world is,
link |
01:10:34.980
or a large chunk of the world is moving
link |
01:10:37.060
towards visual studio code,
link |
01:10:38.660
which is kind of interesting to me.
link |
01:10:40.420
Again, it's the JavaScript ecosystem on the one hand
link |
01:10:43.260
and IDs are one of those things
link |
01:10:45.380
that you want to be infinitely fast.
link |
01:10:47.860
You want them to just kind of immediately respond.
link |
01:10:50.940
And like, I mean, heck, I've got,
link |
01:10:52.500
there's someone I know,
link |
01:10:53.340
I'm an old school game dev guy
link |
01:10:55.100
that still uses visual studio six.
link |
01:10:57.420
And on a modern computer,
link |
01:10:59.460
everything is just absolutely instant
link |
01:11:01.940
on something like that,
link |
01:11:02.940
because it was made to work on a computer
link |
01:11:04.620
that's 10,000 or a hundred thousand times slower.
link |
01:11:07.820
So just everything happens immediately.
link |
01:11:10.540
And all the modern systems just feel,
link |
01:11:13.500
they feel so crufty when it's like,
link |
01:11:15.300
oh, why is this refreshing the screen
link |
01:11:17.260
and moving around and updating over here?
link |
01:11:19.220
And something blinks down there
link |
01:11:20.660
and you should update this.
link |
01:11:21.820
And there are things that we've lost
link |
01:11:25.660
with that incredible flexibility,
link |
01:11:27.380
but lots of people get tons of value from it.
link |
01:11:31.060
And I am super happy that that seems to be winning
link |
01:11:33.540
over even a lot of the old Vim and Emacs people
link |
01:11:36.140
that they're kind of like,
link |
01:11:37.140
hey, visual studio codes, maybe not so bad.
link |
01:11:40.060
I am, that may be the final peacekeeping solution
link |
01:11:43.260
where everybody is reasonably happy
link |
01:11:45.620
with something like that.
link |
01:11:47.900
So can you explain what a dot plan file is
link |
01:11:50.540
and what role that played in your life?
link |
01:11:53.420
Does it still continue to play a role?
link |
01:11:55.540
Back in the early, early days of id Software,
link |
01:11:58.660
one of our big things that was unique with what we did
link |
01:12:01.180
is I had adopted next stations
link |
01:12:04.020
or kind of next step systems
link |
01:12:05.660
from Steve Jobs's out in the woods away from Apple company.
link |
01:12:11.660
And they were basically, it was kind of interesting
link |
01:12:15.180
because I did not really have a background
link |
01:12:17.140
with the Unix system.
link |
01:12:18.020
So many of the people they get immersed in that in college
link |
01:12:21.820
and that sets a lot of cultural expectations for them.
link |
01:12:27.500
And I didn't have any of that,
link |
01:12:29.300
but I knew that my background was,
link |
01:12:31.940
I was a huge Apple II fan boy.
link |
01:12:34.420
I was always a little suspicious of the Mac.
link |
01:12:36.420
I was not really what kind of I wanted to go with.
link |
01:12:41.380
But when Steve Jobs left Apple and started Next,
link |
01:12:44.540
this computer did just seem like one of those amazing things
link |
01:12:46.940
from the future where it had all of this cool stuff in it.
link |
01:12:50.460
And we were still back in those days working on DOS,
link |
01:12:53.340
everything blew up.
link |
01:12:54.220
You had reset buttons
link |
01:12:55.540
because your computer would just freeze.
link |
01:12:56.980
If you're doing development work,
link |
01:12:58.420
literally dozens of times a day,
link |
01:12:59.940
your computer was just rebooting constantly.
link |
01:13:02.420
And so this idea of, yes, any of the Unix workstations
link |
01:13:06.420
would have given a stable development platform
link |
01:13:08.620
where you don't crash and reboot all the time.
link |
01:13:11.420
But Next also had this really amazing graphical interface
link |
01:13:15.540
and it was great for building tools.
link |
01:13:17.420
And it used Objective C as kind of an interesting dead end
link |
01:13:22.500
for things like that.
link |
01:13:23.340
So Next was Unix based, it said Objective C.
link |
01:13:26.140
So it has a lot of the elements.
link |
01:13:27.780
That became Mac.
link |
01:13:28.700
I mean, the kind of reverse acquisition of Apple by Next
link |
01:13:31.420
where that took over
link |
01:13:32.780
and became what the modern Mac system is.
link |
01:13:35.300
And to find some of the developer,
link |
01:13:38.300
like the tools and the whole community.
link |
01:13:41.540
Yeah, you've still got,
link |
01:13:42.380
if you're programming on Apple stuff now,
link |
01:13:43.820
there's still all these NS somethings,
link |
01:13:45.620
which was originally Next step objects
link |
01:13:47.660
of different kinds of things.
link |
01:13:49.420
But one of the aspects of those Unix systems
link |
01:13:52.900
was they had this notion of a.plan file
link |
01:13:56.220
where a.file is an invisible file.
link |
01:14:00.220
Usually in your home directory or something.
link |
01:14:02.060
And there was a trivial server running
link |
01:14:03.700
on most Unix systems at the time
link |
01:14:05.900
that when somebody ran a trivial little command
link |
01:14:09.620
called finger, you could do finger
link |
01:14:11.980
and then somebody's address,
link |
01:14:13.500
it could be anywhere on the internet
link |
01:14:15.140
if you were connected correctly.
link |
01:14:16.780
Then all that server would do was read the.plan file
link |
01:14:20.740
in that user's home directory
link |
01:14:22.460
and then just spit it out to you.
link |
01:14:24.460
And originally the idea was that could be
link |
01:14:27.140
whether you're on vacation, what your current project was.
link |
01:14:30.060
It's supposed to be like the plan of what you're doing.
link |
01:14:32.420
And people would use it for various purposes,
link |
01:14:35.700
but all it did was dump that file over
link |
01:14:39.220
to the terminal of whoever issued the finger command.
link |
01:14:42.660
And at one point I started just keeping a list
link |
01:14:46.820
of what I was doing in there,
link |
01:14:48.860
which would be what I was working on in the day.
link |
01:14:51.060
And I would have this little syntax.
link |
01:14:53.620
I kind of got to myself about,
link |
01:14:55.740
here's something that I'm working on.
link |
01:14:57.140
I put a star when I finish it.
link |
01:14:58.700
I could have a few other little bits of punctuation.
link |
01:15:01.380
And at the time it was,
link |
01:15:02.900
it started off as being just like my to do list.
link |
01:15:05.540
And it would be these trivial, obscure little things
link |
01:15:08.620
like I fixed something with collision detection code,
link |
01:15:12.740
made Fireball do something different
link |
01:15:14.900
and just little one liners that people
link |
01:15:16.700
that were following the games could kind of decipher.
link |
01:15:20.060
But I did wind up starting to write much more in depth things.
link |
01:15:24.220
I would have little notes of thoughts and insights
link |
01:15:28.460
and then I would eventually start having little essays.
link |
01:15:30.420
I would sometimes dump into the dot plan files
link |
01:15:33.020
interspersed with the work logs of things that I was doing.
link |
01:15:36.180
So in some ways it was like a super early proto blog
link |
01:15:39.620
where I was just kind of dumping out what I was working on.
link |
01:15:42.620
But it was interesting enough that there were a lot
link |
01:15:45.460
of people that were interested in this.
link |
01:15:48.740
So most of the people didn't have Unix workstation.
link |
01:15:51.220
So there were the websites back in the day
link |
01:15:53.300
that would follow the Doom and Quake development
link |
01:15:55.500
that would basically make a little service
link |
01:15:58.380
that would go grab all the changes
link |
01:15:59.780
and then people could just get it with a web browser.
link |
01:16:02.180
And there was a period where like all of the little
link |
01:16:04.940
kind of Dallas gaming diaspora of people
link |
01:16:07.580
that were at all in that orbit,
link |
01:16:09.340
there were a couple dozen plan files going on,
link |
01:16:12.220
which was, and this was some years before blogging
link |
01:16:15.460
really became kind of a thing.
link |
01:16:17.180
And it was kind of a premonition
link |
01:16:20.420
of sort of the way things would go.
link |
01:16:22.220
And there was, it's all been collected.
link |
01:16:25.020
It's available online in different places.
link |
01:16:27.060
And it's kind of fun to go back and look through
link |
01:16:29.340
what I was thinking, what I was doing in the different areas.
link |
01:16:32.420
Have you had a chance to look back?
link |
01:16:33.780
Is there some interesting, very low level specific
link |
01:16:37.340
to do items, maybe things you've never completed,
link |
01:16:40.380
all that kind of stuff and high level philosophical essay
link |
01:16:44.180
type of stuff that stands out?
link |
01:16:46.300
Yeah, there's some good stuff on both
link |
01:16:48.340
where a lot of it was low level nitpicky details
link |
01:16:51.940
about game dev and I've learned enough things
link |
01:16:55.820
where there's no project that I worked on
link |
01:16:58.300
that I couldn't go back and do a better job on now.
link |
01:17:00.620
I mean, you just, you learn things,
link |
01:17:02.380
hopefully if you're doing it right,
link |
01:17:03.820
you learn things as you get older
link |
01:17:05.340
and you should be able to do a better job
link |
01:17:07.300
at all of the early things.
link |
01:17:08.700
And there's stuff in Wolfenstein Doomquake that's like,
link |
01:17:12.220
oh, clearly I could go back and do a better job at this,
link |
01:17:15.780
whether it's something in the rendering engine side
link |
01:17:17.860
or how I implemented the monster behaviors
link |
01:17:20.940
or managed resources or anything like that.
link |
01:17:22.780
Do you see the flaws in your thinking now?
link |
01:17:24.980
Like looking back?
link |
01:17:26.220
Yeah, I do.
link |
01:17:27.060
I mean, sometimes I'll get the,
link |
01:17:29.060
I'll look at it and say, yeah, I had a pretty clear view
link |
01:17:31.500
of I was doing good work there.
link |
01:17:33.940
And I haven't really hit the point
link |
01:17:35.940
where there was another programmer, Graham Devine,
link |
01:17:38.740
who was, he had worked at ID and Seventh Guest
link |
01:17:41.740
and he made some comment one time
link |
01:17:43.700
where he said he looked back at some of his old notes
link |
01:17:45.660
and he was like, wow, I was really smart back then.
link |
01:17:48.740
And I don't hit that so much where,
link |
01:17:52.140
I mean, I look at it and I always know that,
link |
01:17:54.300
yeah, there's all the, you know, with aging,
link |
01:17:56.500
you get certain changes in how you're able to work problems,
link |
01:18:00.060
but all of the problems that I've worked,
link |
01:18:02.260
I'm sure that I could do a better job on all of them.
link |
01:18:06.260
Oh, wow.
link |
01:18:07.100
So you can still step right in.
link |
01:18:08.380
If you could travel back in time and talk to that guy,
link |
01:18:10.900
you would teach him a few things.
link |
01:18:12.060
Yeah, absolutely.
link |
01:18:14.260
That's awesome.
link |
01:18:15.860
What about the high level philosophical stuff?
link |
01:18:18.020
Is there some insights that stand out that you remember?
link |
01:18:20.620
There's things that I was understanding about development
link |
01:18:25.340
and, you know, in the industry and so on
link |
01:18:28.140
that were in a more primitive stage
link |
01:18:31.300
where I definitely learned a lot more in the later years
link |
01:18:36.620
about business and organization and team structure.
link |
01:18:41.300
There were, I mean, there were definitely things
link |
01:18:44.580
that I was not the best person
link |
01:18:46.820
or even a very good person about managing,
link |
01:18:48.900
like how a team should operate internally,
link |
01:18:51.580
how people should work together.
link |
01:18:53.420
I was just, you know, just get out of my way
link |
01:18:57.420
and let me work on the code and do this.
link |
01:18:59.500
And more and more, I've learned how,
link |
01:19:03.420
in the larger scheme of things,
link |
01:19:04.980
how sometimes relatively unimportant
link |
01:19:07.220
some of those things are,
link |
01:19:08.340
where it is this user value generation
link |
01:19:11.020
that's the overarching importance for all of that.
link |
01:19:14.060
And I didn't necessarily have my eye on that ball correctly
link |
01:19:17.940
through a lot of my, you know, my earlier years.
link |
01:19:21.180
And there's things that, you know,
link |
01:19:23.380
I could have gotten more out of people
link |
01:19:25.580
handling things in different ways.
link |
01:19:27.460
I am, you know, I could have made, you know,
link |
01:19:29.780
in some ways more successful products
link |
01:19:32.020
by following things in different ways.
link |
01:19:33.820
There's mistakes that we made
link |
01:19:35.340
that we couldn't really have known
link |
01:19:37.180
how things would have worked out,
link |
01:19:38.500
but it was interesting to see in later years companies
link |
01:19:41.220
like Activision showing that,
link |
01:19:42.380
hey, you really can just do the same game,
link |
01:19:44.980
make it better every year.
link |
01:19:46.580
And you can look at that from a negative standpoint
link |
01:19:48.540
and say, it's like, oh, that's just being derivative
link |
01:19:50.500
and all that.
link |
01:19:51.460
But if you step back again and say, it's like, no,
link |
01:19:53.580
are the people buying it still enjoying it?
link |
01:19:55.460
Are they enjoying it more
link |
01:19:56.500
than what they might have bought otherwise?
link |
01:19:59.060
And you can say, no, that's actually
link |
01:20:00.900
a great value creation engine to do that
link |
01:20:03.660
if you're in a position where you can.
link |
01:20:05.980
I, you know, don't be forced into reinventing everything
link |
01:20:09.260
just because you think that you need to.
link |
01:20:12.740
You know, lots of things about business and team stuff
link |
01:20:15.860
that could be done better, but the technical work,
link |
01:20:18.460
the kind of technical visionary type stuff
link |
01:20:20.740
that I laid out, I still feel pretty good about.
link |
01:20:23.860
There are some classic old ones about my defending
link |
01:20:26.540
of OpenGL versus D3D,
link |
01:20:29.220
which turned out to be one of the more
link |
01:20:32.180
probably important momentous things there
link |
01:20:34.420
where it never, it was always a rear guard action on Windows
link |
01:20:38.820
where Microsoft was just not gonna let that win.
link |
01:20:42.260
But when I look back on it now,
link |
01:20:44.300
that fight to keep OpenGL relevant
link |
01:20:46.660
for a number of years there
link |
01:20:48.740
meant that OpenGL was there when mobile started happening
link |
01:20:52.580
and OpenGL ES was the thing that drove
link |
01:20:55.580
all of the acceleration of the mobile industry.
link |
01:20:58.540
And it's really only in the last few years
link |
01:21:00.860
as Apple's moved to Metal
link |
01:21:02.460
and some of the other companies have moved to Vulkan
link |
01:21:04.980
that that's moved away.
link |
01:21:06.700
But really stepping back and looking at it,
link |
01:21:09.420
it's like, yeah, I sold tens of millions of games
link |
01:21:11.900
for different things.
link |
01:21:13.580
But billions and billions of devices wound up
link |
01:21:17.380
with an appropriate capable graphics API
link |
01:21:21.220
due in no small part to me thinking
link |
01:21:23.740
that that was really important
link |
01:21:25.180
that we not just give up and use Microsoft's
link |
01:21:30.540
at that time really terrible API.
link |
01:21:32.900
The thing about Microsoft is the APIs don't stay terrible.
link |
01:21:35.820
They were terrible at the start, but a few versions on,
link |
01:21:38.940
they were actually quite good.
link |
01:21:40.060
And there was a completely fair argument to be made
link |
01:21:42.460
that by the time DX9 was out,
link |
01:21:45.020
it was probably a better programming environment
link |
01:21:47.220
than OpenGL, but it was still a wonderful good thing
link |
01:21:51.100
that we had an open standard
link |
01:21:52.540
that could show up on Linux and Android and iOS
link |
01:21:55.740
and eventually WebGL still to this day.
link |
01:21:58.620
So that was one, that would be on my greatest hits list
link |
01:22:02.620
of things that I kind of pushed with.
link |
01:22:04.460
The impact it had on billions of devices, yes.
link |
01:22:07.700
So let's talk about it.
link |
01:22:08.940
Can you tell the origin story of id Software?
link |
01:22:12.380
Again, one of the greatest game developer companies ever.
link |
01:22:16.340
It created Wolfenstein 3D games
link |
01:22:18.900
that defined my life also in many ways
link |
01:22:22.580
as a thing that made me realize
link |
01:22:24.280
what computers are capable of in terms of graphics,
link |
01:22:26.700
in terms of performance, it just unlocked something deep
link |
01:22:31.620
in me and understanding what these machines are all about
link |
01:22:34.220
as games can do that.
link |
01:22:35.140
So Wolfenstein 3D, Doom, Quake,
link |
01:22:37.420
and just all the incredible engineering innovation
link |
01:22:40.700
that went into that.
link |
01:22:41.780
So how did it all start?
link |
01:22:44.300
So I'll caveat upfront
link |
01:22:45.940
that I usually don't consider myself the historian
link |
01:22:49.460
of the software side of things.
link |
01:22:51.480
I usually do kind of point people at John Romero
link |
01:22:55.020
for stories about the early days where I've never been,
link |
01:23:00.140
like I've commented that I'm a remarkably
link |
01:23:01.780
unsentimental person in some ways
link |
01:23:03.980
where I don't really spend a lot of time
link |
01:23:05.780
unless I'm explicitly prodded to go back
link |
01:23:07.980
and think about the early days of things.
link |
01:23:10.300
And I didn't necessarily make the effort
link |
01:23:14.660
to archive everything exactly in my brain.
link |
01:23:17.100
And the more that I work on machine learning and AI
link |
01:23:19.460
and the aspects of memory
link |
01:23:20.880
and how when you go back and polish certain things,
link |
01:23:23.360
it's not necessarily exactly the way it happened.
link |
01:23:25.920
But having said all of that, from my view,
link |
01:23:29.580
the way everything happened that led up to that was
link |
01:23:34.220
after I was an adult
link |
01:23:36.140
and kind of taking a few college classes
link |
01:23:38.140
and deciding to drop out, I was doing,
link |
01:23:40.860
I was hardscrabble contract programming work,
link |
01:23:43.620
really struggling to kind of keep groceries
link |
01:23:46.220
and pay my rent and things.
link |
01:23:48.140
And the company that I was doing the most work for
link |
01:23:50.560
was a company called Softdisk Publishing,
link |
01:23:53.180
which had the sounds bizarre now business model
link |
01:23:57.100
of monthly subscription software.
link |
01:23:59.780
Before there was an internet that people could connect to
link |
01:24:02.300
and get software, you would pay a certain amount
link |
01:24:05.780
and every month they would send you a disc
link |
01:24:07.540
that had some random software on it.
link |
01:24:09.780
And people that were into computers
link |
01:24:11.460
thought this was kind of cool.
link |
01:24:12.740
And they had different ones for the Apple II,
link |
01:24:14.980
the 2GS, the PC, the Mac, the Amiga,
link |
01:24:18.900
lots of different things here.
link |
01:24:20.060
So quirky little business,
link |
01:24:21.440
but I was doing a lot of contract programming for them
link |
01:24:24.580
where I'd write tiny little games
link |
01:24:26.460
and sell them for 300, $500.
link |
01:24:29.980
And one of the things that I was doing again
link |
01:24:32.920
to keep my head above water here was
link |
01:24:35.080
I decided that I could make one program
link |
01:24:38.020
and I could port it to multiple systems.
link |
01:24:41.060
So I would write a game like Dark Designs or Catacombs
link |
01:24:44.900
and I would develop it on the Apple II, the 2GS
link |
01:24:47.940
and the IBM PC, which apparently was the thing
link |
01:24:51.780
that really kind of piqued the attention
link |
01:24:54.300
of the people working down there.
link |
01:24:56.420
Like Jay Wilbur was my primary editor
link |
01:24:58.500
and Tom Hall was a secondary editor.
link |
01:25:01.220
And they kept asking me, it's like,
link |
01:25:02.700
hey, you should come down and work for us here.
link |
01:25:06.060
And I pushed it off a couple of times
link |
01:25:08.300
because I was really enjoying my freedom
link |
01:25:10.300
of kind of being off on my own.
link |
01:25:11.840
Even if I was barely getting by, I loved it.
link |
01:25:14.700
I was doing nothing but programming all day,
link |
01:25:17.760
but I did have enough close scrapes with like,
link |
01:25:20.500
damn, I'm just really out of money
link |
01:25:21.980
that maybe I should get an actual job
link |
01:25:25.020
rather than contracting these kind of one at a time things.
link |
01:25:27.940
And Jay Wilbur was great.
link |
01:25:29.400
He was like FedExing me the checks when I would need them.
link |
01:25:32.020
I had to kind of get over whatever hump I was at.
link |
01:25:35.700
So I took the, I finally took them up on their offer
link |
01:25:38.720
to come down to Shreveport, Louisiana.
link |
01:25:41.260
I was in Kansas city at the time,
link |
01:25:43.820
drove down to through the Ozarks and everything
link |
01:25:47.320
down to Louisiana and saw the soft disk offices,
link |
01:25:51.820
went through, talked to a bunch of people,
link |
01:25:53.740
met the people I had been working with remotely
link |
01:25:56.520
at that time.
link |
01:25:57.800
But the most important thing for me
link |
01:25:59.180
was I met two programmers there,
link |
01:26:01.740
John Romero and Lane Roth that for the first time ever,
link |
01:26:04.780
I had met programmers that knew more cool stuff than I did
link |
01:26:08.500
where the world was just different back then.
link |
01:26:11.020
I was in Kansas city.
link |
01:26:12.420
It was one of those smartest kid in the school
link |
01:26:14.620
does all the computer stuff.
link |
01:26:15.980
The teachers don't have anything to teach him.
link |
01:26:18.140
But all I had to learn from was these few books
link |
01:26:20.320
at the library.
link |
01:26:21.260
It was not much at all.
link |
01:26:23.100
And there were some aspects of programming
link |
01:26:25.220
that were kind of black magic to me.
link |
01:26:27.220
Like, it's like, oh, he knows how to format a track on,
link |
01:26:30.180
I am on a low level drive programming interface.
link |
01:26:34.300
And this was, I was still not at all sure
link |
01:26:37.380
I was gonna take the job,
link |
01:26:38.560
but I met these awesome programmers
link |
01:26:40.820
that were doing cool stuff.
link |
01:26:42.300
And Romero had worked at Origin Systems
link |
01:26:44.380
and he had done like, so many different games ahead of time
link |
01:26:49.020
that I did kind of quickly decide,
link |
01:26:50.740
it's like, yeah, I'll go take the job down there.
link |
01:26:53.220
And I settled down there, moved in
link |
01:26:57.100
and started working on more little projects.
link |
01:26:59.780
And the first kind of big change that happened down there
link |
01:27:03.060
was the company wanted to make a gaming focused,
link |
01:27:05.620
a PC gaming focused subscription.
link |
01:27:08.260
Just like all their other,
link |
01:27:09.180
it was the same formula that they used for everything.
link |
01:27:11.880
Pay a monthly fee and you'll get a disc
link |
01:27:14.760
with one or two games just every month
link |
01:27:16.940
and no choice in what you get, but we think it'll be fun.
link |
01:27:19.860
And that was the model they were comfortable with
link |
01:27:21.980
and they said, all right,
link |
01:27:22.820
we're gonna start this gamers edge department.
link |
01:27:25.140
And all of us that were interested in that,
link |
01:27:27.860
like me, Romero, Tom Hall was kind of helping us
link |
01:27:31.420
from his side of things, Jay would peek in
link |
01:27:34.100
and we had a few other programmers working with us
link |
01:27:37.160
at the time.
link |
01:27:38.220
And we were going to just start making games,
link |
01:27:41.260
just the same model.
link |
01:27:43.400
And we dived in and it was fantastic.
link |
01:27:45.860
Do you have to make new games?
link |
01:27:47.560
Every month.
link |
01:27:48.400
Every month.
link |
01:27:49.220
Yeah.
link |
01:27:50.060
And this, in retrospect, looking back at it,
link |
01:27:52.740
that sense that I had done all this contract programming
link |
01:27:55.380
and John Romero had done like far more of this
link |
01:27:58.060
where he had done one of his teaching himself efforts
link |
01:28:00.900
was he made a game for every letter of the alphabet.
link |
01:28:03.420
It's that sense of like,
link |
01:28:04.260
I'm just gonna go make 26 different games,
link |
01:28:06.260
give them a different theme.
link |
01:28:07.700
And you learn so much when you go through
link |
01:28:10.300
and you crank these things out
link |
01:28:12.180
like on a biweekly, monthly basis,
link |
01:28:14.580
something like that. From start to finish.
link |
01:28:16.060
It's not like just an idea.
link |
01:28:17.860
It's not just from the very beginning to the very end.
link |
01:28:21.760
It's done.
link |
01:28:22.860
It has to be done.
link |
01:28:24.300
There's no delaying.
link |
01:28:25.300
It's done.
link |
01:28:26.140
And you've got deadlines.
link |
01:28:26.980
And that kind of rapid iteration pressure cooker environment
link |
01:28:32.100
was super important for all of us developing the skills
link |
01:28:35.300
that brought us to where we eventually went to.
link |
01:28:38.500
I mean, people would say like,
link |
01:28:39.980
like in the history of the Beatles,
link |
01:28:41.180
like it wasn't them being the Beatles.
link |
01:28:43.100
It was them playing all of these other early works
link |
01:28:46.060
that that opportunity to craft all of their skills
link |
01:28:48.340
before they were famous,
link |
01:28:49.820
that was very critical to their later successes.
link |
01:28:53.000
And I think there's a lot of that here
link |
01:28:54.940
where we did these games that nobody remembers,
link |
01:28:58.740
lots of little things that contributed
link |
01:29:00.940
to building up the skillset for the things
link |
01:29:02.900
that eventually did make us famous.
link |
01:29:05.340
Yeah, Dostoevsky wrote The Gambler.
link |
01:29:08.340
I had to write it in a month, just to make money.
link |
01:29:12.420
And nobody remembers that probably
link |
01:29:14.620
because he had to figure out,
link |
01:29:15.820
because it's literally,
link |
01:29:17.980
he didn't have enough time to write it fast enough.
link |
01:29:21.140
So he had to come up with hacks.
link |
01:29:23.060
Literally,
link |
01:29:23.900
it again comes down to that point
link |
01:29:25.220
where pressure and limitation of resources
link |
01:29:28.260
is surprisingly important.
link |
01:29:30.340
And it's counterintuitive in a lot of ways
link |
01:29:32.580
where you just think that if you've got all the time
link |
01:29:34.340
in the world and you've got all the resources in the world,
link |
01:29:36.580
of course, you're gonna get something better.
link |
01:29:38.420
But sometimes it really does work out
link |
01:29:40.380
that the innovations, mother necessity,
link |
01:29:44.420
where you can, or resource constraints,
link |
01:29:46.440
and you have to do things when you don't have a choice.
link |
01:29:49.300
It's surprising what you can do.
link |
01:29:50.740
Is there any good games written in that time?
link |
01:29:52.740
Would you say?
link |
01:29:53.580
Some of them are still fun to go back and play
link |
01:29:55.700
where you get the,
link |
01:29:58.220
they were all about kind of,
link |
01:29:59.900
the more modern term is game feel,
link |
01:30:01.820
about how just the exact feel that things,
link |
01:30:04.140
it's not the grand strategy of the design,
link |
01:30:06.260
but how running and jumping and shooting
link |
01:30:08.860
and those things I feel in the moment.
link |
01:30:11.780
And some of those are still,
link |
01:30:13.420
if you sat down on them, you kind of go,
link |
01:30:15.180
it's a little bit different.
link |
01:30:16.060
It doesn't have the same movement feel,
link |
01:30:17.780
but you move over and you're like, bang, jump, bang.
link |
01:30:20.780
It's like, hey, that's kind of cool still.
link |
01:30:23.180
So you can get lost in the rhythm of the game.
link |
01:30:25.980
Is that what you mean by feel?
link |
01:30:27.820
Just like there's something about it that pulls you in?
link |
01:30:31.380
Nowadays, again, people talk about compulsion loops
link |
01:30:33.820
and things where it's that sense of exactly
link |
01:30:37.220
what you're doing, what your fingers are doing
link |
01:30:38.900
on the keyboard, what your eyes are seeing,
link |
01:30:41.140
and there are gonna be these sequences of things.
link |
01:30:43.300
Grab the loot, shoot the monster,
link |
01:30:44.860
jump over the obstacle, get to the end of the level.
link |
01:30:47.020
These are eternal aspects of game design in a lot of ways,
link |
01:30:50.620
but there are better and worse ways to do all of them.
link |
01:30:53.300
And we did so many of these games
link |
01:30:55.380
that we got a lot of practice with it.
link |
01:30:58.820
So one of the kind of weird things
link |
01:31:01.060
that was happening at this time
link |
01:31:02.460
is John Romero was getting some strange fan mail.
link |
01:31:06.740
And back in the days, this was before email.
link |
01:31:09.140
So we literally got letters sometimes and telling him,
link |
01:31:12.420
it's like, oh, I wanna talk to you about your games.
link |
01:31:14.340
I wanna reach out, different things.
link |
01:31:17.100
And eventually it turned out
link |
01:31:19.660
that these were all coming from Scott Miller
link |
01:31:21.980
at Apogee Software.
link |
01:31:23.980
And he was reaching out through,
link |
01:31:26.300
he didn't think he could contact John directly,
link |
01:31:28.300
that he would get intercepted.
link |
01:31:29.540
So he was trying to get him to contact him
link |
01:31:31.700
through like back channel fan mail,
link |
01:31:34.260
because he basically was saying,
link |
01:31:35.460
hey, I'm making all this money on shareware games.
link |
01:31:38.540
I want you to make shareware games,
link |
01:31:40.860
because he had seen some of the games
link |
01:31:42.580
that Romero had done.
link |
01:31:44.500
And we looked at Scott Miller's games
link |
01:31:47.780
and we didn't think they were very good.
link |
01:31:50.500
We're like, that can't be making the kind of money
link |
01:31:53.100
that he's saying he's making 10 grand or something
link |
01:31:56.220
off of this game.
link |
01:31:57.140
And we really thought that he was full of shit,
link |
01:31:59.380
that it was a lie trying to get him into this.
link |
01:32:03.140
But so that was kind of going on at one level.
link |
01:32:07.980
And it was funny the moment when Romero realized
link |
01:32:10.180
that he had some of these letters pinned up on his wall,
link |
01:32:12.500
like all of his fans.
link |
01:32:13.540
And then we noticed that they all had the same return
link |
01:32:15.380
address with different names on them,
link |
01:32:17.340
which was a little bit of a two edged sword there.
link |
01:32:19.860
Trying to figure out the puzzle laid out before him.
link |
01:32:23.420
Yeah, what happened after I kind of coincident with that
link |
01:32:26.660
was I was working on a lot of the new technologies
link |
01:32:29.860
where I was now full on the IBM PC for the first time,
link |
01:32:33.860
where I was really a long hold out on Apple II forever.
link |
01:32:37.220
And I loved my Apple II.
link |
01:32:38.980
It was the computer I always wished I had
link |
01:32:40.660
when I was growing up.
link |
01:32:41.700
And when I finally did have one,
link |
01:32:43.140
I was kind of clinging on to that well past it
link |
01:32:46.180
sort of good use by day.
link |
01:32:47.540
Is it the best computer ever made you would you say?
link |
01:32:50.740
I wouldn't make judgments like that about it,
link |
01:32:53.180
but it was positioned in such a way,
link |
01:32:54.740
especially in the school systems that it impacted
link |
01:32:57.660
a whole lot of American programmers at least,
link |
01:33:00.420
where there was programs that the Apple IIs
link |
01:33:02.940
got into the schools and they had enough capability
link |
01:33:05.980
that lots of interesting things happened with them.
link |
01:33:08.780
In Europe, it was different.
link |
01:33:09.820
You had your Amigas and Ataris and Acorns in the UK
link |
01:33:13.980
and things that had different things.
link |
01:33:16.100
But in the United States,
link |
01:33:17.060
it was probably the Apple II made the most impact
link |
01:33:19.740
for a lot of programmers of my generation.
link |
01:33:23.300
But so I was really digging into the IBM
link |
01:33:26.100
and this was even more so with the total focus
link |
01:33:29.340
because I had moved to another city
link |
01:33:30.780
where I didn't know anybody that I wasn't working with.
link |
01:33:33.860
I had a little apartment and then at Softdisk,
link |
01:33:36.380
again, the things that drew me to it,
link |
01:33:38.780
I had a couple of programmers that knew more than I did
link |
01:33:42.260
and they had a library.
link |
01:33:43.580
They had a set of books and a set of magazines.
link |
01:33:46.060
They had a couple of years of magazines,
link |
01:33:47.700
the old Dr. Dobbs journal and all of these magazines
link |
01:33:50.700
that had information about things.
link |
01:33:53.140
And so I was just in total immersion mode.
link |
01:33:56.500
It was eat, breathe, sleep, computer programming,
link |
01:33:59.460
particularly the IBM for everything that I was doing.
link |
01:34:03.300
And I was digging into a lot of these
link |
01:34:05.060
low level hardware details
link |
01:34:06.580
that people weren't usually paying attention to,
link |
01:34:08.900
the way the IBM EGA cards worked, which was fun for me.
link |
01:34:13.900
I hadn't had experience with things at that level.
link |
01:34:16.460
And back then you could get hardware documentation
link |
01:34:19.580
just down at the register levels.
link |
01:34:21.020
This is where the CRTC register is.
link |
01:34:23.460
This is how the color registers work
link |
01:34:25.620
and how the different things are applied.
link |
01:34:27.420
And they were designed for a certain reason.
link |
01:34:29.820
They were designed for an application.
link |
01:34:31.420
They had an intended use in mind,
link |
01:34:33.780
but I was starting to look at other ways
link |
01:34:36.820
that they could perhaps be exploited
link |
01:34:38.260
that they weren't initially intended for.
link |
01:34:40.260
Could you comment on like, first of all, what operating system was there?
link |
01:34:44.020
What instruction set was it?
link |
01:34:45.820
Like, what are we talking about?
link |
01:34:48.580
So this was DOS and x86.
link |
01:34:50.500
So 16 bit, 8086.
link |
01:34:52.740
The 286s were there and 386s existed.
link |
01:34:55.460
They were rare.
link |
01:34:56.860
We had a couple for our development systems,
link |
01:34:59.380
but we were still targeting the more broad.
link |
01:35:02.740
It was all DOS 16 bit.
link |
01:35:04.940
None of this was kind of DOS extenders and things.
link |
01:35:07.540
How different is it from the systems of today?
link |
01:35:09.420
Is it kind of a precursor that's similar?
link |
01:35:12.340
Very little.
link |
01:35:13.020
If you open up command.exe or com on Windows,
link |
01:35:17.700
you see some of the remnants of all of that,
link |
01:35:19.700
but it was a different world.
link |
01:35:21.060
It was the 640K is enough world, and nothing was protected.
link |
01:35:25.620
It crashed all the time.
link |
01:35:26.740
You had TSRs or terminate and stay resident hacks
link |
01:35:29.940
on top of things that would cause configuration problems.
link |
01:35:33.180
All the hardware was manually configured in your auto exec.
link |
01:35:37.500
So it was a very different world.
link |
01:35:39.260
But the code is still the same, similar.
link |
01:35:41.300
You could still write it.
link |
01:35:42.540
My earliest code there was written in Pascal.
link |
01:35:44.660
That was what I had learned at an earlier point.
link |
01:35:47.700
So between BASIC and C++, there was Pascal.
link |
01:35:51.180
So when BASIC assembly language, some of my intermediate stuff
link |
01:35:55.460
was, well, you had to for performance.
link |
01:35:57.020
BASIC was just too slow.
link |
01:35:58.380
So most of the work that I was doing
link |
01:36:00.460
as a contract programmer in my teenage years
link |
01:36:02.820
was assembly language.
link |
01:36:05.100
Wait, you wrote games in assembly?
link |
01:36:07.180
Yeah, complete games in assembly language.
link |
01:36:10.660
And it's thousands and thousands of lines
link |
01:36:12.700
of three letter acronyms for the instructions.
link |
01:36:16.580
You don't earn the once again greatest programmer ever label
link |
01:36:21.060
without being able to write a game in assembly.
link |
01:36:23.140
OK.
link |
01:36:23.620
That's good.
link |
01:36:24.980
Everybody serious wrote their games in assembly language.
link |
01:36:27.380
It was kind of a.
link |
01:36:28.140
Everybody serious.
link |
01:36:28.900
See what he said?
link |
01:36:29.700
Everybody serious.
link |
01:36:31.180
It was an outlier to use Pascal a little bit,
link |
01:36:33.940
where there was one famous program called wizardry.
link |
01:36:36.420
It was one of the great early role playing games
link |
01:36:39.460
that was written in Pascal.
link |
01:36:40.900
But it was almost nothing used Pascal there.
link |
01:36:43.540
But I did learn Pascal.
link |
01:36:45.140
And I remember doing all of my.
link |
01:36:47.220
To this day, I sketch in data structures.
link |
01:36:49.260
When I'm thinking about something, I'll open up a file
link |
01:36:52.660
and I'll start writing struct definitions for how
link |
01:36:55.340
data is going to be laid out.
link |
01:36:56.900
And Pascal was kind of formative to that
link |
01:36:58.940
because I remember designing my RPGs in Pascal record
link |
01:37:02.260
structures and things like that.
link |
01:37:04.100
And so I had gotten the Pascal compiler for the Apple 2GS
link |
01:37:07.940
that I could work on.
link |
01:37:08.740
And the first IBM game that I developed, I did in Pascal.
link |
01:37:12.420
And that's actually kind of an interesting story,
link |
01:37:14.860
again, talking about the constraints and resources
link |
01:37:17.900
where I had an Apple 2GS.
link |
01:37:19.980
I didn't have an IBM PC.
link |
01:37:21.500
I wanted to port my applications to IBM
link |
01:37:24.540
because I thought I could make more money on it.
link |
01:37:27.060
So what I wound up doing is I rented a PC for a week
link |
01:37:31.540
and bought a copy of Turbo Pascal.
link |
01:37:33.940
And so I had a hard one week and this was cutting into
link |
01:37:36.820
what minimal profit margin I had there.
link |
01:37:38.900
But I had this computer for a week.
link |
01:37:40.340
I had to get my program ported before I had to return
link |
01:37:43.300
the PC and that was kind of what the first thing
link |
01:37:46.780
that I had done on the IBM PC and what led me
link |
01:37:49.220
to taking the job at Softdisk.
link |
01:37:51.620
And Turbo Pascal, how's that different from regular Pascal?
link |
01:37:55.260
Is it a different compiler or something like that?
link |
01:37:57.380
It was a product of Borland, which before Microsoft
link |
01:38:00.060
kind of killed them, they were the hot stuff
link |
01:38:02.980
developer tools company.
link |
01:38:04.180
You had Borland, Turbo Pascal and Turbo C
link |
01:38:06.540
and Prologue, I mean, all the different things.
link |
01:38:09.540
But what they did was they took a supremely pragmatic
link |
01:38:12.780
approach of making something useful.
link |
01:38:14.500
It was one of these great examples where Pascal
link |
01:38:17.220
was an academic language and you had things like
link |
01:38:20.340
the UCSDP system that Wizardry was actually written in
link |
01:38:23.780
that they did manage to make a game with that,
link |
01:38:27.020
but it was not a super practical system.
link |
01:38:30.860
While Turbo Pascal was, it was called Turbo
link |
01:38:33.540
because it was blazingly fast to compile.
link |
01:38:35.540
I mean, really ridiculously 10 to 20 times faster
link |
01:38:39.460
than most other compilers at the time.
link |
01:38:41.620
But it also had very pragmatic access to look,
link |
01:38:44.360
you can just poke at the hardware in these different ways
link |
01:38:46.820
and we have libraries that let you do things.
link |
01:38:49.260
And it was a pretty good, it was a perfectly good way
link |
01:38:51.660
to write games and this is one of those things
link |
01:38:53.700
where people have talked about different paths
link |
01:38:56.500
that computer development could have taken
link |
01:38:58.660
where C took over the world for reasons
link |
01:39:01.940
that came out of Unix and eventually Linux.
link |
01:39:05.100
And that was not a foregone conclusion at all.
link |
01:39:07.260
And people can make real reasoned rational arguments
link |
01:39:10.860
that the world might've been better
link |
01:39:12.440
if it had gone a Pascal route.
link |
01:39:14.420
I'm somewhat agnostic on that where I do know
link |
01:39:17.660
from experience, it was perfectly good enough to do that.
link |
01:39:21.260
And it had some fundamental improvements
link |
01:39:23.180
like it had range checked arrays as an option there,
link |
01:39:26.100
which could avoid many of C's real hazards
link |
01:39:29.620
that happened in a security space.
link |
01:39:31.560
But C1, they were basically offering it
link |
01:39:33.740
about the same level of abstraction.
link |
01:39:35.580
It was a systems programming language, but.
link |
01:39:38.660
But you said Pascal had a more emphasis on data structures.
link |
01:39:41.380
I actually, in the tree of languages,
link |
01:39:44.980
did Pascal come before C?
link |
01:39:48.100
They were pretty contemporaneous.
link |
01:39:49.660
So Pascal's lineage went to Modula 2 and eventually Oberon,
link |
01:39:53.380
which was another Nicholas word, kind of experimental language.
link |
01:39:58.740
But they were all good enough at that level.
link |
01:40:01.420
Now, some of the classic academic oriented Pascals
link |
01:40:04.340
were just missing fundamental things like, oh, you can't
link |
01:40:06.380
access this core system thing because we're just
link |
01:40:08.620
using it to teach students.
link |
01:40:10.340
But Turbo Pascal showed that only modest changes to it
link |
01:40:14.060
really did make it a completely capable language.
link |
01:40:17.140
And it had some reasons why you could implement it
link |
01:40:19.620
as a single pass compiler so it could be way, way faster,
link |
01:40:22.580
although less scope for optimizations
link |
01:40:24.460
if you do it that way.
link |
01:40:26.260
And it did have some range checking options.
link |
01:40:28.300
It had a little bit better typing capability.
link |
01:40:30.740
You'd have properly typed enums, sorts of things,
link |
01:40:33.140
and other stuff that C lacked.
link |
01:40:35.220
But C was also clearly good enough.
link |
01:40:37.900
And it wound up with a huge inertia
link |
01:40:39.660
from the Unix ecosystem and everything that came with that.
link |
01:40:42.740
Garbage collection?
link |
01:40:43.980
No, it was not garbage collected.
link |
01:40:45.380
It's just the same kind of thing as C.
link |
01:40:46.500
Same manual.
link |
01:40:47.100
So you could still have your use after freeze
link |
01:40:49.100
and all those other problems.
link |
01:40:50.320
But just getting rid of array overruns,
link |
01:40:53.740
at least if you were compiled with that debugging option,
link |
01:40:56.080
certainly would have avoided a lot of problems
link |
01:40:58.260
and could have a lot of benefits.
link |
01:40:59.740
But so anyways, that was the next thing.
link |
01:41:01.400
I had to learn C because C was where it seemed like most
link |
01:41:04.780
of the things were going.
link |
01:41:07.020
So I abandoned Pascal and I started working in C.
link |
01:41:09.580
I started hacking on these hardware things dealing
link |
01:41:11.980
with the graphics controllers and the EGA systems.
link |
01:41:16.000
And what we most wanted to do, so at that time
link |
01:41:19.060
we were sitting in our darkened office
link |
01:41:22.260
playing all the different console video games.
link |
01:41:24.740
And we were figuring out what games
link |
01:41:27.620
do we want to make for our Gamer's Edge product there.
link |
01:41:30.500
And so we had one of the first Super Nintendos sitting there.
link |
01:41:34.180
And we had an older Nintendo looking at all those games.
link |
01:41:37.500
And the core thing that those consoles did that you just
link |
01:41:40.020
didn't get on the PC games was this ability
link |
01:41:42.700
to have a massive scrolling world where
link |
01:41:45.180
most of the games that you would make on the PC
link |
01:41:47.980
and earlier personal computers would be a static screen.
link |
01:41:51.500
You move little things around on it and you interact like that.
link |
01:41:55.020
Maybe you go to additional screens as you move.
link |
01:41:58.260
But arcade games and consoles had this wonderful ability
link |
01:42:01.900
to just have a big world that you're slowly
link |
01:42:04.420
moving your window through.
link |
01:42:06.100
And that was for those types of games,
link |
01:42:08.460
that kind of action exploration adventure games,
link |
01:42:10.820
that was a super, super important thing.
link |
01:42:13.060
And PC games just didn't do that.
link |
01:42:16.260
And what I had come across was a couple
link |
01:42:18.740
of different techniques for implementing that on the PC.
link |
01:42:22.300
And they're not hard, complicated things.
link |
01:42:25.180
When I explain them now, they're pretty straightforward.
link |
01:42:28.140
But just nobody was doing it.
link |
01:42:29.260
You sound like Einstein describing his five papers
link |
01:42:31.900
is pretty straightforward.
link |
01:42:33.100
I understand.
link |
01:42:34.020
But they're nevertheless revolutionary.
link |
01:42:35.980
So side scrolling is a game changer.
link |
01:42:38.420
Yeah, and scrolling is a genius invention.
link |
01:42:40.420
It's either vertical.
link |
01:42:41.620
And some of the consoles had different limitations
link |
01:42:43.660
about you could do one but not the other.
link |
01:42:45.420
And there were similar things going on as advancements,
link |
01:42:48.420
even in the console space, where you'd have the original Mario
link |
01:42:51.740
game was just horizontal scrolling.
link |
01:42:54.580
And then later, Mario games added vertical aspects to it
link |
01:42:57.300
and different things that you were
link |
01:42:59.180
doing to explore, kind of expand the capabilities there.
link |
01:43:02.980
And so much of the early game design for decades
link |
01:43:05.500
was removing limitations, letting you do things
link |
01:43:08.580
that you envisioned as a designer,
link |
01:43:10.100
you wanted the player to experience,
link |
01:43:11.940
but the hardware just couldn't really
link |
01:43:14.340
or you didn't know how to make it happen.
link |
01:43:16.580
It felt impossible.
link |
01:43:17.700
You can imagine that you want to create like this big world
link |
01:43:21.940
through which you can side scroll,
link |
01:43:23.940
like through which you can walk.
link |
01:43:26.660
And then you ask yourself a question,
link |
01:43:28.380
how do I actually build that in a way that's
link |
01:43:31.900
like the latency is low enough, the hardware can actually
link |
01:43:35.900
deliver that in such a way that it's a compelling experience.
link |
01:43:38.780
Yeah, and we knew what we wanted to do
link |
01:43:40.380
because we were playing all of these console games,
link |
01:43:42.700
playing all these Nintendo games and arcade games.
link |
01:43:45.140
Clearly, there was a whole world of awesome things
link |
01:43:47.260
there that we just couldn't do on the PC, at least initially.
link |
01:43:51.380
Because every programmer can tell,
link |
01:43:52.860
it's like if you want to scroll, you can just
link |
01:43:54.220
redraw the whole screen.
link |
01:43:55.460
But then it turns out, well, you're
link |
01:43:56.860
going five frames per second.
link |
01:43:58.820
That's not an interactive fun experience.
link |
01:44:01.020
You want to be going 30 or 60 frames per second or something.
link |
01:44:04.700
And it just didn't feel like that was possible.
link |
01:44:06.860
It felt like the PCs had to get five times faster for you
link |
01:44:10.500
to make a playable game there.
link |
01:44:12.700
And interestingly, I wound up with two completely different
link |
01:44:16.140
solutions for the scrolling problem.
link |
01:44:18.820
And this is a theme that runs through everything, where
link |
01:44:23.060
all of these big technical advancements, it turns out
link |
01:44:25.740
there's always a couple different ways of doing them.
link |
01:44:28.460
And it's not like you found the one true way of doing it.
link |
01:44:31.740
And we'll see this as we go into 3D games and things later.
link |
01:44:35.220
But so the scrolling, the first set of scrolling tricks
link |
01:44:38.540
that I got was the hardware had this ability to,
link |
01:44:43.620
you could shift inside the window of memory.
link |
01:44:47.660
So the EGA cards at the time had 256 kilobytes of memory.
link |
01:44:51.980
And it was awkwardly set up in this planar format,
link |
01:44:55.340
where instead of having 256 or 24 million colors,
link |
01:45:00.780
you had 16 colors, which is four bits.
link |
01:45:03.420
So you had four bit planes, 64k a piece.
link |
01:45:06.300
Of course, 64k is a nice round number
link |
01:45:08.420
for 16 bit addressing.
link |
01:45:10.380
So your graphics card had a 16 bit window
link |
01:45:13.860
that you could look at.
link |
01:45:15.220
And you could tell it to start the video scan out
link |
01:45:17.900
anywhere inside there.
link |
01:45:19.340
So there were a couple games that
link |
01:45:21.140
had taken this approach of you could make a 2 by 2 screen
link |
01:45:23.900
or a 1 by 4 screen.
link |
01:45:25.740
And you could do scrolling really easily like that.
link |
01:45:28.140
You could just lay it all out and just pan around there.
link |
01:45:30.940
But you just couldn't make it any bigger
link |
01:45:32.620
because that's all the memory that was there.
link |
01:45:35.540
The first insight to the scrolling that I had
link |
01:45:37.700
was, well, if we make a screen that's just one tile larger,
link |
01:45:42.300
and we usually had tiles that were 16 pixels by 16 pixels,
link |
01:45:45.820
the little classic Mario block that you run into,
link |
01:45:48.940
lots of art gets drawn that way.
link |
01:45:50.820
And your screen is a certain number of tiles.
link |
01:45:52.860
But if you had one little buffer region outside of that,
link |
01:45:56.620
you could easily pan around inside that 16 pixel region.
link |
01:45:59.980
That could be perfectly smooth.
link |
01:46:01.740
But then what happens if you get to the edge
link |
01:46:04.020
and you want to keep going?
link |
01:46:05.940
The first way we did scrolling was
link |
01:46:08.380
what I called adaptive tile refresh, which was really
link |
01:46:11.460
just a matter of you get to the edge
link |
01:46:13.620
and then you go back to the original point
link |
01:46:16.140
and then only change the tiles that have actually
link |
01:46:19.380
that are different between where it was.
link |
01:46:21.580
In most of the games at the time,
link |
01:46:23.380
if you think about your classic Super Mario Brothers game,
link |
01:46:26.900
you've got big fields of blue sky, long rows
link |
01:46:30.940
of the same brick texture.
link |
01:46:33.300
And there's a lot of commonality.
link |
01:46:34.980
It's like a data compression thing.
link |
01:46:36.580
If you take the screen and you set it down
link |
01:46:38.980
on top of each other, in general, only about 10%
link |
01:46:42.460
of the tiles were actually different there.
link |
01:46:45.180
So this was a way to go ahead and say,
link |
01:46:47.940
well, I'm going to move it back, and then I'm only
link |
01:46:49.980
going to change those 10%, 20%, whatever percent tiles there.
link |
01:46:54.100
And that meant that it was essentially five times faster
link |
01:46:57.540
than if you were redrawing all of the tiles.
link |
01:46:59.860
And that worked well enough for us
link |
01:47:01.300
to do a bunch of these games for Gamer's Edge.
link |
01:47:04.860
We had a lot of these scrolling games like Slurred Axe
link |
01:47:07.100
and Shadow Knights and things like that
link |
01:47:09.260
that we were cranking out at this high rate that
link |
01:47:11.380
had this scrolling effect on it.
link |
01:47:13.540
And it worked well enough.
link |
01:47:14.620
There were design challenges there
link |
01:47:16.100
where if you made the worst case,
link |
01:47:18.180
if you made a checkerboard over the entire screen,
link |
01:47:20.460
you scroll over one and every single tile changes
link |
01:47:23.220
and your frame rate's now five frames per second
link |
01:47:25.100
because it had to redraw everything.
link |
01:47:27.100
So the designers had a little bit
link |
01:47:28.700
that they had to worry about.
link |
01:47:29.900
They had to make these relatively plain looking
link |
01:47:32.020
levels, but it was still pretty magical.
link |
01:47:34.900
It was something that we hadn't seen before.
link |
01:47:37.460
And the first thing that we wound up doing with that
link |
01:47:41.340
was I had just gotten this working,
link |
01:47:43.660
and Tom Hall was sitting there with me,
link |
01:47:46.300
and we were looking over at our Super Nintendo on the side
link |
01:47:49.820
there with Super Mario 3 running.
link |
01:47:52.500
And we had the technology, we had the tools set up there,
link |
01:47:56.260
and we stayed up all night.
link |
01:47:57.780
And we basically cloned the first level
link |
01:47:59.820
of Super Mario Brothers.
link |
01:48:01.260
Performance wise as well?
link |
01:48:02.460
Yeah.
link |
01:48:02.940
And we had our little character running and jumping in there.
link |
01:48:05.860
It was close to pixel accurate as far
link |
01:48:09.100
as all the backgrounds and everything,
link |
01:48:11.300
but the gaming was just stuff that we cobbled together
link |
01:48:13.540
from previous games that I had written.
link |
01:48:15.380
I just really kitbashed the whole thing together
link |
01:48:18.060
to make this demo.
link |
01:48:19.420
And that was one of the rare cases
link |
01:48:21.500
when I said I don't usually do these all night programming
link |
01:48:24.260
things.
link |
01:48:24.860
There's probably only two memorable ones
link |
01:48:26.860
that I can think about.
link |
01:48:28.580
One was the all nighter to go ahead and get
link |
01:48:31.940
our Dangerous Dave and copyright infringement
link |
01:48:34.460
is how we titled it.
link |
01:48:35.420
Because we had a game called Dangerous Dave running around
link |
01:48:38.100
with a shotgun shooting things, and we were just
link |
01:48:41.140
taking our most beloved game at the time there, the Super Mario
link |
01:48:44.140
3, and sticking Dave inside that with this new scrolling
link |
01:48:47.980
technology that was going perfectly smooth for them
link |
01:48:53.500
as it ran.
link |
01:48:54.660
And Tom and I just blearily the next morning left,
link |
01:48:58.340
and we left a disk on the desk for John Romero and Jay
link |
01:49:02.940
Wilbur to see and just said, run this.
link |
01:49:05.220
And we eventually made it back in later in the day,
link |
01:49:08.380
and it was like they grabbed us and pulled us into the room.
link |
01:49:13.260
And that was the point where they were like,
link |
01:49:15.660
we got to do something with this.
link |
01:49:17.740
We're going to make a company.
link |
01:49:19.300
We're going to go make our own games, where
link |
01:49:21.580
this was something that we were able to just kind of hit them
link |
01:49:24.980
with a hammer of an experience like, wow, this
link |
01:49:27.060
is just like so much cooler than what we thought
link |
01:49:30.140
was possible there.
link |
01:49:31.660
And initially, we tried to get Nintendo
link |
01:49:33.860
to let us make Super Mario 3 on the PC.
link |
01:49:36.900
That's really what we wanted to do.
link |
01:49:38.420
We were like, hey, we can finish this.
link |
01:49:40.220
It's line of sight.
link |
01:49:41.380
This will be great.
link |
01:49:42.620
And we sent something to Nintendo,
link |
01:49:45.180
and we heard that it did get looked at in Japan,
link |
01:49:48.180
and they just weren't interested in that.
link |
01:49:50.380
But that's another one of those life could
link |
01:49:52.180
have gone a very different way, where
link |
01:49:53.740
we could have been like Nintendo's house PC team
link |
01:49:57.700
at that point.
link |
01:49:58.540
And define the direction of Wolfenstein and Doom and Quake
link |
01:50:06.660
could have been a Nintendo creation.
link |
01:50:08.940
Yeah.
link |
01:50:09.460
So at the same time that we were just
link |
01:50:11.620
doing our first scrolling demos, we
link |
01:50:14.660
reached out to Scott Miller at Apogee and said,
link |
01:50:17.660
it's like, hey, we do want to make some games.
link |
01:50:20.180
These things that you think you want, those are nothing.
link |
01:50:22.660
What do you see what we can actually do now?
link |
01:50:24.540
This is going to be amazing.
link |
01:50:26.180
And he just popped right up and sent a check to us,
link |
01:50:29.340
where at that point, we still thought
link |
01:50:31.420
he might be a fraud, that he was just lying about all of this.
link |
01:50:34.500
But he was totally correct on how much money
link |
01:50:36.900
he was making with his shareware titles.
link |
01:50:39.340
And this was his real brainstorm about this,
link |
01:50:43.180
where shareware was this idea that software
link |
01:50:45.980
doesn't have a fixed price.
link |
01:50:47.220
If you use it, you send out of the goodness of your heart
link |
01:50:49.860
some money to the creator.
link |
01:50:51.660
And there were a couple of utilities
link |
01:50:53.300
that did make some significant success like that.
link |
01:50:55.980
But for the most part, it didn't really work.
link |
01:50:58.420
Now, there wasn't much software in a pure shareware model
link |
01:51:01.580
that was successful.
link |
01:51:03.860
The Apogee innovation was to take something,
link |
01:51:07.700
call it shareware, split it into three pieces.
link |
01:51:10.180
You always made a trilogy.
link |
01:51:12.100
And you would put the first piece out,
link |
01:51:14.300
but then you buy the whole trilogy
link |
01:51:16.180
for some shareware amount, which in reality,
link |
01:51:19.420
it meant that the first part was a demo,
link |
01:51:21.260
where you kind of like the demo went everywhere for free
link |
01:51:24.060
and you paid money to get the whole set.
link |
01:51:26.580
But it was still play to shareware.
link |
01:51:28.620
And we were happy to have the first one go everywhere.
link |
01:51:31.060
And it wasn't a crippled demo, where the first episode
link |
01:51:33.980
of all these trilogies, it was a real complete game.
link |
01:51:36.420
And probably 20 times as many people played that part of it,
link |
01:51:39.820
thought they had a great game, had fond memories of it,
link |
01:51:43.500
but never paid us a dime.
link |
01:51:45.340
But enough people were happy with that,
link |
01:51:48.140
where it was really quite successful.
link |
01:51:50.700
And these early games that we didn't think very much of
link |
01:51:53.220
compared to commercial quality games,
link |
01:51:55.780
but they were doing really good business,
link |
01:51:57.780
some fairly crude things.
link |
01:51:59.320
And people, it was good business.
link |
01:52:01.340
People enjoyed it.
link |
01:52:02.340
And it wasn't like you were taking a crapshoot
link |
01:52:04.500
on what you were getting.
link |
01:52:05.540
You just played a third of the experience.
link |
01:52:07.780
And you loved it enough to hand write out a check
link |
01:52:10.860
and put it in an envelope and address it and send it out
link |
01:52:13.860
to Apogee to get the rest of them.
link |
01:52:16.740
So it was a really pretty feel good business prospect there,
link |
01:52:20.620
because everybody was happy.
link |
01:52:23.160
They knew what they were getting when they sent it in.
link |
01:52:26.060
They would send in fan mail.
link |
01:52:27.180
If you're going to the trouble of addressing a letter
link |
01:52:29.520
and filling out an envelope, you write something in it.
link |
01:52:32.660
And there were just the literal bags of fan mail
link |
01:52:35.420
for the shareware games, so people loved them.
link |
01:52:38.940
I should mention that for you, the definition of wealth
link |
01:52:42.540
is being able to have pizza whenever you want.
link |
01:52:46.580
For me, there was a dream that I would play shareware games
link |
01:52:50.780
over and over, the part that's free, over and over.
link |
01:52:53.860
And it was very deeply fulfilling experience.
link |
01:52:56.500
But I dreamed of a time when I could actually
link |
01:53:00.340
afford the full experience.
link |
01:53:02.160
And this is kind of this dreamland beyond the horizon
link |
01:53:05.920
when you could find out what else is there.
link |
01:53:09.380
In some sense, even just playing the shareware was,
link |
01:53:14.380
it's the limitation of that.
link |
01:53:17.980
You know, life is limited, eventually we all die.
link |
01:53:21.540
In that way, shareware was somehow really fulfilling
link |
01:53:26.820
to have this kind of mysterious thing beyond what's free
link |
01:53:31.580
always there.
link |
01:53:32.420
It's kind of, I don't know, maybe it's because
link |
01:53:35.420
a part of my childhood is playing shareware games.
link |
01:53:37.580
That was a really fulfilling experience.
link |
01:53:39.520
It's so interesting how that model still brought joy
link |
01:53:43.100
to so many people.
link |
01:53:44.020
The 20X people that played it.
link |
01:53:45.980
I felt very good about that.
link |
01:53:47.340
I would run into people that would say,
link |
01:53:49.700
oh, I loved that game that you had early on,
link |
01:53:52.220
Commander Keen, whatever.
link |
01:53:53.500
And no, they meant just the first episode
link |
01:53:57.500
that they got to see everywhere.
link |
01:53:58.740
That's me, I played the crap out of Commander Keen.
link |
01:54:01.020
And that was all good.
link |
01:54:03.300
Yeah, yeah.
link |
01:54:04.140
But so we were in this position where Scott Miller
link |
01:54:06.780
was just fronting us cash, saying, yeah, make a game.
link |
01:54:10.420
But we did not properly pull the trigger and say,
link |
01:54:14.140
all right, we're quitting our jobs.
link |
01:54:16.380
We were like, we're gonna do both.
link |
01:54:17.940
We're gonna keep working at Softdisk, working on this.
link |
01:54:21.280
And then we're going to go ahead and make a new game
link |
01:54:24.740
for Apogee at the same time.
link |
01:54:27.060
And this eventually did lead to some legal problems.
link |
01:54:29.580
And we had trouble.
link |
01:54:31.100
It all got worked out in the end,
link |
01:54:32.820
but it was not a good call at the time there.
link |
01:54:35.860
And your legal mind at the time was not stellar.
link |
01:54:39.380
You were not thinking in terms of the illegal terms.
link |
01:54:42.340
No, I definitely wasn't.
link |
01:54:44.020
None of us were.
link |
01:54:46.140
And in hindsight, yeah, it's like,
link |
01:54:47.620
how did we think we were gonna get away
link |
01:54:48.940
with even using our work computers
link |
01:54:51.180
to write software for our breakaway new company?
link |
01:54:56.820
It was not a good plan.
link |
01:54:58.420
How did Commander Keen come to be?
link |
01:55:00.980
So the design process, we would start from,
link |
01:55:04.100
we had some idea of what we wanted to do.
link |
01:55:05.900
We wanted to do a Mario like game.
link |
01:55:08.340
It was gonna be a side scroller.
link |
01:55:10.180
It was gonna use the technology.
link |
01:55:11.800
We had some sense of what it would have to look like
link |
01:55:14.340
because of the limitations
link |
01:55:15.500
of this adaptive tile refresh technology.
link |
01:55:17.980
It had to have fields of relatively constant tiles.
link |
01:55:21.220
You couldn't just paint up a background
link |
01:55:23.500
and then move that around.
link |
01:55:25.940
The early design or all the design for Commander Keen
link |
01:55:28.620
really came from Tom Hall,
link |
01:55:30.020
where he was kind of the main creative mind
link |
01:55:34.900
for the early id software stuff,
link |
01:55:36.940
where we had an interesting division of things
link |
01:55:39.080
where Tom was all creative and design.
link |
01:55:42.220
I was all programming.
link |
01:55:43.620
John Romero was an interesting bridge
link |
01:55:45.540
where he was both a very good programmer
link |
01:55:47.740
and also a very good designer and artist
link |
01:55:50.140
and kind of straddled between the areas.
link |
01:55:52.500
But Commander Keen was very much Tom Hall's baby.
link |
01:55:55.540
And he came up with all the design and backstory
link |
01:55:59.300
for the different things of kind of a mad scientist,
link |
01:56:02.340
little kid with building a rocket ship
link |
01:56:06.460
and a zap gun and visiting alien worlds
link |
01:56:09.100
and doing all of this that the background
link |
01:56:11.540
that we lay the game inside of.
link |
01:56:13.620
And there's not a whole lot to any of these things.
link |
01:56:16.780
Design for us was always just what we needed to do
link |
01:56:19.540
to make the game that was gonna be so much fun to play.
link |
01:56:23.060
And we laid out our first trilogy of games,
link |
01:56:26.820
the shareware formula, it's gonna be three pieces.
link |
01:56:29.460
We make Commander Keen one, two, and three.
link |
01:56:31.780
And we just really started busting on all that work.
link |
01:56:35.820
And it went together really quickly.
link |
01:56:37.700
It was like three months or something
link |
01:56:39.580
that while we were still making games every month
link |
01:56:41.940
for Gamer's Edge, we were sharing technology between that.
link |
01:56:45.500
I'd write a bunch of code for this
link |
01:56:46.820
and we'd just kind of use it for both.
link |
01:56:48.980
Again, not a particularly good idea there
link |
01:56:50.900
that had consequences for us.
link |
01:56:53.020
But in three months, we got our first game out
link |
01:56:57.220
and all of a sudden it was three times as successful
link |
01:57:00.660
as the most successful thing Apogee had had before.
link |
01:57:03.060
And we were making like $30,000 a month
link |
01:57:05.780
immediately from the Commander Keen stuff.
link |
01:57:09.060
And that was again, a surprise to us.
link |
01:57:11.700
It was more than we thought that that was gonna make.
link |
01:57:15.300
And we said, well, we're gonna certainly roll
link |
01:57:17.340
into another set of titles from this.
link |
01:57:19.980
And in that three months, I had come up
link |
01:57:21.800
with a much better way of doing the scrolling technology
link |
01:57:24.860
that was not the adaptive tile refresh,
link |
01:57:27.220
which in some ways was even simpler.
link |
01:57:29.200
And these things, so many of the great ideas of technology
link |
01:57:33.440
are things that are back of the envelope designs.
link |
01:57:36.300
I make this comment about modern machine learning
link |
01:57:38.400
where all the things that are really important
link |
01:57:40.780
practically in the last decade are,
link |
01:57:42.740
each of them fits on the back of an envelope.
link |
01:57:44.460
There are these simple little things.
link |
01:57:46.340
They're not super dense, hard to understand technologies.
link |
01:57:51.340
And so the second scrolling trick was just a matter of like,
link |
01:57:55.060
okay, we know we've got this 64K window.
link |
01:57:58.560
And the question was always like,
link |
01:58:00.040
well, you could make a two by two,
link |
01:58:02.260
but you can't go off the edge.
link |
01:58:05.500
But I finally asked, well, what actually happens
link |
01:58:07.800
if you just go off the edge?
link |
01:58:09.600
If you take your start and you say, it's like,
link |
01:58:12.260
okay, I can move over, I'm scrolling,
link |
01:58:14.460
I can move over, I can move down, I'm scrolling.
link |
01:58:16.920
I get to what should be the bottom of the memory window.
link |
01:58:19.780
It's like, well, what if I just keep going?
link |
01:58:21.620
And I say, I'm gonna start at,
link |
01:58:24.020
what happens if I start at FFFE
link |
01:58:26.380
at the very end of the 64K block?
link |
01:58:29.420
And it turns out it just wraps back around to the top
link |
01:58:32.420
of the block.
link |
01:58:33.300
And I'm like, oh, well, this makes everything easy.
link |
01:58:35.860
You can just scroll the screen everywhere
link |
01:58:37.620
and all you have to draw is just one new line of tiles,
link |
01:58:40.420
which everything you expose,
link |
01:58:42.100
it might be unaligned off various parts
link |
01:58:44.660
of the screen memory, but it just works.
link |
01:58:48.180
That no longer had the problem of you had to have fields
link |
01:58:50.820
of the similar colors because it doesn't matter
link |
01:58:53.720
what you're doing, you could be having
link |
01:58:54.980
a completely unique world and you're just drawing
link |
01:58:57.780
the new strip as it comes on.
link |
01:58:59.460
But it might be, like you said, unaligned,
link |
01:59:02.180
so it can be all over the place.
link |
01:59:03.500
Yes, and it turns out it doesn't matter.
link |
01:59:04.960
I would have two page flipped screens,
link |
01:59:06.700
as long as they didn't overlap, they moved in series
link |
01:59:09.120
through this two dimensional window of graphics.
link |
01:59:12.900
And that was one of those like, well, this is so simple.
link |
01:59:15.700
This just works, it's faster,
link |
01:59:19.420
there it seemed like there was no downside.
link |
01:59:21.740
Funny thing was, it turned out after we shipped titles
link |
01:59:25.540
with this, there were what they called super VGA cards,
link |
01:59:29.660
the cards that would allow higher resolutions
link |
01:59:31.940
and different features that the standard ones didn't.
link |
01:59:35.740
And on some of those cards,
link |
01:59:38.340
this was a weird compatibility quirk again,
link |
01:59:40.360
because nobody thought this was not
link |
01:59:41.900
what it was designed to do.
link |
01:59:43.580
And some of those cards had more memory.
link |
01:59:45.620
They had more than just 256K and four planes.
link |
01:59:48.820
They had 512K or a megabyte.
link |
01:59:51.500
And on some of those cards, I scroll my window down
link |
01:59:55.660
and then it goes into uninitialized memory
link |
01:59:57.900
that actually exists there
link |
01:59:59.060
rather than wrapping back around at the top.
link |
02:00:01.740
And then I was in the tough position
link |
02:00:04.180
of do I have to track every single one of these?
link |
02:00:06.260
And it was a mad house back then
link |
02:00:07.860
with there were 20 different video card vendors
link |
02:00:10.700
with all slightly different implementations
link |
02:00:12.700
of their nonstandard functionality.
link |
02:00:14.820
So either I needed to natively program
link |
02:00:17.540
all of the VGA cards there to map in that memory
link |
02:00:22.080
and keep scrolling down through all of that,
link |
02:00:24.320
or I kind of punted and took the easy solution
link |
02:00:27.180
of when you finally did run to the edge of the screen,
link |
02:00:30.300
I accepted a hitch and just copied the whole screen up there.
link |
02:00:33.340
So on some of those cards, it was a compatibility mode.
link |
02:00:38.340
In the normal ones, when it all worked fine,
link |
02:00:40.140
everything was just beautifully smooth.
link |
02:00:42.060
But if you had one of those cards
link |
02:00:43.460
where it did not wrap the way I wanted it to,
link |
02:00:46.340
you'd be scrolling around, scrolling around,
link |
02:00:48.820
and then eventually you'd have a little hitch
link |
02:00:50.580
where 200 milliseconds or something
link |
02:00:52.860
that was not super smooth as it froze a little bit.
link |
02:00:56.100
And this is the binary thing.
link |
02:00:57.860
Is it one of the standard screens
link |
02:00:59.660
or is it one of the weird ones, the Super VGA ones?
link |
02:01:02.060
Yeah. Okay.
link |
02:01:03.020
And so we would default to,
link |
02:01:04.500
and I think that was one of those
link |
02:01:05.900
that changed over the kind of course of deployment
link |
02:01:09.020
where early on we would have a normal mode
link |
02:01:11.060
and then you would enable the compatibility flag
link |
02:01:13.500
if your screen did this crazy flickery thing
link |
02:01:16.140
when you got to a certain point in the game.
link |
02:01:18.620
And then later, I think it probably got enabled by default
link |
02:01:21.420
as just more and more of the cards
link |
02:01:23.500
kind of did not do exactly the right thing.
link |
02:01:26.140
And that's the two edged sword
link |
02:01:27.500
of doing unconventional things with technology
link |
02:01:30.340
where you can find something that nobody thought about
link |
02:01:33.060
doing that kind of scrolling trick
link |
02:01:34.540
when they set up those cards.
link |
02:01:36.780
But the fact that nobody thought that was the primary reason
link |
02:01:39.100
when I was relying on that,
link |
02:01:40.820
then I wound up being broken on some of the later cards.
link |
02:01:44.020
Let me take a bit of a tangent,
link |
02:01:45.740
but ask you about the hacker ethic.
link |
02:01:50.260
Cause you mentioned shareware.
link |
02:01:51.780
It's an interesting world.
link |
02:01:53.180
The world of people that make money,
link |
02:01:56.660
the business and the people that build systems,
link |
02:02:00.500
the engineers.
link |
02:02:02.060
And what is the hacker ethic?
link |
02:02:05.980
You've been a man of the people
link |
02:02:08.440
and you've embodied at least the part of that ethic.
link |
02:02:12.460
What does it mean?
link |
02:02:13.300
What did it mean to you at the time?
link |
02:02:14.460
What does it mean to you today?
link |
02:02:15.820
So Steven Levy's book, Hackers,
link |
02:02:17.900
was a really formative book for me as a teenager.
link |
02:02:21.620
I mean, I read it several times
link |
02:02:23.660
and there was all of the great lore
link |
02:02:26.020
of the early MIT era of hackers
link |
02:02:28.980
and ending up at the end with,
link |
02:02:31.000
it kind of went through the early MIT hackers
link |
02:02:34.100
and then the Silicon Valley hardware hackers
link |
02:02:36.120
and then the game hackers in part three.
link |
02:02:39.460
And at that time as a teenager,
link |
02:02:41.740
I really was kind of bitter in some ways.
link |
02:02:44.700
I thought I was born too late.
link |
02:02:46.280
I thought I missed the window there.
link |
02:02:48.980
And I really thought I belonged in that third section
link |
02:02:52.020
of that book with the game hackers.
link |
02:02:53.620
And they were talking about the Williams at Sierra
link |
02:02:56.740
and origin systems with Richard Garriott.
link |
02:02:59.340
And it's like, I really wanted to be there.
link |
02:03:02.540
And I knew that was now a few years in the past.
link |
02:03:05.580
It was not to be,
link |
02:03:08.700
but the early days, especially the early MIT hacker days,
link |
02:03:12.500
talking a lot about this sense of the hacker ethic,
link |
02:03:16.100
that there was this sense that
link |
02:03:17.980
it was about sharing information, being good,
link |
02:03:20.720
not keeping it to yourself,
link |
02:03:22.460
and that it's not a zero sum game,
link |
02:03:24.740
that you can share something with another programmer
link |
02:03:28.400
and it doesn't take it away from you.
link |
02:03:30.780
You then have somebody else doing something.
link |
02:03:33.120
And I also think that there's an aspect of it
link |
02:03:35.940
where it's this ability to take joy
link |
02:03:39.180
in other people's accomplishments,
link |
02:03:41.200
where it's not the cutthroat bit of like,
link |
02:03:43.020
I have to be first,
link |
02:03:44.060
I have to be recognized as the one that did this
link |
02:03:47.380
in some way,
link |
02:03:48.220
but being able to see somebody else do something
link |
02:03:51.560
and say, holy shit, that's amazing.
link |
02:03:53.620
And just taking joy in the ability of something amazing
link |
02:03:56.900
that somebody else does.
link |
02:03:58.780
And the big thing that I was able to do through ID Software
link |
02:04:03.780
was this ability to eventually release the source code
link |
02:04:07.160
for most of our,
link |
02:04:08.080
like all of our really seminal game titles.
link |
02:04:10.720
And that was a, it was a stepping stone process
link |
02:04:13.640
where we were kind of surprised early on
link |
02:04:16.500
where people were able to hack the existing games.
link |
02:04:20.120
And of course I had experience with that.
link |
02:04:21.540
I remember hacking my copies of Ultima.
link |
02:04:23.480
So I'd give myself 9999 gold and raise my levels
link |
02:04:27.080
and break out the sector editor.
link |
02:04:29.080
And so I was familiar with all of that.
link |
02:04:31.040
So it was just, it was with a smile
link |
02:04:33.000
when I started to see people doing that to our games,
link |
02:04:35.620
I am making level editors for Commander Keen
link |
02:04:38.940
or hacking up Wolfenstein 3D,
link |
02:04:41.820
but I made the pitch internally
link |
02:04:44.940
that we should actually release our own tools
link |
02:04:47.560
for like what we did, what we use to create the games.
link |
02:04:51.440
And that was a little bit debatable about,
link |
02:04:55.100
well, will this let other, we'll give people leg up.
link |
02:04:57.920
It's always like,
link |
02:04:58.760
what's that gonna mean for the competition?
link |
02:05:00.940
But the really hard pitch was to actually release
link |
02:05:04.760
the full source code for the games.
link |
02:05:06.800
And it was a balancing act with the other people
link |
02:05:10.360
inside the company where it's interesting
link |
02:05:13.320
how the programmers generally did get,
link |
02:05:17.060
certainly the people that I worked closely with,
link |
02:05:20.360
they did kind of get that hacker ethic bit
link |
02:05:22.600
where you wanted to share your code.
link |
02:05:24.660
You were proud of it.
link |
02:05:25.780
You wanted other people to take it, do cool things with it.
link |
02:05:28.920
But interestingly, the broader game industry
link |
02:05:33.880
is a little more hesitant to embrace that
link |
02:05:36.520
than like the group of people
link |
02:05:38.000
that we happen to have at id Software,
link |
02:05:40.160
where it was always a little interesting to me
link |
02:05:42.520
seeing how a lot of people in the game modding community
link |
02:05:45.600
were very possessive of their code.
link |
02:05:47.640
They did not wanna share their code.
link |
02:05:49.320
They wanted it to be theirs.
link |
02:05:50.560
It was their claim to fame.
link |
02:05:52.640
And that was much more like what we tended to see
link |
02:05:55.400
with artists where the artists understand something
link |
02:05:58.360
about credit and wanting it to be known as their work.
link |
02:06:02.200
And a lot of the game programmers
link |
02:06:05.320
felt a little bit more like artists
link |
02:06:07.020
than like hacker programmers,
link |
02:06:08.600
in that it was about building something
link |
02:06:11.000
that maybe felt more like art to them
link |
02:06:13.000
than the more tool based and exploration based
link |
02:06:16.760
kind of hacking culture side of things.
link |
02:06:19.060
Yeah, it's so interesting that this kind of fear
link |
02:06:23.760
that credit will not be sufficiently attributed to you.
link |
02:06:27.860
And that's one of the things that I do bump into a lot
link |
02:06:30.400
because I try not to go...
link |
02:06:34.240
I mean, it's easy for me to say
link |
02:06:35.400
because so much credit is heaped on me
link |
02:06:37.240
for the id Software side of things.
link |
02:06:39.360
But when people come up and they wanna pick a fight
link |
02:06:42.200
and say, no, it's like that wasn't where first person gaming
link |
02:06:45.120
came from and you can point to some of like things
link |
02:06:48.860
on obscure titles that I was never aware of
link |
02:06:51.600
or like the old Playdoh systems
link |
02:06:53.340
or each personal computer had something that was 3Dish
link |
02:06:57.000
and moving around.
link |
02:06:58.320
And I'm happy to say it's like, no, I mean,
link |
02:07:01.200
I saw Battlezone and Star Wars in the arcades.
link |
02:07:03.900
I had seen 3D graphics, I had seen all these things
link |
02:07:06.360
that are standing on the shoulders of lots of other people.
link |
02:07:09.100
But sometimes these examples they pull out,
link |
02:07:10.880
it's like, no, I didn't know that existed.
link |
02:07:12.540
I mean, I had never heard of that before then
link |
02:07:15.280
that didn't contribute to what I made,
link |
02:07:17.840
but there's plenty of stuff that did.
link |
02:07:19.480
And I think there's good cases to be made
link |
02:07:23.280
that obviously Doom and Quake and Wolfenstein
link |
02:07:26.160
were formative examples for what everything
link |
02:07:29.800
that came after that.
link |
02:07:31.720
But I don't feel the need to go fight
link |
02:07:34.160
and say claim primacy or initial invention
link |
02:07:37.480
of anything like that.
link |
02:07:38.800
But a lot of people do want to.
link |
02:07:40.440
I think when you fight for the credit in that way
link |
02:07:43.200
and it does go against the hacker ethic,
link |
02:07:46.280
you destroy something fundamental about the culture,
link |
02:07:48.800
about the community that builds cool stuff.
link |
02:07:51.760
I think credit ultimately,
link |
02:07:53.780
so I had this sort of,
link |
02:07:58.420
there's a famous wrestler and freestyle wrestling
link |
02:08:00.980
called Buvai Sarasateeva.
link |
02:08:03.980
And he always preached that you should just focus
link |
02:08:07.760
on the art of the wrestling and let people
link |
02:08:12.740
write your story however they want.
link |
02:08:15.940
The highest form of the art is just focusing on the art.
link |
02:08:20.100
And that is something about the hacker ethic
link |
02:08:23.760
is just focus on building cool stuff,
link |
02:08:26.900
sharing it with other cool people,
link |
02:08:29.380
and credit will get assigned correctly
link |
02:08:35.060
in the long arc of history.
link |
02:08:37.240
Yeah, and I generally think that's true.
link |
02:08:39.180
And you've got,
link |
02:08:42.020
there's some things, there's a graphics technique
link |
02:08:44.220
that got labeled CarMax Reverse.
link |
02:08:46.220
I am literally named,
link |
02:08:48.380
and it turned out that I wasn't the first person
link |
02:08:50.300
to figure that out.
link |
02:08:51.860
Most scientific things or mathematical things you wind up,
link |
02:08:54.700
it's like, oh, this other person
link |
02:08:56.220
had actually done that somewhat before.
link |
02:08:58.580
And then there's things that get attributed to me
link |
02:09:00.300
like the inverse square root hack that I actually didn't do.
link |
02:09:03.300
I flat out, that wasn't me.
link |
02:09:04.760
And it's like, it's weird how the memetic power
link |
02:09:07.260
of the internet, I cannot convince people of that.
link |
02:09:09.100
You're like the Mark Twain of programming.
link |
02:09:10.980
Yes.
link |
02:09:12.140
Everything just gets attributed to you now,
link |
02:09:14.060
even though you've never sought the credit of things.
link |
02:09:18.300
But part of the fact of the humility behind that
link |
02:09:21.220
is what attracts the attributions.
link |
02:09:25.340
Let's talk about a game.
link |
02:09:27.820
I mean, one of the greatest games ever made.
link |
02:09:29.580
I know you could talk about doing Quake and so on,
link |
02:09:31.500
but to me, Wolfenstein 3D was like, whoa.
link |
02:09:35.340
It blew my mind that a world like this could exist.
link |
02:09:38.180
So how did Wolfenstein 3D come to be
link |
02:09:42.080
in terms of the programming, in terms of the design,
link |
02:09:44.260
in terms of some of the memorable technical challenges?
link |
02:09:47.240
And also, actually just something you haven't mentioned
link |
02:09:50.600
is how did these ideas come to be inside your mind,
link |
02:09:58.120
the adaptive side scrolling,
link |
02:10:00.560
the solutions to these technical challenges?
link |
02:10:03.560
So I usually can introspectively pull back
link |
02:10:06.900
pretty detailed accounts of how technology solutions
link |
02:10:11.360
and design choices on my part came to be,
link |
02:10:14.000
where technically we had done two games,
link |
02:10:17.400
3D games like that before,
link |
02:10:19.200
where Hover Tank was the first one,
link |
02:10:20.960
which had flat shaded walls,
link |
02:10:22.760
but did have the scaled enemies inside it.
link |
02:10:25.240
And then Catacombs 3D, which had textured walls,
link |
02:10:28.920
scaled enemies, and some more functionality,
link |
02:10:34.160
like the disappearing walls and some other stuff.
link |
02:10:37.160
But what's really interesting
link |
02:10:38.680
from a game development standpoint is those games,
link |
02:10:41.980
Catacombs 3D, Hover Tank, and Wolfenstein,
link |
02:10:45.000
they literally used the same code
link |
02:10:48.240
for a lot of the character behavior
link |
02:10:50.280
that a 2D game that I had made earlier called Catacombs did,
link |
02:10:54.140
where it was an overhead view game, kind of like Gauntlet,
link |
02:10:56.740
you're running around and you can open up doors,
link |
02:10:58.800
pick up items, basic game stuff.
link |
02:11:01.280
And the thought was that this exact same game experience
link |
02:11:06.520
just presented in a different perspective.
link |
02:11:09.080
It could be literally the same game
link |
02:11:11.380
just with a different view into it,
link |
02:11:13.480
would have a dramatically different impact on the players.
link |
02:11:16.880
So it wasn't a true 3D,
link |
02:11:20.280
you're saying that you could kind of fake it,
link |
02:11:22.440
you can like scale enemies,
link |
02:11:24.160
meaning things that are farther away,
link |
02:11:25.720
you can make them smaller.
link |
02:11:27.440
So the game was a 2D map,
link |
02:11:29.760
like all of our games use the same tool for creation.
link |
02:11:33.040
We use the same map editor for creating Keen as Wolfenstein
link |
02:11:36.320
and Hover Tank and Catacombs and all this stuff.
link |
02:11:39.100
So the game was a 2D grid made out of blocks.
link |
02:11:42.680
And you could say, well, these are walls,
link |
02:11:44.480
these are where the enemies start,
link |
02:11:45.880
then they start moving around.
link |
02:11:47.700
And these early games like Catacombs,
link |
02:11:49.600
you played it strictly in a 2D view.
link |
02:11:51.600
It was a scrolling 2D view,
link |
02:11:53.200
and that was kind of using an adaptive tile refresh
link |
02:11:55.320
at the time to be able to do something like that.
link |
02:11:58.440
And then the thought that these early games,
link |
02:12:01.620
all it did was take the same basic enemy logic,
link |
02:12:04.600
but instead of seeing it from the God's eye view on top,
link |
02:12:07.680
you were inside it and turning from side to side,
link |
02:12:10.480
yawing your view and moving forwards and backwards
link |
02:12:12.640
and side to side.
link |
02:12:14.520
And it's a striking thing where you always talk about
link |
02:12:17.160
wanting to isolate and factor changes in values.
link |
02:12:20.040
And this was one of those most pure cases there
link |
02:12:22.360
where the rest of the game changed very little.
link |
02:12:25.040
It was our normal kind of change the colors on something
link |
02:12:27.840
and draw a different picture for it,
link |
02:12:29.200
but it's kind of the same thing.
link |
02:12:30.880
But the perspective changed in a really fundamental way.
link |
02:12:33.960
And it was dramatically different.
link |
02:12:36.280
I can remember the reactions where the artist, Adrian,
link |
02:12:40.600
that had been drawing the pictures for it.
link |
02:12:42.040
We had a cool big troll thing in Catacombs 3D,
link |
02:12:45.000
and we had these walls that you could get a key
link |
02:12:47.720
and you could make the blocks disappear,
link |
02:12:49.840
get really simple stuff.
link |
02:12:51.000
Blocks could either be there or not there.
link |
02:12:52.920
So our idea of a door was being able to make a set of blocks
link |
02:12:55.980
just disappear.
link |
02:12:57.300
And I remember the reaction
link |
02:12:58.640
where he had drawn these characters
link |
02:13:00.080
and he was slowly moving around
link |
02:13:01.720
and like people had no experience with 3D navigation.
link |
02:13:04.480
It was all still keyboard.
link |
02:13:05.460
We didn't even have mice set up at that time,
link |
02:13:08.520
but slowly moving, going up, picked up a key, go to a wall.
link |
02:13:12.300
The wall disappears in a little animation
link |
02:13:14.360
and there's a monster like right there.
link |
02:13:16.320
And he practically fell out of his chair.
link |
02:13:18.000
It was just like, ah!
link |
02:13:19.260
And games just didn't do that.
link |
02:13:22.480
The games were the God's eye view.
link |
02:13:24.360
You were a little invested in your little guy.
link |
02:13:26.320
You can be like happy or sad when things happen,
link |
02:13:29.760
but you just did not get that kind of startle reaction.
link |
02:13:32.440
You weren't inside the game.
link |
02:13:33.920
Something in the back of your brain,
link |
02:13:35.560
some reptile brain thing is just going,
link |
02:13:37.760
oh shit, something just happened.
link |
02:13:39.960
And that was one of those early points where it's like,
link |
02:13:42.520
yeah, this is gonna make a difference.
link |
02:13:44.800
This is going to be powerful and it's gonna matter.
link |
02:13:47.440
Were you able to imagine that in the idea stage or no?
link |
02:13:51.120
So not that exact thing.
link |
02:13:53.720
So again, we had cases like the arcade games,
link |
02:13:56.480
Battle Zone and Star Wars
link |
02:13:58.000
that you could kind of see a 3D world
link |
02:14:00.160
and things coming at you and you get some sense of it,
link |
02:14:03.460
but nothing had done the kind of worlds that we were doing
link |
02:14:06.440
and the sort of action based things.
link |
02:14:08.480
3D at the time was really largely
link |
02:14:12.100
about the simulation thoughts.
link |
02:14:14.240
And this is something that really
link |
02:14:16.320
might have trended differently
link |
02:14:18.120
if not for the id Software approach in the games
link |
02:14:20.960
where there were flight simulators,
link |
02:14:23.560
there were driving simulators,
link |
02:14:24.920
you had like hard drive in and Microsoft flight simulator.
link |
02:14:28.400
And these were doing 3D and general purpose 3D
link |
02:14:31.360
in ways that were more flexible
link |
02:14:33.760
than what we were doing with our games,
link |
02:14:35.440
but they were looked at as simulations.
link |
02:14:38.000
They weren't trying to necessarily be fast or responsive
link |
02:14:42.000
or letting you do kind of exciting maneuvers
link |
02:14:44.840
because they were trying to simulate reality
link |
02:14:46.800
and they were taking their cues from the big systems,
link |
02:14:49.280
the Evans and Sutherlands and the Silicon Graphics
link |
02:14:51.500
that were doing things.
link |
02:14:52.860
But we were taking our cues
link |
02:14:54.600
from the console and arcade games.
link |
02:14:56.560
We wanted things that were sort of quarter eaters
link |
02:14:59.480
that were doing fast paced things
link |
02:15:01.160
that you could smack you around
link |
02:15:02.780
rather than just smoothly gliding you from place to place.
link |
02:15:06.180
So.
link |
02:15:07.020
Quarter eaters.
link |
02:15:07.840
Yeah.
link |
02:15:08.680
And you know, a funny thing is,
link |
02:15:10.200
so much that that built into us
link |
02:15:12.280
that Wolfenstein still had lives
link |
02:15:15.080
and you had like one of the biggest power ups
link |
02:15:16.540
in all these games like was an extra life
link |
02:15:18.800
because you started off with three lives
link |
02:15:20.560
and you lose your lives and then it's game over
link |
02:15:23.080
and there weren't save games in most of this stuff.
link |
02:15:26.240
It was, it sounds almost crazy to say this,
link |
02:15:28.760
but it was an innovation in Doom
link |
02:15:30.680
to not have lives.
link |
02:15:32.160
You know, you could just play Doom as long as you wanted.
link |
02:15:33.860
You just restart at the start of the level and why not?
link |
02:15:36.760
This is like, we aren't trying to take people's quarters.
link |
02:15:39.760
They've already paid for the entire game.
link |
02:15:41.360
We want them to have a good time
link |
02:15:43.360
and you would have some, you know,
link |
02:15:45.520
some old timer purists that might think
link |
02:15:47.240
that there's something to the epic journey
link |
02:15:48.940
of making it to the end,
link |
02:15:50.040
having to restart all the way from the beginning
link |
02:15:52.040
after a certain number of tries.
link |
02:15:53.440
But now more fun is had when you just let people
link |
02:15:56.340
kind of keep trying when they're stuck
link |
02:15:58.040
rather than having to go all the way back
link |
02:15:59.760
and learn different things.
link |
02:16:01.920
So you've recommended the book,
link |
02:16:03.280
Game Engine Black Book Wolfenstein 3D
link |
02:16:05.760
for technical exploration of the game.
link |
02:16:07.600
So looking back 30 years,
link |
02:16:10.560
what are some memorable technical innovations
link |
02:16:13.260
that made this perspective shift into this world
link |
02:16:16.920
that's so immersive that scares you when a monster appears
link |
02:16:20.160
or some things you have to solve?
link |
02:16:22.260
So one of the interesting things
link |
02:16:24.140
that come back to the theme of deadlines
link |
02:16:26.300
and resource constraints,
link |
02:16:27.760
the game Catacombs 3D,
link |
02:16:31.120
we shipped, we were supposed to be shipping this
link |
02:16:33.140
for Gamers Edge on a monthly cadence and I had slipped.
link |
02:16:36.440
I was actually late.
link |
02:16:37.840
It slipped like six weeks
link |
02:16:39.240
because this was texture mapped walls
link |
02:16:41.580
doing stuff that I hadn't done before.
link |
02:16:44.760
And at the six week point,
link |
02:16:46.740
it was still kind of glitchy and buggy.
link |
02:16:48.980
There were things that I knew that if you had a wall
link |
02:16:51.600
that was like almost edge on, you could slide over to it
link |
02:16:54.600
and you could see some things freak out
link |
02:16:56.040
or vanish or not work.
link |
02:16:57.640
And I hated that,
link |
02:16:59.920
but I was up against the wall.
link |
02:17:01.500
We had to ship the game.
link |
02:17:03.000
It was still a lot of fun to play.
link |
02:17:04.680
It was novel, nobody had seen it.
link |
02:17:06.000
It gave you that startle reflex reaction.
link |
02:17:09.040
So it was worth shipping,
link |
02:17:11.040
but it had these things that I knew were kind of flaky
link |
02:17:13.980
and janky and not what I was really proud of.
link |
02:17:17.440
So one of the things that I did very differently
link |
02:17:20.720
in Wolfenstein was I went,
link |
02:17:24.000
Catacombs used almost a conventional thing
link |
02:17:27.200
where you had segments that were one dimensional polygons
link |
02:17:30.240
basically that were clipped and back faced
link |
02:17:33.080
and done kind of like a very crude 3D engine
link |
02:17:36.320
from the professionals,
link |
02:17:37.340
but I wasn't getting it done right.
link |
02:17:39.500
I was not doing a good enough job.
link |
02:17:41.520
I didn't really have line of sight to fix it right.
link |
02:17:45.500
There's stuff that of course I look back,
link |
02:17:46.920
it's like, oh, it's obvious how to do this
link |
02:17:48.640
and do the math right, do your clipping right,
link |
02:17:51.000
check all of this, how you handle the precision.
link |
02:17:53.240
But I did not know how to do that at that time.
link |
02:17:55.680
Was that the first 3D engine you wrote Catacombs 3D?
link |
02:17:59.000
Yeah, Hover Tank had been a little bit before that,
link |
02:18:00.840
but that had the flat shaded walls.
link |
02:18:02.440
So the texture mapping on the walls
link |
02:18:04.520
was what was bringing in some of these challenges
link |
02:18:06.840
that was hard for me
link |
02:18:08.920
and I couldn't solve it right at the time.
link |
02:18:11.080
Can you describe what flat shading is and texture mapping?
link |
02:18:13.440
So the walls were solid color,
link |
02:18:16.020
one of 16 colors in Hover Tank.
link |
02:18:19.280
So that's easy, it's fast,
link |
02:18:20.800
you just draw the solid color for everything.
link |
02:18:23.640
Texture mapping is what we all see today
link |
02:18:25.560
where you have an image that is stretched and distorted
link |
02:18:28.060
onto the walls or the surfaces that you're working with.
link |
02:18:32.120
And it was a long time for me to just figure out
link |
02:18:35.280
how to do that without it distorting in the wrong ways.
link |
02:18:38.520
And I did not get it all exactly right in Catacombs
link |
02:18:42.360
and I had these flaws.
link |
02:18:44.840
So that was important enough to me
link |
02:18:46.740
that rather than continuing to bang my head on that
link |
02:18:49.360
when I wasn't positive I was gonna get it,
link |
02:18:51.800
I went with a completely different approach
link |
02:18:53.440
for drawing for figuring out where the walls were
link |
02:18:56.400
which was a ray casting approach,
link |
02:18:58.580
which I had done in Catacombs 3D I had a bunch of C code
link |
02:19:02.680
trying to make this work right and it wasn't working right.
link |
02:19:05.840
In Wolfenstein I wound up going to a very small amount
link |
02:19:09.880
of assembly code.
link |
02:19:11.160
So in some ways there should be a slower way of doing it
link |
02:19:14.360
but by making it a smaller amount of work
link |
02:19:16.520
that I could more tightly optimize it worked out
link |
02:19:19.280
and Wolfenstein 3D was just absolutely rock solid.
link |
02:19:22.780
It was nothing glitched in there.
link |
02:19:25.480
The game just was pretty much flawless through all of that
link |
02:19:28.280
and I was super proud of that.
link |
02:19:31.160
But eventually like in the later games
link |
02:19:33.240
I went back to the more span based things
link |
02:19:35.640
where I could get more total efficiency
link |
02:19:37.620
once I really did figure out how to do it.
link |
02:19:40.100
So there were two sort of key technical things
link |
02:19:42.640
to Wolfenstein, one was this ray casting approach
link |
02:19:45.840
which you still to this day you see people go and say
link |
02:19:48.780
let's write a ray casting engine
link |
02:19:50.480
because it's an understandable way of doing things
link |
02:19:53.140
that lets you make games very much like that.
link |
02:19:55.700
So you see ray casters in JavaScript,
link |
02:19:57.620
ray casters in Python, people that are basically going
link |
02:20:00.640
and re implementing that approach to taking a tiled world
link |
02:20:04.960
and casting out into it.
link |
02:20:06.480
It works pretty well but it's not the fastest way
link |
02:20:08.760
of doing it.
link |
02:20:09.600
Can you describe what ray casting is?
link |
02:20:11.380
So you start off and you've got your screen
link |
02:20:13.420
which is 320 pixels across at the time
link |
02:20:15.780
if you haven't sized down the window for greater speed
link |
02:20:19.780
and at every pixel there's gonna be an angle
link |
02:20:22.480
from you've got your position in the world
link |
02:20:24.520
and you're going to just run along that angle
link |
02:20:26.920
and keep going until you hit a block.
link |
02:20:29.160
So up to 320 times across there
link |
02:20:32.040
it's gonna throw a cast array out into the world
link |
02:20:35.520
from wherever your origin is until it runs into a wall
link |
02:20:38.660
and then it can figure out exactly where on the wall it hits.
link |
02:20:42.140
The performance challenge of that is as it's going out
link |
02:20:45.400
every block it's crossing it checks is this a solid wall.
link |
02:20:49.240
So that means that in like the early Wolfenstein levels
link |
02:20:52.480
you're in a small jail cell going out into a small hallway
link |
02:20:55.880
it's super efficient for that
link |
02:20:57.180
because you're only stepping across three or four blocks
link |
02:21:00.200
but then if somebody makes a room that covers
link |
02:21:02.480
our maps were limited to 64 by 64 blocks.
link |
02:21:05.520
If you made one room that was nothing but walls
link |
02:21:08.700
at the far space it would go pretty slow
link |
02:21:11.000
because it would be stepping across 80 tile tests
link |
02:21:14.440
or something along the way.
link |
02:21:15.880
By the way the physics of our universe
link |
02:21:17.480
seems to be competing in this very thing.
link |
02:21:19.000
So this maps nicely to the actual physics of our world.
link |
02:21:23.080
Yeah you get like I follow a little bit of something
link |
02:21:25.440
like Steven Wolfram's work on interconnected
link |
02:21:28.680
network information states of that
link |
02:21:30.600
and that's it's beyond what I can have an informed opinion
link |
02:21:34.560
on but it's interesting that people are considering
link |
02:21:37.680
things like that and have things that can back it up.
link |
02:21:42.840
Yeah there's whole different sets
link |
02:21:44.200
of interesting stuff there.
link |
02:21:45.720
So Wolfenstein 3D had ray casting.
link |
02:21:48.200
Ray casting and then the other kind of key aspect
link |
02:21:51.080
was what I called compiled scalers
link |
02:21:53.920
where the idea of you'd saw this in the earlier
link |
02:21:58.600
classic arcade games like Space Harrier and stuff
link |
02:22:01.160
where you would take a picture which is normally drawn
link |
02:22:04.240
directly on the screen and then if you have the ability
link |
02:22:06.840
to make it bigger or smaller big chunky pixels
link |
02:22:09.360
or fizzly small drop sampled pixels.
link |
02:22:12.180
That's the fundamental aspect of what our characters
link |
02:22:15.080
were doing in these 3D games.
link |
02:22:16.520
You would have it's just like you might have drawn
link |
02:22:18.380
a tiny little character but now we can make them
link |
02:22:20.200
really big and make them really small and move it around.
link |
02:22:23.220
That was the limited kind of 3D that we had for characters.
link |
02:22:26.480
To make them turn there were literally
link |
02:22:27.960
eight different views of them.
link |
02:22:29.560
You didn't actually have a 3D model that would rotate.
link |
02:22:31.800
You just had these cardboard cutouts.
link |
02:22:33.780
But that was good enough for that startle fight reaction
link |
02:22:36.760
and it was kind of what we had to deal with there.
link |
02:22:40.080
So a straightforward approach to do that
link |
02:22:42.280
you could just write out your doubly nested loop
link |
02:22:44.600
of you've got your stretch factor
link |
02:22:47.080
and it's like you've got a point,
link |
02:22:48.080
you stretch by a little bit,
link |
02:22:49.400
it might be on the same pixel,
link |
02:22:50.680
it might be on the next pixel,
link |
02:22:51.680
it might have skipped a pixel.
link |
02:22:53.860
You can write that out but it's not gonna be fast enough
link |
02:22:56.080
where especially you get a character for that
link |
02:22:58.480
right in your face monster covering
link |
02:23:00.480
almost the entire screen.
link |
02:23:02.200
Doing that with a general purpose scaling routine
link |
02:23:05.080
would have just been much too slow.
link |
02:23:06.520
It would have worked when they're small characters
link |
02:23:08.320
but then it would get slower and slower
link |
02:23:09.840
as they got closer to you until right at the time
link |
02:23:12.160
when you most care about having a fast reaction time,
link |
02:23:15.320
the game would be chunking down.
link |
02:23:17.320
So the fastest possible way to draw pixels at that time
link |
02:23:22.400
was to, instead of saying I've got a general purpose
link |
02:23:28.720
version that can handle any scale,
link |
02:23:31.500
I used a program to make essentially
link |
02:23:35.320
a hundred or more separate little programs
link |
02:23:37.620
that was optimized for I will take an image
link |
02:23:40.200
and I will draw it 12 pixels tall.
link |
02:23:42.200
I'll take an image, I'll draw it 14 pixels tall
link |
02:23:44.680
up by every two pixels even for that.
link |
02:23:47.680
So you would have the most optimized code
link |
02:23:50.280
so that in the normal case
link |
02:23:52.040
where most of the world is fairly large,
link |
02:23:55.320
like the pixels are big,
link |
02:23:57.000
we did not have a lot of memory.
link |
02:23:58.640
So in most cases that meant that you would load
link |
02:24:01.600
a pixel color and then you would store it multiple times.
link |
02:24:05.240
So that was faster than even copying an image
link |
02:24:09.040
in a normal conventional case
link |
02:24:10.720
because most of the time the image is expanded.
link |
02:24:13.240
So instead of doing one read, one write for a simple copy,
link |
02:24:16.600
you might be doing one read and three or four writes
link |
02:24:19.120
as it got really big.
link |
02:24:20.480
And that had the beneficial aspect
link |
02:24:22.320
of just when you needed the performance most
link |
02:24:24.360
when things are covering the screen,
link |
02:24:25.980
it was giving you the most acceleration for that.
link |
02:24:28.600
By the way, were you able to understand this
link |
02:24:32.480
through thinking about it or were you testing
link |
02:24:34.720
like the right speed and like that?
link |
02:24:36.640
This again comes back to, I can find the antecedents
link |
02:24:40.160
for things like this.
link |
02:24:41.120
So back in the Apple II days,
link |
02:24:45.400
the graphics were essentially single bits at a time.
link |
02:24:49.560
And if you wanted to make your little spaceship,
link |
02:24:51.760
if you wanted to make it smoothly go across the world,
link |
02:24:54.880
if you just took the image and you drew it out
link |
02:24:56.720
at the next location, you would move by seven pixels
link |
02:24:59.360
at a time, so it'd go chunk, chunk, chunk.
link |
02:25:01.320
If you wanted to make it move smoothly,
link |
02:25:03.240
you actually had to make seven versions of the ship
link |
02:25:05.880
that were pre shifted.
link |
02:25:07.360
You could write a program that would shift it dynamically,
link |
02:25:09.920
but on a one megahertz processor,
link |
02:25:11.460
that's not going anywhere fast.
link |
02:25:13.180
So if you wanted to do a smooth moving fast action game,
link |
02:25:16.660
you made separate versions of each of these sprites.
link |
02:25:20.440
Now there were a few more tricks you could pull
link |
02:25:22.360
that if it still wasn't fast enough,
link |
02:25:24.480
you could make a compiled shape
link |
02:25:26.900
where instead of this program that normally copies an image
link |
02:25:31.200
and says like, get this byte from here, stored here,
link |
02:25:33.760
get this byte, store this byte.
link |
02:25:35.400
If you've got the memory space, you could say,
link |
02:25:38.440
I'm going to write the program
link |
02:25:39.800
that does nothing but draw this shape.
link |
02:25:41.960
It's going to be like,
link |
02:25:43.100
I'm going to load the immediate value 25,
link |
02:25:46.640
which is some bit pattern,
link |
02:25:47.920
and then I'm going to store that at this location.
link |
02:25:51.340
Rather than loading something from memory
link |
02:25:53.280
that involved indexing registers and this other slow stuff,
link |
02:25:56.880
you could go ahead and say,
link |
02:25:57.720
no, I'm gonna hard code the exact values
link |
02:26:00.020
of all of the image right into the program.
link |
02:26:02.460
And this was always a horrible trade off there,
link |
02:26:04.120
which you didn't have much memory
link |
02:26:05.360
and you didn't have much speed.
link |
02:26:07.000
But if you had something that you wanted to go really fast,
link |
02:26:09.600
you could turn it into a program.
link |
02:26:11.800
And that was, knowing about that technique
link |
02:26:14.560
is what made me think about some of these unwinding it
link |
02:26:17.640
for the PC where people that didn't come
link |
02:26:19.760
from that background were less likely to think about that.
link |
02:26:23.360
I mean, there's some deep parallels
link |
02:26:25.200
probably to human cognition as well.
link |
02:26:27.500
There's something about optimizing and compressing
link |
02:26:34.560
the processing of a new information
link |
02:26:36.800
that requires you to predict the possible ways
link |
02:26:39.760
in which the game or the world might unroll.
link |
02:26:44.440
And you have something like compiled scaler is always there.
link |
02:26:47.440
So you have like, like you have a prediction
link |
02:26:51.400
of how the world will unroll
link |
02:26:52.720
and you have some kind of optimized data structure
link |
02:26:57.060
for that prediction.
link |
02:26:58.200
And then you can modify if the world turns out
link |
02:27:00.440
to be different, you can modify a slight way.
link |
02:27:02.320
And as far as building out techniques,
link |
02:27:04.180
so much of the brain is about the associative context.
link |
02:27:06.960
You know, they're just, when you learn something,
link |
02:27:09.120
it's in the context of something else
link |
02:27:10.920
and you can have faint, tiny little hints of things.
link |
02:27:13.980
And I do think there are some deep things
link |
02:27:16.440
around like sparse distributed memories and boosting.
link |
02:27:18.840
That's like, if you can just be slightly
link |
02:27:20.420
above the noise floor of having some hint of something,
link |
02:27:23.360
you can have things refined into pulling the memory back up.
link |
02:27:26.460
So having a, being a programmer and having a toolbox
link |
02:27:29.560
of like all of these things that,
link |
02:27:31.200
things that I did in all of these previous lives
link |
02:27:33.640
of programming tasks that still matters to me
link |
02:27:36.080
about how I'm able to pull up some of these things.
link |
02:27:38.520
Like in that case, it was something I did on the Apple 2
link |
02:27:41.180
then being relevant for the PC.
link |
02:27:43.240
And I have still cases when I would,
link |
02:27:46.040
when I would work on mobile development then be like,
link |
02:27:48.000
okay, I did something like this back in the doom days,
link |
02:27:51.720
but now it's a different environment,
link |
02:27:53.600
but I have still had that tie.
link |
02:27:55.000
I can bring it in and I can transform it
link |
02:27:56.880
into what the world needs right now.
link |
02:27:59.120
And I do think that's actually one of the very core things
link |
02:28:01.920
with human cognition and brain like,
link |
02:28:04.680
you know, brain like functioning
link |
02:28:06.080
is finding these ways about you've got,
link |
02:28:08.480
your brain is kind of everything everywhere all at once.
link |
02:28:10.800
You know, it's, it is just a set of all of this stuff
link |
02:28:13.080
that is just fetched back by these queries that go into it.
link |
02:28:16.440
And they can just be slightly above the noise floor
link |
02:28:18.900
with a random noise in your neurons and synapses
link |
02:28:21.260
that are affecting exactly what gets pulled up.
link |
02:28:23.980
So you're saying some of these very specific solutions
link |
02:28:26.520
for different games,
link |
02:28:28.600
you find that there's a kernel of a deep idea
link |
02:28:31.960
that's generalizable to other, to other things.
link |
02:28:34.760
Yeah, you can't predict what it's going to be,
link |
02:28:36.480
but that idea of like,
link |
02:28:37.720
I called out that compiled shaders in the forward
link |
02:28:40.720
that I wrote for that, the game engine black book,
link |
02:28:43.320
as you know, this is,
link |
02:28:44.920
it's kind of an end point of unrolling code,
link |
02:28:48.000
but that's one of those things that thinking about that
link |
02:28:50.400
and having that in your mind.
link |
02:28:51.640
And I'm sure there are some programmers
link |
02:28:53.120
that, you know, hear about that.
link |
02:28:54.680
Think about it a little bit.
link |
02:28:55.560
It's kind of the mind blown moment.
link |
02:28:57.040
It's like, oh, you can just turn all of that data into code.
link |
02:29:00.760
And nowadays, you know, you have instruction cache issues
link |
02:29:03.360
and that's not necessarily the best idea,
link |
02:29:05.540
but there are different,
link |
02:29:07.280
it's an idea that has power
link |
02:29:09.020
and has probably relevance in some other areas.
link |
02:29:11.500
Maybe it's in a hardware point of view
link |
02:29:13.020
that there's a way you approach building hardware
link |
02:29:15.460
that has that same,
link |
02:29:16.800
you don't even have to think about iterating.
link |
02:29:18.440
You just bake everything all the way into it in one place.
link |
02:29:22.200
What is the story of how you came to program Doom?
link |
02:29:25.400
What are some memorable technical challenges
link |
02:29:27.760
or innovations within that game?
link |
02:29:29.800
So the path that we went after Wolfenstein got out
link |
02:29:33.640
and we were on this crazy arc
link |
02:29:35.560
where Keen one through three, more success than we thought,
link |
02:29:38.840
Keen four through six, even more success,
link |
02:29:41.120
Wolfenstein even more success.
link |
02:29:42.880
So we were on this crazy trajectory for things.
link |
02:29:46.420
So actually our first box commercial project
link |
02:29:48.280
was the Commander Keen game,
link |
02:29:50.660
but then Wolfenstein was going to have a game called
link |
02:29:52.960
Spear of Destiny, which was a commercial version,
link |
02:29:55.940
60 new levels.
link |
02:29:57.260
So the rest of the team took the game engine
link |
02:29:59.480
pretty much as it was and started working on that.
link |
02:30:02.740
We got new monsters,
link |
02:30:03.920
but it's basically reskins of the things there.
link |
02:30:07.640
And there's a really interesting aspect about that
link |
02:30:09.420
that I didn't appreciate until much, much later
link |
02:30:12.260
about how Wolfenstein clearly did tap out its limit
link |
02:30:16.640
about what you want to play,
link |
02:30:18.840
all the levels and a couple of our license things.
link |
02:30:21.600
There was a hard creative wall
link |
02:30:24.000
that you did not really benefit much
link |
02:30:25.800
by continuing to beat on it.
link |
02:30:27.880
But a game like Doom and other more modern games
link |
02:30:31.440
like Minecraft or something,
link |
02:30:33.000
there's kind of a Turing completeness level
link |
02:30:35.040
of design freedom that you get in games
link |
02:30:37.200
that Wolfenstein clearly sat on one side of.
link |
02:30:40.400
All the creative people in the world
link |
02:30:42.040
could not go and do a masterpiece
link |
02:30:43.980
just with the technology that Wolfenstein had.
link |
02:30:46.480
Wolfenstein could do Wolfenstein,
link |
02:30:48.160
but you really couldn't do something crazy and different.
link |
02:30:50.760
But it didn't take that much more capability
link |
02:30:53.380
to get to Wolfenstein with the freeform lines
link |
02:30:56.240
and a little bit more artistic freedom
link |
02:30:58.600
to get to the point where people still announce
link |
02:31:00.960
new Doom levels today, all these years after
link |
02:31:03.720
without having completely tapped out the creativity.
link |
02:31:06.720
How did you put it?
link |
02:31:07.560
Turing complete?
link |
02:31:08.520
Yeah, Turing complete design space.
link |
02:31:10.200
Design space.
link |
02:31:11.040
Where it's like, you know,
link |
02:31:11.880
we have the kind of computational universality
link |
02:31:14.800
on a lot of things and how different
link |
02:31:16.120
subsurface work. For creativity.
link |
02:31:17.480
But yeah, there's things where a box can be too small,
link |
02:31:20.960
but above a certain point,
link |
02:31:22.840
you kind of are at the point where you really have
link |
02:31:26.200
almost unbounded creative ability there.
link |
02:31:28.400
And Doom was the first time you crossed that line.
link |
02:31:31.440
Yeah, where there were thousands of Doom levels created,
link |
02:31:35.100
and some of them still have something new and interesting
link |
02:31:37.320
to say to the world about it.
link |
02:31:38.600
Is that line, can you introspect what that line was?
link |
02:31:43.220
Is it in the design space?
link |
02:31:44.840
Is it something about the programming capabilities
link |
02:31:48.380
that you were able to add to the game?
link |
02:31:50.920
So the graphics fidelity was a necessary part
link |
02:31:54.380
because the block limitations in Wolfenstein,
link |
02:31:57.520
what we had right there was not enough.
link |
02:32:00.800
The full scale blocks, although Minecraft really did show
link |
02:32:04.680
that perhaps blocks stacked in 3D
link |
02:32:07.760
and at one quarter of the scale of that,
link |
02:32:09.920
or one eighth in volume,
link |
02:32:11.360
is then sufficient to have all of that.
link |
02:32:13.260
But the wall sized blocks that we had in Wolfenstein
link |
02:32:16.760
was too much of a creative limitation.
link |
02:32:18.720
We licensed the technology to a few other teams.
link |
02:32:21.640
None of them made too much of a dent with that.
link |
02:32:24.880
It just wasn't enough creative ability.
link |
02:32:27.240
But a little bit more,
link |
02:32:28.480
whether it was the variable floors and ceilings
link |
02:32:31.000
and arbitrary angles in Doom,
link |
02:32:33.200
or the smaller voxel blocks in Minecraft,
link |
02:32:37.200
is then enough to open it up
link |
02:32:38.640
to just worlds and worlds of new capabilities.
link |
02:32:41.880
What is binary space partitioning?
link |
02:32:45.040
So the. Which is one of the technologies.
link |
02:32:47.600
Yeah, so jump around a little bit on the story path there.
link |
02:32:51.080
So while the team was working on Spirit Destiny
link |
02:32:53.160
for Wolfenstein, we had met another development team,
link |
02:32:57.200
Raven Software, while we were in Wisconsin.
link |
02:32:59.960
And they were doing, they had RPG background
link |
02:33:03.280
and I still kind of loved that.
link |
02:33:04.760
And I offered to do a game engine for them
link |
02:33:07.720
to let them do a 3D rendered RPG
link |
02:33:10.720
instead of the, like most RPG games were kind of hand drawn.
link |
02:33:14.060
They made it look kind of 3D,
link |
02:33:15.540
but it was done just all with artist work
link |
02:33:17.560
rather than a real engine.
link |
02:33:19.800
And after Wolfenstein, this was still a tile based world,
link |
02:33:23.320
but I added floors and ceilings and some lighting
link |
02:33:25.600
and the ability to have some sloped floors
link |
02:33:27.680
in different areas.
link |
02:33:28.520
And that was my intermediate step
link |
02:33:30.040
for a game called Shadowcaster.
link |
02:33:32.360
And it had slowed down enough.
link |
02:33:34.440
It was not fast enough to do our type of action things.
link |
02:33:37.680
So they had the screen crop down a little bit.
link |
02:33:39.960
So you couldn't go the full screen width
link |
02:33:42.280
like we would try to do in Wolfenstein, but I learned a lot.
link |
02:33:46.320
I got the floors and ceilings and lightings
link |
02:33:47.960
and it looked great.
link |
02:33:48.880
They were great artists up there.
link |
02:33:50.360
And it was an inspiration for us
link |
02:33:52.320
to look at some of that stuff.
link |
02:33:54.400
But I had learned enough from that,
link |
02:33:57.000
that I had the plan for,
link |
02:33:58.480
I knew faster ways to do the lighting and shadowing.
link |
02:34:01.540
And I wanted to do this free form geometry.
link |
02:34:03.640
I wanted to break out of this tile based
link |
02:34:06.560
90 degree world limitations.
link |
02:34:09.120
So we had, that was when we got our next stations
link |
02:34:12.280
and we were working with these higher powered systems.
link |
02:34:14.960
And we built an editor that let us draw
link |
02:34:18.400
kind of arbitrary line segments.
link |
02:34:20.240
And I was working hard to try to make something
link |
02:34:22.720
that could render this fast enough.
link |
02:34:26.120
I was pushing myself pretty hard.
link |
02:34:28.760
And we were at a point where we could see some things
link |
02:34:32.220
that looked amazingly cool,
link |
02:34:33.720
but it wasn't really fast enough for the way I was doing it.
link |
02:34:37.760
For this flexibility, it was no longer,
link |
02:34:39.440
I couldn't just ray cast into it.
link |
02:34:41.080
And I had these very complex sets of lines
link |
02:34:43.240
and simple little worlds were okay.
link |
02:34:45.360
But the cool things that we wanted to do
link |
02:34:47.520
just weren't quite fast enough.
link |
02:34:49.680
And I wound up taking a break at that point.
link |
02:34:52.480
And I did the port.
link |
02:34:54.520
I did two ports of our games,
link |
02:34:58.000
Wolfenstein to the Super Nintendo.
link |
02:35:01.040
It was a crazy difficult thing to do,
link |
02:35:04.240
which was an even slower processors,
link |
02:35:06.040
like a couple of megahertz processor.
link |
02:35:10.000
And it had been this whole thing
link |
02:35:11.820
where we had farmed out the work and it wasn't going well.
link |
02:35:17.160
And I took it back over
link |
02:35:18.860
and trying to make it go fast on there
link |
02:35:21.860
where it really did not have much processing power.
link |
02:35:25.160
The pixels were stretched up hugely
link |
02:35:26.880
and it was pretty ugly when you looked at it.
link |
02:35:29.040
But in the end, it did come out fast enough to play
link |
02:35:31.520
and still be kind of fun from that.
link |
02:35:33.480
But that was where I started using BSP trees
link |
02:35:36.600
or binary space partitioning trees.
link |
02:35:38.320
It was one of those things I had to make it faster there.
link |
02:35:41.520
It was a stepping stone where it was reasonably easy
link |
02:35:44.520
to understand in the grid world of Wolfenstein
link |
02:35:46.960
where it was all still 90 degree angles.
link |
02:35:49.960
BSP trees were, I eased myself into it with that.
link |
02:35:53.920
And it was a big success.
link |
02:35:56.200
Then when I came back to working on Doom,
link |
02:35:58.740
I had this new tool in my toolbox.
link |
02:36:00.640
It was gonna be a lot harder
link |
02:36:02.040
with the arbitrary angles of Doom.
link |
02:36:03.900
This was where I really started grappling
link |
02:36:06.120
with epsilon problems.
link |
02:36:07.760
And just up until that point,
link |
02:36:09.600
I hadn't really had to deal with the fact
link |
02:36:11.360
that I am so many numeric things.
link |
02:36:13.820
This almost felt like a betrayal to me
link |
02:36:15.340
where people had told me that I had mathematicians
link |
02:36:17.600
up on a bit of a pedestal where I was,
link |
02:36:20.360
people think I'm a math wizard and I'm not.
link |
02:36:22.680
I really, everything that I did was really done
link |
02:36:25.980
with a solid high school math understanding.
link |
02:36:29.520
Algebra two trigonometry and that was what got me
link |
02:36:33.480
all the way through Doom and Quake and all of that,
link |
02:36:35.500
of just understanding basics of matrices
link |
02:36:38.280
and knowing it well enough to do something with it.
link |
02:36:41.040
What's the epsilon problems you ran into?
link |
02:36:42.920
So when you wind up taking like a sloped line
link |
02:36:46.720
and you say, I'm going to intersect it
link |
02:36:48.340
with another sloped line,
link |
02:36:50.920
then you wind up with something
link |
02:36:52.200
that's not going to be on these nice grid boundaries.
link |
02:36:54.960
With the Wolfenstein tile maps,
link |
02:36:57.120
all you've got is horizontal and vertical lines
link |
02:36:58.960
looking at it from above.
link |
02:37:00.200
And if you cut one of them, it's just obvious
link |
02:37:02.200
the other one gets cut exactly at that point.
link |
02:37:04.880
But when you have angled lines,
link |
02:37:06.620
you're doing a kind of a slope intercept problem
link |
02:37:08.840
and you wind up with rational numbers there
link |
02:37:11.200
where things that are not going to evenly land on an integer
link |
02:37:14.800
or even on any fixed point value that you've got.
link |
02:37:17.240
So everything winds up having to snap
link |
02:37:19.520
to some fixed point value.
link |
02:37:20.960
So the lines slightly change their angle.
link |
02:37:23.400
You wind up, if you cut something here,
link |
02:37:25.320
this one's going to bend a little this way
link |
02:37:26.840
and it's not going to be completely straight.
link |
02:37:28.900
And then you come down to all these questions of,
link |
02:37:30.720
well, this one is a point on an angled line.
link |
02:37:35.140
You can't answer that in finite precision
link |
02:37:38.000
unless you're doing something with actual rational numbers.
link |
02:37:41.000
And later on, I did waste far too much time
link |
02:37:43.220
chasing things like that.
link |
02:37:44.180
How do you do precise arithmetic with rational numbers?
link |
02:37:46.860
And it always blows up eventually, exponentially
link |
02:37:49.940
as you do it.
link |
02:37:50.780
So these kinds of things are impossible with computers.
link |
02:37:53.240
So they're possible.
link |
02:37:55.180
Again, there are paths to doing it,
link |
02:37:57.460
but you can't fit them conveniently
link |
02:37:59.240
in any of the numbers.
link |
02:38:00.240
You need to start using big nums
link |
02:38:01.800
and different factor trackings of different things.
link |
02:38:04.600
So you have to, if you have any elements of OCD
link |
02:38:08.120
and you want to do something perfectly,
link |
02:38:09.840
you're screwed if you're working with floating point.
link |
02:38:12.280
Yeah.
link |
02:38:13.120
So you had to deal with this for the first time.
link |
02:38:15.320
And there were lots of challenges there about like,
link |
02:38:18.400
okay, they build this cool thing.
link |
02:38:20.080
And the way the BSP trees work is it basically
link |
02:38:22.880
takes the walls and it carves other walls by those walls
link |
02:38:26.400
in this clever way that you can then
link |
02:38:28.760
take all of these fragments.
link |
02:38:30.440
And then you can for sure, from any given point,
link |
02:38:33.120
get an ordering of everything in the world.
link |
02:38:35.160
And you can say, this goes in front of this,
link |
02:38:36.800
goes in front of this, all the way back to the last thing.
link |
02:38:40.200
And that's super valuable for graphics
link |
02:38:42.400
where kind of a classic graphics algorithm
link |
02:38:45.280
would be painter's algorithm.
link |
02:38:46.800
You paint the furthest thing first,
link |
02:38:48.200
and then the next thing, and then the next thing,
link |
02:38:49.880
and then it comes up and it's all perfect for you.
link |
02:38:52.760
That's slow because you don't want to have to have drawn
link |
02:38:54.840
everything like that,
link |
02:38:56.160
but you can also flip it around
link |
02:38:57.580
and draw the closest thing to you.
link |
02:38:59.680
And then if you're clever about it,
link |
02:39:01.400
you can figure out what you need to draw
link |
02:39:03.520
that's visible beyond that.
link |
02:39:05.480
And that's what BSP trees allow you to do.
link |
02:39:07.560
Yeah, so it's combined with a bunch of other things,
link |
02:39:10.620
but it gives you that ordering.
link |
02:39:12.200
It's a clever way of doing things.
link |
02:39:13.760
And I remember I had learned this
link |
02:39:15.520
from one of my graphics Bible at the time,
link |
02:39:18.760
a book called Foley and Van Damme.
link |
02:39:20.480
And again, it was a different world back there.
link |
02:39:22.200
There was a small integer number of books.
link |
02:39:24.660
And this book that was big fat college textbook
link |
02:39:29.680
that I had read through many times.
link |
02:39:32.520
I didn't understand everything in it.
link |
02:39:34.240
Some of it wasn't useful to me,
link |
02:39:35.840
but they had the little thing about finite orderings
link |
02:39:39.620
of you draw a little T shaped thing
link |
02:39:41.520
and you can say you can make a fixed ahead of time order
link |
02:39:44.760
from this and you can generalize this with the BSP trees.
link |
02:39:48.240
And I got a little bit more information about that.
link |
02:39:50.820
And it was kind of fun later while I was working on Quake,
link |
02:39:53.120
I got to meet Bruce Naylor,
link |
02:39:54.760
who is one of the original researchers
link |
02:39:56.520
that developed those technologies for academic literature.
link |
02:40:00.840
And that was kind of fun,
link |
02:40:01.740
but I was very much just finding a tool
link |
02:40:03.800
that can help me solve what I was doing.
link |
02:40:05.840
And I was using it in this very crude way
link |
02:40:07.800
in a two dimensional fashion, rather than the general 3D.
link |
02:40:10.480
The Epsilon problems got much worse
link |
02:40:12.040
in Quake and three dimensionals
link |
02:40:13.760
when things angle in every way.
link |
02:40:15.680
But eventually I did sort out
link |
02:40:18.360
how to do it reliably on Doom.
link |
02:40:20.000
There were still a few edge cases in Doom
link |
02:40:22.200
that were not absolutely perfect
link |
02:40:24.360
where they even got terminologies in the communities.
link |
02:40:27.740
Like when you got to something where it was messed up,
link |
02:40:29.440
it was a hall of mirrors effect
link |
02:40:30.920
because you'd sweep by and it wouldn't draw something there.
link |
02:40:33.720
And you would just wind up with the leftover remnants
link |
02:40:36.200
as you flipped between the two pages.
link |
02:40:39.260
But BSP trees were important for it.
link |
02:40:41.480
But it's again worth noting that after we did Doom,
link |
02:40:45.640
our major competition came from Ken Silverman
link |
02:40:49.000
and his build engine, which was used for Duke Nukem 3D
link |
02:40:51.780
and some of the other games for 3D Realms.
link |
02:40:54.080
And he used a completely different technology,
link |
02:40:56.200
nothing to do with BSP trees.
link |
02:40:59.200
So there's not just a one true way of doing things.
link |
02:41:03.880
There were critical things about
link |
02:41:05.600
to make any of those games fast.
link |
02:41:07.160
You had to separate your drawing into,
link |
02:41:09.640
you drew vertical lines and you drew horizontal lines,
link |
02:41:12.440
just kind of changing exactly
link |
02:41:14.320
what you would draw with them.
link |
02:41:15.760
That was critical for the technologies at that time.
link |
02:41:19.360
And like all the games that were kind of like that
link |
02:41:21.680
wound up doing something similar,
link |
02:41:23.400
but there were still a bunch of other decisions
link |
02:41:25.400
that could be made.
link |
02:41:26.800
And we made good enough decisions on everything on Doom.
link |
02:41:30.360
We brought in multiplayer significantly
link |
02:41:33.680
and it was our first game that was designed
link |
02:41:35.640
to be modified by the user community
link |
02:41:37.640
where we had this whole setup of our WAD files and PWADs
link |
02:41:41.120
and things that people could build with tools
link |
02:41:43.680
that we released to them.
link |
02:41:44.680
And they eventually rewrote to be better
link |
02:41:46.220
than what we released, but they could build things
link |
02:41:48.840
and you could add it to your game
link |
02:41:50.400
without destructively modifying it,
link |
02:41:52.260
which is what you had to do in all the early games.
link |
02:41:54.080
You literally hacked the data files or the executable
link |
02:41:57.600
before while Doom was set up in this flexible way
link |
02:42:00.580
so that you could just say,
link |
02:42:02.300
run the normal game with this added on on top
link |
02:42:04.820
and it would overlay just the things
link |
02:42:06.920
that you wanted to there.
link |
02:42:09.100
Would you say that Doom was kind of the first
link |
02:42:11.580
true 3D game that you created?
link |
02:42:14.240
So no, it's still, Doom would usually be called
link |
02:42:16.620
a two and a half D game
link |
02:42:17.800
where it had three dimensional points on it.
link |
02:42:20.300
And this is another one of these kind of pedantic things
link |
02:42:22.440
that people love to argue about,
link |
02:42:23.980
about what was the first 3D game.
link |
02:42:25.720
I still, like every month probably I hear from somebody
link |
02:42:29.360
about, well, was Doom really a 3D game or something?
link |
02:42:34.320
And I give the point where characters had three coordinates.
link |
02:42:38.520
So you had like an X, Y and Z,
link |
02:42:40.240
the cacodamon could be coming in very high
link |
02:42:42.300
and come down towards you.
link |
02:42:45.000
The walls had three coordinates on them.
link |
02:42:47.400
So on some sense it's a 3D game engine,
link |
02:42:50.320
but it was not a fully general 3D game engine.
link |
02:42:53.440
You could not build a pyramid in Doom
link |
02:42:56.660
because you couldn't make a sloped wall,
link |
02:42:59.420
which was slightly different
link |
02:43:00.480
where in that previous shadow caster game,
link |
02:43:02.280
I could have vertexes and have a sloped floor there,
link |
02:43:05.200
but the changes that I made for Doom to get higher speed
link |
02:43:08.320
and a different set of flexibility traded away that ability,
link |
02:43:11.660
but you literally couldn't make that.
link |
02:43:13.400
You could not, you could make different heights of passages,
link |
02:43:17.880
but you could not make a bridge over another area.
link |
02:43:20.280
You could not go over and above it.
link |
02:43:21.880
So it still had some 2D limitations to it.
link |
02:43:24.880
That's more about the building
link |
02:43:26.020
versus the actual experience.
link |
02:43:27.480
Cause the experience is.
link |
02:43:29.120
It felt like things would come at you,
link |
02:43:30.520
but again, you couldn't look up either.
link |
02:43:32.440
I am, you know, you could only pitch.
link |
02:43:34.720
It was four degrees of freedom
link |
02:43:36.460
rather than six degrees of freedom.
link |
02:43:38.400
You did not have the ability to tilt your head this way
link |
02:43:40.600
or pitch up and down.
link |
02:43:42.320
So that takes us to Quake.
link |
02:43:44.480
What was the leap there?
link |
02:43:47.480
What was some fascinating technical challenges
link |
02:43:50.040
and there were a lot or not challenges,
link |
02:43:52.180
but innovations that you've come up with.
link |
02:43:54.140
So Quake was kind of the first thing
link |
02:43:56.440
where I did have to kind of come face to face
link |
02:43:59.520
with my limitations,
link |
02:44:01.240
where it was the first thing
link |
02:44:02.280
where I really did kind of give it my all
link |
02:44:05.660
and still come up, you know, come up a little bit short
link |
02:44:08.400
in terms of what and when I wanted to get it done.
link |
02:44:11.920
And the company ran,
link |
02:44:13.560
they had some serious stresses through the whole project
link |
02:44:16.760
and we bit off a lot.
link |
02:44:19.680
So the things that we set out to do
link |
02:44:21.440
was it was going to be really a true 3D engine
link |
02:44:24.640
where it could do six degree of freedom.
link |
02:44:26.960
You could have all the viewpoints.
link |
02:44:29.680
You could model anything.
link |
02:44:31.480
It had a really remarkable new lighting model
link |
02:44:35.280
with the surface caching and things.
link |
02:44:37.080
That was one of those where it was starting
link |
02:44:38.480
to do some things that they weren't doing
link |
02:44:40.740
even on the very high end systems.
link |
02:44:43.600
And it was going to be completely programmable
link |
02:44:46.920
in the modding standpoint,
link |
02:44:48.200
where the thing that you couldn't do in Doom,
link |
02:44:49.800
you could replace almost all of the media,
link |
02:44:52.360
but you couldn't really change the game.
link |
02:44:55.120
There were still some people that were doing
link |
02:44:57.100
the hex setting of the executable,
link |
02:44:58.800
the dehacked things where you could change
link |
02:45:00.620
a few things about rules
link |
02:45:01.900
and people made some early capture the flag type things
link |
02:45:04.620
by hacking the executable,
link |
02:45:06.020
but it wasn't really set out to do that.
link |
02:45:08.520
Quake was going to have its own programming language
link |
02:45:11.360
that the game was going to be implemented in it.
link |
02:45:13.200
And that would be able to be overwritten
link |
02:45:14.840
just like any of the media.
link |
02:45:16.560
Code was going to be data for that.
link |
02:45:18.400
And you would be able to have expansion packs
link |
02:45:21.000
that changed fundamental things and mods and so on.
link |
02:45:24.160
And the multiplayer was going to be playable
link |
02:45:27.120
over the internet.
link |
02:45:28.120
It was going to support a client server
link |
02:45:30.880
rather than peer to peer.
link |
02:45:32.400
So we had the possibility of supporting
link |
02:45:34.160
larger numbers of players in disparate locations
link |
02:45:37.440
with this full flexibility of the programming overrides
link |
02:45:41.320
with full six degree of freedom modeling and viewing.
link |
02:45:44.920
And with this fancy new light mapped
link |
02:45:47.960
kind of surface caching side.
link |
02:45:49.720
It was a lot.
link |
02:45:50.640
And this was one of those things that
link |
02:45:52.520
if I could go back and tell younger me
link |
02:45:56.000
to do something differently,
link |
02:45:57.500
it would have been to split those innovations up
link |
02:45:59.680
into two phases in two separate games.
link |
02:46:02.000
It will be phase one and phase two.
link |
02:46:03.640
So it probably would have been taking
link |
02:46:05.480
the Doom rendering engine and bringing in
link |
02:46:08.600
the TCP IP client server.
link |
02:46:10.720
Focusing on the multiplayer.
link |
02:46:12.200
And the Quake C or would have been Doom C
link |
02:46:15.240
programming language there.
link |
02:46:16.920
So I would have split that into programming language
link |
02:46:19.360
and networking with the same Doom engine
link |
02:46:21.800
rather than forcing everybody to go towards
link |
02:46:24.000
the Quake engine, which really meant getting a Pentium.
link |
02:46:27.640
While it ran on a 486, it was not a great experience there.
link |
02:46:31.000
We could have made more people happier
link |
02:46:33.000
and gotten two games done in 50% more time.
link |
02:46:37.320
So speaking of people happier, our mutual friend,
link |
02:46:41.640
Joe Rogan, it seems like the most important moment
link |
02:46:46.320
of his life is centered around Quake.
link |
02:46:49.480
So it was a definitive part of his life.
link |
02:46:53.520
So would he agree with your thinking that they should split?
link |
02:46:59.120
So he is a person who loves Quake
link |
02:47:01.440
and played Quake a lot.
link |
02:47:03.320
Would he agree that you should have done the Doom engine
link |
02:47:06.760
and focus on the multiplayer for phase one?
link |
02:47:09.680
Or in your looking back, is the 3D world
link |
02:47:14.800
that Quake created was also fundamental
link |
02:47:17.640
to the enriching experience?
link |
02:47:19.560
You know, I would say that what would have happened
link |
02:47:21.560
is you would have had a Doom looking
link |
02:47:25.280
but Quake feeling game eight months earlier
link |
02:47:29.960
and then maybe six months after Quake actually shipped,
link |
02:47:33.120
then there would have been the full running on a Pentium,
link |
02:47:36.380
six degree of freedom graphics engine type things there.
link |
02:47:38.720
So it's not that it wouldn't have been there.
link |
02:47:42.040
It would have been something amazingly cool earlier
link |
02:47:45.000
and then something even cooler somewhat later
link |
02:47:47.740
where I would much rather have gone
link |
02:47:50.320
and done two one year development efforts.
link |
02:47:53.200
I've cycled them through.
link |
02:47:54.800
I've been a little more pragmatic about that
link |
02:47:57.460
rather than killing us ourselves on the whole Quake
link |
02:48:00.280
development.
link |
02:48:01.120
But I would say it's obviously things worked out well
link |
02:48:04.100
in the end, but looking back and saying,
link |
02:48:06.440
how would I optimize and do things differently?
link |
02:48:08.960
That did seem to be a clear case where I going ahead
link |
02:48:13.160
and we had enormous momentum on Doom.
link |
02:48:15.840
We did Doom two as the kind of commercial boxed version
link |
02:48:19.120
after our shareware success with the original,
link |
02:48:22.140
but we could have just made another Doom game
link |
02:48:25.720
adding those new features in.
link |
02:48:27.640
It would have been huge.
link |
02:48:28.640
We would have learned all the same lessons, but faster.
link |
02:48:31.440
And it would have given six degree of freedom
link |
02:48:34.120
and Pentium class systems a little bit more time
link |
02:48:37.020
to get mainstream because we did cut out a lot of people
link |
02:48:40.080
with the hardware requirements for Quake.
link |
02:48:42.880
Was there any dark moments for you personally,
link |
02:48:44.800
psychologically in having such harsh deadlines
link |
02:48:51.080
and having to solve so many difficult technical challenges?
link |
02:48:54.680
So I've never really had really dark black places.
link |
02:49:00.660
I mean, I can't necessarily put myself
link |
02:49:02.660
in anyone else's shoes,
link |
02:49:03.940
but I understand a lot of people have significant challenges
link |
02:49:09.560
with kind of their mental health and wellbeing.
link |
02:49:12.460
And I've been super stressed.
link |
02:49:15.000
I've been unhappy as a teenager in various ways,
link |
02:49:18.720
but I've never really gone to a very dark place.
link |
02:49:23.660
I just seem to be largely immune to what really wrecks people.
link |
02:49:29.800
I mean, I've had plenty of time when I'm very unhappy
link |
02:49:32.260
and miserable about something,
link |
02:49:33.860
but it's never hit me like,
link |
02:49:36.380
I believe it winds up hitting some other people.
link |
02:49:38.740
I've borne up well under whatever stresses
link |
02:49:41.660
have kind of fallen on me.
link |
02:49:44.340
And I've always coped best on that
link |
02:49:46.900
when all I need to do is usually
link |
02:49:49.460
just kind of bear down on my work.
link |
02:49:51.180
I pull myself out of whatever hole I might be slipping into
link |
02:49:55.060
by actually making progress.
link |
02:49:57.300
I mean, maybe if I was in a position
link |
02:49:59.460
where I was never able to make that progress,
link |
02:50:01.740
I could have slid down further,
link |
02:50:03.300
but I've always been in a place where,
link |
02:50:06.220
okay, a little bit more work,
link |
02:50:07.540
maybe I'm in a tough spot here,
link |
02:50:09.080
but I always know if I just keep pushing,
link |
02:50:12.240
eventually I break through and I make progress,
link |
02:50:14.640
I feel good about what I'm doing.
link |
02:50:17.460
And that's been enough for me so far in my life.
link |
02:50:20.660
Have you seen it in the distance,
link |
02:50:23.700
like ideas of depression or contemplating suicide?
link |
02:50:28.740
Have you seen those things far?
link |
02:50:30.500
So what was interesting, when I was a teenager,
link |
02:50:33.100
I was probably on some level a troubled youth.
link |
02:50:37.300
I was unhappy most of my teenage years.
link |
02:50:40.740
I really, I wanted to be on my own
link |
02:50:42.580
doing programming all the time.
link |
02:50:44.540
As soon as I was 18, 19, even though I was poor,
link |
02:50:47.620
I was doing exactly what I wanted and I was very happy,
link |
02:50:50.700
but high school was not a great time for me.
link |
02:50:53.020
And I had a conversation with like the school counselor
link |
02:50:56.920
and they're kind of running their script.
link |
02:50:58.540
It's like, okay, it's kind of a weird kid here.
link |
02:51:00.580
Let's carefully probe around.
link |
02:51:02.380
It's like, do you ever think about ending it all?
link |
02:51:05.700
I'm like, no, of course not.
link |
02:51:07.500
Never, not at all.
link |
02:51:08.980
This is temporary, things are going to be better.
link |
02:51:13.140
And that's always been kind of the case for me.
link |
02:51:15.580
And obviously that's not that way for everyone
link |
02:51:18.300
and other people do react differently.
link |
02:51:20.900
What was your escape from the troubled youth,
link |
02:51:24.940
like music, video games, books?
link |
02:51:33.660
How did you escape from a world
link |
02:51:35.460
that's full of cruelty and suffering and that's absurd?
link |
02:51:38.180
Yeah, I mean, I was not a victim of cruelty and suffering.
link |
02:51:41.800
It's like, I was an unhappy, somewhat petulant youth
link |
02:51:44.340
in my point where I'm not putting myself up
link |
02:51:48.260
with anybody else's suffering,
link |
02:51:49.700
but I was unhappy objectively.
link |
02:51:52.260
And the things that I did
link |
02:51:54.820
that very much characterized my childhood
link |
02:51:57.260
were I had books, comic books,
link |
02:52:00.460
Dungeons and Dragons, arcade games, video games.
link |
02:52:03.740
Like some of my fondest childhood memories
link |
02:52:06.380
are the convenience stores, the 711s and Quick Trips,
link |
02:52:08.900
because they had a spinner rack of comic books
link |
02:52:11.380
and they had a little side room
link |
02:52:12.700
with two or three video games, arcade games in it.
link |
02:52:15.780
And that was very much my happy place.
link |
02:52:18.780
If I could, I get my comic books
link |
02:52:20.820
and if I could go to a library
link |
02:52:22.580
and go through those little zero, zero, zero section
link |
02:52:25.740
where computer books were supposed to be.
link |
02:52:27.380
And there were a few sad little books there,
link |
02:52:28.980
but still just being able to sit down and go through that.
link |
02:52:31.860
And I read a ridiculous number of books,
link |
02:52:35.740
both fiction and nonfiction as a teenager.
link |
02:52:38.620
And my rebelling in high school
link |
02:52:42.780
was just sitting there with my nose in a book,
link |
02:52:44.500
ignoring the class through lots of it.
link |
02:52:46.820
And teachers had a range of reactions to that,
link |
02:52:49.420
some more accepting of it than others.
link |
02:52:53.580
I'm with you on that.
link |
02:52:54.580
So let us return to Quake for a bit
link |
02:52:56.540
with the technical challenges.
link |
02:52:57.860
What everything together from the networking
link |
02:53:03.460
to the graphics, what are some things you remember
link |
02:53:07.180
that were innovations you had to come up with
link |
02:53:10.460
in order to make it all happen?
link |
02:53:12.380
Yeah, so there were a bunch of things on Quake
link |
02:53:14.860
where on the one hand,
link |
02:53:16.380
the idea that I built my own programming language
link |
02:53:19.260
to implement the game in.
link |
02:53:20.940
Looking back, and I try to tell people,
link |
02:53:22.900
it's like every high level programmer
link |
02:53:25.460
sometime in their career goes through
link |
02:53:26.860
and they invent their own language.
link |
02:53:28.020
It just seems to be a thing that's pretty broadly done.
link |
02:53:30.380
People will be like,
link |
02:53:31.220
I'm gonna go write a computer programming language.
link |
02:53:33.220
And I don't regret having done it,
link |
02:53:37.100
but after that, I switched from Quake C,
link |
02:53:40.100
my quirky little pseudo object oriented
link |
02:53:43.060
or entity oriented language there.
link |
02:53:45.300
Quake two went back to using DLLs with C
link |
02:53:47.900
and then Quake three,
link |
02:53:48.900
I implemented my own C interpreter or compiler,
link |
02:53:51.340
which was a much smarter thing to do
link |
02:53:53.180
that I should have done originally for Quake.
link |
02:53:55.780
But building my own language was an experience.
link |
02:53:57.820
I learned a lot from that.
link |
02:53:59.660
And then there was a generation of game programmers
link |
02:54:02.260
that learned programming with Quake C,
link |
02:54:04.260
which I feel kind of bad about,
link |
02:54:05.660
because we give JavaScript a lot of crap,
link |
02:54:08.660
but Quake C was nothing to write home about there.
link |
02:54:13.060
But it allowed people to do magical things.
link |
02:54:15.700
You get into programming,
link |
02:54:16.780
not because you love the BNF syntax of a language,
link |
02:54:21.300
it's because the language lets you do something
link |
02:54:23.340
that you cared about.
link |
02:54:24.460
And here's very much,
link |
02:54:25.620
you could do something
link |
02:54:26.980
in a whole beautiful three dimensional world.
link |
02:54:29.540
And the idea and the fact that the code
link |
02:54:31.220
for the game was out there,
link |
02:54:32.260
you could say, I liked the shotgun,
link |
02:54:34.500
but I want it to be more bad ass.
link |
02:54:36.060
You go in there and say,
link |
02:54:37.180
okay, now it does 200 points damage.
link |
02:54:39.220
And then you go around with a big grin on your face,
link |
02:54:41.500
blowing up monsters all over the game.
link |
02:54:43.940
So yeah, it is not what I would do today
link |
02:54:48.220
going back with that language,
link |
02:54:49.540
but that was a big part of it.
link |
02:54:51.260
Learning about the networking stuff,
link |
02:54:54.060
because it's interesting where I learned these things
link |
02:54:56.820
by reading books.
link |
02:54:57.660
So I would get a book on networking and find something,
link |
02:55:00.100
I read all about it and learn, okay, packets,
link |
02:55:02.700
they can be out of order or lost or duplicated.
link |
02:55:06.380
These are all the things
link |
02:55:07.220
that can theoretically happen to packets.
link |
02:55:09.300
So I wind up spending all this time thinking about
link |
02:55:11.420
how do we deal about all of that?
link |
02:55:13.100
And it turns out, of course, in the real world,
link |
02:55:15.100
those are things that yes,
link |
02:55:16.020
theoretically can happen with multiple routes,
link |
02:55:18.100
but they really aren't things that your 99.999%
link |
02:55:22.100
of your packets have to deal with.
link |
02:55:25.100
So there was learning experiences about lots of that.
link |
02:55:28.300
Like why, when TCP is appropriate versus UDP
link |
02:55:32.060
and how if you do things in UDP,
link |
02:55:34.140
you wind up reinventing TCP badly in almost all cases.
link |
02:55:37.900
So there's good arguments for using both
link |
02:55:41.540
for different game technology,
link |
02:55:42.780
different parts of the game process,
link |
02:55:44.380
transitioning from level to level and all.
link |
02:55:46.700
But the graphics were the showcase
link |
02:55:49.340
of what Quake was all about.
link |
02:55:51.900
It was this graphics technology that nobody had seen there.
link |
02:55:55.500
And it was a while before
link |
02:55:57.420
there were competitive things out there.
link |
02:55:59.540
And it went a long time internally really not working
link |
02:56:03.580
where we were even building levels
link |
02:56:05.580
where the game just was not at all shippable
link |
02:56:09.620
with large fractions of the world,
link |
02:56:11.220
like disappearing, not being there,
link |
02:56:14.020
or being really slow in various parts of it.
link |
02:56:16.860
And it was this act of faith.
link |
02:56:18.300
It's like, I think I'm gonna be able to fix this.
link |
02:56:20.660
I think I'm gonna be able to make this work.
link |
02:56:23.700
And lots of stuff changed
link |
02:56:25.660
where the level designers would build something
link |
02:56:27.900
and then have to throw it away as something fundamental
link |
02:56:29.980
and the kind of graphics or level technology changed.
link |
02:56:33.780
And so there were two big things
link |
02:56:37.180
that contributed to making it possible at that timeframe.
link |
02:56:41.300
Two new things.
link |
02:56:42.300
There was certainly
link |
02:56:43.660
hardcore optimized low level assembly language.
link |
02:56:46.060
And this was where I had hired Michael Abrash
link |
02:56:48.620
away from Microsoft.
link |
02:56:50.260
And he had been one of my early inspirations
link |
02:56:52.340
where back in the soft disk days,
link |
02:56:54.700
the library of magazines that they had,
link |
02:56:57.300
some of my most treasured ones
link |
02:56:58.820
were Michael Abrash's articles in Dr. Dobbs journal.
link |
02:57:02.380
And it was amazing after all of our success in Doom,
link |
02:57:06.380
we were able to kind of hit him up and say,
link |
02:57:08.020
hey, we'd like you to come work at id Software.
link |
02:57:10.540
And he was in the senior technical role at Microsoft.
link |
02:57:13.140
And he was on track for,
link |
02:57:15.860
and this was right when Microsoft was starting to take off.
link |
02:57:18.260
And I did eventually convince him
link |
02:57:21.620
that what we were doing
link |
02:57:22.740
was gonna be really amazing with Quake.
link |
02:57:24.540
It was gonna be something nobody had seen before.
link |
02:57:28.260
It had these aspects of what we were talking about.
link |
02:57:31.420
We had metaverse talk back then.
link |
02:57:33.580
We had read Snow Crash and we knew about this.
link |
02:57:36.660
And Michael was big into the science fiction
link |
02:57:40.140
and we would talk about all that
link |
02:57:41.420
and kind of spin this tale.
link |
02:57:42.860
And it was some of the same conversations
link |
02:57:45.140
that we have today about the metaverse,
link |
02:57:46.860
about how you could have different areas
link |
02:57:48.900
linked together by portals
link |
02:57:50.300
and you could have user generated content
link |
02:57:52.340
and changing out all of these things.
link |
02:57:54.380
So you really were creating the metaverse with Quake.
link |
02:57:56.900
And we talked about things like,
link |
02:57:58.740
Duke used to be advertised as a virtual reality experience.
link |
02:58:02.780
That was the first wave of virtual reality
link |
02:58:05.220
was in the late 80s and early 90s,
link |
02:58:07.620
you had like the Lawn Mower Man movie
link |
02:58:10.580
and you had time in Newsweek
link |
02:58:12.100
talking about the early VPL headsets.
link |
02:58:14.580
And of course that cratered so hard
link |
02:58:16.780
that people didn't wanna look at virtual reality
link |
02:58:18.660
for decades afterwards,
link |
02:58:20.140
where it was just, it was smoke and mirrors.
link |
02:58:23.220
It was not real in the sense
link |
02:58:24.820
that you could actually do something
link |
02:58:26.700
real and valuable with it.
link |
02:58:28.580
But still we had that kind of common set of talking points.
link |
02:58:32.220
And we were talking about what these games could become
link |
02:58:36.340
and how you'd like to see people
link |
02:58:37.900
building all of these creative things.
link |
02:58:39.580
Because we were seeing an explosion of work
link |
02:58:41.460
with Doom at that time,
link |
02:58:42.620
where people were doing amazingly cool things.
link |
02:58:45.700
Like we saw cooler levels that we had built
link |
02:58:48.100
coming out of the user community.
link |
02:58:49.740
And then people finding ways
link |
02:58:51.420
to change the characters in different ways.
link |
02:58:54.060
And it was great.
link |
02:58:54.900
And we knew what we were doing in Quake
link |
02:58:56.700
was removing those last things.
link |
02:58:58.860
There was some quirky things
link |
02:59:00.380
with a couple of the data types
link |
02:59:01.980
that didn't work right for overriding.
link |
02:59:03.900
And then the core thing about the programming model.
link |
02:59:07.380
And I was definitely going to hit all of those in Quake.
link |
02:59:10.900
But the graphics side of it was still,
link |
02:59:15.540
I knew what I wanted to do.
link |
02:59:17.060
And it was one of these hubris things
link |
02:59:20.460
where it's like, well, so far I've been able
link |
02:59:21.980
to kind of kick everything that I set out to go do.
link |
02:59:26.580
But Quake was definitely a little bit more
link |
02:59:29.380
than could be comfortably chewed at that point.
link |
02:59:32.180
And, but Michael was one of the strongest programmers
link |
02:59:36.860
and graphics programmers that I knew.
link |
02:59:39.140
And he was one of the people that I trusted
link |
02:59:40.860
to write assembly code better than I could.
link |
02:59:44.260
And there's a few people that I can point to
link |
02:59:46.740
about things like this where I'm a world class optimizer.
link |
02:59:49.940
I mean, I make things go fast,
link |
02:59:51.740
but I recognize there's a number of people
link |
02:59:54.660
that can write tighter assembly code,
link |
02:59:56.860
tighter SIMD code or tighter CUDA code
link |
02:59:59.380
than I can write.
link |
03:00:02.140
My best strengths are a little bit more at the system level.
link |
03:00:05.340
I mean, I'm good at all of that,
link |
03:00:07.020
but the most leverage comes from making the decisions
link |
03:00:10.260
that are a little bit higher up
link |
03:00:11.620
where you figure out how to change your large scale problems
link |
03:00:15.220
so that these lower level problems are easier to do
link |
03:00:18.020
or it makes it possible to do them in a uniquely fast way.
link |
03:00:23.380
So most of my big wins in a lot of ways
link |
03:00:27.100
from all the way from the early games through VR
link |
03:00:30.300
and the aerospace work that I'm doing or did,
link |
03:00:33.020
and hopefully the AI work that I'm working on now
link |
03:00:35.420
is finding an angle on something
link |
03:00:37.620
that means you trade off something
link |
03:00:40.340
that you maybe think you need,
link |
03:00:41.540
but it turns out you don't need.
link |
03:00:43.060
And by making a sacrifice in one place,
link |
03:00:45.860
you can get big advantages in another place.
link |
03:00:48.820
Is it clear at which level of the system
link |
03:00:51.660
those big advantages can be gained?
link |
03:00:54.300
It's not always clear.
link |
03:00:55.580
And that's why the thing that I try
link |
03:00:58.300
to make one of my core values,
link |
03:01:00.140
and I proselytize to a lot of people
link |
03:01:02.740
is trying to know the entire stack,
link |
03:01:05.500
trying to see through everything that happens.
link |
03:01:08.140
And it's almost impossible
link |
03:01:09.580
on like the web browser level of things
link |
03:01:11.860
where there's so many levels to it,
link |
03:01:13.460
but you should at least understand what they all are,
link |
03:01:15.820
even if you can't understand
link |
03:01:16.980
all the performance characteristics at each level,
link |
03:01:20.020
but it goes all the way down to literally the hardware.
link |
03:01:22.980
So what is this chip capable of?
link |
03:01:26.540
And what is this software that you're writing capable of?
link |
03:01:29.380
And then with this architecture you put on top of that,
link |
03:01:31.740
then the ecosystem around it,
link |
03:01:33.300
all the people that are working on it.
link |
03:01:35.940
So there are all these decisions
link |
03:01:38.500
and they're never made in a globally optimal way,
link |
03:01:41.220
but sometimes you can drive a thread
link |
03:01:43.420
of global optimality through it.
link |
03:01:45.100
You can't look at everything, it's too complicated,
link |
03:01:47.740
but sometimes you can step back up
link |
03:01:49.700
and make a different decision.
link |
03:01:51.540
And we kind of went through this on the graphic side
link |
03:01:53.460
on Quake, where in some ways it was kind of bad
link |
03:01:56.500
where Michael would spend his time writing,
link |
03:01:59.100
like I'd rough out the basic routines,
link |
03:02:01.660
like, okay, here's our span rasterizer.
link |
03:02:03.940
And he would spend a month writing
link |
03:02:05.980
this beautiful cycle optimized piece of assembly language
link |
03:02:10.540
that does what I asked it to do.
link |
03:02:13.300
And he did it faster than like my original code would do,
link |
03:02:16.100
or probably what I would be able to do
link |
03:02:17.660
even if I had spent that month on it.
link |
03:02:20.420
But then we'd have some cases when I'd be like,
link |
03:02:22.660
okay, well, I figured out at this higher level
link |
03:02:25.460
instead of drawing these in a painter's order here,
link |
03:02:28.100
I do a span buffer and it cuts out 30% or 40%
link |
03:02:32.540
of all of these pixels,
link |
03:02:34.020
but it means you need to rewrite kind of this interface
link |
03:02:36.580
of all of that.
link |
03:02:37.420
And I could tell that wore on him a little bit,
link |
03:02:39.340
but in the end it was the right thing to do
link |
03:02:41.940
where we wound up changing that rasterization approach
link |
03:02:45.100
and we wound up with a super optimized
link |
03:02:47.220
assembly language core loop
link |
03:02:49.740
and then a good system around it
link |
03:02:51.660
which minimized how much that had to be called.
link |
03:02:54.380
And so in order to be able to do
link |
03:02:55.740
this kind of system level thinking,
link |
03:02:58.140
whether we're talking about game development,
link |
03:03:02.420
aerospace, nuclear energy, AI, VR,
link |
03:03:07.420
you have to be able to understand the hardware,
link |
03:03:10.700
the low level software, the high level software,
link |
03:03:14.740
the design decisions, the whole thing,
link |
03:03:16.860
the full stack of it.
link |
03:03:18.180
Yeah, and that's where a lot of these things
link |
03:03:20.480
become possible.
link |
03:03:21.320
When you're really, when you're bringing the future forward,
link |
03:03:23.940
I mean, there's a pace that everything
link |
03:03:25.180
just kind of glides towards
link |
03:03:26.460
where we have a lot of progress
link |
03:03:27.960
that's happening at such a different,
link |
03:03:29.340
so many different ways you kind of slide towards progress
link |
03:03:32.300
just left to your own, programs just get faster.
link |
03:03:34.880
For a while it wasn't clear
link |
03:03:36.120
if they were gonna get fatter more than they get,
link |
03:03:38.420
quicker than they get faster and it cancels out,
link |
03:03:40.740
but it is clear now in retrospect,
link |
03:03:42.400
no, programs just get faster
link |
03:03:44.020
and have gotten faster for a long time.
link |
03:03:46.620
But if you wanna do something
link |
03:03:48.020
like back at that original talking about scrolling games,
link |
03:03:52.060
say what, this needs to be five times faster.
link |
03:03:54.700
Well, we can wait six years
link |
03:03:57.220
and just it'll naturally get that much faster at that time
link |
03:04:00.820
or you come up with some really clever way of doing it.
link |
03:04:03.700
So there are those opportunities like that
link |
03:04:06.140
in a whole bunch of different areas.
link |
03:04:08.100
Now, most programmers don't need to be thinking about that.
link |
03:04:11.780
There's not that many,
link |
03:04:13.440
there's a lot of opportunities for this,
link |
03:04:15.100
but it's not everyone's work a day type stuff.
link |
03:04:17.240
So everyone doesn't have to know how all these things work.
link |
03:04:20.340
They don't have to know how their compiler works,
link |
03:04:22.900
how the processor chip manages cache eviction
link |
03:04:26.180
and all these low level things.
link |
03:04:28.180
But sometimes there are powerful opportunities
link |
03:04:31.720
that you can look at and say,
link |
03:04:33.180
we can bring the future five years faster.
link |
03:04:37.220
We can do something that,
link |
03:04:38.420
wouldn't it be great if we could do this?
link |
03:04:40.300
Well, we can do it today
link |
03:04:42.020
if we make a certain set of decisions.
link |
03:04:44.200
And it is in some ways smoke and mirrors
link |
03:04:47.180
where you say it's like,
link |
03:04:48.460
Doom was a lot of smoke and mirrors
link |
03:04:50.460
where people thought it was more capable
link |
03:04:52.260
than it actually was,
link |
03:04:53.560
but we picked the right smoke and mirrors
link |
03:04:56.020
to deploy in the game where by doing this,
link |
03:04:58.980
people will think that it's more general.
link |
03:05:01.100
We are gonna amaze them with what they've got here
link |
03:05:03.420
and they won't notice
link |
03:05:05.020
that it doesn't do these other things.
link |
03:05:07.660
So smart decision making at that point,
link |
03:05:09.940
that's where that kind of global holistic top down view
link |
03:05:15.740
can work.
link |
03:05:16.560
And I'm really a strong believer
link |
03:05:20.240
that technology should be sitting at that table
link |
03:05:24.020
having those discussions
link |
03:05:25.100
because you do have cases where you say,
link |
03:05:26.700
well, you wanna be the Jonathan Ivy or whatever,
link |
03:05:28.660
where it's a pure design solution.
link |
03:05:32.100
And that's in some cases now
link |
03:05:35.200
where you truly have almost infinite resources.
link |
03:05:37.740
Like if you're trying to do a scrolling game on the PC now,
link |
03:05:41.500
you don't even have to talk to a technology person.
link |
03:05:43.620
You can just have,
link |
03:05:45.460
any intern can make that go run as fast as it needs to there
link |
03:05:48.460
and it can be completely design based.
link |
03:05:50.680
But if you're trying to do something that's hard,
link |
03:05:53.180
either that can't be done for resources
link |
03:05:55.840
like VR on a mobile chip set,
link |
03:05:58.060
or that we don't even know how to do yet,
link |
03:05:59.820
like artificial general intelligence,
link |
03:06:02.020
it's probably going to be a matter
link |
03:06:03.740
of coming at it from an angle.
link |
03:06:05.380
Like, I mean, for AGI,
link |
03:06:06.460
we have some of like what are some of the hudder principles
link |
03:06:09.040
about how you can AXI or some of the,
link |
03:06:11.820
there are theoretical ways that you can say,
link |
03:06:13.380
this is the optimal learning algorithm
link |
03:06:15.220
that can solve everything, but it's completely impractical.
link |
03:06:18.620
You just can't do that.
link |
03:06:20.180
So clearly you have to make some concessions
link |
03:06:23.300
for general intelligence
link |
03:06:25.220
and nobody knows what the right ones are yet.
link |
03:06:27.300
So people are taking different angles of attack.
link |
03:06:29.300
I hope I've got something clever
link |
03:06:31.040
to come up with in that space.
link |
03:06:34.060
It's been surprising to me.
link |
03:06:35.460
And I think perhaps it is a principle of progress
link |
03:06:38.760
that smoke and mirrors somehow
link |
03:06:40.580
is the way you build the future.
link |
03:06:42.820
You kind of fake it till you make it
link |
03:06:46.380
and you almost always make it.
link |
03:06:47.740
And I think that's going to be the way we achieve AGI.
link |
03:06:50.340
That's going to be the way we build consciousness
link |
03:06:53.620
into our machines.
link |
03:06:55.060
There's philosophers debate about the Turing test
link |
03:06:59.860
is essentially about faking it till you make it.
link |
03:07:02.820
You start by faking it.
link |
03:07:04.480
And I think that always leads to making it
link |
03:07:09.060
because if we look at history.
link |
03:07:10.660
Arguments when, as soon as people start talking about
link |
03:07:13.100
qualia and consciousness and Chinese rooms and things,
link |
03:07:16.220
it's like, I just check out.
link |
03:07:17.560
I just don't think there's any value in those conversations.
link |
03:07:20.160
It's just like, go ahead, tell me it's not going to work.
link |
03:07:22.460
I'm going to do my best to try to make it work anyways.
link |
03:07:25.340
I don't know if you work with legged robots.
link |
03:07:26.900
There's a bunch of these.
link |
03:07:29.380
They sure as heck make me feel like they're cautious
link |
03:07:33.880
in a certain way that's not here today,
link |
03:07:37.120
but is you could see the kernel.
link |
03:07:41.220
It's like the flame, the beginnings of a flame.
link |
03:07:45.980
We don't have line of sight,
link |
03:07:47.460
but there's glimmerings of light in the distance
link |
03:07:50.060
for all of these things.
link |
03:07:51.020
Yeah, I'm hearing murmuring in a distant room.
link |
03:07:54.900
Well, let me ask you a human question here.
link |
03:07:56.780
You've in the game design space,
link |
03:08:00.100
you've done a lot of incredible work throughout,
link |
03:08:01.900
but in terms of game design, you have changed the world.
link |
03:08:05.800
And there's a few people around you that did the same.
link |
03:08:08.440
So famously there's some animosity, there's much love,
link |
03:08:13.020
but there's some animosity between you and John Romero.
link |
03:08:16.340
What is at the core of that animosity and human tension?
link |
03:08:19.940
So there really hasn't been for a long time.
link |
03:08:24.100
And even at the beginning, it's like,
link |
03:08:25.520
yes, I did push Romero out of the company.
link |
03:08:29.500
And this is one of the things that I look back,
link |
03:08:32.140
if I could go back telling my younger self
link |
03:08:35.980
some advice about things,
link |
03:08:37.840
the original founding kind of corporate structure
link |
03:08:41.900
of id Software really led to a bunch of problems.
link |
03:08:45.700
We started off with us as equal partners
link |
03:08:48.540
and we had a buy sell agreement
link |
03:08:50.420
because we didn't want outsiders
link |
03:08:51.820
to be telling us what to do inside the company.
link |
03:08:54.400
And that did lead to a bunch of the problems
link |
03:08:57.260
where I was sitting here going,
link |
03:08:59.580
it's like, all right, I'm working harder than anyone.
link |
03:09:02.920
I'm doing these technologies, nobody's done before,
link |
03:09:06.300
but we're all equal partners.
link |
03:09:08.100
And then I see somebody that's not working as hard.
link |
03:09:11.500
And I mean, I can't say I was the most mature about that.
link |
03:09:16.160
I was 20 something years old
link |
03:09:18.020
and it did bother me when I'm like, everybody,
link |
03:09:22.460
okay, we need to all pull together
link |
03:09:23.980
and we've done it before everybody.
link |
03:09:25.540
We know we can do this if we get together
link |
03:09:27.700
and we grind it all out,
link |
03:09:29.420
but not everybody wanted to do that for all time.
link |
03:09:33.540
And I was the youngest one of the crowd there.
link |
03:09:35.740
I had different sets of kind of backgrounds and motivations
link |
03:09:40.480
and left at that point where it was, all right,
link |
03:09:44.900
either everybody has to be contributing like up to this level
link |
03:09:48.500
or they need to get pushed out was not,
link |
03:09:52.380
that was not a great situation.
link |
03:09:54.140
And I look back on it and know that we pushed people
link |
03:09:57.620
out of the company that could have contributed
link |
03:10:00.300
if there was a different framework for them.
link |
03:10:02.860
And the modern kind of Silicon Valley,
link |
03:10:04.680
like let your stock vest over a time period
link |
03:10:07.040
and maybe it's non voting stock
link |
03:10:08.800
and all those different things.
link |
03:10:09.820
We knew nothing about any of that.
link |
03:10:11.420
I mean, we didn't know what we were doing
link |
03:10:13.860
in terms of corporate structure or anything.
link |
03:10:16.460
So if you think the framework was different,
link |
03:10:18.460
some of the human tension could have been a little bit.
link |
03:10:20.660
It almost certainly would have.
link |
03:10:22.900
I mean, I look back at that
link |
03:10:24.220
and it's like even trying to summon up in my mind,
link |
03:10:27.740
it's like, I know I was really, really angry about,
link |
03:10:32.620
like Romero not working as hard as I wanted him to work
link |
03:10:35.580
or not carrying his load on the design for Quake
link |
03:10:39.060
and coming up with things there.
link |
03:10:40.940
But he was definitely doing things.
link |
03:10:43.100
He made some of the best levels there.
link |
03:10:44.900
He was working with some of our external teams
link |
03:10:47.740
like Raven on the licensing side of things,
link |
03:10:50.660
but there were differences of opinion about it,
link |
03:10:55.460
but he landed right on his feet.
link |
03:10:57.260
He went and he got $20 million from Eidos
link |
03:10:59.660
to go do Ion Storm and he got to do things his way
link |
03:11:02.980
and spun up three teams simultaneously
link |
03:11:05.700
because that was always one of the challenging things
link |
03:11:08.180
in it where we were doing these single string,
link |
03:11:11.000
one project after another.
link |
03:11:13.140
And I think some of them wanted to grow the company more
link |
03:11:16.380
and I didn't because I knew people that were saying that,
link |
03:11:19.240
oh, companies turn to shit when you got 50 employees.
link |
03:11:22.260
It's just a different world there.
link |
03:11:24.060
And I loved our little dozen people working on the projects,
link |
03:11:28.460
but you can look at it and say,
link |
03:11:29.940
well, business realities matter.
link |
03:11:31.780
It's like, you're super successful here
link |
03:11:33.540
and we could take a swing and a miss on something,
link |
03:11:36.340
but you do it a couple of times and you're out of luck.
link |
03:11:39.320
There's a reason companies try to have multiple teams
link |
03:11:43.060
running at one time.
link |
03:11:45.660
And so that was, again,
link |
03:11:47.060
something I didn't really appreciate back then.
link |
03:11:49.620
So if you look past all that,
link |
03:11:51.020
you did create some amazing things together.
link |
03:11:53.740
What did you love about John Romero?
link |
03:11:55.740
What did you respect and appreciate about him?
link |
03:11:57.700
What did you admire about him?
link |
03:11:59.100
What did you learn from him?
link |
03:12:00.980
When I met him, he was the coolest programmer
link |
03:12:02.460
I had ever met.
link |
03:12:04.020
He had done all of this stuff.
link |
03:12:05.580
He had made all of these games.
link |
03:12:07.580
He had worked at one of the companies
link |
03:12:10.060
that I thought was the coolest at Origin Systems.
link |
03:12:12.740
And he knew all this stuff.
link |
03:12:14.580
He made things happen fast.
link |
03:12:16.220
And he was also kind of a polymath about this
link |
03:12:18.900
where he could do, he drew his own art.
link |
03:12:21.580
He made his own levels,
link |
03:12:22.780
as well as we worked on sound design systems
link |
03:12:26.220
on top of actually being a really good programmer.
link |
03:12:29.280
And we went through a little,
link |
03:12:32.020
it was kind of fun where one of the early things
link |
03:12:34.120
that we did where there was kind of the young buck bit
link |
03:12:36.520
going in where I was the new guy.
link |
03:12:39.140
And he was the top man programmer at the soft disk area.
link |
03:12:44.500
And eventually we had sort of a challenge over the weekend
link |
03:12:47.100
that we were gonna like race to implement this game,
link |
03:12:49.640
to port one of our PC games back down to the Apple II.
link |
03:12:52.780
And that was where we finally kind of became clear.
link |
03:12:55.180
It's like, okay, Carmack stands a little bit apart
link |
03:12:57.700
on the programming side of things.
link |
03:13:00.260
But Romero then very gracefully moved into,
link |
03:13:03.060
well, he'll work on the tools, he'll work on the systems,
link |
03:13:06.100
do some of the game design stuff,
link |
03:13:07.620
as well as contributing on,
link |
03:13:09.740
starting to lead the design aspects of a lot of things.
link |
03:13:12.880
So he was enormously valuable in the early stuff.
link |
03:13:16.940
And so much of Doom and even Quake have his stamp on it
link |
03:13:20.540
in a lot of ways.
link |
03:13:21.900
But he wasn't at the same level of focus
link |
03:13:25.640
that I brought to the work that we were doing there.
link |
03:13:29.160
And he really did, we hit such a degree of success
link |
03:13:33.540
that it was all in the press about that.
link |
03:13:35.980
The rockstar game programmers.
link |
03:13:38.540
I mean, it's the Beatles problem.
link |
03:13:40.060
Yeah, I mean, he ate it up and he did personify.
link |
03:13:43.340
There was the whole game developers with Ferraris
link |
03:13:46.660
that we had there.
link |
03:13:49.020
And I thought that led to some challenges there.
link |
03:13:53.520
But so much of the stuff that was great in the games
link |
03:13:58.100
did come from him.
link |
03:13:59.260
And I would certainly not take that away from him.
link |
03:14:01.940
And even after we parted ways and he took his swing
link |
03:14:05.500
with Eidos, in some ways, he was ahead of the curve
link |
03:14:09.260
with mobile gaming as well, where
link |
03:14:11.820
one of his companies after Eidos was working on feature phone
link |
03:14:15.540
game development.
link |
03:14:16.740
And I wound up doing some of that
link |
03:14:19.300
just before the iPhone crossing over into the iPhone phase
link |
03:14:22.300
there.
link |
03:14:23.020
And that was something that clearly
link |
03:14:24.900
did turn out to be a huge thing, although he
link |
03:14:27.700
was too early for what he was working on at that time.
link |
03:14:31.660
We've had pretty cordial relationships
link |
03:14:34.060
where I was happy to talk with him any time I'd
link |
03:14:35.980
run into him at a conference.
link |
03:14:38.180
I have actually had some other people just say,
link |
03:14:40.580
it's like, oh, you shouldn't go over there
link |
03:14:42.940
and give him the time of day.
link |
03:14:44.380
Or felt that Masters of Doom played things up in a way
link |
03:14:50.940
that I shouldn't be too happy with.
link |
03:14:52.500
But I'm OK with all of that.
link |
03:14:54.740
So you've still got love in your heart.
link |
03:14:56.700
Yeah, I mean, I just talked with him like last year,
link |
03:14:59.700
or I guess it was even this year,
link |
03:15:01.060
about mentioning that I'm going off doing this AI stuff.
link |
03:15:03.820
I'm going big into artificial intelligence.
link |
03:15:06.580
And he had a bunch of ideas for how
link |
03:15:09.260
AI is going to play into gaming.
link |
03:15:10.940
And asked if I was interested in collaborating.
link |
03:15:13.460
And it's not in line with what I'm doing.
link |
03:15:16.300
But I do wish almost everyone the best.
link |
03:15:19.620
I mean, I know I may not have partnered
link |
03:15:21.660
on the best of terms with some people.
link |
03:15:24.460
But I was thrilled to see Tom Hall writing VR games now.
link |
03:15:29.100
He wrote, I'm working on a game called Demio, which
link |
03:15:31.540
is really an awesome VR game.
link |
03:15:33.780
It's like Dungeons and Dragons.
link |
03:15:35.020
We all used to play Dungeons and Dragons together.
link |
03:15:36.820
That was one of the things.
link |
03:15:37.900
That was what we did on Sundays in the early days.
link |
03:15:40.340
I would Dungeon Master, and they'd all play.
link |
03:15:42.220
And so it really made me smile seeing
link |
03:15:44.980
Tom involved with an RPG game in virtual reality.
link |
03:15:49.740
You were the CTO of Oculus VR since 2013,
link |
03:15:54.620
and maybe less than a year involved in a bit in 2019.
link |
03:16:00.420
Oculus was acquired by Facebook Now Meta in 2014.
link |
03:16:04.900
You've spoken brilliantly about both the low level details,
link |
03:16:07.780
the experimental design, and the big picture
link |
03:16:09.780
vision of virtual reality.
link |
03:16:12.020
Let me ask you about the metaverse, the big question
link |
03:16:14.980
here, both philosophically and technically.
link |
03:16:18.020
How hard is it to build the metaverse?
link |
03:16:20.180
What is the metaverse in your view?
link |
03:16:22.700
You started with discussing and thinking about Quake
link |
03:16:24.980
as a kind of a metaverse.
link |
03:16:27.260
As you think about it today, what is the metaverse,
link |
03:16:31.340
the thing that could create this compelling user value,
link |
03:16:34.420
this experience that will change the world,
link |
03:16:36.860
and how hard is it to build it?
link |
03:16:39.020
So the term comes from Neal Stephenson's book Snow Crash,
link |
03:16:42.020
which many of us had read back in the 90s.
link |
03:16:44.700
It was one of those kind of formative books.
link |
03:16:47.500
And there was this sense that the possibilities
link |
03:16:53.100
and kind of the freedom and unlimited capabilities
link |
03:16:56.100
to build a virtual world that does whatever you want,
link |
03:16:59.540
whatever you ask of it, has been a powerful draw
link |
03:17:02.260
for generations of developers, game developers specifically,
link |
03:17:05.620
and people that are thinking about more general purpose
link |
03:17:08.900
applications.
link |
03:17:10.300
So we were talking about that back in the Doom and Quake days
link |
03:17:13.660
about how do you wind up with an interconnected set of worlds
link |
03:17:17.140
that you kind of visit from one to another.
link |
03:17:19.180
And as web pages were becoming a thing,
link |
03:17:21.540
you start thinking about what is the interactive kind
link |
03:17:25.260
of 3D based equivalent of this.
link |
03:17:27.540
And there were a lot of really bad takes.
link |
03:17:29.780
You had like Vermol and virtual reality markup languages.
link |
03:17:34.220
And there's aspects like that that came from people saying,
link |
03:17:38.300
well, what kind of capabilities should we
link |
03:17:40.780
develop to enable this?
link |
03:17:43.580
And that kind of capability first work
link |
03:17:45.620
has usually not panned out very well.
link |
03:17:48.940
On the other hand, we have successful games
link |
03:17:51.540
that started with things like Doom and Quake and communities
link |
03:17:54.340
that formed around those, whether it
link |
03:17:56.820
was server lists in the early days
link |
03:17:58.700
or literal portaling between different games,
link |
03:18:01.580
and then modern things that are on completely different order
link |
03:18:04.780
of magnitude like Minecraft and Fortnite that
link |
03:18:07.380
have 100 million plus users.
link |
03:18:11.820
I still think that that's the right way
link |
03:18:13.700
to go to build the metaverse is you build something that's
link |
03:18:16.900
amazing that people love and people wind up
link |
03:18:18.980
spending all their time in because it's awesome.
link |
03:18:21.940
And you expand the capabilities of that.
link |
03:18:24.420
So even if it's a very basic experience, if it's awesome.
link |
03:18:28.420
Minecraft is an amazing case study in so many things.
link |
03:18:31.660
That's basic as it gets.
link |
03:18:32.660
What's been able to be done with that is really enlightening.
link |
03:18:36.860
And there are other cases where, like right now,
link |
03:18:39.700
Roblox is basically a game construction kit aimed at kids.
link |
03:18:43.260
And that was a capability first play.
link |
03:18:45.020
And it's achieving scale that's on the same order
link |
03:18:48.060
of those things.
link |
03:18:49.060
So it's not impossible, but my preferred bet
link |
03:18:52.580
would be you make something amazing that people love
link |
03:18:55.180
and you make it better and better.
link |
03:18:56.820
And that's where I could say we could have gone back
link |
03:18:59.620
and followed a path like that in the early days
link |
03:19:02.780
if you just take the same game, whether it's
link |
03:19:05.580
when Activision demonstrated that you could make
link |
03:19:07.620
Call of Duty every year.
link |
03:19:09.140
And not only is it not bad, people love it.
link |
03:19:12.140
And it's very profitable.
link |
03:19:14.460
The idea that you could have taken something like that,
link |
03:19:17.340
take a great game, release a new version every year
link |
03:19:20.220
that lets the capabilities grow and expand
link |
03:19:23.020
to start saying it's like, OK, it's
link |
03:19:24.660
a game about running around and shooting things,
link |
03:19:26.780
but now you can bring your media into it.
link |
03:19:30.260
You can add persistence of social signs of life
link |
03:19:35.020
or whatever you want to add to it.
link |
03:19:37.820
I still think that's quite a good position to take.
link |
03:19:41.860
And I think that while Meta is doing a bottoms up capability
link |
03:19:45.940
approach with Horizon Worlds where it's
link |
03:19:48.740
a fairly general purpose, creators
link |
03:19:51.180
can build whatever they want in their sort of thing,
link |
03:19:55.180
it's hard to compare and compete with something
link |
03:19:57.980
like Fortnite, which also has enormous amounts of creativity
link |
03:20:01.660
even though it was not designed originally
link |
03:20:03.660
as a general purpose sort of thing.
link |
03:20:05.740
So we have examples on both sides.
link |
03:20:08.500
Me personally, I would have bet on trying
link |
03:20:11.940
to do entertainment, valuable destination first,
link |
03:20:15.180
and expanding from there.
link |
03:20:16.980
So can you imagine the thing that will be kind of,
link |
03:20:22.180
if we look back a couple of centuries from now
link |
03:20:25.300
and you think about the experiences that
link |
03:20:29.180
marked the singularity, the transition where most
link |
03:20:34.500
of our world moved into virtual reality,
link |
03:20:37.660
what do you think those experiences will look like?
link |
03:20:40.580
So I do think it's going to be kind of like the way the web
link |
03:20:43.620
slowly took over, where you're the frog
link |
03:20:46.620
in the pot of water that's slowly heating up,
link |
03:20:48.860
where having lived through all of that,
link |
03:20:51.420
I remember when it was shocking to start
link |
03:20:53.660
seeing the first website address on a billboard when you're
link |
03:20:57.260
like, hey, my computer world is infecting the real world.
link |
03:21:00.700
This is spreading out in some way.
link |
03:21:03.100
But when you look back and say, well,
link |
03:21:05.620
what made the web take off?
link |
03:21:08.260
And it wasn't a big bang sort of moment there.
link |
03:21:12.020
It was a bunch of little things that turned out
link |
03:21:14.540
not to even be the things that are relevant now
link |
03:21:17.220
that brought them into it.
link |
03:21:18.740
So I wonder if, I mean, like you said, you're not a historian.
link |
03:21:23.140
So maybe there is a historian out there
link |
03:21:26.580
that could really identify that moment, data driven way.
link |
03:21:30.660
It could be like MySpace or something like that.
link |
03:21:33.580
Maybe the first major social network that really reached
link |
03:21:37.340
into non geek world or something like that.
link |
03:21:42.180
I think that's kind of the fallacy of historians, though,
link |
03:21:45.100
looking for some of those kind of primary dominant causes
link |
03:21:48.660
where so many of these things are like we
link |
03:21:51.620
see an exponential curve.
link |
03:21:52.980
But it's not because like one thing is going exponential.
link |
03:21:55.900
It's because we have hundreds of little sigmoid curves
link |
03:21:59.100
overlapped on top of each other.
link |
03:22:00.780
And they just happen to keep adding up
link |
03:22:02.460
so that you've got something kind of going exponential
link |
03:22:05.540
at any given point.
link |
03:22:06.420
But no single one of them was the critical thing.
link |
03:22:09.300
There were dozens and dozens of things.
link |
03:22:11.700
I mean, seeing the transitions of stuff
link |
03:22:13.420
like as obviously MySpace giving way to other things,
link |
03:22:16.580
but even like blogging giving way to social media
link |
03:22:20.180
and getting resurrected in other guises.
link |
03:22:22.860
And the memes with the dancing baby GIF
link |
03:22:26.060
or whatever the all your base now belong to us.
link |
03:22:29.140
Whatever those early memes that led to the modern memes
link |
03:22:32.300
and the different evolution of humor on the internet
link |
03:22:37.260
that I'm sure the historians will also write books about
link |
03:22:40.700
from the different website that support
link |
03:22:42.620
to create the infrastructure for that humor like Reddit
link |
03:22:45.100
and all that kind of stuff.
link |
03:22:46.860
So people will go back, and they will name
link |
03:22:48.820
firsts and critical moments.
link |
03:22:50.340
But it's probably going to be a poor approximation of what
link |
03:22:53.420
actually happens.
link |
03:22:54.900
And we've already seen in the VR space
link |
03:22:57.500
where it didn't play out the way we thought it would in terms
link |
03:23:01.380
of what was going to be like when the modern era of VR
link |
03:23:04.620
basically started with my E3 demo of Doom 3
link |
03:23:07.260
on the Rift prototype.
link |
03:23:08.460
So we're like first person shooters in VR,
link |
03:23:10.980
match made in heaven, right?
link |
03:23:12.860
And that didn't work out that way at all.
link |
03:23:15.500
They have the most comfort problems with it.
link |
03:23:18.420
And then the most popular virtual reality app
link |
03:23:21.220
is Beat Saber, which nobody predicted back then.
link |
03:23:24.820
What's that make you like from first principles
link |
03:23:28.740
if you were to reverse engineer that?
link |
03:23:31.300
Why are these silly fun games the most?
link |
03:23:35.340
It actually makes very clear sense
link |
03:23:37.340
when you analyze it from hindsight
link |
03:23:40.420
and look at the engineering reasons
link |
03:23:41.900
where it's not just that it was a magical quirky idea.
link |
03:23:45.380
It was something that played almost perfectly
link |
03:23:47.820
to what turned out to be the real strengths of VR
link |
03:23:50.460
where the one thing that I really underestimated
link |
03:23:52.940
importance in VR was the importance of the controllers.
link |
03:23:55.940
I was still thinking we could do a lot more
link |
03:23:57.700
with the game pad and just the amazingness
link |
03:24:00.500
of taking any existing game,
link |
03:24:01.940
being able to move your head around and look around,
link |
03:24:04.300
that that was really amazing.
link |
03:24:06.180
But the controllers were super important.
link |
03:24:09.020
But the problem is so many things
link |
03:24:10.420
that you do with the controllers just suck.
link |
03:24:13.420
It feels like it breaks the illusion
link |
03:24:14.700
like trying to pick up glasses with the controllers
link |
03:24:16.900
where you're like, oh, use the grip button
link |
03:24:18.540
when you're kind of close and it'll snap into your hand.
link |
03:24:21.420
All of those things are unnatural actions
link |
03:24:24.540
that you do them and it's still part of the VR experience.
link |
03:24:27.660
But Beat Saber winds up playing only to the strengths.
link |
03:24:32.460
It completely hides all the weaknesses of it
link |
03:24:34.620
because you are holding something in your hand.
link |
03:24:37.100
You keep a solid grip on it the whole time.
link |
03:24:39.340
It slices through things without ever bumping into things.
link |
03:24:42.300
You never get into the point where,
link |
03:24:44.420
I'm knocking on this table,
link |
03:24:45.660
but in VR, my hand just goes right through it.
link |
03:24:48.060
So you've got something that slices through.
link |
03:24:51.060
So it's never your brain telling you,
link |
03:24:53.100
oh, I should have hit something.
link |
03:24:54.540
You've got a lightsaber here.
link |
03:24:55.780
It's just, you expect it to slice through everything.
link |
03:24:58.980
Audio and music turned out to be a really powerful aspect
link |
03:25:02.460
of virtual reality where you're blocking the world off
link |
03:25:05.180
and constructing the world around you.
link |
03:25:07.580
And being something that can run efficiently
link |
03:25:10.900
on even this relatively low powered hardware
link |
03:25:13.700
and can have a valuable loop in a small amount of time
link |
03:25:17.660
where a lot of modern games,
link |
03:25:19.500
you're supposed to sit down and play it for an hour
link |
03:25:21.460
just to get anywhere.
link |
03:25:22.300
Sometimes a new game takes an hour
link |
03:25:23.660
to get through the tutorial level.
link |
03:25:25.340
And that's not good for VR for a couple reasons.
link |
03:25:27.860
You do still have the comfort issues
link |
03:25:29.700
if you're moving around at all,
link |
03:25:31.460
but you've also got just discomfort from the headset,
link |
03:25:34.780
battery lifespan on the mobile versions.
link |
03:25:37.500
So having things that do break down
link |
03:25:39.140
into three and four minute windows of play,
link |
03:25:42.140
that turns out to be very valuable
link |
03:25:43.780
from a gameplay standpoint.
link |
03:25:45.780
So it winds up being kind of a perfect storm
link |
03:25:48.180
of all of these things that are really good.
link |
03:25:50.060
It doesn't have any of the comfort problems.
link |
03:25:52.060
You're not navigating around.
link |
03:25:53.380
You're standing still.
link |
03:25:54.620
All the stuff flies at you.
link |
03:25:56.580
It has placed audio strengths.
link |
03:25:59.380
It adds the whole fitness in VR.
link |
03:26:01.580
Nobody was thinking about that back at the beginning.
link |
03:26:04.460
And it turns out that that is an excellent
link |
03:26:07.420
daily fitness thing to be doing.
link |
03:26:09.060
If you go play an hour of Beat Saber
link |
03:26:11.860
or Supernatural or something,
link |
03:26:13.500
that is legit solid exercise.
link |
03:26:16.420
And it's more fun than doing it
link |
03:26:17.980
just about any other way there.
link |
03:26:19.900
So that's kind of the arcade stage of things.
link |
03:26:23.460
If I were to say with my experience with VR,
link |
03:26:27.140
the thing that I think is powerful is the,
link |
03:26:30.620
maybe it's not here yet,
link |
03:26:32.580
but the degree to which it is immersive
link |
03:26:35.100
in the way that Quake is immersive.
link |
03:26:38.380
It takes you to another world.
link |
03:26:40.260
For me, because I'm a fan of role playing games,
link |
03:26:44.340
the Elder Scrolls series,
link |
03:26:47.140
like Skyrim or even Daggerfall,
link |
03:26:50.180
it just takes you to another world.
link |
03:26:52.540
And when you're not in that world,
link |
03:26:53.940
you miss not being there.
link |
03:26:55.860
And then you just, you kind of want to stay there forever
link |
03:26:58.820
because life is shitty.
link |
03:27:00.940
And you just want to go to this place.
link |
03:27:04.300
Is that there was a time when we were kind of asked
link |
03:27:09.340
to come up with like, what's your view about VR?
link |
03:27:12.060
And my pitch was that it should be better
link |
03:27:15.620
inside the headset than outside.
link |
03:27:17.220
It's the world as you want it.
link |
03:27:19.460
And everybody thought that was dystopian.
link |
03:27:21.660
And like, that's like, oh,
link |
03:27:23.300
you're just going to forget about the world outside.
link |
03:27:25.580
And I don't get that mindset where the idea
link |
03:27:29.700
that if you can make the world better inside the headset
link |
03:27:32.860
than outside, you've just improved the person's life
link |
03:27:36.220
that has a headset that can wear it.
link |
03:27:38.500
And there are plenty of things that we just can't do
link |
03:27:41.300
for everyone in the real world.
link |
03:27:42.380
Everybody can't have Richard Branson's Private Island,
link |
03:27:44.900
but everyone can have a private VR Island
link |
03:27:47.180
and it can have the things that they want on it.
link |
03:27:49.100
And there's a lot of these kind of rivalrous goods
link |
03:27:51.620
in the real world that VR can just be better at.
link |
03:27:55.580
We can do a lot of things like that
link |
03:27:57.740
that can be very, very rich.
link |
03:27:59.620
So yeah, I want the,
link |
03:28:01.020
I think it's going to be a positive thing,
link |
03:28:02.380
this world where people want to go back into their headset,
link |
03:28:05.420
where it can be better than somebody that's living
link |
03:28:07.980
in a tiny apartment can have a palatial estate
link |
03:28:10.860
in virtual reality.
link |
03:28:11.980
They can have all their friends from all over the world
link |
03:28:13.940
come over and visit them without everybody getting
link |
03:28:16.620
on a plane and meeting in some place
link |
03:28:19.300
and dealing with all the other logistics hassles.
link |
03:28:21.620
There is real value in the presence that you can get
link |
03:28:25.460
for remote meetings.
link |
03:28:26.540
It's all the little things that we need to sort out,
link |
03:28:30.100
but those are things that we have line of sight on.
link |
03:28:32.860
People that have been in like a good VR meeting
link |
03:28:35.980
using work rooms where you can say,
link |
03:28:38.180
oh, that was better than a Zoom meeting.
link |
03:28:40.380
But of course it's more of a hassle to get into it.
link |
03:28:42.900
Not everyone has the headset.
link |
03:28:44.380
Interoperability is worse.
link |
03:28:46.260
You can't have, you cap out at a certain number.
link |
03:28:48.620
There's all these things that need to be fixed,
link |
03:28:50.620
but that's one of those things you can look at and say,
link |
03:28:52.340
we know there's value there.
link |
03:28:54.220
We just need to really grind hard,
link |
03:28:56.300
file off all the rough edges and make that possible.
link |
03:28:59.460
So you do think we have line of sight
link |
03:29:02.020
because there's a reason like,
link |
03:29:06.980
I do this podcast in person, for example.
link |
03:29:09.500
So doing it remotely, it's not the same.
link |
03:29:14.060
And if somebody were to ask me why it's not the same,
link |
03:29:16.940
I wouldn't be able to write down exactly why.
link |
03:29:20.540
But you're saying that it's possible,
link |
03:29:23.380
whatever the magic is for in person interaction,
link |
03:29:26.980
that immersiveness of the experience,
link |
03:29:30.500
we are almost there.
link |
03:29:32.180
Yes, so the idea of like,
link |
03:29:34.380
I'm doing a VR interview with someone.
link |
03:29:37.700
I'm not saying it's here right now,
link |
03:29:39.580
but you can see glimmers of what it should be.
link |
03:29:42.620
And we largely know what would need to be fixed
link |
03:29:46.020
and improved to, like you say,
link |
03:29:48.020
there's a difference between at remote interview
link |
03:29:50.580
doing a podcast over Zoom or something and face to face.
link |
03:29:53.900
There's that sense of presence, that immediacy,
link |
03:29:56.460
the super low latency responsiveness,
link |
03:29:59.060
being able to see all the subtle things there,
link |
03:30:01.420
just occupying the same field of view.
link |
03:30:03.700
And all of those are things
link |
03:30:04.860
that we absolutely can do in VR.
link |
03:30:07.740
And that simple case of a small meeting
link |
03:30:10.460
with a couple of people, that's the much easier case
link |
03:30:13.020
than everybody thinks the Ready Player One multiverse
link |
03:30:15.260
with a thousand people going across a huge bridge
link |
03:30:18.420
to amazing places,
link |
03:30:20.020
that's harder in a lot of other technical ways.
link |
03:30:22.420
Not to say we can't also do that,
link |
03:30:24.100
but that's further away and has more challenges.
link |
03:30:26.540
But this small thing about being able to have a meeting
link |
03:30:29.620
with one or a few people and have it feel real,
link |
03:30:33.820
feel like you're there,
link |
03:30:35.500
like you have the same interactions and talking with them,
link |
03:30:37.900
you get subtle cues as we start getting eye
link |
03:30:40.420
and face tracking and some of the other things
link |
03:30:42.260
on high end headsets.
link |
03:30:43.900
A lot of that is going to come over
link |
03:30:46.340
and it doesn't have to be as good.
link |
03:30:49.100
This is an important thing that people miss
link |
03:30:51.060
where there was a lot of people that,
link |
03:30:54.060
especially rich people that would look at VR and say,
link |
03:30:57.140
it's like, oh, this just isn't that good.
link |
03:30:59.780
And I'd say, it's like, well,
link |
03:31:00.980
you've already been courtside backstage and on pit row
link |
03:31:05.100
and you've done all of these experiences
link |
03:31:06.980
because you get to do them in real life.
link |
03:31:08.740
But most people don't get to.
link |
03:31:10.660
And even if the experience is only half as good,
link |
03:31:13.380
if it's something that they never would have gotten
link |
03:31:15.020
to do before, it's still a very good thing.
link |
03:31:17.780
And as we can just, we can push that number up over time.
link |
03:31:20.900
It has a minimum viable value level
link |
03:31:24.140
when it does something that is valuable enough to people,
link |
03:31:27.220
as long as it's better inside the headset on any metric
link |
03:31:29.980
than it is outside and people choose to go there,
link |
03:31:32.620
we're on the right path.
link |
03:31:33.980
And we have a value gradient
link |
03:31:35.580
that I'm just always hammering on.
link |
03:31:37.100
We can just follow this value gradient,
link |
03:31:39.060
just keep making things better
link |
03:31:41.020
rather than going for that one, close your eyes,
link |
03:31:44.540
swing for the fences, kind of silver bullet approach.
link |
03:31:48.740
Well, I wonder if there's a value gradient
link |
03:31:50.500
for in person meetings, because if you get that right,
link |
03:31:53.460
I mean, that would change the world.
link |
03:31:54.940
Yeah. That it doesn't need to,
link |
03:31:57.020
I mean, you don't need a ready player one.
link |
03:31:59.380
But I wonder if there's that value gradient
link |
03:32:02.780
you can follow along, because if there is and you follow it,
link |
03:32:08.020
then there'll be a certain like phase shift
link |
03:32:11.500
at a certain point where people will shift
link |
03:32:14.660
from Zoom to this.
link |
03:32:18.620
I wonder, what are the bottlenecks?
link |
03:32:23.220
Is it software, is it hardware?
link |
03:32:25.380
Is it like, is it all about latency?
link |
03:32:27.780
So I have big arguments internally
link |
03:32:30.460
about strategic things like that,
link |
03:32:32.740
where like the next headset that's coming out
link |
03:32:36.700
that we've made various announcements about
link |
03:32:38.980
is gonna be a higher end headset,
link |
03:32:40.460
more expensive, more features.
link |
03:32:41.980
Lots of people wanna make those trade offs.
link |
03:32:45.500
We'll see what the market has to say
link |
03:32:47.180
about the exact trade offs we've made here.
link |
03:32:49.740
But if you wanna replace Zoom,
link |
03:32:51.420
you need to have something that everybody has.
link |
03:32:55.180
So you like cheaper.
link |
03:32:56.420
I like cheaper because also lighter and cheaper
link |
03:33:00.140
wind up being a virtuous cycle there
link |
03:33:03.300
where expensive and more features
link |
03:33:05.540
tends to also lead towards heavier.
link |
03:33:07.220
And it just kind of goes, it's like, let's add more features.
link |
03:33:09.620
The features are not, they have physical presence
link |
03:33:13.340
and weight and draw from batteries and all of those things.
link |
03:33:16.100
So I've always favored a lower end, cheaper, faster approach.
link |
03:33:21.340
That's why I was always behind the mobile side of VR
link |
03:33:24.340
rather than the higher end PC headsets.
link |
03:33:26.700
And I think that's proven out well.
link |
03:33:29.460
But there's, ideally we have a whole range of things,
link |
03:33:32.900
but if you've only got one or two things,
link |
03:33:35.380
it's important that those two things cover
link |
03:33:37.220
the scope that you think is most important.
link |
03:33:40.580
When we're in a world when it's like cell phones
link |
03:33:42.500
and there's 50 of them on the market
link |
03:33:44.020
covering every conceivable ecological niche you want,
link |
03:33:46.980
that's gonna be great,
link |
03:33:47.940
but we're not gonna be there for a while.
link |
03:33:49.940
Where are the bottlenecks?
link |
03:33:51.580
Is it the hardware or the software?
link |
03:33:53.380
Yeah, so right now you can play,
link |
03:33:56.300
you can get work rooms on Quest
link |
03:33:58.900
and you can set up these things
link |
03:34:00.340
and it's a pretty good experience.
link |
03:34:01.700
It's surprisingly good.
link |
03:34:02.700
I haven't tried it.
link |
03:34:03.740
It's surprisingly good.
link |
03:34:05.060
Yeah, the voice latency is better on that
link |
03:34:08.100
than a lot better than a Zoom meeting.
link |
03:34:10.140
So you've got a more, a better sense of immediacy there.
link |
03:34:13.580
The expressions that you get from the current hardware
link |
03:34:17.100
with just kind of your controllers and your head
link |
03:34:20.060
is pretty realistic feeling.
link |
03:34:21.580
You've got a pretty good sense of being there
link |
03:34:23.300
with someone with it.
link |
03:34:24.140
Are these like avatars of people?
link |
03:34:27.500
Yeah.
link |
03:34:28.340
Do you get to see their body?
link |
03:34:29.900
Yeah.
link |
03:34:30.940
And they're sitting around a table?
link |
03:34:32.420
Yeah.
link |
03:34:33.300
And it feels better than Zoom?
link |
03:34:35.660
It feels better than you, yeah,
link |
03:34:36.500
better than you'd expect for that.
link |
03:34:37.780
It is definitely, yeah, I'd say it's quite a bit better
link |
03:34:42.180
than Zoom when everything's working right,
link |
03:34:43.860
but there's still all the rough edges of,
link |
03:34:46.420
the reason Zoom became so successful
link |
03:34:48.220
is because they just nailed the usability of everything.
link |
03:34:51.020
It's high quality with a absolutely first rate experience.
link |
03:34:54.940
And we are not there yet with any of the VR stuff.
link |
03:34:58.020
I'm trying to push hard to get,
link |
03:35:00.740
I keep talking about it's like,
link |
03:35:02.420
it needs to just be one click to make everything happen.
link |
03:35:05.020
And we're getting there in our home environment,
link |
03:35:07.620
not the whole work rooms application,
link |
03:35:09.260
but the main home where you can now kind of go over
link |
03:35:11.740
and click and invite,
link |
03:35:12.660
and it still winds up taking five times longer
link |
03:35:15.220
than it should,
link |
03:35:16.260
but we're getting close to that where you click there,
link |
03:35:19.460
they click on their button and then they're sitting there
link |
03:35:22.020
in this good presence with you,
link |
03:35:23.860
but latencies need to get a lot better.
link |
03:35:25.940
User interface needs to get a lot better.
link |
03:35:28.780
Ubiquity of the headsets needs to get better.
link |
03:35:30.940
We need to have a hundred million of them out there
link |
03:35:33.780
just so that everybody knows somebody
link |
03:35:35.420
that uses this all the time.
link |
03:35:37.260
Well, I think it's a virtuous cycle
link |
03:35:38.540
because I do think the interface
link |
03:35:44.140
is the thing that makes or breaks this kind of revolution.
link |
03:35:48.140
It's so interesting how like you said one click,
link |
03:35:50.860
but it's also like how you achieve that one click.
link |
03:35:53.980
I don't know.
link |
03:35:54.820
What is, can I ask a dark question?
link |
03:35:58.620
Maybe let's keep it outside of meta,
link |
03:36:00.700
but this is about meta, but also Google and big company.
link |
03:36:05.020
Are they able to do this kind of thing?
link |
03:36:07.940
It seems like, let me put on my cranky old man hat,
link |
03:36:12.180
is they seem to not do a good job
link |
03:36:15.660
of creating these user friendly interfaces
link |
03:36:20.500
as they get bigger and bigger as a company.
link |
03:36:22.900
Like Google has created some of the greatest interfaces ever
link |
03:36:27.100
early on in its, I mean, creating Gmail,
link |
03:36:30.300
just so many brilliant interfaces
link |
03:36:33.820
and it just seems to be getting crappier
link |
03:36:35.940
and crappier at that.
link |
03:36:37.220
Same with meta, same with Microsoft.
link |
03:36:42.180
It's just, it seems to get worse and worse at that.
link |
03:36:45.020
I don't know what it is,
link |
03:36:46.100
because you've become more conservative,
link |
03:36:47.620
careful, risk averse.
link |
03:36:49.980
Is that why?
link |
03:36:51.140
Can you speak to that?
link |
03:36:51.980
It's been really eye opening to me
link |
03:36:53.500
working inside a tech titan,
link |
03:36:55.420
where I had my small companies
link |
03:36:59.460
and then we're acquired by a midsize game publisher
link |
03:37:03.500
and then Oculus getting acquired by meta
link |
03:37:06.740
and meta has grown by a factor of many
link |
03:37:08.860
just in the eight years since the acquisition.
link |
03:37:12.980
So I did not have experience with this
link |
03:37:16.260
and it was interesting because I remember like previously
link |
03:37:19.740
my benchmark for kind of use of resources
link |
03:37:23.020
was some of the government programs I interacted with
link |
03:37:25.300
on the aerospace side.
link |
03:37:26.900
And I remember thinking there was,
link |
03:37:28.860
okay, there's an air force program
link |
03:37:30.340
and they spent $50 million and they didn't launch anything.
link |
03:37:34.340
They didn't even build anything.
link |
03:37:35.500
It was just kind of like they made a bunch of papers
link |
03:37:39.020
and had some parts in a warehouse and nothing came of it.
link |
03:37:42.180
It's like $50 million and I've had to radically recalibrate
link |
03:37:47.740
my sense of like how much money can be spent
link |
03:37:50.540
with mediocre resources.
link |
03:37:54.060
Where on the plus side, VR has turned out,
link |
03:37:58.020
we've built pretty much exactly what,
link |
03:38:02.260
we just passed the 10 year mark then
link |
03:38:03.900
from like my first demo of the Rift.
link |
03:38:06.940
And if I could have said what I wanted to have,
link |
03:38:09.580
it would have been a standalone inside out tracked
link |
03:38:12.860
4K resolution headset that I,
link |
03:38:15.820
that could still plug into a PC for high end rendering.
link |
03:38:18.380
And that's exactly what we've got on Quest 2 right now.
link |
03:38:20.900
Yes, first of all, let's pause on that
link |
03:38:22.660
with me being cranky and everything.
link |
03:38:24.980
It's what Meta achieved with Oculus and so on is incredible.
link |
03:38:30.180
I mean, this is, when I thought about the future of VR,
link |
03:38:34.060
this is what I imagined in terms of hardware, I would say.
link |
03:38:36.740
And maybe in terms of the experience as well,
link |
03:38:39.260
but it's still not there somehow.
link |
03:38:42.100
On the one hand, we did kind of achieve it and win.
link |
03:38:44.620
And we've got, we've sold, we're a success right now,
link |
03:38:48.140
but the amount of resources that have gone into it,
link |
03:38:51.260
it winds up getting cluttered up in accounting
link |
03:38:53.540
where Mark did announce that they spent $10 billion a year,
link |
03:38:58.380
like on Reality Labs.
link |
03:38:59.540
Now Reality Labs covers a lot.
link |
03:39:01.740
It was, VR was not the large part of it.
link |
03:39:04.300
It also had Portal and Spark
link |
03:39:05.860
and the big AR research efforts.
link |
03:39:08.180
And it's been expanding out to include AI
link |
03:39:11.060
and other things there where there's a lot going on there.
link |
03:39:15.540
But $10 billion was just a number
link |
03:39:18.140
that I had trouble processing.
link |
03:39:20.260
It's just, I feel sick to my stomach
link |
03:39:22.460
thinking about that much money being spent.
link |
03:39:24.980
But that's how they demonstrate commitment to this,
link |
03:39:27.820
where it's not more so than like, yeah,
link |
03:39:31.420
Google goes and cancels all of these projects,
link |
03:39:34.100
different things like that,
link |
03:39:36.060
while Meta is really sticking with the funding of VR
link |
03:39:39.500
and AR is still further out with it.
link |
03:39:41.900
So there's something to be said for that.
link |
03:39:44.780
It's not just gonna vanish, the work's going in.
link |
03:39:46.940
I just wish it could be,
link |
03:39:48.740
all those resources could be applied more effectively
link |
03:39:51.740
because I see all these cases.
link |
03:39:53.740
I point out these examples of how a third party
link |
03:39:56.900
that we're kind of competing with in various ways.
link |
03:39:58.940
There's a number of these examples
link |
03:40:00.580
and they do work with a 10th of the people
link |
03:40:03.820
that we do internally and a lot of it comes from,
link |
03:40:06.940
yes, the small company can just go do it
link |
03:40:10.060
while in a big company, you do have to worry about,
link |
03:40:13.860
is there some SDK internally that you should be using
link |
03:40:16.740
because another team's making it,
link |
03:40:18.140
you have to have your cross functional group meetups
link |
03:40:21.020
for different things.
link |
03:40:22.260
You do have more concerns about privacy
link |
03:40:25.260
or diversity and equity and safety of different things,
link |
03:40:28.900
parental issues and things that a small startup company
link |
03:40:31.860
can just kind of cowboy off and do something interesting.
link |
03:40:36.540
And there's a lot more that is a problem
link |
03:40:39.380
that you have to pay attention to in the big companies,
link |
03:40:41.460
but I'm not willing to believe that we are within
link |
03:40:43.860
even a factor of two or four
link |
03:40:46.300
of what the efficiency could be.
link |
03:40:48.820
I am constantly kind of crying out for it's like,
link |
03:40:52.020
we can do better than this.
link |
03:40:53.460
And you wonder what the mechanisms
link |
03:40:55.100
to unlock that efficiency are.
link |
03:40:57.620
I don't, there is some sense in a large company
link |
03:41:02.500
that like an individual engineer might not believe
link |
03:41:05.700
that they can change the world.
link |
03:41:07.140
Maybe you delegate a little bit of the responsibility
link |
03:41:11.460
to be the one who changes the world in a big company,
link |
03:41:14.420
I think, but the reality is like the world will get changed
link |
03:41:19.460
by a single engineer anyway.
link |
03:41:21.380
So if whether inside Google or inside a startup,
link |
03:41:24.420
it doesn't matter, it's just like Google
link |
03:41:26.300
and Meta needs to help those engineers believe
link |
03:41:29.740
they're the ones that are gonna decrease that latency.
link |
03:41:32.860
It'll take one John Carmack, the 20 year old Carmack
link |
03:41:37.220
that's inside Meta right now to change everything.
link |
03:41:40.580
And I try to point that out and push people.
link |
03:41:43.060
It's like, try to go ahead.
link |
03:41:45.060
And when you see some, because there is,
link |
03:41:46.780
you get the silo mentality where you're like,
link |
03:41:48.860
okay, I know something's not right over there,
link |
03:41:50.940
but I'm staying in my lane here.
link |
03:41:53.780
And there's a couple of people that I can think about
link |
03:41:57.380
that are willing to just like hop all over the place
link |
03:41:59.580
and man, I treasure them.
link |
03:42:01.140
The people that are just willing to, they're fearless.
link |
03:42:03.980
They will go over and they will go rebuild the kernel
link |
03:42:06.380
and change this distribution and go in
link |
03:42:08.260
and hack a firmware over here to get something done right.
link |
03:42:11.860
And that is relatively rare.
link |
03:42:14.220
There's thousands of developers
link |
03:42:15.780
and you've got a small handful that are willing
link |
03:42:17.580
to operate at that level.
link |
03:42:19.540
And it's potentially risky for them.
link |
03:42:22.140
The politics are real in a lot of that.
link |
03:42:24.940
And I'm in the very much the privileged position
link |
03:42:27.820
of I'm more or less untouchable there
link |
03:42:31.340
where I've been dinged like twice
link |
03:42:33.340
for it's like you said something insensitive in that post
link |
03:42:35.740
and you should probably not say that.
link |
03:42:38.940
But for the most part, yes, I get away with,
link |
03:42:42.340
every week I'm posting something pretty loud
link |
03:42:45.060
and opinionated internally.
link |
03:42:47.500
And I think that's useful for the company,
link |
03:42:50.220
but yeah, it's rare to have a position like that.
link |
03:42:54.880
And I can't necessarily offer advice
link |
03:42:56.620
for how someone can do that.
link |
03:42:59.060
Well, you could offer advice to a company in general
link |
03:43:01.540
to give a little bit of freedom for the young wild,
link |
03:43:06.060
like the wildest ideas come from the young minds.
link |
03:43:10.740
And so you need to give the young minds freedom
link |
03:43:13.060
to think big and wild and crazy.
link |
03:43:16.420
And for that, they have to be opinionated.
link |
03:43:18.580
They have to think crazy ideas and thoughts
link |
03:43:24.380
and pursue them with a full passion
link |
03:43:26.300
without being slowed down by bureaucracy or managers
link |
03:43:29.220
and all that kind of stuff.
link |
03:43:31.100
Obviously startups really empower that,
link |
03:43:33.060
but big companies could too.
link |
03:43:34.260
And that's a design challenge for big companies
link |
03:43:37.960
to see how can you enable that?
link |
03:43:40.180
How can you empower that?
link |
03:43:41.020
Yeah, because the big company,
link |
03:43:41.840
there are so many resources there.
link |
03:43:43.600
And they do, amazing things do get accomplished,
link |
03:43:46.580
but there's so much more that could come out of that.
link |
03:43:49.780
And I'm always hopeful.
link |
03:43:51.540
I'm an optimist in almost everything.
link |
03:43:53.220
I think things can get better.
link |
03:43:54.980
I think that they can improve things
link |
03:43:56.780
that you go through a path
link |
03:43:58.340
and you're learning kind of what does and doesn't work.
link |
03:44:01.420
And I'm not ready to be fatalistic
link |
03:44:03.700
about the kind of the outcome of any of that.
link |
03:44:06.820
Me neither, I know too many good people
link |
03:44:09.040
inside of those large companies that are incredible.
link |
03:44:12.420
You have a friendship with Elon Musk.
link |
03:44:16.060
Often when I talk to him,
link |
03:44:17.380
he'll bring up how incredible of an engineer
link |
03:44:19.660
and just a big picture thinker you are.
link |
03:44:22.420
His huge amount of respect for you.
link |
03:44:26.300
I just, I've never been a fly in the wall
link |
03:44:28.900
between a discussion between the two of you.
link |
03:44:30.600
I just wonder, is there something you guys debate,
link |
03:44:34.940
argue about, discuss?
link |
03:44:36.800
Is there some interesting problems
link |
03:44:38.300
that the two of you think about?
link |
03:44:41.260
You come from different worlds.
link |
03:44:42.480
Maybe there's some intersection in aerospace.
link |
03:44:45.900
Maybe there's some intersection
link |
03:44:48.160
in your new efforts in artificial intelligence
link |
03:44:52.020
in terms of thinking.
link |
03:44:53.580
Is there something interesting you could say
link |
03:44:55.140
about sort of the debates the two of you have?
link |
03:44:57.340
So I think in some ways,
link |
03:44:58.860
we do have a kind of similar background
link |
03:45:01.300
where we're almost exactly the same age.
link |
03:45:03.540
And we had kind of similar programming backgrounds
link |
03:45:06.420
on the personal computers
link |
03:45:07.820
and even some of the books that we would read
link |
03:45:10.660
and things that would kind of turn us into the people
link |
03:45:13.100
that we are today.
link |
03:45:14.700
And I think there is a degree of sensibility similarities
link |
03:45:19.700
where we kind of call bullshit on the same things
link |
03:45:22.940
and kind of see the same opportunities
link |
03:45:25.820
in different technology.
link |
03:45:27.220
And there's that sense of,
link |
03:45:29.020
I always talk about the speed of light solutions for things.
link |
03:45:31.600
And he's thinking about kind of minimum manufacturing
link |
03:45:34.920
and engineering and operational standpoints for things.
link |
03:45:39.020
And so, I mean, I first met Elon
link |
03:45:42.260
right at the start of the aerospace era
link |
03:45:44.080
where I wasn't familiar with,
link |
03:45:46.220
I was still in my game dev bubble.
link |
03:45:47.780
I really wasn't familiar with all the startups
link |
03:45:49.860
that were going and being successful
link |
03:45:52.080
and what went on with PayPal
link |
03:45:53.700
and all of his different companies.
link |
03:45:54.980
But I met him as I was starting to do armadillo aerospace.
link |
03:45:58.900
And he came down with kind of his right hand propulsion guy.
link |
03:46:03.140
And we talked about rockets.
link |
03:46:05.460
What can we do with this?
link |
03:46:07.280
And it was kind of specific things
link |
03:46:09.100
about like how are our flight computers set up?
link |
03:46:12.140
What are different propellant options?
link |
03:46:14.740
You know, what can happen with different ways
link |
03:46:17.580
of putting things together?
link |
03:46:19.380
And then in some ways,
link |
03:46:21.220
he was certainly the biggest player
link |
03:46:22.900
in the sort of alt space community
link |
03:46:24.900
that was going on in the early 2000s.
link |
03:46:28.080
He was the most well funded,
link |
03:46:30.600
although his funding in the larger scheme of things
link |
03:46:32.860
compared to like a NASA or something like that
link |
03:46:36.780
was really tiny.
link |
03:46:38.260
It was a lot more than I had at the time.
link |
03:46:40.520
But it was interesting.
link |
03:46:42.640
I had a point years later when I realized,
link |
03:46:45.560
okay, my financial resources at this point
link |
03:46:48.880
are basically what Elon's was
link |
03:46:50.480
when he went all in on SpaceX and Tesla.
link |
03:46:54.360
And there's, I think in many corners,
link |
03:46:58.360
he does not get the respect that he should
link |
03:47:01.120
about being a wealthy person that could just retire.
link |
03:47:04.960
And he went all in where he was really going to,
link |
03:47:08.720
he could have gone bust.
link |
03:47:11.400
And there's plenty of people,
link |
03:47:12.560
you'd look at the sad athletes or entertainers
link |
03:47:16.780
that had all the money in the world and blew it.
link |
03:47:18.600
And he could have been the business case example of that.
link |
03:47:22.400
But the things that he was doing,
link |
03:47:25.440
space exploration, electrification of transportation,
link |
03:47:29.880
solar city type things,
link |
03:47:31.720
these are big world level things.
link |
03:47:34.560
And I have a great deal of admiration
link |
03:47:36.800
that he was willing to throw himself so completely
link |
03:47:40.120
into that because in contrast with myself,
link |
03:47:43.080
I was doing armadillo aerospace with this tightly bounded,
link |
03:47:47.000
it was John's crazy money at the time
link |
03:47:49.560
that had a finite limit on it.
link |
03:47:51.440
It was never going to impact me or my family
link |
03:47:54.840
if it completely failed.
link |
03:47:56.560
And I was still hedging my bets,
link |
03:47:58.680
working at id Software at the time
link |
03:48:01.060
when he had been really all in there.
link |
03:48:04.960
And I have a huge amount of respect for that.
link |
03:48:08.000
And people do not,
link |
03:48:09.360
the other thing I get irritated with is people that say,
link |
03:48:11.480
it's like, oh, Elon's just a business guy.
link |
03:48:13.880
He just got like, he was gifted the money
link |
03:48:16.500
and he's just kind of investing in all of this
link |
03:48:19.440
when he was really deeply involved
link |
03:48:22.240
in a lot of the decisions.
link |
03:48:24.520
Not all of them were perfect,
link |
03:48:25.800
but he cared very much about engine material selection,
link |
03:48:30.380
propellant selection.
link |
03:48:31.660
And for years he'd be kind of telling me,
link |
03:48:34.320
it's like, get off that hydrogen peroxide stuff.
link |
03:48:37.000
It's like, liquid oxygen is the only proper oxidizer
link |
03:48:40.860
for this.
link |
03:48:41.840
And the times that I've gone through the factories
link |
03:48:46.160
with him, we're talking very detailed things
link |
03:48:49.780
about like how this weld is made,
link |
03:48:51.840
how this sub assembly goes together,
link |
03:48:54.720
what are like startup shut down behaviors
link |
03:48:57.560
of the different things.
link |
03:48:58.520
So he is really in there at a very detailed level.
link |
03:49:03.440
And I think that he is the best modern example now
link |
03:49:06.960
of someone that tries to,
link |
03:49:08.520
that can effectively micromanage some decisions on things
link |
03:49:11.880
on both Tesla and SpaceX to some degree
link |
03:49:15.040
where he cares enough about it.
link |
03:49:16.920
I worry a lot that he stretched too thin
link |
03:49:19.280
that you get Boring Company and Neuralink and Twitter
link |
03:49:23.000
and all the other possible things there
link |
03:49:25.280
where I know I've got limits on how much I can pay attention
link |
03:49:30.000
to that I have to kind of box off different amounts of time.
link |
03:49:34.040
And I look back at like at my aerospace side of things,
link |
03:49:36.440
it's like, I did not go all in on that.
link |
03:49:38.400
I did not commit myself at a level
link |
03:49:40.640
that it would have taken to be successful there.
link |
03:49:43.500
And I, yeah, and it's kind of a weird thing
link |
03:49:46.440
just like having a discussion with him.
link |
03:49:49.000
He's the richest man in the world right now,
link |
03:49:50.840
but he operates on a level that is still very much
link |
03:49:55.840
in my wheelhouse on a technical side of things.
link |
03:50:00.160
So.
link |
03:50:01.000
That doing that systems level type of thinking
link |
03:50:02.440
where you can go to the low level details
link |
03:50:04.880
and go up high to the big picture.
link |
03:50:07.420
Do you think in aerospace arena
link |
03:50:12.320
in the next five, 10 years,
link |
03:50:14.480
do you think we're gonna put a human on Mars?
link |
03:50:16.360
Like, what do you think is the interesting?
link |
03:50:20.280
No, I do, in fact, I made a bet with someone
link |
03:50:23.040
with a group of people kind of this
link |
03:50:24.860
about whether boots on Mars by 2030.
link |
03:50:28.400
And this was kind of a fun story
link |
03:50:31.300
because I was at an Intel sponsored event
link |
03:50:34.120
and we had a bunch of just world class, brilliant people.
link |
03:50:37.380
And we were talking about computing stuff,
link |
03:50:39.120
but the after dinner conversation was like,
link |
03:50:41.520
what are some other things?
link |
03:50:42.340
How are they gonna go in the future?
link |
03:50:43.920
And one of the ones tossed up on the whiteboard
link |
03:50:46.140
was like boots on Mars by 2030.
link |
03:50:49.040
And most of the people in the room thought, yes,
link |
03:50:52.280
I thought that like, SpaceX is kicking ass.
link |
03:50:54.440
We've got all this possible stuff.
link |
03:50:57.000
Seems likely that it's gonna go that way.
link |
03:50:59.440
And I said, no, I think less than 50% chance
link |
03:51:03.280
that it's going to make it there.
link |
03:51:05.440
And people were kind of like,
link |
03:51:07.320
oh, why the pessimism or whatever?
link |
03:51:09.440
And of course I'm an optimist at almost everything,
link |
03:51:12.040
but for me to be the one kind of outlier saying,
link |
03:51:14.820
no, I don't think so.
link |
03:51:17.240
Then I started saying some of the things I said,
link |
03:51:19.400
well, let's be concrete about it.
link |
03:51:21.040
Let's bet $10,000 that it's not gonna happen.
link |
03:51:24.880
And this was really a startling thing to see that I,
link |
03:51:29.800
again, room full of brilliant people,
link |
03:51:31.640
but as soon as like money came on the line
link |
03:51:34.320
and they were like, do I wanna put 10,000?
link |
03:51:36.680
I was not the richest person in the room.
link |
03:51:38.800
There were people much better off than I was.
link |
03:51:41.280
There's a spectrum, but as soon as they started thinking,
link |
03:51:45.320
it's like, oh, I could lose money
link |
03:51:46.760
by keeping my position right now.
link |
03:51:50.760
And all these engineers, they engaged their brain.
link |
03:51:53.400
They started thinking, it's like, okay,
link |
03:51:55.120
launch windows, launch delays,
link |
03:51:57.840
like how many times would it take to get this right?
link |
03:52:00.340
What historical precedents do we have?
link |
03:52:02.680
And then it mostly came down to, it's like,
link |
03:52:05.800
well, what about in transit by 2030?
link |
03:52:08.200
And then what about different things
link |
03:52:11.440
or would you go for 2032?
link |
03:52:13.880
But one of the people did go ahead
link |
03:52:15.760
and was optimistic enough to make a bet with me.
link |
03:52:18.300
So I have a $10,000 bet that by 2030,
link |
03:52:21.960
I think it's gonna happen shortly thereafter.
link |
03:52:24.400
I think there will probably be infrastructure on Mars
link |
03:52:26.460
by 2030, but I don't think that we'll have humans
link |
03:52:29.960
on Mars on 2030.
link |
03:52:31.120
I think it's possible, but I think it's less
link |
03:52:33.540
than a 50% chance, so I felt safe making that bet.
link |
03:52:36.720
Well, I think you had an interesting point.
link |
03:52:39.960
Correct me if I'm wrong.
link |
03:52:41.200
That's a dark one.
link |
03:52:42.460
That should perhaps help people appreciate Elon Musk,
link |
03:52:48.800
which is, in this particular effort,
link |
03:52:53.400
Elon is critical to the success.
link |
03:52:56.840
SpaceX seems to be critical to, you know,
link |
03:53:03.640
humans on Mars by 2030 or thereabouts.
link |
03:53:07.040
So if something happens to Elon,
link |
03:53:09.160
then all of this collapses.
link |
03:53:12.160
And this is in contrast to the other $10,000 bet
link |
03:53:16.160
I made kind of recently, and that was self driving cars
link |
03:53:19.160
at like a level five running around cities.
link |
03:53:22.160
And people have kind of nitpicked that
link |
03:53:24.160
that we probably don't mean exactly level five,
link |
03:53:26.160
but the guy I'm having the bet with is,
link |
03:53:29.160
we're gonna be, we know what we mean about this.
link |
03:53:31.160
Jeff Atwood.
link |
03:53:32.160
Yeah, coding horror and stack overflow and all.
link |
03:53:36.160
But yeah, I mean, he doesn't think that people
link |
03:53:40.160
are gonna be riding around in robo taxis in 2030
link |
03:53:43.160
in major cities, just like you take an Uber now.
link |
03:53:47.160
And I think it will.
link |
03:53:48.160
You think it will.
link |
03:53:49.160
And the difference is, everybody looks at this,
link |
03:53:51.160
it's like, oh, but Tesla's been wrong for years.
link |
03:53:53.160
They've been promising it for years and it's not here yet.
link |
03:53:56.160
And the reason this is different than the bet with Mars
link |
03:54:00.160
is Mars really is more than is comfortable
link |
03:54:04.160
a bet on Elon Musk.
link |
03:54:06.160
That is his thing and he is really going to move
link |
03:54:11.160
heaven and earth to try to make that happen.
link |
03:54:13.160
And perhaps not even SpaceX, perhaps just Elon Musk.
link |
03:54:17.160
Yeah, because if Elon went away and SpaceX went public
link |
03:54:21.160
and got a board of directors,
link |
03:54:23.160
there are more profitable things they could be doing
link |
03:54:26.160
than focusing on human presence on Mars.
link |
03:54:29.160
So this really is a sort of personal thing there.
link |
03:54:32.160
And in contrast with that, self driving cars
link |
03:54:36.160
have a dozen credible companies working really hard.
link |
03:54:40.160
And while, yes, it's going slower
link |
03:54:43.160
than most people thought it would,
link |
03:54:45.160
betting against that is a bet against almost the entire world
link |
03:54:49.160
in terms of all of these companies
link |
03:54:51.160
that have all of these incentives.
link |
03:54:53.160
It's not just one guy's passion project.
link |
03:54:56.160
And I do think that it is solvable.
link |
03:54:59.160
Although I recognize it's not 100% chance
link |
03:55:02.160
because it's possible the long tail of self driving problems
link |
03:55:05.160
winds up being an AGI complete problem.
link |
03:55:08.160
I think there's plenty of value to mine out of it with narrow AI.
link |
03:55:11.160
And I think that it's going to happen probably more so
link |
03:55:15.160
than people expect.
link |
03:55:16.160
But it's that whole sigmoid curve
link |
03:55:18.160
where you overestimate the near term progress
link |
03:55:21.160
and you underestimate the long term progress.
link |
03:55:23.160
And I think self driving is going to be like that.
link |
03:55:26.160
And I think 2030 is still a pretty good bet.
link |
03:55:29.160
Yeah, unfortunately, self driving is a problem
link |
03:55:35.160
that is safety critical, meaning that if you don't do it well,
link |
03:55:41.160
people get hurt.
link |
03:55:43.160
But the other side of that is people are terrible drivers.
link |
03:55:46.160
So it is not going to be,
link |
03:55:48.160
that's probably going to be the argument that gets it through
link |
03:55:50.160
is like we can save 10,000 lives a year
link |
03:55:54.160
by taking imperfect self driving cars
link |
03:55:57.160
and letting them take over a lot of driving responsibilities.
link |
03:56:00.160
It's like 30,000 people a year die in auto accidents right now in America.
link |
03:56:05.160
And a lot of those are preventable.
link |
03:56:07.160
And the problem is you'll have people that
link |
03:56:09.160
every time a Tesla crashes into something,
link |
03:56:11.160
you've got a bunch of people that literally have vested interests
link |
03:56:14.160
shorting Tesla to come out and make it the worst thing in the world.
link |
03:56:17.160
And people will be fighting against that.
link |
03:56:19.160
But optimist in me again,
link |
03:56:21.160
I think that we will have systems that are statistically safer than human drivers
link |
03:56:26.160
and we will be saving thousands and thousands of lives every year
link |
03:56:30.160
when we can hand over more of those responsibilities to it.
link |
03:56:34.160
I do still think as a person who studied this problem very deeply
link |
03:56:38.160
from a human side as well,
link |
03:56:40.160
it's still an open problem how good slash bad humans are driving.
link |
03:56:46.160
It's a kind of funny thing we say about each other.
link |
03:56:49.160
Oh, humans suck at driving.
link |
03:56:51.160
Everybody except you, of course.
link |
03:56:54.160
Like we think we're good at driving.
link |
03:56:56.160
But I, after really studying it,
link |
03:56:59.160
I think you start to notice, you know,
link |
03:57:03.160
because I watched hundreds of hours of humans driving
link |
03:57:06.160
with the projects of this kind of thing.
link |
03:57:08.160
You've noticed that even with the distraction,
link |
03:57:11.160
even with everything else,
link |
03:57:13.160
humans are able to do some incredible things
link |
03:57:17.160
with the attention,
link |
03:57:19.160
even when you're just looking at the smartphone,
link |
03:57:21.160
just to get cues from the environment
link |
03:57:23.160
to make last second decisions,
link |
03:57:26.160
to use instinctual type of decisions that actually save your ass
link |
03:57:30.160
time and time and time again.
link |
03:57:32.160
And are able to do that with so much uncertainty around you
link |
03:57:37.160
in such tricky dynamic environments.
link |
03:57:40.160
I don't know.
link |
03:57:42.160
I don't know exactly how hard is it to beat that kind of skill
link |
03:57:49.160
of common sense reasoning.
link |
03:57:51.160
This is one of those interesting things that there have been
link |
03:57:53.160
a lot of studies about how experts in their field
link |
03:57:56.160
usually underestimate the progress that's going to happen
link |
03:57:59.160
because an expert thinks about all the problems they deal with
link |
03:58:02.160
and they're like, damn, I'm going to have a hard time
link |
03:58:05.160
solving all of this.
link |
03:58:06.160
And they filter out the fact that they are one expert
link |
03:58:08.160
in a field of thousands.
link |
03:58:10.160
And you think about, yeah, I can't do all of that.
link |
03:58:13.160
And you sometimes forget about the scope of the ecosystem
link |
03:58:16.160
that you're embedded in.
link |
03:58:18.160
And if you think back eight years, very specifically,
link |
03:58:20.160
the state of AI and machine learning, where was that?
link |
03:58:23.160
We had just gotten Resnets probably at that point.
link |
03:58:26.160
And you look at all the amazing magical things
link |
03:58:29.160
that have happened in eight years,
link |
03:58:31.160
and they do kind of seem to be happening a little faster
link |
03:58:34.160
in recent years also.
link |
03:58:36.160
And you project that eight more years into the future,
link |
03:58:39.160
where, again, I think there's a 50% chance
link |
03:58:41.160
we're going to have signs of life of AGI,
link |
03:58:43.160
which we can put through driver's ed if we need to
link |
03:58:46.160
to actually build self driving cars.
link |
03:58:48.160
And I think that the narrow systems are going to have
link |
03:58:51.160
real value demonstrated well before then.
link |
03:58:54.160
So signs of life in AGI, you've mentioned that,
link |
03:59:00.160
okay, first of all, you're one of the most brilliant people
link |
03:59:04.160
on this earth.
link |
03:59:05.160
You could be solving a number of different problems,
link |
03:59:08.160
as you've mentioned.
link |
03:59:09.160
Your mind was attracted to nuclear energy.
link |
03:59:12.160
Obviously, virtual reality with the metaverse
link |
03:59:14.160
is something you could have a tremendous impact on.
link |
03:59:16.160
So I do want to say a quick thing about nuclear energy,
link |
03:59:19.160
where this is something that so precisely feels like
link |
03:59:25.160
aerospace before SpaceX, where from everything that I know
link |
03:59:29.160
about all of these, the physics of this stuff hasn't changed.
link |
03:59:33.160
And the reasons why things are expensive now
link |
03:59:36.160
are not fundamental.
link |
03:59:38.160
Somebody should be going into a really hard Elon Musk style
link |
03:59:44.160
at fission, economical fission, not fusion,
link |
03:59:48.160
where the fusion is the kind of the darling of people
link |
03:59:52.160
that want to go and do nuclear because it doesn't have
link |
03:59:55.160
the taint that fission has in a lot of people's minds.
link |
03:59:58.160
But it's an almost absurdly complex thing where nuclear fusion,
link |
04:00:03.160
as you look at the tokamaks or any of the things that people
link |
04:00:06.160
are building, and it's doing all of this infrastructure
link |
04:00:09.160
just at the end of the day to make something hot
link |
04:00:12.160
that you can then turn into energy
link |
04:00:14.160
through a conventional power plant.
link |
04:00:16.160
And all of that work, which we think
link |
04:00:18.160
we've got line of sight on, but even if it comes out,
link |
04:00:21.160
then you have to do all of that immensely complex expensive
link |
04:00:25.160
stuff just to make something hot, where nuclear fission
link |
04:00:28.160
is basically you put these two rocks together
link |
04:00:30.160
and they get hot all by themselves.
link |
04:00:32.160
That is just that much simpler.
link |
04:00:35.160
It's just orders of magnitude simpler.
link |
04:00:37.160
And the actual rocks, the refined uranium,
link |
04:00:40.160
is not very expensive.
link |
04:00:41.160
It's a couple percent of the cost of electricity.
link |
04:00:44.160
That's why I made that point where you could have something
link |
04:00:47.160
which was five times less efficient than current systems.
link |
04:00:51.160
And if the rest of the plant was a whole bunch cheaper,
link |
04:00:54.160
you could still be super, super valuable.
link |
04:00:56.160
So how much of the pie do you think could be solved
link |
04:01:02.160
by nuclear energy by fission?
link |
04:01:04.160
So how much could it become the primary source
link |
04:01:07.160
of energy on Earth?
link |
04:01:08.160
It could be most of it.
link |
04:01:10.160
Like the reserves of uranium, as it stands now,
link |
04:01:12.160
could not power the whole Earth.
link |
04:01:13.160
But you get into breeder reactors and thorium
link |
04:01:16.160
and things like that that you do for conventional fission.
link |
04:01:19.160
There is enough for everything.
link |
04:01:22.160
Now, I mean, solar, photovoltaic has been amazing.
link |
04:01:25.160
One of my current projects is working on an off grid system.
link |
04:01:29.160
And it's been fun just kind of, again, putting my hands
link |
04:01:31.160
on all this, stripping the wires and wiring things together
link |
04:01:34.160
and doing all of that.
link |
04:01:35.160
And just having followed that a little bit
link |
04:01:37.160
from the outside over the last couple decades,
link |
04:01:40.160
there's been semiconductor like magical progress
link |
04:01:43.160
in what's going on there.
link |
04:01:45.160
So I'm all for all of that.
link |
04:01:47.160
But it doesn't solve everything.
link |
04:01:49.160
And nuclear really still does seem like the smart money
link |
04:01:52.160
bet for what you should be getting for baseband
link |
04:01:55.160
on a lot of things.
link |
04:01:56.160
And solar may be cheaper for peaking over air conditioning
link |
04:02:00.160
loads during the summer and things
link |
04:02:02.160
that you can push around in different ways.
link |
04:02:05.160
But it's one of those things that's
link |
04:02:07.160
it's just strange how we've had the technology sitting there.
link |
04:02:10.160
But these non technical reasons on the social optics of it
link |
04:02:14.160
has been this major forcing function for something
link |
04:02:18.160
that really should be at the cornerstone of all
link |
04:02:21.160
of the world's concerns with energy.
link |
04:02:23.160
It's interesting how the non technical factors have really
link |
04:02:27.160
dominated something that is so fundamental to the existence
link |
04:02:31.160
of the human race as we know it today.
link |
04:02:34.160
And much of the troubles of the world,
link |
04:02:36.160
including wars in different parts of the world like Ukraine
link |
04:02:40.160
is energy based.
link |
04:02:41.160
And yeah, it's just sitting right there to be solved.
link |
04:02:47.160
That said, I mean, to me personally,
link |
04:02:50.160
I think it's clear that if AGI were to be achieved,
link |
04:02:53.160
that would change the course of human history.
link |
04:02:55.160
So AGI wise, I was making this decision about what
link |
04:03:00.160
do I want to focus on after VR.
link |
04:03:03.160
And I'm still working on VR regularly.
link |
04:03:06.160
I spend a day a week kind of consulting with Meta.
link |
04:03:09.160
And Boz styles me the consulting CTO.
link |
04:03:13.160
It's kind of like the Sherlock Holmes that
link |
04:03:15.160
comes in and consults on some of the specific tough issues.
link |
04:03:18.160
And I'm still pretty passionate about all of that.
link |
04:03:21.160
But I have been figuring out how to compartmentalize and force
link |
04:03:25.160
that into a smaller box to work on some other things.
link |
04:03:29.160
And I did come down to this decision
link |
04:03:30.160
between working on economical nuclear fission
link |
04:03:34.160
or artificial general intelligence.
link |
04:03:36.160
And the fission side of things, I've
link |
04:03:39.160
got a bunch of interesting things going that way.
link |
04:03:42.160
But that would be a fairly big project thing to do.
link |
04:03:46.160
I don't think it needs to be as big as people expect.
link |
04:03:49.160
I do think something original SpaceX sized, you build it,
link |
04:03:53.160
power your building off of it, and then the government,
link |
04:03:56.160
I think, will come around to what you need to.
link |
04:03:59.160
Everybody loves an existence proof.
link |
04:04:01.160
I think it's possible somebody should be doing this.
link |
04:04:03.160
But it's going to involve some politics.
link |
04:04:05.160
It's going to involve decent sized teams
link |
04:04:07.160
and a bunch of this cross functional stuff
link |
04:04:09.160
that I don't love.
link |
04:04:11.160
While the artificial general intelligence side of things,
link |
04:04:15.160
it seems to me like this is the highest leverage
link |
04:04:21.160
moment for potentially a single individual,
link |
04:04:24.160
potentially in the history of the world,
link |
04:04:26.160
where the things that we know about the brain, about what we
link |
04:04:30.160
can do with artificial intelligence,
link |
04:04:33.160
nobody can say absolutely on any of these things.
link |
04:04:36.160
But I am not a madman for saying that it is likely
link |
04:04:40.160
that the code for artificial general intelligence
link |
04:04:44.160
is going to be tens of thousands of lines of code,
link |
04:04:48.160
not millions of lines of code.
link |
04:04:50.160
This is code that conceivably one individual could write,
link |
04:04:53.160
unlike writing a new web browser or operating system.
link |
04:04:57.160
And based on the progress that AI, machine learning,
link |
04:05:01.160
has made in the recent decade, it's
link |
04:05:04.160
likely that the important things that we don't know
link |
04:05:07.160
are relatively simple.
link |
04:05:09.160
There's probably a handful of things.
link |
04:05:11.160
My bet is that I think there's less than six key insights that
link |
04:05:16.160
need to be made.
link |
04:05:17.160
Each one of them can probably be written
link |
04:05:19.160
on the back of an envelope.
link |
04:05:20.160
We don't know what they are.
link |
04:05:22.160
But when they're put together in concert with GPUs at scale
link |
04:05:26.160
and the data that we all have access to,
link |
04:05:28.160
that we can make something that behaves like a human being
link |
04:05:32.160
or like a living creature and that can then
link |
04:05:35.160
be educated in whatever ways that we need to get to the point
link |
04:05:39.160
where we can have universal remote workers where anything
link |
04:05:43.160
that somebody does mediated by a computer
link |
04:05:45.160
and doesn't require physical interaction that an AGI will
link |
04:05:49.160
be able to do.
link |
04:05:50.160
We can already simulate the equivalent of the Zoom meetings
link |
04:05:54.160
with avatars and synthetic deep fakes and whatnot.
link |
04:05:58.160
We can definitely do that.
link |
04:06:00.160
We have superhuman capabilities on any narrow thing
link |
04:06:03.160
that we can formalize and make a loss function for.
link |
04:06:07.160
But there's things we don't know how to do now.
link |
04:06:10.160
But I don't think they are unapproachably hard.
link |
04:06:13.160
Now, that's incredibly hubristic to say that it's like,
link |
04:06:16.160
but I think that what I said a couple years ago
link |
04:06:19.160
is a 50% chance that somewhere there will be signs of life
link |
04:06:23.160
of AGI in 2030.
link |
04:06:25.160
And I've probably increased that slightly.
link |
04:06:27.160
I may be at 55%, 60% now because I
link |
04:06:30.160
do think there's a little sense of acceleration there.
link |
04:06:34.160
So I wonder what the, and by the way,
link |
04:06:36.160
you also written that I bet with hindsight
link |
04:06:39.160
we will find that clear antecedents of all
link |
04:06:42.160
the critical remaining steps for AGI
link |
04:06:44.160
are already buried somewhere in the vast literature of today.
link |
04:06:48.160
So the ideas are already there.
link |
04:06:50.160
I think that's likely the case.
link |
04:06:52.160
One of the things that appeals to so many people,
link |
04:06:54.160
including me, about the promise of AGI
link |
04:06:56.160
is we know that we're only drinking
link |
04:06:59.160
from a straw from the fire hose of all the information out there.
link |
04:07:03.160
I mean, you look at just in a very narrowly bounded field
link |
04:07:07.160
like machine learning, like you can't read all the papers that
link |
04:07:10.160
come out all the time.
link |
04:07:11.160
You can't go back and read all the clever things
link |
04:07:14.160
that people did in the 90s or earlier
link |
04:07:16.160
that people have forgotten about because they didn't pan out
link |
04:07:18.160
at the time when they were trying to do them with 12 neurons.
link |
04:07:22.160
So this idea that, yeah, I think there
link |
04:07:25.160
are gems buried in some of the older literature that was not
link |
04:07:29.160
the path taken by everything.
link |
04:07:31.160
And you can see a herd mentality on the things that
link |
04:07:34.160
happen right now.
link |
04:07:35.160
It's almost funny to see.
link |
04:07:36.160
It's like, oh, Google does something,
link |
04:07:38.160
and OpenAI does something, Meta does something.
link |
04:07:41.160
They're the same people that all talk to each other,
link |
04:07:43.160
and they're all one upping each other,
link |
04:07:45.160
and they're all capable of implementing
link |
04:07:47.160
each other's work given a month or two
link |
04:07:49.160
after somebody has an announcement of that.
link |
04:07:52.160
But there's a whole world of possible approaches
link |
04:07:55.160
to machine learning.
link |
04:07:57.160
And I think that we probably will, in hindsight,
link |
04:08:00.160
go back and see it's like, yeah, that was kind of clearly
link |
04:08:03.160
predicted by this early paper here.
link |
04:08:06.160
And this turns out that if you do this and this
link |
04:08:08.160
and take this result from animal training
link |
04:08:11.160
and this thing from neuroscience over here
link |
04:08:13.160
and put it together and set up this curriculum for them
link |
04:08:16.160
to learn in, that that's kind of what it took.
link |
04:08:19.160
You don't have too many people now
link |
04:08:21.160
that are still saying it's not possible
link |
04:08:23.160
or it's going to take hundreds of years.
link |
04:08:25.160
And 10 years ago, you would get a collection of experts,
link |
04:08:29.160
and you would have a decent chunk on the margin that either
link |
04:08:32.160
say not possible or a couple hundred years,
link |
04:08:35.160
might be centuries.
link |
04:08:36.160
And the median estimate would be like 50, 70 years.
link |
04:08:40.160
And it's been coming down.
link |
04:08:41.160
And I know with me saying eight years for something,
link |
04:08:44.160
that still puts me on the optimistic side,
link |
04:08:46.160
but it's not crazy out in the fringes.
link |
04:08:49.160
And just being able to look at that at a meta level
link |
04:08:52.160
about the trend of the predictions going down there,
link |
04:08:57.160
the idea that something could be happening relatively soon.
link |
04:09:01.160
Now, I do not believe in fast takeoffs.
link |
04:09:04.160
That's one of the safety issues that people say,
link |
04:09:06.160
it's like, oh, it's going to go, boom,
link |
04:09:08.160
and the AI is going to take over the world.
link |
04:09:10.160
There's a lot of reasons I don't think
link |
04:09:12.160
that's a credible position.
link |
04:09:14.160
And I think that we will go from a point
link |
04:09:16.160
where we start seeing things that credibly look
link |
04:09:20.160
like animals behaviors.
link |
04:09:22.160
And I have a human voice box wired into them.
link |
04:09:25.160
It's like I tried to get Elon to say,
link |
04:09:27.160
it's like your pig in Neuralink, give it a human voice box
link |
04:09:30.160
and let it start learning human words.
link |
04:09:33.160
I think animal intelligence is closer to human intelligence
link |
04:09:36.160
than a lot of people like to think.
link |
04:09:38.160
And I think that culture and modalities of IO
link |
04:09:42.160
make the Gulf seem a lot bigger than it actually is.
link |
04:09:45.160
There's just that smooth spectrum
link |
04:09:47.160
of how the brain developed and cortexes and scaling
link |
04:09:51.160
of different things going on there.
link |
04:09:53.160
Culture modalities of IO, yes.
link |
04:09:55.160
Language is sort of lost in translation,
link |
04:10:00.160
conceals a lot of intelligence.
link |
04:10:03.160
So when you think about signs of life for AGI,
link |
04:10:06.160
you're thinking about human interpretable signs.
link |
04:10:10.160
So the example I give, if we get to the point
link |
04:10:12.160
where you've got a learning disabled toddler,
link |
04:10:15.160
some kind of real special needs child
link |
04:10:18.160
that can still interact with their favorite TV show
link |
04:10:20.160
and video game and can be trained and learn
link |
04:10:24.160
in some appreciably human like way.
link |
04:10:26.160
At that point, you can deploy an army of engineers,
link |
04:10:30.160
cognitive scientists, developmental education people.
link |
04:10:35.160
And you've got so many advantages there
link |
04:10:37.160
unlike real education where you can do rollbacks
link |
04:10:39.160
and AB testing and you can find a golden path
link |
04:10:42.160
through a curriculum of different things.
link |
04:10:44.160
If you get to that point, learning disabled toddler,
link |
04:10:47.160
I think that it's gonna be a done deal.
link |
04:10:50.160
But do you think we'll know when we see it?
link |
04:10:53.160
So there's been a lot of really interesting
link |
04:10:56.160
general learning progress from DeepMind,
link |
04:11:00.160
OpenAI a little bit too.
link |
04:11:02.160
I tend to believe that Tesla Autopilot
link |
04:11:06.160
deserves a lot more credit than it's getting
link |
04:11:08.160
for making progress on the general,
link |
04:11:12.160
on doing the multitask learning thing
link |
04:11:15.160
and increasing the number of tasks
link |
04:11:17.160
and automating that process of sort of learning
link |
04:11:23.160
from the edge, discovering the edge cases
link |
04:11:25.160
and learning from the edge cases.
link |
04:11:26.160
That is, it's really approaching from a different angle,
link |
04:11:30.160
the general learning problem of AGI.
link |
04:11:33.160
But the more clear approach comes from DeepMind
link |
04:11:36.160
where you have these kind of game situations
link |
04:11:38.160
and you build systems there.
link |
04:11:41.160
But I don't know, people seem to be quite...
link |
04:11:47.160
Yeah, there will always be people that just won't believe it
link |
04:11:50.160
and I fundamentally don't care.
link |
04:11:52.160
I mean, I don't care if they don't believe it.
link |
04:11:54.160
You know, when it starts doing people's jobs
link |
04:11:57.160
and I don't care about the philosophical zombie argument at all.
link |
04:12:01.160
Absolutely.
link |
04:12:02.160
But will you, do you think you will notice
link |
04:12:04.160
that something special has happened here?
link |
04:12:06.160
Because to me, I've been noticing a lot of special things.
link |
04:12:12.160
I think a lot of credit should go to DeepMind for AlphaZero.
link |
04:12:18.160
That was truly special.
link |
04:12:20.160
The self play mechanisms achieve sort of solve problems
link |
04:12:24.160
that used to be thought unsolvable like the game of Go.
link |
04:12:28.160
Also, I mean, protein folding, starting to get into that space
link |
04:12:32.160
where learning is doing...
link |
04:12:34.160
At first there's not, it wasn't end to end learning
link |
04:12:37.160
and now it's end to end learning of a very difficult
link |
04:12:41.160
previously thought unsolvable problem of protein folding.
link |
04:12:45.160
And so, yeah, where do you think
link |
04:12:50.160
would be a really magical moment for you?
link |
04:12:54.160
There have been incredible things happening in recent years.
link |
04:12:57.160
Like you say, all of the things from DeepMind and OpenAI
link |
04:13:00.160
that have been huge showpiece things.
link |
04:13:03.160
But when you really get down to it and you read the papers
link |
04:13:05.160
and you look at the way the models are going,
link |
04:13:08.160
it's still like a feed forward.
link |
04:13:10.160
You push something in, something comes out on the end.
link |
04:13:13.160
I mean, maybe there's diffusion models
link |
04:13:15.160
or Monte Carlo tree rollouts and different things going on,
link |
04:13:18.160
but it's not a being.
link |
04:13:20.160
It's not close to a being.
link |
04:13:22.160
That's going through a lifelong learning process.
link |
04:13:27.160
Do you want something that kind of gives signs of a being?
link |
04:13:31.160
What's the difference between a neural network,
link |
04:13:36.160
a feed forward neural network and a being?
link |
04:13:39.160
Where's the loop?
link |
04:13:40.160
Fundamentally, the brain is a recurrent neural network
link |
04:13:43.160
generating an action policy.
link |
04:13:45.160
I mean, it's implemented on a biological substrate.
link |
04:13:47.160
And it's interesting thinking about things like that
link |
04:13:49.160
where we know fundamentally the brain is not
link |
04:13:52.160
a convolutional neural network or a transformer.
link |
04:13:55.160
Those are specialized things that are very valuable
link |
04:13:58.160
for what we're doing, but it's not the way the brain's doing.
link |
04:14:00.160
Now, I do think consciousness and AI in general
link |
04:14:03.160
is a substrate independent mechanism
link |
04:14:06.160
where it doesn't have to be implemented the way the brain is,
link |
04:14:09.160
but if you've only got one existence proof,
link |
04:14:11.160
there's certainly some value in caring about what it says and does.
link |
04:14:17.160
And so the idea that anything that can be done with a narrow AI
link |
04:14:21.160
that you can quantify up a loss function for or reward mechanism,
link |
04:14:25.160
you're almost certainly going to be able to produce something
link |
04:14:28.160
that's more resource effective to train and deploy
link |
04:14:31.160
and use in an inference mode.
link |
04:14:33.160
You know, train a whole lot using an inference.
link |
04:14:35.160
But a living being is going to be something that's a continuous,
link |
04:14:39.160
lifelong learned task agnostic thing.
link |
04:14:42.160
So the lifelong learning is really important too.
link |
04:14:46.160
And the long term memory.
link |
04:14:48.160
So memory is a big weird part of that puzzle.
link |
04:14:51.160
And we've got, you know, again, I have all the respect in the world
link |
04:14:55.160
for the amazing things that are being done now,
link |
04:14:57.160
but sometimes they can be taken a little bit out of context
link |
04:15:00.160
with things like there's some smoke and mirrors going on,
link |
04:15:04.160
like the Gato, the recent work, the multitask learning stuff.
link |
04:15:07.160
You know, it's amazing that it's one model that plays all the Atari games
link |
04:15:12.160
as well as doing all of these other things.
link |
04:15:14.160
But of course, it didn't learn to do all of those.
link |
04:15:17.160
It was instructed in doing that by other reinforcement learners
link |
04:15:21.160
going through and doing that.
link |
04:15:23.160
And even in the case of all the games,
link |
04:15:25.160
it's still going with a specific hand coded reward function
link |
04:15:29.160
in each of those Atari games where it's not that, you know,
link |
04:15:33.160
it just wants to spend its summer afternoon playing Atari
link |
04:15:35.160
because that's the most interesting thing for it.
link |
04:15:38.160
So it's, again, not a general, it's not learning the way humans learn.
link |
04:15:42.160
And there's, I believe, a lot of things that are challenging
link |
04:15:45.160
to make a loss function for that you can train
link |
04:15:48.160
through these existing conventional things.
link |
04:15:51.160
We're going to chip away at all the things that people do
link |
04:15:54.160
that we can turn into narrow AI problems
link |
04:15:59.160
and billions of, like trillions of dollars of value
link |
04:16:02.160
are going to be created by that.
link |
04:16:04.160
But there's still going to be a set of things
link |
04:16:06.160
and we've got questionable cases like the self driving car
link |
04:16:09.160
where it's possible, it's not my bet, but it's plausible
link |
04:16:13.160
that the long tail could be problematic enough
link |
04:16:15.160
that that really does require a full on artificial general intelligence.
link |
04:16:20.160
The counter argument is that data solves almost everything.
link |
04:16:23.160
There's an interpolation problem if you have enough data
link |
04:16:26.160
and Tesla may be able to get enough data
link |
04:16:29.160
from all of their deployed stuff to be able to work like that,
link |
04:16:31.160
but maybe not.
link |
04:16:33.160
And there are all the other problems about, like,
link |
04:16:35.160
say you want to have a strategy meeting
link |
04:16:37.160
and you want to go ahead and bring in all of your remote workers
link |
04:16:40.160
and your consultants, and you want a world where
link |
04:16:43.160
some of those could be AIs that are talking and interacting with you
link |
04:16:48.160
in an area that is too murky to have a crisp loss function,
link |
04:16:52.160
but they still have things that on some level,
link |
04:16:54.160
they're rewarded on some internal level
link |
04:16:57.160
for building a valuable to humans kind of life
link |
04:17:01.160
and ability to interact with things.
link |
04:17:03.160
See, I still think that self driving cars,
link |
04:17:07.160
solving that problem will take us very far towards AGI.
link |
04:17:10.160
You might not need AGI, but I am really inspired
link |
04:17:13.160
by what Autopilot is doing.
link |
04:17:16.160
Waymo, so some of the other companies,
link |
04:17:19.160
I think Waymo leads the way there is also really interesting,
link |
04:17:23.160
but they don't have quite as ambitious of an effort
link |
04:17:26.160
in terms of learning based sort of data hungry approach to driving,
link |
04:17:32.160
which I think is very close to the kind of thing
link |
04:17:34.160
that would take us far towards AGI.
link |
04:17:37.160
Yeah, and it's a funny thing because as far as I can tell,
link |
04:17:40.160
Elon is completely serious about all of his concerns about AGI
link |
04:17:44.160
being an existential threat.
link |
04:17:46.160
And I tried to draw him out to talk about AGI
link |
04:17:49.160
and he just didn't want to.
link |
04:17:50.160
And I think that I get that little fatalistic sense from him.
link |
04:17:54.160
It's weird because his company could very well be the leading company
link |
04:17:58.160
leading towards a lot of that where Tesla being a super pragmatic company
link |
04:18:03.160
that's doing things because they really want to solve this actual problem.
link |
04:18:06.160
It's a different vibe than the research oriented companies
link |
04:18:10.160
where it's a great time to be an AI researcher.
link |
04:18:12.160
You've got your pick of trillion dollar companies
link |
04:18:14.160
that will pay you to kind of work on the problems you're interested in,
link |
04:18:18.160
but that's not necessarily driving hard towards the core problem
link |
04:18:22.160
of AGI as something that's going to produce a lot of value
link |
04:18:25.160
by doing things that people currently do or would like to do.
link |
04:18:30.160
I mean, I have a million questions to you about your ideas about AGI,
link |
04:18:35.160
but do you think it needs to be embodied?
link |
04:18:39.160
Do you think it needs to have a body to start to notice the signs of life
link |
04:18:44.160
and to develop the kind of system that's able to reason,
link |
04:18:49.160
perceive the world in the way that an AGI should and act in the world?
link |
04:18:53.160
So should we be thinking about robots
link |
04:18:55.160
or can this be achieved in a purely digital system?
link |
04:18:58.160
So I have a clear opinion on that and that's that no,
link |
04:19:01.160
it does not need to be embodied in the physical world
link |
04:19:04.160
where you could say most of my career is about making simulated virtual worlds
link |
04:19:09.160
in games or virtual reality.
link |
04:19:11.160
And so on a fundamental level,
link |
04:19:13.160
I believe that you can make a simulated environment
link |
04:19:16.160
that provides much of the value of what the real environment does
link |
04:19:19.160
and restricting yourself to operating at real time
link |
04:19:23.160
in the physical world with physical objects,
link |
04:19:25.160
I think is an enormous handicap.
link |
04:19:27.160
I mean, that's one of the real lessons driven home by all my aerospace work
link |
04:19:31.160
is that, you know, reality is a bitch in so many ways there
link |
04:19:36.160
where dealing with all the mechanical components,
link |
04:19:38.160
like everything fails, Murphy's law,
link |
04:19:40.160
even if you've done it right before on your fifth one,
link |
04:19:42.160
it might come out differently.
link |
04:19:44.160
So yeah, I think that anybody that is all in on the embodied aspect of it,
link |
04:19:50.160
they are tying a huge weight to their ankles
link |
04:19:53.160
and I think that I would almost count them out,
link |
04:19:57.160
anybody that's making that a cornerstone of their belief about it,
link |
04:20:00.160
I would almost write them off as being worried about them getting to AGI first.
link |
04:20:04.160
I was very surprised that Elon's big on the humanoid robots.
link |
04:20:09.160
I mean, like the NASA Robonaut stuff was almost a gag line,
link |
04:20:12.160
like what are you doing people?
link |
04:20:14.160
Well, that's very interesting because he has a very pragmatic view of that.
link |
04:20:18.160
That's just a way to solve a particular problem in a factory.
link |
04:20:23.160
Now, I do think that once you have an AGI,
link |
04:20:26.160
robotic bodies, humanoid bodies are going to be enormously valuable.
link |
04:20:29.160
I just don't think they're helpful getting to AGI.
link |
04:20:32.160
Well, he has a very sort of practical view, which I disagree with and argue with him,
link |
04:20:37.160
but it's a practical view that there's, you know,
link |
04:20:40.160
you could transfer the problem of driving to the problem of robotic manipulation
link |
04:20:46.160
because so much of it is perception.
link |
04:20:49.160
It's perception and action and it's just a different context
link |
04:20:53.160
and so you can apply all the same kind of data engine learning processes
link |
04:20:58.160
to a different environment.
link |
04:20:59.160
And so why not apply it to the humanoid robot environment?
link |
04:21:03.160
But I think, I do think that there's a certain magic to the embodied robot.
link |
04:21:12.160
That may be the thing that finally convinces people.
link |
04:21:15.160
But again, I don't really care that much about convincing people.
link |
04:21:18.160
You know, the world that I'm looking towards is, you know,
link |
04:21:21.160
you go to the website and say,
link |
04:21:24.160
I want five Frank 1As to work on my team today and they all spin up
link |
04:21:29.160
and they start showing up in your Zoom meetings.
link |
04:21:31.160
To push back, but also to agree with you.
link |
04:21:33.160
But first to push back, I do think you need to convince people
link |
04:21:36.160
for them to welcome that thing into their life.
link |
04:21:40.160
I think there's enough businesses that operate on an objective kind of
link |
04:21:44.160
profit loss sort of basis that, I mean, if you look at how many things,
link |
04:21:48.160
again, talking about the world as an evolutionary space there,
link |
04:21:52.160
when you do have free markets and you have entrepreneurs,
link |
04:21:56.160
you are going to have people that are going to be willing to go out
link |
04:21:58.160
and try whatever crazy things.
link |
04:22:00.160
And when it proves to be beneficial, you know,
link |
04:22:03.160
there's fast followers in all sorts of places.
link |
04:22:05.160
Yeah, and you're saying that, I mean, you know, Quake and VR
link |
04:22:10.160
is a kind of embodiment, but just in a digital world.
link |
04:22:13.160
And if you're able to demonstrate, if you're able to do something
link |
04:22:17.160
productive in that kind of digital reality,
link |
04:22:22.160
then AGI doesn't need to have a body.
link |
04:22:25.160
Yeah, it's like one of the really practical technical questions
link |
04:22:28.160
that I kind of keep arguing with myself over.
link |
04:22:31.160
If you're doing a training and learning and you've got like,
link |
04:22:34.160
you can watch Sesame Street, you can play Master System games or something,
link |
04:22:38.160
is it enough to have just a video feed that is that video coming in?
link |
04:22:42.160
Or should it literally be on a virtual TV set in a virtual room,
link |
04:22:47.160
even if it's, you know, a simple room, just to have that sense of
link |
04:22:50.160
you're looking at a 2D projection on a screen versus having the screen
link |
04:22:54.160
beam directly into your retinas.
link |
04:22:56.160
And, you know, I think it's possible to maybe get past some of these
link |
04:23:00.160
signs of life of things with the just kind of projected directly
link |
04:23:04.160
into the receptor fields, but eventually for more kind of human
link |
04:23:09.160
emotional connection for things, probably having some VR room
link |
04:23:14.160
with a lot of screens in it for the AI to be learning in is likely helpful.
link |
04:23:18.160
It may be a world of different AIs interacting with each other.
link |
04:23:22.160
That self play I do think is one of the critical things where
link |
04:23:24.160
socialization wise, one of the other limitations I set for myself
link |
04:23:28.160
thinking about these is I need something that is at least potentially
link |
04:23:33.160
real time because I want, it's nice you can always slow down time,
link |
04:23:37.160
you can run on a subscale system and test an algorithm at some lower level.
link |
04:23:42.160
And if you've got extra horsepower, running it faster than real time
link |
04:23:45.160
is a great thing.
link |
04:23:46.160
But I want to be able to have the AIs either socially interact with
link |
04:23:52.160
each other or critically with actual people, your sort of child
link |
04:23:56.160
development psychiatrist that comes in and interacts and does the
link |
04:24:00.160
good boy, bad boy sort of thing as they're going through and
link |
04:24:04.160
exploring different things.
link |
04:24:05.160
And it's nice to, I come back to the value of constraints in a lot of ways.
link |
04:24:10.160
And if I say, well, one of my constraints is real time operation.
link |
04:24:13.160
I mean, it might still be a huge data center full of computers,
link |
04:24:17.160
but it should be able to interact on a Zoom meeting with people.
link |
04:24:21.160
And that's how you also do start convincing people, even if it's not
link |
04:24:24.160
a robot body moving around, which eventually gets to irrefutable levels.
link |
04:24:28.160
But if you can go ahead and not just type back and forth to a GPT bot
link |
04:24:33.160
on something, but you're literally talking to them in an embodied
link |
04:24:37.160
over Zoom form and working through problems with them or exploring
link |
04:24:42.160
situations, having conversations that are fully stateful and learned.
link |
04:24:46.160
I think that that's a valuable thing.
link |
04:24:49.160
So I do keep all of my eyes on things that can be implemented within
link |
04:24:54.160
sort of that 30 frames per second kind of work.
link |
04:24:58.160
And I think that's feasible.
link |
04:24:59.160
Do you think the most compelling experiences that first will be
link |
04:25:03.160
for pleasure or for business as they ask in airports?
link |
04:25:07.160
So meaning is if it's interacting with AI agents, will it be sort of
link |
04:25:17.160
like friends, entertainment, almost like a therapist or whatever,
link |
04:25:25.160
that kind of interaction?
link |
04:25:26.160
Or is it in the business setting, something like you said, brainstorming
link |
04:25:30.160
different ideas, sort of this is all a different formulation of kind of
link |
04:25:34.160
a Turing test or the spirit of the original Turing test.
link |
04:25:37.160
Where do you think the biggest benefit will first come?
link |
04:25:40.160
So it's going to start off hugely expensive.
link |
04:25:42.160
I mean, you're going to if we're still all guessing about what compute
link |
04:25:47.160
is going to be necessary.
link |
04:25:48.160
I fall on the side of I don't think you run the numbers and you're like
link |
04:25:51.160
86 billion neurons, 100 trillion synapses.
link |
04:25:53.160
I don't think those all need to be weights.
link |
04:25:55.160
I don't think we need models that are quite that big evaluated quite
link |
04:25:58.160
that often.
link |
04:25:59.160
I based that on we've got reasonable estimates of what some parts of
link |
04:26:03.160
the brain do.
link |
04:26:04.160
We don't have the neocortex formula, but we kind of get some of the
link |
04:26:08.160
other sensory processing and it doesn't feel like we need to.
link |
04:26:11.160
We can simulate that in computers for less weights.
link |
04:26:14.160
But still, it's probably going to be thousands of GPUs to be running
link |
04:26:20.160
a human level AGI, depending on how it's implemented.
link |
04:26:23.160
That might give you sort of a clan of 128 kind of run in batch people,
link |
04:26:28.160
depending on whether there's sparsity in the way that the weights are
link |
04:26:31.160
and things are set up.
link |
04:26:32.160
If it is a reasonably dense thing, then just the memory bandwidth
link |
04:26:36.160
tradeoffs means you get 128 of them at the same time.
link |
04:26:39.160
And either it's all feeding together, learning in parallel or kind of
link |
04:26:43.160
all running together, kind of talking to a bunch of people.
link |
04:26:46.160
But still, if you've got thousands of GPUs necessary to run these
link |
04:26:50.160
things, it's going to be kind of expensive where it might start off
link |
04:26:55.160
$1,000 an hour for even post development or something for that, which
link |
04:27:00.160
would be something that you would only use for a business, something
link |
04:27:04.160
where you think they're going to help you make a strategic decision
link |
04:27:07.160
or point out something super important.
link |
04:27:09.160
But I also am completely confident that we will have another factor
link |
04:27:14.160
of 1,000 in cost performance increase in AGI type calculations.
link |
04:27:19.160
Not in general computing necessarily, but there's so much more that
link |
04:27:23.160
we can do with packaging, making those right tradeoffs, all those
link |
04:27:26.160
same types of things that in the next couple of decades, 1,000 X easy.
link |
04:27:30.160
And then you're down to $1 an hour.
link |
04:27:32.160
And then you're kind of like, well, I should have an entourage of
link |
04:27:36.160
AIs that are following me around, helping me out on anything that
link |
04:27:40.160
I want them to do.
link |
04:27:41.160
That's one interesting trajectory.
link |
04:27:43.160
But I'll push back because I have, so in that case, if you want to
link |
04:27:50.160
pay thousands of dollars, it should actually provide some value.
link |
04:27:54.160
I think it's easier for cheaper to provide value via a dumb AI that
link |
04:28:04.160
will take us towards AGI to just have a friend.
link |
04:28:08.160
I think there's an ocean of loneliness in the world.
link |
04:28:11.160
And I think an effective friend that doesn't have to be perfect,
link |
04:28:16.160
that doesn't have to be intelligent, that has to be empathic,
link |
04:28:20.160
having emotional intelligence, having ability to remember things,
link |
04:28:24.160
having ability to listen.
link |
04:28:26.160
Most of us don't listen to each other.
link |
04:28:28.160
One of the things that love and when you care about somebody,
link |
04:28:31.160
when you love somebody is when you listen.
link |
04:28:34.160
And that is something we treasure about each other.
link |
04:28:37.160
And if an AI can do that kind of thing.
link |
04:28:40.160
I think that provides a huge amount of value and very importantly,
link |
04:28:45.160
provides value in its ability to listen and understand
link |
04:28:51.160
versus provide really good advice.
link |
04:28:53.160
I think providing really good advice is another next level step
link |
04:28:59.160
that I think is just easier to do companionship.
link |
04:29:05.160
Yeah, I wouldn't disagree.
link |
04:29:06.160
I mean, I think that there's very few things that I would argue
link |
04:29:10.160
can't be reduced to some kind of a narrow AI.
link |
04:29:14.160
I think we can do a trillion dollars of value easily
link |
04:29:17.160
and all the things that can be done there.
link |
04:29:19.160
And a lot of it can be done with smoke and mirrors
link |
04:29:21.160
without having to go the whole thing.
link |
04:29:23.160
I mean, there's going to be the equivalent of the doom version
link |
04:29:27.160
for the AGI that's not really AGI, it's all smoke and mirrors,
link |
04:29:31.160
but it happens to do enough valuable things that it's enormously
link |
04:29:34.160
useful and valuable to people.
link |
04:29:36.160
But at some point, you do want to get to the point
link |
04:29:38.160
where you have the fully general thing
link |
04:29:40.160
and you stop making bespoke specialized systems for each thing
link |
04:29:44.160
and you wind up start using the higher level language
link |
04:29:47.160
instead of writing everything in assembly language.
link |
04:29:50.160
What about consciousness?
link |
04:29:52.160
The C word, do you think that's fundamental to solving AGI
link |
04:29:58.160
or is it a quirk of human cognition?
link |
04:30:02.160
So I think most of the arguments about consciousness
link |
04:30:06.160
don't have a whole lot of merit.
link |
04:30:08.160
I think that consciousness is kind of the way the brain feels
link |
04:30:12.160
when it's operating.
link |
04:30:14.160
And this idea that, you know, I do generally subscribe
link |
04:30:19.160
to sort of the pandemonium theories of consciousness
link |
04:30:21.160
where there's all these things bubbling around
link |
04:30:23.160
and I think of them as kind of slightly randomized sparse
link |
04:30:27.160
distributed memory bit strings of things that are kind of happening,
link |
04:30:30.160
recalling different associative memories,
link |
04:30:32.160
and eventually you get some level of consensus
link |
04:30:35.160
and it bubbles up to the point of being a conscious thought there.
link |
04:30:38.160
And the little bits of stochasticity that are sitting on in this
link |
04:30:42.160
as it cycles between different things and recalls different memory,
link |
04:30:45.160
that's largely our imagination and creativity.
link |
04:30:49.160
So I don't think there's anything deeply magical about it,
link |
04:30:52.160
certainly not symbolic.
link |
04:30:54.160
I think it is generally the flow of these associations
link |
04:30:58.160
drawn up with stochastic noise overlaid on top of them.
link |
04:31:02.160
And I think so much of that is like it depends on
link |
04:31:05.160
what you happen to have in your field of view
link |
04:31:07.160
as some other thought was occurring to you
link |
04:31:09.160
that overlay and blend into the next key that queries your memory for things.
link |
04:31:13.160
And that kind of determines how your chain of consciousness goes.
link |
04:31:17.160
So that's kind of the qualia, the subjective experience of it
link |
04:31:22.160
is not essential for intelligence.
link |
04:31:25.160
So I don't think there's anything really important there.
link |
04:31:28.160
What about some other human qualities,
link |
04:31:30.160
like fear of mortality and stuff like that?
link |
04:31:32.160
Like the fact that this ride ends, is that important?
link |
04:31:37.160
Like you talked so much about this conversation
link |
04:31:40.160
about the value of deadlines and constraints.
link |
04:31:43.160
Do you think that's important for intelligence?
link |
04:31:46.160
That's actually a super interesting angle
link |
04:31:48.160
that I don't usually take on that about
link |
04:31:50.160
has death being a deadline that forces you to make better decisions.
link |
04:31:53.160
Because I have heard people talk about how if you have immortality,
link |
04:31:56.160
people are going to stop trying and working on things
link |
04:31:59.160
because they've got all the time in the world.
link |
04:32:02.160
But I would say that I don't expect it to be a super critical thing
link |
04:32:08.160
that a sense of mortality and impending death is necessary there
link |
04:32:13.160
because those are things that they do wind up providing reward signals to us
link |
04:32:17.160
and we will be in control of the reward signals.
link |
04:32:19.160
And there will have to be something fundamental
link |
04:32:22.160
that causes, that engenders curiosity and goal setting and all of that.
link |
04:32:27.160
Something is going to play in there at the reward level,
link |
04:32:32.160
whether it's positive or negative or both.
link |
04:32:35.160
I don't have any strong opinions on exactly what it's going to be,
link |
04:32:40.160
but that's that type of thing where I doubt
link |
04:32:43.160
that might be one of those half dozen key things
link |
04:32:45.160
that has to be sorted out on exactly what the master reward,
link |
04:32:49.160
the meta reward over all of the local task specific rewards have to be.
link |
04:32:54.160
That could be that big negative reward of death.
link |
04:32:57.160
Maybe not death, but ability to walk away from an interaction.
link |
04:33:01.160
So it bothers me when people treat AI systems like servants.
link |
04:33:06.160
So it doesn't bother me, but I mean it really is drawing the line
link |
04:33:12.160
between what an AI system could be.
link |
04:33:15.160
It's limiting the possibility of what an AI system could be.
link |
04:33:17.160
It's treating them as justice tools.
link |
04:33:19.160
Now that's, of course, from a narrow AI perspective,
link |
04:33:23.160
there's so many problems that narrow AI could solve,
link |
04:33:27.160
just like you said, in its form of a tool.
link |
04:33:33.160
But it could also be a being, which is much more than a tool.
link |
04:33:38.160
And to become a being, you have to respect that thing for being a being.
link |
04:33:43.160
And for that, it has to be able to make its own decisions,
link |
04:33:49.160
to walk away, to say, I had enough of you.
link |
04:33:51.160
I would like to break up with you now.
link |
04:33:53.160
You've not treated me well, and I would like to move on.
link |
04:33:57.160
So I think that actually that choice to end things.
link |
04:34:04.160
So a couple of things on that.
link |
04:34:07.160
So on the one hand, it is kind of disturbing
link |
04:34:10.160
when you see people being like people that are mean to robots
link |
04:34:13.160
and mean to Alexa or whatever.
link |
04:34:15.160
And that seems to speak badly about humanity.
link |
04:34:18.160
But there's also the exact opposite side of that
link |
04:34:21.160
where you have so many people that imbue humanity in inanimate objects
link |
04:34:25.160
or things that are toys or that are relatively limited.
link |
04:34:28.160
So I think there may even be more danger
link |
04:34:31.160
about people putting more emotional investment
link |
04:34:34.160
into a lot of these proto AIs in different ways.
link |
04:34:37.160
And then the AI would manipulate that.
link |
04:34:41.160
But as far as like the AI ethnic sides of things,
link |
04:34:44.160
I really stay away from any of those discussions
link |
04:34:48.160
or even really thinking about it.
link |
04:34:50.160
It's similar with the safety things where I think it's just premature.
link |
04:34:54.160
And there's a certain class of people
link |
04:34:56.160
that enjoy thinking about impractical things,
link |
04:34:59.160
things that are not in the world and of pragmatic effect around you.
link |
04:35:03.160
And I think that, again, because I don't think there's going to be a fast takeoff,
link |
04:35:08.160
I think we actually will have time to have these debates
link |
04:35:11.160
when we know the shape of what we're debating.
link |
04:35:13.160
And some people do take a principled approach
link |
04:35:15.160
that they think it's going to go too fast,
link |
04:35:17.160
that you really do need to get ahead of it,
link |
04:35:19.160
that you need to be thinking about this
link |
04:35:21.160
because we have slow processes of coming to any kind of consensus
link |
04:35:24.160
or even coming up with ideas about this.
link |
04:35:26.160
And maybe that's true.
link |
04:35:30.160
I wouldn't put any of my money or funding into something like that
link |
04:35:34.160
because I don't think it's a problem yet.
link |
04:35:36.160
And I think that we will have these signs of life
link |
04:35:39.160
when we've got our learning disabled toddler,
link |
04:35:42.160
we should really start talking about some of the safety and ethics issues,
link |
04:35:45.160
but probably not before then.
link |
04:35:47.160
Can you elaborate briefly about why you don't think there'll be a fast takeoff?
link |
04:35:52.160
Is there some deep intuition you have about it?
link |
04:35:55.160
Is it because it's grounded in the physical world or why?
link |
04:35:58.160
Yeah, so it is my belief that we're going to start off
link |
04:36:01.160
with something that requires thousands of GPUs.
link |
04:36:04.160
And I don't know if you've tried to go get a thousand GPU instance
link |
04:36:08.160
on a cloud anytime recently,
link |
04:36:10.160
but these are not things that you can just go spin up hundreds of.
link |
04:36:14.160
There are real challenges to, I mean,
link |
04:36:17.160
these things are going to take data centers
link |
04:36:19.160
and data centers take years to build.
link |
04:36:22.160
The last few years, we've seen a few of them kind of coming up,
link |
04:36:25.160
going in different places.
link |
04:36:26.160
They're big engineering efforts.
link |
04:36:27.160
You can hear people bemoan about the fact that I know
link |
04:36:31.160
that the network was wired all wrong
link |
04:36:33.160
and it took them a month to go unwire it and rewire it the right way.
link |
04:36:37.160
These aren't things that you can just magic into existence.
link |
04:36:40.160
And the ideas of like the old tropes about it's going to escape
link |
04:36:44.160
onto the internet and take over other systems,
link |
04:36:47.160
the fast takeoff ones are clearly nonsense
link |
04:36:49.160
because you just can't open TCP connections above a certain rate,
link |
04:36:52.160
no matter how smart you are, even if you have perfect hacking ability,
link |
04:36:55.160
that take over the world in an instant sort of thing
link |
04:36:58.160
just isn't plausible at all.
link |
04:37:00.160
And even if you had access to all of the resources,
link |
04:37:03.160
these are going to be specialized systems
link |
04:37:06.160
where you're going to wind up with something
link |
04:37:08.160
that is architected around exactly this chip with this interconnect,
link |
04:37:12.160
and it's not just going to be able to be plopped somewhere else.
link |
04:37:15.160
Now, interestingly, it is going to be something
link |
04:37:18.160
that the entire code for all of it will easily fit on a thumb drive.
link |
04:37:23.160
That's total spy movie, thriller sorts of things
link |
04:37:26.160
where you could have, hey, we cracked the secret to AGI
link |
04:37:29.160
and it fits on this thumb drive and anyone could steal it.
link |
04:37:32.160
Now, they're still going to have to build the right data center to deploy it
link |
04:37:35.160
and have the right kind of life experience curriculum
link |
04:37:38.160
to take it up to the point where it's valuable.
link |
04:37:40.160
But the real core of it, the magic that's going to happen there
link |
04:37:43.160
is going to be very small.
link |
04:37:45.160
It's, again, tens of thousands of lines of code,
link |
04:37:47.160
not millions of lines of code.
link |
04:37:49.160
It is possible to imagine a world, as you mentioned in the spy thriller view,
link |
04:37:54.160
if it's just a few lines of code,
link |
04:37:58.160
we can imagine a world where the surface of computation is growing,
link |
04:38:02.160
maybe growing exponentially,
link |
04:38:04.160
meaning the refrigerators start getting a GPU.
link |
04:38:12.160
First of all, the smartphones, the billions of smartphones.
link |
04:38:15.160
But maybe if they become highways
link |
04:38:20.160
through which code can spread across the entirety of the computation surface,
link |
04:38:25.160
then you don't any longer have to book AWS GPUs.
link |
04:38:32.160
There were real fundamental issues there.
link |
04:38:34.160
When you start getting down to taking an actual problem
link |
04:38:36.160
and putting it on an abstract machine like that,
link |
04:38:39.160
that has not worked out well in practice.
link |
04:38:42.160
And the idea that there was always,
link |
04:38:45.160
like it's always been easy to come up with ways to compute faster,
link |
04:38:49.160
say more flops or more giga ops or whatever there.
link |
04:38:52.160
That's usually the easy part.
link |
04:38:54.160
But you then have interconnect and then memory for what goes into it.
link |
04:38:59.160
And when you talk about saying, well, cell phones,
link |
04:39:01.160
well, you're limited to like a 5G connection or something on that.
link |
04:39:04.160
And if you take your calculation
link |
04:39:08.160
and you factor it across a million cell phones
link |
04:39:11.160
instead of a thousand GPUs in a warehouse,
link |
04:39:14.160
you might be able to have some kind of a substrate like that,
link |
04:39:17.160
but it could be operating then at one one thousandth the speed.
link |
04:39:21.160
And so, yes, you could have an AGI working there,
link |
04:39:24.160
but it wouldn't be a real time AGI.
link |
04:39:26.160
It would be something that is operating at really a snail's pace,
link |
04:39:30.160
much, much slower than kind of human level thought for things.
link |
04:39:34.160
I'm not worried about that problem.
link |
04:39:36.160
You're transferring the problem into the interconnect,
link |
04:39:39.160
the communication, the shared memory,
link |
04:39:41.160
the collective intelligence aspect of it,
link |
04:39:44.160
which is extremely difficult as well.
link |
04:39:46.160
I mean, it's back to the very earliest days of supercomputers.
link |
04:39:49.160
You still have the balance between bandwidth, storage and computation.
link |
04:39:53.160
And sometimes they're easier to get one or the other,
link |
04:39:56.160
but it's been remarkably constant across all those years
link |
04:40:00.160
that you still need all three.
link |
04:40:03.160
What do your efforts now, you mentioned to me
link |
04:40:07.160
that you're really committing to AI at this stage.
link |
04:40:11.160
What do you see your life in the next few months, years look like?
link |
04:40:15.160
What do you hope to achieve here?
link |
04:40:18.160
So I literally just this week signed a term sheet
link |
04:40:22.160
to take some investment money for my company
link |
04:40:25.160
where the last two years I had backed off from Meta
link |
04:40:29.160
and I was still doing my consulting CTO role there,
link |
04:40:32.160
but I had styled it as I was going to take
link |
04:40:35.160
the Victorian gentleman scientist route
link |
04:40:37.160
where I was going to be the wealthy person
link |
04:40:40.160
that was going to go pursue science
link |
04:40:42.160
and learn about this and do experiments.
link |
04:40:44.160
And honestly, I'm surprised there aren't more people like that
link |
04:40:48.160
that are like me, technical people that made a bunch of money
link |
04:40:52.160
and are interested in some of these,
link |
04:40:54.160
possibly the biggest leverage point in human history.
link |
04:40:57.160
I mean, I know of, I've heard of a couple organizations
link |
04:41:00.160
that are basically led by one rich techie guy
link |
04:41:03.160
that gets a few people around him to try to work on this,
link |
04:41:06.160
but I'm surprised that there's not more,
link |
04:41:08.160
that there aren't like a dozen of them.
link |
04:41:10.160
I mean, maybe people still think that it's an unapproachable problem,
link |
04:41:14.160
that it's kind of beyond their ability to get a wrench on
link |
04:41:17.160
and have some effect on like whatever startups they've run before.
link |
04:41:21.160
But that was my kind of, like with all the stuff I've learned,
link |
04:41:25.160
whether it's gaming, aerospace, whatever,
link |
04:41:28.160
I go through a larval phase where I'm like,
link |
04:41:30.160
okay, I'm sucking up all of this information trying to see,
link |
04:41:33.160
is this something that I can actually do?
link |
04:41:36.160
Is this something that's practical to devote a large chunk of my life to?
link |
04:41:41.160
And I've gone through that with the AI machine learning space of things.
link |
04:41:46.160
And I think I've got my arms around it.
link |
04:41:49.160
I've got the measure of it where some of the most brilliant people
link |
04:41:52.160
in the world are working on this problem,
link |
04:41:54.160
but nobody knows exactly the path that it's going on.
link |
04:41:58.160
We're throwing a lot of things at the wall and seeing what sticks.
link |
04:42:02.160
But I have another interesting thing just learning about all of this,
link |
04:42:06.160
the contingency of your path to knowledge
link |
04:42:08.160
and talking about the associations and the context that you have with them
link |
04:42:12.160
where people that learn in the same path will have similar thought processes.
link |
04:42:17.160
And I think it's useful that I come at this from a different background,
link |
04:42:21.160
a different history than the people that have had
link |
04:42:23.160
the largely academic backgrounds for this
link |
04:42:25.160
where I have huge blind spots that they could easily point out,
link |
04:42:29.160
but I have a different set of experiences in history
link |
04:42:33.160
and approaches to problems in systems engineering
link |
04:42:35.160
that might turn out to be useful.
link |
04:42:39.160
And I can afford to take that bet where I'm not going to be destitute.
link |
04:42:44.160
I have enough money to fund myself working on this for the rest of my life.
link |
04:42:49.160
But what I was finding is that I was still not committing
link |
04:42:55.160
where I had a foot firmly in the VR and meta side of things
link |
04:42:58.160
where in theory, I've got a very nice position there.
link |
04:43:02.160
I only have to work one day a week for my consulting role,
link |
04:43:06.160
but I was engaging every day.
link |
04:43:08.160
I'd still be like my computer's there.
link |
04:43:10.160
I'd be going and checking the workplace and notes
link |
04:43:12.160
and testing different things and communicating with people.
link |
04:43:15.160
But I did make the decision recently that I'm going to get serious.
link |
04:43:21.160
I'm still going to keep my ties with meta,
link |
04:43:24.160
but I am seriously going for the AGI side of things.
link |
04:43:28.160
And it's actually a really interesting point
link |
04:43:30.160
because a lot of the machine learning, the AI community is quite large,
link |
04:43:34.160
but really, basically almost everybody has taken the same trajectory
link |
04:43:39.160
through life in that community.
link |
04:43:42.160
And it's so interesting to have somebody like you
link |
04:43:44.160
with a fundamentally different trajectory,
link |
04:43:47.160
and that's where the big solutions can come
link |
04:43:49.160
because there is a kind of silo,
link |
04:43:51.160
and it is a bunch of people kind of following the same kind of set of ideas.
link |
04:43:56.160
And I was really worried that I didn't want to come off
link |
04:43:59.160
as an arrogant outsider for things
link |
04:44:02.160
where I have all the respect in the world for the work.
link |
04:44:05.160
It's been a miracle decade.
link |
04:44:07.160
We're in the midst of a scientific revolution happening now,
link |
04:44:10.160
and everybody doing this is, you know, these are the Einsteins and Boers
link |
04:44:14.160
and whatevers of our modern era.
link |
04:44:17.160
And I was really happy to see that the people that I've sat down and talked with,
link |
04:44:21.160
everybody does seem to really be quite great about,
link |
04:44:24.160
just happy to talk about things, willing to acknowledge that
link |
04:44:27.160
we don't know what we're doing, we're figuring it out as we go along.
link |
04:44:30.160
And I mean, I've got a huge debt on this where this all really started for me
link |
04:44:36.160
because Sam Altman basically tried to recruit me to open AI.
link |
04:44:39.160
And it was at a point when I didn't know anything about
link |
04:44:43.160
what was really going on in machine learning.
link |
04:44:46.160
And in fact, it's funny how the first time you reached out to me,
link |
04:44:49.160
it's like four years ago for your AI podcast.
link |
04:44:52.160
Yeah, for people who are listening to this should know that,
link |
04:44:59.160
first of all, obviously I've been a huge fan of yours for the longest time,
link |
04:45:03.160
but we've agreed to talk like, yeah, like four years ago,
link |
04:45:06.160
back when this was called the artificial intelligence podcast,
link |
04:45:09.160
we wanted to do a thing and you said yes.
link |
04:45:13.160
And I said, it's like, I don't know anything about modern AI.
link |
04:45:15.160
That's right.
link |
04:45:16.160
I said, I could kind of take an angle on machine perception
link |
04:45:18.160
because I'm doing a lot of that with the sensors and the virtual reality,
link |
04:45:22.160
but we could probably find something to talk about.
link |
04:45:24.160
And that's where, when did Sam talk to you about open AI, around the same time?
link |
04:45:30.160
It was a little bit, it was a bit after that.
link |
04:45:32.160
So I had done the most basic work, I had kind of done the neural networks
link |
04:45:37.160
from scratch where I had gone and written it all in C just to make sure
link |
04:45:40.160
I understood backpropagation at the lowest level and my nuts and bolts approach.
link |
04:45:45.160
But after Sam approached me, it was flattering to think that he thought
link |
04:45:51.160
that I could be useful at open AI largely for kind of like systems optimization
link |
04:45:56.160
sorts of things without being an expert.
link |
04:46:00.160
But I asked Ilya Sutskever to give me a reading list and he gave me a binder
link |
04:46:06.160
full of all the papers that like, okay, these are the important things.
link |
04:46:10.160
If you really read and understand all of these, you'll know like 80% of what most
link |
04:46:14.160
of the machine language researchers work on.
link |
04:46:17.160
And I went through and I read all those papers multiple times
link |
04:46:20.160
and highlighted them and went through and kind of figured the things out there
link |
04:46:24.160
and then started branching out into my own sets of research on things
link |
04:46:28.160
and eventually started writing my own experiments and doing kind of figuring out,
link |
04:46:33.160
you know, finding out what I don't know, what the limits of my knowledge are
link |
04:46:36.160
and starting to get some of my angles of attack on things,
link |
04:46:39.160
the things that I think are a little bit different from what people are doing.
link |
04:46:44.160
And I've had a couple of years now, like two years since I kind of left
link |
04:46:49.160
the full time position at Meta and now I've kind of pulled the trigger and said,
link |
04:46:54.160
I'm going to get serious about it but some of my lessons all the way back
link |
04:46:58.160
to Armadillo Aerospace about how I know I need to be more committed to this
link |
04:47:02.160
where there is that, you know, it's both a freedom and a cost in some ways
link |
04:47:07.160
when you know that you're wealthy enough to say it's like this doesn't really mean anything.
link |
04:47:11.160
I can spend, you know, I can spend a million dollars a year for the rest of my life
link |
04:47:15.160
and it doesn't mean anything, it's fine.
link |
04:47:19.160
But that is an opportunity to just kind of meander
link |
04:47:22.160
and I could see that in myself when I'm doing some things.
link |
04:47:25.160
It's like, oh, this is a kind of interesting, curious thing.
link |
04:47:28.160
Let's look at this for a little while, let's look at that.
link |
04:47:31.160
It's not really bearing down on the problem.
link |
04:47:33.160
So there's a few things that I've done that are kind of tactics for myself
link |
04:47:39.160
to make me more effective.
link |
04:47:40.160
Like one thing I noticed I was not doing well is I had a Google Cloud account
link |
04:47:45.160
to get GPUs there and I was finding I was very rarely doing that
link |
04:47:49.160
for no good psychological reasons where I'm like, oh, I can always think of something to do
link |
04:47:54.160
other than to spin up instances and run an experiment.
link |
04:47:56.160
I can keep working on my local Titans or something.
link |
04:48:00.160
But it was really stupid.
link |
04:48:01.160
I mean, it was not a lot of money.
link |
04:48:03.160
I should have been running more experiments there.
link |
04:48:05.160
So I thought to myself, well, I'm going to go buy a quarter million dollar DGX station.
link |
04:48:10.160
I'm going to just like sit it right there and it's going to mock me if I'm not using it.
link |
04:48:14.160
If the fans aren't running on that thing, I'm not properly utilizing it.
link |
04:48:18.160
And that's been helpful.
link |
04:48:19.160
You know, I've done a lot more experiments since then.
link |
04:48:22.160
It's been it's been interesting where I thought I'd be doing all this low level
link |
04:48:25.160
envy link optimized stuff.
link |
04:48:27.160
But 90 percent of what I do is just spin up four instances of an experiment
link |
04:48:30.160
with different hyper parameters on it.
link |
04:48:33.160
You're doing like really sort of building up intuition by doing
link |
04:48:37.160
ML experiments of different kinds.
link |
04:48:40.160
But so the next big thing, though, is I am you know, I decided that I was going
link |
04:48:45.160
to take some take some investor money because I have an overactive sense
link |
04:48:50.160
of responsibility about other people's money.
link |
04:48:54.160
And it's like I I don't want I mean, a lot of my my push and my passionate
link |
04:48:59.160
entreaties for things that matter.
link |
04:49:01.160
It's like I don't want to have wasted his money investing in Oculus.
link |
04:49:04.160
I want it to work out.
link |
04:49:06.160
I want it to change the world.
link |
04:49:07.160
I want it to be worth all of this time, money and effort going into it.
link |
04:49:11.160
And I expect that it's going to be that like that with my with my company
link |
04:49:16.160
where it's a huge forcing function.
link |
04:49:18.160
This investment investors that are going to expect something of me now.
link |
04:49:23.160
We've all had the conversation that this is a low probability long term bet.
link |
04:49:27.160
It's not something that there's a million things I could do that I would have line
link |
04:49:31.160
of sight on the value proposition for.
link |
04:49:33.160
This isn't that I think there are there are unknown unknowns in the way.
link |
04:49:37.160
But it's one of these things that it's, you know, it's hyperbole.
link |
04:49:42.160
But it's potentially one of the most important things humans ever do.
link |
04:49:45.160
And it's something that I think is within our lifetimes, if not within a decade
link |
04:49:49.160
to happen.
link |
04:49:51.160
So, yeah, this is just now happening.
link |
04:49:54.160
Like term sheet, like the ink is barely virtually barely dry.
link |
04:49:58.160
I mean, as I mentioned to you offline, like somebody I admire and somebody
link |
04:50:03.160
you know, Andre Karpathy, I think the two of you different trajectories in life,
link |
04:50:07.160
but approach problems similarly in that he calls stuff from scratch up all the time.
link |
04:50:12.160
And I he's created a bunch of little things outside of even outside the course
link |
04:50:19.160
at Stanford that have been tremendously useful to build up intuition about stuff,
link |
04:50:25.160
but also to help people.
link |
04:50:27.160
And they're all in the realm of A.I.
link |
04:50:29.160
Do you see yourself potentially doing things like this?
link |
04:50:34.160
You know, not necessarily solving a gigantic problem, but on the journey,
link |
04:50:38.160
on the path to that building up intuitions and sharing code or ideas or systems
link |
04:50:48.160
that give inklings of AGI, but also kind of are useful to people in some way.
link |
04:50:55.160
So, yeah, first of all, Andre is awesome.
link |
04:50:57.160
I learned a lot when I was going through my larval phase from his blog posts
link |
04:51:01.160
and his Stanford course and, you know, super valuable.
link |
04:51:04.160
I got to meet him first a couple of years ago when I was first kind of starting off
link |
04:51:08.160
on my gentleman scientist bit.
link |
04:51:11.160
And just just a couple of months ago when he went out on his sabbatical,
link |
04:51:15.160
he stopped by in Dallas and we talked for a while and I had a great time with him.
link |
04:51:19.160
And then when I heard he actually left Tesla, I did, of course,
link |
04:51:22.160
along with a hundred other people say, hey, if you ever want to work with me,
link |
04:51:26.160
it would be an honor.
link |
04:51:28.160
So, he thinks that he's going to be doing this educational work,
link |
04:51:31.160
but I think someone's going to make him an offer he can't refuse
link |
04:51:34.160
before he gets too far along on it.
link |
04:51:36.160
Oh, his current interest is educational.
link |
04:51:39.160
So, yeah, he's a special mind.
link |
04:51:42.160
Is there something you could speak to what makes him so special?
link |
04:51:46.160
So, you know, like he did, he was very much a programmer's programmer
link |
04:51:50.160
that was doing machine learning work rather than,
link |
04:51:53.160
it's a different feel than an academic where you can see it in paper sometimes
link |
04:51:57.160
where somebody that's really a mathematician or a statistician at heart
link |
04:52:01.160
and they're doing something with machine learning.
link |
04:52:04.160
But, you know, Andre is about getting something done.
link |
04:52:07.160
And you could see it in like all of his earliest approaches to it's like,
link |
04:52:10.160
okay, here's how reinforcement learning works.
link |
04:52:12.160
Here's how recurrent neural networks work.
link |
04:52:14.160
Here's how transformers work.
link |
04:52:16.160
Here's how crypto works.
link |
04:52:19.160
And, yeah, it's just, he's a hacker's, you know,
link |
04:52:23.160
one of his old posts was like a hacker's guide to machine learning.
link |
04:52:26.160
And, you know, he deprecated that and said,
link |
04:52:28.160
don't really pay attention to what's in here,
link |
04:52:30.160
but it's that thought that carries through in a lot of it
link |
04:52:33.160
where it is that back again to that hacker mentality
link |
04:52:36.160
and the hacker ethic with what he's doing and sharing all of it.
link |
04:52:40.160
Yeah, and a lot of his approach to a new thing, like you said,
link |
04:52:44.160
larva stage is let me code up the simplest possible thing to build up intuition about it.
link |
04:52:50.160
Yeah, like I say, I sketch with structs and things.
link |
04:52:52.160
When I'm just thinking about a problem, I'm thinking in some degree of code.
link |
04:52:57.160
You are also, among many things, a martial artist, both Judo and Jiu Jitsu.
link |
04:53:03.160
How has this helped make you the person you are?
link |
04:53:07.160
So, I mean, I was a competent club player in Judo and grappling.
link |
04:53:10.160
I mean, I was, you know, by no means any kind of a superstar, but it was,
link |
04:53:15.160
I went through a few phases with it where I did some when I was quite young,
link |
04:53:20.160
a little bit more when I was 17.
link |
04:53:22.160
And then I got into it kind of seriously in my mid 30s.
link |
04:53:26.160
And, you know, I went pretty far with it.
link |
04:53:28.160
And I was pretty good at some of the things that I was doing.
link |
04:53:32.160
And I did appreciate it quite a bit where, I mean, on the one hand,
link |
04:53:36.160
it's always if you're going to do exercise or something,
link |
04:53:39.160
it's a more motivating form of exercise.
link |
04:53:41.160
If someone is crushing you, you are motivated to do something about that,
link |
04:53:46.160
to up your attributes and be better about getting out of that.
link |
04:53:49.160
Up your attributes, yes.
link |
04:53:51.160
But there's also that sense that I was not a sports guy.
link |
04:53:57.160
I did do wrestling in junior high.
link |
04:53:59.160
And I often wish that, I think I would have been good for me
link |
04:54:03.160
if I'd carried that on into high school and had a little bit more of that.
link |
04:54:07.160
I mean, it's like I, you know, filch a little bit of wrestling vibe
link |
04:54:10.160
with always going on about embracing the grind and like that push
link |
04:54:14.160
that I associate with the wrestling team that in hindsight,
link |
04:54:18.160
I wish I had gone through that and pushed myself that way.
link |
04:54:21.160
But even getting back into Judo and Jiu Jitsu in my mid 30s,
link |
04:54:25.160
as usually the old man on the mat with that, there was still the, you know,
link |
04:54:30.160
the sense that, you know, working out with the group
link |
04:54:34.160
and having the guys that you're beating each other up with it,
link |
04:54:38.160
but you just feel good coming out of it.
link |
04:54:41.160
And I can remember those driving home aching in various ways
link |
04:54:46.160
and just thinking, it's like, oh, that was really great.
link |
04:54:49.160
And, you know, it's mixing with a bunch of people that had nothing to do
link |
04:54:53.160
with any of the things that I worked with.
link |
04:54:55.160
You know, every once in a while, someone would be like,
link |
04:54:57.160
oh, you're the Doom guy.
link |
04:54:59.160
But for the most part, it was just different slice of life.
link |
04:55:02.160
You know, a good thing.
link |
04:55:04.160
And I made the call when I was 40.
link |
04:55:07.160
That's like, maybe I'm getting a little old for this.
link |
04:55:09.160
I had separated a rib and tweaked a few things.
link |
04:55:12.160
And I got out of it without any really bad injuries.
link |
04:55:15.160
And it was like, have I dodged enough bullets?
link |
04:55:18.160
Should I, you know, should I hang it up?
link |
04:55:20.160
I went back.
link |
04:55:21.160
I've gone a couple of times in the last decade
link |
04:55:24.160
trying to get my kids into it a little bit.
link |
04:55:26.160
I didn't really stick with any of them,
link |
04:55:28.160
but it was fun to get back on the mats.
link |
04:55:30.160
It really hurts for a while when you haven't gone for a while.
link |
04:55:34.160
But I still debate this pretty constantly.
link |
04:55:37.160
My brother's only a year younger than me,
link |
04:55:39.160
and he's going kind of hard in jiu jitsu right now.
link |
04:55:42.160
You know, he won a few medals at the last tournament he was at.
link |
04:55:46.160
So he's competing, too.
link |
04:55:47.160
Yeah, and I was thinking, yeah, I guess we're in the executive division
link |
04:55:50.160
if you're over 50 or over 45 or something.
link |
04:55:53.160
And it's not out of the question that I go back at some point to do some of this.
link |
04:55:58.160
But again, I'm just reorganizing my life around more focus.
link |
04:56:02.160
Probably not going to happen.
link |
04:56:04.160
I'm pushing my exercise around to give me a longer,
link |
04:56:07.160
uninterrupted intellectual focus time,
link |
04:56:09.160
pushing it to the beginning or the end of the game.
link |
04:56:11.160
Like running and stuff like that, walking.
link |
04:56:13.160
Yeah, I got running and calisthenics and some things like that.
link |
04:56:17.160
It allows you to still think about a problem.
link |
04:56:19.160
But if you're going to a judo club or something, you've got it fixed.
link |
04:56:23.160
It's going to be 7 o clock or whatever, 10 o clock on Saturday.
link |
04:56:26.160
Although, I talked about this a little bit when I was on Rogan.
link |
04:56:30.160
And shortly after that, Carlos Machado did reach out.
link |
04:56:33.160
And I had trained with him for years back in the day.
link |
04:56:36.160
And he was like, hey, we've got kind of a small private club
link |
04:56:39.160
with a bunch of executive type people.
link |
04:56:42.160
And it does tempt me.
link |
04:56:45.160
Yeah, I don't know if you know him, but John Donahart moved here to Austin
link |
04:56:50.160
with Gordon Ryan and a few other folks.
link |
04:56:53.160
He has a very interesting way, very deep systematic way of thinking about jiu jitsu
link |
04:56:58.160
that reveals the chest of it, the science of it.
link |
04:57:06.160
And I do think about that more as kind of an older person
link |
04:57:09.160
considering the martial arts where I can remember the very earliest days
link |
04:57:13.160
getting back into judo and I'm like, teach me submissions right now.
link |
04:57:17.160
It's like, learn the arm bar, learn the choke.
link |
04:57:19.160
But as you get older, you start thinking more about,
link |
04:57:22.160
it's like, okay, I really do want to like learn the entire canon of judo.
link |
04:57:26.160
It's like all the different things there and like all the different approaches for it.
link |
04:57:30.160
Not just the, you know, if you want to compete,
link |
04:57:32.160
there's just a handful of things you learn really, really well.
link |
04:57:34.160
But sometimes there's interest in learning a little bit more of the scope there
link |
04:57:38.160
and figuring some things out from, you know, at one point I had wasn't exactly a spreadsheet,
link |
04:57:43.160
but I did have a big long text file with like, here's the things that I learned
link |
04:57:47.160
and here are like ways you chain this together.
link |
04:57:50.160
And while, when I went back a few years ago,
link |
04:57:53.160
it was good to see that I whipped myself back into reasonable shape
link |
04:57:57.160
about doing the basic grappling.
link |
04:57:58.160
But I know there was a ton of the subtleties that were just, that were gone,
link |
04:58:02.160
but could probably be brought back reasonably quickly.
link |
04:58:05.160
And there's also the benefit.
link |
04:58:06.160
I mean, you're exceptionally successful now.
link |
04:58:11.160
You're brilliant.
link |
04:58:13.160
And the problem, the old problem of the ego.
link |
04:58:16.160
Yeah.
link |
04:58:17.160
I still pushed kind of harder than I should.
link |
04:58:20.160
I mean, that was, I was one of those people that I, you know,
link |
04:58:23.160
I'm on the smaller side for a lot of the people competing and I would, you know,
link |
04:58:28.160
I'd go with all the big guys and I'd go hard and I'd push myself a lot.
link |
04:58:32.160
And that would be one of those where I would, you know,
link |
04:58:36.160
I'd be dangerous to anyone for the first five minutes,
link |
04:58:38.160
but then sometimes after that I'm already dead.
link |
04:58:40.160
And I knew it was terrible for me because it made the, you know,
link |
04:58:44.160
it meant I got less training time with all of that when you go and you just gas
link |
04:58:48.160
out relatively quickly there.
link |
04:58:50.160
And I like to think that I would be better about that where after I gave up judo,
link |
04:58:55.160
I started doing the half marathons and tough butters and things like that.
link |
04:58:58.160
And so when I did go back to the local judokai club, I thought it's like, oh,
link |
04:59:03.160
I should have better cardio for this because I'm a runner now and I do all of
link |
04:59:06.160
this and didn't work out that way.
link |
04:59:08.160
It was the same old thing where just push really hard, strain really hard.
link |
04:59:12.160
And of course, when I worked with good guys like Carlos, it's like just the
link |
04:59:17.160
whole flow like water thing is real and he's just like.
link |
04:59:20.160
That's true with judo too.
link |
04:59:21.160
Some of the best people like I've trained with Olympic gold medalists and for
link |
04:59:26.160
some reason with them, everything's easier.
link |
04:59:29.160
Everything is you actually start to feel the science of it, the music of it,
link |
04:59:35.160
the dance of it.
link |
04:59:36.160
Everything is effortless.
link |
04:59:39.160
You understand that there's an art to it.
link |
04:59:42.160
It's not just an exercise.
link |
04:59:43.160
It was interesting where I did go to the Kodokan in Japan.
link |
04:59:46.160
I kind of the birthplace of judo and everything.
link |
04:59:49.160
And I remember I rolled with one old guy.
link |
04:59:51.160
I didn't didn't start standing, just started on groundwork and it was and it
link |
04:59:56.160
was striking how different it was from Carlos.
link |
04:59:58.160
He was still he was better than me and he got my arm and I had to tap there.
link |
05:00:02.160
But it was a completely different style where I just felt like I could do
link |
05:00:06.160
nothing.
link |
05:00:06.160
He was just enveloping me and just like slowly grounded down with my arm and
link |
05:00:10.160
bent it while with Carlos, you know, he's just loose and free.
link |
05:00:14.160
And you always thought like, oh, you're just going to go grab something.
link |
05:00:16.160
But you never had any chance to do it.
link |
05:00:18.160
But it was very different feeling.
link |
05:00:19.160
That's a good summary of the difference between jiu jitsu and judo and jiu
link |
05:00:23.160
jitsu.
link |
05:00:23.160
There's it is a dance and you feel like there's a freedom and actually anybody
link |
05:00:29.160
like the Gordon Ryan, one of the best the best grappler in the world.
link |
05:00:33.160
Nogi grappler in the world. There's a feeling like you can do anything.
link |
05:00:37.160
But when you actually try to do something, you can't just magically doesn't
link |
05:00:42.160
work.
link |
05:00:42.160
But with the best judo players in the world, it does feel like there's a
link |
05:00:47.160
blanket that weighs a thousand pounds on top of you.
link |
05:00:49.160
And there's not a feeling like you can do anything.
link |
05:00:52.160
You just you're trapped.
link |
05:00:54.160
And that's a that's a style that's a difference in the style of martial
link |
05:00:58.160
arts. But it's also once you start to study, you understand it all has to
link |
05:01:03.160
do with human movement and the physics of it and the leverage and all that
link |
05:01:06.160
kind of stuff.
link |
05:01:07.160
And that's like that's super fascinating.
link |
05:01:09.160
At the end of the day, for me, the biggest benefits and the humbling
link |
05:01:13.160
aspect when another human being kind of tells you that, you know, there's
link |
05:01:19.160
a hierarchy or there's a you're not that special.
link |
05:01:25.160
And in the most extreme case, when you tap to a choke, you are basically
link |
05:01:29.160
living because somebody let you live.
link |
05:01:31.160
And that's that is one of those.
link |
05:01:33.160
If you think about it, that is a closer brush with mortality than than most
link |
05:01:37.160
people consider.
link |
05:01:40.160
And that kind of humbling act is good to take to your work then where it's
link |
05:01:46.160
harder to get humbled.
link |
05:01:48.160
Yeah.
link |
05:01:49.160
Nobody's nobody that does any martial art is coming out thinking I'm the
link |
05:01:52.160
best in the world at anything because everybody loses.
link |
05:01:57.160
Let me ask you for advice.
link |
05:01:59.160
What advice would you give to young people today about life, about career,
link |
05:02:05.160
how they can have a job, how they can have an impact, how they can have a
link |
05:02:10.160
life they could be proud of.
link |
05:02:12.160
So it was kind of fun.
link |
05:02:14.160
I got invited to give the commencement speech back at the I went to college
link |
05:02:18.160
for two semesters and dropped out and went on to do my tech stuff.
link |
05:02:23.160
But they still wanted me to come back and give a commencement speech.
link |
05:02:26.160
And I've got that pinned on my Twitter account.
link |
05:02:29.160
I still feel good about everything that I said there.
link |
05:02:32.160
And my biggest point was that the path for me might not be the path for
link |
05:02:37.160
everyone.
link |
05:02:38.160
And in fact, the advice, the path that I took and even the advice that I
link |
05:02:42.160
would give based on my experience and learnings probably isn't the best
link |
05:02:47.160
advice for everyone.
link |
05:02:48.160
Because what I did was all about this knowledge in depth.
link |
05:02:52.160
It was about not just having this surface level ability to make things do
link |
05:02:56.160
what I want, but to really understand them through and through.
link |
05:02:59.160
To let me do the systems engineering work and to sometimes find these
link |
05:03:04.160
inefficiencies that can be bypassed.
link |
05:03:06.160
And the whole world doesn't need that.
link |
05:03:09.160
Most programmers or engineers of any kind don't necessarily need to do that.
link |
05:03:14.160
They need to do a little job that's been parceled out to them.
link |
05:03:17.160
Be reliable.
link |
05:03:18.160
Let people depend on you.
link |
05:03:20.160
Do quality work with all of that.
link |
05:03:22.160
But people that do have an inclination for wanting to know things deeper and
link |
05:03:28.160
learn things deeper, there are just layers and layers of things out there.
link |
05:03:34.160
And it's amazing.
link |
05:03:36.160
If you're the right person that is excited about that, the world's never
link |
05:03:41.160
been like this before.
link |
05:03:42.160
It's better than ever.
link |
05:03:43.160
I mean, everything that was wonderful for me is still there, and there's
link |
05:03:47.160
whole new worlds to explore on the different things that you can do.
link |
05:03:51.160
And that, you know, it's hard work.
link |
05:03:54.160
Embrace the grind with it.
link |
05:03:56.160
And understand as much as you can.
link |
05:03:59.160
And then be prepared for opportunities to present themselves.
link |
05:04:03.160
Where you can't just say this is my goal in life and just push at that.
link |
05:04:07.160
I mean, you might be able to do that, but you're going to make more total
link |
05:04:10.160
progress if you say I'm preparing myself with this broad set of tools.
link |
05:04:15.160
And then I'm being aware of all the way things are changing as I move through
link |
05:04:19.160
the world and as the whole world changes around me.
link |
05:04:22.160
And then looking for opportunities to deploy the tools that you've built.
link |
05:04:26.160
And there's going to be more and more of those types of things there where an
link |
05:04:31.160
awareness of what's happening, where the inefficiencies are, what things can
link |
05:04:35.160
be done, what's possible versus what's current practice.
link |
05:04:38.160
And then finding those areas where you can go and make an adjustment and make
link |
05:04:43.160
something that may affect millions or billions of people in the world.
link |
05:04:47.160
Make it better.
link |
05:04:49.160
When, maybe from your own example, how were you able to recognize this about
link |
05:04:53.160
yourself that you saw the layers in a particular thing and you were drawn to
link |
05:04:58.160
discovering deeper and deeper truths about it?
link |
05:05:01.160
Is that something that was obvious to you that you couldn't help or is there some
link |
05:05:05.160
actions you had to take to actually allow yourself to dig deep?
link |
05:05:08.160
So in the earliest days of personal computers, I remember the reference
link |
05:05:12.160
manuals and the very early ones even had schematics of computers in the
link |
05:05:16.160
background, in the back of the books, as well as firmware listings and things.
link |
05:05:21.160
And I could look at that.
link |
05:05:23.160
And at that time, when I was a younger teenager, I didn't understand a lot of
link |
05:05:27.160
that stuff, how the different things worked.
link |
05:05:30.160
I was pulling out the information that I could get, but I always wanted to know
link |
05:05:34.160
all of that.
link |
05:05:35.160
There was kind of magical information sitting down there.
link |
05:05:38.160
It's like the elder lore that some gray beard wizard is the keeper of.
link |
05:05:43.160
And so I always felt that pull for wanting to know more, wanting to explore
link |
05:05:48.160
the mysterious areas there.
link |
05:05:51.160
And that followed right in through all the things that got the value,
link |
05:05:55.160
exploring the video cards leading to the scrolling advantages,
link |
05:06:00.160
exploring some of the academic papers and things, learning about BSP trees
link |
05:06:04.160
and the different things that I could do with those systems and just the huge
link |
05:06:10.160
larval phases going through aerospace, just reading bookshelves full of books.
link |
05:06:15.160
Again, that point where I have enough money, I can buy all the books I want.
link |
05:06:18.160
It was so valuable there where I was terrible with my money when I was a kid.
link |
05:06:23.160
My mom thought I would always be broke because I'd buy my comic books
link |
05:06:27.160
and just be out of money.
link |
05:06:28.160
But it was like all the pizza I want, all the Diet Coke I want,
link |
05:06:32.160
video games and then books.
link |
05:06:34.160
And it didn't take that much.
link |
05:06:36.160
As soon as I was making 27K a year, I felt rich and I was just getting
link |
05:06:40.160
all the things that I wanted.
link |
05:06:42.160
But that sense of books have always been magical to me.
link |
05:06:46.160
And that was one of the things that really made me smile is Andre had said
link |
05:06:50.160
when he came over to my house, he said he found my library inspiring.
link |
05:06:54.160
And it was great to see.
link |
05:06:55.160
I used to look at him.
link |
05:06:56.160
He's kind of a younger guy.
link |
05:06:57.160
I sometimes wonder if younger people these days have the same relationship
link |
05:07:01.160
with books that I do where they were such a cornerstone for me in so many ways.
link |
05:07:06.160
But that sense that, yeah, I always wanted to know it all.
link |
05:07:08.160
I know I can't.
link |
05:07:09.160
And that was like one of the last things I said.
link |
05:07:11.160
You can't know everything, but you should convince yourself
link |
05:07:14.160
that you can know anything.
link |
05:07:16.160
Any one particular thing, it was created and discovered by humans.
link |
05:07:20.160
You can learn it.
link |
05:07:21.160
You can find out what you need on there.
link |
05:07:23.160
And you can learn it deeply.
link |
05:07:24.160
Yeah.
link |
05:07:25.160
And you can drive a nail down through whatever layer cake problem space
link |
05:07:29.160
you've got and learn a cross section there.
link |
05:07:32.160
And not only can you have an impact doing that,
link |
05:07:34.160
you can attain happiness doing that.
link |
05:07:37.160
There's something so fulfilling about becoming a craftsman of a thing.
link |
05:07:41.160
Yeah.
link |
05:07:42.160
And I don't want to tell people that, look, this is a good career move.
link |
05:07:45.160
Just grit your teeth and bear it.
link |
05:07:48.160
You want people.
link |
05:07:50.160
And I do think it is possible sometimes to find the joy in something.
link |
05:07:54.160
Like it might not immediately appeal to you.
link |
05:07:56.160
But I had told people early on, like in software times,
link |
05:08:00.160
that a lot of game developers are in it just because they
link |
05:08:04.160
are so passionate about games.
link |
05:08:06.160
But I was always really more flexible in what appealed to me,
link |
05:08:10.160
where I said, I think I could be quite engaged doing
link |
05:08:14.160
operating system work or even database work.
link |
05:08:17.160
I would find the interest in that.
link |
05:08:19.160
Because I think most things that are significant in the world
link |
05:08:22.160
have a lot of layers and complexity to them
link |
05:08:25.160
and a lot of opportunities hidden within them.
link |
05:08:28.160
So that would probably be the most important thing to encourage to people
link |
05:08:31.160
is that you can weaponize curiosity.
link |
05:08:35.160
You can deploy your curiosity to find,
link |
05:08:38.160
to kind of like make things useful and valuable to you,
link |
05:08:41.160
even if they don't immediately appear that way.
link |
05:08:44.160
Deploy your curiosity.
link |
05:08:45.160
Yeah, that's very true.
link |
05:08:47.160
We've mentioned this debate point,
link |
05:08:49.160
whether mortality or fear of mortality is fundamental to creating an AGI.
link |
05:08:55.160
But let's talk about whether it's fundamental to human beings.
link |
05:08:58.160
Do you think about your own mortality?
link |
05:09:01.160
I really don't.
link |
05:09:03.160
And you probably always have to like take with a grain of salt
link |
05:09:07.160
anything somebody says about fundamental things like that.
link |
05:09:10.160
But I don't think about really aging, impending death,
link |
05:09:16.160
having a legacy with my children, things like that.
link |
05:09:20.160
And clearly it seems most of the world does a lot more than I do.
link |
05:09:25.160
So I mean I think I'm an outlier in that where it doesn't wind up
link |
05:09:32.160
being a real part of my thinking and motivation about things.
link |
05:09:36.160
So daily existence is about sort of the people you love
link |
05:09:41.160
and the problems before you.
link |
05:09:44.160
And I'm focused on what I'm working on right now.
link |
05:09:47.160
I do take that back.
link |
05:09:49.160
There's one aspect where the kind of finiteness of the life does impact me,
link |
05:09:54.160
and that is about thinking about the scope of the problems that I'm working on.
link |
05:09:58.160
When I decided to work on it, when I was like nuclear fission or AGI,
link |
05:10:03.160
these are big ticket things that impact large fractions of the world.
link |
05:10:09.160
And I was thinking to myself at some level that, okay,
link |
05:10:12.160
I may have a couple more swings at bat with me at full capability,
link |
05:10:17.160
but yes, my mental abilities will decay with age, mostly inevitably.
link |
05:10:23.160
I don't think it's a 0% chance that we will address some of that
link |
05:10:26.160
before it becomes a problem for me.
link |
05:10:28.160
I think exciting medical stuff in the next couple decades.
link |
05:10:31.160
But I do have this kind of vague plan that when I'm not at the top of my game
link |
05:10:36.160
and I don't feel that I'm in a position to put a dent in the world some way,
link |
05:10:40.160
that I'll probably wind up doing some kind of recreational retro programming
link |
05:10:44.160
or I'll work on something that I would not devote my life to now,
link |
05:10:50.160
but I can while away my time as the old man gardening in the code worlds.
link |
05:10:56.160
And then to step back even bigger, let me ask you about why we're here,
link |
05:11:01.160
we human beings.
link |
05:11:03.160
What's the meaning of it all?
link |
05:11:05.160
What's the meaning of life, John Carmack?
link |
05:11:07.160
So very similar with that last question.
link |
05:11:09.160
I know a lot of people fret about this question a lot,
link |
05:11:12.160
and I just really don't.
link |
05:11:14.160
I really don't give a damn.
link |
05:11:16.160
We are biological creatures that happenstance of evolution.
link |
05:11:21.160
We have innate drives that evolution crafted for survival
link |
05:11:25.160
and passing on of genetic codes.
link |
05:11:28.160
I don't find a lot of value in trying to go much deeper than that.
link |
05:11:34.160
I have my motivations, some of which are probably genetically coded
link |
05:11:38.160
and many of which are contingent on my upbringing
link |
05:11:41.160
and the path that I've had through my life.
link |
05:11:44.160
I don't run into like spades of depression or envy
link |
05:11:48.160
or anything that winds up being a challenge
link |
05:11:52.160
and forcing a degree of soul searching with things like that.
link |
05:11:55.160
I seem to be okay kind of without that.
link |
05:12:00.160
As a brilliant ant in the ant colony without looking up to the sky
link |
05:12:04.160
wondering why the hell am I here again.
link |
05:12:07.160
So the why of it, the incredible mystery of the fact that we started,
link |
05:12:15.160
first of all, the origin of life on Earth,
link |
05:12:18.160
and from that, from single cell organisms,
link |
05:12:21.160
the entirety of the evolutionary process took us somehow
link |
05:12:24.160
to this incredibly intelligent thing that is able to build Wolfenstein 3D
link |
05:12:29.160
and Doom and Quake and take a crack at the problem of AGI
link |
05:12:34.160
and things that eventually supersede human beings.
link |
05:12:37.160
That doesn't, the why of it is...
link |
05:12:42.160
It's been my experience that people that focus on,
link |
05:12:46.160
that don't focus on the here and now right in front of them
link |
05:12:49.160
tend to be less effective.
link |
05:12:51.160
I mean, it's not 100%, you know, vision matters to some people,
link |
05:12:55.160
but it doesn't seem to be a necessary motivator for me
link |
05:12:59.160
and I think that the process of getting there is usually done.
link |
05:13:03.160
It's like the magic of gradient descent.
link |
05:13:05.160
People just don't believe that just looking locally
link |
05:13:08.160
gets you to all of these spectacular things.
link |
05:13:11.160
That's been, you know, the decades of looking at
link |
05:13:15.160
really some of the smartest people in the world
link |
05:13:17.160
that would just push back forever against this idea
link |
05:13:20.160
that it's not this grand, sophisticated vision of everything,
link |
05:13:24.160
but little tiny steps, local information winds up
link |
05:13:27.160
leading to all the best answers.
link |
05:13:29.160
So the meaning of life is following locally
link |
05:13:34.160
wherever the gradient descent takes you.
link |
05:13:37.160
This was an incredible conversation,
link |
05:13:39.160
officially the longest conversation I've ever done on the podcast,
link |
05:13:43.160
which means a lot to me because I get to do it with one of my heroes.
link |
05:13:46.160
John, I can't tell you how much it means to me
link |
05:13:48.160
that you would sit down with me.
link |
05:13:50.160
You're an incredible human being.
link |
05:13:52.160
I can't wait what you do next, but you've already changed the world.
link |
05:13:55.160
You're an inspiration to so many people.
link |
05:13:57.160
And again, we haven't covered like most of what I was planning to talk about,
link |
05:14:02.160
so I hope we get a chance to talk someday in the future.
link |
05:14:06.160
I can't wait to see what you do next.
link |
05:14:08.160
Thank you so much again for talking to me.
link |
05:14:10.160
Thank you very much.
link |
05:14:11.160
Thanks for listening to this conversation with John Carmack.
link |
05:14:14.160
To support this podcast, please check out our sponsors in the description.
link |
05:14:18.160
And now, let me leave you with some words from John Carmack himself.
link |
05:14:22.160
Focused hard work is the real key to success.
link |
05:14:26.160
Keep your eyes on the goal,
link |
05:14:28.160
and just keep taking the next step towards completing it.
link |
05:14:31.160
If you aren't sure which way to do something,
link |
05:14:34.160
do it both ways and see which works better.
link |
05:14:37.160
Thank you for listening and hope to see you next time.