{"message": {"transcript": [{"chunks": [{"end": 1.08, "start": 0.0, "text": "Thank"}, {"end": 1.12, "start": 1.08, "text": "you"}, {"end": 1.2, "start": 1.12, "text": "so"}, {"end": 1.2, "start": 1.2, "text": "much,"}, {"end": 1.2, "start": 1.2, "text": "Rock,"}, {"end": 1.2, "start": 1.2, "text": "and"}, {"end": 1.2, "start": 1.2, "text": "thank"}, {"end": 1.2, "start": 1.2, "text": "you"}, {"end": 1.2, "start": 1.2, "text": "to"}, {"end": 1.28, "start": 1.2, "text": "the"}, {"end": 1.96, "start": 1.28, "text": "entire"}, {"end": 2.48, "start": 1.96, "text": "awards"}, {"end": 2.92, "start": 2.48, "text": "committee,"}, {"end": 3.08, "start": 2.92, "text": "the"}, {"end": 3.36, "start": 3.08, "text": "entire"}, {"end": 3.8, "start": 3.36, "text": "sitcom"}, {"end": 4.32, "start": 3.8, "text": "community."}, {"end": 4.76, "start": 4.32, "text": "It's"}, {"end": 4.88, "start": 4.76, "text": "really"}, {"end": 5.32, "start": 4.88, "text": "my"}, {"end": 5.6, "start": 5.32, "text": "honor"}, {"end": 5.88, "start": 5.6, "text": "and"}, {"end": 6.48, "start": 5.88, "text": "privilege"}, {"end": 6.92, "start": 6.48, "text": "to"}, {"end": 7.68, "start": 6.92, "text": "be"}, {"end": 8.08, "start": 7.68, "text": "standing"}, {"end": 8.24, "start": 8.08, "text": "here"}, {"end": 8.28, "start": 8.24, "text": "in"}, {"end": 8.52, "start": 8.28, "text": "front"}, {"end": 8.52, "start": 8.52, "text": "of"}, {"end": 8.56, "start": 8.52, "text": "you"}, {"end": 8.92, "start": 8.56, "text": "today"}, {"end": 9.0, "start": 8.92, "text": "with"}, {"end": 9.16, "start": 9.0, "text": "this"}, {"end": 10.24, "start": 9.16, "text": "presentation."}, {"end": 10.4, "start": 10.24, "text": "I"}, {"end": 11.04, "start": 10.4, "text": "have"}, {"end": 11.6, "start": 11.04, "text": "obsessed"}, {"end": 12.04, "start": 11.6, "text": "over"}, {"end": 12.36, "start": 12.04, "text": "this"}, {"end": 13.0, "start": 12.36, "text": "presentation"}, {"end": 13.0, "start": 13.0, "text": "a"}, {"end": 13.36, "start": 13.0, "text": "bit,"}, {"end": 13.68, "start": 13.36, "text": "as"}, {"end": 14.04, "start": 13.68, "text": "Rock"}, {"end": 15.0, "start": 14.04, "text": "mentioned."}, {"end": 15.92, "start": 15.0, "text": "So"}, {"end": 16.48, "start": 15.92, "text": "I'm"}, {"end": 16.68, "start": 16.48, "text": "really"}, {"end": 17.0, "start": 16.68, "text": "looking"}, {"end": 17.28, "start": 17.0, "text": "forward"}, {"end": 17.88, "start": 17.28, "text": "to"}, {"end": 18.2, "start": 17.88, "text": "giving"}, {"end": 18.2, "start": 18.2, "text": "it."}, {"end": 18.24, "start": 18.2, "text": "The"}, {"end": 20.16, "start": 18.24, "text": "title"}, {"end": 20.6, "start": 20.16, "text": "does"}, {"end": 21.28, "start": 20.6, "text": "reflect"}, {"end": 21.76, "start": 21.28, "text": "a"}, {"end": 22.16, "start": 21.76, "text": "rather"}, {"end": 23.12, "start": 22.16, "text": "profound"}, {"end": 23.72, "start": 23.12, "text": "technical"}, {"end": 23.76, "start": 23.72, "text": "journey"}, {"end": 23.76, "start": 23.76, "text": "that"}, {"end": 23.76, "start": 23.76, "text": "we've"}, {"end": 23.8, "start": 23.76, "text": "been"}, {"end": 24.16, "start": 23.8, "text": "on"}, {"end": 24.56, "start": 24.16, "text": "as"}, {"end": 24.56, "start": 24.56, "text": "a"}, {"end": 25.2, "start": 24.56, "text": "community."}, {"end": 25.64, "start": 25.2, "text": "I"}, {"end": 25.88, "start": 25.64, "text": "think"}, {"end": 26.08, "start": 25.88, "text": "it"}, {"end": 26.56, "start": 26.08, "text": "has"}, {"end": 26.56, "start": 26.56, "text": "a"}, {"end": 27.24, "start": 26.56, "text": "reflection"}, {"end": 27.6, "start": 27.24, "text": "on"}, {"end": 27.8, "start": 27.6, "text": "a"}, {"end": 28.4, "start": 27.8, "text": "much"}, {"end": 28.96, "start": 28.4, "text": "less"}, {"end": 29.96, "start": 28.96, "text": "interesting"}], "text": " Thank you so much, Rock, and thank you to the entire awards committee, the entire sitcom community. It's really my honor and privilege to be standing here in front of you today with this presentation. I have obsessed over this presentation a bit, as Rock mentioned. So I'm really looking forward to giving it. The title does reflect a rather profound technical journey that we've been on as a community. I think it has a reflection on a much less interesting"}, {"chunks": [{"end": 30.6, "start": 30.0, "text": "much"}, {"end": 30.92, "start": 30.6, "text": "less"}, {"end": 31.24, "start": 30.92, "text": "profound"}, {"end": 31.48, "start": 31.24, "text": "personal"}, {"end": 31.84, "start": 31.48, "text": "journey"}, {"end": 32.16, "start": 31.84, "text": "that"}, {"end": 32.48, "start": 32.16, "text": "I've"}, {"end": 32.48, "start": 32.48, "text": "been"}, {"end": 32.48, "start": 32.48, "text": "on"}, {"end": 32.52, "start": 32.48, "text": "that"}, {"end": 32.52, "start": 32.52, "text": "I"}, {"end": 32.6, "start": 32.52, "text": "come"}, {"end": 32.92, "start": 32.6, "text": "back"}, {"end": 32.96, "start": 32.92, "text": "to"}, {"end": 33.32, "start": 32.96, "text": "at"}, {"end": 33.48, "start": 33.32, "text": "the"}, {"end": 33.88, "start": 33.48, "text": "end"}, {"end": 33.92, "start": 33.88, "text": "of"}, {"end": 34.08, "start": 33.92, "text": "this"}, {"end": 34.2, "start": 34.08, "text": "talk."}, {"end": 34.36, "start": 34.2, "text": "I"}, {"end": 34.44, "start": 34.36, "text": "think"}, {"end": 34.480000000000004, "start": 34.44, "text": "it"}, {"end": 34.84, "start": 34.480000000000004, "text": "hopefully"}, {"end": 35.28, "start": 34.84, "text": "goes"}, {"end": 35.8, "start": 35.28, "text": "without"}, {"end": 36.12, "start": 35.8, "text": "saying"}, {"end": 36.4, "start": 36.12, "text": "that"}, {"end": 36.56, "start": 36.4, "text": "the"}, {"end": 37.04, "start": 36.56, "text": "material"}, {"end": 37.04, "start": 37.04, "text": "in"}, {"end": 37.2, "start": 37.04, "text": "this"}, {"end": 38.04, "start": 37.2, "text": "talk"}, {"end": 38.92, "start": 38.04, "text": "reflects"}, {"end": 39.16, "start": 38.92, "text": "the"}, {"end": 39.28, "start": 39.16, "text": "work"}, {"end": 39.32, "start": 39.28, "text": "of"}, {"end": 39.84, "start": 39.32, "text": "literally"}, {"end": 40.24, "start": 39.84, "text": "hundreds"}, {"end": 40.24, "start": 40.24, "text": "of"}, {"end": 40.36, "start": 40.24, "text": "the"}, {"end": 40.88, "start": 40.36, "text": "most"}, {"end": 41.64, "start": 40.88, "text": "talented"}, {"end": 41.8, "start": 41.64, "text": "and"}, {"end": 42.04, "start": 41.8, "text": "kind"}, {"end": 42.480000000000004, "start": 42.04, "text": "colleagues"}, {"end": 42.480000000000004, "start": 42.480000000000004, "text": "you"}, {"end": 42.64, "start": 42.480000000000004, "text": "can"}, {"end": 43.72, "start": 42.64, "text": "imagine."}, {"end": 43.92, "start": 43.72, "text": "The"}, {"end": 44.44, "start": 43.92, "text": "magnitude"}, {"end": 44.6, "start": 44.44, "text": "of"}, {"end": 44.92, "start": 44.6, "text": "my"}, {"end": 44.96, "start": 44.92, "text": "own"}, {"end": 45.8, "start": 44.96, "text": "contributions"}, {"end": 45.96, "start": 45.8, "text": "to"}, {"end": 45.96, "start": 45.96, "text": "this"}, {"end": 46.0, "start": 45.96, "text": "work"}, {"end": 46.2, "start": 46.0, "text": "are"}, {"end": 46.84, "start": 46.2, "text": "substantially"}, {"end": 47.16, "start": 46.84, "text": "less"}, {"end": 47.32, "start": 47.16, "text": "than"}, {"end": 47.44, "start": 47.32, "text": "the"}, {"end": 47.96, "start": 47.44, "text": "magnitude"}, {"end": 48.04, "start": 47.96, "text": "of"}, {"end": 48.28, "start": 48.04, "text": "my"}, {"end": 48.36, "start": 48.28, "text": "good"}, {"end": 48.879999999999995, "start": 48.36, "text": "fortune"}, {"end": 49.0, "start": 48.879999999999995, "text": "in"}, {"end": 49.56, "start": 49.0, "text": "having"}, {"end": 49.56, "start": 49.56, "text": "worked"}, {"end": 49.56, "start": 49.56, "text": "with"}, {"end": 49.92, "start": 49.56, "text": "these"}, {"end": 50.2, "start": 49.92, "text": "people."}, {"end": 50.28, "start": 50.2, "text": "So"}, {"end": 50.28, "start": 50.28, "text": "let"}, {"end": 50.28, "start": 50.28, "text": "me"}, {"end": 50.72, "start": 50.28, "text": "start"}, {"end": 51.28, "start": 50.72, "text": "with"}, {"end": 51.760000000000005, "start": 51.28, "text": "a"}, {"end": 52.04, "start": 51.760000000000005, "text": "bit"}, {"end": 52.36, "start": 52.04, "text": "of"}, {"end": 53.08, "start": 52.36, "text": "history"}, {"end": 53.760000000000005, "start": 53.08, "text": "with"}, {"end": 54.68, "start": 53.760000000000005, "text": "respect"}, {"end": 55.08, "start": 54.68, "text": "to"}, {"end": 55.480000000000004, "start": 55.08, "text": "the"}, {"end": 56.0, "start": 55.480000000000004, "text": "journey"}, {"end": 57.120000000000005, "start": 56.0, "text": "that"}, {"end": 57.120000000000005, "start": 57.120000000000005, "text": "we've"}, {"end": 57.120000000000005, "start": 57.120000000000005, "text": "been"}, {"end": 57.16, "start": 57.120000000000005, "text": "on."}, {"end": 57.4, "start": 57.16, "text": "On"}, {"end": 57.64, "start": 57.4, "text": "the"}, {"end": 58.120000000000005, "start": 57.64, "text": "internet,"}, {"end": 58.239999999999995, "start": 58.120000000000005, "text": "I"}, {"end": 58.480000000000004, "start": 58.239999999999995, "text": "think"}, {"end": 58.480000000000004, "start": 58.480000000000004, "text": "you"}, {"end": 58.56, "start": 58.480000000000004, "text": "could"}, {"end": 59.0, "start": 58.56, "text": "start"}, {"end": 59.56, "start": 59.0, "text": "arbitrarily"}, {"end": 59.72, "start": 59.56, "text": "far"}, {"end": 59.96, "start": 59.72, "text": "back."}], "text": " much less profound personal journey that I've been on that I come back to at the end of this talk. I think it hopefully goes without saying that the material in this talk reflects the work of literally hundreds of the most talented and kind colleagues you can imagine. The magnitude of my own contributions to this work are substantially less than the magnitude of my good fortune in having worked with these people. So let me start with a bit of history with respect to the journey that we've been on. On the internet, I think you could start arbitrarily far back."}, {"chunks": [{"end": 60.28, "start": 60.0, "text": "But"}, {"end": 60.84, "start": 60.28, "text": "let"}, {"end": 61.44, "start": 60.84, "text": "me"}, {"end": 61.76, "start": 61.44, "text": "start"}, {"end": 61.84, "start": 61.76, "text": "in"}, {"end": 63.52, "start": 61.84, "text": "1960,"}, {"end": 64.04, "start": 63.52, "text": "where"}, {"end": 64.48, "start": 64.04, "text": "there"}, {"end": 65.0, "start": 64.48, "text": "was"}, {"end": 65.2, "start": 65.0, "text": "a,"}, {"end": 65.36, "start": 65.2, "text": "this"}, {"end": 65.4, "start": 65.36, "text": "was"}, {"end": 65.72, "start": 65.4, "text": "before"}, {"end": 66.16, "start": 65.72, "text": "the"}, {"end": 66.48, "start": 66.16, "text": "internet,"}, {"end": 66.92, "start": 66.48, "text": "before"}, {"end": 67.36, "start": 66.92, "text": "the"}, {"end": 67.96, "start": 67.36, "text": "ARPANET,"}, {"end": 68.48, "start": 67.96, "text": "and"}, {"end": 68.68, "start": 68.48, "text": "I'll"}, {"end": 69.4, "start": 68.68, "text": "start"}, {"end": 69.68, "start": 69.4, "text": "with"}, {"end": 69.72, "start": 69.68, "text": "a"}, {"end": 69.72, "start": 69.72, "text": "quote"}, {"end": 70.12, "start": 69.72, "text": "from"}, {"end": 70.16, "start": 70.12, "text": "a"}, {"end": 70.8, "start": 70.16, "text": "gentleman"}, {"end": 71.08, "start": 70.8, "text": "named"}, {"end": 71.68, "start": 71.08, "text": "J.C.R."}, {"end": 71.96000000000001, "start": 71.68, "text": "Licklider"}, {"end": 72.16, "start": 71.96000000000001, "text": "that"}, {"end": 72.52, "start": 72.16, "text": "I"}, {"end": 73.03999999999999, "start": 72.52, "text": "find"}, {"end": 73.32, "start": 73.03999999999999, "text": "truly"}, {"end": 73.84, "start": 73.32, "text": "inspirational,"}, {"end": 74.16, "start": 73.84, "text": "so"}, {"end": 74.32, "start": 74.16, "text": "I'm"}, {"end": 74.6, "start": 74.32, "text": "going"}, {"end": 74.6, "start": 74.6, "text": "to"}, {"end": 74.64, "start": 74.6, "text": "read"}, {"end": 74.76, "start": 74.64, "text": "it"}, {"end": 74.96000000000001, "start": 74.76, "text": "to"}, {"end": 75.28, "start": 74.96000000000001, "text": "you"}, {"end": 76.28, "start": 75.28, "text": "all."}, {"end": 76.44, "start": 76.28, "text": "It"}, {"end": 76.92, "start": 76.44, "text": "seems"}, {"end": 77.64, "start": 76.92, "text": "reasonable"}, {"end": 77.84, "start": 77.64, "text": "to"}, {"end": 78.12, "start": 77.84, "text": "envision"}, {"end": 78.12, "start": 78.12, "text": "for"}, {"end": 78.24, "start": 78.12, "text": "a"}, {"end": 78.88, "start": 78.24, "text": "time"}, {"end": 79.0, "start": 78.88, "text": "10"}, {"end": 79.2, "start": 79.0, "text": "or"}, {"end": 79.44, "start": 79.2, "text": "15"}, {"end": 79.88, "start": 79.44, "text": "years"}, {"end": 80.4, "start": 79.88, "text": "hence,"}, {"end": 80.52, "start": 80.4, "text": "a"}, {"end": 80.76, "start": 80.52, "text": "thinking"}, {"end": 81.16, "start": 80.76, "text": "center"}, {"end": 81.28, "start": 81.16, "text": "that"}, {"end": 81.6, "start": 81.28, "text": "will"}, {"end": 82.08, "start": 81.6, "text": "incorporate"}, {"end": 82.12, "start": 82.08, "text": "the"}, {"end": 82.68, "start": 82.12, "text": "functions"}, {"end": 82.68, "start": 82.68, "text": "of"}, {"end": 82.68, "start": 82.68, "text": "present"}, {"end": 82.68, "start": 82.68, "text": "day"}, {"end": 83.84, "start": 82.68, "text": "libraries,"}, {"end": 84.8, "start": 83.84, "text": "together"}, {"end": 84.84, "start": 84.8, "text": "with"}, {"end": 85.44, "start": 84.84, "text": "anticipated"}, {"end": 86.12, "start": 85.44, "text": "advances"}, {"end": 86.28, "start": 86.12, "text": "in"}, {"end": 86.6, "start": 86.28, "text": "information"}, {"end": 87.08, "start": 86.6, "text": "storage"}, {"end": 87.16, "start": 87.08, "text": "and"}, {"end": 88.24, "start": 87.16, "text": "retrieval."}, {"end": 88.36, "start": 88.24, "text": "The"}, {"end": 88.72, "start": 88.36, "text": "picture"}, {"end": 89.08, "start": 88.72, "text": "readily"}, {"end": 89.48, "start": 89.08, "text": "enlarges"}, {"end": 89.88, "start": 89.48, "text": "itself"}, {"end": 89.96000000000001, "start": 89.88, "text": "in"}], "text": " But let me start in 1960, where there was a, this was before the internet, before the ARPANET, and I'll start with a quote from a gentleman named J.C.R. Licklider that I find truly inspirational, so I'm going to read it to you all. It seems reasonable to envision for a time 10 or 15 years hence, a thinking center that will incorporate the functions of present day libraries, together with anticipated advances in information storage and retrieval. The picture readily enlarges itself in"}, {"chunks": [{"end": 90.24, "start": 90.0, "text": "to"}, {"end": 90.48, "start": 90.24, "text": "a"}, {"end": 90.96, "start": 90.48, "text": "network"}, {"end": 91.0, "start": 90.96, "text": "of"}, {"end": 91.32, "start": 91.0, "text": "such"}, {"end": 91.52, "start": 91.32, "text": "centers"}, {"end": 91.76, "start": 91.52, "text": "connected"}, {"end": 91.92, "start": 91.76, "text": "to"}, {"end": 92.2, "start": 91.92, "text": "one"}, {"end": 92.52, "start": 92.2, "text": "another"}, {"end": 92.72, "start": 92.52, "text": "by"}, {"end": 93.28, "start": 92.72, "text": "wideband"}, {"end": 93.76, "start": 93.28, "text": "communication"}, {"end": 94.6, "start": 93.76, "text": "lines"}, {"end": 94.72, "start": 94.6, "text": "and"}, {"end": 95.0, "start": 94.72, "text": "to"}, {"end": 95.28, "start": 95.0, "text": "individual"}, {"end": 95.96, "start": 95.28, "text": "users"}, {"end": 96.12, "start": 95.96, "text": "by"}, {"end": 96.32, "start": 96.12, "text": "leased"}, {"end": 96.52, "start": 96.32, "text": "wire"}, {"end": 97.28, "start": 96.52, "text": "services."}, {"end": 97.68, "start": 97.28, "text": "In"}, {"end": 97.72, "start": 97.68, "text": "such"}, {"end": 98.03999999999999, "start": 97.72, "text": "a"}, {"end": 98.76, "start": 98.03999999999999, "text": "system,"}, {"end": 98.76, "start": 98.76, "text": "the"}, {"end": 98.76, "start": 98.76, "text": "speed"}, {"end": 99.0, "start": 98.76, "text": "of"}, {"end": 99.64, "start": 99.0, "text": "the"}, {"end": 100.0, "start": 99.64, "text": "computers"}, {"end": 100.16, "start": 100.0, "text": "would"}, {"end": 100.2, "start": 100.16, "text": "be"}, {"end": 100.76, "start": 100.2, "text": "balanced,"}, {"end": 101.03999999999999, "start": 100.76, "text": "and"}, {"end": 101.28, "start": 101.03999999999999, "text": "the"}, {"end": 101.72, "start": 101.28, "text": "cost"}, {"end": 101.76, "start": 101.72, "text": "of"}, {"end": 101.96000000000001, "start": 101.76, "text": "the"}, {"end": 102.32, "start": 101.96000000000001, "text": "gigantic"}, {"end": 102.88, "start": 102.32, "text": "memories"}, {"end": 102.92, "start": 102.88, "text": "and"}, {"end": 103.0, "start": 102.92, "text": "the"}, {"end": 103.68, "start": 103.0, "text": "sophisticated"}, {"end": 104.4, "start": 103.68, "text": "programs"}, {"end": 104.56, "start": 104.4, "text": "would"}, {"end": 104.56, "start": 104.56, "text": "be"}, {"end": 104.6, "start": 104.56, "text": "divided"}, {"end": 104.92, "start": 104.6, "text": "by"}, {"end": 105.16, "start": 104.92, "text": "the"}, {"end": 105.36, "start": 105.16, "text": "number"}, {"end": 105.4, "start": 105.36, "text": "of"}, {"end": 107.64, "start": 105.4, "text": "users."}, {"end": 107.88, "start": 107.64, "text": "I"}, {"end": 107.88, "start": 107.88, "text": "find"}, {"end": 107.88, "start": 107.88, "text": "this"}, {"end": 108.44, "start": 107.88, "text": "quote"}, {"end": 109.68, "start": 108.44, "text": "stunning"}, {"end": 110.32, "start": 109.68, "text": "and"}, {"end": 110.88, "start": 110.32, "text": "inspiring"}, {"end": 110.96000000000001, "start": 110.88, "text": "with"}, {"end": 111.4, "start": 110.96000000000001, "text": "respect"}, {"end": 111.76, "start": 111.4, "text": "to"}, {"end": 112.12, "start": 111.76, "text": "the"}, {"end": 112.64, "start": 112.12, "text": "power"}, {"end": 112.88, "start": 112.64, "text": "of"}, {"end": 113.32, "start": 112.88, "text": "our"}, {"end": 113.6, "start": 113.32, "text": "collective"}, {"end": 114.64, "start": 113.6, "text": "imagination."}, {"end": 115.0, "start": 114.64, "text": "Again,"}, {"end": 115.03999999999999, "start": 115.0, "text": "this"}, {"end": 115.08, "start": 115.03999999999999, "text": "is"}, {"end": 116.28, "start": 115.08, "text": "1960,"}, {"end": 116.96000000000001, "start": 116.28, "text": "before"}, {"end": 117.32, "start": 116.96000000000001, "text": "many"}, {"end": 117.52, "start": 117.32, "text": "people"}, {"end": 118.24, "start": 117.52, "text": "were"}, {"end": 118.56, "start": 118.24, "text": "thinking"}, {"end": 118.84, "start": 118.56, "text": "about"}, {"end": 119.56, "start": 118.84, "text": "such"}, {"end": 119.96000000000001, "start": 119.56, "text": "things."}], "text": " to a network of such centers connected to one another by wideband communication lines and to individual users by leased wire services. In such a system, the speed of the computers would be balanced, and the cost of the gigantic memories and the sophisticated programs would be divided by the number of users. I find this quote stunning and inspiring with respect to the power of our collective imagination. Again, this is 1960, before many people were thinking about such things."}, {"chunks": [{"end": 120.6, "start": 120.0, "text": "And"}, {"end": 121.0, "start": 120.6, "text": "I"}, {"end": 121.4, "start": 121.0, "text": "would"}, {"end": 121.84, "start": 121.4, "text": "say"}, {"end": 122.72, "start": 121.84, "text": "that"}, {"end": 122.84, "start": 122.72, "text": "60"}, {"end": 123.16, "start": 122.84, "text": "years"}, {"end": 123.52, "start": 123.16, "text": "later,"}, {"end": 123.56, "start": 123.52, "text": "we've"}, {"end": 124.0, "start": 123.56, "text": "achieved"}, {"end": 124.0, "start": 124.0, "text": "a"}, {"end": 124.0, "start": 124.0, "text": "lot"}, {"end": 124.0, "start": 124.0, "text": "of"}, {"end": 124.44, "start": 124.0, "text": "what"}, {"end": 124.44, "start": 124.44, "text": "this"}, {"end": 124.8, "start": 124.44, "text": "quote"}, {"end": 125.04, "start": 124.8, "text": "puts"}, {"end": 125.6, "start": 125.04, "text": "forth,"}, {"end": 126.28, "start": 125.6, "text": "but"}, {"end": 126.64, "start": 126.28, "text": "we're"}, {"end": 126.84, "start": 126.64, "text": "not"}, {"end": 126.92, "start": 126.84, "text": "quite"}, {"end": 127.32, "start": 126.92, "text": "done"}, {"end": 127.84, "start": 127.32, "text": "yet."}, {"end": 128.4, "start": 127.84, "text": "J.C.R."}, {"end": 128.68, "start": 128.4, "text": "didn't"}, {"end": 129.12, "start": 128.68, "text": "stop"}, {"end": 129.56, "start": 129.12, "text": "with"}, {"end": 130.56, "start": 129.56, "text": "such"}, {"end": 131.28, "start": 130.56, "text": "quotes."}, {"end": 131.52, "start": 131.28, "text": "He"}, {"end": 132.28, "start": 131.52, "text": "actually,"}, {"end": 132.68, "start": 132.28, "text": "the"}, {"end": 133.08, "start": 132.68, "text": "following"}, {"end": 134.2, "start": 133.08, "text": "year,"}, {"end": 134.44, "start": 134.2, "text": "sorry,"}, {"end": 135.2, "start": 134.44, "text": "two"}, {"end": 135.44, "start": 135.2, "text": "years"}, {"end": 135.88, "start": 135.44, "text": "later,"}, {"end": 136.52, "start": 135.88, "text": "started,"}, {"end": 136.84, "start": 136.52, "text": "was"}, {"end": 137.04, "start": 136.84, "text": "the"}, {"end": 137.44, "start": 137.04, "text": "first"}, {"end": 138.32, "start": 137.44, "text": "director"}, {"end": 138.92000000000002, "start": 138.32, "text": "of"}, {"end": 139.4, "start": 138.92000000000002, "text": "the"}, {"end": 140.2, "start": 139.4, "text": "ARPA"}, {"end": 140.44, "start": 140.2, "text": "IPTO,"}, {"end": 140.6, "start": 140.44, "text": "which"}, {"end": 141.24, "start": 140.6, "text": "laid"}, {"end": 141.6, "start": 141.24, "text": "the"}, {"end": 142.16, "start": 141.6, "text": "groundwork"}, {"end": 142.64, "start": 142.16, "text": "for"}, {"end": 142.64, "start": 142.64, "text": "the"}, {"end": 143.12, "start": 142.64, "text": "programs"}, {"end": 143.44, "start": 143.12, "text": "that"}, {"end": 143.44, "start": 143.44, "text": "would"}, {"end": 144.04, "start": 143.44, "text": "launch"}, {"end": 144.48, "start": 144.04, "text": "the"}, {"end": 144.68, "start": 144.48, "text": "ARPANET"}, {"end": 144.68, "start": 144.68, "text": "in"}, {"end": 145.48, "start": 144.68, "text": "1969."}, {"end": 145.64, "start": 145.48, "text": "And"}, {"end": 145.88, "start": 145.64, "text": "here"}, {"end": 146.2, "start": 145.88, "text": "is"}, {"end": 146.4, "start": 146.2, "text": "the"}, {"end": 146.72, "start": 146.4, "text": "apocryphal"}, {"end": 146.96, "start": 146.72, "text": "drawing"}, {"end": 147.0, "start": 146.96, "text": "on"}, {"end": 147.32, "start": 147.0, "text": "the"}, {"end": 147.72, "start": 147.32, "text": "back"}, {"end": 148.07999999999998, "start": 147.72, "text": "of"}, {"end": 148.32, "start": 148.07999999999998, "text": "the"}, {"end": 148.64, "start": 148.32, "text": "napkin"}, {"end": 149.4, "start": 148.64, "text": "that"}, {"end": 149.96, "start": 149.4, "text": "showed"}], "text": " And I would say that 60 years later, we've achieved a lot of what this quote puts forth, but we're not quite done yet. J.C.R. didn't stop with such quotes. He actually, the following year, sorry, two years later, started, was the first director of the ARPA IPTO, which laid the groundwork for the programs that would launch the ARPANET in 1969. And here is the apocryphal drawing on the back of the napkin that showed"}, {"chunks": [{"end": 150.36, "start": 150.0, "text": "topology"}, {"end": 150.72, "start": 150.36, "text": "of"}, {"end": 151.0, "start": 150.72, "text": "the"}, {"end": 151.28, "start": 151.0, "text": "first"}, {"end": 151.48, "start": 151.28, "text": "four"}, {"end": 151.88, "start": 151.48, "text": "nodes"}, {"end": 152.12, "start": 151.88, "text": "on"}, {"end": 152.32, "start": 152.12, "text": "the"}, {"end": 152.64, "start": 152.32, "text": "internet"}, {"end": 152.84, "start": 152.64, "text": "in"}, {"end": 153.56, "start": 152.84, "text": "ARPANET"}, {"end": 153.64, "start": 153.56, "text": "in"}, {"end": 154.52, "start": 153.64, "text": "1969,"}, {"end": 155.24, "start": 154.52, "text": "the"}, {"end": 155.48, "start": 155.24, "text": "direct"}, {"end": 156.24, "start": 155.48, "text": "precursor"}, {"end": 157.44, "start": 156.24, "text": "to"}, {"end": 158.32, "start": 157.44, "text": "today's"}, {"end": 158.96, "start": 158.32, "text": "internet."}, {"end": 159.36, "start": 158.96, "text": "51"}, {"end": 159.88, "start": 159.36, "text": "years"}, {"end": 160.4, "start": 159.88, "text": "later,"}, {"end": 160.56, "start": 160.4, "text": "we've"}, {"end": 161.04, "start": 160.56, "text": "gone"}, {"end": 161.84, "start": 161.04, "text": "from"}, {"end": 162.16, "start": 161.84, "text": "four"}, {"end": 162.52, "start": 162.16, "text": "nodes"}, {"end": 162.52, "start": 162.52, "text": "to"}, {"end": 162.6, "start": 162.52, "text": "20"}, {"end": 163.04, "start": 162.6, "text": "billion"}, {"end": 163.4, "start": 163.04, "text": "connected"}, {"end": 163.8, "start": 163.4, "text": "devices"}, {"end": 163.96, "start": 163.8, "text": "to"}, {"end": 164.32, "start": 163.96, "text": "the"}, {"end": 164.44, "start": 164.32, "text": "internet"}, {"end": 164.64, "start": 164.44, "text": "and"}, {"end": 164.96, "start": 164.64, "text": "4"}, {"end": 165.28, "start": 164.96, "text": "billion"}, {"end": 166.24, "start": 165.28, "text": "users."}, {"end": 166.8, "start": 166.24, "text": "Approximately"}, {"end": 167.07999999999998, "start": 166.8, "text": "half"}, {"end": 167.2, "start": 167.07999999999998, "text": "of"}, {"end": 167.24, "start": 167.2, "text": "the"}, {"end": 167.56, "start": 167.24, "text": "world's"}, {"end": 168.36, "start": 167.56, "text": "population"}, {"end": 168.4, "start": 168.36, "text": "is"}, {"end": 168.56, "start": 168.4, "text": "on"}, {"end": 168.84, "start": 168.56, "text": "the"}, {"end": 169.32, "start": 168.84, "text": "internet"}, {"end": 169.56, "start": 169.32, "text": "and"}, {"end": 169.6, "start": 169.56, "text": "that"}, {"end": 170.07999999999998, "start": 169.6, "text": "number"}, {"end": 170.32, "start": 170.07999999999998, "text": "is"}, {"end": 170.76, "start": 170.32, "text": "rapidly"}, {"end": 171.76, "start": 170.76, "text": "increasing."}, {"end": 172.12, "start": 171.76, "text": "So"}, {"end": 172.16, "start": 172.12, "text": "a"}, {"end": 173.36, "start": 172.16, "text": "factor"}, {"end": 173.8, "start": 173.36, "text": "of"}, {"end": 174.12, "start": 173.8, "text": "5"}, {"end": 174.48, "start": 174.12, "text": "billion"}, {"end": 175.28, "start": 174.48, "text": "growth"}, {"end": 175.68, "start": 175.28, "text": "over"}, {"end": 175.8, "start": 175.68, "text": "a"}, {"end": 176.04, "start": 175.8, "text": "50-year"}, {"end": 176.56, "start": 176.04, "text": "period"}, {"end": 176.96, "start": 176.56, "text": "is"}, {"end": 177.24, "start": 176.96, "text": "truly"}, {"end": 177.6, "start": 177.24, "text": "stunning."}, {"end": 177.84, "start": 177.6, "text": "And"}, {"end": 178.04, "start": 177.84, "text": "I"}, {"end": 178.28, "start": 178.04, "text": "think"}, {"end": 178.8, "start": 178.28, "text": "that"}, {"end": 179.07999999999998, "start": 178.8, "text": "we"}, {"end": 179.12, "start": 179.07999999999998, "text": "in"}, {"end": 179.44, "start": 179.12, "text": "this"}, {"end": 179.96, "start": 179.44, "text": "community"}], "text": " topology of the first four nodes on the internet in ARPANET in 1969, the direct precursor to today's internet. 51 years later, we've gone from four nodes to 20 billion connected devices to the internet and 4 billion users. Approximately half of the world's population is on the internet and that number is rapidly increasing. So a factor of 5 billion growth over a 50-year period is truly stunning. And I think that we in this community"}, {"chunks": [{"end": 180.0, "start": 180.0, "text": "I"}, {"end": 180.48, "start": 180.0, "text": "can"}, {"end": 180.88, "start": 180.48, "text": "take"}, {"end": 181.24, "start": 180.88, "text": "legitimate"}, {"end": 181.72, "start": 181.24, "text": "pride"}, {"end": 181.8, "start": 181.72, "text": "in"}, {"end": 182.08, "start": 181.8, "text": "our"}, {"end": 182.8, "start": 182.08, "text": "contributions"}, {"end": 182.92, "start": 182.8, "text": "to"}, {"end": 183.36, "start": 182.92, "text": "this"}, {"end": 184.64, "start": 183.36, "text": "journey."}, {"end": 185.0, "start": 184.64, "text": "The"}, {"end": 185.4, "start": 185.0, "text": "internet"}, {"end": 185.8, "start": 185.4, "text": "truly,"}, {"end": 185.92, "start": 185.8, "text": "I"}, {"end": 186.16, "start": 185.92, "text": "think,"}, {"end": 187.32, "start": 186.16, "text": "represents"}, {"end": 187.6, "start": 187.32, "text": "a"}, {"end": 188.12, "start": 187.6, "text": "revolution."}, {"end": 188.12, "start": 188.12, "text": "It"}, {"end": 188.12, "start": 188.12, "text": "is"}, {"end": 188.4, "start": 188.12, "text": "one"}, {"end": 188.44, "start": 188.4, "text": "of"}, {"end": 189.04, "start": 188.44, "text": "humanity's"}, {"end": 189.4, "start": 189.04, "text": "greatest"}, {"end": 189.76, "start": 189.4, "text": "achievements"}, {"end": 190.2, "start": 189.76, "text": "across"}, {"end": 190.24, "start": 190.2, "text": "time."}, {"end": 190.96, "start": 190.24, "text": "It"}, {"end": 191.24, "start": 190.96, "text": "is"}, {"end": 191.56, "start": 191.24, "text": "the"}, {"end": 191.96, "start": 191.56, "text": "basis"}, {"end": 192.32, "start": 191.96, "text": "today"}, {"end": 192.68, "start": 192.32, "text": "of"}, {"end": 193.12, "start": 192.68, "text": "all"}, {"end": 193.4, "start": 193.12, "text": "human"}, {"end": 193.88, "start": 193.4, "text": "communication"}, {"end": 194.04, "start": 193.88, "text": "at"}, {"end": 194.28, "start": 194.04, "text": "any"}, {"end": 194.84, "start": 194.28, "text": "distance."}, {"end": 195.4, "start": 194.84, "text": "It"}, {"end": 195.72, "start": 195.4, "text": "is"}, {"end": 195.96, "start": 195.72, "text": "the"}, {"end": 196.44, "start": 195.96, "text": "ultimate"}, {"end": 197.12, "start": 196.44, "text": "repository"}, {"end": 197.56, "start": 197.12, "text": "of"}, {"end": 197.72, "start": 197.56, "text": "human"}, {"end": 199.04, "start": 197.72, "text": "knowledge."}, {"end": 199.28, "start": 199.04, "text": "And"}, {"end": 199.56, "start": 199.28, "text": "it"}, {"end": 199.88, "start": 199.56, "text": "is"}, {"end": 200.28, "start": 199.88, "text": "the"}, {"end": 200.76, "start": 200.28, "text": "basis"}, {"end": 201.2, "start": 200.76, "text": "for"}, {"end": 201.36, "start": 201.2, "text": "all"}, {"end": 202.2, "start": 201.36, "text": "planetary"}, {"end": 202.44, "start": 202.2, "text": "scale"}, {"end": 204.04, "start": 202.44, "text": "software"}, {"end": 204.64, "start": 204.04, "text": "services."}, {"end": 205.0, "start": 204.64, "text": "Today,"}, {"end": 205.07999999999998, "start": 205.0, "text": "we're"}, {"end": 205.48, "start": 205.07999999999998, "text": "saying"}, {"end": 205.48, "start": 205.48, "text": "that"}, {"end": 205.48, "start": 205.48, "text": "increasingly,"}, {"end": 205.76, "start": 205.48, "text": "it"}, {"end": 205.96, "start": 205.76, "text": "is"}, {"end": 206.04, "start": 205.96, "text": "the"}, {"end": 206.56, "start": 206.04, "text": "basis"}, {"end": 207.16, "start": 206.56, "text": "for"}, {"end": 207.32, "start": 207.16, "text": "all"}, {"end": 207.88, "start": 207.32, "text": "sensing"}, {"end": 207.92000000000002, "start": 207.88, "text": "and"}, {"end": 208.6, "start": 207.92000000000002, "text": "actuation"}, {"end": 208.8, "start": 208.6, "text": "of"}, {"end": 209.0, "start": 208.8, "text": "our"}, {"end": 209.6, "start": 209.0, "text": "physical"}, {"end": 209.96, "start": 209.6, "text": "world."}], "text": " I can take legitimate pride in our contributions to this journey. The internet truly, I think, represents a revolution. It is one of humanity's greatest achievements across time. It is the basis today of all human communication at any distance. It is the ultimate repository of human knowledge. And it is the basis for all planetary scale software services. Today, we're saying that increasingly, it is the basis for all sensing and actuation of our physical world."}, {"chunks": [{"end": 210.72, "start": 210.0, "text": "And"}, {"end": 210.96, "start": 210.72, "text": "50"}, {"end": 211.32, "start": 210.96, "text": "years"}, {"end": 211.56, "start": 211.32, "text": "in,"}, {"end": 211.68, "start": 211.56, "text": "I"}, {"end": 211.88, "start": 211.68, "text": "think"}, {"end": 212.24, "start": 211.88, "text": "it's"}, {"end": 212.68, "start": 212.24, "text": "fair"}, {"end": 212.68, "start": 212.68, "text": "to"}, {"end": 212.76, "start": 212.68, "text": "say"}, {"end": 212.76, "start": 212.76, "text": "that"}, {"end": 212.84, "start": 212.76, "text": "we're"}, {"end": 213.16, "start": 212.84, "text": "just"}, {"end": 213.48, "start": 213.16, "text": "getting"}, {"end": 213.96, "start": 213.48, "text": "started."}, {"end": 213.96, "start": 213.96, "text": "What"}, {"end": 214.72, "start": 213.96, "text": "can"}, {"end": 214.92, "start": 214.72, "text": "we"}, {"end": 215.28, "start": 214.92, "text": "imagine"}, {"end": 215.32, "start": 215.28, "text": "for"}, {"end": 215.44, "start": 215.32, "text": "the"}, {"end": 215.72, "start": 215.44, "text": "next"}, {"end": 216.08, "start": 215.72, "text": "50,"}, {"end": 216.4, "start": 216.08, "text": "60"}, {"end": 218.24, "start": 216.4, "text": "years?"}, {"end": 219.08, "start": 218.24, "text": "At"}, {"end": 219.32, "start": 219.08, "text": "the"}, {"end": 219.56, "start": 219.32, "text": "same"}, {"end": 219.96, "start": 219.56, "text": "time,"}, {"end": 220.04, "start": 219.96, "text": "I"}, {"end": 220.2, "start": 220.04, "text": "think"}, {"end": 220.4, "start": 220.2, "text": "50"}, {"end": 220.88, "start": 220.4, "text": "years"}, {"end": 221.04, "start": 220.88, "text": "in,"}, {"end": 221.28, "start": 221.04, "text": "we"}, {"end": 221.76, "start": 221.28, "text": "are"}, {"end": 222.12, "start": 221.76, "text": "at"}, {"end": 222.24, "start": 222.12, "text": "an"}, {"end": 222.52, "start": 222.24, "text": "inflection"}, {"end": 222.64, "start": 222.52, "text": "point."}, {"end": 222.88, "start": 222.64, "text": "And"}, {"end": 223.6, "start": 222.88, "text": "paradoxically,"}, {"end": 223.76, "start": 223.6, "text": "it"}, {"end": 224.0, "start": 223.76, "text": "may"}, {"end": 224.28, "start": 224.0, "text": "be"}, {"end": 224.32, "start": 224.28, "text": "that"}, {"end": 224.52, "start": 224.32, "text": "the"}, {"end": 224.92, "start": 224.52, "text": "underlying"}, {"end": 225.68, "start": 224.92, "text": "principles"}, {"end": 225.76, "start": 225.68, "text": "that"}, {"end": 226.32, "start": 225.76, "text": "enabled"}, {"end": 226.72, "start": 226.32, "text": "this"}, {"end": 226.96, "start": 226.72, "text": "revolution,"}, {"end": 227.07999999999998, "start": 226.96, "text": "this"}, {"end": 227.4, "start": 227.07999999999998, "text": "true"}, {"end": 228.44, "start": 227.4, "text": "revolution,"}, {"end": 228.8, "start": 228.44, "text": "may"}, {"end": 228.8, "start": 228.8, "text": "need"}, {"end": 228.8, "start": 228.8, "text": "to"}, {"end": 228.88, "start": 228.8, "text": "be"}, {"end": 229.64, "start": 228.88, "text": "revisited"}, {"end": 230.04, "start": 229.64, "text": "to"}, {"end": 230.24, "start": 230.04, "text": "allow"}, {"end": 230.72, "start": 230.24, "text": "us"}, {"end": 230.92000000000002, "start": 230.72, "text": "to"}, {"end": 230.92000000000002, "start": 230.92000000000002, "text": "take"}, {"end": 230.92000000000002, "start": 230.92000000000002, "text": "the"}, {"end": 230.92000000000002, "start": 230.92000000000002, "text": "internet"}, {"end": 231.12, "start": 230.92000000000002, "text": "to"}, {"end": 231.48, "start": 231.12, "text": "the"}, {"end": 233.36, "start": 231.48, "text": "next"}, {"end": 233.68, "start": 233.36, "text": "level."}, {"end": 234.2, "start": 233.68, "text": "So"}, {"end": 235.4, "start": 234.2, "text": "what"}, {"end": 235.6, "start": 235.4, "text": "I'm"}, {"end": 235.6, "start": 235.6, "text": "going"}, {"end": 235.6, "start": 235.6, "text": "to"}, {"end": 235.6, "start": 235.6, "text": "be"}, {"end": 235.6, "start": 235.6, "text": "arguing"}, {"end": 235.6, "start": 235.6, "text": "in"}, {"end": 235.6, "start": 235.6, "text": "this"}, {"end": 235.6, "start": 235.6, "text": "talk"}, {"end": 235.6, "start": 235.6, "text": "and"}, {"end": 235.6, "start": 235.6, "text": "presenting"}, {"end": 235.6, "start": 235.6, "text": "to"}, {"end": 235.6, "start": 235.6, "text": "you"}, {"end": 235.6, "start": 235.6, "text": "in"}, {"end": 235.64, "start": 235.6, "text": "this"}, {"end": 235.88, "start": 235.64, "text": "talk"}, {"end": 236.2, "start": 235.88, "text": "is"}, {"end": 236.68, "start": 236.2, "text": "that"}, {"end": 237.04, "start": 236.68, "text": "the"}, {"end": 237.44, "start": 237.04, "text": "enablers"}, {"end": 237.72, "start": 237.44, "text": "of"}, {"end": 238.2, "start": 237.72, "text": "exponential"}, {"end": 238.6, "start": 238.2, "text": "growth"}, {"end": 238.6, "start": 238.6, "text": "that"}, {"end": 238.64, "start": 238.6, "text": "have"}, {"end": 238.96, "start": 238.64, "text": "gotten"}, {"end": 239.36, "start": 238.96, "text": "us"}, {"end": 239.48, "start": 239.36, "text": "through"}, {"end": 239.96, "start": 239.48, "text": "the"}], "text": " And 50 years in, I think it's fair to say that we're just getting started. What can we imagine for the next 50, 60 years? At the same time, I think 50 years in, we are at an inflection point. And paradoxically, it may be that the underlying principles that enabled this revolution, this true revolution, may need to be revisited to allow us to take the internet to the next level. So what I'm going to be arguing in this talk and presenting to you in this talk is that the enablers of exponential growth that have gotten us through the"}, {"chunks": [{"end": 240.52, "start": 240.0, "text": "last"}, {"end": 240.56, "start": 240.52, "text": "50"}, {"end": 240.8, "start": 240.56, "text": "years"}, {"end": 241.44, "start": 240.8, "text": "across"}, {"end": 241.8, "start": 241.44, "text": "the"}, {"end": 241.88, "start": 241.8, "text": "internet,"}, {"end": 242.08, "start": 241.88, "text": "but"}, {"end": 242.48, "start": 242.08, "text": "in"}, {"end": 242.8, "start": 242.48, "text": "neighboring"}, {"end": 243.32, "start": 242.8, "text": "domains"}, {"end": 243.4, "start": 243.32, "text": "like"}, {"end": 243.96, "start": 243.4, "text": "computer"}, {"end": 244.44, "start": 243.96, "text": "architecture,"}, {"end": 245.4, "start": 244.44, "text": "storage,"}, {"end": 246.36, "start": 245.4, "text": "memory,"}, {"end": 246.84, "start": 246.36, "text": "the"}, {"end": 246.96, "start": 246.84, "text": "enablers"}, {"end": 247.08, "start": 246.96, "text": "of"}, {"end": 247.4, "start": 247.08, "text": "this"}, {"end": 247.84, "start": 247.4, "text": "exponential"}, {"end": 248.44, "start": 247.84, "text": "growth"}, {"end": 249.0, "start": 248.44, "text": "have"}, {"end": 249.72, "start": 249.0, "text": "effectively"}, {"end": 250.44, "start": 249.72, "text": "stalled"}, {"end": 250.6, "start": 250.44, "text": "or"}, {"end": 250.88, "start": 250.6, "text": "come"}, {"end": 251.2, "start": 250.88, "text": "to"}, {"end": 251.2, "start": 251.2, "text": "a"}, {"end": 251.72, "start": 251.2, "text": "dramatic"}, {"end": 252.52, "start": 251.72, "text": "slowdown."}, {"end": 252.76, "start": 252.52, "text": "This"}, {"end": 252.88, "start": 252.76, "text": "is"}, {"end": 253.2, "start": 252.88, "text": "at"}, {"end": 253.52, "start": 253.2, "text": "the"}, {"end": 253.8, "start": 253.52, "text": "same"}, {"end": 254.0, "start": 253.8, "text": "time"}, {"end": 254.24, "start": 254.0, "text": "that"}, {"end": 254.76, "start": 254.24, "text": "societal"}, {"end": 255.36, "start": 254.76, "text": "infrastructure"}, {"end": 255.56, "start": 255.36, "text": "demand"}, {"end": 255.72, "start": 255.56, "text": "continues"}, {"end": 256.68, "start": 255.72, "text": "to"}, {"end": 256.96, "start": 256.68, "text": "rise"}, {"end": 257.48, "start": 256.96, "text": "exponentially,"}, {"end": 257.6, "start": 257.48, "text": "in"}, {"end": 257.88, "start": 257.6, "text": "fact,"}, {"end": 258.68, "start": 257.88, "text": "accelerates."}, {"end": 259.0, "start": 258.68, "text": "So"}, {"end": 259.08, "start": 259.0, "text": "we're"}, {"end": 259.76, "start": 259.08, "text": "facing"}, {"end": 260.04, "start": 259.76, "text": "a"}, {"end": 260.28, "start": 260.04, "text": "very"}, {"end": 260.56, "start": 260.28, "text": "interesting"}, {"end": 261.48, "start": 260.56, "text": "situation"}, {"end": 261.88, "start": 261.48, "text": "where"}, {"end": 262.0, "start": 261.88, "text": "the"}, {"end": 262.52, "start": 262.0, "text": "enablers"}, {"end": 262.84, "start": 262.52, "text": "of"}, {"end": 263.08, "start": 262.84, "text": "exponential"}, {"end": 263.72, "start": 263.08, "text": "growth"}, {"end": 263.88, "start": 263.72, "text": "are"}, {"end": 264.2, "start": 263.88, "text": "slowing"}, {"end": 264.28, "start": 264.2, "text": "or"}, {"end": 265.04, "start": 264.28, "text": "stopping"}, {"end": 265.56, "start": 265.04, "text": "while"}, {"end": 265.72, "start": 265.56, "text": "the"}, {"end": 266.2, "start": 265.72, "text": "demand"}, {"end": 266.48, "start": 266.2, "text": "for"}, {"end": 266.48, "start": 266.48, "text": "the"}, {"end": 267.08, "start": 266.48, "text": "infrastructure"}, {"end": 267.08, "start": 267.08, "text": "is"}, {"end": 267.12, "start": 267.08, "text": "growing"}, {"end": 267.48, "start": 267.12, "text": "ever"}, {"end": 267.8, "start": 267.48, "text": "more"}, {"end": 269.2, "start": 267.8, "text": "rapidly."}, {"end": 269.6, "start": 269.2, "text": "So"}, {"end": 269.6, "start": 269.6, "text": "putting"}, {"end": 269.88, "start": 269.6, "text": "these"}, {"end": 269.96, "start": 269.88, "text": "two"}], "text": " last 50 years across the internet, but in neighboring domains like computer architecture, storage, memory, the enablers of this exponential growth have effectively stalled or come to a dramatic slowdown. This is at the same time that societal infrastructure demand continues to rise exponentially, in fact, accelerates. So we're facing a very interesting situation where the enablers of exponential growth are slowing or stopping while the demand for the infrastructure is growing ever more rapidly. So putting these two"}, {"chunks": [{"end": 270.24, "start": 270.0, "text": "together"}, {"end": 270.28, "start": 270.24, "text": "we"}, {"end": 270.64, "start": 270.28, "text": "have"}, {"end": 270.88, "start": 270.64, "text": "a"}, {"end": 271.6, "start": 270.88, "text": "substantial"}, {"end": 272.32, "start": 271.6, "text": "challenge"}, {"end": 272.6, "start": 272.32, "text": "and"}, {"end": 272.84, "start": 272.6, "text": "I"}, {"end": 273.12, "start": 272.84, "text": "believe"}, {"end": 273.12, "start": 273.12, "text": "that"}, {"end": 273.24, "start": 273.12, "text": "we"}, {"end": 273.28, "start": 273.24, "text": "have"}, {"end": 273.36, "start": 273.28, "text": "a"}, {"end": 273.68, "start": 273.36, "text": "once"}, {"end": 273.68, "start": 273.68, "text": "in"}, {"end": 273.72, "start": 273.68, "text": "a"}, {"end": 274.12, "start": 273.72, "text": "generation"}, {"end": 274.76, "start": 274.12, "text": "opportunity"}, {"end": 275.36, "start": 274.76, "text": "to"}, {"end": 276.04, "start": 275.36, "text": "redefine"}, {"end": 276.04, "start": 276.04, "text": "what"}, {"end": 276.08, "start": 276.04, "text": "the"}, {"end": 276.44, "start": 276.08, "text": "basic"}, {"end": 276.68, "start": 276.44, "text": "model"}, {"end": 276.84, "start": 276.68, "text": "of"}, {"end": 276.84, "start": 276.84, "text": "computing"}, {"end": 276.84, "start": 276.84, "text": "is"}, {"end": 277.04, "start": 276.84, "text": "to"}, {"end": 277.32, "start": 277.04, "text": "enable"}, {"end": 277.8, "start": 277.32, "text": "us"}, {"end": 278.16, "start": 277.8, "text": "to"}, {"end": 279.28, "start": 278.16, "text": "sustain"}, {"end": 279.68, "start": 279.28, "text": "the"}, {"end": 280.16, "start": 279.68, "text": "necessary"}, {"end": 280.64, "start": 280.16, "text": "exponential"}, {"end": 281.0, "start": 280.64, "text": "growth"}, {"end": 281.0, "start": 281.0, "text": "to"}, {"end": 281.0, "start": 281.0, "text": "take"}, {"end": 281.24, "start": 281.0, "text": "on"}, {"end": 282.52, "start": 281.24, "text": "society's"}, {"end": 283.36, "start": 282.52, "text": "computational"}, {"end": 283.88, "start": 283.36, "text": "storage"}, {"end": 284.16, "start": 283.88, "text": "and"}, {"end": 284.56, "start": 284.16, "text": "communication"}, {"end": 286.0, "start": 284.56, "text": "needs."}, {"end": 286.12, "start": 286.0, "text": "I"}, {"end": 287.0, "start": 286.12, "text": "believe"}, {"end": 287.76, "start": 287.0, "text": "that"}, {"end": 288.44, "start": 287.76, "text": "just"}, {"end": 289.16, "start": 288.44, "text": "as"}, {"end": 289.24, "start": 289.16, "text": "the"}, {"end": 289.6, "start": 289.24, "text": "past"}, {"end": 289.68, "start": 289.6, "text": "50"}, {"end": 290.36, "start": 289.68, "text": "years"}, {"end": 290.96, "start": 290.36, "text": "have"}, {"end": 291.92, "start": 290.96, "text": "shown"}, {"end": 291.92, "start": 291.92, "text": "the"}, {"end": 291.92, "start": 291.92, "text": "network"}, {"end": 291.92, "start": 291.92, "text": "must"}, {"end": 292.56, "start": 291.92, "text": "and"}, {"end": 292.68, "start": 292.56, "text": "will"}, {"end": 292.88, "start": 292.68, "text": "enable"}, {"end": 293.36, "start": 292.88, "text": "sustained"}, {"end": 293.8, "start": 293.36, "text": "exponential"}, {"end": 294.32, "start": 293.8, "text": "growth"}, {"end": 294.48, "start": 294.32, "text": "in"}, {"end": 294.96, "start": 294.48, "text": "effective"}, {"end": 295.36, "start": 294.96, "text": "computing"}, {"end": 295.76, "start": 295.36, "text": "storage"}, {"end": 296.24, "start": 295.76, "text": "capacity."}, {"end": 296.96, "start": 296.24, "text": "Computing,"}, {"end": 297.52, "start": 296.96, "text": "storage"}, {"end": 297.72, "start": 297.52, "text": "and"}, {"end": 298.32, "start": 297.72, "text": "networking"}, {"end": 298.64, "start": 298.32, "text": "are"}, {"end": 298.84, "start": 298.64, "text": "deeply"}, {"end": 299.96, "start": 298.84, "text": "intertwined."}], "text": " together we have a substantial challenge and I believe that we have a once in a generation opportunity to redefine what the basic model of computing is to enable us to sustain the necessary exponential growth to take on society's computational storage and communication needs. I believe that just as the past 50 years have shown the network must and will enable sustained exponential growth in effective computing storage capacity. Computing, storage and networking are deeply intertwined."}, {"chunks": [{"end": 300.0, "start": 300.0, "text": "But"}, {"end": 300.0, "start": 300.0, "text": "we're"}, {"end": 300.28, "start": 300.0, "text": "gonna"}, {"end": 301.68, "start": 300.28, "text": "have"}, {"end": 301.96, "start": 301.68, "text": "a"}, {"end": 302.72, "start": 301.96, "text": "really"}, {"end": 303.08, "start": 302.72, "text": "exciting"}, {"end": 303.68, "start": 303.08, "text": "opportunity"}, {"end": 303.68, "start": 303.68, "text": "in"}, {"end": 303.92, "start": 303.68, "text": "that"}, {"end": 303.96, "start": 303.92, "text": "the"}, {"end": 304.44, "start": 303.96, "text": "conventional"}, {"end": 304.76, "start": 304.44, "text": "wisdom"}, {"end": 305.0, "start": 304.76, "text": "that"}, {"end": 305.08, "start": 305.0, "text": "we've"}, {"end": 305.48, "start": 305.08, "text": "developed"}, {"end": 305.72, "start": 305.48, "text": "over"}, {"end": 305.76, "start": 305.72, "text": "the"}, {"end": 306.4, "start": 305.76, "text": "past"}, {"end": 306.76, "start": 306.4, "text": "15,"}, {"end": 307.04, "start": 306.76, "text": "20"}, {"end": 307.4, "start": 307.04, "text": "years,"}, {"end": 307.48, "start": 307.4, "text": "depending"}, {"end": 307.6, "start": 307.48, "text": "on"}, {"end": 307.84, "start": 307.6, "text": "how"}, {"end": 308.16, "start": 307.84, "text": "you"}, {"end": 308.64, "start": 308.16, "text": "look"}, {"end": 308.72, "start": 308.64, "text": "at"}, {"end": 308.96, "start": 308.72, "text": "things,"}, {"end": 309.16, "start": 308.96, "text": "is"}, {"end": 309.2, "start": 309.16, "text": "breaking"}, {"end": 309.64, "start": 309.2, "text": "down."}, {"end": 309.88, "start": 309.64, "text": "We're"}, {"end": 310.08, "start": 309.88, "text": "going"}, {"end": 310.08, "start": 310.08, "text": "to"}, {"end": 310.2, "start": 310.08, "text": "need"}, {"end": 310.2, "start": 310.2, "text": "to"}, {"end": 310.72, "start": 310.2, "text": "develop"}, {"end": 310.88, "start": 310.72, "text": "in"}, {"end": 311.28, "start": 310.88, "text": "this"}, {"end": 311.76, "start": 311.28, "text": "generation"}, {"end": 312.04, "start": 311.76, "text": "new"}, {"end": 312.44, "start": 312.04, "text": "conventional"}, {"end": 312.68, "start": 312.44, "text": "wisdom."}, {"end": 313.88, "start": 312.68, "text": "We"}, {"end": 314.28, "start": 313.88, "text": "are"}, {"end": 314.32, "start": 314.28, "text": "on"}, {"end": 314.48, "start": 314.32, "text": "this"}, {"end": 315.32, "start": 314.48, "text": "manifest"}, {"end": 316.2, "start": 315.32, "text": "journey"}, {"end": 316.44, "start": 316.2, "text": "where"}, {"end": 316.44, "start": 316.44, "text": "we"}, {"end": 317.44, "start": 316.44, "text": "continuously"}, {"end": 318.2, "start": 317.44, "text": "conquer"}, {"end": 318.28, "start": 318.2, "text": "the"}, {"end": 318.88, "start": 318.28, "text": "previously"}, {"end": 319.64, "start": 318.88, "text": "impossible"}, {"end": 319.76, "start": 319.64, "text": "through"}, {"end": 320.24, "start": 319.76, "text": "tides"}, {"end": 320.24, "start": 320.24, "text": "of"}, {"end": 320.68, "start": 320.24, "text": "innovation,"}, {"end": 320.68, "start": 320.68, "text": "but"}, {"end": 320.68, "start": 320.68, "text": "we're"}, {"end": 320.68, "start": 320.68, "text": "at"}, {"end": 320.72, "start": 320.68, "text": "a"}, {"end": 321.92, "start": 320.72, "text": "transition"}, {"end": 322.32, "start": 321.92, "text": "point"}, {"end": 322.88, "start": 322.32, "text": "from"}, {"end": 323.12, "start": 322.88, "text": "one"}, {"end": 323.32, "start": 323.12, "text": "point"}, {"end": 323.32, "start": 323.32, "text": "in"}, {"end": 323.52, "start": 323.32, "text": "this"}, {"end": 323.72, "start": 323.52, "text": "journey"}, {"end": 324.28, "start": 323.72, "text": "to"}, {"end": 324.76, "start": 324.28, "text": "another."}, {"end": 325.12, "start": 324.76, "text": "I'm"}, {"end": 325.24, "start": 325.12, "text": "going"}, {"end": 325.24, "start": 325.24, "text": "to"}, {"end": 325.68, "start": 325.24, "text": "present"}, {"end": 325.96, "start": 325.68, "text": "to"}, {"end": 326.12, "start": 325.96, "text": "you"}, {"end": 326.24, "start": 326.12, "text": "one"}, {"end": 326.88, "start": 326.24, "text": "taxonomy"}, {"end": 326.88, "start": 326.88, "text": "of"}, {"end": 327.28, "start": 326.88, "text": "the"}, {"end": 327.48, "start": 327.28, "text": "50"}, {"end": 327.64, "start": 327.48, "text": "year"}, {"end": 328.2, "start": 327.64, "text": "journey"}, {"end": 328.52, "start": 328.2, "text": "that"}, {"end": 328.56, "start": 328.52, "text": "we've"}, {"end": 328.56, "start": 328.56, "text": "been"}, {"end": 328.76, "start": 328.56, "text": "on,"}, {"end": 328.96, "start": 328.76, "text": "split"}, {"end": 329.36, "start": 328.96, "text": "across"}, {"end": 329.96, "start": 329.36, "text": "multiple"}], "text": " But we're gonna have a really exciting opportunity in that the conventional wisdom that we've developed over the past 15, 20 years, depending on how you look at things, is breaking down. We're going to need to develop in this generation new conventional wisdom. We are on this manifest journey where we continuously conquer the previously impossible through tides of innovation, but we're at a transition point from one point in this journey to another. I'm going to present to you one taxonomy of the 50 year journey that we've been on, split across multiple"}, {"chunks": [{"end": 330.64, "start": 330.0, "text": "epochs"}, {"end": 330.84, "start": 330.64, "text": "of"}, {"end": 331.48, "start": 330.84, "text": "time."}, {"end": 331.68, "start": 331.48, "text": "I'll"}, {"end": 331.68, "start": 331.68, "text": "argue"}, {"end": 331.76, "start": 331.68, "text": "that"}, {"end": 332.16, "start": 331.76, "text": "we"}, {"end": 332.48, "start": 332.16, "text": "are"}, {"end": 332.8, "start": 332.48, "text": "just"}, {"end": 333.48, "start": 332.8, "text": "entering"}, {"end": 333.88, "start": 333.48, "text": "the"}, {"end": 334.08, "start": 333.88, "text": "fifth"}, {"end": 334.68, "start": 334.08, "text": "epoch"}, {"end": 334.88, "start": 334.68, "text": "of"}, {"end": 335.6, "start": 334.88, "text": "time"}, {"end": 336.16, "start": 335.6, "text": "and"}, {"end": 336.52, "start": 336.16, "text": "some"}, {"end": 337.24, "start": 336.52, "text": "substantial"}, {"end": 337.84, "start": 337.24, "text": "transitions"}, {"end": 337.88, "start": 337.84, "text": "are"}, {"end": 338.08, "start": 337.88, "text": "going"}, {"end": 338.08, "start": 338.08, "text": "to"}, {"end": 338.2, "start": 338.08, "text": "need"}, {"end": 338.4, "start": 338.2, "text": "to"}, {"end": 338.4, "start": 338.4, "text": "take"}, {"end": 338.88, "start": 338.4, "text": "place,"}, {"end": 339.24, "start": 338.88, "text": "not"}, {"end": 339.76, "start": 339.24, "text": "least"}, {"end": 339.8, "start": 339.76, "text": "of"}, {"end": 340.44, "start": 339.8, "text": "which"}, {"end": 340.84, "start": 340.44, "text": "are"}, {"end": 341.16, "start": 340.84, "text": "we're"}, {"end": 341.24, "start": 341.16, "text": "going"}, {"end": 341.24, "start": 341.24, "text": "to"}, {"end": 341.24, "start": 341.24, "text": "need"}, {"end": 341.24, "start": 341.24, "text": "new"}, {"end": 341.64, "start": 341.24, "text": "programming"}, {"end": 342.24, "start": 341.64, "text": "models"}, {"end": 342.24, "start": 342.24, "text": "and"}, {"end": 342.36, "start": 342.24, "text": "new"}, {"end": 342.96, "start": 342.36, "text": "networking"}, {"end": 343.64, "start": 342.96, "text": "stacks"}, {"end": 344.2, "start": 343.64, "text": "to"}, {"end": 344.76, "start": 344.2, "text": "basically"}, {"end": 345.0, "start": 344.76, "text": "meet"}, {"end": 345.4, "start": 345.0, "text": "the"}, {"end": 345.76, "start": 345.4, "text": "evolving"}, {"end": 346.6, "start": 345.76, "text": "productivity"}, {"end": 347.0, "start": 346.6, "text": "and"}, {"end": 347.56, "start": 347.0, "text": "computing"}, {"end": 348.0, "start": 347.56, "text": "needs"}, {"end": 348.32, "start": 348.0, "text": "of"}, {"end": 348.64, "start": 348.32, "text": "our"}, {"end": 349.36, "start": 348.64, "text": "distributed"}, {"end": 349.64, "start": 349.36, "text": "systems."}, {"end": 349.88, "start": 349.64, "text": "This"}, {"end": 350.16, "start": 349.88, "text": "will"}, {"end": 350.88, "start": 350.16, "text": "require,"}, {"end": 351.2, "start": 350.88, "text": "again,"}, {"end": 351.44, "start": 351.2, "text": "among"}, {"end": 351.68, "start": 351.44, "text": "many"}, {"end": 351.84, "start": 351.68, "text": "other"}, {"end": 352.32, "start": 351.84, "text": "things,"}, {"end": 352.4, "start": 352.32, "text": "a"}, {"end": 352.6, "start": 352.4, "text": "move"}, {"end": 352.68, "start": 352.6, "text": "from"}, {"end": 353.28, "start": 352.68, "text": "software-defined"}, {"end": 353.8, "start": 353.28, "text": "networking"}, {"end": 353.96, "start": 353.8, "text": "to"}, {"end": 354.8, "start": 353.96, "text": "software-defined"}, {"end": 355.64, "start": 354.8, "text": "infrastructure,"}, {"end": 355.88, "start": 355.64, "text": "really"}, {"end": 356.16, "start": 355.88, "text": "bringing"}, {"end": 356.56, "start": 356.16, "text": "together"}, {"end": 357.0, "start": 356.56, "text": "finally"}, {"end": 357.32, "start": 357.0, "text": "compute"}, {"end": 357.64, "start": 357.32, "text": "storage"}, {"end": 357.92, "start": 357.64, "text": "and"}, {"end": 358.68, "start": 357.92, "text": "networking"}, {"end": 358.92, "start": 358.68, "text": "in"}, {"end": 359.28, "start": 358.92, "text": "an"}, {"end": 359.52, "start": 359.28, "text": "intertwined"}, {"end": 359.96, "start": 359.52, "text": "manner."}], "text": " epochs of time. I'll argue that we are just entering the fifth epoch of time and some substantial transitions are going to need to take place, not least of which are we're going to need new programming models and new networking stacks to basically meet the evolving productivity and computing needs of our distributed systems. This will require, again, among many other things, a move from software-defined networking to software-defined infrastructure, really bringing together finally compute storage and networking in an intertwined manner."}, {"chunks": [{"end": 361.32, "start": 360.0, "text": "Okay,"}, {"end": 361.72, "start": 361.32, "text": "so"}, {"end": 362.28, "start": 361.72, "text": "continuing"}, {"end": 362.52, "start": 362.28, "text": "on"}, {"end": 363.04, "start": 362.52, "text": "the"}, {"end": 363.4, "start": 363.04, "text": "theme"}, {"end": 363.64, "start": 363.4, "text": "of"}, {"end": 364.12, "start": 363.64, "text": "history,"}, {"end": 364.36, "start": 364.12, "text": "let"}, {"end": 364.36, "start": 364.36, "text": "me"}, {"end": 365.16, "start": 364.36, "text": "present"}, {"end": 365.24, "start": 365.16, "text": "to"}, {"end": 365.44, "start": 365.24, "text": "you"}, {"end": 365.56, "start": 365.44, "text": "a"}, {"end": 366.4, "start": 365.56, "text": "taxonomy"}, {"end": 366.64, "start": 366.4, "text": "of"}, {"end": 367.0, "start": 366.64, "text": "five"}, {"end": 367.68, "start": 367.0, "text": "epochs"}, {"end": 367.92, "start": 367.68, "text": "of"}, {"end": 368.44, "start": 367.92, "text": "distributed"}, {"end": 368.92, "start": 368.44, "text": "computing."}, {"end": 369.32, "start": 368.92, "text": "Each"}, {"end": 369.56, "start": 369.32, "text": "of"}, {"end": 370.08, "start": 369.56, "text": "these"}, {"end": 370.48, "start": 370.08, "text": "epochs,"}, {"end": 370.52, "start": 370.48, "text": "you"}, {"end": 370.92, "start": 370.52, "text": "know,"}, {"end": 371.4, "start": 370.92, "text": "they"}, {"end": 371.64, "start": 371.4, "text": "have"}, {"end": 372.0, "start": 371.64, "text": "fuzzy"}, {"end": 372.36, "start": 372.0, "text": "beginnings"}, {"end": 372.36, "start": 372.36, "text": "and"}, {"end": 372.64, "start": 372.36, "text": "fuzzy"}, {"end": 373.0, "start": 372.64, "text": "endings"}, {"end": 373.36, "start": 373.0, "text": "as"}, {"end": 373.52, "start": 373.36, "text": "all"}, {"end": 373.92, "start": 373.52, "text": "historical"}, {"end": 374.72, "start": 373.92, "text": "epochs"}, {"end": 374.88, "start": 374.72, "text": "do."}, {"end": 374.92, "start": 374.88, "text": "Let's"}, {"end": 374.92, "start": 374.92, "text": "say"}, {"end": 374.92, "start": 374.92, "text": "that"}, {"end": 374.92, "start": 374.92, "text": "we"}, {"end": 375.0, "start": 374.92, "text": "start"}, {"end": 375.64, "start": 375.0, "text": "roughly"}, {"end": 376.16, "start": 375.64, "text": "around"}, {"end": 377.44, "start": 376.16, "text": "1970"}, {"end": 377.72, "start": 377.44, "text": "with"}, {"end": 377.92, "start": 377.72, "text": "both"}, {"end": 378.36, "start": 377.92, "text": "the"}, {"end": 378.44, "start": 378.36, "text": "birth"}, {"end": 378.64, "start": 378.44, "text": "of"}, {"end": 379.04, "start": 378.64, "text": "the"}, {"end": 379.88, "start": 379.04, "text": "internet"}, {"end": 380.12, "start": 379.88, "text": "and"}, {"end": 380.88, "start": 380.12, "text": "interestingly"}, {"end": 381.32, "start": 380.88, "text": "about"}, {"end": 381.68, "start": 381.32, "text": "the"}, {"end": 381.96, "start": 381.68, "text": "point"}, {"end": 382.0, "start": 381.96, "text": "in"}, {"end": 382.28, "start": 382.0, "text": "which"}, {"end": 382.56, "start": 382.28, "text": "Moore's"}, {"end": 382.88, "start": 382.56, "text": "law"}, {"end": 382.96, "start": 382.88, "text": "took"}, {"end": 383.16, "start": 382.96, "text": "off"}, {"end": 383.48, "start": 383.16, "text": "for"}, {"end": 384.0, "start": 383.48, "text": "computer"}, {"end": 384.56, "start": 384.0, "text": "architecture"}, {"end": 385.32, "start": 384.56, "text": "improvements"}, {"end": 385.52, "start": 385.32, "text": "in"}, {"end": 386.08, "start": 385.52, "text": "performance."}, {"end": 386.2, "start": 386.08, "text": "We'll"}, {"end": 386.4, "start": 386.2, "text": "see"}, {"end": 386.6, "start": 386.4, "text": "that"}, {"end": 387.04, "start": 386.6, "text": "connect"}, {"end": 387.28, "start": 387.04, "text": "back"}, {"end": 388.24, "start": 387.28, "text": "later."}, {"end": 389.2, "start": 388.24, "text": "So"}, {"end": 389.2, "start": 389.2, "text": "epoch"}, {"end": 389.2, "start": 389.2, "text": "one"}, {"end": 389.84, "start": 389.2, "text": "consisted"}, {"end": 389.96, "start": 389.84, "text": "of"}], "text": " Okay, so continuing on the theme of history, let me present to you a taxonomy of five epochs of distributed computing. Each of these epochs, you know, they have fuzzy beginnings and fuzzy endings as all historical epochs do. Let's say that we start roughly around 1970 with both the birth of the internet and interestingly about the point in which Moore's law took off for computer architecture improvements in performance. We'll see that connect back later. So epoch one consisted of"}, {"chunks": [{"end": 391.0, "start": 390.0, "text": "applications"}, {"end": 391.32, "start": 391.0, "text": "like"}, {"end": 391.8, "start": 391.32, "text": "FTP,"}, {"end": 392.04, "start": 391.8, "text": "email,"}, {"end": 392.2, "start": 392.04, "text": "and"}, {"end": 392.64, "start": 392.2, "text": "telnet."}, {"end": 392.76, "start": 392.64, "text": "At"}, {"end": 392.76, "start": 392.76, "text": "this"}, {"end": 392.76, "start": 392.76, "text": "point,"}, {"end": 393.48, "start": 392.76, "text": "they"}, {"end": 394.12, "start": 393.48, "text": "also"}, {"end": 394.84, "start": 394.12, "text": "mark"}, {"end": 394.84, "start": 394.84, "text": "in"}, {"end": 395.16, "start": 394.84, "text": "each"}, {"end": 395.48, "start": 395.16, "text": "epoch"}, {"end": 395.56, "start": 395.48, "text": "the"}, {"end": 396.24, "start": 395.56, "text": "interaction"}, {"end": 396.64, "start": 396.24, "text": "times"}, {"end": 397.0, "start": 396.64, "text": "among"}, {"end": 397.2, "start": 397.0, "text": "computers."}, {"end": 397.2, "start": 397.2, "text": "At"}, {"end": 397.56, "start": 397.2, "text": "this"}, {"end": 398.12, "start": 397.56, "text": "point,"}, {"end": 398.56, "start": 398.12, "text": "interaction"}, {"end": 398.84, "start": 398.56, "text": "time"}, {"end": 399.04, "start": 398.84, "text": "was"}, {"end": 399.08, "start": 399.04, "text": "on"}, {"end": 399.2, "start": 399.08, "text": "the"}, {"end": 399.56, "start": 399.2, "text": "order"}, {"end": 399.84, "start": 399.56, "text": "of"}, {"end": 399.92, "start": 399.84, "text": "100"}, {"end": 400.64, "start": 399.92, "text": "milliseconds."}, {"end": 400.96, "start": 400.64, "text": "We"}, {"end": 401.56, "start": 400.96, "text": "had"}, {"end": 401.88, "start": 401.56, "text": "low"}, {"end": 402.68, "start": 401.88, "text": "bandwidth"}, {"end": 403.04, "start": 402.68, "text": "links,"}, {"end": 403.36, "start": 403.04, "text": "high"}, {"end": 403.6, "start": 403.36, "text": "latency"}, {"end": 404.24, "start": 403.6, "text": "networks,"}, {"end": 404.56, "start": 404.24, "text": "and"}, {"end": 404.72, "start": 404.56, "text": "again,"}, {"end": 404.88, "start": 404.72, "text": "there"}, {"end": 405.2, "start": 404.88, "text": "was"}, {"end": 405.44, "start": 405.2, "text": "rare"}, {"end": 405.96, "start": 405.44, "text": "pairwise"}, {"end": 406.84, "start": 405.96, "text": "interactions"}, {"end": 407.36, "start": 406.84, "text": "between"}, {"end": 407.92, "start": 407.36, "text": "expensive"}, {"end": 408.48, "start": 407.92, "text": "computers."}, {"end": 409.6, "start": 408.48, "text": "Epoch"}, {"end": 410.52, "start": 409.6, "text": "II"}, {"end": 411.28, "start": 410.52, "text": "started"}, {"end": 412.44, "start": 411.28, "text": "approximately,"}, {"end": 412.6, "start": 412.44, "text": "let's"}, {"end": 412.8, "start": 412.6, "text": "say,"}, {"end": 413.44, "start": 412.8, "text": "1984,"}, {"end": 414.52, "start": 413.44, "text": "1985"}, {"end": 414.72, "start": 414.52, "text": "by"}, {"end": 414.84, "start": 414.72, "text": "one"}, {"end": 414.84, "start": 414.84, "text": "marking"}, {"end": 414.88, "start": 414.84, "text": "with"}, {"end": 415.08, "start": 414.88, "text": "the"}, {"end": 415.32, "start": 415.08, "text": "birth"}, {"end": 415.64, "start": 415.32, "text": "of"}, {"end": 416.16, "start": 415.64, "text": "RPC,"}, {"end": 416.32, "start": 416.16, "text": "the"}, {"end": 416.6, "start": 416.32, "text": "remote"}, {"end": 416.92, "start": 416.6, "text": "procedure"}, {"end": 417.32, "start": 416.92, "text": "call,"}, {"end": 417.4, "start": 417.32, "text": "and"}, {"end": 418.36, "start": 417.4, "text": "client-server"}, {"end": 419.96, "start": 418.36, "text": "computing."}], "text": " applications like FTP, email, and telnet. At this point, they also mark in each epoch the interaction times among computers. At this point, interaction time was on the order of 100 milliseconds. We had low bandwidth links, high latency networks, and again, there was rare pairwise interactions between expensive computers. Epoch II started approximately, let's say, 1984, 1985 by one marking with the birth of RPC, the remote procedure call, and client-server computing."}, {"chunks": [{"end": 420.24, "start": 420.0, "text": "certainly"}, {"end": 420.48, "start": 420.24, "text": "for"}, {"end": 420.68, "start": 420.48, "text": "the"}, {"end": 420.92, "start": 420.68, "text": "time,"}, {"end": 421.2, "start": 420.92, "text": "local"}, {"end": 421.32, "start": 421.2, "text": "area"}, {"end": 421.6, "start": 421.32, "text": "networks."}, {"end": 421.96, "start": 421.6, "text": "Interaction"}, {"end": 422.0, "start": 421.96, "text": "times"}, {"end": 422.32, "start": 422.0, "text": "may"}, {"end": 423.04, "start": 422.32, "text": "have"}, {"end": 423.6, "start": 423.04, "text": "dropped"}, {"end": 423.84, "start": 423.6, "text": "to"}, {"end": 424.16, "start": 423.84, "text": "about"}, {"end": 424.48, "start": 424.16, "text": "10"}, {"end": 425.24, "start": 424.48, "text": "milliseconds."}, {"end": 425.84, "start": 425.24, "text": "Networks"}, {"end": 425.88, "start": 425.84, "text": "grew"}, {"end": 426.16, "start": 425.88, "text": "to"}, {"end": 426.32, "start": 426.16, "text": "10"}, {"end": 427.04, "start": 426.32, "text": "megabits"}, {"end": 427.24, "start": 427.04, "text": "per"}, {"end": 427.36, "start": 427.24, "text": "second"}, {"end": 427.52, "start": 427.36, "text": "in"}, {"end": 428.56, "start": 427.52, "text": "speed."}, {"end": 428.92, "start": 428.56, "text": "And"}, {"end": 429.04, "start": 428.92, "text": "we"}, {"end": 429.96, "start": 429.04, "text": "started"}, {"end": 430.28, "start": 429.96, "text": "through"}, {"end": 430.64, "start": 430.28, "text": "things"}, {"end": 430.88, "start": 430.64, "text": "like"}, {"end": 431.24, "start": 430.88, "text": "RPC,"}, {"end": 431.64, "start": 431.24, "text": "sharing"}, {"end": 432.28, "start": 431.64, "text": "resources"}, {"end": 432.48, "start": 432.28, "text": "between"}, {"end": 432.92, "start": 432.48, "text": "multiple"}, {"end": 433.52, "start": 432.92, "text": "computers,"}, {"end": 433.64, "start": 433.52, "text": "you"}, {"end": 433.76, "start": 433.64, "text": "know,"}, {"end": 435.2, "start": 433.76, "text": "synchronously."}, {"end": 435.44, "start": 435.2, "text": "Epoch"}, {"end": 436.48, "start": 435.44, "text": "3"}, {"end": 437.0, "start": 436.48, "text": "saw"}, {"end": 437.2, "start": 437.0, "text": "the"}, {"end": 437.92, "start": 437.2, "text": "rise"}, {"end": 438.16, "start": 437.92, "text": "of"}, {"end": 438.56, "start": 438.16, "text": "HTTP"}, {"end": 438.6, "start": 438.56, "text": "in"}, {"end": 438.84, "start": 438.6, "text": "the"}, {"end": 439.44, "start": 438.84, "text": "web,"}, {"end": 439.8, "start": 439.44, "text": "three-tiered"}, {"end": 440.48, "start": 439.8, "text": "services,"}, {"end": 440.52, "start": 440.48, "text": "and"}, {"end": 440.92, "start": 440.52, "text": "massively"}, {"end": 441.52, "start": 440.92, "text": "parallel"}, {"end": 442.72, "start": 441.52, "text": "processing."}, {"end": 443.28, "start": 442.72, "text": "100"}, {"end": 443.48, "start": 443.28, "text": "megabits"}, {"end": 443.72, "start": 443.48, "text": "to"}, {"end": 443.76, "start": 443.72, "text": "gigabit"}, {"end": 444.12, "start": 443.76, "text": "per"}, {"end": 444.44, "start": 444.12, "text": "second"}, {"end": 444.88, "start": 444.44, "text": "networks"}, {"end": 445.2, "start": 444.88, "text": "were"}, {"end": 445.96, "start": 445.2, "text": "commonplace."}, {"end": 446.32, "start": 445.96, "text": "And"}, {"end": 446.32, "start": 446.32, "text": "we"}, {"end": 446.32, "start": 446.32, "text": "got"}, {"end": 446.32, "start": 446.32, "text": "to"}, {"end": 446.32, "start": 446.32, "text": "a"}, {"end": 446.72, "start": 446.32, "text": "point"}, {"end": 447.08, "start": 446.72, "text": "where"}, {"end": 447.68, "start": 447.08, "text": "complex"}, {"end": 448.4, "start": 447.68, "text": "applications"}, {"end": 448.8, "start": 448.4, "text": "no"}, {"end": 448.8, "start": 448.8, "text": "longer"}, {"end": 448.8, "start": 448.8, "text": "fit"}, {"end": 448.8, "start": 448.8, "text": "on"}, {"end": 448.8, "start": 448.8, "text": "a"}, {"end": 449.36, "start": 448.8, "text": "single"}, {"end": 449.96, "start": 449.36, "text": "server."}], "text": " certainly for the time, local area networks. Interaction times may have dropped to about 10 milliseconds. Networks grew to 10 megabits per second in speed. And we started through things like RPC, sharing resources between multiple computers, you know, synchronously. Epoch 3 saw the rise of HTTP in the web, three-tiered services, and massively parallel processing. 100 megabits to gigabit per second networks were commonplace. And we got to a point where complex applications no longer fit on a single server."}, {"chunks": [{"end": 450.2, "start": 450.0, "text": "We"}, {"end": 450.2, "start": 450.2, "text": "had"}, {"end": 450.32, "start": 450.2, "text": "to"}, {"end": 450.88, "start": 450.32, "text": "scale"}, {"end": 451.2, "start": 450.88, "text": "out"}, {"end": 451.36, "start": 451.2, "text": "across"}, {"end": 451.6, "start": 451.36, "text": "multiple"}, {"end": 451.6, "start": 451.6, "text": "servers."}, {"end": 451.6, "start": 451.6, "text": "Epoch"}, {"end": 451.68, "start": 451.6, "text": "4,"}, {"end": 451.68, "start": 451.68, "text": "we"}, {"end": 451.68, "start": 451.68, "text": "saw"}, {"end": 451.96, "start": 451.68, "text": "this"}, {"end": 451.96, "start": 451.96, "text": "is,"}, {"end": 453.76, "start": 451.96, "text": "let's"}, {"end": 454.84, "start": 453.76, "text": "say,"}, {"end": 457.36, "start": 454.84, "text": "around"}, {"end": 457.96, "start": 457.36, "text": "the"}, {"end": 458.32, "start": 457.96, "text": "year"}, {"end": 459.04, "start": 458.32, "text": "2000."}, {"end": 459.68, "start": 459.04, "text": "Moore's"}, {"end": 460.28, "start": 459.68, "text": "law"}, {"end": 460.48, "start": 460.28, "text": "hit"}, {"end": 460.72, "start": 460.48, "text": "its"}, {"end": 461.0, "start": 460.72, "text": "first"}, {"end": 461.6, "start": 461.0, "text": "wall,"}, {"end": 462.36, "start": 461.6, "text": "where"}, {"end": 463.12, "start": 462.36, "text": "after,"}, {"end": 463.36, "start": 463.12, "text": "let's"}, {"end": 463.64, "start": 463.36, "text": "say,"}, {"end": 463.88, "start": 463.64, "text": "30"}, {"end": 464.48, "start": 463.88, "text": "years"}, {"end": 464.56, "start": 464.48, "text": "of"}, {"end": 465.04, "start": 464.56, "text": "sustained"}, {"end": 465.64, "start": 465.04, "text": "exponential"}, {"end": 466.08, "start": 465.64, "text": "growth"}, {"end": 466.16, "start": 466.08, "text": "in"}, {"end": 466.16, "start": 466.16, "text": "the"}, {"end": 466.8, "start": 466.16, "text": "performance"}, {"end": 466.92, "start": 466.8, "text": "of"}, {"end": 467.2, "start": 466.92, "text": "individual"}, {"end": 468.2, "start": 467.2, "text": "processors,"}, {"end": 468.28, "start": 468.2, "text": "we"}, {"end": 468.68, "start": 468.28, "text": "no"}, {"end": 469.28, "start": 468.68, "text": "longer"}, {"end": 469.52, "start": 469.28, "text": "had"}, {"end": 469.76, "start": 469.52, "text": "any"}, {"end": 470.16, "start": 469.76, "text": "more"}, {"end": 470.68, "start": 470.16, "text": "performance"}, {"end": 471.12, "start": 470.68, "text": "improvements"}, {"end": 471.92, "start": 471.12, "text": "for"}, {"end": 472.24, "start": 471.92, "text": "single"}, {"end": 473.24, "start": 472.24, "text": "threads."}, {"end": 473.44, "start": 473.24, "text": "So"}, {"end": 473.48, "start": 473.44, "text": "we"}, {"end": 474.2, "start": 473.48, "text": "basically"}, {"end": 474.68, "start": 474.2, "text": "hit"}, {"end": 474.96, "start": 474.68, "text": "a"}, {"end": 475.6, "start": 474.96, "text": "core"}, {"end": 476.36, "start": 475.6, "text": "performance"}, {"end": 477.24, "start": 476.36, "text": "plateau."}, {"end": 477.44, "start": 477.24, "text": "We"}, {"end": 477.48, "start": 477.44, "text": "saw"}, {"end": 477.88, "start": 477.48, "text": "the"}, {"end": 478.52, "start": 477.88, "text": "rise"}, {"end": 478.8, "start": 478.52, "text": "of"}, {"end": 478.96, "start": 478.8, "text": "web"}, {"end": 479.56, "start": 478.96, "text": "search"}, {"end": 479.56, "start": 479.56, "text": "and"}, {"end": 479.96, "start": 479.56, "text": "planets"}], "text": " We had to scale out across multiple servers. Epoch 4, we saw this is, let's say, around the year 2000. Moore's law hit its first wall, where after, let's say, 30 years of sustained exponential growth in the performance of individual processors, we no longer had any more performance improvements for single threads. So we basically hit a core performance plateau. We saw the rise of web search and planets"}, {"chunks": [{"end": 480.2, "start": 480.0, "text": "So"}, {"end": 480.8, "start": 480.2, "text": "services,"}, {"end": 481.36, "start": 480.8, "text": "social"}, {"end": 481.72, "start": 481.36, "text": "networking,"}, {"end": 481.88, "start": 481.72, "text": "10"}, {"end": 481.92, "start": 481.88, "text": "gigit"}, {"end": 482.24, "start": 481.92, "text": "per"}, {"end": 482.48, "start": 482.24, "text": "second"}, {"end": 483.16, "start": 482.48, "text": "networks"}, {"end": 483.48, "start": 483.16, "text": "are"}, {"end": 484.04, "start": 483.48, "text": "becoming"}, {"end": 484.92, "start": 484.04, "text": "commonplace."}, {"end": 485.4, "start": 484.92, "text": "And"}, {"end": 485.76, "start": 485.4, "text": "we"}, {"end": 486.16, "start": 485.76, "text": "saw"}, {"end": 486.76, "start": 486.16, "text": "infrastructure"}, {"end": 487.12, "start": 486.76, "text": "scaling"}, {"end": 487.32, "start": 487.12, "text": "out"}, {"end": 487.84, "start": 487.32, "text": "across"}, {"end": 488.16, "start": 487.84, "text": "lands."}, {"end": 488.56, "start": 488.16, "text": "So"}, {"end": 488.96, "start": 488.56, "text": "let's"}, {"end": 489.32, "start": 488.96, "text": "say"}, {"end": 489.56, "start": 489.32, "text": "data"}, {"end": 490.0, "start": 489.56, "text": "center"}, {"end": 490.72, "start": 490.0, "text": "scale"}, {"end": 491.44, "start": 490.72, "text": "services"}, {"end": 491.56, "start": 491.44, "text": "for"}, {"end": 492.28, "start": 491.56, "text": "storage,"}, {"end": 492.56, "start": 492.28, "text": "for"}, {"end": 492.84, "start": 492.56, "text": "data"}, {"end": 493.4, "start": 492.84, "text": "analytics,"}, {"end": 493.6, "start": 493.4, "text": "and"}, {"end": 493.68, "start": 493.6, "text": "many"}, {"end": 493.88, "start": 493.68, "text": "more."}, {"end": 493.88, "start": 493.88, "text": "I'll"}, {"end": 494.6, "start": 493.88, "text": "argue"}, {"end": 495.16, "start": 494.6, "text": "that"}, {"end": 495.32, "start": 495.16, "text": "we"}, {"end": 495.72, "start": 495.32, "text": "are"}, {"end": 496.16, "start": 495.72, "text": "today"}, {"end": 496.68, "start": 496.16, "text": "at"}, {"end": 497.16, "start": 496.68, "text": "about"}, {"end": 497.4, "start": 497.16, "text": "the"}, {"end": 497.8, "start": 497.4, "text": "tail"}, {"end": 498.16, "start": 497.8, "text": "end"}, {"end": 498.48, "start": 498.16, "text": "of"}, {"end": 498.68, "start": 498.48, "text": "epoch"}, {"end": 499.16, "start": 498.68, "text": "four"}, {"end": 499.32, "start": 499.16, "text": "and"}, {"end": 499.92, "start": 499.32, "text": "entering"}, {"end": 500.24, "start": 499.92, "text": "epoch"}, {"end": 501.0, "start": 500.24, "text": "five,"}, {"end": 501.52, "start": 501.0, "text": "where"}, {"end": 501.68, "start": 501.52, "text": "we're"}, {"end": 502.08, "start": 501.68, "text": "seeing"}, {"end": 502.88, "start": 502.08, "text": "actually"}, {"end": 503.64, "start": 502.88, "text": "perfect"}, {"end": 504.16, "start": 503.64, "text": "TCO"}, {"end": 504.6, "start": 504.16, "text": "for"}, {"end": 505.16, "start": 504.6, "text": "individual"}, {"end": 506.84, "start": 505.16, "text": "processors"}, {"end": 507.08, "start": 506.84, "text": "actually"}, {"end": 507.6, "start": 507.08, "text": "plateauing."}, {"end": 508.08, "start": 507.6, "text": "We're"}, {"end": 508.2, "start": 508.08, "text": "seeing"}, {"end": 508.28, "start": 508.2, "text": "the"}, {"end": 508.8, "start": 508.28, "text": "rise"}, {"end": 509.12, "start": 508.8, "text": "of"}, {"end": 509.32, "start": 509.12, "text": "machine"}, {"end": 509.96, "start": 509.32, "text": "learning."}], "text": " So services, social networking, 10 gigit per second networks are becoming commonplace. And we saw infrastructure scaling out across lands. So let's say data center scale services for storage, for data analytics, and many more. I'll argue that we are today at about the tail end of epoch four and entering epoch five, where we're seeing actually perfect TCO for individual processors actually plateauing. We're seeing the rise of machine learning."}, {"chunks": [{"end": 510.32, "start": 510.0, "text": "and"}, {"end": 510.44, "start": 510.32, "text": "the"}, {"end": 510.8, "start": 510.44, "text": "rise"}, {"end": 510.88, "start": 510.8, "text": "of"}, {"end": 511.52, "start": 510.88, "text": "data-centric"}, {"end": 511.68, "start": 511.52, "text": "computing."}, {"end": 512.16, "start": 511.68, "text": "We're"}, {"end": 512.32, "start": 512.16, "text": "seeing"}, {"end": 512.84, "start": 512.32, "text": "interaction"}, {"end": 513.32, "start": 512.84, "text": "time"}, {"end": 513.8, "start": 513.32, "text": "among"}, {"end": 514.4, "start": 513.8, "text": "servers,"}, {"end": 514.68, "start": 514.4, "text": "let's"}, {"end": 515.36, "start": 514.68, "text": "say,"}, {"end": 515.68, "start": 515.36, "text": "and"}, {"end": 515.88, "start": 515.68, "text": "among"}, {"end": 515.92, "start": 515.88, "text": "the,"}, {"end": 516.04, "start": 515.92, "text": "for"}, {"end": 516.32, "start": 516.04, "text": "the"}, {"end": 516.8, "start": 516.32, "text": "networks"}, {"end": 517.0, "start": 516.8, "text": "that"}, {"end": 517.2, "start": 517.0, "text": "support"}, {"end": 517.2, "start": 517.2, "text": "them,"}, {"end": 517.24, "start": 517.2, "text": "dropping"}, {"end": 517.56, "start": 517.24, "text": "to"}, {"end": 517.8, "start": 517.56, "text": "about"}, {"end": 517.92, "start": 517.8, "text": "10"}, {"end": 519.2, "start": 517.92, "text": "microseconds."}, {"end": 520.08, "start": 519.2, "text": "200"}, {"end": 520.2, "start": 520.08, "text": "gigabit"}, {"end": 520.2, "start": 520.2, "text": "per"}, {"end": 520.36, "start": 520.2, "text": "second"}, {"end": 521.12, "start": 520.36, "text": "networks"}, {"end": 521.4, "start": 521.12, "text": "are"}, {"end": 522.12, "start": 521.4, "text": "starting"}, {"end": 522.44, "start": 522.12, "text": "to"}, {"end": 522.8, "start": 522.44, "text": "come"}, {"end": 522.8, "start": 522.8, "text": "out."}, {"end": 523.08, "start": 522.8, "text": "And"}, {"end": 523.4, "start": 523.08, "text": "I"}, {"end": 523.48, "start": 523.4, "text": "believe"}, {"end": 523.68, "start": 523.48, "text": "in"}, {"end": 524.08, "start": 523.68, "text": "epoch"}, {"end": 524.76, "start": 524.08, "text": "five,"}, {"end": 524.96, "start": 524.76, "text": "we"}, {"end": 524.96, "start": 524.96, "text": "will"}, {"end": 524.96, "start": 524.96, "text": "see"}, {"end": 525.08, "start": 524.96, "text": "terabit"}, {"end": 525.56, "start": 525.08, "text": "per"}, {"end": 525.84, "start": 525.56, "text": "second"}, {"end": 526.56, "start": 525.84, "text": "networks."}, {"end": 527.6, "start": 526.56, "text": "Specialized"}, {"end": 528.48, "start": 527.6, "text": "accelerators"}, {"end": 528.64, "start": 528.48, "text": "are"}, {"end": 528.88, "start": 528.64, "text": "becoming"}, {"end": 529.16, "start": 528.88, "text": "more"}, {"end": 529.48, "start": 529.16, "text": "and"}, {"end": 529.48, "start": 529.48, "text": "more"}, {"end": 529.92, "start": 529.48, "text": "commonplace,"}, {"end": 530.56, "start": 529.92, "text": "starting"}, {"end": 530.56, "start": 530.56, "text": "with"}, {"end": 531.48, "start": 530.56, "text": "TPUs,"}, {"end": 532.0, "start": 531.48, "text": "GPUs,"}, {"end": 532.28, "start": 532.0, "text": "and"}, {"end": 532.76, "start": 532.28, "text": "smart"}, {"end": 532.92, "start": 532.76, "text": "NICs."}, {"end": 532.96, "start": 532.92, "text": "But"}, {"end": 533.32, "start": 532.96, "text": "I"}, {"end": 533.64, "start": 533.32, "text": "think"}, {"end": 533.96, "start": 533.64, "text": "that"}, {"end": 534.12, "start": 533.96, "text": "we're"}, {"end": 534.4, "start": 534.12, "text": "going"}, {"end": 534.4, "start": 534.4, "text": "to"}, {"end": 534.48, "start": 534.4, "text": "see"}, {"end": 534.64, "start": 534.48, "text": "an"}, {"end": 534.96, "start": 534.64, "text": "increasing"}, {"end": 535.12, "start": 534.96, "text": "number"}, {"end": 535.2, "start": 535.12, "text": "of"}, {"end": 535.76, "start": 535.2, "text": "these"}, {"end": 538.8, "start": 535.76, "text": "over"}, {"end": 539.96, "start": 538.8, "text": "time."}], "text": " and the rise of data-centric computing. We're seeing interaction time among servers, let's say, and among the, for the networks that support them, dropping to about 10 microseconds. 200 gigabit per second networks are starting to come out. And I believe in epoch five, we will see terabit per second networks. Specialized accelerators are becoming more and more commonplace, starting with TPUs, GPUs, and smart NICs. But I think that we're going to see an increasing number of these over time."}, {"chunks": [{"end": 540.44, "start": 540.0, "text": "And"}, {"end": 541.04, "start": 540.44, "text": "to"}, {"end": 541.6, "start": 541.04, "text": "look"}, {"end": 542.2, "start": 541.6, "text": "at"}, {"end": 542.4, "start": 542.2, "text": "what"}, {"end": 542.84, "start": 542.4, "text": "happens"}, {"end": 543.2, "start": 542.84, "text": "at"}, {"end": 543.24, "start": 543.2, "text": "a"}, {"end": 543.6, "start": 543.24, "text": "higher"}, {"end": 543.8, "start": 543.6, "text": "level"}, {"end": 543.8, "start": 543.8, "text": "with"}, {"end": 543.8, "start": 543.8, "text": "respect"}, {"end": 543.8, "start": 543.8, "text": "to"}, {"end": 543.8, "start": 543.8, "text": "the"}, {"end": 543.8, "start": 543.8, "text": "type"}, {"end": 543.84, "start": 543.8, "text": "of"}, {"end": 544.44, "start": 543.84, "text": "connectivity"}, {"end": 544.64, "start": 544.44, "text": "that"}, {"end": 544.64, "start": 544.64, "text": "we're"}, {"end": 545.0, "start": 544.64, "text": "delivering"}, {"end": 545.0, "start": 545.0, "text": "in"}, {"end": 545.32, "start": 545.0, "text": "these"}, {"end": 545.72, "start": 545.32, "text": "various"}, {"end": 546.44, "start": 545.72, "text": "epochs."}, {"end": 546.8, "start": 546.44, "text": "Again,"}, {"end": 546.96, "start": 546.8, "text": "I'll"}, {"end": 547.28, "start": 546.96, "text": "provide"}, {"end": 547.28, "start": 547.28, "text": "the"}, {"end": 548.12, "start": 547.28, "text": "taxonomy"}, {"end": 548.6, "start": 548.12, "text": "as"}, {"end": 549.2, "start": 548.6, "text": "follows."}, {"end": 549.2, "start": 549.2, "text": "In"}, {"end": 549.2, "start": 549.2, "text": "epoch"}, {"end": 549.2, "start": 549.2, "text": "one,"}, {"end": 549.24, "start": 549.2, "text": "we"}, {"end": 549.68, "start": 549.24, "text": "were"}, {"end": 550.2, "start": 549.68, "text": "interested"}, {"end": 550.48, "start": 550.2, "text": "in"}, {"end": 551.36, "start": 550.48, "text": "connecting"}, {"end": 551.64, "start": 551.36, "text": "people"}, {"end": 551.88, "start": 551.64, "text": "to"}, {"end": 552.84, "start": 551.88, "text": "computers."}, {"end": 552.92, "start": 552.84, "text": "In"}, {"end": 553.24, "start": 552.92, "text": "epoch"}, {"end": 553.64, "start": 553.24, "text": "two,"}, {"end": 553.72, "start": 553.64, "text": "we"}, {"end": 553.8, "start": 553.72, "text": "got"}, {"end": 554.52, "start": 553.8, "text": "into"}, {"end": 554.72, "start": 554.52, "text": "the"}, {"end": 555.28, "start": 554.72, "text": "business"}, {"end": 555.48, "start": 555.28, "text": "of"}, {"end": 555.88, "start": 555.48, "text": "connecting"}, {"end": 555.88, "start": 555.88, "text": "computers"}, {"end": 555.88, "start": 555.88, "text": "to"}, {"end": 556.52, "start": 555.88, "text": "computers"}, {"end": 556.64, "start": 556.52, "text": "with"}, {"end": 557.28, "start": 556.64, "text": "local"}, {"end": 557.48, "start": 557.28, "text": "area"}, {"end": 558.08, "start": 557.48, "text": "networks"}, {"end": 558.2, "start": 558.08, "text": "and"}, {"end": 558.2, "start": 558.2, "text": "remote"}, {"end": 558.6, "start": 558.2, "text": "procedure"}, {"end": 558.8, "start": 558.6, "text": "call."}, {"end": 559.6, "start": 558.8, "text": "Epoch"}, {"end": 559.64, "start": 559.6, "text": "three,"}, {"end": 559.64, "start": 559.64, "text": "the"}, {"end": 561.2, "start": 559.64, "text": "connectivity"}, {"end": 561.36, "start": 561.2, "text": "at"}, {"end": 561.76, "start": 561.36, "text": "the"}, {"end": 562.56, "start": 561.76, "text": "network"}, {"end": 563.64, "start": 562.56, "text": "level"}, {"end": 564.04, "start": 563.64, "text": "shifted"}, {"end": 564.28, "start": 564.04, "text": "to"}, {"end": 564.64, "start": 564.28, "text": "connecting"}, {"end": 565.48, "start": 564.64, "text": "services"}, {"end": 565.48, "start": 565.48, "text": "to"}, {"end": 565.56, "start": 565.48, "text": "one"}, {"end": 566.32, "start": 565.56, "text": "another."}, {"end": 566.64, "start": 566.32, "text": "And"}, {"end": 567.4, "start": 566.64, "text": "increasingly,"}, {"end": 568.36, "start": 567.4, "text": "people"}, {"end": 568.36, "start": 568.36, "text": "in"}, {"end": 568.72, "start": 568.36, "text": "near"}, {"end": 568.92, "start": 568.72, "text": "real"}, {"end": 569.96, "start": 568.92, "text": "time"}], "text": " And to look at what happens at a higher level with respect to the type of connectivity that we're delivering in these various epochs. Again, I'll provide the taxonomy as follows. In epoch one, we were interested in connecting people to computers. In epoch two, we got into the business of connecting computers to computers with local area networks and remote procedure call. Epoch three, the connectivity at the network level shifted to connecting services to one another. And increasingly, people in near real time"}, {"chunks": [{"end": 570.08, "start": 570.0, "text": "to"}, {"end": 570.48, "start": 570.08, "text": "static"}, {"end": 571.36, "start": 570.48, "text": "data."}, {"end": 572.48, "start": 571.36, "text": "Epoch"}, {"end": 573.04, "start": 572.48, "text": "IV,"}, {"end": 573.12, "start": 573.04, "text": "the"}, {"end": 573.8, "start": 573.12, "text": "networks"}, {"end": 573.8, "start": 573.8, "text": "played"}, {"end": 573.92, "start": 573.8, "text": "a"}, {"end": 574.4, "start": 573.92, "text": "role"}, {"end": 574.88, "start": 574.4, "text": "in"}, {"end": 575.32, "start": 574.88, "text": "increasing"}, {"end": 575.92, "start": 575.32, "text": "fraction"}, {"end": 576.08, "start": 575.92, "text": "of"}, {"end": 576.84, "start": 576.08, "text": "people-to-people"}, {"end": 577.8, "start": 576.84, "text": "communication,"}, {"end": 578.2, "start": 577.8, "text": "whether"}, {"end": 578.32, "start": 578.2, "text": "through"}, {"end": 578.64, "start": 578.32, "text": "social"}, {"end": 579.28, "start": 578.64, "text": "networks,"}, {"end": 579.28, "start": 579.28, "text": "through"}, {"end": 579.32, "start": 579.28, "text": "your"}, {"end": 579.72, "start": 579.32, "text": "cell"}, {"end": 580.0, "start": 579.72, "text": "phone"}, {"end": 580.24, "start": 580.0, "text": "or"}, {"end": 581.04, "start": 580.24, "text": "otherwise,"}, {"end": 581.2, "start": 581.04, "text": "but"}, {"end": 581.92, "start": 581.2, "text": "also"}, {"end": 581.92, "start": 581.92, "text": "people"}, {"end": 582.16, "start": 581.92, "text": "to"}, {"end": 582.84, "start": 582.16, "text": "interactive"}, {"end": 583.64, "start": 582.84, "text": "results."}, {"end": 583.8, "start": 583.64, "text": "There"}, {"end": 584.32, "start": 583.8, "text": "was"}, {"end": 585.0, "start": 584.32, "text": "not"}, {"end": 585.36, "start": 585.0, "text": "a"}, {"end": 585.84, "start": 585.36, "text": "static"}, {"end": 586.08, "start": 585.84, "text": "serving"}, {"end": 586.08, "start": 586.08, "text": "of"}, {"end": 586.24, "start": 586.08, "text": "content,"}, {"end": 586.36, "start": 586.24, "text": "but"}, {"end": 587.08, "start": 586.36, "text": "substantial"}, {"end": 588.04, "start": 587.08, "text": "complex"}, {"end": 588.84, "start": 588.04, "text": "code"}, {"end": 589.6, "start": 588.84, "text": "could"}, {"end": 590.16, "start": 589.6, "text": "run"}, {"end": 590.52, "start": 590.16, "text": "and"}, {"end": 590.88, "start": 590.52, "text": "return"}, {"end": 591.12, "start": 590.88, "text": "very"}, {"end": 591.52, "start": 591.12, "text": "interesting"}, {"end": 591.72, "start": 591.52, "text": "rich"}, {"end": 592.2, "start": 591.72, "text": "results"}, {"end": 592.32, "start": 592.2, "text": "to"}, {"end": 592.48, "start": 592.32, "text": "people."}, {"end": 592.48, "start": 592.48, "text": "In"}, {"end": 592.52, "start": 592.48, "text": "Epoch"}, {"end": 592.52, "start": 592.52, "text": "V,"}, {"end": 593.0, "start": 592.52, "text": "I"}, {"end": 593.8, "start": 593.0, "text": "think"}, {"end": 594.24, "start": 593.8, "text": "we're"}, {"end": 595.16, "start": 594.24, "text": "going"}, {"end": 595.16, "start": 595.16, "text": "to"}, {"end": 595.2, "start": 595.16, "text": "be"}, {"end": 595.92, "start": 595.2, "text": "increasingly"}, {"end": 596.36, "start": 595.92, "text": "connecting"}, {"end": 596.8, "start": 596.36, "text": "people"}, {"end": 596.84, "start": 596.8, "text": "to"}, {"end": 597.64, "start": 596.84, "text": "insights"}, {"end": 597.72, "start": 597.64, "text": "with"}, {"end": 597.76, "start": 597.72, "text": "the"}, {"end": 598.12, "start": 597.76, "text": "rise"}, {"end": 598.12, "start": 598.12, "text": "of"}, {"end": 598.32, "start": 598.12, "text": "machine"}, {"end": 598.4, "start": 598.32, "text": "learning"}, {"end": 598.84, "start": 598.4, "text": "and"}, {"end": 599.36, "start": 598.84, "text": "data-centric"}, {"end": 599.96, "start": 599.36, "text": "computing."}], "text": " to static data. Epoch IV, the networks played a role in increasing fraction of people-to-people communication, whether through social networks, through your cell phone or otherwise, but also people to interactive results. There was not a static serving of content, but substantial complex code could run and return very interesting rich results to people. In Epoch V, I think we're going to be increasingly connecting people to insights with the rise of machine learning and data-centric computing."}, {"chunks": [{"end": 601.64, "start": 600.0, "text": "Integrating"}, {"end": 601.84, "start": 601.64, "text": "across"}, {"end": 602.44, "start": 601.84, "text": "these"}, {"end": 603.32, "start": 602.44, "text": "five"}, {"end": 604.04, "start": 603.32, "text": "epochs,"}, {"end": 604.12, "start": 604.04, "text": "I"}, {"end": 604.4, "start": 604.12, "text": "think"}, {"end": 605.12, "start": 604.4, "text": "it's"}, {"end": 605.56, "start": 605.12, "text": "also"}, {"end": 605.6, "start": 605.56, "text": "interesting"}, {"end": 605.68, "start": 605.6, "text": "to"}, {"end": 605.92, "start": 605.68, "text": "note"}, {"end": 606.32, "start": 605.92, "text": "that"}, {"end": 606.56, "start": 606.32, "text": "shifting"}, {"end": 606.88, "start": 606.56, "text": "from"}, {"end": 606.96, "start": 606.88, "text": "one"}, {"end": 607.4, "start": 606.96, "text": "epoch"}, {"end": 607.92, "start": 607.4, "text": "to"}, {"end": 608.76, "start": 607.92, "text": "another,"}, {"end": 609.4, "start": 608.76, "text": "we"}, {"end": 609.84, "start": 609.4, "text": "see"}, {"end": 610.08, "start": 609.84, "text": "a"}, {"end": 610.52, "start": 610.08, "text": "10x"}, {"end": 610.92, "start": 610.52, "text": "increase"}, {"end": 610.96, "start": 610.92, "text": "in"}, {"end": 611.92, "start": 610.96, "text": "bandwidth"}, {"end": 612.2, "start": 611.92, "text": "and"}, {"end": 612.72, "start": 612.2, "text": "a"}, {"end": 613.8, "start": 612.72, "text": "one-tenth"}, {"end": 614.36, "start": 613.8, "text": "reduction"}, {"end": 614.56, "start": 614.36, "text": "in"}, {"end": 615.2, "start": 614.56, "text": "latency"}, {"end": 615.48, "start": 615.2, "text": "or"}, {"end": 616.12, "start": 615.48, "text": "interaction"}, {"end": 616.2, "start": 616.12, "text": "rate"}, {"end": 616.4, "start": 616.2, "text": "among"}, {"end": 616.52, "start": 616.4, "text": "the"}, {"end": 617.64, "start": 616.52, "text": "computers."}, {"end": 617.76, "start": 617.64, "text": "And"}, {"end": 618.24, "start": 617.76, "text": "perhaps"}, {"end": 618.32, "start": 618.24, "text": "it"}, {"end": 618.52, "start": 618.32, "text": "is"}, {"end": 618.96, "start": 618.52, "text": "this"}, {"end": 619.28, "start": 618.96, "text": "relatively"}, {"end": 620.24, "start": 619.28, "text": "substantial"}, {"end": 620.84, "start": 620.24, "text": "shift"}, {"end": 621.4, "start": 620.84, "text": "over"}, {"end": 621.64, "start": 621.4, "text": "a"}, {"end": 621.92, "start": 621.64, "text": "10"}, {"end": 621.96, "start": 621.92, "text": "or"}, {"end": 622.32, "start": 621.96, "text": "15-year"}, {"end": 622.6, "start": 622.32, "text": "period"}, {"end": 623.32, "start": 622.6, "text": "that"}, {"end": 623.88, "start": 623.32, "text": "allows"}, {"end": 625.28, "start": 623.88, "text": "the"}, {"end": 625.6, "start": 625.28, "text": "rise"}, {"end": 626.28, "start": 625.6, "text": "of"}, {"end": 626.72, "start": 626.28, "text": "the"}, {"end": 627.08, "start": 626.72, "text": "next"}, {"end": 627.4, "start": 627.08, "text": "epoch."}, {"end": 627.48, "start": 627.4, "text": "What"}, {"end": 627.48, "start": 627.48, "text": "we"}, {"end": 627.48, "start": 627.48, "text": "see"}, {"end": 627.48, "start": 627.48, "text": "is"}, {"end": 627.48, "start": 627.48, "text": "that"}, {"end": 627.56, "start": 627.48, "text": "these"}, {"end": 628.04, "start": 627.56, "text": "epochs"}, {"end": 628.16, "start": 628.04, "text": "are"}, {"end": 628.72, "start": 628.16, "text": "marked"}, {"end": 629.16, "start": 628.72, "text": "by"}, {"end": 629.96, "start": 629.16, "text": "shifting"}], "text": " Integrating across these five epochs, I think it's also interesting to note that shifting from one epoch to another, we see a 10x increase in bandwidth and a one-tenth reduction in latency or interaction rate among the computers. And perhaps it is this relatively substantial shift over a 10 or 15-year period that allows the rise of the next epoch. What we see is that these epochs are marked by shifting"}, {"chunks": [{"end": 630.2, "start": 630.0, "text": "making"}, {"end": 631.16, "start": 630.2, "text": "the"}, {"end": 631.92, "start": 631.16, "text": "imaginable"}, {"end": 632.4, "start": 631.92, "text": "at"}, {"end": 632.68, "start": 632.4, "text": "the"}, {"end": 633.04, "start": 632.68, "text": "beginning"}, {"end": 633.12, "start": 633.04, "text": "of"}, {"end": 633.48, "start": 633.12, "text": "an"}, {"end": 633.64, "start": 633.48, "text": "epoch"}, {"end": 634.72, "start": 633.64, "text": "routine,"}, {"end": 635.28, "start": 634.72, "text": "but"}, {"end": 635.76, "start": 635.28, "text": "then"}, {"end": 636.24, "start": 635.76, "text": "finally,"}, {"end": 636.32, "start": 636.24, "text": "and"}, {"end": 636.56, "start": 636.32, "text": "maybe"}, {"end": 636.8, "start": 636.56, "text": "as"}, {"end": 637.24, "start": 636.8, "text": "importantly,"}, {"end": 637.68, "start": 637.24, "text": "making"}, {"end": 637.68, "start": 637.68, "text": "the"}, {"end": 638.16, "start": 637.68, "text": "impossible"}, {"end": 639.32, "start": 638.16, "text": "imaginable."}, {"end": 639.84, "start": 639.32, "text": "I've"}, {"end": 640.28, "start": 639.84, "text": "heard"}, {"end": 640.88, "start": 640.28, "text": "a"}, {"end": 641.32, "start": 640.88, "text": "story"}, {"end": 641.56, "start": 641.32, "text": "that"}, {"end": 642.04, "start": 641.56, "text": "JCR"}, {"end": 642.8, "start": 642.04, "text": "Licklider"}, {"end": 643.48, "start": 642.8, "text": "obsessed"}, {"end": 643.68, "start": 643.48, "text": "in"}, {"end": 644.0, "start": 643.68, "text": "Epoch"}, {"end": 644.2, "start": 644.0, "text": "One,"}, {"end": 644.52, "start": 644.2, "text": "around"}, {"end": 644.84, "start": 644.52, "text": "Epoch"}, {"end": 645.48, "start": 644.84, "text": "One,"}, {"end": 645.8, "start": 645.48, "text": "about"}, {"end": 645.92, "start": 645.8, "text": "being"}, {"end": 646.16, "start": 645.92, "text": "able"}, {"end": 646.24, "start": 646.16, "text": "to"}, {"end": 646.48, "start": 646.24, "text": "echo"}, {"end": 647.28, "start": 646.48, "text": "keystrokes"}, {"end": 647.28, "start": 647.28, "text": "at"}, {"end": 647.32, "start": 647.28, "text": "the"}, {"end": 647.68, "start": 647.32, "text": "rate"}, {"end": 647.88, "start": 647.68, "text": "of"}, {"end": 648.4, "start": 647.88, "text": "100"}, {"end": 648.84, "start": 648.4, "text": "millisecond"}, {"end": 649.28, "start": 648.84, "text": "interaction"}, {"end": 649.84, "start": 649.28, "text": "times"}, {"end": 650.04, "start": 649.84, "text": "to"}, {"end": 650.2, "start": 650.04, "text": "remote"}, {"end": 650.76, "start": 650.2, "text": "computers"}, {"end": 650.76, "start": 650.76, "text": "to"}, {"end": 651.52, "start": 650.76, "text": "maintain"}, {"end": 652.12, "start": 651.52, "text": "interactivity."}, {"end": 652.2, "start": 652.12, "text": "It"}, {"end": 653.08, "start": 652.2, "text": "seemed"}, {"end": 653.48, "start": 653.08, "text": "somewhere"}, {"end": 653.92, "start": 653.48, "text": "between"}, {"end": 654.12, "start": 653.92, "text": "hard"}, {"end": 654.44, "start": 654.12, "text": "and"}, {"end": 654.84, "start": 654.44, "text": "impossible,"}, {"end": 654.88, "start": 654.84, "text": "and"}, {"end": 654.88, "start": 654.88, "text": "yet"}, {"end": 654.88, "start": 654.88, "text": "we"}, {"end": 655.68, "start": 654.88, "text": "made"}, {"end": 655.88, "start": 655.68, "text": "it"}, {"end": 656.2, "start": 655.88, "text": "happen."}, {"end": 657.08, "start": 656.2, "text": "If"}, {"end": 657.12, "start": 657.08, "text": "you"}, {"end": 657.76, "start": 657.12, "text": "consider"}, {"end": 658.04, "start": 657.76, "text": "where"}, {"end": 658.2, "start": 658.04, "text": "we"}, {"end": 658.52, "start": 658.2, "text": "were"}, {"end": 658.64, "start": 658.52, "text": "at"}, {"end": 659.0, "start": 658.64, "text": "the"}, {"end": 659.2, "start": 659.0, "text": "end"}, {"end": 659.24, "start": 659.2, "text": "of"}, {"end": 659.24, "start": 659.24, "text": "Epoch"}, {"end": 659.44, "start": 659.24, "text": "Three,"}, {"end": 659.48, "start": 659.44, "text": "at"}, {"end": 659.6, "start": 659.48, "text": "the"}, {"end": 659.76, "start": 659.6, "text": "beginning"}, {"end": 659.96, "start": 659.76, "text": "of"}], "text": " making the imaginable at the beginning of an epoch routine, but then finally, and maybe as importantly, making the impossible imaginable. I've heard a story that JCR Licklider obsessed in Epoch One, around Epoch One, about being able to echo keystrokes at the rate of 100 millisecond interaction times to remote computers to maintain interactivity. It seemed somewhere between hard and impossible, and yet we made it happen. If you consider where we were at the end of Epoch Three, at the beginning of"}, {"chunks": [{"end": 660.28, "start": 660.0, "text": "Epoch"}, {"end": 660.76, "start": 660.28, "text": "4,"}, {"end": 661.12, "start": 660.76, "text": "the"}, {"end": 661.56, "start": 661.12, "text": "notion"}, {"end": 661.76, "start": 661.56, "text": "of"}, {"end": 662.04, "start": 661.76, "text": "being"}, {"end": 662.28, "start": 662.04, "text": "able"}, {"end": 662.48, "start": 662.28, "text": "to"}, {"end": 662.68, "start": 662.48, "text": "run"}, {"end": 663.32, "start": 662.68, "text": "services"}, {"end": 663.88, "start": 663.32, "text": "across"}, {"end": 664.28, "start": 663.88, "text": "hundreds,"}, {"end": 664.76, "start": 664.28, "text": "thousands,"}, {"end": 665.12, "start": 664.76, "text": "tens"}, {"end": 665.56, "start": 665.12, "text": "of"}, {"end": 665.8, "start": 665.56, "text": "thousands"}, {"end": 665.84, "start": 665.8, "text": "of"}, {"end": 666.04, "start": 665.84, "text": "individual"}, {"end": 666.64, "start": 666.04, "text": "servers"}, {"end": 666.76, "start": 666.64, "text": "tightly"}, {"end": 666.96, "start": 666.76, "text": "connected"}, {"end": 667.4, "start": 666.96, "text": "across"}, {"end": 667.8, "start": 667.4, "text": "a"}, {"end": 668.44, "start": 667.8, "text": "local"}, {"end": 668.64, "start": 668.44, "text": "area"}, {"end": 668.96, "start": 668.64, "text": "network"}, {"end": 669.12, "start": 668.96, "text": "and"}, {"end": 669.36, "start": 669.12, "text": "having"}, {"end": 669.56, "start": 669.36, "text": "them"}, {"end": 669.92, "start": 669.56, "text": "scale"}, {"end": 670.68, "start": 669.92, "text": "out"}, {"end": 671.68, "start": 670.68, "text": "was"}, {"end": 672.68, "start": 671.68, "text": "imaginable,"}, {"end": 672.88, "start": 672.68, "text": "but"}, {"end": 673.72, "start": 672.88, "text": "perhaps"}, {"end": 674.04, "start": 673.72, "text": "very,"}, {"end": 674.4, "start": 674.04, "text": "very"}, {"end": 674.56, "start": 674.4, "text": "hard."}, {"end": 675.12, "start": 674.56, "text": "Today,"}, {"end": 675.6, "start": 675.12, "text": "15,"}, {"end": 676.2, "start": 675.6, "text": "perhaps"}, {"end": 676.2, "start": 676.2, "text": "20"}, {"end": 676.56, "start": 676.2, "text": "years"}, {"end": 677.04, "start": 676.56, "text": "later,"}, {"end": 677.44, "start": 677.04, "text": "it's"}, {"end": 677.6, "start": 677.44, "text": "not"}, {"end": 678.32, "start": 677.6, "text": "routine."}, {"end": 678.92, "start": 678.32, "text": "So"}, {"end": 679.32, "start": 678.92, "text": "now"}, {"end": 679.4, "start": 679.32, "text": "that"}, {"end": 679.56, "start": 679.4, "text": "we've"}, {"end": 679.72, "start": 679.56, "text": "made"}, {"end": 680.12, "start": 679.72, "text": "the"}, {"end": 680.36, "start": 680.12, "text": "very,"}, {"end": 680.56, "start": 680.36, "text": "very"}, {"end": 681.16, "start": 680.56, "text": "difficult"}, {"end": 681.8, "start": 681.16, "text": "routine,"}, {"end": 682.12, "start": 681.8, "text": "what's"}, {"end": 682.16, "start": 682.12, "text": "the"}, {"end": 682.68, "start": 682.16, "text": "next"}, {"end": 683.08, "start": 682.68, "text": "rate"}, {"end": 683.2, "start": 683.08, "text": "of"}, {"end": 683.76, "start": 683.2, "text": "innovation,"}, {"end": 684.28, "start": 683.76, "text": "the"}, {"end": 684.6, "start": 684.28, "text": "next"}, {"end": 684.8, "start": 684.6, "text": "tide"}, {"end": 685.0, "start": 684.8, "text": "of"}, {"end": 685.04, "start": 685.0, "text": "innovation"}, {"end": 685.36, "start": 685.04, "text": "that"}, {"end": 685.36, "start": 685.36, "text": "we"}, {"end": 685.36, "start": 685.36, "text": "will"}, {"end": 685.36, "start": 685.36, "text": "take"}, {"end": 685.44, "start": 685.36, "text": "on"}, {"end": 685.48, "start": 685.44, "text": "in"}, {"end": 685.6, "start": 685.48, "text": "Epoch"}, {"end": 685.8, "start": 685.6, "text": "5?"}, {"end": 685.8, "start": 685.8, "text": "OK,"}, {"end": 685.8, "start": 685.8, "text": "so"}, {"end": 685.96, "start": 685.8, "text": "now"}, {"end": 688.48, "start": 685.96, "text": "let"}, {"end": 689.12, "start": 688.48, "text": "me"}, {"end": 689.36, "start": 689.12, "text": "shift"}, {"end": 689.96, "start": 689.36, "text": "to"}], "text": " Epoch 4, the notion of being able to run services across hundreds, thousands, tens of thousands of individual servers tightly connected across a local area network and having them scale out was imaginable, but perhaps very, very hard. Today, 15, perhaps 20 years later, it's not routine. So now that we've made the very, very difficult routine, what's the next rate of innovation, the next tide of innovation that we will take on in Epoch 5? OK, so now let me shift to"}, {"chunks": [{"end": 691.44, "start": 690.0, "text": "some"}, {"end": 692.52, "start": 691.44, "text": "modern"}, {"end": 692.84, "start": 692.52, "text": "day"}, {"end": 693.56, "start": 692.84, "text": "implications"}, {"end": 693.76, "start": 693.56, "text": "of"}, {"end": 694.0, "start": 693.76, "text": "the"}, {"end": 694.4, "start": 694.0, "text": "shifts"}, {"end": 694.44, "start": 694.4, "text": "in"}, {"end": 694.72, "start": 694.44, "text": "these"}, {"end": 695.28, "start": 694.72, "text": "epochs."}, {"end": 695.8, "start": 695.28, "text": "And"}, {"end": 696.24, "start": 695.8, "text": "I'll"}, {"end": 696.28, "start": 696.24, "text": "argue"}, {"end": 696.6, "start": 696.28, "text": "that"}, {"end": 696.88, "start": 696.6, "text": "this"}, {"end": 697.2, "start": 696.88, "text": "march"}, {"end": 697.64, "start": 697.2, "text": "forward"}, {"end": 698.16, "start": 697.64, "text": "has"}, {"end": 698.2, "start": 698.16, "text": "been"}, {"end": 698.56, "start": 698.2, "text": "done"}, {"end": 698.68, "start": 698.56, "text": "in"}, {"end": 698.88, "start": 698.68, "text": "the"}, {"end": 699.24, "start": 698.88, "text": "context"}, {"end": 699.24, "start": 699.24, "text": "of"}, {"end": 699.68, "start": 699.24, "text": "building"}, {"end": 700.28, "start": 699.68, "text": "balanced"}, {"end": 700.4, "start": 700.28, "text": "distributed"}, {"end": 701.0, "start": 700.4, "text": "systems"}, {"end": 701.0, "start": 701.0, "text": "with"}, {"end": 701.08, "start": 701.0, "text": "a"}, {"end": 701.52, "start": 701.08, "text": "network"}, {"end": 701.88, "start": 701.52, "text": "as"}, {"end": 702.48, "start": 701.88, "text": "always"}, {"end": 702.76, "start": 702.48, "text": "playing"}, {"end": 702.8, "start": 702.76, "text": "a"}, {"end": 703.12, "start": 702.8, "text": "critical"}, {"end": 704.24, "start": 703.12, "text": "role."}, {"end": 704.68, "start": 704.24, "text": "So"}, {"end": 705.0, "start": 704.68, "text": "as"}, {"end": 705.32, "start": 705.0, "text": "I've"}, {"end": 705.32, "start": 705.32, "text": "argued,"}, {"end": 705.4, "start": 705.32, "text": "the"}, {"end": 705.84, "start": 705.4, "text": "network"}, {"end": 706.04, "start": 705.84, "text": "is"}, {"end": 706.2, "start": 706.04, "text": "just"}, {"end": 706.56, "start": 706.2, "text": "one"}, {"end": 707.2, "start": 706.56, "text": "component"}, {"end": 707.2, "start": 707.2, "text": "in"}, {"end": 707.24, "start": 707.2, "text": "any"}, {"end": 707.64, "start": 707.24, "text": "distributed"}, {"end": 708.52, "start": 707.64, "text": "computation,"}, {"end": 708.76, "start": 708.52, "text": "with"}, {"end": 710.0, "start": 708.76, "text": "others,"}, {"end": 710.28, "start": 710.0, "text": "in"}, {"end": 710.88, "start": 710.28, "text": "particular,"}, {"end": 711.04, "start": 710.88, "text": "compute"}, {"end": 711.16, "start": 711.04, "text": "and"}, {"end": 711.72, "start": 711.16, "text": "storage"}, {"end": 712.12, "start": 711.72, "text": "playing"}, {"end": 712.44, "start": 712.12, "text": "very,"}, {"end": 712.68, "start": 712.44, "text": "very"}, {"end": 712.76, "start": 712.68, "text": "important"}, {"end": 713.76, "start": 712.76, "text": "roles."}, {"end": 713.88, "start": 713.76, "text": "In"}, {"end": 714.24, "start": 713.88, "text": "running"}, {"end": 714.6, "start": 714.24, "text": "your"}, {"end": 715.04, "start": 714.6, "text": "distributed"}, {"end": 715.64, "start": 715.04, "text": "computation,"}, {"end": 715.96, "start": 715.64, "text": "you"}, {"end": 716.44, "start": 715.96, "text": "have"}, {"end": 716.44, "start": 716.44, "text": "to"}, {"end": 716.44, "start": 716.44, "text": "think"}, {"end": 716.92, "start": 716.44, "text": "carefully"}, {"end": 717.2, "start": 716.92, "text": "about"}, {"end": 717.32, "start": 717.2, "text": "system"}, {"end": 717.84, "start": 717.32, "text": "balance."}, {"end": 717.92, "start": 717.84, "text": "In"}, {"end": 718.04, "start": 717.92, "text": "other"}, {"end": 718.44, "start": 718.04, "text": "words,"}, {"end": 718.84, "start": 718.44, "text": "how"}, {"end": 719.4, "start": 718.84, "text": "much"}, {"end": 719.68, "start": 719.4, "text": "I.O."}, {"end": 719.84, "start": 719.68, "text": "are"}, {"end": 719.84, "start": 719.84, "text": "you"}, {"end": 719.84, "start": 719.84, "text": "going"}, {"end": 719.96, "start": 719.84, "text": "to"}], "text": " some modern day implications of the shifts in these epochs. And I'll argue that this march forward has been done in the context of building balanced distributed systems with a network as always playing a critical role. So as I've argued, the network is just one component in any distributed computation, with others, in particular, compute and storage playing very, very important roles. In running your distributed computation, you have to think carefully about system balance. In other words, how much I.O. are you going to"}, {"chunks": [{"end": 720.16, "start": 720.0, "text": "How"}, {"end": 720.4, "start": 720.16, "text": "much"}, {"end": 720.6, "start": 720.4, "text": "networking"}, {"end": 720.96, "start": 720.6, "text": "are"}, {"end": 721.4, "start": 720.96, "text": "you"}, {"end": 721.6, "start": 721.4, "text": "going"}, {"end": 721.84, "start": 721.6, "text": "to"}, {"end": 722.4, "start": 721.84, "text": "have?"}, {"end": 722.6, "start": 722.4, "text": "How"}, {"end": 722.96, "start": 722.6, "text": "much"}, {"end": 723.56, "start": 722.96, "text": "computer"}, {"end": 723.8, "start": 723.56, "text": "are"}, {"end": 723.84, "start": 723.8, "text": "you"}, {"end": 724.0, "start": 723.84, "text": "going"}, {"end": 724.16, "start": 724.0, "text": "to"}, {"end": 724.52, "start": 724.16, "text": "have"}, {"end": 724.6, "start": 724.52, "text": "for"}, {"end": 724.64, "start": 724.6, "text": "your"}, {"end": 725.48, "start": 724.64, "text": "computation?"}, {"end": 725.92, "start": 725.48, "text": "And"}, {"end": 726.04, "start": 725.92, "text": "building"}, {"end": 726.64, "start": 726.04, "text": "that"}, {"end": 727.12, "start": 726.64, "text": "balance"}, {"end": 727.36, "start": 727.12, "text": "is"}, {"end": 727.92, "start": 727.36, "text": "critical"}, {"end": 728.24, "start": 727.92, "text": "because"}, {"end": 728.44, "start": 728.24, "text": "if"}, {"end": 728.52, "start": 728.44, "text": "you"}, {"end": 728.84, "start": 728.52, "text": "build"}, {"end": 729.04, "start": 728.84, "text": "an"}, {"end": 729.44, "start": 729.04, "text": "unbalanced"}, {"end": 730.0, "start": 729.44, "text": "system,"}, {"end": 730.32, "start": 730.0, "text": "some"}, {"end": 730.72, "start": 730.32, "text": "resource"}, {"end": 731.2, "start": 730.72, "text": "that"}, {"end": 731.44, "start": 731.2, "text": "you"}, {"end": 731.6, "start": 731.44, "text": "happen"}, {"end": 731.68, "start": 731.6, "text": "to"}, {"end": 731.68, "start": 731.68, "text": "need"}, {"end": 731.68, "start": 731.68, "text": "at"}, {"end": 731.68, "start": 731.68, "text": "a"}, {"end": 731.88, "start": 731.68, "text": "particular"}, {"end": 732.12, "start": 731.88, "text": "point"}, {"end": 732.16, "start": 732.12, "text": "in"}, {"end": 732.4, "start": 732.16, "text": "time,"}, {"end": 732.92, "start": 732.4, "text": "compute,"}, {"end": 733.36, "start": 732.92, "text": "storage,"}, {"end": 733.64, "start": 733.36, "text": "and"}, {"end": 733.76, "start": 733.64, "text": "networking,"}, {"end": 734.04, "start": 733.76, "text": "is"}, {"end": 734.32, "start": 734.04, "text": "going"}, {"end": 734.4, "start": 734.32, "text": "to"}, {"end": 734.48, "start": 734.4, "text": "be"}, {"end": 735.12, "start": 734.48, "text": "scarce."}, {"end": 735.24, "start": 735.12, "text": "And"}, {"end": 735.72, "start": 735.24, "text": "that's"}, {"end": 736.12, "start": 735.72, "text": "going"}, {"end": 736.12, "start": 736.12, "text": "to"}, {"end": 736.12, "start": 736.12, "text": "limit"}, {"end": 736.28, "start": 736.12, "text": "the"}, {"end": 736.96, "start": 736.28, "text": "value"}, {"end": 737.16, "start": 736.96, "text": "of"}, {"end": 737.36, "start": 737.16, "text": "your"}, {"end": 738.4, "start": 737.36, "text": "computation."}, {"end": 738.48, "start": 738.4, "text": "On"}, {"end": 738.6, "start": 738.48, "text": "the"}, {"end": 738.68, "start": 738.6, "text": "other"}, {"end": 739.28, "start": 738.68, "text": "hand,"}, {"end": 739.36, "start": 739.28, "text": "if"}, {"end": 739.36, "start": 739.36, "text": "you"}, {"end": 739.76, "start": 739.36, "text": "build"}, {"end": 739.76, "start": 739.76, "text": "an"}, {"end": 740.16, "start": 739.76, "text": "unbalanced"}, {"end": 740.36, "start": 740.16, "text": "system,"}, {"end": 740.6, "start": 740.36, "text": "some"}, {"end": 740.84, "start": 740.6, "text": "other"}, {"end": 741.32, "start": 740.84, "text": "resource"}, {"end": 741.52, "start": 741.32, "text": "is"}, {"end": 741.88, "start": 741.52, "text": "going"}, {"end": 741.88, "start": 741.88, "text": "to"}, {"end": 742.12, "start": 741.88, "text": "sit"}, {"end": 742.52, "start": 742.12, "text": "idle,"}, {"end": 742.56, "start": 742.52, "text": "which"}, {"end": 742.56, "start": 742.56, "text": "is"}, {"end": 742.76, "start": 742.56, "text": "going"}, {"end": 742.76, "start": 742.76, "text": "to"}, {"end": 743.08, "start": 742.76, "text": "increase"}, {"end": 743.32, "start": 743.08, "text": "your"}, {"end": 743.64, "start": 743.32, "text": "cost."}, {"end": 743.64, "start": 743.64, "text": "I'll"}, {"end": 744.28, "start": 743.64, "text": "put"}, {"end": 744.48, "start": 744.28, "text": "this"}, {"end": 744.48, "start": 744.48, "text": "in"}, {"end": 745.96, "start": 744.48, "text": "the"}, {"end": 746.64, "start": 745.96, "text": "context"}, {"end": 746.88, "start": 746.64, "text": "of"}, {"end": 747.6, "start": 746.88, "text": "Amdahl's"}, {"end": 748.04, "start": 747.6, "text": "lesser"}, {"end": 748.4, "start": 748.04, "text": "known"}, {"end": 749.08, "start": 748.4, "text": "law,"}, {"end": 749.52, "start": 749.08, "text": "developed"}, {"end": 749.52, "start": 749.52, "text": "again"}, {"end": 749.52, "start": 749.52, "text": "in"}, {"end": 749.96, "start": 749.52, "text": "the"}], "text": " How much networking are you going to have? How much computer are you going to have for your computation? And building that balance is critical because if you build an unbalanced system, some resource that you happen to need at a particular point in time, compute, storage, and networking, is going to be scarce. And that's going to limit the value of your computation. On the other hand, if you build an unbalanced system, some other resource is going to sit idle, which is going to increase your cost. I'll put this in the context of Amdahl's lesser known law, developed again in the"}, {"chunks": [{"end": 751.12, "start": 750.0, "text": "1960s,"}, {"end": 751.68, "start": 751.12, "text": "perhaps"}, {"end": 752.08, "start": 751.68, "text": "by"}, {"end": 753.36, "start": 752.08, "text": "coincidence,"}, {"end": 753.76, "start": 753.36, "text": "where"}, {"end": 753.76, "start": 753.76, "text": "you"}, {"end": 753.88, "start": 753.76, "text": "need"}, {"end": 754.28, "start": 753.88, "text": "one"}, {"end": 754.44, "start": 754.28, "text": "megabit"}, {"end": 754.52, "start": 754.44, "text": "per"}, {"end": 754.84, "start": 754.52, "text": "second"}, {"end": 754.96, "start": 754.84, "text": "of"}, {"end": 755.68, "start": 754.96, "text": "I.O."}, {"end": 755.92, "start": 755.68, "text": "for"}, {"end": 756.24, "start": 755.92, "text": "every"}, {"end": 756.44, "start": 756.24, "text": "one"}, {"end": 757.08, "start": 756.44, "text": "megahertz"}, {"end": 757.08, "start": 757.08, "text": "of"}, {"end": 757.96, "start": 757.08, "text": "computation"}, {"end": 758.04, "start": 757.96, "text": "in"}, {"end": 758.64, "start": 758.04, "text": "parallel"}, {"end": 758.92, "start": 758.64, "text": "or"}, {"end": 759.2, "start": 758.92, "text": "distributed"}, {"end": 759.48, "start": 759.2, "text": "computing."}, {"end": 759.48, "start": 759.48, "text": "While"}, {"end": 759.48, "start": 759.48, "text": "this"}, {"end": 759.48, "start": 759.48, "text": "is"}, {"end": 759.52, "start": 759.48, "text": "a"}, {"end": 760.16, "start": 759.52, "text": "rule"}, {"end": 761.16, "start": 760.16, "text": "of"}, {"end": 761.44, "start": 761.16, "text": "thumb"}, {"end": 761.44, "start": 761.44, "text": "rather"}, {"end": 761.44, "start": 761.44, "text": "than"}, {"end": 761.6, "start": 761.44, "text": "a"}, {"end": 762.16, "start": 761.6, "text": "law"}, {"end": 762.36, "start": 762.16, "text": "of"}, {"end": 762.8, "start": 762.36, "text": "nature,"}, {"end": 763.04, "start": 762.8, "text": "it's"}, {"end": 763.28, "start": 763.04, "text": "actually"}, {"end": 763.6, "start": 763.28, "text": "held"}, {"end": 763.64, "start": 763.6, "text": "up"}, {"end": 764.16, "start": 763.64, "text": "remarkably"}, {"end": 764.4, "start": 764.16, "text": "well"}, {"end": 764.84, "start": 764.4, "text": "over"}, {"end": 764.96, "start": 764.84, "text": "a"}, {"end": 765.44, "start": 764.96, "text": "50-year"}, {"end": 767.28, "start": 765.44, "text": "duration."}, {"end": 767.52, "start": 767.28, "text": "Let"}, {"end": 767.6, "start": 767.52, "text": "me"}, {"end": 769.16, "start": 767.6, "text": "put"}, {"end": 769.68, "start": 769.16, "text": "this"}, {"end": 770.08, "start": 769.68, "text": "all"}, {"end": 770.64, "start": 770.08, "text": "into"}, {"end": 771.04, "start": 770.64, "text": "concrete"}, {"end": 772.04, "start": 771.04, "text": "context."}, {"end": 772.52, "start": 772.04, "text": "Do"}, {"end": 772.92, "start": 772.52, "text": "these"}, {"end": 773.24, "start": 772.92, "text": "balanced"}, {"end": 773.68, "start": 773.24, "text": "systems"}, {"end": 773.8, "start": 773.68, "text": "really"}, {"end": 774.48, "start": 773.8, "text": "matter?"}, {"end": 774.92, "start": 774.48, "text": "And"}, {"end": 774.96, "start": 774.92, "text": "in"}, {"end": 775.44, "start": 774.96, "text": "fact,"}, {"end": 775.68, "start": 775.44, "text": "they"}, {"end": 775.84, "start": 775.68, "text": "do"}, {"end": 776.0, "start": 775.84, "text": "in"}, {"end": 777.24, "start": 776.0, "text": "taking"}, {"end": 777.68, "start": 777.24, "text": "on"}, {"end": 778.04, "start": 777.68, "text": "some"}, {"end": 778.32, "start": 778.04, "text": "of"}, {"end": 778.68, "start": 778.32, "text": "the"}, {"end": 779.08, "start": 778.68, "text": "most"}, {"end": 779.68, "start": 779.08, "text": "challenging"}, {"end": 779.96, "start": 779.68, "text": "problems"}], "text": " 1960s, perhaps by coincidence, where you need one megabit per second of I.O. for every one megahertz of computation in parallel or distributed computing. While this is a rule of thumb rather than a law of nature, it's actually held up remarkably well over a 50-year duration. Let me put this all into concrete context. Do these balanced systems really matter? And in fact, they do in taking on some of the most challenging problems"}, {"chunks": [{"end": 780.2, "start": 780.0, "text": "that"}, {"end": 780.4, "start": 780.2, "text": "we"}, {"end": 780.96, "start": 780.4, "text": "face."}, {"end": 781.08, "start": 780.96, "text": "If"}, {"end": 781.28, "start": 781.08, "text": "you"}, {"end": 781.84, "start": 781.28, "text": "don't"}, {"end": 781.96, "start": 781.84, "text": "build"}, {"end": 782.52, "start": 781.96, "text": "balanced"}, {"end": 783.12, "start": 782.52, "text": "systems,"}, {"end": 783.56, "start": 783.12, "text": "you"}, {"end": 783.76, "start": 783.56, "text": "can"}, {"end": 784.32, "start": 783.76, "text": "dramatically"}, {"end": 784.4, "start": 784.32, "text": "limit"}, {"end": 784.64, "start": 784.4, "text": "the"}, {"end": 785.04, "start": 784.64, "text": "efficiency"}, {"end": 785.2, "start": 785.04, "text": "of"}, {"end": 785.64, "start": 785.2, "text": "your"}, {"end": 786.28, "start": 785.64, "text": "infrastructure."}, {"end": 786.32, "start": 786.28, "text": "We"}, {"end": 787.32, "start": 786.32, "text": "took"}, {"end": 788.0, "start": 787.32, "text": "on"}, {"end": 788.44, "start": 788.0, "text": "some"}, {"end": 788.96, "start": 788.44, "text": "work"}, {"end": 790.0, "start": 788.96, "text": "for"}, {"end": 790.96, "start": 790.0, "text": "actually"}, {"end": 791.12, "start": 790.96, "text": "a"}, {"end": 791.6, "start": 791.12, "text": "contest,"}, {"end": 791.92, "start": 791.6, "text": "an"}, {"end": 792.04, "start": 791.92, "text": "annual"}, {"end": 792.32, "start": 792.04, "text": "contest"}, {"end": 792.6, "start": 792.32, "text": "called"}, {"end": 793.2, "start": 792.6, "text": "GraySort."}, {"end": 793.44, "start": 793.2, "text": "At"}, {"end": 793.6, "start": 793.44, "text": "the"}, {"end": 794.04, "start": 793.6, "text": "time"}, {"end": 794.52, "start": 794.04, "text": "that"}, {"end": 794.68, "start": 794.52, "text": "we"}, {"end": 794.68, "start": 794.68, "text": "did"}, {"end": 795.0, "start": 794.68, "text": "this,"}, {"end": 795.16, "start": 795.0, "text": "about"}, {"end": 795.32, "start": 795.16, "text": "10"}, {"end": 795.6, "start": 795.32, "text": "years"}, {"end": 796.12, "start": 795.6, "text": "ago,"}, {"end": 796.52, "start": 796.12, "text": "the"}, {"end": 796.84, "start": 796.52, "text": "question"}, {"end": 797.24, "start": 796.84, "text": "was,"}, {"end": 797.48, "start": 797.24, "text": "how"}, {"end": 797.92, "start": 797.48, "text": "fast"}, {"end": 798.0, "start": 797.92, "text": "could"}, {"end": 798.2, "start": 798.0, "text": "you"}, {"end": 798.52, "start": 798.2, "text": "sort"}, {"end": 798.84, "start": 798.52, "text": "100"}, {"end": 799.52, "start": 798.84, "text": "terabytes"}, {"end": 800.32, "start": 799.52, "text": "of"}, {"end": 800.44, "start": 800.32, "text": "data?"}, {"end": 800.44, "start": 800.44, "text": "In"}, {"end": 800.64, "start": 800.44, "text": "about"}, {"end": 801.68, "start": 800.64, "text": "2009,"}, {"end": 802.48, "start": 801.68, "text": "2010,"}, {"end": 802.6, "start": 802.48, "text": "the"}, {"end": 803.12, "start": 802.6, "text": "world"}, {"end": 803.44, "start": 803.12, "text": "record"}, {"end": 803.88, "start": 803.44, "text": "holder"}, {"end": 804.32, "start": 803.88, "text": "was"}, {"end": 804.48, "start": 804.32, "text": "Yahoo,"}, {"end": 804.88, "start": 804.48, "text": "and"}, {"end": 805.04, "start": 804.88, "text": "they"}, {"end": 805.2, "start": 805.04, "text": "were"}, {"end": 805.52, "start": 805.2, "text": "able"}, {"end": 805.68, "start": 805.52, "text": "to"}, {"end": 806.04, "start": 805.68, "text": "sort"}, {"end": 806.8, "start": 806.04, "text": "100"}, {"end": 807.72, "start": 806.8, "text": "terabytes"}, {"end": 807.8, "start": 807.72, "text": "of"}, {"end": 808.04, "start": 807.8, "text": "data"}, {"end": 808.04, "start": 808.04, "text": "in"}, {"end": 808.64, "start": 808.04, "text": "173"}, {"end": 809.04, "start": 808.64, "text": "minutes,"}, {"end": 809.2, "start": 809.04, "text": "which"}, {"end": 809.2, "start": 809.2, "text": "was"}, {"end": 809.2, "start": 809.2, "text": "truly"}, {"end": 809.96, "start": 809.2, "text": "impressive"}], "text": " that we face. If you don't build balanced systems, you can dramatically limit the efficiency of your infrastructure. We took on some work for actually a contest, an annual contest called GraySort. At the time that we did this, about 10 years ago, the question was, how fast could you sort 100 terabytes of data? In about 2009, 2010, the world record holder was Yahoo, and they were able to sort 100 terabytes of data in 173 minutes, which was truly impressive"}, {"chunks": [{"end": 810.12, "start": 810.0, "text": "the"}, {"end": 810.28, "start": 810.12, "text": "time."}, {"end": 810.84, "start": 810.28, "text": "But"}, {"end": 810.84, "start": 810.84, "text": "if"}, {"end": 811.12, "start": 810.84, "text": "you"}, {"end": 811.56, "start": 811.12, "text": "broke"}, {"end": 811.84, "start": 811.56, "text": "this"}, {"end": 812.6, "start": 811.84, "text": "down"}, {"end": 812.92, "start": 812.6, "text": "and"}, {"end": 813.04, "start": 812.92, "text": "looked"}, {"end": 813.16, "start": 813.04, "text": "at"}, {"end": 813.48, "start": 813.16, "text": "the"}, {"end": 814.12, "start": 813.48, "text": "configuration"}, {"end": 814.12, "start": 814.12, "text": "that"}, {"end": 814.28, "start": 814.12, "text": "they"}, {"end": 814.56, "start": 814.28, "text": "used,"}, {"end": 814.72, "start": 814.56, "text": "they"}, {"end": 815.08, "start": 814.72, "text": "ran"}, {"end": 815.16, "start": 815.08, "text": "this"}, {"end": 815.64, "start": 815.16, "text": "100"}, {"end": 816.16, "start": 815.64, "text": "terabytes"}, {"end": 816.52, "start": 816.16, "text": "sort"}, {"end": 816.88, "start": 816.52, "text": "across"}, {"end": 818.48, "start": 816.88, "text": "3,452"}, {"end": 819.84, "start": 818.48, "text": "servers."}, {"end": 820.12, "start": 819.84, "text": "And"}, {"end": 820.48, "start": 820.12, "text": "then"}, {"end": 820.52, "start": 820.48, "text": "the"}, {"end": 821.0, "start": 820.52, "text": "rate"}, {"end": 821.12, "start": 821.0, "text": "per"}, {"end": 821.6, "start": 821.12, "text": "server"}, {"end": 821.96, "start": 821.6, "text": "works"}, {"end": 822.08, "start": 821.96, "text": "out"}, {"end": 822.08, "start": 822.08, "text": "to"}, {"end": 822.24, "start": 822.08, "text": "be"}, {"end": 823.0, "start": 822.24, "text": "2.8"}, {"end": 823.52, "start": 823.0, "text": "megabytes"}, {"end": 823.6, "start": 823.52, "text": "per"}, {"end": 823.92, "start": 823.6, "text": "second."}, {"end": 824.04, "start": 823.92, "text": "If"}, {"end": 824.32, "start": 824.04, "text": "you"}, {"end": 824.48, "start": 824.32, "text": "want"}, {"end": 824.52, "start": 824.48, "text": "to"}, {"end": 824.8, "start": 824.52, "text": "put"}, {"end": 825.12, "start": 824.8, "text": "this"}, {"end": 825.12, "start": 825.12, "text": "in"}, {"end": 825.52, "start": 825.12, "text": "networking"}, {"end": 826.28, "start": 825.52, "text": "terms,"}, {"end": 826.6, "start": 826.28, "text": "about"}, {"end": 826.84, "start": 826.6, "text": "20"}, {"end": 827.24, "start": 826.84, "text": "megabits"}, {"end": 827.32, "start": 827.24, "text": "per"}, {"end": 827.84, "start": 827.32, "text": "second"}, {"end": 828.08, "start": 827.84, "text": "of"}, {"end": 828.32, "start": 828.08, "text": "throughput"}, {"end": 828.68, "start": 828.32, "text": "per"}, {"end": 829.72, "start": 828.68, "text": "server,"}, {"end": 830.28, "start": 829.72, "text": "which"}, {"end": 830.64, "start": 830.28, "text": "certainly"}, {"end": 830.76, "start": 830.64, "text": "for"}, {"end": 831.92, "start": 830.76, "text": "2010"}, {"end": 832.2, "start": 831.92, "text": "was"}, {"end": 832.36, "start": 832.2, "text": "not"}, {"end": 832.96, "start": 832.36, "text": "something"}, {"end": 833.44, "start": 832.96, "text": "that"}, {"end": 833.44, "start": 833.44, "text": "in"}, {"end": 833.72, "start": 833.44, "text": "the"}, {"end": 834.16, "start": 833.72, "text": "end"}, {"end": 834.64, "start": 834.16, "text": "looks"}, {"end": 835.04, "start": 834.64, "text": "impressive."}, {"end": 835.32, "start": 835.04, "text": "So"}, {"end": 835.32, "start": 835.32, "text": "now"}, {"end": 835.32, "start": 835.32, "text": "you"}, {"end": 835.32, "start": 835.32, "text": "have"}, {"end": 835.68, "start": 835.32, "text": "this"}, {"end": 836.4, "start": 835.68, "text": "large"}, {"end": 836.72, "start": 836.4, "text": "scale"}, {"end": 837.04, "start": 836.72, "text": "distributed"}, {"end": 837.4, "start": 837.04, "text": "system"}, {"end": 837.72, "start": 837.4, "text": "at"}, {"end": 838.2, "start": 837.72, "text": "substantial"}, {"end": 838.64, "start": 838.2, "text": "cost,"}, {"end": 839.68, "start": 838.64, "text": "3,452"}, {"end": 839.96, "start": 839.68, "text": "servers."}], "text": " the time. But if you broke this down and looked at the configuration that they used, they ran this 100 terabytes sort across 3,452 servers. And then the rate per server works out to be 2.8 megabytes per second. If you want to put this in networking terms, about 20 megabits per second of throughput per server, which certainly for 2010 was not something that in the end looks impressive. So now you have this large scale distributed system at substantial cost, 3,452 servers."}, {"chunks": [{"end": 840.6, "start": 840.0, "text": "But"}, {"end": 840.84, "start": 840.6, "text": "the"}, {"end": 841.0, "start": 840.84, "text": "throughput"}, {"end": 841.24, "start": 841.0, "text": "that"}, {"end": 841.92, "start": 841.24, "text": "you"}, {"end": 842.24, "start": 841.92, "text": "were"}, {"end": 842.6, "start": 842.24, "text": "delivering"}, {"end": 842.8, "start": 842.6, "text": "was"}, {"end": 843.16, "start": 842.8, "text": "rather"}, {"end": 843.96, "start": 843.16, "text": "limited."}, {"end": 844.32, "start": 843.96, "text": "So"}, {"end": 844.32, "start": 844.32, "text": "we"}, {"end": 844.68, "start": 844.32, "text": "took"}, {"end": 845.2, "start": 844.68, "text": "on"}, {"end": 845.68, "start": 845.2, "text": "the"}, {"end": 846.52, "start": 845.68, "text": "question,"}, {"end": 847.12, "start": 846.52, "text": "how"}, {"end": 847.72, "start": 847.12, "text": "quickly"}, {"end": 848.0, "start": 847.72, "text": "could"}, {"end": 848.0, "start": 848.0, "text": "we"}, {"end": 848.08, "start": 848.0, "text": "do"}, {"end": 848.64, "start": 848.08, "text": "the"}, {"end": 849.04, "start": 848.64, "text": "sort"}, {"end": 849.04, "start": 849.04, "text": "on"}, {"end": 849.44, "start": 849.04, "text": "a"}, {"end": 849.68, "start": 849.44, "text": "much"}, {"end": 850.04, "start": 849.68, "text": "more"}, {"end": 850.16, "start": 850.04, "text": "limited"}, {"end": 850.64, "start": 850.16, "text": "university"}, {"end": 851.08, "start": 850.64, "text": "budget?"}, {"end": 851.6, "start": 851.08, "text": "Basically,"}, {"end": 851.6, "start": 851.6, "text": "could"}, {"end": 851.6, "start": 851.6, "text": "we"}, {"end": 851.76, "start": 851.6, "text": "put"}, {"end": 851.88, "start": 851.76, "text": "together"}, {"end": 852.16, "start": 851.88, "text": "a"}, {"end": 852.44, "start": 852.16, "text": "small"}, {"end": 852.68, "start": 852.44, "text": "scale"}, {"end": 853.36, "start": 852.68, "text": "cluster"}, {"end": 853.72, "start": 853.36, "text": "that"}, {"end": 853.8, "start": 853.72, "text": "could"}, {"end": 854.0, "start": 853.8, "text": "beat"}, {"end": 854.44, "start": 854.0, "text": "the"}, {"end": 854.96, "start": 854.44, "text": "results"}, {"end": 854.96, "start": 854.96, "text": "by"}, {"end": 855.12, "start": 854.96, "text": "being"}, {"end": 855.36, "start": 855.12, "text": "much"}, {"end": 855.56, "start": 855.36, "text": "more"}, {"end": 856.04, "start": 855.56, "text": "efficient"}, {"end": 856.28, "start": 856.04, "text": "and"}, {"end": 856.32, "start": 856.28, "text": "building"}, {"end": 856.32, "start": 856.32, "text": "a"}, {"end": 856.6, "start": 856.32, "text": "balanced"}, {"end": 857.36, "start": 856.6, "text": "system"}, {"end": 857.84, "start": 857.36, "text": "across"}, {"end": 858.36, "start": 857.84, "text": "disk,"}, {"end": 858.84, "start": 858.36, "text": "across"}, {"end": 859.08, "start": 858.84, "text": "compute,"}, {"end": 859.24, "start": 859.08, "text": "and"}, {"end": 859.68, "start": 859.24, "text": "across"}, {"end": 859.96, "start": 859.68, "text": "network"}, {"end": 860.08, "start": 859.96, "text": "to"}, {"end": 860.08, "start": 860.08, "text": "do"}, {"end": 860.24, "start": 860.08, "text": "so?"}, {"end": 860.64, "start": 860.24, "text": "It"}, {"end": 861.44, "start": 860.64, "text": "turned"}, {"end": 861.72, "start": 861.44, "text": "out"}, {"end": 861.72, "start": 861.72, "text": "to"}, {"end": 861.8, "start": 861.72, "text": "be"}, {"end": 862.24, "start": 861.8, "text": "much"}, {"end": 862.56, "start": 862.24, "text": "harder"}, {"end": 862.8, "start": 862.56, "text": "than"}, {"end": 862.96, "start": 862.8, "text": "we"}, {"end": 863.6, "start": 862.96, "text": "anticipated."}, {"end": 864.52, "start": 863.6, "text": "But"}, {"end": 865.16, "start": 864.52, "text": "after"}, {"end": 865.6, "start": 865.16, "text": "a"}, {"end": 865.76, "start": 865.6, "text": "bit"}, {"end": 866.24, "start": 865.76, "text": "of"}, {"end": 866.84, "start": 866.24, "text": "work,"}, {"end": 867.0, "start": 866.84, "text": "we"}, {"end": 867.32, "start": 867.0, "text": "were"}, {"end": 868.24, "start": 867.32, "text": "able"}, {"end": 868.36, "start": 868.24, "text": "to"}, {"end": 868.4, "start": 868.36, "text": "beat"}, {"end": 869.48, "start": 868.4, "text": "the"}, {"end": 869.96, "start": 869.48, "text": "world"}], "text": " But the throughput that you were delivering was rather limited. So we took on the question, how quickly could we do the sort on a much more limited university budget? Basically, could we put together a small scale cluster that could beat the results by being much more efficient and building a balanced system across disk, across compute, and across network to do so? It turned out to be much harder than we anticipated. But after a bit of work, we were able to beat the world"}, {"chunks": [{"end": 870.76, "start": 870.0, "text": "record"}, {"end": 870.92, "start": 870.76, "text": "at"}, {"end": 870.92, "start": 870.92, "text": "the"}, {"end": 871.0, "start": 870.92, "text": "time."}, {"end": 871.56, "start": 871.0, "text": "So"}, {"end": 871.56, "start": 871.56, "text": "we"}, {"end": 871.56, "start": 871.56, "text": "were"}, {"end": 871.56, "start": 871.56, "text": "able"}, {"end": 871.68, "start": 871.56, "text": "to"}, {"end": 871.92, "start": 871.68, "text": "sort"}, {"end": 871.92, "start": 871.92, "text": "the"}, {"end": 872.16, "start": 871.92, "text": "100"}, {"end": 872.84, "start": 872.16, "text": "terabytes"}, {"end": 872.84, "start": 872.84, "text": "in"}, {"end": 873.36, "start": 872.84, "text": "107"}, {"end": 874.12, "start": 873.36, "text": "minutes"}, {"end": 874.44, "start": 874.12, "text": "on"}, {"end": 874.88, "start": 874.44, "text": "52"}, {"end": 875.48, "start": 874.88, "text": "servers."}, {"end": 875.64, "start": 875.48, "text": "And"}, {"end": 875.76, "start": 875.64, "text": "if"}, {"end": 875.8, "start": 875.76, "text": "you"}, {"end": 875.96, "start": 875.8, "text": "then"}, {"end": 876.28, "start": 875.96, "text": "look"}, {"end": 876.28, "start": 876.28, "text": "at"}, {"end": 876.4, "start": 876.28, "text": "the"}, {"end": 876.6, "start": 876.4, "text": "rate"}, {"end": 876.72, "start": 876.6, "text": "per"}, {"end": 877.32, "start": 876.72, "text": "server,"}, {"end": 877.56, "start": 877.32, "text": "that's"}, {"end": 877.96, "start": 877.56, "text": "300"}, {"end": 878.8, "start": 877.96, "text": "megabytes"}, {"end": 879.76, "start": 878.8, "text": "per"}, {"end": 880.4, "start": 879.76, "text": "second,"}, {"end": 880.64, "start": 880.4, "text": "or"}, {"end": 880.96, "start": 880.64, "text": "about"}, {"end": 881.28, "start": 880.96, "text": "a"}, {"end": 881.48, "start": 881.28, "text": "factor"}, {"end": 881.6, "start": 881.48, "text": "of"}, {"end": 882.12, "start": 881.6, "text": "100x"}, {"end": 882.56, "start": 882.12, "text": "efficiency"}, {"end": 883.32, "start": 882.56, "text": "improvement"}, {"end": 883.8, "start": 883.32, "text": "relative"}, {"end": 884.48, "start": 883.8, "text": "to"}, {"end": 884.8, "start": 884.48, "text": "the"}, {"end": 885.32, "start": 884.8, "text": "previous"}, {"end": 886.64, "start": 885.32, "text": "record"}, {"end": 887.32, "start": 886.64, "text": "holder."}, {"end": 887.64, "start": 887.32, "text": "So"}, {"end": 888.08, "start": 887.64, "text": "this"}, {"end": 888.48, "start": 888.08, "text": "argues"}, {"end": 889.08, "start": 888.48, "text": "again"}, {"end": 889.28, "start": 889.08, "text": "for"}, {"end": 889.52, "start": 889.28, "text": "the"}, {"end": 890.2, "start": 889.52, "text": "importance"}, {"end": 890.48, "start": 890.2, "text": "of"}, {"end": 890.8, "start": 890.48, "text": "balanced"}, {"end": 891.24, "start": 890.8, "text": "systems"}, {"end": 892.04, "start": 891.24, "text": "and"}, {"end": 892.52, "start": 892.04, "text": "the"}, {"end": 892.8, "start": 892.52, "text": "ability"}, {"end": 892.96, "start": 892.8, "text": "to"}, {"end": 893.4, "start": 892.96, "text": "actually"}, {"end": 893.44, "start": 893.4, "text": "improve"}, {"end": 893.44, "start": 893.44, "text": "the"}, {"end": 894.32, "start": 893.44, "text": "performance"}, {"end": 894.32, "start": 894.32, "text": "of"}, {"end": 894.6, "start": 894.32, "text": "your"}, {"end": 895.24, "start": 894.6, "text": "systems,"}, {"end": 895.44, "start": 895.24, "text": "not"}, {"end": 895.64, "start": 895.44, "text": "by"}, {"end": 896.12, "start": 895.64, "text": "building"}, {"end": 896.56, "start": 896.12, "text": "different"}, {"end": 897.04, "start": 896.56, "text": "hardware,"}, {"end": 897.52, "start": 897.04, "text": "but"}, {"end": 897.76, "start": 897.52, "text": "by"}, {"end": 898.08, "start": 897.76, "text": "composing"}, {"end": 898.2, "start": 898.08, "text": "your"}, {"end": 898.48, "start": 898.2, "text": "system"}, {"end": 898.88, "start": 898.48, "text": "differently."}, {"end": 899.96, "start": 898.88, "text": "Now,"}], "text": " record at the time. So we were able to sort the 100 terabytes in 107 minutes on 52 servers. And if you then look at the rate per server, that's 300 megabytes per second, or about a factor of 100x efficiency improvement relative to the previous record holder. So this argues again for the importance of balanced systems and the ability to actually improve the performance of your systems, not by building different hardware, but by composing your system differently. Now,"}, {"chunks": [{"end": 900.52, "start": 900.0, "text": "Interestingly,"}, {"end": 900.96, "start": 900.52, "text": "when"}, {"end": 900.96, "start": 900.96, "text": "we"}, {"end": 900.96, "start": 900.96, "text": "did"}, {"end": 901.2, "start": 900.96, "text": "the"}, {"end": 901.88, "start": 901.2, "text": "calculation,"}, {"end": 902.0, "start": 901.88, "text": "this"}, {"end": 902.6, "start": 902.0, "text": "300"}, {"end": 903.04, "start": 902.6, "text": "megabytes"}, {"end": 903.2, "start": 903.04, "text": "per"}, {"end": 903.6, "start": 903.2, "text": "second"}, {"end": 903.6, "start": 903.6, "text": "worked"}, {"end": 903.76, "start": 903.6, "text": "out"}, {"end": 903.76, "start": 903.76, "text": "to"}, {"end": 903.96, "start": 903.76, "text": "be"}, {"end": 904.56, "start": 903.96, "text": "about"}, {"end": 905.08, "start": 904.56, "text": "25%"}, {"end": 905.52, "start": 905.08, "text": "of"}, {"end": 905.8, "start": 905.52, "text": "the"}, {"end": 906.16, "start": 905.8, "text": "roofline."}, {"end": 906.52, "start": 906.16, "text": "What"}, {"end": 906.64, "start": 906.52, "text": "I"}, {"end": 906.92, "start": 906.64, "text": "mean"}, {"end": 907.24, "start": 906.92, "text": "by"}, {"end": 907.64, "start": 907.24, "text": "that"}, {"end": 908.12, "start": 907.64, "text": "is"}, {"end": 908.48, "start": 908.12, "text": "that"}, {"end": 908.6, "start": 908.48, "text": "while"}, {"end": 908.64, "start": 908.6, "text": "we"}, {"end": 908.68, "start": 908.64, "text": "did"}, {"end": 908.76, "start": 908.68, "text": "quite"}, {"end": 909.32, "start": 908.76, "text": "well,"}, {"end": 909.84, "start": 909.32, "text": "and"}, {"end": 910.08, "start": 909.84, "text": "I'm"}, {"end": 910.64, "start": 910.08, "text": "certainly"}, {"end": 910.96, "start": 910.64, "text": "proud"}, {"end": 911.12, "start": 910.96, "text": "of"}, {"end": 911.28, "start": 911.12, "text": "the"}, {"end": 911.32, "start": 911.28, "text": "work"}, {"end": 911.68, "start": 911.32, "text": "that"}, {"end": 911.68, "start": 911.68, "text": "the"}, {"end": 911.72, "start": 911.68, "text": "team"}, {"end": 911.72, "start": 911.72, "text": "did,"}, {"end": 911.76, "start": 911.72, "text": "we"}, {"end": 912.12, "start": 911.76, "text": "actually"}, {"end": 912.52, "start": 912.12, "text": "left"}, {"end": 912.68, "start": 912.52, "text": "a"}, {"end": 913.48, "start": 912.68, "text": "factor"}, {"end": 913.76, "start": 913.48, "text": "of"}, {"end": 914.28, "start": 913.76, "text": "four"}, {"end": 914.6, "start": 914.28, "text": "on"}, {"end": 914.84, "start": 914.6, "text": "the"}, {"end": 915.2, "start": 914.84, "text": "table."}, {"end": 915.4, "start": 915.2, "text": "Now,"}, {"end": 915.8, "start": 915.4, "text": "I'll"}, {"end": 916.44, "start": 915.8, "text": "share"}, {"end": 916.76, "start": 916.44, "text": "that"}, {"end": 916.76, "start": 916.76, "text": "when"}, {"end": 916.8, "start": 916.76, "text": "I"}, {"end": 917.28, "start": 916.8, "text": "raised"}, {"end": 917.28, "start": 917.28, "text": "this"}, {"end": 917.28, "start": 917.28, "text": "with"}, {"end": 917.44, "start": 917.28, "text": "the"}, {"end": 918.0, "start": 917.44, "text": "students"}, {"end": 918.04, "start": 918.0, "text": "who"}, {"end": 918.2, "start": 918.04, "text": "did"}, {"end": 918.68, "start": 918.2, "text": "all"}, {"end": 919.12, "start": 918.68, "text": "the"}, {"end": 919.44, "start": 919.12, "text": "work"}, {"end": 919.44, "start": 919.44, "text": "on"}, {"end": 919.44, "start": 919.44, "text": "this"}, {"end": 919.44, "start": 919.44, "text": "program."}, {"end": 919.68, "start": 919.44, "text": "They"}, {"end": 920.24, "start": 919.68, "text": "said,"}, {"end": 920.44, "start": 920.24, "text": "no"}, {"end": 920.68, "start": 920.44, "text": "way."}, {"end": 921.12, "start": 920.68, "text": "It"}, {"end": 921.92, "start": 921.12, "text": "was"}, {"end": 922.48, "start": 921.92, "text": "way"}, {"end": 922.6, "start": 922.48, "text": "too"}, {"end": 922.88, "start": 922.6, "text": "hard"}, {"end": 922.88, "start": 922.88, "text": "to"}, {"end": 922.92, "start": 922.88, "text": "get"}, {"end": 923.52, "start": 922.92, "text": "where"}, {"end": 923.52, "start": 923.52, "text": "we"}, {"end": 923.76, "start": 923.52, "text": "were"}, {"end": 924.24, "start": 923.76, "text": "at,"}, {"end": 924.6, "start": 924.24, "text": "and"}, {"end": 925.24, "start": 924.6, "text": "there's"}, {"end": 925.44, "start": 925.24, "text": "no"}, {"end": 925.44, "start": 925.44, "text": "way"}, {"end": 925.56, "start": 925.44, "text": "with"}, {"end": 925.8, "start": 925.56, "text": "the"}, {"end": 926.24, "start": 925.8, "text": "tools"}, {"end": 926.24, "start": 926.24, "text": "that"}, {"end": 926.32, "start": 926.24, "text": "we"}, {"end": 926.6, "start": 926.32, "text": "have"}, {"end": 926.76, "start": 926.6, "text": "and"}, {"end": 926.92, "start": 926.76, "text": "the"}, {"end": 926.92, "start": 926.92, "text": "time"}, {"end": 927.0, "start": 926.92, "text": "that"}, {"end": 927.0, "start": 927.0, "text": "we"}, {"end": 927.0, "start": 927.0, "text": "have"}, {"end": 927.0, "start": 927.0, "text": "that"}, {"end": 927.0, "start": 927.0, "text": "we"}, {"end": 927.8, "start": 927.0, "text": "can"}, {"end": 927.84, "start": 927.8, "text": "get"}, {"end": 928.76, "start": 927.84, "text": "this"}, {"end": 928.96, "start": 928.76, "text": "remaining"}, {"end": 929.2, "start": 928.96, "text": "factor"}, {"end": 929.2, "start": 929.2, "text": "of"}, {"end": 929.96, "start": 929.2, "text": "four."}], "text": " Interestingly, when we did the calculation, this 300 megabytes per second worked out to be about 25% of the roofline. What I mean by that is that while we did quite well, and I'm certainly proud of the work that the team did, we actually left a factor of four on the table. Now, I'll share that when I raised this with the students who did all the work on this program. They said, no way. It was way too hard to get where we were at, and there's no way with the tools that we have and the time that we have that we can get this remaining factor of four."}, {"chunks": [{"end": 930.28, "start": 930.0, "text": "And"}, {"end": 930.36, "start": 930.28, "text": "all"}, {"end": 930.36, "start": 930.36, "text": "of"}, {"end": 930.36, "start": 930.36, "text": "this"}, {"end": 930.36, "start": 930.36, "text": "goes"}, {"end": 930.36, "start": 930.36, "text": "hand"}, {"end": 930.4, "start": 930.36, "text": "in"}, {"end": 931.08, "start": 930.4, "text": "hand."}, {"end": 931.32, "start": 931.08, "text": "One"}, {"end": 931.6, "start": 931.32, "text": "of"}, {"end": 932.2, "start": 931.6, "text": "the"}, {"end": 932.8, "start": 932.2, "text": "challenges"}, {"end": 933.12, "start": 932.8, "text": "that"}, {"end": 933.24, "start": 933.12, "text": "the"}, {"end": 933.52, "start": 933.24, "text": "Yahoo"}, {"end": 933.84, "start": 933.52, "text": "team"}, {"end": 934.44, "start": 933.84, "text": "and"}, {"end": 934.68, "start": 934.44, "text": "others"}, {"end": 935.32, "start": 934.68, "text": "had"}, {"end": 935.68, "start": 935.32, "text": "at"}, {"end": 935.68, "start": 935.68, "text": "the"}, {"end": 935.8, "start": 935.68, "text": "time"}, {"end": 936.36, "start": 935.8, "text": "was"}, {"end": 936.68, "start": 936.36, "text": "that"}, {"end": 937.0, "start": 936.68, "text": "they"}, {"end": 937.04, "start": 937.0, "text": "actually"}, {"end": 937.04, "start": 937.04, "text": "didn't"}, {"end": 937.04, "start": 937.04, "text": "have"}, {"end": 937.04, "start": 937.04, "text": "the"}, {"end": 937.12, "start": 937.04, "text": "network"}, {"end": 937.48, "start": 937.12, "text": "bandwidth"}, {"end": 937.48, "start": 937.48, "text": "at"}, {"end": 937.6, "start": 937.48, "text": "the"}, {"end": 938.04, "start": 937.6, "text": "scale"}, {"end": 938.08, "start": 938.04, "text": "of"}, {"end": 939.24, "start": 938.08, "text": "3,452"}, {"end": 940.0, "start": 939.24, "text": "servers"}, {"end": 940.16, "start": 940.0, "text": "to"}, {"end": 940.36, "start": 940.16, "text": "be"}, {"end": 940.56, "start": 940.36, "text": "able"}, {"end": 941.0, "start": 940.56, "text": "to"}, {"end": 941.4, "start": 941.0, "text": "support"}, {"end": 941.4, "start": 941.4, "text": "a"}, {"end": 941.88, "start": 941.4, "text": "balanced"}, {"end": 942.28, "start": 941.88, "text": "system"}, {"end": 942.64, "start": 942.28, "text": "across"}, {"end": 943.0, "start": 942.64, "text": "disk,"}, {"end": 943.64, "start": 943.0, "text": "across"}, {"end": 943.92, "start": 943.64, "text": "compute,"}, {"end": 943.96, "start": 943.92, "text": "and"}, {"end": 944.4, "start": 943.96, "text": "across"}, {"end": 944.64, "start": 944.4, "text": "networking."}, {"end": 945.08, "start": 944.64, "text": "So"}, {"end": 945.2, "start": 945.08, "text": "some"}, {"end": 945.28, "start": 945.2, "text": "of"}, {"end": 945.8, "start": 945.28, "text": "the"}, {"end": 946.2, "start": 945.8, "text": "other"}, {"end": 947.08, "start": 946.2, "text": "work"}, {"end": 947.08, "start": 947.08, "text": "that"}, {"end": 947.08, "start": 947.08, "text": "we"}, {"end": 947.08, "start": 947.08, "text": "were"}, {"end": 947.08, "start": 947.08, "text": "doing"}, {"end": 947.08, "start": 947.08, "text": "in"}, {"end": 947.56, "start": 947.08, "text": "parallel"}, {"end": 947.56, "start": 947.56, "text": "to"}, {"end": 948.04, "start": 947.56, "text": "this"}, {"end": 948.48, "start": 948.04, "text": "was"}, {"end": 949.24, "start": 948.48, "text": "investigating"}, {"end": 949.72, "start": 949.24, "text": "what"}, {"end": 950.08, "start": 949.72, "text": "it"}, {"end": 950.08, "start": 950.08, "text": "might"}, {"end": 950.08, "start": 950.08, "text": "take"}, {"end": 950.32, "start": 950.08, "text": "to"}, {"end": 950.72, "start": 950.32, "text": "build"}, {"end": 951.72, "start": 950.72, "text": "non-blocking"}, {"end": 952.72, "start": 951.72, "text": "topologies"}, {"end": 953.16, "start": 952.72, "text": "for"}, {"end": 953.24, "start": 953.16, "text": "the"}, {"end": 953.28, "start": 953.24, "text": "data"}, {"end": 954.0, "start": 953.28, "text": "center"}, {"end": 954.12, "start": 954.0, "text": "to"}, {"end": 954.36, "start": 954.12, "text": "enable"}, {"end": 954.44, "start": 954.36, "text": "the"}, {"end": 954.8, "start": 954.44, "text": "balanced"}, {"end": 955.16, "start": 954.8, "text": "systems"}, {"end": 955.48, "start": 955.16, "text": "that"}, {"end": 955.6, "start": 955.48, "text": "we"}, {"end": 955.96, "start": 955.6, "text": "needed"}, {"end": 956.4, "start": 955.96, "text": "for"}, {"end": 956.6, "start": 956.4, "text": "ultimate"}, {"end": 957.0, "start": 956.6, "text": "system"}, {"end": 957.84, "start": 957.0, "text": "efficiency."}, {"end": 958.08, "start": 957.84, "text": "We"}, {"end": 958.72, "start": 958.08, "text": "started"}, {"end": 958.88, "start": 958.72, "text": "with"}, {"end": 959.24, "start": 958.88, "text": "thinking"}, {"end": 959.96, "start": 959.24, "text": "about"}], "text": " And all of this goes hand in hand. One of the challenges that the Yahoo team and others had at the time was that they actually didn't have the network bandwidth at the scale of 3,452 servers to be able to support a balanced system across disk, across compute, and across networking. So some of the other work that we were doing in parallel to this was investigating what it might take to build non-blocking topologies for the data center to enable the balanced systems that we needed for ultimate system efficiency. We started with thinking about"}, {"chunks": [{"end": 960.4, "start": 960.0, "text": "topology"}, {"end": 960.4, "start": 960.4, "text": "and"}, {"end": 960.64, "start": 960.4, "text": "the"}, {"end": 961.0, "start": 960.64, "text": "basic"}, {"end": 961.16, "start": 961.0, "text": "approach."}, {"end": 961.16, "start": 961.16, "text": "And"}, {"end": 961.16, "start": 961.16, "text": "that"}, {"end": 961.2, "start": 961.16, "text": "led"}, {"end": 961.48, "start": 961.2, "text": "to"}, {"end": 961.72, "start": 961.48, "text": "our"}, {"end": 962.2, "start": 961.72, "text": "work"}, {"end": 962.72, "start": 962.2, "text": "on"}, {"end": 963.28, "start": 962.72, "text": "factories"}, {"end": 963.28, "start": 963.28, "text": "and"}, {"end": 963.6, "start": 963.28, "text": "cloud"}, {"end": 964.64, "start": 963.6, "text": "topologies"}, {"end": 965.04, "start": 964.64, "text": "for"}, {"end": 965.32, "start": 965.04, "text": "large"}, {"end": 965.52, "start": 965.32, "text": "scale"}, {"end": 965.64, "start": 965.52, "text": "data"}, {"end": 966.16, "start": 965.64, "text": "center"}, {"end": 966.56, "start": 966.16, "text": "networks."}, {"end": 966.96, "start": 966.56, "text": "We"}, {"end": 967.36, "start": 966.96, "text": "next"}, {"end": 967.48, "start": 967.36, "text": "looked"}, {"end": 967.8, "start": 967.48, "text": "at"}, {"end": 967.8, "start": 967.8, "text": "the"}, {"end": 968.24, "start": 967.8, "text": "problems"}, {"end": 968.24, "start": 968.24, "text": "of"}, {"end": 968.92, "start": 968.24, "text": "virtualization,"}, {"end": 968.92, "start": 968.92, "text": "how"}, {"end": 969.0, "start": 968.92, "text": "we"}, {"end": 969.44, "start": 969.0, "text": "could"}, {"end": 969.76, "start": 969.44, "text": "have"}, {"end": 970.12, "start": 969.76, "text": "multiple"}, {"end": 970.64, "start": 970.12, "text": "tenants,"}, {"end": 971.92, "start": 970.64, "text": "perhaps"}, {"end": 971.92, "start": 971.92, "text": "in"}, {"end": 971.92, "start": 971.92, "text": "a"}, {"end": 972.12, "start": 971.92, "text": "cloud"}, {"end": 972.28, "start": 972.12, "text": "environment,"}, {"end": 972.48, "start": 972.28, "text": "running"}, {"end": 973.08, "start": 972.48, "text": "isolated"}, {"end": 973.4, "start": 973.08, "text": "across"}, {"end": 973.52, "start": 973.4, "text": "the"}, {"end": 974.04, "start": 973.52, "text": "network"}, {"end": 974.28, "start": 974.04, "text": "at"}, {"end": 975.36, "start": 974.28, "text": "scale."}, {"end": 975.8, "start": 975.36, "text": "We"}, {"end": 976.08, "start": 975.8, "text": "found"}, {"end": 976.76, "start": 976.08, "text": "that"}, {"end": 977.32, "start": 976.76, "text": "existing"}, {"end": 977.76, "start": 977.32, "text": "techniques"}, {"end": 978.04, "start": 977.76, "text": "for"}, {"end": 978.96, "start": 978.04, "text": "balancing"}, {"end": 979.4, "start": 978.96, "text": "flow"}, {"end": 980.0, "start": 979.4, "text": "communication"}, {"end": 980.52, "start": 980.0, "text": "across"}, {"end": 980.8, "start": 980.52, "text": "these"}, {"end": 981.16, "start": 980.8, "text": "switches"}, {"end": 981.32, "start": 981.16, "text": "would"}, {"end": 981.44, "start": 981.32, "text": "lead"}, {"end": 981.44, "start": 981.44, "text": "to"}, {"end": 982.12, "start": 981.44, "text": "hotspots,"}, {"end": 982.56, "start": 982.12, "text": "especially"}, {"end": 982.88, "start": 982.56, "text": "given"}, {"end": 983.08, "start": 982.88, "text": "any"}, {"end": 983.76, "start": 983.08, "text": "variation"}, {"end": 983.76, "start": 983.76, "text": "in"}, {"end": 984.04, "start": 983.76, "text": "the"}, {"end": 984.64, "start": 984.04, "text": "size"}, {"end": 985.2, "start": 984.64, "text": "of"}, {"end": 985.52, "start": 985.2, "text": "the"}, {"end": 986.32, "start": 985.52, "text": "flows."}, {"end": 986.92, "start": 986.32, "text": "So"}, {"end": 987.24, "start": 986.92, "text": "we"}, {"end": 987.24, "start": 987.24, "text": "looked"}, {"end": 987.24, "start": 987.24, "text": "at"}, {"end": 987.28, "start": 987.24, "text": "dynamically"}, {"end": 987.8, "start": 987.28, "text": "mapping"}, {"end": 988.36, "start": 987.8, "text": "flows"}, {"end": 988.36, "start": 988.36, "text": "to"}, {"end": 989.08, "start": 988.36, "text": "paths"}, {"end": 989.68, "start": 989.08, "text": "in"}, {"end": 989.96, "start": 989.68, "text": "near"}], "text": " topology and the basic approach. And that led to our work on factories and cloud topologies for large scale data center networks. We next looked at the problems of virtualization, how we could have multiple tenants, perhaps in a cloud environment, running isolated across the network at scale. We found that existing techniques for balancing flow communication across these switches would lead to hotspots, especially given any variation in the size of the flows. So we looked at dynamically mapping flows to paths in near"}, {"chunks": [{"end": 990.88, "start": 990.0, "text": "time,"}, {"end": 991.08, "start": 990.88, "text": "but"}, {"end": 991.84, "start": 991.08, "text": "based"}, {"end": 992.12, "start": 991.84, "text": "on"}, {"end": 992.24, "start": 992.12, "text": "detecting"}, {"end": 992.68, "start": 992.24, "text": "the"}, {"end": 993.24, "start": 992.68, "text": "larger"}, {"end": 993.64, "start": 993.24, "text": "flows,"}, {"end": 993.72, "start": 993.64, "text": "the"}, {"end": 993.96, "start": 993.72, "text": "elephants,"}, {"end": 994.04, "start": 993.96, "text": "and"}, {"end": 994.16, "start": 994.04, "text": "being"}, {"end": 994.36, "start": 994.16, "text": "able"}, {"end": 994.64, "start": 994.36, "text": "to"}, {"end": 995.28, "start": 994.64, "text": "rebalance"}, {"end": 995.76, "start": 995.28, "text": "just"}, {"end": 996.28, "start": 995.76, "text": "that"}, {"end": 997.12, "start": 996.28, "text": "subset."}, {"end": 997.28, "start": 997.12, "text": "And"}, {"end": 997.72, "start": 997.28, "text": "finally,"}, {"end": 997.72, "start": 997.72, "text": "we"}, {"end": 998.6, "start": 997.72, "text": "considered"}, {"end": 998.84, "start": 998.6, "text": "what"}, {"end": 998.92, "start": 998.84, "text": "it"}, {"end": 999.2, "start": 998.92, "text": "would"}, {"end": 999.6, "start": 999.2, "text": "take"}, {"end": 999.8, "start": 999.6, "text": "given"}, {"end": 1000.0, "start": 999.8, "text": "stability"}, {"end": 1000.36, "start": 1000.0, "text": "and"}, {"end": 1000.84, "start": 1000.36, "text": "communication"}, {"end": 1001.84, "start": 1000.84, "text": "patterns"}, {"end": 1002.0, "start": 1001.84, "text": "to"}, {"end": 1002.36, "start": 1002.0, "text": "actually"}, {"end": 1002.36, "start": 1002.36, "text": "make"}, {"end": 1002.48, "start": 1002.36, "text": "the"}, {"end": 1002.88, "start": 1002.48, "text": "network"}, {"end": 1002.96, "start": 1002.88, "text": "even"}, {"end": 1003.24, "start": 1002.96, "text": "more"}, {"end": 1003.88, "start": 1003.24, "text": "efficient,"}, {"end": 1004.2, "start": 1003.88, "text": "more"}, {"end": 1004.72, "start": 1004.2, "text": "cost"}, {"end": 1005.32, "start": 1004.72, "text": "effective"}, {"end": 1005.68, "start": 1005.32, "text": "by"}, {"end": 1006.12, "start": 1005.68, "text": "leveraging"}, {"end": 1006.6, "start": 1006.12, "text": "optical"}, {"end": 1007.4, "start": 1006.6, "text": "interconnects,"}, {"end": 1007.92, "start": 1007.4, "text": "especially"}, {"end": 1008.4, "start": 1007.92, "text": "higher"}, {"end": 1008.56, "start": 1008.4, "text": "up"}, {"end": 1008.56, "start": 1008.56, "text": "in"}, {"end": 1008.56, "start": 1008.56, "text": "the"}, {"end": 1009.04, "start": 1008.56, "text": "topology."}, {"end": 1009.52, "start": 1009.04, "text": "The"}, {"end": 1010.08, "start": 1009.52, "text": "observation"}, {"end": 1010.4, "start": 1010.08, "text": "here"}, {"end": 1010.56, "start": 1010.4, "text": "is"}, {"end": 1011.0, "start": 1010.56, "text": "that"}, {"end": 1011.0, "start": 1011.0, "text": "actually"}, {"end": 1011.48, "start": 1011.0, "text": "most"}, {"end": 1011.52, "start": 1011.48, "text": "of"}, {"end": 1011.56, "start": 1011.52, "text": "the"}, {"end": 1012.08, "start": 1011.56, "text": "cost"}, {"end": 1012.32, "start": 1012.08, "text": "of"}, {"end": 1012.68, "start": 1012.32, "text": "your"}, {"end": 1013.08, "start": 1012.68, "text": "data"}, {"end": 1013.08, "start": 1013.08, "text": "center"}, {"end": 1013.68, "start": 1013.08, "text": "network"}, {"end": 1014.2, "start": 1013.68, "text": "comes"}, {"end": 1014.44, "start": 1014.2, "text": "from"}, {"end": 1014.72, "start": 1014.44, "text": "the"}, {"end": 1015.16, "start": 1014.72, "text": "optical"}, {"end": 1016.2, "start": 1015.16, "text": "connectivity"}, {"end": 1016.88, "start": 1016.2, "text": "between"}, {"end": 1017.6, "start": 1016.88, "text": "switches"}, {"end": 1017.76, "start": 1017.6, "text": "at"}, {"end": 1017.76, "start": 1017.76, "text": "any"}, {"end": 1018.16, "start": 1017.76, "text": "length"}, {"end": 1018.44, "start": 1018.16, "text": "and"}, {"end": 1018.96, "start": 1018.44, "text": "converting"}, {"end": 1019.04, "start": 1018.96, "text": "between"}, {"end": 1019.68, "start": 1019.04, "text": "electrical"}, {"end": 1019.96, "start": 1019.68, "text": "signals"}], "text": " time, but based on detecting the larger flows, the elephants, and being able to rebalance just that subset. And finally, we considered what it would take given stability and communication patterns to actually make the network even more efficient, more cost effective by leveraging optical interconnects, especially higher up in the topology. The observation here is that actually most of the cost of your data center network comes from the optical connectivity between switches at any length and converting between electrical signals"}, {"chunks": [{"end": 1020.24, "start": 1020.0, "text": "to"}, {"end": 1020.8, "start": 1020.24, "text": "optical"}, {"end": 1021.32, "start": 1020.8, "text": "signals"}, {"end": 1021.48, "start": 1021.32, "text": "and"}, {"end": 1021.52, "start": 1021.48, "text": "then"}, {"end": 1021.84, "start": 1021.52, "text": "back"}, {"end": 1021.84, "start": 1021.84, "text": "to"}, {"end": 1022.48, "start": 1021.84, "text": "electrical"}, {"end": 1022.72, "start": 1022.48, "text": "is"}, {"end": 1023.08, "start": 1022.72, "text": "a"}, {"end": 1023.84, "start": 1023.08, "text": "substantial"}, {"end": 1024.2, "start": 1023.84, "text": "portion"}, {"end": 1024.2, "start": 1024.2, "text": "of"}, {"end": 1024.32, "start": 1024.2, "text": "the"}, {"end": 1025.04, "start": 1024.32, "text": "cost."}, {"end": 1025.48, "start": 1025.04, "text": "Hence,"}, {"end": 1025.68, "start": 1025.48, "text": "could"}, {"end": 1025.68, "start": 1025.68, "text": "we"}, {"end": 1025.84, "start": 1025.68, "text": "do"}, {"end": 1026.0, "start": 1025.84, "text": "all"}, {"end": 1026.52, "start": 1026.0, "text": "optical"}, {"end": 1027.24, "start": 1026.52, "text": "switching"}, {"end": 1027.52, "start": 1027.24, "text": "at"}, {"end": 1028.0, "start": 1027.52, "text": "one"}, {"end": 1028.44, "start": 1028.0, "text": "region"}, {"end": 1028.64, "start": 1028.44, "text": "of"}, {"end": 1029.12, "start": 1028.64, "text": "the"}, {"end": 1029.52, "start": 1029.12, "text": "network"}, {"end": 1029.76, "start": 1029.52, "text": "to"}, {"end": 1030.12, "start": 1029.76, "text": "save"}, {"end": 1030.12, "start": 1030.12, "text": "on"}, {"end": 1030.52, "start": 1030.12, "text": "cost?"}, {"end": 1030.56, "start": 1030.52, "text": "So"}, {"end": 1030.56, "start": 1030.56, "text": "the"}, {"end": 1032.28, "start": 1030.56, "text": "implications"}, {"end": 1033.12, "start": 1032.28, "text": "of"}, {"end": 1034.24, "start": 1033.12, "text": "this"}, {"end": 1034.28, "start": 1034.24, "text": "work"}, {"end": 1034.28, "start": 1034.28, "text": "as"}, {"end": 1034.28, "start": 1034.28, "text": "we"}, {"end": 1034.28, "start": 1034.28, "text": "looked"}, {"end": 1034.28, "start": 1034.28, "text": "at"}, {"end": 1034.28, "start": 1034.28, "text": "what"}, {"end": 1034.28, "start": 1034.28, "text": "it"}, {"end": 1034.28, "start": 1034.28, "text": "would"}, {"end": 1034.28, "start": 1034.28, "text": "take"}, {"end": 1034.68, "start": 1034.28, "text": "to"}, {"end": 1035.24, "start": 1034.68, "text": "scale"}, {"end": 1035.8, "start": 1035.24, "text": "out"}, {"end": 1036.24, "start": 1035.8, "text": "the"}, {"end": 1037.08, "start": 1036.24, "text": "network"}, {"end": 1037.68, "start": 1037.08, "text": "across"}, {"end": 1037.88, "start": 1037.68, "text": "the"}, {"end": 1037.96, "start": 1037.88, "text": "data"}, {"end": 1038.6, "start": 1037.96, "text": "center"}, {"end": 1038.84, "start": 1038.6, "text": "and"}, {"end": 1038.96, "start": 1038.84, "text": "then"}, {"end": 1038.96, "start": 1038.96, "text": "eventually"}, {"end": 1039.44, "start": 1038.96, "text": "across"}, {"end": 1039.96, "start": 1039.44, "text": "the"}, {"end": 1040.96, "start": 1039.96, "text": "wide"}, {"end": 1041.52, "start": 1040.96, "text": "area"}, {"end": 1041.8, "start": 1041.52, "text": "was"}, {"end": 1042.04, "start": 1041.8, "text": "that"}, {"end": 1042.4, "start": 1042.04, "text": "the"}, {"end": 1043.48, "start": 1042.4, "text": "protocols"}, {"end": 1043.76, "start": 1043.48, "text": "that"}, {"end": 1044.08, "start": 1043.76, "text": "we"}, {"end": 1044.52, "start": 1044.08, "text": "had"}, {"end": 1044.56, "start": 1044.52, "text": "to"}, {"end": 1044.8, "start": 1044.56, "text": "build"}, {"end": 1045.72, "start": 1044.8, "text": "the"}, {"end": 1046.04, "start": 1045.72, "text": "internet"}, {"end": 1046.4, "start": 1046.04, "text": "didn't"}, {"end": 1047.36, "start": 1046.4, "text": "necessarily"}, {"end": 1047.8, "start": 1047.36, "text": "translate"}, {"end": 1048.32, "start": 1047.8, "text": "directly"}, {"end": 1048.56, "start": 1048.32, "text": "to"}, {"end": 1048.56, "start": 1048.56, "text": "the"}, {"end": 1048.56, "start": 1048.56, "text": "data"}, {"end": 1049.08, "start": 1048.56, "text": "center"}, {"end": 1049.96, "start": 1049.08, "text": "environment."}], "text": " to optical signals and then back to electrical is a substantial portion of the cost. Hence, could we do all optical switching at one region of the network to save on cost? So the implications of this work as we looked at what it would take to scale out the network across the data center and then eventually across the wide area was that the protocols that we had to build the internet didn't necessarily translate directly to the data center environment."}, {"chunks": [{"end": 1050.16, "start": 1050.0, "text": "I"}, {"end": 1050.16, "start": 1050.16, "text": "think"}, {"end": 1050.36, "start": 1050.16, "text": "it's"}, {"end": 1050.84, "start": 1050.36, "text": "instructive"}, {"end": 1051.12, "start": 1050.84, "text": "to"}, {"end": 1051.52, "start": 1051.12, "text": "look"}, {"end": 1052.2, "start": 1051.52, "text": "at"}, {"end": 1052.76, "start": 1052.2, "text": "sort"}, {"end": 1052.76, "start": 1052.76, "text": "of"}, {"end": 1052.8, "start": 1052.76, "text": "the"}, {"end": 1053.36, "start": 1052.8, "text": "basis"}, {"end": 1053.64, "start": 1053.36, "text": "for"}, {"end": 1053.96, "start": 1053.64, "text": "networking."}, {"end": 1053.96, "start": 1053.96, "text": "And"}, {"end": 1054.0, "start": 1053.96, "text": "this"}, {"end": 1054.04, "start": 1054.0, "text": "would"}, {"end": 1054.16, "start": 1054.04, "text": "be"}, {"end": 1054.4, "start": 1054.16, "text": "a"}, {"end": 1054.8, "start": 1054.4, "text": "slide"}, {"end": 1055.36, "start": 1054.8, "text": "that"}, {"end": 1055.56, "start": 1055.36, "text": "I"}, {"end": 1055.72, "start": 1055.56, "text": "might"}, {"end": 1055.96, "start": 1055.72, "text": "include"}, {"end": 1056.36, "start": 1055.96, "text": "in"}, {"end": 1056.68, "start": 1056.36, "text": "all"}, {"end": 1056.68, "start": 1056.68, "text": "of"}, {"end": 1056.72, "start": 1056.68, "text": "the"}, {"end": 1056.84, "start": 1056.72, "text": "network"}, {"end": 1056.96, "start": 1056.84, "text": "courses"}, {"end": 1057.76, "start": 1056.96, "text": "that"}, {"end": 1058.32, "start": 1057.76, "text": "I"}, {"end": 1058.84, "start": 1058.32, "text": "had"}, {"end": 1058.92, "start": 1058.84, "text": "the"}, {"end": 1059.24, "start": 1058.92, "text": "privilege"}, {"end": 1059.24, "start": 1059.24, "text": "of"}, {"end": 1059.56, "start": 1059.24, "text": "teaching"}, {"end": 1059.68, "start": 1059.56, "text": "over"}, {"end": 1059.72, "start": 1059.68, "text": "the"}, {"end": 1060.32, "start": 1059.72, "text": "years."}, {"end": 1060.56, "start": 1060.32, "text": "What"}, {"end": 1060.84, "start": 1060.56, "text": "are"}, {"end": 1060.84, "start": 1060.84, "text": "the"}, {"end": 1061.48, "start": 1060.84, "text": "fundamental"}, {"end": 1061.92, "start": 1061.48, "text": "tenets"}, {"end": 1062.16, "start": 1061.92, "text": "of"}, {"end": 1062.16, "start": 1062.16, "text": "networking?"}, {"end": 1062.16, "start": 1062.16, "text": "I"}, {"end": 1062.68, "start": 1062.16, "text": "think"}, {"end": 1063.2, "start": 1062.68, "text": "it"}, {"end": 1063.6, "start": 1063.2, "text": "starts"}, {"end": 1063.64, "start": 1063.6, "text": "with"}, {"end": 1063.88, "start": 1063.64, "text": "best"}, {"end": 1064.48, "start": 1063.88, "text": "effort."}, {"end": 1064.76, "start": 1064.48, "text": "So"}, {"end": 1065.0, "start": 1064.76, "text": "no"}, {"end": 1065.52, "start": 1065.0, "text": "guarantees"}, {"end": 1065.76, "start": 1065.52, "text": "about"}, {"end": 1066.16, "start": 1065.76, "text": "whether"}, {"end": 1066.28, "start": 1066.16, "text": "or"}, {"end": 1066.52, "start": 1066.28, "text": "when"}, {"end": 1066.52, "start": 1066.52, "text": "data"}, {"end": 1067.0, "start": 1066.52, "text": "will"}, {"end": 1067.68, "start": 1067.0, "text": "arrive."}, {"end": 1067.88, "start": 1067.68, "text": "This"}, {"end": 1068.12, "start": 1067.88, "text": "actually"}, {"end": 1068.36, "start": 1068.12, "text": "made"}, {"end": 1068.68, "start": 1068.36, "text": "it"}, {"end": 1069.44, "start": 1068.68, "text": "very"}, {"end": 1069.64, "start": 1069.44, "text": "easy"}, {"end": 1069.76, "start": 1069.64, "text": "to"}, {"end": 1069.92, "start": 1069.76, "text": "join"}, {"end": 1070.08, "start": 1069.92, "text": "the"}, {"end": 1070.48, "start": 1070.08, "text": "internet"}, {"end": 1070.68, "start": 1070.48, "text": "and"}, {"end": 1071.04, "start": 1070.68, "text": "enabled"}, {"end": 1071.28, "start": 1071.04, "text": "that"}, {"end": 1072.0, "start": 1071.28, "text": "factor"}, {"end": 1072.36, "start": 1072.0, "text": "of"}, {"end": 1072.6, "start": 1072.36, "text": "5"}, {"end": 1072.88, "start": 1072.6, "text": "billion"}, {"end": 1073.2, "start": 1072.88, "text": "growth"}, {"end": 1073.44, "start": 1073.2, "text": "that"}, {"end": 1073.92, "start": 1073.44, "text": "we've"}, {"end": 1074.2, "start": 1073.92, "text": "really"}, {"end": 1074.68, "start": 1074.2, "text": "enjoyed"}, {"end": 1074.88, "start": 1074.68, "text": "over"}, {"end": 1074.88, "start": 1074.88, "text": "the"}, {"end": 1075.56, "start": 1074.88, "text": "past"}, {"end": 1075.64, "start": 1075.56, "text": "50"}, {"end": 1077.08, "start": 1075.64, "text": "years."}, {"end": 1077.6, "start": 1077.08, "text": "Another"}, {"end": 1078.28, "start": 1077.6, "text": "tenet"}, {"end": 1078.84, "start": 1078.28, "text": "is"}, {"end": 1079.24, "start": 1078.84, "text": "soft"}, {"end": 1079.96, "start": 1079.24, "text": "state."}], "text": " I think it's instructive to look at sort of the basis for networking. And this would be a slide that I might include in all of the network courses that I had the privilege of teaching over the years. What are the fundamental tenets of networking? I think it starts with best effort. So no guarantees about whether or when data will arrive. This actually made it very easy to join the internet and enabled that factor of 5 billion growth that we've really enjoyed over the past 50 years. Another tenet is soft state."}, {"chunks": [{"end": 1080.04, "start": 1080.0, "text": "Michael"}, {"end": 1080.2, "start": 1080.04, "text": "F."}, {"end": 1080.36, "start": 1080.2, "text": "And"}, {"end": 1080.48, "start": 1080.36, "text": "within"}, {"end": 1081.04, "start": 1080.48, "text": "network"}, {"end": 1081.32, "start": 1081.04, "text": "elements"}, {"end": 1081.48, "start": 1081.32, "text": "are"}, {"end": 1081.8, "start": 1081.48, "text": "useful"}, {"end": 1082.04, "start": 1081.8, "text": "for"}, {"end": 1082.92, "start": 1082.04, "text": "efficiency,"}, {"end": 1083.04, "start": 1082.92, "text": "but"}, {"end": 1083.32, "start": 1083.04, "text": "not"}, {"end": 1083.72, "start": 1083.32, "text": "required"}, {"end": 1083.72, "start": 1083.72, "text": "for"}, {"end": 1084.12, "start": 1083.72, "text": "correct"}, {"end": 1084.84, "start": 1084.12, "text": "operation."}, {"end": 1084.92, "start": 1084.84, "text": "What"}, {"end": 1085.12, "start": 1084.92, "text": "this"}, {"end": 1085.52, "start": 1085.12, "text": "means"}, {"end": 1085.64, "start": 1085.52, "text": "is"}, {"end": 1085.64, "start": 1085.64, "text": "that"}, {"end": 1085.64, "start": 1085.64, "text": "you"}, {"end": 1086.04, "start": 1085.64, "text": "can"}, {"end": 1086.2, "start": 1086.04, "text": "rebuild"}, {"end": 1086.48, "start": 1086.2, "text": "the"}, {"end": 1086.96, "start": 1086.48, "text": "necessary"}, {"end": 1087.4, "start": 1086.96, "text": "states"}, {"end": 1087.44, "start": 1087.4, "text": "to"}, {"end": 1087.76, "start": 1087.44, "text": "be"}, {"end": 1088.0, "start": 1087.76, "text": "able"}, {"end": 1088.16, "start": 1088.0, "text": "to"}, {"end": 1088.64, "start": 1088.16, "text": "carry"}, {"end": 1088.64, "start": 1088.64, "text": "out"}, {"end": 1088.68, "start": 1088.64, "text": "your"}, {"end": 1089.24, "start": 1088.68, "text": "function"}, {"end": 1089.44, "start": 1089.24, "text": "through"}, {"end": 1090.08, "start": 1089.44, "text": "pairwise"}, {"end": 1090.44, "start": 1090.08, "text": "exchange"}, {"end": 1090.48, "start": 1090.44, "text": "of"}, {"end": 1091.32, "start": 1090.48, "text": "messages"}, {"end": 1091.56, "start": 1091.32, "text": "with"}, {"end": 1091.56, "start": 1091.56, "text": "Michael"}, {"end": 1091.56, "start": 1091.56, "text": "F."}, {"end": 1092.0, "start": 1091.56, "text": "Your"}, {"end": 1092.0, "start": 1092.0, "text": "peers."}, {"end": 1092.08, "start": 1092.0, "text": "Michael"}, {"end": 1092.12, "start": 1092.08, "text": "F."}, {"end": 1092.36, "start": 1092.12, "text": "And"}, {"end": 1092.36, "start": 1092.36, "text": "of"}, {"end": 1093.8, "start": 1092.36, "text": "course"}, {"end": 1094.04, "start": 1093.8, "text": "the"}, {"end": 1095.32, "start": 1094.04, "text": "protocols"}, {"end": 1095.76, "start": 1095.32, "text": "are"}, {"end": 1095.96, "start": 1095.76, "text": "fully"}, {"end": 1096.84, "start": 1095.96, "text": "decentralized"}, {"end": 1097.48, "start": 1096.84, "text": "right"}, {"end": 1097.84, "start": 1097.48, "text": "whether"}, {"end": 1098.08, "start": 1097.84, "text": "it's"}, {"end": 1098.68, "start": 1098.08, "text": "BGP"}, {"end": 1099.08, "start": 1098.68, "text": "or"}, {"end": 1099.8, "start": 1099.08, "text": "SPF"}, {"end": 1100.52, "start": 1099.8, "text": "is"}, {"end": 1100.68, "start": 1100.52, "text": "is"}, {"end": 1100.8, "start": 1100.68, "text": "TCT"}, {"end": 1101.0, "start": 1100.8, "text": "IP"}, {"end": 1101.56, "start": 1101.0, "text": "DNS"}, {"end": 1101.6, "start": 1101.56, "text": "or"}, {"end": 1101.68, "start": 1101.6, "text": "others."}, {"end": 1102.32, "start": 1101.68, "text": "Michael"}, {"end": 1102.64, "start": 1102.32, "text": "F."}, {"end": 1103.04, "start": 1102.64, "text": "And"}, {"end": 1103.24, "start": 1103.04, "text": "with"}, {"end": 1103.76, "start": 1103.24, "text": "this"}, {"end": 1104.08, "start": 1103.76, "text": "once"}, {"end": 1104.4, "start": 1104.08, "text": "again"}, {"end": 1104.64, "start": 1104.4, "text": "means"}, {"end": 1104.92, "start": 1104.64, "text": "is"}, {"end": 1105.24, "start": 1104.92, "text": "that"}, {"end": 1105.6, "start": 1105.24, "text": "we"}, {"end": 1105.6, "start": 1105.6, "text": "have"}, {"end": 1105.8, "start": 1105.6, "text": "the"}, {"end": 1106.16, "start": 1105.8, "text": "ability"}, {"end": 1106.48, "start": 1106.16, "text": "to"}, {"end": 1106.72, "start": 1106.48, "text": "not"}, {"end": 1107.16, "start": 1106.72, "text": "rely"}, {"end": 1107.44, "start": 1107.16, "text": "on"}, {"end": 1107.44, "start": 1107.44, "text": "any"}, {"end": 1107.92, "start": 1107.44, "text": "central"}, {"end": 1108.24, "start": 1107.92, "text": "entity"}, {"end": 1108.92, "start": 1108.24, "text": "to"}, {"end": 1109.28, "start": 1108.92, "text": "control"}, {"end": 1109.44, "start": 1109.28, "text": "the"}, {"end": 1109.96, "start": 1109.44, "text": "evolution."}], "text": " Michael F. And within network elements are useful for efficiency, but not required for correct operation. What this means is that you can rebuild the necessary states to be able to carry out your function through pairwise exchange of messages with Michael F. Your peers. Michael F. And of course the protocols are fully decentralized right whether it's BGP or SPF is is TCT IP DNS or others. Michael F. And with this once again means is that we have the ability to not rely on any central entity to control the evolution."}, {"chunks": [{"end": 1110.12, "start": 1110.0, "text": "or"}, {"end": 1110.44, "start": 1110.12, "text": "growth"}, {"end": 1110.56, "start": 1110.44, "text": "of"}, {"end": 1110.68, "start": 1110.56, "text": "the"}, {"end": 1111.16, "start": 1110.68, "text": "internet,"}, {"end": 1111.48, "start": 1111.16, "text": "once"}, {"end": 1111.68, "start": 1111.48, "text": "again"}, {"end": 1112.08, "start": 1111.68, "text": "fueling"}, {"end": 1112.24, "start": 1112.08, "text": "its"}, {"end": 1113.12, "start": 1112.24, "text": "exponential"}, {"end": 1113.32, "start": 1113.12, "text": "growth"}, {"end": 1113.6, "start": 1113.32, "text": "rate."}, {"end": 1115.6, "start": 1113.6, "text": "But"}, {"end": 1116.04, "start": 1115.6, "text": "what"}, {"end": 1116.24, "start": 1116.04, "text": "this"}, {"end": 1116.68, "start": 1116.24, "text": "leaves"}, {"end": 1116.84, "start": 1116.68, "text": "us"}, {"end": 1117.0, "start": 1116.84, "text": "with"}, {"end": 1117.44, "start": 1117.0, "text": "is"}, {"end": 1117.48, "start": 1117.44, "text": "individual"}, {"end": 1117.88, "start": 1117.48, "text": "end"}, {"end": 1118.4, "start": 1117.88, "text": "hosts"}, {"end": 1118.88, "start": 1118.4, "text": "managing"}, {"end": 1119.0, "start": 1118.88, "text": "the"}, {"end": 1119.28, "start": 1119.0, "text": "global"}, {"end": 1119.64, "start": 1119.28, "text": "network"}, {"end": 1119.8, "start": 1119.64, "text": "by"}, {"end": 1120.56, "start": 1119.8, "text": "constantly"}, {"end": 1121.28, "start": 1120.56, "text": "constructing,"}, {"end": 1122.24, "start": 1121.28, "text": "reconstructing,"}, {"end": 1122.48, "start": 1122.24, "text": "and"}, {"end": 1122.64, "start": 1122.48, "text": "then"}, {"end": 1123.44, "start": 1122.64, "text": "deconstructing"}, {"end": 1123.72, "start": 1123.44, "text": "global"}, {"end": 1124.24, "start": 1123.72, "text": "state"}, {"end": 1124.4, "start": 1124.24, "text": "through"}, {"end": 1124.76, "start": 1124.4, "text": "carefully"}, {"end": 1125.2, "start": 1124.76, "text": "constructed"}, {"end": 1126.16, "start": 1125.2, "text": "probes."}, {"end": 1126.64, "start": 1126.16, "text": "The"}, {"end": 1127.08, "start": 1126.64, "text": "resulting"}, {"end": 1128.28, "start": 1127.08, "text": "protocols"}, {"end": 1128.64, "start": 1128.28, "text": "are"}, {"end": 1128.8, "start": 1128.64, "text": "beautiful"}, {"end": 1129.08, "start": 1128.8, "text": "and"}, {"end": 1129.44, "start": 1129.08, "text": "actually"}, {"end": 1129.68, "start": 1129.44, "text": "some"}, {"end": 1129.68, "start": 1129.68, "text": "of"}, {"end": 1129.92, "start": 1129.68, "text": "the"}, {"end": 1130.08, "start": 1129.92, "text": "main"}, {"end": 1130.32, "start": 1130.08, "text": "reason"}, {"end": 1130.64, "start": 1130.32, "text": "that"}, {"end": 1130.68, "start": 1130.64, "text": "I"}, {"end": 1130.96, "start": 1130.68, "text": "was"}, {"end": 1131.2, "start": 1130.96, "text": "drawn"}, {"end": 1131.24, "start": 1131.2, "text": "to"}, {"end": 1131.32, "start": 1131.24, "text": "networking"}, {"end": 1131.32, "start": 1131.32, "text": "in"}, {"end": 1131.56, "start": 1131.32, "text": "the"}, {"end": 1132.12, "start": 1131.56, "text": "first"}, {"end": 1134.36, "start": 1132.12, "text": "place."}, {"end": 1134.52, "start": 1134.36, "text": "On"}, {"end": 1134.8, "start": 1134.52, "text": "the"}, {"end": 1135.4, "start": 1134.8, "text": "other"}, {"end": 1135.96, "start": 1135.4, "text": "hand,"}, {"end": 1136.32, "start": 1135.96, "text": "for"}, {"end": 1136.6, "start": 1136.32, "text": "certain"}, {"end": 1137.04, "start": 1136.6, "text": "settings"}, {"end": 1137.32, "start": 1137.04, "text": "where"}, {"end": 1137.48, "start": 1137.32, "text": "you"}, {"end": 1137.64, "start": 1137.48, "text": "are"}, {"end": 1137.8, "start": 1137.64, "text": "running"}, {"end": 1137.8, "start": 1137.8, "text": "within"}, {"end": 1138.2, "start": 1137.8, "text": "a"}, {"end": 1138.8, "start": 1138.2, "text": "single"}, {"end": 1139.04, "start": 1138.8, "text": "autonomous"}, {"end": 1139.12, "start": 1139.04, "text": "system"}, {"end": 1139.44, "start": 1139.12, "text": "and"}, {"end": 1139.68, "start": 1139.44, "text": "where"}, {"end": 1139.96, "start": 1139.68, "text": "the"}], "text": " or growth of the internet, once again fueling its exponential growth rate. But what this leaves us with is individual end hosts managing the global network by constantly constructing, reconstructing, and then deconstructing global state through carefully constructed probes. The resulting protocols are beautiful and actually some of the main reason that I was drawn to networking in the first place. On the other hand, for certain settings where you are running within a single autonomous system and where the"}, {"chunks": [{"end": 1140.24, "start": 1140.0, "text": "As"}, {"end": 1140.76, "start": 1140.24, "text": "levels"}, {"end": 1141.0, "start": 1140.76, "text": "of"}, {"end": 1141.36, "start": 1141.0, "text": "availability"}, {"end": 1141.56, "start": 1141.36, "text": "and"}, {"end": 1141.6, "start": 1141.56, "text": "the"}, {"end": 1142.16, "start": 1141.6, "text": "highest"}, {"end": 1142.52, "start": 1142.16, "text": "levels"}, {"end": 1142.68, "start": 1142.52, "text": "of"}, {"end": 1143.4, "start": 1142.68, "text": "predictability"}, {"end": 1143.44, "start": 1143.4, "text": "are"}, {"end": 1144.04, "start": 1143.44, "text": "required,"}, {"end": 1144.64, "start": 1144.04, "text": "where"}, {"end": 1144.96, "start": 1144.64, "text": "best"}, {"end": 1145.32, "start": 1144.96, "text": "effort"}, {"end": 1145.52, "start": 1145.32, "text": "might"}, {"end": 1145.56, "start": 1145.52, "text": "not"}, {"end": 1145.8, "start": 1145.56, "text": "be"}, {"end": 1146.44, "start": 1145.8, "text": "the"}, {"end": 1146.92, "start": 1146.44, "text": "rule."}, {"end": 1146.92, "start": 1146.92, "text": "We"}, {"end": 1147.12, "start": 1146.92, "text": "then"}, {"end": 1147.6, "start": 1147.12, "text": "considered"}, {"end": 1148.08, "start": 1147.6, "text": "what"}, {"end": 1148.24, "start": 1148.08, "text": "it"}, {"end": 1148.24, "start": 1148.24, "text": "might"}, {"end": 1148.24, "start": 1148.24, "text": "take"}, {"end": 1148.68, "start": 1148.24, "text": "to"}, {"end": 1148.8, "start": 1148.68, "text": "leverage"}, {"end": 1149.64, "start": 1148.8, "text": "software"}, {"end": 1149.88, "start": 1149.64, "text": "fine"}, {"end": 1150.56, "start": 1149.88, "text": "networking."}, {"end": 1150.72, "start": 1150.56, "text": "And"}, {"end": 1150.8, "start": 1150.72, "text": "the"}, {"end": 1151.24, "start": 1150.8, "text": "question"}, {"end": 1151.48, "start": 1151.24, "text": "here"}, {"end": 1152.16, "start": 1151.48, "text": "was"}, {"end": 1152.84, "start": 1152.16, "text": "how"}, {"end": 1152.84, "start": 1152.84, "text": "to"}, {"end": 1153.48, "start": 1152.84, "text": "leverage"}, {"end": 1153.64, "start": 1153.48, "text": "at"}, {"end": 1153.96, "start": 1153.64, "text": "least"}, {"end": 1154.44, "start": 1153.96, "text": "logically"}, {"end": 1155.28, "start": 1154.44, "text": "centralized"}, {"end": 1155.68, "start": 1155.28, "text": "state"}, {"end": 1156.04, "start": 1155.68, "text": "within"}, {"end": 1156.16, "start": 1156.04, "text": "a"}, {"end": 1156.36, "start": 1156.16, "text": "single"}, {"end": 1156.92, "start": 1156.36, "text": "autonomous"}, {"end": 1157.08, "start": 1156.92, "text": "system"}, {"end": 1157.52, "start": 1157.08, "text": "to"}, {"end": 1157.68, "start": 1157.52, "text": "build"}, {"end": 1158.12, "start": 1157.68, "text": "out"}, {"end": 1159.12, "start": 1158.12, "text": "your"}, {"end": 1159.2, "start": 1159.12, "text": "network."}, {"end": 1159.24, "start": 1159.2, "text": "And"}, {"end": 1159.44, "start": 1159.24, "text": "what"}, {"end": 1159.76, "start": 1159.44, "text": "I'll"}, {"end": 1160.28, "start": 1159.76, "text": "argue"}, {"end": 1160.96, "start": 1160.28, "text": "here"}, {"end": 1161.68, "start": 1160.96, "text": "simplistically"}, {"end": 1161.84, "start": 1161.68, "text": "in"}, {"end": 1162.08, "start": 1161.84, "text": "the"}, {"end": 1162.6, "start": 1162.08, "text": "interest"}, {"end": 1162.88, "start": 1162.6, "text": "of"}, {"end": 1163.08, "start": 1162.88, "text": "time"}, {"end": 1163.28, "start": 1163.08, "text": "is"}, {"end": 1163.52, "start": 1163.28, "text": "that"}, {"end": 1163.76, "start": 1163.52, "text": "the"}, {"end": 1164.48, "start": 1163.76, "text": "protocols"}, {"end": 1164.72, "start": 1164.48, "text": "that"}, {"end": 1165.04, "start": 1164.72, "text": "can"}, {"end": 1165.24, "start": 1165.04, "text": "leverage"}, {"end": 1165.64, "start": 1165.24, "text": "logically"}, {"end": 1166.16, "start": 1165.64, "text": "centralized"}, {"end": 1166.76, "start": 1166.16, "text": "state"}, {"end": 1167.08, "start": 1166.76, "text": "are"}, {"end": 1167.08, "start": 1167.08, "text": "going"}, {"end": 1167.24, "start": 1167.08, "text": "to"}, {"end": 1167.4, "start": 1167.24, "text": "be"}, {"end": 1168.28, "start": 1167.4, "text": "simpler"}, {"end": 1168.36, "start": 1168.28, "text": "and"}, {"end": 1168.64, "start": 1168.36, "text": "more"}, {"end": 1169.24, "start": 1168.64, "text": "efficient,"}, {"end": 1169.24, "start": 1169.24, "text": "easier"}, {"end": 1169.24, "start": 1169.24, "text": "to"}, {"end": 1169.68, "start": 1169.24, "text": "get"}, {"end": 1169.96, "start": 1169.68, "text": "right"}], "text": " As levels of availability and the highest levels of predictability are required, where best effort might not be the rule. We then considered what it might take to leverage software fine networking. And the question here was how to leverage at least logically centralized state within a single autonomous system to build out your network. And what I'll argue here simplistically in the interest of time is that the protocols that can leverage logically centralized state are going to be simpler and more efficient, easier to get right"}, {"chunks": [{"end": 1170.12, "start": 1170.0, "text": "easier"}, {"end": 1170.2, "start": 1170.12, "text": "to"}, {"end": 1170.84, "start": 1170.2, "text": "maintain"}, {"end": 1171.32, "start": 1170.84, "text": "over"}, {"end": 1171.72, "start": 1171.32, "text": "time."}, {"end": 1172.0, "start": 1171.72, "text": "So"}, {"end": 1172.12, "start": 1172.0, "text": "you"}, {"end": 1173.4, "start": 1172.12, "text": "can"}, {"end": 1174.0, "start": 1173.4, "text": "imagine"}, {"end": 1174.36, "start": 1174.0, "text": "that"}, {"end": 1174.52, "start": 1174.36, "text": "in"}, {"end": 1174.6, "start": 1174.52, "text": "a"}, {"end": 1175.16, "start": 1174.6, "text": "distributed"}, {"end": 1175.92, "start": 1175.16, "text": "system"}, {"end": 1176.28, "start": 1175.92, "text": "for"}, {"end": 1176.4, "start": 1176.28, "text": "you"}, {"end": 1176.4, "start": 1176.4, "text": "to"}, {"end": 1176.96, "start": 1176.4, "text": "exchange"}, {"end": 1177.44, "start": 1176.96, "text": "states,"}, {"end": 1177.8, "start": 1177.44, "text": "you're"}, {"end": 1178.04, "start": 1177.8, "text": "going"}, {"end": 1178.04, "start": 1178.04, "text": "to"}, {"end": 1178.4, "start": 1178.04, "text": "need"}, {"end": 1179.0, "start": 1178.4, "text": "order"}, {"end": 1179.32, "start": 1179.0, "text": "and"}, {"end": 1179.4, "start": 1179.32, "text": "log"}, {"end": 1179.56, "start": 1179.4, "text": "in"}, {"end": 1180.6, "start": 1179.56, "text": "communication"}, {"end": 1180.88, "start": 1180.6, "text": "and"}, {"end": 1181.08, "start": 1180.88, "text": "order"}, {"end": 1181.36, "start": 1181.08, "text": "log"}, {"end": 1181.52, "start": 1181.36, "text": "in"}, {"end": 1182.24, "start": 1181.52, "text": "steps"}, {"end": 1182.28, "start": 1182.24, "text": "to"}, {"end": 1182.44, "start": 1182.28, "text": "get"}, {"end": 1182.48, "start": 1182.44, "text": "the"}, {"end": 1183.44, "start": 1182.48, "text": "convergence."}, {"end": 1184.12, "start": 1183.44, "text": "Whereas"}, {"end": 1184.2, "start": 1184.12, "text": "in"}, {"end": 1184.36, "start": 1184.2, "text": "a"}, {"end": 1185.12, "start": 1184.36, "text": "centralized"}, {"end": 1185.72, "start": 1185.12, "text": "system,"}, {"end": 1186.0, "start": 1185.72, "text": "again,"}, {"end": 1186.04, "start": 1186.0, "text": "in"}, {"end": 1186.08, "start": 1186.04, "text": "the"}, {"end": 1186.24, "start": 1186.08, "text": "best"}, {"end": 1186.6, "start": 1186.24, "text": "case,"}, {"end": 1186.84, "start": 1186.6, "text": "you're"}, {"end": 1187.0, "start": 1186.84, "text": "going"}, {"end": 1187.0, "start": 1187.0, "text": "to"}, {"end": 1187.08, "start": 1187.0, "text": "need"}, {"end": 1187.64, "start": 1187.08, "text": "order"}, {"end": 1187.8, "start": 1187.64, "text": "and"}, {"end": 1189.04, "start": 1187.8, "text": "communication"}, {"end": 1189.36, "start": 1189.04, "text": "and"}, {"end": 1189.96, "start": 1189.36, "text": "constant"}, {"end": 1190.24, "start": 1189.96, "text": "time"}, {"end": 1190.28, "start": 1190.24, "text": "to"}, {"end": 1190.32, "start": 1190.28, "text": "get"}, {"end": 1191.08, "start": 1190.32, "text": "to"}, {"end": 1191.32, "start": 1191.08, "text": "convergence."}, {"end": 1192.12, "start": 1191.32, "text": "These"}, {"end": 1192.44, "start": 1192.12, "text": "are"}, {"end": 1192.48, "start": 1192.44, "text": "all"}, {"end": 1193.12, "start": 1192.48, "text": "idealized"}, {"end": 1193.84, "start": 1193.12, "text": "and"}, {"end": 1193.84, "start": 1193.84, "text": "all"}, {"end": 1194.24, "start": 1193.84, "text": "cartoons,"}, {"end": 1194.48, "start": 1194.24, "text": "but"}, {"end": 1195.12, "start": 1194.48, "text": "essentially"}, {"end": 1195.12, "start": 1195.12, "text": "it"}, {"end": 1195.4, "start": 1195.12, "text": "argues"}, {"end": 1195.8, "start": 1195.4, "text": "for"}, {"end": 1196.56, "start": 1195.8, "text": "simpler,"}, {"end": 1197.08, "start": 1196.56, "text": "perhaps"}, {"end": 1197.48, "start": 1197.08, "text": "faster"}, {"end": 1198.24, "start": 1197.48, "text": "protocols"}, {"end": 1198.24, "start": 1198.24, "text": "if"}, {"end": 1198.24, "start": 1198.24, "text": "you"}, {"end": 1198.24, "start": 1198.24, "text": "are"}, {"end": 1198.24, "start": 1198.24, "text": "able"}, {"end": 1198.32, "start": 1198.24, "text": "to"}, {"end": 1199.0, "start": 1198.32, "text": "leverage"}, {"end": 1199.44, "start": 1199.0, "text": "centralized"}, {"end": 1199.96, "start": 1199.44, "text": "states."}], "text": " easier to maintain over time. So you can imagine that in a distributed system for you to exchange states, you're going to need order and log in communication and order log in steps to get the convergence. Whereas in a centralized system, again, in the best case, you're going to need order and communication and constant time to get to convergence. These are all idealized and all cartoons, but essentially it argues for simpler, perhaps faster protocols if you are able to leverage centralized states."}, {"chunks": [{"end": 1200.16, "start": 1200.0, "text": "And"}, {"end": 1200.16, "start": 1200.16, "text": "in"}, {"end": 1200.76, "start": 1200.16, "text": "the"}, {"end": 1201.52, "start": 1200.76, "text": "interim,"}, {"end": 1201.6, "start": 1201.52, "text": "in"}, {"end": 1201.76, "start": 1201.6, "text": "the"}, {"end": 1202.16, "start": 1201.76, "text": "intervening"}, {"end": 1202.4, "start": 1202.16, "text": "50"}, {"end": 1203.16, "start": 1202.4, "text": "years,"}, {"end": 1203.52, "start": 1203.16, "text": "our"}, {"end": 1203.56, "start": 1203.52, "text": "peers"}, {"end": 1204.28, "start": 1203.56, "text": "have"}, {"end": 1204.76, "start": 1204.28, "text": "helped"}, {"end": 1204.8, "start": 1204.76, "text": "us"}, {"end": 1204.8, "start": 1204.8, "text": "develop"}, {"end": 1205.16, "start": 1204.8, "text": "deep"}, {"end": 1205.88, "start": 1205.16, "text": "understanding"}, {"end": 1206.44, "start": 1205.88, "text": "of"}, {"end": 1207.32, "start": 1206.44, "text": "scalable"}, {"end": 1207.56, "start": 1207.32, "text": "fault"}, {"end": 1207.96, "start": 1207.56, "text": "tolerant"}, {"end": 1208.36, "start": 1207.96, "text": "design"}, {"end": 1208.48, "start": 1208.36, "text": "for"}, {"end": 1208.6, "start": 1208.48, "text": "these"}, {"end": 1208.96, "start": 1208.6, "text": "logically"}, {"end": 1209.64, "start": 1208.96, "text": "centralized"}, {"end": 1210.6, "start": 1209.64, "text": "services."}, {"end": 1210.96, "start": 1210.6, "text": "Now,"}, {"end": 1211.04, "start": 1210.96, "text": "it's"}, {"end": 1211.04, "start": 1211.04, "text": "not"}, {"end": 1211.2, "start": 1211.04, "text": "one"}, {"end": 1211.64, "start": 1211.2, "text": "answer"}, {"end": 1211.84, "start": 1211.64, "text": "or"}, {"end": 1212.16, "start": 1211.84, "text": "the"}, {"end": 1212.6, "start": 1212.16, "text": "other,"}, {"end": 1212.8, "start": 1212.6, "text": "as"}, {"end": 1212.84, "start": 1212.8, "text": "you're"}, {"end": 1213.24, "start": 1212.84, "text": "not"}, {"end": 1213.44, "start": 1213.24, "text": "going"}, {"end": 1213.64, "start": 1213.44, "text": "to"}, {"end": 1213.96, "start": 1213.64, "text": "go"}, {"end": 1214.0, "start": 1213.96, "text": "with"}, {"end": 1214.28, "start": 1214.0, "text": "full"}, {"end": 1215.16, "start": 1214.28, "text": "decentralization"}, {"end": 1215.36, "start": 1215.16, "text": "or"}, {"end": 1215.56, "start": 1215.36, "text": "full"}, {"end": 1216.36, "start": 1215.56, "text": "centralization."}, {"end": 1216.48, "start": 1216.36, "text": "But"}, {"end": 1216.8, "start": 1216.48, "text": "the"}, {"end": 1217.28, "start": 1216.8, "text": "question"}, {"end": 1217.44, "start": 1217.28, "text": "is,"}, {"end": 1217.52, "start": 1217.44, "text": "can"}, {"end": 1217.52, "start": 1217.52, "text": "you"}, {"end": 1217.64, "start": 1217.52, "text": "turn"}, {"end": 1218.04, "start": 1217.64, "text": "the"}, {"end": 1218.2, "start": 1218.04, "text": "dial"}, {"end": 1218.8, "start": 1218.2, "text": "dynamically"}, {"end": 1218.88, "start": 1218.8, "text": "for"}, {"end": 1219.28, "start": 1218.88, "text": "what"}, {"end": 1219.44, "start": 1219.28, "text": "you"}, {"end": 1219.48, "start": 1219.44, "text": "need"}, {"end": 1219.68, "start": 1219.48, "text": "in"}, {"end": 1219.76, "start": 1219.68, "text": "a"}, {"end": 1220.12, "start": 1219.76, "text": "particular"}, {"end": 1220.6, "start": 1220.12, "text": "protocol"}, {"end": 1220.92, "start": 1220.6, "text": "deployment"}, {"end": 1222.56, "start": 1220.92, "text": "scenario?"}, {"end": 1223.0, "start": 1222.56, "text": "At"}, {"end": 1223.6, "start": 1223.0, "text": "Google,"}, {"end": 1224.04, "start": 1223.6, "text": "we've"}, {"end": 1224.16, "start": 1224.04, "text": "been"}, {"end": 1224.44, "start": 1224.16, "text": "able"}, {"end": 1225.04, "start": 1224.44, "text": "to"}, {"end": 1225.48, "start": 1225.04, "text": "apply"}, {"end": 1225.68, "start": 1225.48, "text": "these"}, {"end": 1226.12, "start": 1225.68, "text": "ideas"}, {"end": 1226.48, "start": 1226.12, "text": "to"}, {"end": 1226.92, "start": 1226.48, "text": "essentially"}, {"end": 1227.12, "start": 1226.92, "text": "all"}, {"end": 1227.8, "start": 1227.12, "text": "aspects"}, {"end": 1228.0, "start": 1227.8, "text": "of"}, {"end": 1228.04, "start": 1228.0, "text": "our"}, {"end": 1228.12, "start": 1228.04, "text": "network,"}, {"end": 1229.08, "start": 1228.12, "text": "starting"}, {"end": 1229.2, "start": 1229.08, "text": "with"}, {"end": 1229.68, "start": 1229.2, "text": "B4,"}, {"end": 1229.96, "start": 1229.68, "text": "our"}], "text": " And in the interim, in the intervening 50 years, our peers have helped us develop deep understanding of scalable fault tolerant design for these logically centralized services. Now, it's not one answer or the other, as you're not going to go with full decentralization or full centralization. But the question is, can you turn the dial dynamically for what you need in a particular protocol deployment scenario? At Google, we've been able to apply these ideas to essentially all aspects of our network, starting with B4, our"}, {"chunks": [{"end": 1230.36, "start": 1230.0, "text": "Wide"}, {"end": 1230.64, "start": 1230.36, "text": "Area"}, {"end": 1231.2, "start": 1230.64, "text": "Network,"}, {"end": 1231.88, "start": 1231.2, "text": "Interconnect"}, {"end": 1232.2, "start": 1231.88, "text": "to"}, {"end": 1232.56, "start": 1232.2, "text": "Jupyter,"}, {"end": 1232.72, "start": 1232.56, "text": "our"}, {"end": 1233.28, "start": 1232.72, "text": "data"}, {"end": 1233.32, "start": 1233.28, "text": "center"}, {"end": 1233.48, "start": 1233.32, "text": "networking"}, {"end": 1234.48, "start": 1233.48, "text": "environments,"}, {"end": 1235.04, "start": 1234.48, "text": "Andromeda,"}, {"end": 1235.08, "start": 1235.04, "text": "which"}, {"end": 1235.08, "start": 1235.08, "text": "is"}, {"end": 1235.12, "start": 1235.08, "text": "our"}, {"end": 1235.72, "start": 1235.12, "text": "network"}, {"end": 1236.24, "start": 1235.72, "text": "virtualization"}, {"end": 1236.92, "start": 1236.24, "text": "stack,"}, {"end": 1237.24, "start": 1236.92, "text": "and"}, {"end": 1237.96, "start": 1237.24, "text": "Espresso,"}, {"end": 1238.68, "start": 1237.96, "text": "which"}, {"end": 1239.12, "start": 1238.68, "text": "is"}, {"end": 1239.52, "start": 1239.12, "text": "how"}, {"end": 1239.8, "start": 1239.52, "text": "we"}, {"end": 1239.8, "start": 1239.8, "text": "do"}, {"end": 1240.0, "start": 1239.8, "text": "curing"}, {"end": 1240.08, "start": 1240.0, "text": "with"}, {"end": 1240.28, "start": 1240.08, "text": "the"}, {"end": 1240.4, "start": 1240.28, "text": "public"}, {"end": 1241.52, "start": 1240.4, "text": "internet."}, {"end": 1242.0, "start": 1241.52, "text": "Underlying"}, {"end": 1242.24, "start": 1242.0, "text": "all"}, {"end": 1242.8, "start": 1242.24, "text": "of"}, {"end": 1243.16, "start": 1242.8, "text": "these"}, {"end": 1243.56, "start": 1243.16, "text": "are"}, {"end": 1243.8, "start": 1243.56, "text": "the"}, {"end": 1244.0, "start": 1243.8, "text": "key"}, {"end": 1244.96, "start": 1244.0, "text": "considerations"}, {"end": 1245.2, "start": 1244.96, "text": "around"}, {"end": 1245.64, "start": 1245.2, "text": "availability,"}, {"end": 1246.16, "start": 1245.64, "text": "security,"}, {"end": 1246.2, "start": 1246.16, "text": "and"}, {"end": 1246.84, "start": 1246.2, "text": "isolation"}, {"end": 1247.52, "start": 1246.84, "text": "in"}, {"end": 1247.68, "start": 1247.52, "text": "our"}, {"end": 1248.4, "start": 1247.68, "text": "networks"}, {"end": 1249.0, "start": 1248.4, "text": "that"}, {"end": 1249.08, "start": 1249.0, "text": "allow"}, {"end": 1249.2, "start": 1249.08, "text": "us"}, {"end": 1249.52, "start": 1249.2, "text": "to"}, {"end": 1249.56, "start": 1249.52, "text": "move"}, {"end": 1249.56, "start": 1249.56, "text": "to"}, {"end": 1249.56, "start": 1249.56, "text": "these"}, {"end": 1249.6, "start": 1249.56, "text": "fifth"}, {"end": 1249.6, "start": 1249.6, "text": "epoch"}, {"end": 1250.48, "start": 1249.6, "text": "distributed"}, {"end": 1251.12, "start": 1250.48, "text": "systems"}, {"end": 1251.4, "start": 1251.12, "text": "that"}, {"end": 1251.56, "start": 1251.4, "text": "are"}, {"end": 1251.68, "start": 1251.56, "text": "now"}, {"end": 1251.96, "start": 1251.68, "text": "starting"}, {"end": 1252.04, "start": 1251.96, "text": "to"}, {"end": 1254.04, "start": 1252.04, "text": "rise."}, {"end": 1254.52, "start": 1254.04, "text": "So"}, {"end": 1254.84, "start": 1254.52, "text": "briefly,"}, {"end": 1255.2, "start": 1254.84, "text": "I'll"}, {"end": 1255.68, "start": 1255.2, "text": "go"}, {"end": 1255.88, "start": 1255.68, "text": "through"}, {"end": 1256.28, "start": 1255.88, "text": "each"}, {"end": 1256.52, "start": 1256.28, "text": "of"}, {"end": 1256.68, "start": 1256.52, "text": "these."}, {"end": 1257.08, "start": 1256.68, "text": "B4"}, {"end": 1257.08, "start": 1257.08, "text": "is"}, {"end": 1257.4, "start": 1257.08, "text": "Google's"}, {"end": 1258.28, "start": 1257.4, "text": "software-defined"}, {"end": 1258.48, "start": 1258.28, "text": "WAN"}, {"end": 1259.0, "start": 1258.48, "text": "for"}, {"end": 1259.32, "start": 1259.0, "text": "our"}, {"end": 1259.68, "start": 1259.32, "text": "data"}, {"end": 1259.96, "start": 1259.68, "text": "centers."}], "text": " Wide Area Network, Interconnect to Jupyter, our data center networking environments, Andromeda, which is our network virtualization stack, and Espresso, which is how we do curing with the public internet. Underlying all of these are the key considerations around availability, security, and isolation in our networks that allow us to move to these fifth epoch distributed systems that are now starting to rise. So briefly, I'll go through each of these. B4 is Google's software-defined WAN for our data centers."}, {"chunks": [{"end": 1260.68, "start": 1260.0, "text": "So"}, {"end": 1261.64, "start": 1260.68, "text": "interestingly,"}, {"end": 1262.08, "start": 1261.64, "text": "B4"}, {"end": 1262.56, "start": 1262.08, "text": "is"}, {"end": 1263.16, "start": 1262.56, "text": "now"}, {"end": 1263.56, "start": 1263.16, "text": "bigger"}, {"end": 1263.68, "start": 1263.56, "text": "and"}, {"end": 1263.96, "start": 1263.68, "text": "growing"}, {"end": 1264.52, "start": 1263.96, "text": "faster"}, {"end": 1264.92, "start": 1264.52, "text": "than"}, {"end": 1265.32, "start": 1264.92, "text": "our"}, {"end": 1265.96, "start": 1265.32, "text": "public"}, {"end": 1265.96, "start": 1265.96, "text": "network."}, {"end": 1266.32, "start": 1265.96, "text": "That"}, {"end": 1266.72, "start": 1266.32, "text": "is"}, {"end": 1266.92, "start": 1266.72, "text": "our"}, {"end": 1267.32, "start": 1266.92, "text": "connectivity"}, {"end": 1267.64, "start": 1267.32, "text": "to"}, {"end": 1268.08, "start": 1267.64, "text": "the"}, {"end": 1268.48, "start": 1268.08, "text": "rest"}, {"end": 1268.6, "start": 1268.48, "text": "of"}, {"end": 1268.6, "start": 1268.6, "text": "the"}, {"end": 1268.92, "start": 1268.6, "text": "internet"}, {"end": 1269.36, "start": 1268.92, "text": "while"}, {"end": 1269.88, "start": 1269.36, "text": "growing"}, {"end": 1270.12, "start": 1269.88, "text": "very,"}, {"end": 1270.12, "start": 1270.12, "text": "very"}, {"end": 1270.16, "start": 1270.12, "text": "quickly"}, {"end": 1270.28, "start": 1270.16, "text": "is"}, {"end": 1270.36, "start": 1270.28, "text": "not"}, {"end": 1270.76, "start": 1270.36, "text": "growing"}, {"end": 1271.04, "start": 1270.76, "text": "as"}, {"end": 1271.44, "start": 1271.04, "text": "fast"}, {"end": 1271.8, "start": 1271.44, "text": "as"}, {"end": 1272.12, "start": 1271.8, "text": "our"}, {"end": 1272.52, "start": 1272.12, "text": "computer"}, {"end": 1272.56, "start": 1272.52, "text": "to"}, {"end": 1273.04, "start": 1272.56, "text": "computer"}, {"end": 1273.52, "start": 1273.04, "text": "communication."}, {"end": 1273.56, "start": 1273.52, "text": "Over"}, {"end": 1274.28, "start": 1273.56, "text": "the"}, {"end": 1275.08, "start": 1274.28, "text": "life"}, {"end": 1275.6, "start": 1275.08, "text": "of"}, {"end": 1275.92, "start": 1275.6, "text": "B4,"}, {"end": 1276.16, "start": 1275.92, "text": "it"}, {"end": 1276.72, "start": 1276.16, "text": "went"}, {"end": 1277.08, "start": 1276.72, "text": "from"}, {"end": 1277.64, "start": 1277.08, "text": "a"}, {"end": 1278.36, "start": 1277.64, "text": "non-business"}, {"end": 1278.64, "start": 1278.36, "text": "critical"}, {"end": 1279.44, "start": 1278.64, "text": "copy"}, {"end": 1279.96, "start": 1279.44, "text": "network"}, {"end": 1280.36, "start": 1279.96, "text": "that"}, {"end": 1280.72, "start": 1280.36, "text": "promised"}, {"end": 1280.88, "start": 1280.72, "text": "very"}, {"end": 1281.2, "start": 1280.88, "text": "little"}, {"end": 1281.84, "start": 1281.2, "text": "availability,"}, {"end": 1282.16, "start": 1281.84, "text": "but"}, {"end": 1282.44, "start": 1282.16, "text": "cheap"}, {"end": 1282.84, "start": 1282.44, "text": "bandwidth"}, {"end": 1283.16, "start": 1282.84, "text": "to"}, {"end": 1283.52, "start": 1283.16, "text": "something"}, {"end": 1283.96, "start": 1283.52, "text": "that"}, {"end": 1284.32, "start": 1283.96, "text": "now"}, {"end": 1284.56, "start": 1284.32, "text": "actually"}, {"end": 1285.0, "start": 1284.56, "text": "has,"}, {"end": 1285.16, "start": 1285.0, "text": "depending"}, {"end": 1285.32, "start": 1285.16, "text": "on"}, {"end": 1285.6, "start": 1285.32, "text": "how"}, {"end": 1285.72, "start": 1285.6, "text": "you"}, {"end": 1286.4, "start": 1285.72, "text": "measure,"}, {"end": 1286.8, "start": 1286.4, "text": "as"}, {"end": 1286.96, "start": 1286.8, "text": "good"}, {"end": 1287.24, "start": 1286.96, "text": "or"}, {"end": 1287.52, "start": 1287.24, "text": "better"}, {"end": 1287.88, "start": 1287.52, "text": "availability"}, {"end": 1288.4, "start": 1287.88, "text": "than"}, {"end": 1288.84, "start": 1288.4, "text": "the"}, {"end": 1289.2, "start": 1288.84, "text": "public"}, {"end": 1289.96, "start": 1289.2, "text": "internet,"}], "text": " So interestingly, B4 is now bigger and growing faster than our public network. That is our connectivity to the rest of the internet while growing very, very quickly is not growing as fast as our computer to computer communication. Over the life of B4, it went from a non-business critical copy network that promised very little availability, but cheap bandwidth to something that now actually has, depending on how you measure, as good or better availability than the public internet,"}, {"chunks": [{"end": 1290.2, "start": 1290.0, "text": "with"}, {"end": 1290.64, "start": 1290.2, "text": "again,"}, {"end": 1290.88, "start": 1290.64, "text": "much"}, {"end": 1291.0, "start": 1290.88, "text": "more"}, {"end": 1294.08, "start": 1291.0, "text": "bandwidth."}, {"end": 1294.84, "start": 1294.08, "text": "Andromeda"}, {"end": 1295.0, "start": 1294.84, "text": "is"}, {"end": 1295.24, "start": 1295.0, "text": "how"}, {"end": 1295.4, "start": 1295.24, "text": "we"}, {"end": 1295.68, "start": 1295.4, "text": "actually"}, {"end": 1295.76, "start": 1295.68, "text": "do"}, {"end": 1296.0, "start": 1295.76, "text": "network"}, {"end": 1296.76, "start": 1296.0, "text": "virtualization"}, {"end": 1296.92, "start": 1296.76, "text": "across"}, {"end": 1297.32, "start": 1296.92, "text": "our"}, {"end": 1297.8, "start": 1297.32, "text": "cloud"}, {"end": 1298.48, "start": 1297.8, "text": "infrastructure."}, {"end": 1298.68, "start": 1298.48, "text": "And"}, {"end": 1299.0, "start": 1298.68, "text": "basically"}, {"end": 1299.2, "start": 1299.0, "text": "the"}, {"end": 1299.44, "start": 1299.2, "text": "idea"}, {"end": 1299.64, "start": 1299.44, "text": "here"}, {"end": 1300.12, "start": 1299.64, "text": "is"}, {"end": 1300.32, "start": 1300.12, "text": "leveraging"}, {"end": 1301.04, "start": 1300.32, "text": "software-defined"}, {"end": 1301.64, "start": 1301.04, "text": "networking"}, {"end": 1301.76, "start": 1301.64, "text": "to"}, {"end": 1301.84, "start": 1301.76, "text": "be"}, {"end": 1302.16, "start": 1301.84, "text": "able"}, {"end": 1302.16, "start": 1302.16, "text": "to"}, {"end": 1302.96, "start": 1302.16, "text": "program"}, {"end": 1303.28, "start": 1302.96, "text": "virtual"}, {"end": 1303.96, "start": 1303.28, "text": "machines"}, {"end": 1304.12, "start": 1303.96, "text": "with"}, {"end": 1304.48, "start": 1304.12, "text": "all"}, {"end": 1304.68, "start": 1304.48, "text": "the"}, {"end": 1304.88, "start": 1304.68, "text": "information"}, {"end": 1305.12, "start": 1304.88, "text": "they"}, {"end": 1305.44, "start": 1305.12, "text": "need"}, {"end": 1305.56, "start": 1305.44, "text": "to"}, {"end": 1306.0, "start": 1305.56, "text": "have"}, {"end": 1306.32, "start": 1306.0, "text": "the"}, {"end": 1306.56, "start": 1306.32, "text": "illusion"}, {"end": 1306.72, "start": 1306.56, "text": "of"}, {"end": 1306.88, "start": 1306.72, "text": "a"}, {"end": 1306.96, "start": 1306.88, "text": "dedicated"}, {"end": 1307.52, "start": 1306.96, "text": "network"}, {"end": 1307.84, "start": 1307.52, "text": "at"}, {"end": 1308.2, "start": 1307.84, "text": "the"}, {"end": 1308.6, "start": 1308.2, "text": "scale"}, {"end": 1308.6, "start": 1308.6, "text": "of"}, {"end": 1308.92, "start": 1308.6, "text": "tens,"}, {"end": 1309.52, "start": 1308.92, "text": "hundreds,"}, {"end": 1309.52, "start": 1309.52, "text": "or"}, {"end": 1310.44, "start": 1309.52, "text": "thousands"}, {"end": 1311.0, "start": 1310.44, "text": "even"}, {"end": 1311.28, "start": 1311.0, "text": "of"}, {"end": 1311.68, "start": 1311.28, "text": "VMs"}, {"end": 1311.68, "start": 1311.68, "text": "for"}, {"end": 1311.84, "start": 1311.68, "text": "their"}, {"end": 1313.28, "start": 1311.84, "text": "clusters."}, {"end": 1314.28, "start": 1313.28, "text": "And"}, {"end": 1315.48, "start": 1314.28, "text": "we"}, {"end": 1315.6, "start": 1315.48, "text": "similarly"}, {"end": 1316.32, "start": 1315.6, "text": "applied"}, {"end": 1316.84, "start": 1316.32, "text": "the"}, {"end": 1317.72, "start": 1316.84, "text": "ideas"}, {"end": 1317.92, "start": 1317.72, "text": "originally"}, {"end": 1318.4, "start": 1317.92, "text": "started"}, {"end": 1318.84, "start": 1318.4, "text": "before"}, {"end": 1319.48, "start": 1318.84, "text": "to"}, {"end": 1319.96, "start": 1319.48, "text": "Jupyter"}], "text": " with again, much more bandwidth. Andromeda is how we actually do network virtualization across our cloud infrastructure. And basically the idea here is leveraging software-defined networking to be able to program virtual machines with all the information they need to have the illusion of a dedicated network at the scale of tens, hundreds, or thousands even of VMs for their clusters. And we similarly applied the ideas originally started before to Jupyter"}, {"chunks": [{"end": 1320.28, "start": 1320.0, "text": "our"}, {"end": 1320.32, "start": 1320.28, "text": "data"}, {"end": 1320.68, "start": 1320.32, "text": "center"}, {"end": 1321.44, "start": 1320.68, "text": "networks."}, {"end": 1321.8, "start": 1321.44, "text": "And"}, {"end": 1321.88, "start": 1321.8, "text": "this"}, {"end": 1322.48, "start": 1321.88, "text": "has"}, {"end": 1322.8, "start": 1322.48, "text": "actually"}, {"end": 1323.16, "start": 1322.8, "text": "been"}, {"end": 1323.56, "start": 1323.16, "text": "across"}, {"end": 1323.84, "start": 1323.56, "text": "multiple"}, {"end": 1324.8, "start": 1323.84, "text": "generations."}, {"end": 1325.16, "start": 1324.8, "text": "We"}, {"end": 1325.64, "start": 1325.16, "text": "started"}, {"end": 1325.92, "start": 1325.64, "text": "with"}, {"end": 1326.4, "start": 1325.92, "text": "standard"}, {"end": 1326.44, "start": 1326.4, "text": "data"}, {"end": 1326.8, "start": 1326.44, "text": "center"}, {"end": 1327.44, "start": 1326.8, "text": "network"}, {"end": 1328.08, "start": 1327.44, "text": "designs,"}, {"end": 1328.24, "start": 1328.08, "text": "but"}, {"end": 1328.52, "start": 1328.24, "text": "then"}, {"end": 1328.72, "start": 1328.52, "text": "grew"}, {"end": 1328.96, "start": 1328.72, "text": "them"}, {"end": 1329.24, "start": 1328.96, "text": "to"}, {"end": 1329.32, "start": 1329.24, "text": "the"}, {"end": 1329.96, "start": 1329.32, "text": "scale"}, {"end": 1330.16, "start": 1329.96, "text": "of,"}, {"end": 1330.44, "start": 1330.16, "text": "as"}, {"end": 1330.64, "start": 1330.44, "text": "of"}, {"end": 1331.6, "start": 1330.64, "text": "2013,"}, {"end": 1332.2, "start": 1331.6, "text": "1.3"}, {"end": 1332.6, "start": 1332.2, "text": "petabits"}, {"end": 1332.68, "start": 1332.6, "text": "per"}, {"end": 1333.8, "start": 1332.68, "text": "second,"}, {"end": 1334.0, "start": 1333.8, "text": "again,"}, {"end": 1334.6, "start": 1334.0, "text": "leveraging"}, {"end": 1335.0, "start": 1334.6, "text": "commodity"}, {"end": 1335.84, "start": 1335.0, "text": "switches"}, {"end": 1336.04, "start": 1335.84, "text": "with"}, {"end": 1336.32, "start": 1336.04, "text": "remote"}, {"end": 1336.96, "start": 1336.32, "text": "control"}, {"end": 1337.12, "start": 1336.96, "text": "running"}, {"end": 1337.28, "start": 1337.12, "text": "the"}, {"end": 1338.12, "start": 1337.28, "text": "protocols."}, {"end": 1338.84, "start": 1338.12, "text": "And"}, {"end": 1338.92, "start": 1338.84, "text": "finally,"}, {"end": 1339.16, "start": 1338.92, "text": "we"}, {"end": 1340.32, "start": 1339.16, "text": "were"}, {"end": 1340.44, "start": 1340.32, "text": "able"}, {"end": 1341.52, "start": 1340.44, "text": "to"}, {"end": 1342.4, "start": 1341.52, "text": "bring"}, {"end": 1342.76, "start": 1342.4, "text": "these"}, {"end": 1343.52, "start": 1342.76, "text": "ideas"}, {"end": 1343.6, "start": 1343.52, "text": "to"}, {"end": 1344.16, "start": 1343.6, "text": "actually"}, {"end": 1344.64, "start": 1344.16, "text": "the"}, {"end": 1344.64, "start": 1344.64, "text": "public"}, {"end": 1345.04, "start": 1344.64, "text": "internet"}, {"end": 1345.16, "start": 1345.04, "text": "with"}, {"end": 1345.84, "start": 1345.16, "text": "Espresso."}, {"end": 1345.88, "start": 1345.84, "text": "And"}, {"end": 1345.88, "start": 1345.88, "text": "the"}, {"end": 1345.88, "start": 1345.88, "text": "idea"}, {"end": 1345.88, "start": 1345.88, "text": "here"}, {"end": 1345.88, "start": 1345.88, "text": "is"}, {"end": 1345.88, "start": 1345.88, "text": "that"}, {"end": 1345.92, "start": 1345.88, "text": "we"}, {"end": 1346.56, "start": 1345.92, "text": "can"}, {"end": 1347.04, "start": 1346.56, "text": "leverage"}, {"end": 1347.48, "start": 1347.04, "text": "the"}, {"end": 1348.08, "start": 1347.48, "text": "fact"}, {"end": 1348.96, "start": 1348.08, "text": "that"}, {"end": 1349.2, "start": 1348.96, "text": "we"}, {"end": 1349.36, "start": 1349.2, "text": "have"}, {"end": 1349.96, "start": 1349.36, "text": "actually"}], "text": " our data center networks. And this has actually been across multiple generations. We started with standard data center network designs, but then grew them to the scale of, as of 2013, 1.3 petabits per second, again, leveraging commodity switches with remote control running the protocols. And finally, we were able to bring these ideas to actually the public internet with Espresso. And the idea here is that we can leverage the fact that we have actually"}, {"chunks": [{"end": 1350.36, "start": 1350.0, "text": "Many"}, {"end": 1350.6, "start": 1350.36, "text": "different"}, {"end": 1350.68, "start": 1350.6, "text": "points"}, {"end": 1350.76, "start": 1350.68, "text": "of"}, {"end": 1351.28, "start": 1350.76, "text": "presence"}, {"end": 1351.56, "start": 1351.28, "text": "across"}, {"end": 1351.96, "start": 1351.56, "text": "the"}, {"end": 1352.12, "start": 1351.96, "text": "internet,"}, {"end": 1352.16, "start": 1352.12, "text": "many"}, {"end": 1352.84, "start": 1352.16, "text": "places"}, {"end": 1352.92, "start": 1352.84, "text": "where"}, {"end": 1353.0, "start": 1352.92, "text": "we"}, {"end": 1353.32, "start": 1353.0, "text": "peer"}, {"end": 1353.32, "start": 1353.32, "text": "with"}, {"end": 1353.52, "start": 1353.32, "text": "the"}, {"end": 1354.04, "start": 1353.52, "text": "rest"}, {"end": 1354.24, "start": 1354.04, "text": "of"}, {"end": 1354.24, "start": 1354.24, "text": "the"}, {"end": 1354.52, "start": 1354.24, "text": "internet"}, {"end": 1355.0, "start": 1354.52, "text": "to"}, {"end": 1355.44, "start": 1355.0, "text": "observe"}, {"end": 1355.8, "start": 1355.44, "text": "through"}, {"end": 1356.32, "start": 1355.8, "text": "randomized"}, {"end": 1357.12, "start": 1356.32, "text": "experiments"}, {"end": 1357.36, "start": 1357.12, "text": "the"}, {"end": 1357.96, "start": 1357.36, "text": "performance"}, {"end": 1358.2, "start": 1357.96, "text": "that"}, {"end": 1358.72, "start": 1358.2, "text": "particular"}, {"end": 1359.32, "start": 1358.72, "text": "clients"}, {"end": 1359.52, "start": 1359.32, "text": "get"}, {"end": 1359.76, "start": 1359.52, "text": "in"}, {"end": 1360.24, "start": 1359.76, "text": "particular"}, {"end": 1361.24, "start": 1360.24, "text": "regions"}, {"end": 1361.8, "start": 1361.24, "text": "based"}, {"end": 1362.2, "start": 1361.8, "text": "on"}, {"end": 1362.48, "start": 1362.2, "text": "what"}, {"end": 1363.0, "start": 1362.48, "text": "egress"}, {"end": 1363.16, "start": 1363.0, "text": "point"}, {"end": 1363.24, "start": 1363.16, "text": "we"}, {"end": 1363.48, "start": 1363.24, "text": "use"}, {"end": 1363.6, "start": 1363.48, "text": "in"}, {"end": 1363.88, "start": 1363.6, "text": "our"}, {"end": 1364.08, "start": 1363.88, "text": "network."}, {"end": 1364.24, "start": 1364.08, "text": "So"}, {"end": 1364.68, "start": 1364.24, "text": "essentially"}, {"end": 1365.08, "start": 1364.68, "text": "imagine"}, {"end": 1365.28, "start": 1365.08, "text": "that"}, {"end": 1365.4, "start": 1365.28, "text": "we"}, {"end": 1365.6, "start": 1365.4, "text": "can"}, {"end": 1365.76, "start": 1365.6, "text": "keep"}, {"end": 1366.2, "start": 1365.76, "text": "track"}, {"end": 1366.36, "start": 1366.2, "text": "of"}, {"end": 1366.56, "start": 1366.36, "text": "the"}, {"end": 1367.32, "start": 1366.56, "text": "performance,"}, {"end": 1367.92, "start": 1367.32, "text": "reliability,"}, {"end": 1368.76, "start": 1367.92, "text": "latency"}, {"end": 1368.92, "start": 1368.76, "text": "that"}, {"end": 1369.6, "start": 1368.92, "text": "clients"}, {"end": 1370.0, "start": 1369.6, "text": "see"}, {"end": 1370.48, "start": 1370.0, "text": "based"}, {"end": 1370.52, "start": 1370.48, "text": "on"}, {"end": 1370.96, "start": 1370.52, "text": "how"}, {"end": 1371.0, "start": 1370.96, "text": "we"}, {"end": 1371.28, "start": 1371.0, "text": "forward"}, {"end": 1372.0, "start": 1371.28, "text": "packets"}, {"end": 1372.08, "start": 1372.0, "text": "to"}, {"end": 1372.28, "start": 1372.08, "text": "them"}, {"end": 1372.68, "start": 1372.28, "text": "across"}, {"end": 1372.92, "start": 1372.68, "text": "one"}, {"end": 1373.12, "start": 1372.92, "text": "of"}, {"end": 1373.28, "start": 1373.12, "text": "multiple"}, {"end": 1374.0, "start": 1373.28, "text": "paths."}, {"end": 1374.0, "start": 1374.0, "text": "We"}, {"end": 1374.72, "start": 1374.0, "text": "analyze"}, {"end": 1374.96, "start": 1374.72, "text": "this"}, {"end": 1375.48, "start": 1374.96, "text": "information"}, {"end": 1375.52, "start": 1375.48, "text": "in"}, {"end": 1375.92, "start": 1375.52, "text": "near"}, {"end": 1376.16, "start": 1375.92, "text": "real"}, {"end": 1376.56, "start": 1376.16, "text": "time,"}, {"end": 1376.92, "start": 1376.56, "text": "set"}, {"end": 1377.2, "start": 1376.92, "text": "the"}, {"end": 1378.04, "start": 1377.2, "text": "granularity"}, {"end": 1378.28, "start": 1378.04, "text": "of,"}, {"end": 1378.44, "start": 1378.28, "text": "let's"}, {"end": 1378.48, "start": 1378.44, "text": "say,"}, {"end": 1378.56, "start": 1378.48, "text": "tens"}, {"end": 1378.68, "start": 1378.56, "text": "of"}, {"end": 1379.64, "start": 1378.68, "text": "seconds,"}, {"end": 1379.76, "start": 1379.64, "text": "and"}, {"end": 1379.96, "start": 1379.76, "text": "then"}], "text": " Many different points of presence across the internet, many places where we peer with the rest of the internet to observe through randomized experiments the performance that particular clients get in particular regions based on what egress point we use in our network. So essentially imagine that we can keep track of the performance, reliability, latency that clients see based on how we forward packets to them across one of multiple paths. We analyze this information in near real time, set the granularity of, let's say, tens of seconds, and then"}, {"chunks": [{"end": 1380.6, "start": 1380.0, "text": "use"}, {"end": 1380.6, "start": 1380.6, "text": "this"}, {"end": 1380.8, "start": 1380.6, "text": "to"}, {"end": 1380.92, "start": 1380.8, "text": "feed"}, {"end": 1381.36, "start": 1380.92, "text": "back"}, {"end": 1381.68, "start": 1381.36, "text": "our"}, {"end": 1382.04, "start": 1381.68, "text": "forwarding"}, {"end": 1382.64, "start": 1382.04, "text": "information,"}, {"end": 1382.68, "start": 1382.64, "text": "again,"}, {"end": 1382.72, "start": 1382.68, "text": "in"}, {"end": 1383.2, "start": 1382.72, "text": "real"}, {"end": 1383.92, "start": 1383.2, "text": "time,"}, {"end": 1384.12, "start": 1383.92, "text": "to"}, {"end": 1384.4, "start": 1384.12, "text": "pick"}, {"end": 1384.4, "start": 1384.4, "text": "the"}, {"end": 1384.92, "start": 1384.4, "text": "paths"}, {"end": 1385.12, "start": 1384.92, "text": "that"}, {"end": 1385.16, "start": 1385.12, "text": "are"}, {"end": 1385.24, "start": 1385.16, "text": "going"}, {"end": 1385.36, "start": 1385.24, "text": "to"}, {"end": 1385.56, "start": 1385.36, "text": "deliver"}, {"end": 1385.68, "start": 1385.56, "text": "the"}, {"end": 1385.92, "start": 1385.68, "text": "best"}, {"end": 1386.28, "start": 1385.92, "text": "quality"}, {"end": 1386.32, "start": 1386.28, "text": "of"}, {"end": 1387.16, "start": 1386.32, "text": "experience"}, {"end": 1387.36, "start": 1387.16, "text": "to"}, {"end": 1387.36, "start": 1387.36, "text": "our"}, {"end": 1387.92, "start": 1387.36, "text": "users."}, {"end": 1388.16, "start": 1387.92, "text": "Again,"}, {"end": 1388.44, "start": 1388.16, "text": "this"}, {"end": 1388.72, "start": 1388.44, "text": "would"}, {"end": 1388.72, "start": 1388.72, "text": "not"}, {"end": 1388.72, "start": 1388.72, "text": "be"}, {"end": 1389.4, "start": 1388.72, "text": "possible"}, {"end": 1389.56, "start": 1389.4, "text": "without"}, {"end": 1389.92, "start": 1389.56, "text": "having"}, {"end": 1390.2, "start": 1389.92, "text": "this"}, {"end": 1390.68, "start": 1390.2, "text": "logically"}, {"end": 1391.36, "start": 1390.68, "text": "centralized"}, {"end": 1391.88, "start": 1391.36, "text": "state"}, {"end": 1391.88, "start": 1391.88, "text": "that"}, {"end": 1392.36, "start": 1391.88, "text": "can"}, {"end": 1393.48, "start": 1392.36, "text": "reprogram"}, {"end": 1393.96, "start": 1393.48, "text": "forwarding"}, {"end": 1394.2, "start": 1393.96, "text": "tables"}, {"end": 1394.56, "start": 1394.2, "text": "based"}, {"end": 1394.84, "start": 1394.56, "text": "on"}, {"end": 1395.12, "start": 1394.84, "text": "performance"}, {"end": 1395.8, "start": 1395.12, "text": "that's"}, {"end": 1395.92, "start": 1395.8, "text": "being"}, {"end": 1396.32, "start": 1395.92, "text": "observed"}, {"end": 1396.76, "start": 1396.32, "text": "across"}, {"end": 1396.76, "start": 1396.76, "text": "the"}, {"end": 1397.4, "start": 1396.76, "text": "internet"}, {"end": 1397.8, "start": 1397.4, "text": "rather"}, {"end": 1398.04, "start": 1397.8, "text": "than"}, {"end": 1398.24, "start": 1398.04, "text": "what"}, {"end": 1398.4, "start": 1398.24, "text": "might"}, {"end": 1398.48, "start": 1398.4, "text": "be"}, {"end": 1399.04, "start": 1398.48, "text": "available"}, {"end": 1399.24, "start": 1399.04, "text": "at"}, {"end": 1399.24, "start": 1399.24, "text": "the"}, {"end": 1399.36, "start": 1399.24, "text": "purview"}, {"end": 1399.36, "start": 1399.36, "text": "of"}, {"end": 1399.36, "start": 1399.36, "text": "any"}, {"end": 1399.36, "start": 1399.36, "text": "single"}, {"end": 1399.4, "start": 1399.36, "text": "node."}, {"end": 1399.68, "start": 1399.4, "text": "So"}, {"end": 1399.8, "start": 1399.68, "text": "where"}, {"end": 1399.96, "start": 1399.8, "text": "does"}, {"end": 1400.48, "start": 1399.96, "text": "this"}, {"end": 1401.84, "start": 1400.48, "text": "leave"}, {"end": 1401.88, "start": 1401.84, "text": "us"}, {"end": 1403.16, "start": 1401.88, "text": "with"}, {"end": 1403.4, "start": 1403.16, "text": "respect"}, {"end": 1404.0, "start": 1403.4, "text": "to"}, {"end": 1406.2, "start": 1404.0, "text": "software-defined"}, {"end": 1407.28, "start": 1406.2, "text": "networking"}, {"end": 1407.88, "start": 1407.28, "text": "and"}, {"end": 1408.44, "start": 1407.88, "text": "maybe"}, {"end": 1408.64, "start": 1408.44, "text": "more"}, {"end": 1409.0, "start": 1408.64, "text": "broadly"}, {"end": 1409.08, "start": 1409.0, "text": "the"}, {"end": 1409.72, "start": 1409.08, "text": "software-defined"}, {"end": 1409.96, "start": 1409.72, "text": "future"}], "text": " use this to feed back our forwarding information, again, in real time, to pick the paths that are going to deliver the best quality of experience to our users. Again, this would not be possible without having this logically centralized state that can reprogram forwarding tables based on performance that's being observed across the internet rather than what might be available at the purview of any single node. So where does this leave us with respect to software-defined networking and maybe more broadly the software-defined future"}, {"chunks": [{"end": 1410.08, "start": 1410.0, "text": "I"}, {"end": 1410.12, "start": 1410.08, "text": "think"}, {"end": 1410.36, "start": 1410.12, "text": "that"}, {"end": 1411.04, "start": 1410.36, "text": "there"}, {"end": 1411.88, "start": 1411.04, "text": "is"}, {"end": 1412.2, "start": 1411.88, "text": "a"}, {"end": 1412.6, "start": 1412.2, "text": "ton"}, {"end": 1412.88, "start": 1412.6, "text": "left"}, {"end": 1412.92, "start": 1412.88, "text": "to"}, {"end": 1413.04, "start": 1412.92, "text": "do."}, {"end": 1413.28, "start": 1413.04, "text": "I"}, {"end": 1413.44, "start": 1413.28, "text": "think"}, {"end": 1413.48, "start": 1413.44, "text": "we've"}, {"end": 1414.0, "start": 1413.48, "text": "gotten"}, {"end": 1414.08, "start": 1414.0, "text": "to"}, {"end": 1414.52, "start": 1414.08, "text": "a"}, {"end": 1414.96, "start": 1414.52, "text": "place"}, {"end": 1415.2, "start": 1414.96, "text": "where"}, {"end": 1415.48, "start": 1415.2, "text": "the"}, {"end": 1415.76, "start": 1415.48, "text": "data"}, {"end": 1416.16, "start": 1415.76, "text": "plane"}, {"end": 1416.48, "start": 1416.16, "text": "for"}, {"end": 1416.8, "start": 1416.48, "text": "our"}, {"end": 1417.4, "start": 1416.8, "text": "networks"}, {"end": 1417.64, "start": 1417.4, "text": "is"}, {"end": 1417.92, "start": 1417.64, "text": "in"}, {"end": 1418.44, "start": 1417.92, "text": "pretty"}, {"end": 1418.44, "start": 1418.44, "text": "good"}, {"end": 1418.44, "start": 1418.44, "text": "shape."}, {"end": 1418.52, "start": 1418.44, "text": "We"}, {"end": 1418.88, "start": 1418.52, "text": "are"}, {"end": 1419.04, "start": 1418.88, "text": "able"}, {"end": 1419.16, "start": 1419.04, "text": "to"}, {"end": 1419.6, "start": 1419.16, "text": "leverage"}, {"end": 1419.92, "start": 1419.6, "text": "high"}, {"end": 1420.44, "start": 1419.92, "text": "bandwidth"}, {"end": 1420.76, "start": 1420.44, "text": "communication"}, {"end": 1420.84, "start": 1420.76, "text": "at"}, {"end": 1421.44, "start": 1420.84, "text": "scale."}, {"end": 1421.56, "start": 1421.44, "text": "The"}, {"end": 1422.2, "start": 1421.56, "text": "control"}, {"end": 1422.52, "start": 1422.2, "text": "plane,"}, {"end": 1422.76, "start": 1422.52, "text": "there's"}, {"end": 1423.2, "start": 1422.76, "text": "more"}, {"end": 1423.36, "start": 1423.2, "text": "work"}, {"end": 1423.36, "start": 1423.36, "text": "to"}, {"end": 1423.36, "start": 1423.36, "text": "do,"}, {"end": 1423.36, "start": 1423.36, "text": "but"}, {"end": 1423.36, "start": 1423.36, "text": "it"}, {"end": 1423.36, "start": 1423.36, "text": "is"}, {"end": 1423.4, "start": 1423.36, "text": "not"}, {"end": 1423.48, "start": 1423.4, "text": "a"}, {"end": 1423.84, "start": 1423.48, "text": "place"}, {"end": 1424.24, "start": 1423.84, "text": "where"}, {"end": 1424.76, "start": 1424.24, "text": "it"}, {"end": 1424.96, "start": 1424.76, "text": "is"}, {"end": 1425.6, "start": 1424.96, "text": "reasonably"}, {"end": 1426.28, "start": 1425.6, "text": "robust"}, {"end": 1426.56, "start": 1426.28, "text": "and"}, {"end": 1427.32, "start": 1426.56, "text": "high"}, {"end": 1428.16, "start": 1427.32, "text": "performance."}, {"end": 1428.48, "start": 1428.16, "text": "Network"}, {"end": 1428.96, "start": 1428.48, "text": "management,"}, {"end": 1429.08, "start": 1428.96, "text": "I"}, {"end": 1429.2, "start": 1429.08, "text": "think,"}, {"end": 1429.6, "start": 1429.2, "text": "remains"}, {"end": 1429.92, "start": 1429.6, "text": "a"}, {"end": 1430.64, "start": 1429.92, "text": "substantial"}, {"end": 1430.96, "start": 1430.64, "text": "problem"}, {"end": 1431.24, "start": 1430.96, "text": "and"}, {"end": 1431.6, "start": 1431.24, "text": "a"}, {"end": 1432.16, "start": 1431.6, "text": "substantial"}, {"end": 1433.12, "start": 1432.16, "text": "opportunity."}, {"end": 1433.8, "start": 1433.12, "text": "So"}, {"end": 1434.4, "start": 1433.8, "text": "basically,"}, {"end": 1434.84, "start": 1434.4, "text": "the"}, {"end": 1435.2, "start": 1434.84, "text": "way"}, {"end": 1435.36, "start": 1435.2, "text": "that"}, {"end": 1435.48, "start": 1435.36, "text": "we"}, {"end": 1435.76, "start": 1435.48, "text": "view"}, {"end": 1436.12, "start": 1435.76, "text": "it,"}, {"end": 1436.4, "start": 1436.12, "text": "and"}, {"end": 1436.4, "start": 1436.4, "text": "I"}, {"end": 1436.4, "start": 1436.4, "text": "think"}, {"end": 1436.44, "start": 1436.4, "text": "that"}, {"end": 1436.76, "start": 1436.44, "text": "many"}, {"end": 1436.96, "start": 1436.76, "text": "are"}, {"end": 1437.0, "start": 1436.96, "text": "looking"}, {"end": 1437.04, "start": 1437.0, "text": "at"}, {"end": 1437.32, "start": 1437.04, "text": "this"}, {"end": 1437.48, "start": 1437.32, "text": "problem,"}, {"end": 1438.0, "start": 1437.48, "text": "how"}, {"end": 1438.0, "start": 1438.0, "text": "do"}, {"end": 1438.04, "start": 1438.0, "text": "you"}, {"end": 1439.56, "start": 1438.04, "text": "transform"}, {"end": 1439.8, "start": 1439.56, "text": "higher"}, {"end": 1439.96, "start": 1439.8, "text": "level"}], "text": " I think that there is a ton left to do. I think we've gotten to a place where the data plane for our networks is in pretty good shape. We are able to leverage high bandwidth communication at scale. The control plane, there's more work to do, but it is not a place where it is reasonably robust and high performance. Network management, I think, remains a substantial problem and a substantial opportunity. So basically, the way that we view it, and I think that many are looking at this problem, how do you transform higher level"}, {"chunks": [{"end": 1440.48, "start": 1440.0, "text": "management"}, {"end": 1441.08, "start": 1440.48, "text": "states"}, {"end": 1441.36, "start": 1441.08, "text": "into"}, {"end": 1441.48, "start": 1441.36, "text": "a"}, {"end": 1441.92, "start": 1441.48, "text": "sequence"}, {"end": 1442.16, "start": 1441.92, "text": "of"}, {"end": 1442.76, "start": 1442.16, "text": "SLO"}, {"end": 1443.48, "start": 1442.76, "text": "compliance."}, {"end": 1443.6, "start": 1443.48, "text": "What"}, {"end": 1443.8, "start": 1443.6, "text": "I"}, {"end": 1443.8, "start": 1443.8, "text": "mean"}, {"end": 1444.0, "start": 1443.8, "text": "is"}, {"end": 1444.2, "start": 1444.0, "text": "by"}, {"end": 1444.56, "start": 1444.2, "text": "basically"}, {"end": 1444.84, "start": 1444.56, "text": "SLO"}, {"end": 1445.2, "start": 1444.84, "text": "is"}, {"end": 1445.68, "start": 1445.2, "text": "the"}, {"end": 1446.28, "start": 1445.68, "text": "guarantees"}, {"end": 1446.84, "start": 1446.28, "text": "that"}, {"end": 1446.88, "start": 1446.84, "text": "the"}, {"end": 1446.88, "start": 1446.88, "text": "network"}, {"end": 1446.88, "start": 1446.88, "text": "is"}, {"end": 1447.4, "start": 1446.88, "text": "providing"}, {"end": 1447.52, "start": 1447.4, "text": "to"}, {"end": 1447.68, "start": 1447.52, "text": "its"}, {"end": 1448.44, "start": 1447.68, "text": "users."}, {"end": 1448.96, "start": 1448.44, "text": "SLO"}, {"end": 1449.36, "start": 1448.96, "text": "compliant"}, {"end": 1451.4, "start": 1449.36, "text": "transformations"}, {"end": 1451.76, "start": 1451.4, "text": "that"}, {"end": 1451.84, "start": 1451.76, "text": "will"}, {"end": 1452.0, "start": 1451.84, "text": "take"}, {"end": 1452.56, "start": 1452.0, "text": "your"}, {"end": 1452.96, "start": 1452.56, "text": "network"}, {"end": 1453.32, "start": 1452.96, "text": "from"}, {"end": 1454.0, "start": 1453.32, "text": "one"}, {"end": 1454.0, "start": 1454.0, "text": "state"}, {"end": 1454.32, "start": 1454.0, "text": "to"}, {"end": 1455.08, "start": 1454.32, "text": "another."}, {"end": 1455.76, "start": 1455.08, "text": "And"}, {"end": 1456.08, "start": 1455.76, "text": "I"}, {"end": 1456.08, "start": 1456.08, "text": "think"}, {"end": 1456.08, "start": 1456.08, "text": "there's"}, {"end": 1456.08, "start": 1456.08, "text": "been"}, {"end": 1456.08, "start": 1456.08, "text": "a"}, {"end": 1456.12, "start": 1456.08, "text": "lot"}, {"end": 1456.32, "start": 1456.12, "text": "of"}, {"end": 1456.32, "start": 1456.32, "text": "great"}, {"end": 1456.32, "start": 1456.32, "text": "work"}, {"end": 1456.32, "start": 1456.32, "text": "on"}, {"end": 1456.44, "start": 1456.32, "text": "network"}, {"end": 1457.28, "start": 1456.44, "text": "verification"}, {"end": 1457.6, "start": 1457.28, "text": "around"}, {"end": 1458.2, "start": 1457.6, "text": "central"}, {"end": 1459.16, "start": 1458.2, "text": "repositories,"}, {"end": 1459.52, "start": 1459.16, "text": "once"}, {"end": 1459.56, "start": 1459.52, "text": "again,"}, {"end": 1459.56, "start": 1459.56, "text": "leveraging"}, {"end": 1459.64, "start": 1459.56, "text": "the"}, {"end": 1459.96, "start": 1459.64, "text": "central"}, {"end": 1460.52, "start": 1459.96, "text": "states"}, {"end": 1460.68, "start": 1460.52, "text": "of"}, {"end": 1461.04, "start": 1460.68, "text": "ground"}, {"end": 1461.52, "start": 1461.04, "text": "truth"}, {"end": 1461.84, "start": 1461.52, "text": "to"}, {"end": 1462.12, "start": 1461.84, "text": "allow"}, {"end": 1462.32, "start": 1462.12, "text": "us"}, {"end": 1462.4, "start": 1462.32, "text": "to"}, {"end": 1462.56, "start": 1462.4, "text": "move"}, {"end": 1462.96, "start": 1462.56, "text": "from"}, {"end": 1463.12, "start": 1462.96, "text": "one"}, {"end": 1463.4, "start": 1463.12, "text": "state"}, {"end": 1463.52, "start": 1463.4, "text": "to"}, {"end": 1463.84, "start": 1463.52, "text": "another"}, {"end": 1463.84, "start": 1463.84, "text": "in"}, {"end": 1464.24, "start": 1463.84, "text": "this"}, {"end": 1464.84, "start": 1464.24, "text": "manner."}, {"end": 1464.96, "start": 1464.84, "text": "I"}, {"end": 1465.36, "start": 1464.96, "text": "think"}, {"end": 1465.44, "start": 1465.36, "text": "we're"}, {"end": 1466.64, "start": 1465.44, "text": "going"}, {"end": 1466.88, "start": 1466.64, "text": "to"}, {"end": 1467.4, "start": 1466.88, "text": "increasingly"}, {"end": 1468.04, "start": 1467.4, "text": "see"}, {"end": 1468.8, "start": 1468.04, "text": "software-defined"}, {"end": 1469.28, "start": 1468.8, "text": "networking"}, {"end": 1469.6, "start": 1469.28, "text": "extend"}, {"end": 1469.6, "start": 1469.6, "text": "all"}, {"end": 1469.6, "start": 1469.6, "text": "the"}, {"end": 1469.96, "start": 1469.6, "text": "way"}], "text": " management states into a sequence of SLO compliance. What I mean is by basically SLO is the guarantees that the network is providing to its users. SLO compliant transformations that will take your network from one state to another. And I think there's been a lot of great work on network verification around central repositories, once again, leveraging the central states of ground truth to allow us to move from one state to another in this manner. I think we're going to increasingly see software-defined networking extend all the way"}, {"chunks": [{"end": 1470.4, "start": 1470.0, "text": "to"}, {"end": 1470.44, "start": 1470.4, "text": "end"}, {"end": 1470.8, "start": 1470.44, "text": "hosts."}, {"end": 1471.04, "start": 1470.8, "text": "This"}, {"end": 1471.12, "start": 1471.04, "text": "is"}, {"end": 1471.56, "start": 1471.12, "text": "already"}, {"end": 1471.8, "start": 1471.56, "text": "happening"}, {"end": 1471.84, "start": 1471.8, "text": "with"}, {"end": 1472.2, "start": 1471.84, "text": "network"}, {"end": 1472.8, "start": 1472.2, "text": "virtualization,"}, {"end": 1472.96, "start": 1472.8, "text": "but"}, {"end": 1473.2, "start": 1472.96, "text": "I"}, {"end": 1473.24, "start": 1473.2, "text": "think"}, {"end": 1473.52, "start": 1473.24, "text": "it's"}, {"end": 1473.56, "start": 1473.52, "text": "going"}, {"end": 1473.76, "start": 1473.56, "text": "to"}, {"end": 1473.92, "start": 1473.76, "text": "be"}, {"end": 1474.6, "start": 1473.92, "text": "extending"}, {"end": 1474.84, "start": 1474.6, "text": "with"}, {"end": 1474.88, "start": 1474.84, "text": "the"}, {"end": 1475.56, "start": 1474.88, "text": "rise"}, {"end": 1475.56, "start": 1475.56, "text": "of"}, {"end": 1475.68, "start": 1475.56, "text": "smart"}, {"end": 1476.04, "start": 1475.68, "text": "NICs"}, {"end": 1476.08, "start": 1476.04, "text": "and"}, {"end": 1476.32, "start": 1476.08, "text": "to"}, {"end": 1476.52, "start": 1476.32, "text": "many"}, {"end": 1476.76, "start": 1476.52, "text": "other"}, {"end": 1477.64, "start": 1476.76, "text": "scenarios,"}, {"end": 1478.08, "start": 1477.64, "text": "as"}, {"end": 1478.56, "start": 1478.08, "text": "well"}, {"end": 1478.76, "start": 1478.56, "text": "as"}, {"end": 1479.16, "start": 1478.76, "text": "the"}, {"end": 1479.84, "start": 1479.16, "text": "rise"}, {"end": 1480.04, "start": 1479.84, "text": "of"}, {"end": 1480.08, "start": 1480.04, "text": "5G,"}, {"end": 1480.88, "start": 1480.08, "text": "where"}, {"end": 1480.88, "start": 1480.88, "text": "we're"}, {"end": 1480.88, "start": 1480.88, "text": "going"}, {"end": 1480.88, "start": 1480.88, "text": "to"}, {"end": 1480.92, "start": 1480.88, "text": "have"}, {"end": 1481.2, "start": 1480.92, "text": "much"}, {"end": 1481.44, "start": 1481.2, "text": "more"}, {"end": 1482.04, "start": 1481.44, "text": "information"}, {"end": 1482.4, "start": 1482.04, "text": "about"}, {"end": 1482.56, "start": 1482.4, "text": "what"}, {"end": 1482.88, "start": 1482.56, "text": "the"}, {"end": 1483.64, "start": 1482.88, "text": "applications"}, {"end": 1483.64, "start": 1483.64, "text": "are"}, {"end": 1484.44, "start": 1483.64, "text": "experiencing."}, {"end": 1484.88, "start": 1484.44, "text": "This"}, {"end": 1485.0, "start": 1484.88, "text": "will"}, {"end": 1485.24, "start": 1485.0, "text": "enable,"}, {"end": 1485.4, "start": 1485.24, "text": "I"}, {"end": 1485.52, "start": 1485.4, "text": "think,"}, {"end": 1485.52, "start": 1485.52, "text": "a"}, {"end": 1485.52, "start": 1485.52, "text": "new"}, {"end": 1486.28, "start": 1485.52, "text": "golden"}, {"end": 1486.6, "start": 1486.28, "text": "age"}, {"end": 1486.68, "start": 1486.6, "text": "in"}, {"end": 1486.92, "start": 1486.68, "text": "how"}, {"end": 1487.04, "start": 1486.92, "text": "we"}, {"end": 1487.04, "start": 1487.04, "text": "do"}, {"end": 1487.52, "start": 1487.04, "text": "congestion"}, {"end": 1487.88, "start": 1487.52, "text": "control,"}, {"end": 1488.12, "start": 1487.88, "text": "how"}, {"end": 1488.12, "start": 1488.12, "text": "we"}, {"end": 1488.44, "start": 1488.12, "text": "deliver"}, {"end": 1489.4, "start": 1488.44, "text": "isolation,"}, {"end": 1489.96, "start": 1489.4, "text": "and"}, {"end": 1490.36, "start": 1489.96, "text": "how"}, {"end": 1490.36, "start": 1490.36, "text": "we"}, {"end": 1490.44, "start": 1490.36, "text": "do"}, {"end": 1490.64, "start": 1490.44, "text": "routing"}, {"end": 1491.36, "start": 1490.64, "text": "virtualization"}, {"end": 1491.8, "start": 1491.36, "text": "policy."}, {"end": 1491.8, "start": 1491.8, "text": "In"}, {"end": 1491.8, "start": 1491.8, "text": "the"}, {"end": 1491.8, "start": 1491.8, "text": "end,"}, {"end": 1491.8, "start": 1491.8, "text": "I"}, {"end": 1492.0, "start": 1491.8, "text": "think"}, {"end": 1492.6, "start": 1492.0, "text": "this"}, {"end": 1492.6, "start": 1492.6, "text": "is"}, {"end": 1492.6, "start": 1492.6, "text": "going"}, {"end": 1493.2, "start": 1492.6, "text": "to"}, {"end": 1493.88, "start": 1493.2, "text": "enable"}, {"end": 1494.48, "start": 1493.88, "text": "us"}, {"end": 1494.96, "start": 1494.48, "text": "to"}, {"end": 1495.28, "start": 1494.96, "text": "bring"}, {"end": 1495.8, "start": 1495.28, "text": "true"}, {"end": 1496.56, "start": 1495.8, "text": "networking"}, {"end": 1496.8, "start": 1496.56, "text": "as"}, {"end": 1497.08, "start": 1496.8, "text": "a"}, {"end": 1497.8, "start": 1497.08, "text": "service"}, {"end": 1498.12, "start": 1497.8, "text": "to"}, {"end": 1498.48, "start": 1498.12, "text": "companies"}, {"end": 1498.48, "start": 1498.48, "text": "and"}, {"end": 1499.12, "start": 1498.48, "text": "customers,"}, {"end": 1499.64, "start": 1499.12, "text": "essentially"}, {"end": 1499.64, "start": 1499.64, "text": "being"}, {"end": 1499.8, "start": 1499.64, "text": "able"}, {"end": 1499.96, "start": 1499.8, "text": "to"}], "text": " to end hosts. This is already happening with network virtualization, but I think it's going to be extending with the rise of smart NICs and to many other scenarios, as well as the rise of 5G, where we're going to have much more information about what the applications are experiencing. This will enable, I think, a new golden age in how we do congestion control, how we deliver isolation, and how we do routing virtualization policy. In the end, I think this is going to enable us to bring true networking as a service to companies and customers, essentially being able to"}, {"chunks": [{"end": 1500.48, "start": 1500.0, "text": "the"}, {"end": 1501.28, "start": 1500.48, "text": "network"}, {"end": 1501.64, "start": 1501.28, "text": "they"}, {"end": 1501.92, "start": 1501.64, "text": "want"}, {"end": 1501.92, "start": 1501.92, "text": "in"}, {"end": 1501.96, "start": 1501.92, "text": "the"}, {"end": 1502.24, "start": 1501.96, "text": "shape"}, {"end": 1502.24, "start": 1502.24, "text": "they"}, {"end": 1502.24, "start": 1502.24, "text": "want"}, {"end": 1502.24, "start": 1502.24, "text": "with"}, {"end": 1502.24, "start": 1502.24, "text": "the"}, {"end": 1502.64, "start": 1502.24, "text": "performance"}, {"end": 1503.48, "start": 1502.64, "text": "characteristics"}, {"end": 1503.84, "start": 1503.48, "text": "that"}, {"end": 1503.84, "start": 1503.84, "text": "they"}, {"end": 1504.04, "start": 1503.84, "text": "want"}, {"end": 1504.36, "start": 1504.04, "text": "and"}, {"end": 1505.2, "start": 1504.36, "text": "availability"}, {"end": 1505.52, "start": 1505.2, "text": "requirements"}, {"end": 1505.96, "start": 1505.52, "text": "that"}, {"end": 1506.16, "start": 1505.96, "text": "they"}, {"end": 1506.32, "start": 1506.16, "text": "need"}, {"end": 1506.52, "start": 1506.32, "text": "to"}, {"end": 1506.92, "start": 1506.52, "text": "meet"}, {"end": 1506.96, "start": 1506.92, "text": "in"}, {"end": 1507.08, "start": 1506.96, "text": "near"}, {"end": 1507.48, "start": 1507.08, "text": "real"}, {"end": 1507.68, "start": 1507.48, "text": "time."}, {"end": 1507.68, "start": 1507.68, "text": "But"}, {"end": 1508.48, "start": 1507.68, "text": "I"}, {"end": 1509.6, "start": 1508.48, "text": "think"}, {"end": 1510.24, "start": 1509.6, "text": "that"}, {"end": 1510.6, "start": 1510.24, "text": "in"}, {"end": 1511.48, "start": 1510.6, "text": "terms"}, {"end": 1511.76, "start": 1511.48, "text": "of"}, {"end": 1512.72, "start": 1511.76, "text": "tectonic"}, {"end": 1513.24, "start": 1512.72, "text": "shifts"}, {"end": 1513.64, "start": 1513.24, "text": "and"}, {"end": 1513.64, "start": 1513.64, "text": "big"}, {"end": 1514.16, "start": 1513.64, "text": "transition"}, {"end": 1514.4, "start": 1514.16, "text": "points,"}, {"end": 1514.64, "start": 1514.4, "text": "we're"}, {"end": 1514.68, "start": 1514.64, "text": "going"}, {"end": 1514.68, "start": 1514.68, "text": "to"}, {"end": 1515.24, "start": 1514.68, "text": "be"}, {"end": 1515.4, "start": 1515.24, "text": "making"}, {"end": 1515.48, "start": 1515.4, "text": "a"}, {"end": 1515.68, "start": 1515.48, "text": "leap"}, {"end": 1515.88, "start": 1515.68, "text": "from"}, {"end": 1516.48, "start": 1515.88, "text": "software-defined"}, {"end": 1517.04, "start": 1516.48, "text": "networking"}, {"end": 1517.36, "start": 1517.04, "text": "to"}, {"end": 1518.28, "start": 1517.36, "text": "software-defined"}, {"end": 1519.16, "start": 1518.28, "text": "infrastructure."}, {"end": 1519.24, "start": 1519.16, "text": "In"}, {"end": 1519.72, "start": 1519.24, "text": "other"}, {"end": 1520.04, "start": 1519.72, "text": "words,"}, {"end": 1520.24, "start": 1520.04, "text": "the"}, {"end": 1520.6, "start": 1520.24, "text": "network"}, {"end": 1520.68, "start": 1520.6, "text": "is"}, {"end": 1520.68, "start": 1520.68, "text": "going"}, {"end": 1520.68, "start": 1520.68, "text": "to"}, {"end": 1520.72, "start": 1520.68, "text": "be"}, {"end": 1521.04, "start": 1520.72, "text": "playing"}, {"end": 1521.04, "start": 1521.04, "text": "a"}, {"end": 1521.48, "start": 1521.04, "text": "critical"}, {"end": 1521.8, "start": 1521.48, "text": "role"}, {"end": 1521.92, "start": 1521.8, "text": "in"}, {"end": 1522.6, "start": 1521.92, "text": "fundamentally"}, {"end": 1522.92, "start": 1522.6, "text": "how"}, {"end": 1522.96, "start": 1522.92, "text": "we"}, {"end": 1523.56, "start": 1522.96, "text": "build"}, {"end": 1523.88, "start": 1523.56, "text": "distributed"}, {"end": 1525.2, "start": 1523.88, "text": "systems."}, {"end": 1525.84, "start": 1525.2, "text": "So"}, {"end": 1526.28, "start": 1525.84, "text": "now"}, {"end": 1526.44, "start": 1526.28, "text": "let"}, {"end": 1526.48, "start": 1526.44, "text": "me"}, {"end": 1526.52, "start": 1526.48, "text": "shift"}, {"end": 1527.0, "start": 1526.52, "text": "toward"}, {"end": 1528.04, "start": 1527.0, "text": "software-defined"}, {"end": 1528.68, "start": 1528.04, "text": "infrastructure"}, {"end": 1529.24, "start": 1528.68, "text": "and"}, {"end": 1529.44, "start": 1529.24, "text": "what"}, {"end": 1529.48, "start": 1529.44, "text": "this"}, {"end": 1529.48, "start": 1529.48, "text": "might"}, {"end": 1529.96, "start": 1529.48, "text": "mean."}], "text": " the network they want in the shape they want with the performance characteristics that they want and availability requirements that they need to meet in near real time. But I think that in terms of tectonic shifts and big transition points, we're going to be making a leap from software-defined networking to software-defined infrastructure. In other words, the network is going to be playing a critical role in fundamentally how we build distributed systems. So now let me shift toward software-defined infrastructure and what this might mean."}, {"chunks": [{"end": 1530.72, "start": 1530.0, "text": "thoughts"}, {"end": 1530.96, "start": 1530.72, "text": "are"}, {"end": 1531.4, "start": 1530.96, "text": "not"}, {"end": 1531.64, "start": 1531.4, "text": "fully"}, {"end": 1532.0, "start": 1531.64, "text": "formed"}, {"end": 1532.6, "start": 1532.0, "text": "and"}, {"end": 1532.88, "start": 1532.6, "text": "I"}, {"end": 1533.0, "start": 1532.88, "text": "think"}, {"end": 1533.08, "start": 1533.0, "text": "that"}, {"end": 1533.4, "start": 1533.08, "text": "we"}, {"end": 1533.56, "start": 1533.4, "text": "are"}, {"end": 1533.68, "start": 1533.56, "text": "at"}, {"end": 1533.84, "start": 1533.68, "text": "the"}, {"end": 1533.84, "start": 1533.84, "text": "beginning"}, {"end": 1533.84, "start": 1533.84, "text": "of"}, {"end": 1533.88, "start": 1533.84, "text": "thinking"}, {"end": 1534.2, "start": 1533.88, "text": "about"}, {"end": 1534.36, "start": 1534.2, "text": "and"}, {"end": 1535.16, "start": 1534.36, "text": "understanding"}, {"end": 1535.28, "start": 1535.16, "text": "what"}, {"end": 1535.68, "start": 1535.28, "text": "this"}, {"end": 1535.76, "start": 1535.68, "text": "could"}, {"end": 1536.0, "start": 1535.76, "text": "look"}, {"end": 1536.76, "start": 1536.0, "text": "like."}, {"end": 1536.84, "start": 1536.76, "text": "Let"}, {"end": 1537.4, "start": 1536.84, "text": "me"}, {"end": 1538.84, "start": 1537.4, "text": "start"}, {"end": 1539.92, "start": 1538.84, "text": "with"}, {"end": 1540.36, "start": 1539.92, "text": "the"}, {"end": 1540.68, "start": 1540.36, "text": "need"}, {"end": 1541.12, "start": 1540.68, "text": "that"}, {"end": 1541.36, "start": 1541.12, "text": "I"}, {"end": 1541.84, "start": 1541.36, "text": "hinted"}, {"end": 1542.28, "start": 1541.84, "text": "at"}, {"end": 1542.72, "start": 1542.28, "text": "early"}, {"end": 1542.88, "start": 1542.72, "text": "on."}, {"end": 1543.12, "start": 1542.88, "text": "So"}, {"end": 1543.76, "start": 1543.12, "text": "this"}, {"end": 1544.32, "start": 1543.76, "text": "reflects"}, {"end": 1544.44, "start": 1544.32, "text": "in"}, {"end": 1544.88, "start": 1544.44, "text": "this"}, {"end": 1545.04, "start": 1544.88, "text": "particular"}, {"end": 1545.6, "start": 1545.04, "text": "graph"}, {"end": 1545.88, "start": 1545.6, "text": "40"}, {"end": 1546.4, "start": 1545.88, "text": "years"}, {"end": 1546.4, "start": 1546.4, "text": "of"}, {"end": 1546.92, "start": 1546.4, "text": "process"}, {"end": 1546.96, "start": 1546.92, "text": "of"}, {"end": 1547.6, "start": 1546.96, "text": "performance"}, {"end": 1548.6, "start": 1547.6, "text": "improvements."}, {"end": 1548.84, "start": 1548.6, "text": "So"}, {"end": 1549.12, "start": 1548.84, "text": "this"}, {"end": 1549.32, "start": 1549.12, "text": "is"}, {"end": 1550.2, "start": 1549.32, "text": "normalized"}, {"end": 1550.44, "start": 1550.2, "text": "to"}, {"end": 1551.16, "start": 1550.44, "text": "1.0"}, {"end": 1551.2, "start": 1551.16, "text": "which"}, {"end": 1551.2, "start": 1551.2, "text": "is"}, {"end": 1551.2, "start": 1551.2, "text": "the"}, {"end": 1551.92, "start": 1551.2, "text": "performance"}, {"end": 1552.12, "start": 1551.92, "text": "of"}, {"end": 1552.88, "start": 1552.12, "text": "perhaps"}, {"end": 1552.88, "start": 1552.88, "text": "the"}, {"end": 1553.04, "start": 1552.88, "text": "computer"}, {"end": 1553.8, "start": 1553.04, "text": "architect's"}, {"end": 1553.92, "start": 1553.8, "text": "favorite"}, {"end": 1554.48, "start": 1553.92, "text": "architecture,"}, {"end": 1554.88, "start": 1554.48, "text": "the"}, {"end": 1555.24, "start": 1554.88, "text": "VAX"}, {"end": 1556.24, "start": 1555.24, "text": "11780."}, {"end": 1557.32, "start": 1556.24, "text": "So"}, {"end": 1557.8, "start": 1557.32, "text": "over"}, {"end": 1558.12, "start": 1557.8, "text": "the"}, {"end": 1558.52, "start": 1558.12, "text": "intervening"}, {"end": 1558.76, "start": 1558.52, "text": "40"}, {"end": 1559.2, "start": 1558.76, "text": "years"}, {"end": 1559.56, "start": 1559.2, "text": "what"}, {"end": 1559.64, "start": 1559.56, "text": "we"}, {"end": 1559.68, "start": 1559.64, "text": "see"}, {"end": 1559.96, "start": 1559.68, "text": "is"}], "text": " thoughts are not fully formed and I think that we are at the beginning of thinking about and understanding what this could look like. Let me start with the need that I hinted at early on. So this reflects in this particular graph 40 years of process of performance improvements. So this is normalized to 1.0 which is the performance of perhaps the computer architect's favorite architecture, the VAX 11780. So over the intervening 40 years what we see is"}, {"chunks": [{"end": 1560.48, "start": 1560.0, "text": "rather"}, {"end": 1560.92, "start": 1560.48, "text": "rapid"}, {"end": 1560.92, "start": 1560.92, "text": "increase"}, {"end": 1561.0, "start": 1560.92, "text": "in"}, {"end": 1562.04, "start": 1561.0, "text": "performance"}, {"end": 1562.4, "start": 1562.04, "text": "for"}, {"end": 1562.56, "start": 1562.4, "text": "a"}, {"end": 1562.96, "start": 1562.56, "text": "long"}, {"end": 1563.44, "start": 1562.96, "text": "period"}, {"end": 1563.56, "start": 1563.44, "text": "of"}, {"end": 1564.0, "start": 1563.56, "text": "time."}, {"end": 1564.08, "start": 1564.0, "text": "But"}, {"end": 1564.36, "start": 1564.08, "text": "then"}, {"end": 1564.72, "start": 1564.36, "text": "as"}, {"end": 1564.92, "start": 1564.72, "text": "we"}, {"end": 1565.36, "start": 1564.92, "text": "went"}, {"end": 1565.48, "start": 1565.36, "text": "through"}, {"end": 1565.88, "start": 1565.48, "text": "the"}, {"end": 1566.4, "start": 1565.88, "text": "multi-core"}, {"end": 1566.84, "start": 1566.4, "text": "era,"}, {"end": 1566.96, "start": 1566.84, "text": "and"}, {"end": 1567.04, "start": 1566.96, "text": "today"}, {"end": 1567.32, "start": 1567.04, "text": "where"}, {"end": 1567.32, "start": 1567.32, "text": "we're"}, {"end": 1567.6, "start": 1567.32, "text": "at"}, {"end": 1568.08, "start": 1567.6, "text": "right"}, {"end": 1568.56, "start": 1568.08, "text": "now,"}, {"end": 1568.68, "start": 1568.56, "text": "the"}, {"end": 1569.16, "start": 1568.68, "text": "performance"}, {"end": 1569.6, "start": 1569.16, "text": "improvements"}, {"end": 1569.6, "start": 1569.6, "text": "in"}, {"end": 1570.44, "start": 1569.6, "text": "processors"}, {"end": 1570.84, "start": 1570.44, "text": "have"}, {"end": 1571.76, "start": 1570.84, "text": "substantially"}, {"end": 1571.96, "start": 1571.76, "text": "slowed"}, {"end": 1571.96, "start": 1571.96, "text": "to"}, {"end": 1571.96, "start": 1571.96, "text": "the"}, {"end": 1572.0, "start": 1571.96, "text": "point"}, {"end": 1572.2, "start": 1572.0, "text": "where"}, {"end": 1572.28, "start": 1572.2, "text": "we're"}, {"end": 1572.76, "start": 1572.28, "text": "now"}, {"end": 1573.64, "start": 1572.76, "text": "at,"}, {"end": 1573.92, "start": 1573.64, "text": "certainly"}, {"end": 1574.12, "start": 1573.92, "text": "when"}, {"end": 1574.64, "start": 1574.12, "text": "normalized"}, {"end": 1574.76, "start": 1574.64, "text": "for"}, {"end": 1575.4, "start": 1574.76, "text": "cost,"}, {"end": 1575.8, "start": 1575.4, "text": "single"}, {"end": 1576.08, "start": 1575.8, "text": "digit"}, {"end": 1576.56, "start": 1576.08, "text": "performance"}, {"end": 1576.96, "start": 1576.56, "text": "improvements,"}, {"end": 1577.12, "start": 1576.96, "text": "single"}, {"end": 1577.56, "start": 1577.12, "text": "digit"}, {"end": 1578.48, "start": 1577.56, "text": "percentage"}, {"end": 1579.28, "start": 1578.48, "text": "performance"}, {"end": 1580.52, "start": 1579.28, "text": "improvements"}, {"end": 1582.32, "start": 1580.52, "text": "on"}, {"end": 1582.48, "start": 1582.32, "text": "a"}, {"end": 1582.52, "start": 1582.48, "text": "yearly"}, {"end": 1583.0, "start": 1582.52, "text": "basis."}, {"end": 1583.0, "start": 1583.0, "text": "All"}, {"end": 1585.0, "start": 1583.0, "text": "of"}, {"end": 1585.24, "start": 1585.0, "text": "this"}, {"end": 1586.0, "start": 1585.24, "text": "actually"}, {"end": 1586.2, "start": 1586.0, "text": "can"}, {"end": 1586.36, "start": 1586.2, "text": "be"}, {"end": 1587.0, "start": 1586.36, "text": "coupled"}, {"end": 1587.24, "start": 1587.0, "text": "with"}, {"end": 1588.12, "start": 1587.24, "text": "actually"}, {"end": 1589.08, "start": 1588.12, "text": "exploding"}, {"end": 1589.96, "start": 1589.08, "text": "demand"}], "text": " rather rapid increase in performance for a long period of time. But then as we went through the multi-core era, and today where we're at right now, the performance improvements in processors have substantially slowed to the point where we're now at, certainly when normalized for cost, single digit performance improvements, single digit percentage performance improvements on a yearly basis. All of this actually can be coupled with actually exploding demand"}, {"chunks": [{"end": 1590.2, "start": 1590.0, "text": "And"}, {"end": 1590.44, "start": 1590.2, "text": "for"}, {"end": 1590.68, "start": 1590.44, "text": "data,"}, {"end": 1591.04, "start": 1590.68, "text": "there"}, {"end": 1591.64, "start": 1591.04, "text": "are"}, {"end": 1592.0, "start": 1591.64, "text": "lots"}, {"end": 1592.04, "start": 1592.0, "text": "of"}, {"end": 1592.04, "start": 1592.04, "text": "ways"}, {"end": 1592.04, "start": 1592.04, "text": "to"}, {"end": 1592.08, "start": 1592.04, "text": "look"}, {"end": 1592.24, "start": 1592.08, "text": "at"}, {"end": 1592.52, "start": 1592.24, "text": "this."}, {"end": 1592.84, "start": 1592.52, "text": "We"}, {"end": 1593.12, "start": 1592.84, "text": "have"}, {"end": 1593.16, "start": 1593.12, "text": "many"}, {"end": 1593.52, "start": 1593.16, "text": "internal"}, {"end": 1594.28, "start": 1593.52, "text": "measures."}, {"end": 1594.52, "start": 1594.28, "text": "Here's"}, {"end": 1595.12, "start": 1594.52, "text": "one"}, {"end": 1595.52, "start": 1595.12, "text": "externally"}, {"end": 1595.92, "start": 1595.52, "text": "available"}, {"end": 1596.28, "start": 1595.92, "text": "measure."}, {"end": 1596.28, "start": 1596.28, "text": "What"}, {"end": 1596.76, "start": 1596.28, "text": "this"}, {"end": 1597.36, "start": 1596.76, "text": "graph"}, {"end": 1597.68, "start": 1597.36, "text": "shows"}, {"end": 1597.92, "start": 1597.68, "text": "you"}, {"end": 1598.4, "start": 1597.92, "text": "is"}, {"end": 1598.96, "start": 1598.4, "text": "the"}, {"end": 1599.4, "start": 1598.96, "text": "amount"}, {"end": 1599.96, "start": 1599.4, "text": "of"}, {"end": 1600.88, "start": 1599.96, "text": "YouTube"}, {"end": 1601.76, "start": 1600.88, "text": "hours"}, {"end": 1601.84, "start": 1601.76, "text": "of"}, {"end": 1601.88, "start": 1601.84, "text": "video"}, {"end": 1602.24, "start": 1601.88, "text": "that"}, {"end": 1602.48, "start": 1602.24, "text": "are"}, {"end": 1602.88, "start": 1602.48, "text": "uploaded"}, {"end": 1603.08, "start": 1602.88, "text": "to"}, {"end": 1603.88, "start": 1603.08, "text": "Google"}, {"end": 1604.36, "start": 1603.88, "text": "every"}, {"end": 1604.96, "start": 1604.36, "text": "minute"}, {"end": 1605.0, "start": 1604.96, "text": "on"}, {"end": 1605.28, "start": 1605.0, "text": "an"}, {"end": 1605.8, "start": 1605.28, "text": "exponential"}, {"end": 1607.0, "start": 1605.8, "text": "y-axis"}, {"end": 1607.52, "start": 1607.0, "text": "over"}, {"end": 1607.52, "start": 1607.52, "text": "a"}, {"end": 1607.64, "start": 1607.52, "text": "10-year"}, {"end": 1608.08, "start": 1607.64, "text": "period."}, {"end": 1609.56, "start": 1608.08, "text": "That's"}, {"end": 1609.88, "start": 1609.56, "text": "the"}, {"end": 1610.28, "start": 1609.88, "text": "red"}, {"end": 1610.28, "start": 1610.28, "text": "curve"}, {"end": 1610.28, "start": 1610.28, "text": "that"}, {"end": 1610.48, "start": 1610.28, "text": "you"}, {"end": 1610.8, "start": 1610.48, "text": "see."}, {"end": 1611.36, "start": 1610.8, "text": "At"}, {"end": 1611.8, "start": 1611.36, "text": "the"}, {"end": 1612.0, "start": 1611.8, "text": "same"}, {"end": 1612.04, "start": 1612.0, "text": "time,"}, {"end": 1612.4, "start": 1612.04, "text": "for"}, {"end": 1612.92, "start": 1612.4, "text": "that"}, {"end": 1613.52, "start": 1612.92, "text": "same"}, {"end": 1614.2, "start": 1613.52, "text": "10-year"}, {"end": 1614.48, "start": 1614.2, "text": "period,"}, {"end": 1614.48, "start": 1614.48, "text": "you"}, {"end": 1614.72, "start": 1614.48, "text": "see"}, {"end": 1615.28, "start": 1614.72, "text": "the"}, {"end": 1615.32, "start": 1615.28, "text": "spec"}, {"end": 1615.64, "start": 1615.32, "text": "ins"}, {"end": 1616.0, "start": 1615.64, "text": "rates"}, {"end": 1616.24, "start": 1616.0, "text": "for"}, {"end": 1617.32, "start": 1616.24, "text": "CPUs."}, {"end": 1617.72, "start": 1617.32, "text": "Essentially,"}, {"end": 1618.2, "start": 1617.72, "text": "what"}, {"end": 1618.24, "start": 1618.2, "text": "we're"}, {"end": 1618.24, "start": 1618.24, "text": "seeing"}, {"end": 1618.72, "start": 1618.24, "text": "is"}, {"end": 1619.32, "start": 1618.72, "text": "that"}, {"end": 1619.56, "start": 1619.32, "text": "at"}, {"end": 1619.72, "start": 1619.56, "text": "the"}, {"end": 1619.88, "start": 1619.72, "text": "same"}, {"end": 1619.88, "start": 1619.88, "text": "time"}, {"end": 1619.88, "start": 1619.88, "text": "that"}, {"end": 1619.96, "start": 1619.88, "text": "the"}], "text": " And for data, there are lots of ways to look at this. We have many internal measures. Here's one externally available measure. What this graph shows you is the amount of YouTube hours of video that are uploaded to Google every minute on an exponential y-axis over a 10-year period. That's the red curve that you see. At the same time, for that same 10-year period, you see the spec ins rates for CPUs. Essentially, what we're seeing is that at the same time that the"}, {"chunks": [{"end": 1620.6, "start": 1620.0, "text": "performance"}, {"end": 1620.88, "start": 1620.6, "text": "of"}, {"end": 1621.44, "start": 1620.88, "text": "CPUs"}, {"end": 1621.6, "start": 1621.44, "text": "and"}, {"end": 1621.68, "start": 1621.6, "text": "our"}, {"end": 1622.04, "start": 1621.68, "text": "capability"}, {"end": 1622.36, "start": 1622.04, "text": "to"}, {"end": 1622.84, "start": 1622.36, "text": "process"}, {"end": 1623.24, "start": 1622.84, "text": "data"}, {"end": 1623.52, "start": 1623.24, "text": "is"}, {"end": 1623.96, "start": 1623.52, "text": "slowing"}, {"end": 1625.28, "start": 1623.96, "text": "substantially."}, {"end": 1625.64, "start": 1625.28, "text": "The"}, {"end": 1625.8, "start": 1625.64, "text": "amount"}, {"end": 1626.08, "start": 1625.8, "text": "of"}, {"end": 1626.12, "start": 1626.08, "text": "data"}, {"end": 1626.16, "start": 1626.12, "text": "that"}, {"end": 1626.52, "start": 1626.16, "text": "we're"}, {"end": 1627.32, "start": 1626.52, "text": "having"}, {"end": 1627.6, "start": 1627.32, "text": "to"}, {"end": 1628.08, "start": 1627.6, "text": "ingest"}, {"end": 1628.16, "start": 1628.08, "text": "and"}, {"end": 1629.04, "start": 1628.16, "text": "process"}, {"end": 1629.48, "start": 1629.04, "text": "is"}, {"end": 1629.6, "start": 1629.48, "text": "growing"}, {"end": 1629.64, "start": 1629.6, "text": "even"}, {"end": 1629.92, "start": 1629.64, "text": "more"}, {"end": 1630.16, "start": 1629.92, "text": "rapidly."}, {"end": 1630.24, "start": 1630.16, "text": "If"}, {"end": 1630.24, "start": 1630.24, "text": "you"}, {"end": 1630.32, "start": 1630.24, "text": "were"}, {"end": 1631.04, "start": 1630.32, "text": "to"}, {"end": 1631.36, "start": 1631.04, "text": "extend"}, {"end": 1631.76, "start": 1631.36, "text": "this"}, {"end": 1632.16, "start": 1631.76, "text": "curve"}, {"end": 1632.6, "start": 1632.16, "text": "out"}, {"end": 1632.84, "start": 1632.6, "text": "past"}, {"end": 1633.92, "start": 1632.84, "text": "2016,"}, {"end": 1634.36, "start": 1633.92, "text": "actually"}, {"end": 1634.48, "start": 1634.36, "text": "the"}, {"end": 1634.96, "start": 1634.48, "text": "divergence"}, {"end": 1635.0, "start": 1634.96, "text": "would"}, {"end": 1635.24, "start": 1635.0, "text": "be"}, {"end": 1635.72, "start": 1635.24, "text": "larger."}, {"end": 1636.08, "start": 1635.72, "text": "So"}, {"end": 1636.6, "start": 1636.08, "text": "as"}, {"end": 1636.76, "start": 1636.6, "text": "we"}, {"end": 1637.04, "start": 1636.76, "text": "move"}, {"end": 1637.36, "start": 1637.04, "text": "toward"}, {"end": 1637.44, "start": 1637.36, "text": "a"}, {"end": 1637.88, "start": 1637.44, "text": "place"}, {"end": 1638.12, "start": 1637.88, "text": "where"}, {"end": 1638.28, "start": 1638.12, "text": "we"}, {"end": 1638.56, "start": 1638.28, "text": "are"}, {"end": 1639.08, "start": 1638.56, "text": "increasingly"}, {"end": 1639.24, "start": 1639.08, "text": "again"}, {"end": 1639.72, "start": 1639.24, "text": "sensing"}, {"end": 1639.84, "start": 1639.72, "text": "and"}, {"end": 1640.32, "start": 1639.84, "text": "actuating"}, {"end": 1640.48, "start": 1640.32, "text": "the"}, {"end": 1641.08, "start": 1640.48, "text": "physical"}, {"end": 1641.4, "start": 1641.08, "text": "world,"}, {"end": 1641.52, "start": 1641.4, "text": "the"}, {"end": 1641.92, "start": 1641.52, "text": "amount"}, {"end": 1641.92, "start": 1641.92, "text": "of"}, {"end": 1641.92, "start": 1641.92, "text": "data"}, {"end": 1641.96, "start": 1641.92, "text": "that"}, {"end": 1642.52, "start": 1641.96, "text": "we're"}, {"end": 1642.8, "start": 1642.52, "text": "having"}, {"end": 1643.32, "start": 1642.8, "text": "to"}, {"end": 1643.76, "start": 1643.32, "text": "work"}, {"end": 1643.8, "start": 1643.76, "text": "with"}, {"end": 1643.96, "start": 1643.8, "text": "is"}, {"end": 1644.6, "start": 1643.96, "text": "just"}, {"end": 1645.04, "start": 1644.6, "text": "growing"}, {"end": 1645.44, "start": 1645.04, "text": "ever"}, {"end": 1645.88, "start": 1645.44, "text": "faster,"}, {"end": 1646.04, "start": 1645.88, "text": "right?"}, {"end": 1646.44, "start": 1646.04, "text": "So"}, {"end": 1646.52, "start": 1646.44, "text": "the"}, {"end": 1647.04, "start": 1646.52, "text": "exponential"}, {"end": 1647.04, "start": 1647.04, "text": "is"}, {"end": 1647.44, "start": 1647.04, "text": "increasing."}, {"end": 1647.88, "start": 1647.44, "text": "At"}, {"end": 1648.12, "start": 1647.88, "text": "the"}, {"end": 1648.4, "start": 1648.12, "text": "same"}, {"end": 1648.88, "start": 1648.4, "text": "time,"}, {"end": 1648.96, "start": 1648.88, "text": "we're"}, {"end": 1649.04, "start": 1648.96, "text": "hitting"}, {"end": 1649.2, "start": 1649.04, "text": "more"}, {"end": 1649.4, "start": 1649.2, "text": "and"}, {"end": 1649.68, "start": 1649.4, "text": "more"}, {"end": 1649.96, "start": 1649.68, "text": "fundamental"}], "text": " performance of CPUs and our capability to process data is slowing substantially. The amount of data that we're having to ingest and process is growing even more rapidly. If you were to extend this curve out past 2016, actually the divergence would be larger. So as we move toward a place where we are increasingly again sensing and actuating the physical world, the amount of data that we're having to work with is just growing ever faster, right? So the exponential is increasing. At the same time, we're hitting more and more fundamental"}, {"chunks": [{"end": 1650.76, "start": 1650.0, "text": "limits"}, {"end": 1650.88, "start": 1650.76, "text": "in"}, {"end": 1651.04, "start": 1650.88, "text": "our"}, {"end": 1651.68, "start": 1651.04, "text": "ability"}, {"end": 1651.96, "start": 1651.68, "text": "to"}, {"end": 1652.08, "start": 1651.96, "text": "scale"}, {"end": 1652.8, "start": 1652.08, "text": "compute"}, {"end": 1653.92, "start": 1652.8, "text": "efficiently."}, {"end": 1654.2, "start": 1653.92, "text": "So"}, {"end": 1654.36, "start": 1654.2, "text": "again,"}, {"end": 1654.68, "start": 1654.36, "text": "this"}, {"end": 1655.48, "start": 1654.68, "text": "divergence"}, {"end": 1655.88, "start": 1655.48, "text": "between"}, {"end": 1656.2, "start": 1655.88, "text": "demand"}, {"end": 1656.48, "start": 1656.2, "text": "for"}, {"end": 1656.88, "start": 1656.48, "text": "compute"}, {"end": 1657.04, "start": 1656.88, "text": "and"}, {"end": 1657.92, "start": 1657.04, "text": "affordability"}, {"end": 1658.0, "start": 1657.92, "text": "of"}, {"end": 1658.6, "start": 1658.0, "text": "compute"}, {"end": 1658.76, "start": 1658.6, "text": "is"}, {"end": 1661.24, "start": 1658.76, "text": "rather"}, {"end": 1661.6, "start": 1661.24, "text": "striking."}, {"end": 1661.64, "start": 1661.6, "text": "It"}, {"end": 1662.44, "start": 1661.64, "text": "becomes"}, {"end": 1662.6, "start": 1662.44, "text": "even"}, {"end": 1662.96, "start": 1662.6, "text": "more"}, {"end": 1663.56, "start": 1662.96, "text": "striking"}, {"end": 1663.92, "start": 1663.56, "text": "when"}, {"end": 1663.96, "start": 1663.92, "text": "you"}, {"end": 1664.6, "start": 1663.96, "text": "consider"}, {"end": 1664.88, "start": 1664.6, "text": "the"}, {"end": 1665.44, "start": 1664.88, "text": "rise"}, {"end": 1665.44, "start": 1665.44, "text": "of"}, {"end": 1665.68, "start": 1665.44, "text": "machine"}, {"end": 1666.24, "start": 1665.68, "text": "learning."}, {"end": 1666.92, "start": 1666.24, "text": "So"}, {"end": 1667.52, "start": 1666.92, "text": "again,"}, {"end": 1668.08, "start": 1667.52, "text": "lots"}, {"end": 1668.6, "start": 1668.08, "text": "of"}, {"end": 1669.04, "start": 1668.6, "text": "ways"}, {"end": 1669.04, "start": 1669.04, "text": "to"}, {"end": 1669.16, "start": 1669.04, "text": "look"}, {"end": 1669.44, "start": 1669.16, "text": "at"}, {"end": 1669.88, "start": 1669.44, "text": "it,"}, {"end": 1670.24, "start": 1669.88, "text": "lots"}, {"end": 1670.44, "start": 1670.24, "text": "of"}, {"end": 1670.92, "start": 1670.44, "text": "ways"}, {"end": 1671.28, "start": 1670.92, "text": "to"}, {"end": 1671.68, "start": 1671.28, "text": "look"}, {"end": 1672.12, "start": 1671.68, "text": "at"}, {"end": 1672.56, "start": 1672.12, "text": "the"}, {"end": 1673.04, "start": 1672.56, "text": "explosion"}, {"end": 1673.52, "start": 1673.04, "text": "in"}, {"end": 1674.24, "start": 1673.52, "text": "demand"}, {"end": 1674.56, "start": 1674.24, "text": "for"}, {"end": 1675.04, "start": 1674.56, "text": "compute"}, {"end": 1675.44, "start": 1675.04, "text": "and"}, {"end": 1675.68, "start": 1675.44, "text": "the"}, {"end": 1675.76, "start": 1675.68, "text": "data"}, {"end": 1676.24, "start": 1675.76, "text": "that"}, {"end": 1676.76, "start": 1676.24, "text": "feeds"}, {"end": 1676.76, "start": 1676.76, "text": "it."}, {"end": 1676.76, "start": 1676.76, "text": "This"}, {"end": 1676.76, "start": 1676.76, "text": "is,"}, {"end": 1676.84, "start": 1676.76, "text": "again,"}, {"end": 1677.32, "start": 1676.84, "text": "one"}, {"end": 1677.64, "start": 1677.32, "text": "public"}, {"end": 1677.72, "start": 1677.64, "text": "version"}, {"end": 1677.72, "start": 1677.72, "text": "of"}, {"end": 1677.72, "start": 1677.72, "text": "it"}, {"end": 1678.08, "start": 1677.72, "text": "for"}, {"end": 1678.8, "start": 1678.08, "text": "AlexNet"}, {"end": 1679.4, "start": 1678.8, "text": "AlphaGo"}, {"end": 1679.96, "start": 1679.4, "text": "Zero,"}], "text": " limits in our ability to scale compute efficiently. So again, this divergence between demand for compute and affordability of compute is rather striking. It becomes even more striking when you consider the rise of machine learning. So again, lots of ways to look at it, lots of ways to look at the explosion in demand for compute and the data that feeds it. This is, again, one public version of it for AlexNet AlphaGo Zero,"}, {"chunks": [{"end": 1680.28, "start": 1680.0, "text": "Based"}, {"end": 1680.36, "start": 1680.28, "text": "on"}, {"end": 1680.48, "start": 1680.36, "text": "an"}, {"end": 1680.68, "start": 1680.48, "text": "open"}, {"end": 1681.0, "start": 1680.68, "text": "AI"}, {"end": 1681.2, "start": 1681.0, "text": "study,"}, {"end": 1681.2, "start": 1681.2, "text": "again,"}, {"end": 1681.28, "start": 1681.2, "text": "looking"}, {"end": 1681.44, "start": 1681.28, "text": "at"}, {"end": 1681.56, "start": 1681.44, "text": "it"}, {"end": 1681.92, "start": 1681.56, "text": "over"}, {"end": 1682.28, "start": 1681.92, "text": "a"}, {"end": 1682.84, "start": 1682.28, "text": "six"}, {"end": 1682.88, "start": 1682.84, "text": "or"}, {"end": 1683.0, "start": 1682.88, "text": "seven"}, {"end": 1683.08, "start": 1683.0, "text": "year"}, {"end": 1683.4, "start": 1683.08, "text": "period"}, {"end": 1683.6, "start": 1683.4, "text": "with"}, {"end": 1683.68, "start": 1683.6, "text": "an"}, {"end": 1684.2, "start": 1683.68, "text": "exponential"}, {"end": 1684.2, "start": 1684.2, "text": "on"}, {"end": 1684.28, "start": 1684.2, "text": "the"}, {"end": 1685.44, "start": 1684.28, "text": "y-axis,"}, {"end": 1685.6, "start": 1685.44, "text": "what"}, {"end": 1685.68, "start": 1685.6, "text": "you"}, {"end": 1686.12, "start": 1685.68, "text": "see"}, {"end": 1686.48, "start": 1686.12, "text": "is"}, {"end": 1686.6, "start": 1686.48, "text": "a"}, {"end": 1687.64, "start": 1686.6, "text": "300,000"}, {"end": 1688.0, "start": 1687.64, "text": "fold"}, {"end": 1688.68, "start": 1688.0, "text": "increase"}, {"end": 1688.76, "start": 1688.68, "text": "in"}, {"end": 1689.04, "start": 1688.76, "text": "compute"}, {"end": 1689.76, "start": 1689.04, "text": "demand"}, {"end": 1690.16, "start": 1689.76, "text": "for"}, {"end": 1690.64, "start": 1690.16, "text": "running"}, {"end": 1690.76, "start": 1690.64, "text": "the"}, {"end": 1691.56, "start": 1690.76, "text": "various"}, {"end": 1692.2, "start": 1691.56, "text": "models"}, {"end": 1692.2, "start": 1692.2, "text": "that"}, {"end": 1692.48, "start": 1692.2, "text": "the"}, {"end": 1692.6, "start": 1692.48, "text": "community"}, {"end": 1693.16, "start": 1692.6, "text": "wishes"}, {"end": 1693.28, "start": 1693.16, "text": "to"}, {"end": 1693.44, "start": 1693.28, "text": "go"}, {"end": 1693.64, "start": 1693.44, "text": "after."}, {"end": 1693.84, "start": 1693.64, "text": "And"}, {"end": 1694.04, "start": 1693.84, "text": "these"}, {"end": 1694.32, "start": 1694.04, "text": "are"}, {"end": 1694.84, "start": 1694.32, "text": "externally"}, {"end": 1695.04, "start": 1694.84, "text": "available."}, {"end": 1695.32, "start": 1695.04, "text": "What"}, {"end": 1695.36, "start": 1695.32, "text": "you"}, {"end": 1695.76, "start": 1695.36, "text": "can"}, {"end": 1696.12, "start": 1695.76, "text": "imagine"}, {"end": 1696.28, "start": 1696.12, "text": "is"}, {"end": 1696.48, "start": 1696.28, "text": "that"}, {"end": 1696.64, "start": 1696.48, "text": "many"}, {"end": 1697.24, "start": 1696.64, "text": "companies"}, {"end": 1697.32, "start": 1697.24, "text": "are"}, {"end": 1697.6, "start": 1697.32, "text": "looking"}, {"end": 1697.84, "start": 1697.6, "text": "at"}, {"end": 1698.28, "start": 1697.84, "text": "even"}, {"end": 1698.56, "start": 1698.28, "text": "larger"}, {"end": 1698.88, "start": 1698.56, "text": "scale"}, {"end": 1699.4, "start": 1698.88, "text": "problems"}, {"end": 1700.36, "start": 1699.4, "text": "internally."}, {"end": 1700.8, "start": 1700.36, "text": "So"}, {"end": 1701.24, "start": 1700.8, "text": "it's"}, {"end": 1701.72, "start": 1701.24, "text": "not"}, {"end": 1702.0, "start": 1701.72, "text": "hard"}, {"end": 1702.2, "start": 1702.0, "text": "to"}, {"end": 1702.4, "start": 1702.2, "text": "imagine"}, {"end": 1702.52, "start": 1702.4, "text": "that"}, {"end": 1702.68, "start": 1702.52, "text": "we're"}, {"end": 1702.68, "start": 1702.68, "text": "going"}, {"end": 1702.68, "start": 1702.68, "text": "to"}, {"end": 1702.68, "start": 1702.68, "text": "get"}, {"end": 1702.88, "start": 1702.68, "text": "to"}, {"end": 1702.88, "start": 1702.88, "text": "a"}, {"end": 1703.28, "start": 1702.88, "text": "place"}, {"end": 1703.28, "start": 1703.28, "text": "where"}, {"end": 1703.6, "start": 1703.28, "text": "machine"}, {"end": 1703.92, "start": 1703.6, "text": "learning"}, {"end": 1704.44, "start": 1703.92, "text": "compute"}, {"end": 1704.76, "start": 1704.44, "text": "demand"}, {"end": 1705.08, "start": 1704.76, "text": "is"}, {"end": 1705.28, "start": 1705.08, "text": "going"}, {"end": 1705.6, "start": 1705.28, "text": "to"}, {"end": 1706.16, "start": 1705.6, "text": "outpace"}, {"end": 1706.32, "start": 1706.16, "text": "general"}, {"end": 1706.8, "start": 1706.32, "text": "purpose"}, {"end": 1707.0, "start": 1706.8, "text": "compute"}, {"end": 1707.28, "start": 1707.0, "text": "demand,"}, {"end": 1707.28, "start": 1707.28, "text": "given"}, {"end": 1707.28, "start": 1707.28, "text": "the"}, {"end": 1707.28, "start": 1707.28, "text": "growth"}, {"end": 1707.44, "start": 1707.28, "text": "rate"}, {"end": 1708.16, "start": 1707.44, "text": "certainly"}, {"end": 1708.4, "start": 1708.16, "text": "that"}, {"end": 1708.52, "start": 1708.4, "text": "we're"}, {"end": 1709.04, "start": 1708.52, "text": "seeing"}, {"end": 1709.96, "start": 1709.04, "text": "today."}], "text": " Based on an open AI study, again, looking at it over a six or seven year period with an exponential on the y-axis, what you see is a 300,000 fold increase in compute demand for running the various models that the community wishes to go after. And these are externally available. What you can imagine is that many companies are looking at even larger scale problems internally. So it's not hard to imagine that we're going to get to a place where machine learning compute demand is going to outpace general purpose compute demand, given the growth rate certainly that we're seeing today."}, {"chunks": [{"end": 1710.68, "start": 1710.0, "text": "So"}, {"end": 1713.2, "start": 1710.68, "text": "what"}, {"end": 1713.48, "start": 1713.2, "text": "are"}, {"end": 1713.96, "start": 1713.48, "text": "the"}, {"end": 1715.12, "start": 1713.96, "text": "implications"}, {"end": 1715.12, "start": 1715.12, "text": "of"}, {"end": 1715.64, "start": 1715.12, "text": "these"}, {"end": 1716.72, "start": 1715.64, "text": "trends?"}, {"end": 1717.32, "start": 1716.72, "text": "I"}, {"end": 1717.88, "start": 1717.32, "text": "believe"}, {"end": 1718.28, "start": 1717.88, "text": "that"}, {"end": 1718.44, "start": 1718.28, "text": "a"}, {"end": 1718.88, "start": 1718.44, "text": "single"}, {"end": 1719.24, "start": 1718.88, "text": "general"}, {"end": 1719.48, "start": 1719.24, "text": "purpose"}, {"end": 1720.04, "start": 1719.48, "text": "server"}, {"end": 1720.64, "start": 1720.04, "text": "architecture"}, {"end": 1720.92, "start": 1720.64, "text": "cannot"}, {"end": 1721.2, "start": 1720.92, "text": "generalize"}, {"end": 1721.8, "start": 1721.2, "text": "to"}, {"end": 1722.04, "start": 1721.8, "text": "all"}, {"end": 1722.6, "start": 1722.04, "text": "application"}, {"end": 1723.4, "start": 1722.6, "text": "needs"}, {"end": 1724.08, "start": 1723.4, "text": "because"}, {"end": 1724.36, "start": 1724.08, "text": "of"}, {"end": 1724.64, "start": 1724.36, "text": "huge"}, {"end": 1725.4, "start": 1724.64, "text": "variability"}, {"end": 1725.52, "start": 1725.4, "text": "in"}, {"end": 1725.52, "start": 1725.52, "text": "per"}, {"end": 1726.16, "start": 1725.52, "text": "service"}, {"end": 1726.6, "start": 1726.16, "text": "system"}, {"end": 1727.44, "start": 1726.6, "text": "balance."}, {"end": 1727.84, "start": 1727.44, "text": "So"}, {"end": 1727.88, "start": 1727.84, "text": "what"}, {"end": 1728.16, "start": 1727.88, "text": "does"}, {"end": 1728.56, "start": 1728.16, "text": "this"}, {"end": 1728.68, "start": 1728.56, "text": "mean?"}, {"end": 1728.76, "start": 1728.68, "text": "It"}, {"end": 1728.96, "start": 1728.76, "text": "means"}, {"end": 1729.2, "start": 1728.96, "text": "that"}, {"end": 1729.24, "start": 1729.2, "text": "for"}, {"end": 1729.52, "start": 1729.24, "text": "the,"}, {"end": 1729.72, "start": 1729.52, "text": "let's"}, {"end": 1730.28, "start": 1729.72, "text": "say,"}, {"end": 1730.32, "start": 1730.28, "text": "the"}, {"end": 1730.84, "start": 1730.32, "text": "conventional"}, {"end": 1731.12, "start": 1730.84, "text": "wisdom"}, {"end": 1731.4, "start": 1731.12, "text": "that"}, {"end": 1731.4, "start": 1731.4, "text": "we've"}, {"end": 1731.6, "start": 1731.4, "text": "developed"}, {"end": 1731.92, "start": 1731.6, "text": "over"}, {"end": 1732.08, "start": 1731.92, "text": "the"}, {"end": 1732.48, "start": 1732.08, "text": "past"}, {"end": 1732.8, "start": 1732.48, "text": "20"}, {"end": 1732.8, "start": 1732.8, "text": "years"}, {"end": 1732.84, "start": 1732.8, "text": "or"}, {"end": 1733.2, "start": 1732.84, "text": "so,"}, {"end": 1733.56, "start": 1733.2, "text": "15"}, {"end": 1733.56, "start": 1733.56, "text": "or"}, {"end": 1734.12, "start": 1733.56, "text": "20"}, {"end": 1734.44, "start": 1734.12, "text": "years"}, {"end": 1735.16, "start": 1734.44, "text": "is,"}, {"end": 1735.28, "start": 1735.16, "text": "you"}, {"end": 1735.76, "start": 1735.28, "text": "could,"}, {"end": 1736.36, "start": 1735.76, "text": "because"}, {"end": 1736.4, "start": 1736.36, "text": "of"}, {"end": 1736.52, "start": 1736.4, "text": "the"}, {"end": 1737.04, "start": 1736.52, "text": "underlying"}, {"end": 1737.56, "start": 1737.04, "text": "performance"}, {"end": 1738.32, "start": 1737.56, "text": "improvements"}, {"end": 1738.52, "start": 1738.32, "text": "in"}, {"end": 1738.6, "start": 1738.52, "text": "the"}, {"end": 1739.12, "start": 1738.6, "text": "hardware"}, {"end": 1739.96, "start": 1739.12, "text": "architecture,"}], "text": " So what are the implications of these trends? I believe that a single general purpose server architecture cannot generalize to all application needs because of huge variability in per service system balance. So what does this mean? It means that for the, let's say, the conventional wisdom that we've developed over the past 20 years or so, 15 or 20 years is, you could, because of the underlying performance improvements in the hardware architecture,"}, {"chunks": [{"end": 1740.64, "start": 1740.0, "text": "Average"}, {"end": 1740.92, "start": 1740.64, "text": "a"}, {"end": 1741.4, "start": 1740.92, "text": "basically"}, {"end": 1742.0, "start": 1741.4, "text": "one"}, {"end": 1742.28, "start": 1742.0, "text": "general"}, {"end": 1742.56, "start": 1742.28, "text": "purpose"}, {"end": 1743.2, "start": 1742.56, "text": "design"}, {"end": 1744.04, "start": 1743.2, "text": "deploy"}, {"end": 1744.56, "start": 1744.04, "text": "many,"}, {"end": 1744.84, "start": 1744.56, "text": "many"}, {"end": 1744.88, "start": 1744.84, "text": "tens"}, {"end": 1744.92, "start": 1744.88, "text": "of"}, {"end": 1745.6, "start": 1744.92, "text": "thousands"}, {"end": 1745.72, "start": 1745.6, "text": "of"}, {"end": 1745.88, "start": 1745.72, "text": "it"}, {"end": 1746.0, "start": 1745.88, "text": "and"}, {"end": 1746.44, "start": 1746.0, "text": "use"}, {"end": 1746.52, "start": 1746.44, "text": "it"}, {"end": 1746.52, "start": 1746.52, "text": "as"}, {"end": 1746.56, "start": 1746.52, "text": "the"}, {"end": 1746.96, "start": 1746.56, "text": "basis"}, {"end": 1747.4, "start": 1746.96, "text": "for"}, {"end": 1747.68, "start": 1747.4, "text": "all"}, {"end": 1747.68, "start": 1747.68, "text": "of"}, {"end": 1747.72, "start": 1747.68, "text": "your"}, {"end": 1748.2, "start": 1747.72, "text": "compute"}, {"end": 1748.72, "start": 1748.2, "text": "with"}, {"end": 1750.08, "start": 1748.72, "text": "substantial"}, {"end": 1750.6, "start": 1750.08, "text": "average"}, {"end": 1751.48, "start": 1750.6, "text": "efficiency"}, {"end": 1751.8, "start": 1751.48, "text": "for"}, {"end": 1751.88, "start": 1751.8, "text": "all"}, {"end": 1751.96, "start": 1751.88, "text": "of"}, {"end": 1752.52, "start": 1751.96, "text": "them."}, {"end": 1753.28, "start": 1752.52, "text": "Okay."}, {"end": 1753.96, "start": 1753.28, "text": "That"}, {"end": 1754.12, "start": 1753.96, "text": "one"}, {"end": 1754.48, "start": 1754.12, "text": "single"}, {"end": 1754.76, "start": 1754.48, "text": "general"}, {"end": 1755.08, "start": 1754.76, "text": "purpose"}, {"end": 1755.48, "start": 1755.08, "text": "architecture"}, {"end": 1756.0, "start": 1755.48, "text": "might"}, {"end": 1756.0, "start": 1756.0, "text": "not"}, {"end": 1756.0, "start": 1756.0, "text": "be"}, {"end": 1756.08, "start": 1756.0, "text": "perfect"}, {"end": 1756.48, "start": 1756.08, "text": "for"}, {"end": 1756.52, "start": 1756.48, "text": "any"}, {"end": 1757.04, "start": 1756.52, "text": "one"}, {"end": 1757.68, "start": 1757.04, "text": "application"}, {"end": 1757.8, "start": 1757.68, "text": "or"}, {"end": 1757.8, "start": 1757.8, "text": "it"}, {"end": 1758.08, "start": 1757.8, "text": "might"}, {"end": 1758.08, "start": 1758.08, "text": "be"}, {"end": 1758.08, "start": 1758.08, "text": "perfect"}, {"end": 1758.24, "start": 1758.08, "text": "for"}, {"end": 1758.44, "start": 1758.24, "text": "only"}, {"end": 1758.64, "start": 1758.44, "text": "a"}, {"end": 1758.92, "start": 1758.64, "text": "small"}, {"end": 1759.16, "start": 1758.92, "text": "number"}, {"end": 1759.48, "start": 1759.16, "text": "of"}, {"end": 1760.28, "start": 1759.48, "text": "applications,"}, {"end": 1760.56, "start": 1760.28, "text": "but"}, {"end": 1760.6, "start": 1760.56, "text": "it"}, {"end": 1761.0, "start": 1760.6, "text": "would"}, {"end": 1761.48, "start": 1761.0, "text": "average"}, {"end": 1761.72, "start": 1761.48, "text": "out"}, {"end": 1761.84, "start": 1761.72, "text": "to"}, {"end": 1761.96, "start": 1761.84, "text": "be"}, {"end": 1762.6, "start": 1761.96, "text": "terrific"}, {"end": 1763.0, "start": 1762.6, "text": "across"}, {"end": 1763.04, "start": 1763.0, "text": "the"}, {"end": 1763.28, "start": 1763.04, "text": "board."}, {"end": 1764.6, "start": 1763.28, "text": "That's"}, {"end": 1764.76, "start": 1764.6, "text": "no"}, {"end": 1764.76, "start": 1764.76, "text": "longer"}, {"end": 1764.76, "start": 1764.76, "text": "the"}, {"end": 1765.52, "start": 1764.76, "text": "case"}, {"end": 1765.88, "start": 1765.52, "text": "because"}, {"end": 1766.0, "start": 1765.88, "text": "the"}, {"end": 1766.2, "start": 1766.0, "text": "underlying"}, {"end": 1766.68, "start": 1766.2, "text": "performance"}, {"end": 1767.24, "start": 1766.68, "text": "improvements"}, {"end": 1767.48, "start": 1767.24, "text": "are"}, {"end": 1767.96, "start": 1767.48, "text": "slowing"}, {"end": 1768.08, "start": 1767.96, "text": "and"}, {"end": 1768.24, "start": 1768.08, "text": "stopping."}, {"end": 1768.6, "start": 1768.24, "text": "And"}, {"end": 1768.92, "start": 1768.6, "text": "because"}, {"end": 1768.96, "start": 1768.92, "text": "we're"}, {"end": 1769.12, "start": 1768.96, "text": "seeing"}, {"end": 1769.24, "start": 1769.12, "text": "an"}, {"end": 1769.96, "start": 1769.24, "text": "explosion"}], "text": " Average a basically one general purpose design deploy many, many tens of thousands of it and use it as the basis for all of your compute with substantial average efficiency for all of them. Okay. That one single general purpose architecture might not be perfect for any one application or it might be perfect for only a small number of applications, but it would average out to be terrific across the board. That's no longer the case because the underlying performance improvements are slowing and stopping. And because we're seeing an explosion"}, {"chunks": [{"end": 1770.28, "start": 1770.0, "text": "in"}, {"end": 1770.36, "start": 1770.28, "text": "the"}, {"end": 1770.76, "start": 1770.36, "text": "variety"}, {"end": 1771.2, "start": 1770.76, "text": "and"}, {"end": 1771.92, "start": 1771.2, "text": "heterogeneity"}, {"end": 1772.12, "start": 1771.92, "text": "of"}, {"end": 1772.52, "start": 1772.12, "text": "applications."}, {"end": 1772.84, "start": 1772.52, "text": "What"}, {"end": 1774.48, "start": 1772.84, "text": "this"}, {"end": 1775.24, "start": 1774.48, "text": "means"}, {"end": 1775.48, "start": 1775.24, "text": "is"}, {"end": 1775.76, "start": 1775.48, "text": "that"}, {"end": 1776.08, "start": 1775.76, "text": "domain"}, {"end": 1776.32, "start": 1776.08, "text": "and"}, {"end": 1777.16, "start": 1776.32, "text": "application-specific"}, {"end": 1778.0, "start": 1777.16, "text": "accelerators"}, {"end": 1778.2, "start": 1778.0, "text": "are"}, {"end": 1778.24, "start": 1778.2, "text": "going"}, {"end": 1778.4, "start": 1778.24, "text": "to"}, {"end": 1778.88, "start": 1778.4, "text": "now"}, {"end": 1779.36, "start": 1778.88, "text": "proliferate."}, {"end": 1779.36, "start": 1779.36, "text": "In"}, {"end": 1779.6, "start": 1779.36, "text": "the"}, {"end": 1780.08, "start": 1779.6, "text": "past,"}, {"end": 1780.2, "start": 1780.08, "text": "we"}, {"end": 1780.92, "start": 1780.2, "text": "could"}, {"end": 1781.68, "start": 1780.92, "text": "basically"}, {"end": 1782.16, "start": 1781.68, "text": "ignore"}, {"end": 1782.76, "start": 1782.16, "text": "2x"}, {"end": 1783.12, "start": 1782.76, "text": "performance"}, {"end": 1783.84, "start": 1783.12, "text": "improvements."}, {"end": 1783.84, "start": 1783.84, "text": "We"}, {"end": 1783.84, "start": 1783.84, "text": "could"}, {"end": 1783.92, "start": 1783.84, "text": "often"}, {"end": 1784.72, "start": 1783.92, "text": "ignore"}, {"end": 1785.2, "start": 1784.72, "text": "10x"}, {"end": 1785.56, "start": 1785.2, "text": "performance"}, {"end": 1786.36, "start": 1785.56, "text": "improvements"}, {"end": 1786.84, "start": 1786.36, "text": "because"}, {"end": 1787.08, "start": 1786.84, "text": "the"}, {"end": 1787.32, "start": 1787.08, "text": "rate"}, {"end": 1787.44, "start": 1787.32, "text": "at"}, {"end": 1787.68, "start": 1787.44, "text": "which"}, {"end": 1787.96, "start": 1787.68, "text": "general"}, {"end": 1788.48, "start": 1787.96, "text": "purpose"}, {"end": 1789.0, "start": 1788.48, "text": "compute"}, {"end": 1789.32, "start": 1789.0, "text": "was"}, {"end": 1789.64, "start": 1789.32, "text": "improving"}, {"end": 1789.76, "start": 1789.64, "text": "was"}, {"end": 1790.04, "start": 1789.76, "text": "so"}, {"end": 1790.72, "start": 1790.04, "text": "fast"}, {"end": 1791.0, "start": 1790.72, "text": "that"}, {"end": 1791.0, "start": 1791.0, "text": "we"}, {"end": 1791.24, "start": 1791.0, "text": "couldn't"}, {"end": 1791.72, "start": 1791.24, "text": "basically"}, {"end": 1792.12, "start": 1791.72, "text": "figure"}, {"end": 1792.44, "start": 1792.12, "text": "out"}, {"end": 1792.44, "start": 1792.44, "text": "how"}, {"end": 1792.44, "start": 1792.44, "text": "to"}, {"end": 1792.6, "start": 1792.44, "text": "take"}, {"end": 1793.04, "start": 1792.6, "text": "advantage"}, {"end": 1793.32, "start": 1793.04, "text": "of"}, {"end": 1793.32, "start": 1793.32, "text": "a"}, {"end": 1793.48, "start": 1793.32, "text": "new"}, {"end": 1794.32, "start": 1793.48, "text": "accelerator"}, {"end": 1794.64, "start": 1794.32, "text": "fast"}, {"end": 1794.88, "start": 1794.64, "text": "enough"}, {"end": 1794.96, "start": 1794.88, "text": "from,"}, {"end": 1795.28, "start": 1794.96, "text": "let's"}, {"end": 1795.28, "start": 1795.28, "text": "say,"}, {"end": 1795.28, "start": 1795.28, "text": "a"}, {"end": 1796.04, "start": 1795.28, "text": "programming"}, {"end": 1796.28, "start": 1796.04, "text": "model"}, {"end": 1796.64, "start": 1796.28, "text": "perspective,"}, {"end": 1796.64, "start": 1796.64, "text": "or"}, {"end": 1796.68, "start": 1796.64, "text": "it"}, {"end": 1796.92, "start": 1796.68, "text": "wouldn't"}, {"end": 1797.04, "start": 1796.92, "text": "be"}, {"end": 1797.76, "start": 1797.04, "text": "widely"}, {"end": 1798.28, "start": 1797.76, "text": "available"}, {"end": 1798.6, "start": 1798.28, "text": "enough"}, {"end": 1799.08, "start": 1798.6, "text": "relative"}, {"end": 1799.32, "start": 1799.08, "text": "to"}, {"end": 1799.6, "start": 1799.32, "text": "general"}, {"end": 1799.96, "start": 1799.6, "text": "purpose"}], "text": " in the variety and heterogeneity of applications. What this means is that domain and application-specific accelerators are going to now proliferate. In the past, we could basically ignore 2x performance improvements. We could often ignore 10x performance improvements because the rate at which general purpose compute was improving was so fast that we couldn't basically figure out how to take advantage of a new accelerator fast enough from, let's say, a programming model perspective, or it wouldn't be widely available enough relative to general purpose"}, {"chunks": [{"end": 1800.4, "start": 1800.0, "text": "where"}, {"end": 1800.56, "start": 1800.4, "text": "it"}, {"end": 1801.68, "start": 1800.56, "text": "would"}, {"end": 1802.2, "start": 1801.68, "text": "matter."}, {"end": 1802.64, "start": 1802.2, "text": "That"}, {"end": 1802.84, "start": 1802.64, "text": "trend"}, {"end": 1802.96, "start": 1802.84, "text": "is"}, {"end": 1803.16, "start": 1802.96, "text": "going"}, {"end": 1803.44, "start": 1803.16, "text": "to"}, {"end": 1803.72, "start": 1803.44, "text": "end."}, {"end": 1803.92, "start": 1803.72, "text": "And"}, {"end": 1803.92, "start": 1803.92, "text": "what"}, {"end": 1804.12, "start": 1803.92, "text": "that"}, {"end": 1804.56, "start": 1804.12, "text": "means"}, {"end": 1804.8, "start": 1804.56, "text": "is"}, {"end": 1804.84, "start": 1804.8, "text": "that"}, {"end": 1805.0, "start": 1804.84, "text": "given"}, {"end": 1805.2, "start": 1805.0, "text": "that"}, {"end": 1805.24, "start": 1805.2, "text": "we"}, {"end": 1805.68, "start": 1805.24, "text": "can't"}, {"end": 1806.6, "start": 1805.68, "text": "ignore"}, {"end": 1806.92, "start": 1806.6, "text": "the"}, {"end": 1807.44, "start": 1806.92, "text": "benefits"}, {"end": 1807.64, "start": 1807.44, "text": "of"}, {"end": 1807.64, "start": 1807.64, "text": "general"}, {"end": 1807.84, "start": 1807.64, "text": "purpose"}, {"end": 1808.6, "start": 1807.84, "text": "accelerators,"}, {"end": 1808.6, "start": 1808.6, "text": "we're"}, {"end": 1808.64, "start": 1808.6, "text": "going"}, {"end": 1808.92, "start": 1808.64, "text": "to"}, {"end": 1809.12, "start": 1808.92, "text": "see"}, {"end": 1809.48, "start": 1809.12, "text": "more"}, {"end": 1809.64, "start": 1809.48, "text": "of"}, {"end": 1809.8, "start": 1809.64, "text": "them"}, {"end": 1810.2, "start": 1809.8, "text": "with"}, {"end": 1810.92, "start": 1810.2, "text": "GPUs"}, {"end": 1810.92, "start": 1810.92, "text": "and"}, {"end": 1811.16, "start": 1810.92, "text": "TPUs"}, {"end": 1811.24, "start": 1811.16, "text": "being"}, {"end": 1811.6, "start": 1811.24, "text": "just"}, {"end": 1811.76, "start": 1811.6, "text": "one"}, {"end": 1812.44, "start": 1811.76, "text": "example."}, {"end": 1812.68, "start": 1812.44, "text": "Finally,"}, {"end": 1812.76, "start": 1812.68, "text": "what"}, {"end": 1813.52, "start": 1812.76, "text": "we're"}, {"end": 1813.84, "start": 1813.52, "text": "seeing"}, {"end": 1814.28, "start": 1813.84, "text": "is"}, {"end": 1815.2, "start": 1814.28, "text": "that"}, {"end": 1815.8, "start": 1815.2, "text": "individual"}, {"end": 1816.24, "start": 1815.8, "text": "hardware"}, {"end": 1816.8, "start": 1816.24, "text": "elements"}, {"end": 1817.08, "start": 1816.8, "text": "are"}, {"end": 1817.36, "start": 1817.08, "text": "getting"}, {"end": 1817.56, "start": 1817.36, "text": "ever"}, {"end": 1818.0, "start": 1817.56, "text": "larger"}, {"end": 1818.12, "start": 1818.0, "text": "to"}, {"end": 1818.64, "start": 1818.12, "text": "amortize"}, {"end": 1819.0, "start": 1818.64, "text": "fixed"}, {"end": 1819.4, "start": 1819.0, "text": "costs."}, {"end": 1820.24, "start": 1819.4, "text": "So"}, {"end": 1820.28, "start": 1820.24, "text": "one"}, {"end": 1820.28, "start": 1820.28, "text": "of"}, {"end": 1820.36, "start": 1820.28, "text": "the"}, {"end": 1820.76, "start": 1820.36, "text": "ways"}, {"end": 1820.76, "start": 1820.76, "text": "that"}, {"end": 1820.76, "start": 1820.76, "text": "the"}, {"end": 1820.76, "start": 1820.76, "text": "community"}, {"end": 1820.76, "start": 1820.76, "text": "correctly"}, {"end": 1820.84, "start": 1820.76, "text": "is"}, {"end": 1821.48, "start": 1820.84, "text": "combating"}, {"end": 1822.32, "start": 1821.48, "text": "the"}, {"end": 1823.36, "start": 1822.32, "text": "trends"}, {"end": 1823.64, "start": 1823.36, "text": "that"}, {"end": 1823.8, "start": 1823.64, "text": "they're"}, {"end": 1824.12, "start": 1823.8, "text": "seeing"}, {"end": 1824.4, "start": 1824.12, "text": "is"}, {"end": 1824.56, "start": 1824.4, "text": "they're"}, {"end": 1824.96, "start": 1824.56, "text": "building"}, {"end": 1825.08, "start": 1824.96, "text": "ever"}, {"end": 1825.44, "start": 1825.08, "text": "larger"}, {"end": 1826.2, "start": 1825.44, "text": "CPUs,"}, {"end": 1827.0, "start": 1826.2, "text": "SSDs,"}, {"end": 1827.76, "start": 1827.0, "text": "GPUs,"}, {"end": 1828.48, "start": 1827.76, "text": "TPUs,"}, {"end": 1828.88, "start": 1828.48, "text": "DRAM"}, {"end": 1829.44, "start": 1828.88, "text": "modules,"}, {"end": 1829.6, "start": 1829.44, "text": "and"}, {"end": 1829.96, "start": 1829.6, "text": "NICs."}], "text": " where it would matter. That trend is going to end. And what that means is that given that we can't ignore the benefits of general purpose accelerators, we're going to see more of them with GPUs and TPUs being just one example. Finally, what we're seeing is that individual hardware elements are getting ever larger to amortize fixed costs. So one of the ways that the community correctly is combating the trends that they're seeing is they're building ever larger CPUs, SSDs, GPUs, TPUs, DRAM modules, and NICs."}, {"chunks": [{"end": 1830.68, "start": 1830.0, "text": "switches"}, {"end": 1830.76, "start": 1830.68, "text": "and"}, {"end": 1830.96, "start": 1830.76, "text": "even"}, {"end": 1831.08, "start": 1830.96, "text": "new"}, {"end": 1832.2, "start": 1831.08, "text": "accelerators."}, {"end": 1832.84, "start": 1832.2, "text": "But"}, {"end": 1832.92, "start": 1832.84, "text": "each"}, {"end": 1833.24, "start": 1832.92, "text": "individual"}, {"end": 1833.32, "start": 1833.24, "text": "one"}, {"end": 1833.8, "start": 1833.32, "text": "is"}, {"end": 1834.04, "start": 1833.8, "text": "so"}, {"end": 1834.6, "start": 1834.04, "text": "large"}, {"end": 1834.92, "start": 1834.6, "text": "that"}, {"end": 1835.08, "start": 1834.92, "text": "it"}, {"end": 1835.6, "start": 1835.08, "text": "cannot"}, {"end": 1836.68, "start": 1835.6, "text": "necessarily,"}, {"end": 1837.0, "start": 1836.68, "text": "it's"}, {"end": 1837.56, "start": 1837.0, "text": "not"}, {"end": 1838.0, "start": 1837.56, "text": "necessarily"}, {"end": 1838.32, "start": 1838.0, "text": "needed"}, {"end": 1838.88, "start": 1838.32, "text": "for"}, {"end": 1838.88, "start": 1838.88, "text": "all"}, {"end": 1839.48, "start": 1838.88, "text": "applications,"}, {"end": 1839.8, "start": 1839.48, "text": "tipping"}, {"end": 1840.16, "start": 1839.8, "text": "system"}, {"end": 1840.64, "start": 1840.16, "text": "balance"}, {"end": 1840.68, "start": 1840.64, "text": "in"}, {"end": 1840.76, "start": 1840.68, "text": "one"}, {"end": 1841.08, "start": 1840.76, "text": "direction"}, {"end": 1841.32, "start": 1841.08, "text": "or"}, {"end": 1841.68, "start": 1841.32, "text": "another."}, {"end": 1841.96, "start": 1841.68, "text": "And"}, {"end": 1842.24, "start": 1841.96, "text": "then"}, {"end": 1842.68, "start": 1842.24, "text": "furthermore,"}, {"end": 1842.84, "start": 1842.68, "text": "it's"}, {"end": 1843.44, "start": 1842.84, "text": "actually"}, {"end": 1843.44, "start": 1843.44, "text": "even"}, {"end": 1844.4, "start": 1843.44, "text": "making"}, {"end": 1844.76, "start": 1844.4, "text": "reliability"}, {"end": 1845.4, "start": 1844.76, "text": "harder"}, {"end": 1845.64, "start": 1845.4, "text": "as"}, {"end": 1845.88, "start": 1845.64, "text": "these"}, {"end": 1846.4, "start": 1845.88, "text": "individual"}, {"end": 1846.68, "start": 1846.4, "text": "elements"}, {"end": 1846.68, "start": 1846.68, "text": "are"}, {"end": 1846.96, "start": 1846.68, "text": "becoming"}, {"end": 1847.28, "start": 1846.96, "text": "larger"}, {"end": 1847.32, "start": 1847.28, "text": "and"}, {"end": 1847.52, "start": 1847.32, "text": "larger."}, {"end": 1849.48, "start": 1847.52, "text": "So"}, {"end": 1849.88, "start": 1849.48, "text": "what"}, {"end": 1850.16, "start": 1849.88, "text": "are"}, {"end": 1850.72, "start": 1850.16, "text": "the"}, {"end": 1851.92, "start": 1850.72, "text": "implications"}, {"end": 1852.28, "start": 1851.92, "text": "of"}, {"end": 1852.44, "start": 1852.28, "text": "these"}, {"end": 1852.76, "start": 1852.44, "text": "trends?"}, {"end": 1853.08, "start": 1852.76, "text": "As"}, {"end": 1853.52, "start": 1853.08, "text": "we're"}, {"end": 1854.24, "start": 1853.52, "text": "basically"}, {"end": 1854.6, "start": 1854.24, "text": "facing"}, {"end": 1854.68, "start": 1854.6, "text": "a"}, {"end": 1855.76, "start": 1854.68, "text": "slowdown"}, {"end": 1856.0, "start": 1855.76, "text": "in"}, {"end": 1856.44, "start": 1856.0, "text": "the"}, {"end": 1856.96, "start": 1856.44, "text": "underlying"}, {"end": 1857.48, "start": 1856.96, "text": "exponential"}, {"end": 1857.88, "start": 1857.48, "text": "growth"}, {"end": 1858.12, "start": 1857.88, "text": "of"}, {"end": 1858.16, "start": 1858.12, "text": "the"}, {"end": 1858.4, "start": 1858.16, "text": "capability"}, {"end": 1858.4, "start": 1858.4, "text": "of"}, {"end": 1858.52, "start": 1858.4, "text": "the"}, {"end": 1859.12, "start": 1858.52, "text": "hardware,"}, {"end": 1859.76, "start": 1859.12, "text": "we're"}, {"end": 1859.96, "start": 1859.76, "text": "seeing"}], "text": " switches and even new accelerators. But each individual one is so large that it cannot necessarily, it's not necessarily needed for all applications, tipping system balance in one direction or another. And then furthermore, it's actually even making reliability harder as these individual elements are becoming larger and larger. So what are the implications of these trends? As we're basically facing a slowdown in the underlying exponential growth of the capability of the hardware, we're seeing"}, {"chunks": [{"end": 1860.2, "start": 1860.0, "text": "Many,"}, {"end": 1860.48, "start": 1860.2, "text": "many"}, {"end": 1861.12, "start": 1860.48, "text": "opportunities,"}, {"end": 1861.24, "start": 1861.12, "text": "many"}, {"end": 1861.92, "start": 1861.24, "text": "hard"}, {"end": 1862.2, "start": 1861.92, "text": "opportunities"}, {"end": 1862.64, "start": 1862.2, "text": "arise"}, {"end": 1862.64, "start": 1862.64, "text": "at"}, {"end": 1862.76, "start": 1862.64, "text": "the"}, {"end": 1863.16, "start": 1862.76, "text": "beginning"}, {"end": 1863.28, "start": 1863.16, "text": "of"}, {"end": 1863.48, "start": 1863.28, "text": "Epoch"}, {"end": 1863.56, "start": 1863.48, "text": "V."}, {"end": 1864.32, "start": 1863.56, "text": "I"}, {"end": 1864.52, "start": 1864.32, "text": "believe"}, {"end": 1864.96, "start": 1864.52, "text": "that"}, {"end": 1865.36, "start": 1864.96, "text": "there"}, {"end": 1865.76, "start": 1865.36, "text": "is"}, {"end": 1866.12, "start": 1865.76, "text": "a"}, {"end": 1866.52, "start": 1866.12, "text": "greater"}, {"end": 1866.52, "start": 1866.52, "text": "than"}, {"end": 1867.0, "start": 1866.52, "text": "10x"}, {"end": 1867.84, "start": 1867.0, "text": "opportunity"}, {"end": 1868.0, "start": 1867.84, "text": "in"}, {"end": 1868.56, "start": 1868.0, "text": "scale-out"}, {"end": 1869.04, "start": 1868.56, "text": "efficiency"}, {"end": 1869.36, "start": 1869.04, "text": "of"}, {"end": 1869.72, "start": 1869.36, "text": "our"}, {"end": 1870.2, "start": 1869.72, "text": "distributed"}, {"end": 1870.8, "start": 1870.2, "text": "infrastructure"}, {"end": 1870.92, "start": 1870.8, "text": "and"}, {"end": 1871.12, "start": 1870.92, "text": "being"}, {"end": 1871.2, "start": 1871.12, "text": "able"}, {"end": 1871.24, "start": 1871.2, "text": "to"}, {"end": 1872.48, "start": 1871.24, "text": "leverage"}, {"end": 1872.68, "start": 1872.48, "text": "tightly"}, {"end": 1872.8, "start": 1872.68, "text": "coupled"}, {"end": 1873.4, "start": 1872.8, "text": "distributed"}, {"end": 1873.88, "start": 1873.4, "text": "computing"}, {"end": 1874.0, "start": 1873.88, "text": "and"}, {"end": 1875.2, "start": 1874.0, "text": "communication."}, {"end": 1875.68, "start": 1875.2, "text": "So"}, {"end": 1876.24, "start": 1875.68, "text": "one"}, {"end": 1876.52, "start": 1876.24, "text": "way"}, {"end": 1876.52, "start": 1876.52, "text": "to"}, {"end": 1876.8, "start": 1876.52, "text": "look"}, {"end": 1877.12, "start": 1876.8, "text": "at"}, {"end": 1877.12, "start": 1877.12, "text": "it,"}, {"end": 1877.28, "start": 1877.12, "text": "again,"}, {"end": 1877.6, "start": 1877.28, "text": "as"}, {"end": 1877.6, "start": 1877.6, "text": "a"}, {"end": 1877.88, "start": 1877.6, "text": "cartoon"}, {"end": 1878.52, "start": 1877.88, "text": "is,"}, {"end": 1878.64, "start": 1878.52, "text": "we've"}, {"end": 1878.68, "start": 1878.64, "text": "been"}, {"end": 1879.12, "start": 1878.68, "text": "on"}, {"end": 1879.48, "start": 1879.12, "text": "the"}, {"end": 1879.56, "start": 1879.48, "text": "blue"}, {"end": 1880.12, "start": 1879.56, "text": "curve."}, {"end": 1880.12, "start": 1880.12, "text": "We've"}, {"end": 1880.2, "start": 1880.12, "text": "built"}, {"end": 1880.48, "start": 1880.2, "text": "our"}, {"end": 1881.28, "start": 1880.48, "text": "distributed"}, {"end": 1881.6, "start": 1881.28, "text": "systems"}, {"end": 1881.64, "start": 1881.6, "text": "with"}, {"end": 1882.16, "start": 1881.64, "text": "loose"}, {"end": 1883.12, "start": 1882.16, "text": "coupling,"}, {"end": 1883.36, "start": 1883.12, "text": "and"}, {"end": 1883.72, "start": 1883.36, "text": "we've"}, {"end": 1884.24, "start": 1883.72, "text": "lived"}, {"end": 1884.92, "start": 1884.24, "text": "with"}, {"end": 1885.52, "start": 1884.92, "text": "relatively"}, {"end": 1886.04, "start": 1885.52, "text": "modest"}, {"end": 1886.52, "start": 1886.04, "text": "efficiency."}, {"end": 1886.88, "start": 1886.52, "text": "So"}, {"end": 1886.88, "start": 1886.88, "text": "in"}, {"end": 1886.92, "start": 1886.88, "text": "other"}, {"end": 1887.24, "start": 1886.92, "text": "words,"}, {"end": 1887.36, "start": 1887.24, "text": "the"}, {"end": 1888.0, "start": 1887.36, "text": "performance"}, {"end": 1888.36, "start": 1888.0, "text": "scaling,"}, {"end": 1888.72, "start": 1888.36, "text": "while"}, {"end": 1888.8, "start": 1888.72, "text": "linear,"}, {"end": 1889.32, "start": 1888.8, "text": "for"}, {"end": 1889.52, "start": 1889.32, "text": "our"}, {"end": 1889.72, "start": 1889.52, "text": "loosely"}, {"end": 1889.96, "start": 1889.72, "text": "coupled"}], "text": " Many, many opportunities, many hard opportunities arise at the beginning of Epoch V. I believe that there is a greater than 10x opportunity in scale-out efficiency of our distributed infrastructure and being able to leverage tightly coupled distributed computing and communication. So one way to look at it, again, as a cartoon is, we've been on the blue curve. We've built our distributed systems with loose coupling, and we've lived with relatively modest efficiency. So in other words, the performance scaling, while linear, for our loosely coupled"}, {"chunks": [{"end": 1890.44, "start": 1890.0, "text": "distributed"}, {"end": 1891.24, "start": 1890.44, "text": "systems"}, {"end": 1891.96, "start": 1891.24, "text": "has"}, {"end": 1892.32, "start": 1891.96, "text": "gone"}, {"end": 1892.56, "start": 1892.32, "text": "out"}, {"end": 1892.56, "start": 1892.56, "text": "infinitely"}, {"end": 1892.84, "start": 1892.56, "text": "far."}, {"end": 1892.88, "start": 1892.84, "text": "So"}, {"end": 1892.96, "start": 1892.88, "text": "we"}, {"end": 1893.28, "start": 1892.96, "text": "could"}, {"end": 1893.64, "start": 1893.28, "text": "scale"}, {"end": 1893.96, "start": 1893.64, "text": "out"}, {"end": 1894.2, "start": 1893.96, "text": "to"}, {"end": 1894.8, "start": 1894.2, "text": "1,000,"}, {"end": 1895.36, "start": 1894.8, "text": "10,000,"}, {"end": 1896.12, "start": 1895.36, "text": "20,000,"}, {"end": 1896.48, "start": 1896.12, "text": "perhaps"}, {"end": 1896.88, "start": 1896.48, "text": "50,000"}, {"end": 1897.6, "start": 1896.88, "text": "servers"}, {"end": 1897.68, "start": 1897.6, "text": "and"}, {"end": 1897.96, "start": 1897.68, "text": "keep"}, {"end": 1898.24, "start": 1897.96, "text": "getting"}, {"end": 1898.76, "start": 1898.24, "text": "incremental"}, {"end": 1899.4, "start": 1898.76, "text": "wins."}, {"end": 1899.96, "start": 1899.4, "text": "We're"}, {"end": 1900.36, "start": 1899.96, "text": "now"}, {"end": 1900.52, "start": 1900.36, "text": "at"}, {"end": 1900.56, "start": 1900.52, "text": "a"}, {"end": 1900.88, "start": 1900.56, "text": "point,"}, {"end": 1901.48, "start": 1900.88, "text": "though,"}, {"end": 1901.8, "start": 1901.48, "text": "now"}, {"end": 1901.84, "start": 1901.8, "text": "we're"}, {"end": 1902.08, "start": 1901.84, "text": "doing"}, {"end": 1902.52, "start": 1902.08, "text": "so"}, {"end": 1903.0, "start": 1902.52, "text": "given"}, {"end": 1903.28, "start": 1903.0, "text": "the"}, {"end": 1903.92, "start": 1903.28, "text": "slowing"}, {"end": 1904.12, "start": 1903.92, "text": "of"}, {"end": 1904.12, "start": 1904.12, "text": "the"}, {"end": 1904.6, "start": 1904.12, "text": "benefits"}, {"end": 1904.72, "start": 1904.6, "text": "from"}, {"end": 1904.92, "start": 1904.72, "text": "each"}, {"end": 1905.2, "start": 1904.92, "text": "individual"}, {"end": 1905.6, "start": 1905.2, "text": "server"}, {"end": 1905.72, "start": 1905.6, "text": "from"}, {"end": 1906.24, "start": 1905.72, "text": "generation"}, {"end": 1906.28, "start": 1906.24, "text": "to"}, {"end": 1907.32, "start": 1906.28, "text": "generation,"}, {"end": 1907.72, "start": 1907.32, "text": "where"}, {"end": 1907.72, "start": 1907.72, "text": "we"}, {"end": 1908.08, "start": 1907.72, "text": "probably"}, {"end": 1908.72, "start": 1908.08, "text": "have"}, {"end": 1909.0, "start": 1908.72, "text": "to"}, {"end": 1909.44, "start": 1909.0, "text": "revisit"}, {"end": 1909.64, "start": 1909.44, "text": "and"}, {"end": 1910.08, "start": 1909.64, "text": "look"}, {"end": 1910.08, "start": 1910.08, "text": "at"}, {"end": 1910.44, "start": 1910.08, "text": "tight"}, {"end": 1910.64, "start": 1910.44, "text": "coupling."}, {"end": 1911.24, "start": 1910.64, "text": "Basically,"}, {"end": 1911.72, "start": 1911.24, "text": "what's"}, {"end": 1911.88, "start": 1911.72, "text": "it"}, {"end": 1912.0, "start": 1911.88, "text": "going"}, {"end": 1912.04, "start": 1912.0, "text": "to"}, {"end": 1912.04, "start": 1912.04, "text": "take"}, {"end": 1912.52, "start": 1912.04, "text": "to"}, {"end": 1912.56, "start": 1912.52, "text": "have"}, {"end": 1912.88, "start": 1912.56, "text": "much"}, {"end": 1913.12, "start": 1912.88, "text": "more"}, {"end": 1913.96, "start": 1913.12, "text": "efficiency"}, {"end": 1914.44, "start": 1913.96, "text": "on"}, {"end": 1914.44, "start": 1914.44, "text": "a"}, {"end": 1914.56, "start": 1914.44, "text": "per"}, {"end": 1914.88, "start": 1914.56, "text": "server"}, {"end": 1915.36, "start": 1914.88, "text": "basis,"}, {"end": 1915.68, "start": 1915.36, "text": "even"}, {"end": 1915.72, "start": 1915.68, "text": "if"}, {"end": 1915.84, "start": 1915.72, "text": "it"}, {"end": 1916.24, "start": 1915.84, "text": "means"}, {"end": 1916.52, "start": 1916.24, "text": "that"}, {"end": 1916.6, "start": 1916.52, "text": "you"}, {"end": 1917.0, "start": 1916.6, "text": "flatten"}, {"end": 1917.08, "start": 1917.0, "text": "out"}, {"end": 1917.2, "start": 1917.08, "text": "the"}, {"end": 1917.2, "start": 1917.2, "text": "curve"}, {"end": 1917.2, "start": 1917.2, "text": "much"}, {"end": 1917.64, "start": 1917.2, "text": "earlier"}, {"end": 1918.08, "start": 1917.64, "text": "because"}, {"end": 1918.28, "start": 1918.08, "text": "of"}, {"end": 1918.88, "start": 1918.28, "text": "inherent"}, {"end": 1919.8, "start": 1918.88, "text": "overheads"}, {"end": 1919.96, "start": 1919.8, "text": "that"}], "text": " distributed systems has gone out infinitely far. So we could scale out to 1,000, 10,000, 20,000, perhaps 50,000 servers and keep getting incremental wins. We're now at a point, though, now we're doing so given the slowing of the benefits from each individual server from generation to generation, where we probably have to revisit and look at tight coupling. Basically, what's it going to take to have much more efficiency on a per server basis, even if it means that you flatten out the curve much earlier because of inherent overheads that"}, {"chunks": [{"end": 1920.28, "start": 1920.0, "text": "I'm"}, {"end": 1920.28, "start": 1920.28, "text": "going"}, {"end": 1920.28, "start": 1920.28, "text": "to"}, {"end": 1920.56, "start": 1920.28, "text": "introduce"}, {"end": 1920.84, "start": 1920.56, "text": "from"}, {"end": 1921.28, "start": 1920.84, "text": "tight"}, {"end": 1922.04, "start": 1921.28, "text": "coupling."}, {"end": 1922.32, "start": 1922.04, "text": "I"}, {"end": 1922.56, "start": 1922.32, "text": "think"}, {"end": 1922.8, "start": 1922.56, "text": "the"}, {"end": 1923.12, "start": 1922.8, "text": "Triton"}, {"end": 1923.36, "start": 1923.12, "text": "sort"}, {"end": 1923.8, "start": 1923.36, "text": "example"}, {"end": 1924.16, "start": 1923.8, "text": "is"}, {"end": 1924.44, "start": 1924.16, "text": "one"}, {"end": 1924.64, "start": 1924.44, "text": "that"}, {"end": 1924.76, "start": 1924.64, "text": "you"}, {"end": 1924.8, "start": 1924.76, "text": "could"}, {"end": 1924.96, "start": 1924.8, "text": "take"}, {"end": 1925.6, "start": 1924.96, "text": "away."}, {"end": 1925.76, "start": 1925.6, "text": "Are"}, {"end": 1926.08, "start": 1925.76, "text": "you"}, {"end": 1926.12, "start": 1926.08, "text": "willing"}, {"end": 1926.24, "start": 1926.12, "text": "to"}, {"end": 1926.48, "start": 1926.24, "text": "take"}, {"end": 1926.56, "start": 1926.48, "text": "a"}, {"end": 1927.4, "start": 1926.56, "text": "100x"}, {"end": 1927.8, "start": 1927.4, "text": "improvement,"}, {"end": 1927.96, "start": 1927.8, "text": "let's"}, {"end": 1928.2, "start": 1927.96, "text": "say,"}, {"end": 1928.4, "start": 1928.2, "text": "in"}, {"end": 1928.84, "start": 1928.4, "text": "efficiency"}, {"end": 1929.36, "start": 1928.84, "text": "in"}, {"end": 1929.92, "start": 1929.36, "text": "exchange"}, {"end": 1930.12, "start": 1929.92, "text": "for"}, {"end": 1930.68, "start": 1930.12, "text": "perhaps"}, {"end": 1930.76, "start": 1930.68, "text": "limiting"}, {"end": 1930.88, "start": 1930.76, "text": "your"}, {"end": 1932.44, "start": 1930.88, "text": "scale,"}, {"end": 1932.76, "start": 1932.44, "text": "maximum"}, {"end": 1934.12, "start": 1932.76, "text": "scale?"}, {"end": 1934.48, "start": 1934.12, "text": "Okay,"}, {"end": 1934.84, "start": 1934.48, "text": "so"}, {"end": 1935.16, "start": 1934.84, "text": "that's"}, {"end": 1935.44, "start": 1935.16, "text": "one"}, {"end": 1935.92, "start": 1935.44, "text": "10x"}, {"end": 1936.6, "start": 1935.92, "text": "opportunity."}, {"end": 1937.04, "start": 1936.6, "text": "Another"}, {"end": 1937.52, "start": 1937.04, "text": "10x"}, {"end": 1938.12, "start": 1937.52, "text": "opportunity"}, {"end": 1938.52, "start": 1938.12, "text": "is"}, {"end": 1939.04, "start": 1938.52, "text": "matching"}, {"end": 1939.76, "start": 1939.04, "text": "application"}, {"end": 1940.36, "start": 1939.76, "text": "balance"}, {"end": 1940.64, "start": 1940.36, "text": "to"}, {"end": 1940.8, "start": 1940.64, "text": "your"}, {"end": 1941.12, "start": 1940.8, "text": "virtual"}, {"end": 1941.44, "start": 1941.12, "text": "server"}, {"end": 1941.72, "start": 1941.44, "text": "or"}, {"end": 1942.28, "start": 1941.72, "text": "cluster"}, {"end": 1942.8, "start": 1942.28, "text": "composition."}, {"end": 1942.8, "start": 1942.8, "text": "And"}, {"end": 1942.8, "start": 1942.8, "text": "this"}, {"end": 1943.04, "start": 1942.8, "text": "is"}, {"end": 1943.28, "start": 1943.04, "text": "where"}, {"end": 1943.36, "start": 1943.28, "text": "a"}, {"end": 1944.44, "start": 1943.36, "text": "software-defined"}, {"end": 1945.2, "start": 1944.44, "text": "infrastructure"}, {"end": 1945.56, "start": 1945.2, "text": "can"}, {"end": 1945.84, "start": 1945.56, "text": "come"}, {"end": 1945.88, "start": 1945.84, "text": "into"}, {"end": 1946.32, "start": 1945.88, "text": "play."}, {"end": 1946.8, "start": 1946.32, "text": "Essentially,"}, {"end": 1947.12, "start": 1946.8, "text": "imagine"}, {"end": 1947.36, "start": 1947.12, "text": "being"}, {"end": 1947.56, "start": 1947.36, "text": "able"}, {"end": 1947.76, "start": 1947.56, "text": "to"}, {"end": 1948.36, "start": 1947.76, "text": "extract"}, {"end": 1948.56, "start": 1948.36, "text": "the"}, {"end": 1949.24, "start": 1948.56, "text": "balance"}, {"end": 1949.6, "start": 1949.24, "text": "points"}, {"end": 1949.64, "start": 1949.6, "text": "for"}, {"end": 1949.96, "start": 1949.64, "text": "a"}], "text": " I'm going to introduce from tight coupling. I think the Triton sort example is one that you could take away. Are you willing to take a 100x improvement, let's say, in efficiency in exchange for perhaps limiting your scale, maximum scale? Okay, so that's one 10x opportunity. Another 10x opportunity is matching application balance to your virtual server or cluster composition. And this is where a software-defined infrastructure can come into play. Essentially, imagine being able to extract the balance points for a"}, {"chunks": [{"end": 1950.44, "start": 1950.0, "text": "particular"}, {"end": 1950.92, "start": 1950.44, "text": "distributed"}, {"end": 1951.56, "start": 1950.92, "text": "computation"}, {"end": 1951.88, "start": 1951.56, "text": "and"}, {"end": 1952.0, "start": 1951.88, "text": "being"}, {"end": 1952.4, "start": 1952.0, "text": "able"}, {"end": 1952.64, "start": 1952.4, "text": "to"}, {"end": 1953.04, "start": 1952.64, "text": "carve"}, {"end": 1953.56, "start": 1953.04, "text": "out"}, {"end": 1953.8, "start": 1953.56, "text": "an"}, {"end": 1954.44, "start": 1953.8, "text": "isolated"}, {"end": 1955.24, "start": 1954.44, "text": "subset"}, {"end": 1955.4, "start": 1955.24, "text": "of"}, {"end": 1955.8, "start": 1955.4, "text": "your"}, {"end": 1956.48, "start": 1955.8, "text": "compute,"}, {"end": 1957.44, "start": 1956.48, "text": "communication,"}, {"end": 1958.52, "start": 1957.44, "text": "accelerator,"}, {"end": 1958.84, "start": 1958.52, "text": "and"}, {"end": 1959.16, "start": 1958.84, "text": "storage"}, {"end": 1959.92, "start": 1959.16, "text": "infrastructure"}, {"end": 1960.04, "start": 1959.92, "text": "to"}, {"end": 1960.48, "start": 1960.04, "text": "match"}, {"end": 1960.52, "start": 1960.48, "text": "that"}, {"end": 1960.96, "start": 1960.52, "text": "balance"}, {"end": 1961.2, "start": 1960.96, "text": "point."}, {"end": 1961.2, "start": 1961.2, "text": "I"}, {"end": 1961.68, "start": 1961.2, "text": "believe"}, {"end": 1961.96, "start": 1961.68, "text": "there's"}, {"end": 1962.32, "start": 1961.96, "text": "at"}, {"end": 1962.56, "start": 1962.32, "text": "least"}, {"end": 1962.56, "start": 1962.56, "text": "a"}, {"end": 1963.0, "start": 1962.56, "text": "10x"}, {"end": 1963.48, "start": 1963.0, "text": "opportunity"}, {"end": 1963.6, "start": 1963.48, "text": "and"}, {"end": 1963.96, "start": 1963.6, "text": "efficiency"}, {"end": 1964.84, "start": 1963.96, "text": "there."}, {"end": 1965.12, "start": 1964.84, "text": "And"}, {"end": 1965.44, "start": 1965.12, "text": "then"}, {"end": 1965.96, "start": 1965.44, "text": "finally,"}, {"end": 1966.4, "start": 1965.96, "text": "there"}, {"end": 1966.8, "start": 1966.4, "text": "is"}, {"end": 1966.96, "start": 1966.8, "text": "a"}, {"end": 1967.12, "start": 1966.96, "text": "greater"}, {"end": 1967.44, "start": 1967.12, "text": "than"}, {"end": 1967.84, "start": 1967.44, "text": "10x"}, {"end": 1968.4, "start": 1967.84, "text": "opportunity"}, {"end": 1968.52, "start": 1968.4, "text": "in"}, {"end": 1969.0, "start": 1968.52, "text": "distributed"}, {"end": 1969.48, "start": 1969.0, "text": "systems"}, {"end": 1969.96, "start": 1969.48, "text": "developer"}, {"end": 1969.96, "start": 1969.96, "text": "productivity."}, {"end": 1970.0, "start": 1969.96, "text": "Go"}, {"end": 1970.2, "start": 1970.0, "text": "back"}, {"end": 1970.2, "start": 1970.2, "text": "to"}, {"end": 1970.2, "start": 1970.2, "text": "the"}, {"end": 1970.24, "start": 1970.2, "text": "source"}, {"end": 1970.44, "start": 1970.24, "text": "system"}, {"end": 1970.48, "start": 1970.44, "text": "that"}, {"end": 1970.56, "start": 1970.48, "text": "we"}, {"end": 1971.84, "start": 1970.56, "text": "built"}, {"end": 1972.28, "start": 1971.84, "text": "where"}, {"end": 1972.28, "start": 1972.28, "text": "we"}, {"end": 1972.28, "start": 1972.28, "text": "left"}, {"end": 1972.28, "start": 1972.28, "text": "the"}, {"end": 1973.12, "start": 1972.28, "text": "factor"}, {"end": 1973.48, "start": 1973.12, "text": "four"}, {"end": 1973.88, "start": 1973.48, "text": "on"}, {"end": 1974.4, "start": 1973.88, "text": "the"}, {"end": 1974.6, "start": 1974.4, "text": "table,"}, {"end": 1974.88, "start": 1974.6, "text": "and"}, {"end": 1975.52, "start": 1974.88, "text": "that's"}, {"end": 1975.96, "start": 1975.52, "text": "just"}, {"end": 1976.04, "start": 1975.96, "text": "one"}, {"end": 1976.52, "start": 1976.04, "text": "example."}, {"end": 1976.88, "start": 1976.52, "text": "That's"}, {"end": 1977.04, "start": 1976.88, "text": "one"}, {"end": 1977.48, "start": 1977.04, "text": "example"}, {"end": 1977.76, "start": 1977.48, "text": "where"}, {"end": 1977.76, "start": 1977.76, "text": "we"}, {"end": 1978.0, "start": 1977.76, "text": "were"}, {"end": 1978.2, "start": 1978.0, "text": "able"}, {"end": 1978.44, "start": 1978.2, "text": "to"}, {"end": 1978.44, "start": 1978.44, "text": "do"}, {"end": 1978.88, "start": 1978.44, "text": "extreme"}, {"end": 1979.4, "start": 1978.88, "text": "amounts"}, {"end": 1979.52, "start": 1979.4, "text": "of"}, {"end": 1979.96, "start": 1979.52, "text": "performance"}], "text": " particular distributed computation and being able to carve out an isolated subset of your compute, communication, accelerator, and storage infrastructure to match that balance point. I believe there's at least a 10x opportunity and efficiency there. And then finally, there is a greater than 10x opportunity in distributed systems developer productivity. Go back to the source system that we built where we left the factor four on the table, and that's just one example. That's one example where we were able to do extreme amounts of performance"}, {"chunks": [{"end": 1980.48, "start": 1980.0, "text": "performance"}, {"end": 1980.72, "start": 1980.48, "text": "work."}, {"end": 1981.32, "start": 1980.72, "text": "Imagine"}, {"end": 1981.96, "start": 1981.32, "text": "that"}, {"end": 1982.44, "start": 1981.96, "text": "actually"}, {"end": 1982.92, "start": 1982.44, "text": "most"}, {"end": 1983.72, "start": 1982.92, "text": "developers"}, {"end": 1984.0, "start": 1983.72, "text": "don't"}, {"end": 1984.4, "start": 1984.0, "text": "necessarily"}, {"end": 1984.6, "start": 1984.4, "text": "have"}, {"end": 1984.68, "start": 1984.6, "text": "the"}, {"end": 1985.52, "start": 1984.68, "text": "expertise"}, {"end": 1985.52, "start": 1985.52, "text": "to"}, {"end": 1985.6, "start": 1985.52, "text": "be"}, {"end": 1986.0, "start": 1985.6, "text": "able"}, {"end": 1986.32, "start": 1986.0, "text": "to"}, {"end": 1986.36, "start": 1986.32, "text": "debug"}, {"end": 1986.6, "start": 1986.36, "text": "the"}, {"end": 1986.96, "start": 1986.6, "text": "large"}, {"end": 1987.04, "start": 1986.96, "text": "scale"}, {"end": 1987.4, "start": 1987.04, "text": "distributed"}, {"end": 1987.68, "start": 1987.4, "text": "system."}, {"end": 1987.76, "start": 1987.68, "text": "And"}, {"end": 1987.96, "start": 1987.76, "text": "that"}, {"end": 1988.12, "start": 1987.96, "text": "is"}, {"end": 1988.4, "start": 1988.12, "text": "only"}, {"end": 1988.64, "start": 1988.4, "text": "for"}, {"end": 1988.68, "start": 1988.64, "text": "a"}, {"end": 1989.12, "start": 1988.68, "text": "very"}, {"end": 1989.36, "start": 1989.12, "text": "small"}, {"end": 1989.88, "start": 1989.36, "text": "subset"}, {"end": 1990.04, "start": 1989.88, "text": "of"}, {"end": 1990.16, "start": 1990.04, "text": "these"}, {"end": 1990.48, "start": 1990.16, "text": "pieces"}, {"end": 1990.76, "start": 1990.48, "text": "of"}, {"end": 1991.88, "start": 1990.76, "text": "infrastructure"}, {"end": 1992.16, "start": 1991.88, "text": "that"}, {"end": 1992.2, "start": 1992.16, "text": "we"}, {"end": 1992.44, "start": 1992.2, "text": "do"}, {"end": 1994.0, "start": 1992.44, "text": "performance"}, {"end": 1994.68, "start": 1994.0, "text": "efficiency"}, {"end": 1994.96, "start": 1994.68, "text": "work"}, {"end": 1995.36, "start": 1994.96, "text": "across"}, {"end": 1995.36, "start": 1995.36, "text": "the"}, {"end": 1995.6, "start": 1995.36, "text": "community."}, {"end": 1996.48, "start": 1995.6, "text": "So"}, {"end": 1997.08, "start": 1996.48, "text": "basically,"}, {"end": 1997.36, "start": 1997.08, "text": "what"}, {"end": 1997.6, "start": 1997.36, "text": "tooling"}, {"end": 1997.92, "start": 1997.6, "text": "can"}, {"end": 1998.12, "start": 1997.92, "text": "we"}, {"end": 1998.52, "start": 1998.12, "text": "provide?"}, {"end": 1998.88, "start": 1998.52, "text": "What"}, {"end": 1999.36, "start": 1998.88, "text": "programming"}, {"end": 1999.92, "start": 1999.36, "text": "models"}, {"end": 2000.28, "start": 1999.92, "text": "can"}, {"end": 2000.32, "start": 2000.28, "text": "we"}, {"end": 2001.16, "start": 2000.32, "text": "provide"}, {"end": 2001.48, "start": 2001.16, "text": "where"}, {"end": 2001.84, "start": 2001.48, "text": "distributed"}, {"end": 2002.4, "start": 2001.84, "text": "systems"}, {"end": 2002.76, "start": 2002.4, "text": "efficiency"}, {"end": 2003.0, "start": 2002.76, "text": "comes"}, {"end": 2003.28, "start": 2003.0, "text": "from,"}, {"end": 2003.44, "start": 2003.28, "text": "let's"}, {"end": 2003.64, "start": 2003.44, "text": "say,"}, {"end": 2004.16, "start": 2003.64, "text": "runtime,"}, {"end": 2004.72, "start": 2004.16, "text": "comes"}, {"end": 2004.88, "start": 2004.72, "text": "from"}, {"end": 2004.96, "start": 2004.88, "text": "a"}, {"end": 2005.56, "start": 2004.96, "text": "compiler"}, {"end": 2005.96, "start": 2005.56, "text": "rather"}, {"end": 2006.44, "start": 2005.96, "text": "than"}, {"end": 2006.72, "start": 2006.44, "text": "from"}, {"end": 2006.92, "start": 2006.72, "text": "human"}, {"end": 2007.68, "start": 2006.92, "text": "expertise."}, {"end": 2008.68, "start": 2007.68, "text": "Combined"}, {"end": 2008.96, "start": 2008.68, "text": "across"}, {"end": 2009.56, "start": 2008.96, "text": "these"}, {"end": 2009.64, "start": 2009.56, "text": "three,"}, {"end": 2009.96, "start": 2009.64, "text": "I"}], "text": " performance work. Imagine that actually most developers don't necessarily have the expertise to be able to debug the large scale distributed system. And that is only for a very small subset of these pieces of infrastructure that we do performance efficiency work across the community. So basically, what tooling can we provide? What programming models can we provide where distributed systems efficiency comes from, let's say, runtime, comes from a compiler rather than from human expertise. Combined across these three, I"}, {"chunks": [{"end": 2010.2, "start": 2010.0, "text": "believe"}, {"end": 2010.36, "start": 2010.2, "text": "that"}, {"end": 2010.56, "start": 2010.36, "text": "there"}, {"end": 2010.8, "start": 2010.56, "text": "is"}, {"end": 2010.8, "start": 2010.8, "text": "a"}, {"end": 2011.2, "start": 2010.8, "text": "thousand"}, {"end": 2011.48, "start": 2011.2, "text": "X"}, {"end": 2011.96, "start": 2011.48, "text": "efficiency"}, {"end": 2012.24, "start": 2011.96, "text": "plus"}, {"end": 2012.88, "start": 2012.24, "text": "velocity"}, {"end": 2013.32, "start": 2012.88, "text": "roofline"}, {"end": 2013.92, "start": 2013.32, "text": "opportunity"}, {"end": 2014.4, "start": 2013.92, "text": "to"}, {"end": 2014.8, "start": 2014.4, "text": "sustain"}, {"end": 2015.32, "start": 2014.8, "text": "exponential"}, {"end": 2015.84, "start": 2015.32, "text": "growth."}, {"end": 2016.56, "start": 2015.84, "text": "None"}, {"end": 2016.68, "start": 2016.56, "text": "of"}, {"end": 2017.16, "start": 2016.68, "text": "these"}, {"end": 2017.4, "start": 2017.16, "text": "are"}, {"end": 2017.4, "start": 2017.4, "text": "gonna"}, {"end": 2018.36, "start": 2017.4, "text": "come"}, {"end": 2018.56, "start": 2018.36, "text": "easy."}, {"end": 2018.56, "start": 2018.56, "text": "I'm"}, {"end": 2018.76, "start": 2018.56, "text": "not"}, {"end": 2019.12, "start": 2018.76, "text": "at"}, {"end": 2019.36, "start": 2019.12, "text": "all"}, {"end": 2019.76, "start": 2019.36, "text": "claiming"}, {"end": 2020.12, "start": 2019.76, "text": "that"}, {"end": 2020.48, "start": 2020.12, "text": "these"}, {"end": 2020.68, "start": 2020.48, "text": "are"}, {"end": 2020.72, "start": 2020.68, "text": "easy"}, {"end": 2021.04, "start": 2020.72, "text": "problems"}, {"end": 2021.44, "start": 2021.04, "text": "that"}, {"end": 2021.8, "start": 2021.44, "text": "any"}, {"end": 2021.96, "start": 2021.8, "text": "one"}, {"end": 2021.96, "start": 2021.96, "text": "team,"}, {"end": 2022.04, "start": 2021.96, "text": "any"}, {"end": 2022.2, "start": 2022.04, "text": "one"}, {"end": 2022.52, "start": 2022.2, "text": "company,"}, {"end": 2022.52, "start": 2022.52, "text": "any"}, {"end": 2022.52, "start": 2022.52, "text": "one"}, {"end": 2022.52, "start": 2022.52, "text": "group"}, {"end": 2022.8, "start": 2022.52, "text": "can"}, {"end": 2023.04, "start": 2022.8, "text": "take"}, {"end": 2023.04, "start": 2023.04, "text": "on."}, {"end": 2023.16, "start": 2023.04, "text": "But"}, {"end": 2023.6, "start": 2023.16, "text": "I"}, {"end": 2023.68, "start": 2023.6, "text": "believe"}, {"end": 2023.88, "start": 2023.68, "text": "that"}, {"end": 2023.88, "start": 2023.88, "text": "it"}, {"end": 2024.36, "start": 2023.88, "text": "provides"}, {"end": 2024.48, "start": 2024.36, "text": "a"}, {"end": 2024.92, "start": 2024.48, "text": "framework"}, {"end": 2025.08, "start": 2024.92, "text": "for"}, {"end": 2025.4, "start": 2025.08, "text": "which"}, {"end": 2025.44, "start": 2025.4, "text": "we"}, {"end": 2025.64, "start": 2025.44, "text": "can"}, {"end": 2025.8, "start": 2025.64, "text": "continue"}, {"end": 2025.8, "start": 2025.8, "text": "the"}, {"end": 2026.48, "start": 2025.8, "text": "exponential"}, {"end": 2026.84, "start": 2026.48, "text": "growth"}, {"end": 2027.12, "start": 2026.84, "text": "of"}, {"end": 2027.32, "start": 2027.12, "text": "our"}, {"end": 2028.08, "start": 2027.32, "text": "infrastructure,"}, {"end": 2028.32, "start": 2028.08, "text": "working"}, {"end": 2028.48, "start": 2028.32, "text": "together"}, {"end": 2029.12, "start": 2028.48, "text": "as"}, {"end": 2029.16, "start": 2029.12, "text": "a"}, {"end": 2029.32, "start": 2029.16, "text": "community"}, {"end": 2029.76, "start": 2029.32, "text": "to"}, {"end": 2030.2, "start": 2029.76, "text": "go"}, {"end": 2030.56, "start": 2030.2, "text": "after"}, {"end": 2030.64, "start": 2030.56, "text": "each"}, {"end": 2030.84, "start": 2030.64, "text": "of"}, {"end": 2031.32, "start": 2030.84, "text": "these"}, {"end": 2035.76, "start": 2031.32, "text": "incrementally."}, {"end": 2036.24, "start": 2035.76, "text": "All"}, {"end": 2036.76, "start": 2036.24, "text": "right,"}, {"end": 2037.2, "start": 2036.76, "text": "so"}, {"end": 2037.52, "start": 2037.2, "text": "let's"}, {"end": 2037.56, "start": 2037.52, "text": "look"}, {"end": 2037.72, "start": 2037.56, "text": "at"}, {"end": 2037.88, "start": 2037.72, "text": "what"}, {"end": 2038.44, "start": 2037.88, "text": "this"}, {"end": 2039.32, "start": 2038.44, "text": "looks"}, {"end": 2039.96, "start": 2039.32, "text": "like"}], "text": " believe that there is a thousand X efficiency plus velocity roofline opportunity to sustain exponential growth. None of these are gonna come easy. I'm not at all claiming that these are easy problems that any one team, any one company, any one group can take on. But I believe that it provides a framework for which we can continue the exponential growth of our infrastructure, working together as a community to go after each of these incrementally. All right, so let's look at what this looks like"}, {"chunks": [{"end": 2040.2, "start": 2040.0, "text": "One"}, {"end": 2040.24, "start": 2040.2, "text": "observation"}, {"end": 2040.36, "start": 2040.24, "text": "is"}, {"end": 2041.04, "start": 2040.36, "text": "that"}, {"end": 2041.48, "start": 2041.04, "text": "while"}, {"end": 2041.92, "start": 2041.48, "text": "we"}, {"end": 2042.0, "start": 2041.92, "text": "figured"}, {"end": 2042.08, "start": 2042.0, "text": "out"}, {"end": 2042.8, "start": 2042.08, "text": "how"}, {"end": 2043.0, "start": 2042.8, "text": "to"}, {"end": 2043.68, "start": 2043.0, "text": "build"}, {"end": 2044.4, "start": 2043.68, "text": "ever"}, {"end": 2045.24, "start": 2044.4, "text": "larger"}, {"end": 2046.24, "start": 2045.24, "text": "clusters,"}, {"end": 2046.96, "start": 2046.24, "text": "10,000,"}, {"end": 2048.04, "start": 2046.96, "text": "20,000,"}, {"end": 2048.88, "start": 2048.04, "text": "50,000"}, {"end": 2049.72, "start": 2048.88, "text": "servers"}, {"end": 2050.28, "start": 2049.72, "text": "perhaps,"}, {"end": 2050.44, "start": 2050.28, "text": "it"}, {"end": 2050.72, "start": 2050.44, "text": "may"}, {"end": 2050.88, "start": 2050.72, "text": "be"}, {"end": 2051.24, "start": 2050.88, "text": "time"}, {"end": 2051.52, "start": 2051.24, "text": "to"}, {"end": 2051.8, "start": 2051.52, "text": "actually"}, {"end": 2052.0, "start": 2051.8, "text": "go"}, {"end": 2052.64, "start": 2052.0, "text": "back"}, {"end": 2053.0, "start": 2052.64, "text": "and"}, {"end": 2053.08, "start": 2053.0, "text": "think"}, {"end": 2053.44, "start": 2053.08, "text": "a"}, {"end": 2053.88, "start": 2053.44, "text": "little"}, {"end": 2054.2, "start": 2053.88, "text": "bit"}, {"end": 2054.76, "start": 2054.2, "text": "smaller."}, {"end": 2055.08, "start": 2054.76, "text": "Shall"}, {"end": 2055.24, "start": 2055.08, "text": "we"}, {"end": 2055.84, "start": 2055.24, "text": "transition"}, {"end": 2056.2, "start": 2055.84, "text": "from"}, {"end": 2057.08, "start": 2056.2, "text": "clusters"}, {"end": 2057.32, "start": 2057.08, "text": "as"}, {"end": 2057.32, "start": 2057.32, "text": "a"}, {"end": 2057.56, "start": 2057.32, "text": "basis"}, {"end": 2058.0, "start": 2057.56, "text": "for"}, {"end": 2059.0, "start": 2058.0, "text": "computation"}, {"end": 2059.16, "start": 2059.0, "text": "to"}, {"end": 2059.36, "start": 2059.16, "text": "thinking"}, {"end": 2059.6, "start": 2059.36, "text": "about"}, {"end": 2060.0, "start": 2059.6, "text": "cliques"}, {"end": 2060.32, "start": 2060.0, "text": "for"}, {"end": 2060.4, "start": 2060.32, "text": "a"}, {"end": 2061.12, "start": 2060.4, "text": "subset"}, {"end": 2061.2, "start": 2061.12, "text": "of"}, {"end": 2061.2, "start": 2061.2, "text": "our"}, {"end": 2062.04, "start": 2061.2, "text": "computation?"}, {"end": 2062.16, "start": 2062.04, "text": "What"}, {"end": 2062.24, "start": 2062.16, "text": "you"}, {"end": 2062.8, "start": 2062.24, "text": "can"}, {"end": 2063.4, "start": 2062.8, "text": "imagine"}, {"end": 2063.6, "start": 2063.4, "text": "is"}, {"end": 2063.8, "start": 2063.6, "text": "the"}, {"end": 2064.32, "start": 2063.8, "text": "bandwidth"}, {"end": 2064.72, "start": 2064.32, "text": "that"}, {"end": 2064.8, "start": 2064.72, "text": "you"}, {"end": 2065.0, "start": 2064.8, "text": "have"}, {"end": 2065.2, "start": 2065.0, "text": "among"}, {"end": 2065.52, "start": 2065.2, "text": "your"}, {"end": 2066.08, "start": 2065.52, "text": "servers"}, {"end": 2066.4, "start": 2066.08, "text": "is"}, {"end": 2066.44, "start": 2066.4, "text": "in"}, {"end": 2066.8, "start": 2066.44, "text": "the"}, {"end": 2067.08, "start": 2066.8, "text": "end"}, {"end": 2067.32, "start": 2067.08, "text": "going"}, {"end": 2067.32, "start": 2067.32, "text": "to"}, {"end": 2067.48, "start": 2067.32, "text": "be"}, {"end": 2067.88, "start": 2067.48, "text": "limited"}, {"end": 2068.24, "start": 2067.88, "text": "by"}, {"end": 2068.6, "start": 2068.24, "text": "physical"}, {"end": 2069.96, "start": 2068.6, "text": "radius."}], "text": " One observation is that while we figured out how to build ever larger clusters, 10,000, 20,000, 50,000 servers perhaps, it may be time to actually go back and think a little bit smaller. Shall we transition from clusters as a basis for computation to thinking about cliques for a subset of our computation? What you can imagine is the bandwidth that you have among your servers is in the end going to be limited by physical radius."}, {"chunks": [{"end": 2070.08, "start": 2070.0, "text": "So"}, {"end": 2070.44, "start": 2070.08, "text": "in"}, {"end": 2070.6, "start": 2070.44, "text": "a"}, {"end": 2071.0, "start": 2070.6, "text": "smaller"}, {"end": 2071.6, "start": 2071.0, "text": "scale"}, {"end": 2072.4, "start": 2071.6, "text": "setting,"}, {"end": 2073.48, "start": 2072.4, "text": "perhaps"}, {"end": 2073.68, "start": 2073.48, "text": "100,"}, {"end": 2074.0, "start": 2073.68, "text": "perhaps"}, {"end": 2074.36, "start": 2074.0, "text": "1,000"}, {"end": 2074.96, "start": 2074.36, "text": "servers,"}, {"end": 2075.28, "start": 2074.96, "text": "can"}, {"end": 2075.28, "start": 2075.28, "text": "you"}, {"end": 2075.68, "start": 2075.28, "text": "imagine"}, {"end": 2076.12, "start": 2075.68, "text": "delivering"}, {"end": 2076.52, "start": 2076.12, "text": "10x"}, {"end": 2077.2, "start": 2076.52, "text": "bandwidth,"}, {"end": 2077.8, "start": 2077.2, "text": "40x"}, {"end": 2077.96, "start": 2077.8, "text": "lower"}, {"end": 2078.32, "start": 2077.96, "text": "latency"}, {"end": 2078.52, "start": 2078.32, "text": "to"}, {"end": 2079.12, "start": 2078.52, "text": "200,000"}, {"end": 2079.52, "start": 2079.12, "text": "cores"}, {"end": 2079.64, "start": 2079.52, "text": "today?"}, {"end": 2080.28, "start": 2079.64, "text": "And"}, {"end": 2080.68, "start": 2080.28, "text": "I"}, {"end": 2080.76, "start": 2080.68, "text": "believe"}, {"end": 2080.88, "start": 2080.76, "text": "the"}, {"end": 2081.24, "start": 2080.88, "text": "answer"}, {"end": 2081.56, "start": 2081.24, "text": "is"}, {"end": 2082.16, "start": 2081.56, "text": "yes,"}, {"end": 2082.56, "start": 2082.16, "text": "and"}, {"end": 2082.76, "start": 2082.56, "text": "you"}, {"end": 2083.24, "start": 2082.76, "text": "can"}, {"end": 2083.24, "start": 2083.24, "text": "do"}, {"end": 2083.24, "start": 2083.24, "text": "it"}, {"end": 2083.68, "start": 2083.24, "text": "economically."}, {"end": 2084.64, "start": 2083.68, "text": "Can"}, {"end": 2084.84, "start": 2084.64, "text": "you"}, {"end": 2085.2, "start": 2084.84, "text": "then"}, {"end": 2085.56, "start": 2085.2, "text": "imagine"}, {"end": 2085.84, "start": 2085.56, "text": "having"}, {"end": 2086.48, "start": 2085.84, "text": "flexible"}, {"end": 2086.92, "start": 2086.48, "text": "compute,"}, {"end": 2087.64, "start": 2086.92, "text": "accelerator,"}, {"end": 2088.48, "start": 2087.64, "text": "flash,"}, {"end": 2089.08, "start": 2088.48, "text": "NVRAM"}, {"end": 2089.12, "start": 2089.08, "text": "and"}, {"end": 2089.44, "start": 2089.12, "text": "DRAM"}, {"end": 2090.0, "start": 2089.44, "text": "pools"}, {"end": 2090.04, "start": 2090.0, "text": "to"}, {"end": 2090.56, "start": 2090.04, "text": "be"}, {"end": 2091.04, "start": 2090.56, "text": "able"}, {"end": 2091.44, "start": 2091.04, "text": "to"}, {"end": 2091.96, "start": 2091.44, "text": "compose"}, {"end": 2092.2, "start": 2091.96, "text": "them"}, {"end": 2092.44, "start": 2092.2, "text": "for"}, {"end": 2093.0, "start": 2092.44, "text": "individual"}, {"end": 2095.76, "start": 2093.0, "text": "computations?"}, {"end": 2096.08, "start": 2095.76, "text": "So"}, {"end": 2096.12, "start": 2096.08, "text": "one"}, {"end": 2096.48, "start": 2096.12, "text": "view"}, {"end": 2097.04, "start": 2096.48, "text": "of"}, {"end": 2097.72, "start": 2097.04, "text": "software-defined"}, {"end": 2098.32, "start": 2097.72, "text": "infrastructure"}, {"end": 2098.36, "start": 2098.32, "text": "in"}, {"end": 2098.56, "start": 2098.36, "text": "such"}, {"end": 2099.0, "start": 2098.56, "text": "a"}, {"end": 2099.4, "start": 2099.0, "text": "smaller"}, {"end": 2099.96, "start": 2099.4, "text": "scale"}], "text": " So in a smaller scale setting, perhaps 100, perhaps 1,000 servers, can you imagine delivering 10x bandwidth, 40x lower latency to 200,000 cores today? And I believe the answer is yes, and you can do it economically. Can you then imagine having flexible compute, accelerator, flash, NVRAM and DRAM pools to be able to compose them for individual computations? So one view of software-defined infrastructure in such a smaller scale"}, {"chunks": [{"end": 2100.36, "start": 2100.0, "text": "Click"}, {"end": 2101.32, "start": 2100.36, "text": "world"}, {"end": 2101.52, "start": 2101.32, "text": "is"}, {"end": 2101.6, "start": 2101.52, "text": "being"}, {"end": 2102.2, "start": 2101.6, "text": "able"}, {"end": 2102.32, "start": 2102.2, "text": "to"}, {"end": 2102.96, "start": 2102.32, "text": "define"}, {"end": 2103.24, "start": 2102.96, "text": "virtual"}, {"end": 2104.32, "start": 2103.24, "text": "servers"}, {"end": 2104.56, "start": 2104.32, "text": "as"}, {"end": 2104.72, "start": 2104.56, "text": "the"}, {"end": 2105.12, "start": 2104.72, "text": "basis"}, {"end": 2106.04, "start": 2105.12, "text": "for"}, {"end": 2106.52, "start": 2106.04, "text": "building"}, {"end": 2107.2, "start": 2106.52, "text": "distributed"}, {"end": 2108.04, "start": 2107.2, "text": "computation."}, {"end": 2108.44, "start": 2108.04, "text": "Individual"}, {"end": 2108.92, "start": 2108.44, "text": "servers"}, {"end": 2108.92, "start": 2108.92, "text": "can"}, {"end": 2109.0, "start": 2108.92, "text": "be"}, {"end": 2109.4, "start": 2109.0, "text": "software"}, {"end": 2110.2, "start": 2109.4, "text": "defined"}, {"end": 2110.52, "start": 2110.2, "text": "based"}, {"end": 2110.64, "start": 2110.52, "text": "on"}, {"end": 2110.88, "start": 2110.64, "text": "per"}, {"end": 2111.08, "start": 2110.88, "text": "job"}, {"end": 2111.44, "start": 2111.08, "text": "system"}, {"end": 2112.04, "start": 2111.44, "text": "requirements."}, {"end": 2112.24, "start": 2112.04, "text": "And"}, {"end": 2112.24, "start": 2112.24, "text": "you"}, {"end": 2112.44, "start": 2112.24, "text": "can"}, {"end": 2112.92, "start": 2112.44, "text": "imagine"}, {"end": 2113.28, "start": 2112.92, "text": "composing"}, {"end": 2113.48, "start": 2113.28, "text": "them"}, {"end": 2113.48, "start": 2113.48, "text": "within"}, {"end": 2113.64, "start": 2113.48, "text": "a"}, {"end": 2114.44, "start": 2113.64, "text": "rack"}, {"end": 2114.56, "start": 2114.44, "text": "or"}, {"end": 2114.92, "start": 2114.56, "text": "smaller"}, {"end": 2115.24, "start": 2114.92, "text": "scale"}, {"end": 2116.0, "start": 2115.24, "text": "perhaps,"}, {"end": 2116.28, "start": 2116.0, "text": "but"}, {"end": 2116.76, "start": 2116.28, "text": "across"}, {"end": 2117.08, "start": 2116.76, "text": "a"}, {"end": 2117.32, "start": 2117.08, "text": "network"}, {"end": 2117.56, "start": 2117.32, "text": "in"}, {"end": 2117.68, "start": 2117.56, "text": "the"}, {"end": 2117.88, "start": 2117.68, "text": "end,"}, {"end": 2118.24, "start": 2117.88, "text": "across"}, {"end": 2118.64, "start": 2118.24, "text": "your"}, {"end": 2118.96, "start": 2118.64, "text": "pools"}, {"end": 2118.96, "start": 2118.96, "text": "of"}, {"end": 2119.08, "start": 2118.96, "text": "general"}, {"end": 2119.36, "start": 2119.08, "text": "purpose"}, {"end": 2119.96, "start": 2119.36, "text": "compute,"}, {"end": 2120.36, "start": 2119.96, "text": "across"}, {"end": 2120.36, "start": 2120.36, "text": "your"}, {"end": 2121.16, "start": 2120.36, "text": "accelerator,"}, {"end": 2121.52, "start": 2121.16, "text": "across"}, {"end": 2121.6, "start": 2121.52, "text": "your"}, {"end": 2122.16, "start": 2121.6, "text": "flash"}, {"end": 2122.64, "start": 2122.16, "text": "pool,"}, {"end": 2122.84, "start": 2122.64, "text": "your"}, {"end": 2123.2, "start": 2122.84, "text": "NVRAM"}, {"end": 2123.28, "start": 2123.2, "text": "pool"}, {"end": 2123.76, "start": 2123.28, "text": "or"}, {"end": 2124.0, "start": 2123.76, "text": "your"}, {"end": 2124.08, "start": 2124.0, "text": "DRAM"}, {"end": 2124.76, "start": 2124.08, "text": "pool."}, {"end": 2125.24, "start": 2124.76, "text": "Essentially,"}, {"end": 2125.56, "start": 2125.24, "text": "what"}, {"end": 2125.56, "start": 2125.56, "text": "do"}, {"end": 2125.56, "start": 2125.56, "text": "you"}, {"end": 2125.56, "start": 2125.56, "text": "need"}, {"end": 2125.8, "start": 2125.56, "text": "to"}, {"end": 2125.96, "start": 2125.8, "text": "hit"}, {"end": 2126.28, "start": 2125.96, "text": "the"}, {"end": 2126.52, "start": 2126.28, "text": "right"}, {"end": 2126.84, "start": 2126.52, "text": "system"}, {"end": 2127.36, "start": 2126.84, "text": "balance"}, {"end": 2127.56, "start": 2127.36, "text": "points"}, {"end": 2127.6, "start": 2127.56, "text": "to"}, {"end": 2127.6, "start": 2127.6, "text": "be"}, {"end": 2127.6, "start": 2127.6, "text": "able"}, {"end": 2128.08, "start": 2127.6, "text": "to"}, {"end": 2128.32, "start": 2128.08, "text": "run"}, {"end": 2128.6, "start": 2128.32, "text": "your"}, {"end": 2129.36, "start": 2128.6, "text": "computation"}, {"end": 2129.68, "start": 2129.36, "text": "most"}, {"end": 2129.96, "start": 2129.68, "text": "effective"}], "text": " Click world is being able to define virtual servers as the basis for building distributed computation. Individual servers can be software defined based on per job system requirements. And you can imagine composing them within a rack or smaller scale perhaps, but across a network in the end, across your pools of general purpose compute, across your accelerator, across your flash pool, your NVRAM pool or your DRAM pool. Essentially, what do you need to hit the right system balance points to be able to run your computation most effective"}, {"chunks": [{"end": 2130.64, "start": 2130.0, "text": "and"}, {"end": 2131.04, "start": 2130.64, "text": "then"}, {"end": 2131.2, "start": 2131.04, "text": "compose"}, {"end": 2131.72, "start": 2131.2, "text": "that"}, {"end": 2131.8, "start": 2131.72, "text": "out"}, {"end": 2131.8, "start": 2131.8, "text": "of"}, {"end": 2131.88, "start": 2131.8, "text": "the"}, {"end": 2132.56, "start": 2131.88, "text": "available"}, {"end": 2133.36, "start": 2132.56, "text": "resources"}, {"end": 2133.52, "start": 2133.36, "text": "within"}, {"end": 2133.68, "start": 2133.52, "text": "the"}, {"end": 2134.08, "start": 2133.68, "text": "clique"}, {"end": 2134.16, "start": 2134.08, "text": "or"}, {"end": 2134.64, "start": 2134.16, "text": "perhaps"}, {"end": 2134.72, "start": 2134.64, "text": "your"}, {"end": 2134.84, "start": 2134.72, "text": "RAC."}, {"end": 2135.6, "start": 2134.84, "text": "So"}, {"end": 2135.92, "start": 2135.6, "text": "that's"}, {"end": 2136.12, "start": 2135.92, "text": "one"}, {"end": 2136.52, "start": 2136.12, "text": "basis"}, {"end": 2136.72, "start": 2136.52, "text": "for"}, {"end": 2137.2, "start": 2136.72, "text": "software-defined"}, {"end": 2139.0, "start": 2137.2, "text": "infrastructure."}, {"end": 2139.56, "start": 2139.0, "text": "Now"}, {"end": 2139.64, "start": 2139.56, "text": "you"}, {"end": 2140.0, "start": 2139.64, "text": "can"}, {"end": 2140.36, "start": 2140.0, "text": "then"}, {"end": 2140.92, "start": 2140.36, "text": "generalize"}, {"end": 2140.96, "start": 2140.92, "text": "it"}, {"end": 2141.32, "start": 2140.96, "text": "and"}, {"end": 2141.64, "start": 2141.32, "text": "actually"}, {"end": 2142.08, "start": 2141.64, "text": "build"}, {"end": 2142.48, "start": 2142.08, "text": "your"}, {"end": 2142.56, "start": 2142.48, "text": "own"}, {"end": 2143.0, "start": 2142.56, "text": "dedicated"}, {"end": 2143.52, "start": 2143.0, "text": "cluster,"}, {"end": 2143.56, "start": 2143.52, "text": "if"}, {"end": 2143.6, "start": 2143.56, "text": "you"}, {"end": 2143.64, "start": 2143.6, "text": "will,"}, {"end": 2144.08, "start": 2143.64, "text": "virtual"}, {"end": 2144.6, "start": 2144.08, "text": "cluster"}, {"end": 2145.16, "start": 2144.6, "text": "for"}, {"end": 2145.52, "start": 2145.16, "text": "your"}, {"end": 2146.12, "start": 2145.52, "text": "distributed"}, {"end": 2147.76, "start": 2146.12, "text": "computation."}, {"end": 2147.88, "start": 2147.76, "text": "And"}, {"end": 2148.2, "start": 2147.88, "text": "this"}, {"end": 2148.24, "start": 2148.2, "text": "will"}, {"end": 2148.44, "start": 2148.24, "text": "then"}, {"end": 2148.64, "start": 2148.44, "text": "take"}, {"end": 2148.96, "start": 2148.64, "text": "into"}, {"end": 2149.56, "start": 2148.96, "text": "account"}, {"end": 2150.08, "start": 2149.56, "text": "the"}, {"end": 2150.32, "start": 2150.08, "text": "more"}, {"end": 2150.6, "start": 2150.32, "text": "global"}, {"end": 2151.28, "start": 2150.6, "text": "for"}, {"end": 2151.76, "start": 2151.28, "text": "your"}, {"end": 2152.12, "start": 2151.76, "text": "computation"}, {"end": 2152.4, "start": 2152.12, "text": "system"}, {"end": 2153.0, "start": 2152.4, "text": "balance"}, {"end": 2153.08, "start": 2153.0, "text": "point,"}, {"end": 2153.48, "start": 2153.08, "text": "not"}, {"end": 2153.92, "start": 2153.48, "text": "based"}, {"end": 2154.0, "start": 2153.92, "text": "on"}, {"end": 2154.48, "start": 2154.0, "text": "necessarily"}, {"end": 2154.56, "start": 2154.48, "text": "any"}, {"end": 2154.72, "start": 2154.56, "text": "one"}, {"end": 2155.24, "start": 2154.72, "text": "server"}, {"end": 2155.56, "start": 2155.24, "text": "because"}, {"end": 2155.96, "start": 2155.56, "text": "the"}, {"end": 2156.08, "start": 2155.96, "text": "individual"}, {"end": 2156.6, "start": 2156.08, "text": "virtual"}, {"end": 2157.12, "start": 2156.6, "text": "servers"}, {"end": 2157.12, "start": 2157.12, "text": "in"}, {"end": 2157.4, "start": 2157.12, "text": "your"}, {"end": 2157.88, "start": 2157.4, "text": "computation"}, {"end": 2158.2, "start": 2157.88, "text": "may"}, {"end": 2158.72, "start": 2158.2, "text": "have"}, {"end": 2159.2, "start": 2158.72, "text": "different"}, {"end": 2159.96, "start": 2159.2, "text": "requirements."}], "text": " and then compose that out of the available resources within the clique or perhaps your RAC. So that's one basis for software-defined infrastructure. Now you can then generalize it and actually build your own dedicated cluster, if you will, virtual cluster for your distributed computation. And this will then take into account the more global for your computation system balance point, not based on necessarily any one server because the individual virtual servers in your computation may have different requirements."}, {"chunks": [{"end": 2160.08, "start": 2160.0, "text": "But"}, {"end": 2160.32, "start": 2160.08, "text": "then"}, {"end": 2160.6, "start": 2160.32, "text": "how"}, {"end": 2161.0, "start": 2160.6, "text": "do"}, {"end": 2161.16, "start": 2161.0, "text": "you"}, {"end": 2161.48, "start": 2161.16, "text": "compose"}, {"end": 2161.56, "start": 2161.48, "text": "them"}, {"end": 2162.0, "start": 2161.56, "text": "together"}, {"end": 2162.0, "start": 2162.0, "text": "again"}, {"end": 2162.08, "start": 2162.0, "text": "with"}, {"end": 2162.4, "start": 2162.08, "text": "a"}, {"end": 2162.8, "start": 2162.4, "text": "network"}, {"end": 2163.12, "start": 2162.8, "text": "that"}, {"end": 2163.36, "start": 2163.12, "text": "can"}, {"end": 2163.76, "start": 2163.36, "text": "deliver"}, {"end": 2164.04, "start": 2163.76, "text": "the"}, {"end": 2164.36, "start": 2164.04, "text": "right"}, {"end": 2164.88, "start": 2164.36, "text": "level"}, {"end": 2165.16, "start": 2164.88, "text": "of"}, {"end": 2166.32, "start": 2165.16, "text": "predictability"}, {"end": 2166.64, "start": 2166.32, "text": "such"}, {"end": 2166.96, "start": 2166.64, "text": "that"}, {"end": 2167.0, "start": 2166.96, "text": "we"}, {"end": 2167.2, "start": 2167.0, "text": "can,"}, {"end": 2167.36, "start": 2167.2, "text": "I"}, {"end": 2167.68, "start": 2167.36, "text": "think,"}, {"end": 2168.2, "start": 2167.68, "text": "critically"}, {"end": 2168.48, "start": 2168.2, "text": "move"}, {"end": 2169.04, "start": 2168.48, "text": "away"}, {"end": 2169.32, "start": 2169.04, "text": "from"}, {"end": 2169.68, "start": 2169.32, "text": "the"}, {"end": 2170.24, "start": 2169.68, "text": "defensive"}, {"end": 2170.8, "start": 2170.24, "text": "programming"}, {"end": 2171.2, "start": 2170.8, "text": "models"}, {"end": 2171.36, "start": 2171.2, "text": "that"}, {"end": 2171.84, "start": 2171.36, "text": "destroys"}, {"end": 2172.28, "start": 2171.84, "text": "efficiency"}, {"end": 2172.88, "start": 2172.28, "text": "today."}, {"end": 2173.12, "start": 2172.88, "text": "So"}, {"end": 2173.8, "start": 2173.12, "text": "necessarily"}, {"end": 2174.04, "start": 2173.8, "text": "given"}, {"end": 2174.08, "start": 2174.04, "text": "the"}, {"end": 2174.64, "start": 2174.08, "text": "failure"}, {"end": 2174.8, "start": 2174.64, "text": "rates"}, {"end": 2175.24, "start": 2174.8, "text": "that"}, {"end": 2175.56, "start": 2175.24, "text": "we"}, {"end": 2176.32, "start": 2175.56, "text": "have"}, {"end": 2176.4, "start": 2176.32, "text": "in"}, {"end": 2176.68, "start": 2176.4, "text": "our"}, {"end": 2177.08, "start": 2176.68, "text": "network"}, {"end": 2177.24, "start": 2177.08, "text": "and"}, {"end": 2177.44, "start": 2177.24, "text": "the"}, {"end": 2177.48, "start": 2177.44, "text": "failure"}, {"end": 2178.28, "start": 2177.48, "text": "probabilities"}, {"end": 2178.88, "start": 2178.28, "text": "that"}, {"end": 2178.92, "start": 2178.88, "text": "we"}, {"end": 2179.0, "start": 2178.92, "text": "have"}, {"end": 2179.0, "start": 2179.0, "text": "in"}, {"end": 2179.12, "start": 2179.0, "text": "our"}, {"end": 2179.32, "start": 2179.12, "text": "network,"}, {"end": 2179.32, "start": 2179.32, "text": "we"}, {"end": 2179.36, "start": 2179.32, "text": "leave"}, {"end": 2179.72, "start": 2179.36, "text": "huge"}, {"end": 2180.08, "start": 2179.72, "text": "amounts"}, {"end": 2180.12, "start": 2180.08, "text": "of"}, {"end": 2180.72, "start": 2180.12, "text": "efficiency"}, {"end": 2180.76, "start": 2180.72, "text": "on"}, {"end": 2180.76, "start": 2180.76, "text": "the"}, {"end": 2181.2, "start": 2180.76, "text": "table"}, {"end": 2181.28, "start": 2181.2, "text": "as"}, {"end": 2181.52, "start": 2181.28, "text": "a"}, {"end": 2182.12, "start": 2181.52, "text": "result"}, {"end": 2182.16, "start": 2182.12, "text": "of"}, {"end": 2182.56, "start": 2182.16, "text": "forcing"}, {"end": 2183.28, "start": 2182.56, "text": "programmers"}, {"end": 2183.56, "start": 2183.28, "text": "to"}, {"end": 2183.72, "start": 2183.56, "text": "develop"}, {"end": 2184.04, "start": 2183.72, "text": "their"}, {"end": 2184.52, "start": 2184.04, "text": "code"}, {"end": 2184.84, "start": 2184.52, "text": "very,"}, {"end": 2185.12, "start": 2184.84, "text": "very"}, {"end": 2185.56, "start": 2185.12, "text": "defensively."}, {"end": 2187.4, "start": 2185.56, "text": "So"}, {"end": 2189.04, "start": 2187.4, "text": "let's"}, {"end": 2189.56, "start": 2189.04, "text": "start"}, {"end": 2189.56, "start": 2189.56, "text": "with"}, {"end": 2189.96, "start": 2189.56, "text": "the"}], "text": " But then how do you compose them together again with a network that can deliver the right level of predictability such that we can, I think, critically move away from the defensive programming models that destroys efficiency today. So necessarily given the failure rates that we have in our network and the failure probabilities that we have in our network, we leave huge amounts of efficiency on the table as a result of forcing programmers to develop their code very, very defensively. So let's start with the"}, {"chunks": [{"end": 2190.68, "start": 2190.0, "text": "Come"}, {"end": 2191.28, "start": 2190.68, "text": "back"}, {"end": 2191.6, "start": 2191.28, "text": "to"}, {"end": 2191.6, "start": 2191.6, "text": "the"}, {"end": 2191.64, "start": 2191.6, "text": "five"}, {"end": 2192.04, "start": 2191.64, "text": "epochs"}, {"end": 2192.12, "start": 2192.04, "text": "of"}, {"end": 2193.04, "start": 2192.12, "text": "distributed"}, {"end": 2193.52, "start": 2193.04, "text": "computing."}, {"end": 2193.52, "start": 2193.52, "text": "This"}, {"end": 2193.56, "start": 2193.52, "text": "is"}, {"end": 2193.92, "start": 2193.56, "text": "the"}, {"end": 2194.24, "start": 2193.92, "text": "original"}, {"end": 2194.24, "start": 2194.24, "text": "view"}, {"end": 2194.24, "start": 2194.24, "text": "of"}, {"end": 2194.28, "start": 2194.24, "text": "it"}, {"end": 2194.76, "start": 2194.28, "text": "that"}, {"end": 2195.28, "start": 2194.76, "text": "I"}, {"end": 2195.36, "start": 2195.28, "text": "put"}, {"end": 2195.44, "start": 2195.36, "text": "on."}, {"end": 2195.92, "start": 2195.44, "text": "But"}, {"end": 2196.0, "start": 2195.92, "text": "I"}, {"end": 2196.24, "start": 2196.0, "text": "think"}, {"end": 2196.56, "start": 2196.24, "text": "it's"}, {"end": 2196.84, "start": 2196.56, "text": "also"}, {"end": 2197.36, "start": 2196.84, "text": "instructive"}, {"end": 2197.68, "start": 2197.36, "text": "to"}, {"end": 2197.84, "start": 2197.68, "text": "look"}, {"end": 2198.16, "start": 2197.84, "text": "at"}, {"end": 2198.44, "start": 2198.16, "text": "how"}, {"end": 2198.84, "start": 2198.44, "text": "programming"}, {"end": 2199.32, "start": 2198.84, "text": "models"}, {"end": 2199.68, "start": 2199.32, "text": "have"}, {"end": 2200.16, "start": 2199.68, "text": "evolved"}, {"end": 2200.32, "start": 2200.16, "text": "over"}, {"end": 2200.72, "start": 2200.32, "text": "these"}, {"end": 2201.72, "start": 2200.72, "text": "epochs."}, {"end": 2202.52, "start": 2201.72, "text": "So"}, {"end": 2202.72, "start": 2202.52, "text": "moving"}, {"end": 2203.16, "start": 2202.72, "text": "across"}, {"end": 2203.68, "start": 2203.16, "text": "that"}, {"end": 2204.0, "start": 2203.68, "text": "box,"}, {"end": 2204.4, "start": 2204.0, "text": "what"}, {"end": 2204.48, "start": 2204.4, "text": "we"}, {"end": 2204.96, "start": 2204.48, "text": "can"}, {"end": 2205.16, "start": 2204.96, "text": "see"}, {"end": 2205.56, "start": 2205.16, "text": "is"}, {"end": 2206.04, "start": 2205.56, "text": "that"}, {"end": 2206.12, "start": 2206.04, "text": "with"}, {"end": 2206.12, "start": 2206.12, "text": "the"}, {"end": 2206.12, "start": 2206.12, "text": "birth"}, {"end": 2206.12, "start": 2206.12, "text": "of"}, {"end": 2206.12, "start": 2206.12, "text": "the"}, {"end": 2206.12, "start": 2206.12, "text": "internet,"}, {"end": 2206.6, "start": 2206.12, "text": "FTP,"}, {"end": 2206.92, "start": 2206.6, "text": "email,"}, {"end": 2207.8, "start": 2206.92, "text": "telnet,"}, {"end": 2208.56, "start": 2207.8, "text": "there"}, {"end": 2209.0, "start": 2208.56, "text": "was"}, {"end": 2209.16, "start": 2209.0, "text": "no"}, {"end": 2209.52, "start": 2209.16, "text": "concurrency"}, {"end": 2209.84, "start": 2209.52, "text": "model"}, {"end": 2209.92, "start": 2209.84, "text": "in"}, {"end": 2210.2, "start": 2209.92, "text": "building"}, {"end": 2210.24, "start": 2210.2, "text": "a"}, {"end": 2210.64, "start": 2210.24, "text": "distributed"}, {"end": 2211.32, "start": 2210.64, "text": "system."}, {"end": 2211.56, "start": 2211.32, "text": "Everything"}, {"end": 2212.0, "start": 2211.56, "text": "was"}, {"end": 2212.36, "start": 2212.0, "text": "sequential,"}, {"end": 2212.52, "start": 2212.36, "text": "and"}, {"end": 2212.52, "start": 2212.52, "text": "you"}, {"end": 2212.68, "start": 2212.52, "text": "put"}, {"end": 2213.16, "start": 2212.68, "text": "bytes"}, {"end": 2213.4, "start": 2213.16, "text": "on"}, {"end": 2213.4, "start": 2213.4, "text": "the"}, {"end": 2214.24, "start": 2213.4, "text": "wire."}, {"end": 2214.24, "start": 2214.24, "text": "In"}, {"end": 2214.32, "start": 2214.24, "text": "epoch"}, {"end": 2214.44, "start": 2214.32, "text": "two,"}, {"end": 2214.44, "start": 2214.44, "text": "as"}, {"end": 2214.44, "start": 2214.44, "text": "we"}, {"end": 2214.44, "start": 2214.44, "text": "moved"}, {"end": 2214.44, "start": 2214.44, "text": "to"}, {"end": 2215.52, "start": 2214.44, "text": "RPC,"}, {"end": 2216.8, "start": 2215.52, "text": "concurrency"}, {"end": 2217.48, "start": 2216.8, "text": "wound"}, {"end": 2217.68, "start": 2217.48, "text": "up"}, {"end": 2218.04, "start": 2217.68, "text": "being"}, {"end": 2218.8, "start": 2218.04, "text": "event-driven"}, {"end": 2219.48, "start": 2218.8, "text": "as"}, {"end": 2219.6, "start": 2219.48, "text": "a"}, {"end": 2219.96, "start": 2219.6, "text": "convenience"}], "text": " Come back to the five epochs of distributed computing. This is the original view of it that I put on. But I think it's also instructive to look at how programming models have evolved over these epochs. So moving across that box, what we can see is that with the birth of the internet, FTP, email, telnet, there was no concurrency model in building a distributed system. Everything was sequential, and you put bytes on the wire. In epoch two, as we moved to RPC, concurrency wound up being event-driven as a convenience"}, {"chunks": [{"end": 2220.68, "start": 2220.0, "text": "Think"}, {"end": 2220.84, "start": 2220.68, "text": "of"}, {"end": 2221.36, "start": 2220.84, "text": "your"}, {"end": 2221.96, "start": 2221.36, "text": "classic"}, {"end": 2222.6, "start": 2221.96, "text": "select"}, {"end": 2223.0, "start": 2222.6, "text": "loop"}, {"end": 2223.08, "start": 2223.0, "text": "in"}, {"end": 2223.32, "start": 2223.08, "text": "building"}, {"end": 2223.52, "start": 2223.32, "text": "your"}, {"end": 2223.6, "start": 2223.52, "text": "client"}, {"end": 2223.92, "start": 2223.6, "text": "server"}, {"end": 2224.48, "start": 2223.92, "text": "systems."}, {"end": 2224.8, "start": 2224.48, "text": "With"}, {"end": 2225.76, "start": 2224.8, "text": "epoch"}, {"end": 2225.92, "start": 2225.76, "text": "three,"}, {"end": 2226.48, "start": 2225.92, "text": "you"}, {"end": 2227.0, "start": 2226.48, "text": "started"}, {"end": 2227.4, "start": 2227.0, "text": "having"}, {"end": 2227.4, "start": 2227.4, "text": "to"}, {"end": 2227.6, "start": 2227.4, "text": "think"}, {"end": 2227.96, "start": 2227.6, "text": "about"}, {"end": 2229.04, "start": 2227.96, "text": "concurrency"}, {"end": 2229.76, "start": 2229.04, "text": "more"}, {"end": 2230.4, "start": 2229.76, "text": "seriously."}, {"end": 2230.68, "start": 2230.4, "text": "As"}, {"end": 2230.84, "start": 2230.68, "text": "we"}, {"end": 2230.84, "start": 2230.84, "text": "hit"}, {"end": 2230.92, "start": 2230.84, "text": "the"}, {"end": 2231.36, "start": 2230.92, "text": "IO"}, {"end": 2231.76, "start": 2231.36, "text": "wall,"}, {"end": 2231.84, "start": 2231.76, "text": "we"}, {"end": 2232.28, "start": 2231.84, "text": "had"}, {"end": 2232.28, "start": 2232.28, "text": "to"}, {"end": 2232.6, "start": 2232.28, "text": "develop"}, {"end": 2233.16, "start": 2232.6, "text": "multi-threaded"}, {"end": 2233.48, "start": 2233.16, "text": "code"}, {"end": 2233.68, "start": 2233.48, "text": "for"}, {"end": 2234.16, "start": 2233.68, "text": "efficiency."}, {"end": 2234.24, "start": 2234.16, "text": "In"}, {"end": 2234.36, "start": 2234.24, "text": "other"}, {"end": 2234.64, "start": 2234.36, "text": "words,"}, {"end": 2234.88, "start": 2234.64, "text": "once"}, {"end": 2235.04, "start": 2234.88, "text": "we"}, {"end": 2235.44, "start": 2235.04, "text": "accessed,"}, {"end": 2235.84, "start": 2235.44, "text": "let's"}, {"end": 2236.56, "start": 2235.84, "text": "say,"}, {"end": 2237.0, "start": 2236.56, "text": "local"}, {"end": 2237.44, "start": 2237.0, "text": "storage"}, {"end": 2237.48, "start": 2237.44, "text": "or"}, {"end": 2237.96, "start": 2237.48, "text": "perhaps"}, {"end": 2238.08, "start": 2237.96, "text": "even"}, {"end": 2238.28, "start": 2238.08, "text": "remote"}, {"end": 2238.88, "start": 2238.28, "text": "storage,"}, {"end": 2238.92, "start": 2238.88, "text": "we"}, {"end": 2238.92, "start": 2238.92, "text": "had"}, {"end": 2238.92, "start": 2238.92, "text": "to"}, {"end": 2239.04, "start": 2238.92, "text": "think"}, {"end": 2239.8, "start": 2239.04, "text": "about"}, {"end": 2240.44, "start": 2239.8, "text": "how"}, {"end": 2240.48, "start": 2240.44, "text": "we"}, {"end": 2240.48, "start": 2240.48, "text": "would"}, {"end": 2240.52, "start": 2240.48, "text": "put"}, {"end": 2240.88, "start": 2240.52, "text": "that"}, {"end": 2241.16, "start": 2240.88, "text": "one"}, {"end": 2241.44, "start": 2241.16, "text": "thread"}, {"end": 2241.44, "start": 2241.44, "text": "to"}, {"end": 2241.44, "start": 2241.44, "text": "sleep"}, {"end": 2241.6, "start": 2241.44, "text": "and"}, {"end": 2241.68, "start": 2241.6, "text": "then"}, {"end": 2241.68, "start": 2241.68, "text": "move"}, {"end": 2241.76, "start": 2241.68, "text": "to"}, {"end": 2242.2, "start": 2241.76, "text": "another"}, {"end": 2242.84, "start": 2242.2, "text": "thread"}, {"end": 2243.56, "start": 2242.84, "text": "such"}, {"end": 2244.12, "start": 2243.56, "text": "that"}, {"end": 2244.16, "start": 2244.12, "text": "we"}, {"end": 2244.44, "start": 2244.16, "text": "could"}, {"end": 2246.64, "start": 2244.44, "text": "get"}, {"end": 2247.0, "start": 2246.64, "text": "the"}, {"end": 2247.52, "start": 2247.0, "text": "right"}, {"end": 2248.32, "start": 2247.52, "text": "level"}, {"end": 2248.64, "start": 2248.32, "text": "of"}, {"end": 2249.96, "start": 2248.64, "text": "performance."}], "text": " Think of your classic select loop in building your client server systems. With epoch three, you started having to think about concurrency more seriously. As we hit the IO wall, we had to develop multi-threaded code for efficiency. In other words, once we accessed, let's say, local storage or perhaps even remote storage, we had to think about how we would put that one thread to sleep and then move to another thread such that we could get the right level of performance."}, {"chunks": [{"end": 2251.0, "start": 2250.0, "text": "performance"}, {"end": 2251.88, "start": 2251.0, "text": "improvements"}, {"end": 2252.16, "start": 2251.88, "text": "slowed"}, {"end": 2252.32, "start": 2252.16, "text": "and"}, {"end": 2252.92, "start": 2252.32, "text": "stopped,"}, {"end": 2253.16, "start": 2252.92, "text": "right?"}, {"end": 2253.2, "start": 2253.16, "text": "We"}, {"end": 2253.52, "start": 2253.2, "text": "had"}, {"end": 2253.88, "start": 2253.52, "text": "max"}, {"end": 2254.04, "start": 2253.88, "text": "single"}, {"end": 2254.4, "start": 2254.04, "text": "thread"}, {"end": 2255.36, "start": 2254.4, "text": "performance."}, {"end": 2255.6, "start": 2255.36, "text": "We"}, {"end": 2255.88, "start": 2255.6, "text": "actually"}, {"end": 2256.12, "start": 2255.88, "text": "had"}, {"end": 2256.16, "start": 2256.12, "text": "to"}, {"end": 2256.44, "start": 2256.16, "text": "go"}, {"end": 2256.44, "start": 2256.44, "text": "to"}, {"end": 2257.4, "start": 2256.44, "text": "concurrency"}, {"end": 2258.28, "start": 2257.4, "text": "models,"}, {"end": 2259.52, "start": 2258.28, "text": "multi-threadedness"}, {"end": 2260.08, "start": 2259.52, "text": "for"}, {"end": 2261.0, "start": 2260.08, "text": "performance."}, {"end": 2261.04, "start": 2261.0, "text": "We"}, {"end": 2261.24, "start": 2261.04, "text": "had"}, {"end": 2261.36, "start": 2261.24, "text": "to"}, {"end": 2261.68, "start": 2261.36, "text": "split"}, {"end": 2261.84, "start": 2261.68, "text": "computation"}, {"end": 2262.2, "start": 2261.84, "text": "across"}, {"end": 2262.4, "start": 2262.2, "text": "multiple"}, {"end": 2262.96, "start": 2262.4, "text": "threads"}, {"end": 2263.24, "start": 2262.96, "text": "and"}, {"end": 2263.48, "start": 2263.24, "text": "able"}, {"end": 2263.76, "start": 2263.48, "text": "to"}, {"end": 2263.76, "start": 2263.76, "text": "be"}, {"end": 2263.76, "start": 2263.76, "text": "able"}, {"end": 2263.76, "start": 2263.76, "text": "to"}, {"end": 2263.84, "start": 2263.76, "text": "scale"}, {"end": 2264.4, "start": 2263.84, "text": "out"}, {"end": 2264.96, "start": 2264.4, "text": "sequentially"}, {"end": 2265.12, "start": 2264.96, "text": "within"}, {"end": 2265.36, "start": 2265.12, "text": "a"}, {"end": 2267.12, "start": 2265.36, "text": "server."}, {"end": 2267.24, "start": 2267.12, "text": "We're"}, {"end": 2267.84, "start": 2267.24, "text": "seeing"}, {"end": 2268.16, "start": 2267.84, "text": "that"}, {"end": 2268.28, "start": 2268.16, "text": "people"}, {"end": 2268.6, "start": 2268.28, "text": "are"}, {"end": 2269.36, "start": 2268.6, "text": "increasingly"}, {"end": 2269.72, "start": 2269.36, "text": "thinking,"}, {"end": 2269.96, "start": 2269.72, "text": "how"}, {"end": 2270.16, "start": 2269.96, "text": "can"}, {"end": 2270.28, "start": 2270.16, "text": "I"}, {"end": 2270.48, "start": 2270.28, "text": "make"}, {"end": 2270.88, "start": 2270.48, "text": "this"}, {"end": 2271.28, "start": 2270.88, "text": "easier"}, {"end": 2271.4, "start": 2271.28, "text": "for"}, {"end": 2271.56, "start": 2271.4, "text": "my"}, {"end": 2272.12, "start": 2271.56, "text": "developers"}, {"end": 2272.32, "start": 2272.12, "text": "through"}, {"end": 2272.92, "start": 2272.32, "text": "declarative"}, {"end": 2275.4, "start": 2272.92, "text": "specifications?"}, {"end": 2275.72, "start": 2275.4, "text": "Finally,"}, {"end": 2275.88, "start": 2275.72, "text": "as"}, {"end": 2275.92, "start": 2275.88, "text": "we"}, {"end": 2276.56, "start": 2275.92, "text": "transition"}, {"end": 2276.8, "start": 2276.56, "text": "into"}, {"end": 2277.08, "start": 2276.8, "text": "epoch"}, {"end": 2277.6, "start": 2277.08, "text": "five,"}, {"end": 2277.64, "start": 2277.6, "text": "we're"}, {"end": 2277.64, "start": 2277.64, "text": "going"}, {"end": 2277.64, "start": 2277.64, "text": "to"}, {"end": 2277.96, "start": 2277.64, "text": "need"}, {"end": 2278.2, "start": 2277.96, "text": "a"}, {"end": 2279.44, "start": 2278.2, "text": "distributed"}, {"end": 2279.96, "start": 2279.44, "text": "runtime."}], "text": " performance improvements slowed and stopped, right? We had max single thread performance. We actually had to go to concurrency models, multi-threadedness for performance. We had to split computation across multiple threads and able to be able to scale out sequentially within a server. We're seeing that people are increasingly thinking, how can I make this easier for my developers through declarative specifications? Finally, as we transition into epoch five, we're going to need a distributed runtime."}, {"chunks": [{"end": 2280.48, "start": 2280.0, "text": "developers"}, {"end": 2280.56, "start": 2280.48, "text": "aren't"}, {"end": 2280.8, "start": 2280.56, "text": "going"}, {"end": 2280.8, "start": 2280.8, "text": "to"}, {"end": 2280.84, "start": 2280.8, "text": "be"}, {"end": 2281.12, "start": 2280.84, "text": "able"}, {"end": 2281.16, "start": 2281.12, "text": "to"}, {"end": 2281.4, "start": 2281.16, "text": "think"}, {"end": 2281.92, "start": 2281.4, "text": "about"}, {"end": 2282.2, "start": 2281.92, "text": "the"}, {"end": 2282.4, "start": 2282.2, "text": "system"}, {"end": 2282.44, "start": 2282.4, "text": "balance"}, {"end": 2283.08, "start": 2282.44, "text": "points"}, {"end": 2283.24, "start": 2283.08, "text": "on"}, {"end": 2283.24, "start": 2283.24, "text": "their"}, {"end": 2283.24, "start": 2283.24, "text": "own."}, {"end": 2283.52, "start": 2283.24, "text": "And"}, {"end": 2283.6, "start": 2283.52, "text": "in"}, {"end": 2283.72, "start": 2283.6, "text": "fact,"}, {"end": 2284.0, "start": 2283.72, "text": "as"}, {"end": 2284.48, "start": 2284.0, "text": "they"}, {"end": 2284.84, "start": 2284.48, "text": "change"}, {"end": 2285.12, "start": 2284.84, "text": "the"}, {"end": 2285.12, "start": 2285.12, "text": "code,"}, {"end": 2285.2, "start": 2285.12, "text": "the"}, {"end": 2285.56, "start": 2285.2, "text": "system"}, {"end": 2286.04, "start": 2285.56, "text": "balance"}, {"end": 2286.12, "start": 2286.04, "text": "point"}, {"end": 2286.76, "start": 2286.12, "text": "might"}, {"end": 2287.84, "start": 2286.76, "text": "evolve."}, {"end": 2288.08, "start": 2287.84, "text": "So"}, {"end": 2288.08, "start": 2288.08, "text": "I"}, {"end": 2288.52, "start": 2288.08, "text": "will"}, {"end": 2288.96, "start": 2288.52, "text": "argue"}, {"end": 2289.24, "start": 2288.96, "text": "that"}, {"end": 2289.8, "start": 2289.24, "text": "declarative"}, {"end": 2290.2, "start": 2289.8, "text": "specs"}, {"end": 2290.2, "start": 2290.2, "text": "are"}, {"end": 2290.24, "start": 2290.2, "text": "actually"}, {"end": 2290.36, "start": 2290.24, "text": "going"}, {"end": 2290.6, "start": 2290.36, "text": "to"}, {"end": 2290.6, "start": 2290.6, "text": "be"}, {"end": 2291.2, "start": 2290.6, "text": "required"}, {"end": 2291.24, "start": 2291.2, "text": "to"}, {"end": 2291.72, "start": 2291.24, "text": "manage"}, {"end": 2291.72, "start": 2291.72, "text": "the"}, {"end": 2292.32, "start": 2291.72, "text": "complexity"}, {"end": 2292.48, "start": 2292.32, "text": "of"}, {"end": 2292.76, "start": 2292.48, "text": "building"}, {"end": 2293.08, "start": 2292.76, "text": "tightly"}, {"end": 2293.36, "start": 2293.08, "text": "coupled"}, {"end": 2293.76, "start": 2293.36, "text": "distributed"}, {"end": 2294.4, "start": 2293.76, "text": "systems"}, {"end": 2294.4, "start": 2294.4, "text": "in"}, {"end": 2294.6, "start": 2294.4, "text": "epoch"}, {"end": 2294.84, "start": 2294.6, "text": "five."}, {"end": 2294.84, "start": 2294.84, "text": "What"}, {"end": 2294.84, "start": 2294.84, "text": "you"}, {"end": 2294.88, "start": 2294.84, "text": "can"}, {"end": 2295.48, "start": 2294.88, "text": "see"}, {"end": 2296.52, "start": 2295.48, "text": "in"}, {"end": 2296.8, "start": 2296.52, "text": "moving"}, {"end": 2297.76, "start": 2296.8, "text": "from"}, {"end": 2298.2, "start": 2297.76, "text": "epoch"}, {"end": 2298.56, "start": 2298.2, "text": "one"}, {"end": 2298.84, "start": 2298.56, "text": "to"}, {"end": 2298.84, "start": 2298.84, "text": "two"}, {"end": 2298.84, "start": 2298.84, "text": "to"}, {"end": 2299.12, "start": 2298.84, "text": "three"}, {"end": 2299.12, "start": 2299.12, "text": "to"}, {"end": 2299.32, "start": 2299.12, "text": "four"}, {"end": 2299.44, "start": 2299.32, "text": "to"}, {"end": 2299.8, "start": 2299.44, "text": "five"}, {"end": 2300.28, "start": 2299.8, "text": "is"}, {"end": 2300.56, "start": 2300.28, "text": "that"}, {"end": 2300.56, "start": 2300.56, "text": "we"}, {"end": 2300.64, "start": 2300.56, "text": "have"}, {"end": 2301.16, "start": 2300.64, "text": "increasing"}, {"end": 2301.64, "start": 2301.16, "text": "developer"}, {"end": 2302.44, "start": 2301.64, "text": "complexity."}, {"end": 2302.96, "start": 2302.44, "text": "Building"}, {"end": 2303.76, "start": 2302.96, "text": "applications"}, {"end": 2304.04, "start": 2303.76, "text": "may"}, {"end": 2304.08, "start": 2304.04, "text": "be"}, {"end": 2304.44, "start": 2304.08, "text": "at"}, {"end": 2304.8, "start": 2304.44, "text": "the"}, {"end": 2305.04, "start": 2304.8, "text": "birth"}, {"end": 2305.52, "start": 2305.04, "text": "of"}, {"end": 2305.52, "start": 2305.52, "text": "the"}, {"end": 2305.52, "start": 2305.52, "text": "internet,"}, {"end": 2305.88, "start": 2305.52, "text": "at"}, {"end": 2306.16, "start": 2305.88, "text": "least"}, {"end": 2306.16, "start": 2306.16, "text": "in"}, {"end": 2306.88, "start": 2306.16, "text": "retrospect"}, {"end": 2307.36, "start": 2306.88, "text": "is"}, {"end": 2307.76, "start": 2307.36, "text": "simple."}, {"end": 2308.92, "start": 2307.76, "text": "But"}, {"end": 2309.48, "start": 2308.92, "text": "we've"}, {"end": 2309.96, "start": 2309.48, "text": "got"}], "text": " developers aren't going to be able to think about the system balance points on their own. And in fact, as they change the code, the system balance point might evolve. So I will argue that declarative specs are actually going to be required to manage the complexity of building tightly coupled distributed systems in epoch five. What you can see in moving from epoch one to two to three to four to five is that we have increasing developer complexity. Building applications may be at the birth of the internet, at least in retrospect is simple. But we've got"}, {"chunks": [{"end": 2310.16, "start": 2310.0, "text": "An"}, {"end": 2310.68, "start": 2310.16, "text": "increasing"}, {"end": 2311.16, "start": 2310.68, "text": "concurrent"}, {"end": 2312.0, "start": 2311.16, "text": "concurrency"}, {"end": 2312.16, "start": 2312.0, "text": "and"}, {"end": 2312.64, "start": 2312.16, "text": "increasing"}, {"end": 2313.28, "start": 2312.64, "text": "complexity"}, {"end": 2313.52, "start": 2313.28, "text": "and"}, {"end": 2313.88, "start": 2313.52, "text": "increasing"}, {"end": 2314.52, "start": 2313.88, "text": "performance"}, {"end": 2314.8, "start": 2314.52, "text": "and"}, {"end": 2315.08, "start": 2314.8, "text": "correctness"}, {"end": 2315.8, "start": 2315.08, "text": "problems"}, {"end": 2316.32, "start": 2315.8, "text": "as"}, {"end": 2316.44, "start": 2316.32, "text": "we"}, {"end": 2316.72, "start": 2316.44, "text": "move"}, {"end": 2317.2, "start": 2316.72, "text": "from"}, {"end": 2317.52, "start": 2317.2, "text": "no"}, {"end": 2318.08, "start": 2317.52, "text": "concurrency"}, {"end": 2318.76, "start": 2318.08, "text": "to"}, {"end": 2318.96, "start": 2318.76, "text": "the"}, {"end": 2319.2, "start": 2318.96, "text": "beginning"}, {"end": 2319.28, "start": 2319.2, "text": "of"}, {"end": 2319.44, "start": 2319.28, "text": "a"}, {"end": 2319.68, "start": 2319.44, "text": "box"}, {"end": 2319.96, "start": 2319.68, "text": "five"}, {"end": 2320.2, "start": 2319.96, "text": "where"}, {"end": 2320.24, "start": 2320.2, "text": "we"}, {"end": 2320.68, "start": 2320.24, "text": "have"}, {"end": 2321.0, "start": 2320.68, "text": "multi"}, {"end": 2321.56, "start": 2321.0, "text": "server"}, {"end": 2321.88, "start": 2321.56, "text": "multi"}, {"end": 2322.24, "start": 2321.88, "text": "threaded"}, {"end": 2322.96, "start": 2322.24, "text": "concurrency"}, {"end": 2323.28, "start": 2322.96, "text": "that"}, {"end": 2323.48, "start": 2323.28, "text": "we"}, {"end": 2323.56, "start": 2323.48, "text": "have"}, {"end": 2325.28, "start": 2323.56, "text": "to"}, {"end": 2325.52, "start": 2325.28, "text": "deal"}, {"end": 2326.24, "start": 2325.52, "text": "with."}, {"end": 2326.92, "start": 2326.24, "text": "I'll"}, {"end": 2327.52, "start": 2326.92, "text": "argue"}, {"end": 2327.92, "start": 2327.52, "text": "that"}, {"end": 2328.04, "start": 2327.92, "text": "today"}, {"end": 2328.04, "start": 2328.04, "text": "you"}, {"end": 2328.44, "start": 2328.04, "text": "very"}, {"end": 2328.64, "start": 2328.44, "text": "few"}, {"end": 2328.76, "start": 2328.64, "text": "can"}, {"end": 2329.12, "start": 2328.76, "text": "actually"}, {"end": 2329.44, "start": 2329.12, "text": "get"}, {"end": 2329.72, "start": 2329.44, "text": "the"}, {"end": 2330.16, "start": 2329.72, "text": "concurrency"}, {"end": 2330.44, "start": 2330.16, "text": "models"}, {"end": 2330.48, "start": 2330.44, "text": "with"}, {"end": 2330.76, "start": 2330.48, "text": "multi"}, {"end": 2331.04, "start": 2330.76, "text": "threading"}, {"end": 2331.68, "start": 2331.04, "text": "rights."}, {"end": 2332.0, "start": 2331.68, "text": "Certainly"}, {"end": 2332.32, "start": 2332.0, "text": "if"}, {"end": 2332.32, "start": 2332.32, "text": "you"}, {"end": 2332.56, "start": 2332.32, "text": "account"}, {"end": 2332.76, "start": 2332.56, "text": "for"}, {"end": 2333.4, "start": 2332.76, "text": "correctness"}, {"end": 2333.48, "start": 2333.4, "text": "and"}, {"end": 2333.64, "start": 2333.48, "text": "very"}, {"end": 2334.08, "start": 2333.64, "text": "subtle"}, {"end": 2334.24, "start": 2334.08, "text": "bugs"}, {"end": 2334.6, "start": 2334.24, "text": "that"}, {"end": 2334.8, "start": 2334.6, "text": "get"}, {"end": 2335.56, "start": 2334.8, "text": "introduced,"}, {"end": 2335.72, "start": 2335.56, "text": "but"}, {"end": 2336.2, "start": 2335.72, "text": "especially"}, {"end": 2336.32, "start": 2336.2, "text": "if"}, {"end": 2336.4, "start": 2336.32, "text": "you"}, {"end": 2336.76, "start": 2336.4, "text": "count"}, {"end": 2337.36, "start": 2336.76, "text": "for"}, {"end": 2338.0, "start": 2337.36, "text": "the"}, {"end": 2338.08, "start": 2338.0, "text": "need"}, {"end": 2339.16, "start": 2338.08, "text": "for"}, {"end": 2339.96, "start": 2339.16, "text": "performance."}], "text": " An increasing concurrent concurrency and increasing complexity and increasing performance and correctness problems as we move from no concurrency to the beginning of a box five where we have multi server multi threaded concurrency that we have to deal with. I'll argue that today you very few can actually get the concurrency models with multi threading rights. Certainly if you account for correctness and very subtle bugs that get introduced, but especially if you count for the need for performance."}, {"chunks": [{"end": 2340.16, "start": 2340.0, "text": "I'll"}, {"end": 2340.44, "start": 2340.16, "text": "argue"}, {"end": 2341.44, "start": 2340.44, "text": "that"}, {"end": 2341.6, "start": 2341.44, "text": "as"}, {"end": 2341.76, "start": 2341.6, "text": "we"}, {"end": 2342.4, "start": 2341.76, "text": "go"}, {"end": 2342.84, "start": 2342.4, "text": "to"}, {"end": 2343.2, "start": 2342.84, "text": "epoch"}, {"end": 2343.88, "start": 2343.2, "text": "five,"}, {"end": 2344.2, "start": 2343.88, "text": "no"}, {"end": 2344.2, "start": 2344.2, "text": "one"}, {"end": 2344.36, "start": 2344.2, "text": "can"}, {"end": 2344.68, "start": 2344.36, "text": "actually"}, {"end": 2345.2, "start": 2344.68, "text": "manage"}, {"end": 2345.36, "start": 2345.2, "text": "the"}, {"end": 2345.72, "start": 2345.36, "text": "complexity"}, {"end": 2345.72, "start": 2345.72, "text": "of"}, {"end": 2345.84, "start": 2345.72, "text": "the"}, {"end": 2346.36, "start": 2345.84, "text": "concurrency"}, {"end": 2346.84, "start": 2346.36, "text": "model."}, {"end": 2347.44, "start": 2346.84, "text": "And"}, {"end": 2347.52, "start": 2347.44, "text": "we're"}, {"end": 2347.52, "start": 2347.52, "text": "going"}, {"end": 2347.52, "start": 2347.52, "text": "to"}, {"end": 2347.52, "start": 2347.52, "text": "need"}, {"end": 2347.68, "start": 2347.52, "text": "the"}, {"end": 2348.24, "start": 2347.68, "text": "equivalent"}, {"end": 2348.52, "start": 2348.24, "text": "of"}, {"end": 2348.8, "start": 2348.52, "text": "a"}, {"end": 2349.16, "start": 2348.8, "text": "operating"}, {"end": 2349.52, "start": 2349.16, "text": "system"}, {"end": 2349.64, "start": 2349.52, "text": "and"}, {"end": 2350.12, "start": 2349.64, "text": "runtime"}, {"end": 2350.2, "start": 2350.12, "text": "to"}, {"end": 2350.44, "start": 2350.2, "text": "manage"}, {"end": 2351.0, "start": 2350.44, "text": "the"}, {"end": 2355.08, "start": 2351.0, "text": "distributed"}, {"end": 2355.92, "start": 2355.08, "text": "state."}, {"end": 2356.52, "start": 2355.92, "text": "So"}, {"end": 2356.92, "start": 2356.52, "text": "very"}, {"end": 2357.44, "start": 2356.92, "text": "quickly"}, {"end": 2357.52, "start": 2357.44, "text": "for"}, {"end": 2357.96, "start": 2357.52, "text": "time"}, {"end": 2358.44, "start": 2357.96, "text": "and"}, {"end": 2359.52, "start": 2358.44, "text": "as"}, {"end": 2359.88, "start": 2359.52, "text": "a"}, {"end": 2359.88, "start": 2359.88, "text": "case"}, {"end": 2360.68, "start": 2359.88, "text": "study,"}, {"end": 2361.12, "start": 2360.68, "text": "let"}, {"end": 2361.56, "start": 2361.12, "text": "me"}, {"end": 2361.8, "start": 2361.56, "text": "show"}, {"end": 2361.96, "start": 2361.8, "text": "you"}, {"end": 2362.56, "start": 2361.96, "text": "how"}, {"end": 2363.4, "start": 2362.56, "text": "many"}, {"end": 2363.68, "start": 2363.4, "text": "distributed"}, {"end": 2364.48, "start": 2363.68, "text": "applications"}, {"end": 2364.84, "start": 2364.48, "text": "are"}, {"end": 2365.16, "start": 2364.84, "text": "built"}, {"end": 2365.16, "start": 2365.16, "text": "today."}, {"end": 2365.2, "start": 2365.16, "text": "This"}, {"end": 2365.68, "start": 2365.2, "text": "is"}, {"end": 2366.24, "start": 2365.68, "text": "how"}, {"end": 2366.4, "start": 2366.24, "text": "we"}, {"end": 2367.0, "start": 2366.4, "text": "scale"}, {"end": 2367.56, "start": 2367.0, "text": "out,"}, {"end": 2367.88, "start": 2367.56, "text": "for"}, {"end": 2368.2, "start": 2367.88, "text": "example,"}, {"end": 2368.36, "start": 2368.2, "text": "web"}, {"end": 2368.56, "start": 2368.36, "text": "search,"}, {"end": 2369.04, "start": 2368.56, "text": "but"}, {"end": 2369.04, "start": 2369.04, "text": "not"}, {"end": 2369.16, "start": 2369.04, "text": "just"}, {"end": 2369.96, "start": 2369.16, "text": "us."}], "text": " I'll argue that as we go to epoch five, no one can actually manage the complexity of the concurrency model. And we're going to need the equivalent of a operating system and runtime to manage the distributed state. So very quickly for time and as a case study, let me show you how many distributed applications are built today. This is how we scale out, for example, web search, but not just us."}, {"chunks": [{"end": 2370.52, "start": 2370.0, "text": "applies"}, {"end": 2370.68, "start": 2370.52, "text": "to"}, {"end": 2370.88, "start": 2370.68, "text": "many,"}, {"end": 2371.04, "start": 2370.88, "text": "many"}, {"end": 2371.56, "start": 2371.04, "text": "different"}, {"end": 2371.88, "start": 2371.56, "text": "scalable"}, {"end": 2372.96, "start": 2371.88, "text": "services."}, {"end": 2373.6, "start": 2372.96, "text": "Essentially"}, {"end": 2373.84, "start": 2373.6, "text": "what"}, {"end": 2374.08, "start": 2373.84, "text": "happens"}, {"end": 2374.16, "start": 2374.08, "text": "is"}, {"end": 2374.64, "start": 2374.16, "text": "that"}, {"end": 2374.8, "start": 2374.64, "text": "requests"}, {"end": 2375.2, "start": 2374.8, "text": "come"}, {"end": 2375.4, "start": 2375.2, "text": "into"}, {"end": 2375.4, "start": 2375.4, "text": "a"}, {"end": 2375.4, "start": 2375.4, "text": "coordinator."}, {"end": 2375.8, "start": 2375.4, "text": "The"}, {"end": 2375.84, "start": 2375.8, "text": "state"}, {"end": 2376.2, "start": 2375.84, "text": "of"}, {"end": 2376.8, "start": 2376.2, "text": "the"}, {"end": 2377.48, "start": 2376.8, "text": "system"}, {"end": 2378.08, "start": 2377.48, "text": "is"}, {"end": 2378.56, "start": 2378.08, "text": "partitioned,"}, {"end": 2378.72, "start": 2378.56, "text": "statically"}, {"end": 2379.72, "start": 2378.72, "text": "partitioned"}, {"end": 2380.2, "start": 2379.72, "text": "across,"}, {"end": 2380.6, "start": 2380.2, "text": "let's"}, {"end": 2381.08, "start": 2380.6, "text": "say,"}, {"end": 2381.48, "start": 2381.08, "text": "100,"}, {"end": 2382.12, "start": 2381.48, "text": "1,000,"}, {"end": 2382.68, "start": 2382.12, "text": "10,000"}, {"end": 2383.76, "start": 2382.68, "text": "servers."}, {"end": 2383.96, "start": 2383.76, "text": "And"}, {"end": 2383.96, "start": 2383.96, "text": "the"}, {"end": 2384.48, "start": 2383.96, "text": "coordinator"}, {"end": 2384.64, "start": 2384.48, "text": "then"}, {"end": 2385.24, "start": 2384.64, "text": "distributes"}, {"end": 2385.48, "start": 2385.24, "text": "the"}, {"end": 2386.12, "start": 2385.48, "text": "request"}, {"end": 2386.44, "start": 2386.12, "text": "to"}, {"end": 2387.32, "start": 2386.44, "text": "all"}, {"end": 2387.76, "start": 2387.32, "text": "1,000,"}, {"end": 2388.24, "start": 2387.76, "text": "10,000"}, {"end": 2388.88, "start": 2388.24, "text": "servers"}, {"end": 2389.04, "start": 2388.88, "text": "and"}, {"end": 2389.72, "start": 2389.04, "text": "asks"}, {"end": 2390.16, "start": 2389.72, "text": "for"}, {"end": 2390.16, "start": 2390.16, "text": "a"}, {"end": 2390.16, "start": 2390.16, "text": "partial"}, {"end": 2390.52, "start": 2390.16, "text": "response."}, {"end": 2391.36, "start": 2390.52, "text": "Code"}, {"end": 2391.6, "start": 2391.36, "text": "gets"}, {"end": 2391.92, "start": 2391.6, "text": "run"}, {"end": 2392.36, "start": 2391.92, "text": "locally"}, {"end": 2392.72, "start": 2392.36, "text": "within"}, {"end": 2392.76, "start": 2392.72, "text": "each"}, {"end": 2393.28, "start": 2392.76, "text": "partition,"}, {"end": 2393.56, "start": 2393.28, "text": "going"}, {"end": 2393.88, "start": 2393.56, "text": "over"}, {"end": 2394.16, "start": 2393.88, "text": "the"}, {"end": 2394.44, "start": 2394.16, "text": "locally"}, {"end": 2394.8, "start": 2394.44, "text": "stored"}, {"end": 2395.4, "start": 2394.8, "text": "data."}, {"end": 2395.56, "start": 2395.4, "text": "And"}, {"end": 2395.96, "start": 2395.56, "text": "then"}, {"end": 2396.36, "start": 2395.96, "text": "a"}, {"end": 2396.68, "start": 2396.36, "text": "snippet,"}, {"end": 2397.12, "start": 2396.68, "text": "essentially,"}, {"end": 2397.2, "start": 2397.12, "text": "is"}, {"end": 2397.24, "start": 2397.2, "text": "returned"}, {"end": 2397.4, "start": 2397.24, "text": "back"}, {"end": 2397.52, "start": 2397.4, "text": "to"}, {"end": 2397.52, "start": 2397.52, "text": "the"}, {"end": 2397.8, "start": 2397.52, "text": "coordinator,"}, {"end": 2398.04, "start": 2397.8, "text": "which"}, {"end": 2398.08, "start": 2398.04, "text": "joins"}, {"end": 2399.44, "start": 2398.08, "text": "across"}, {"end": 2399.96, "start": 2399.44, "text": "all"}], "text": " applies to many, many different scalable services. Essentially what happens is that requests come into a coordinator. The state of the system is partitioned, statically partitioned across, let's say, 100, 1,000, 10,000 servers. And the coordinator then distributes the request to all 1,000, 10,000 servers and asks for a partial response. Code gets run locally within each partition, going over the locally stored data. And then a snippet, essentially, is returned back to the coordinator, which joins across all"}, {"chunks": [{"end": 2400.36, "start": 2400.0, "text": "these"}, {"end": 2400.88, "start": 2400.36, "text": "snippets"}, {"end": 2400.92, "start": 2400.88, "text": "to"}, {"end": 2401.04, "start": 2400.92, "text": "compose"}, {"end": 2401.12, "start": 2401.04, "text": "an"}, {"end": 2401.48, "start": 2401.12, "text": "answer."}, {"end": 2401.72, "start": 2401.48, "text": "This"}, {"end": 2402.2, "start": 2401.72, "text": "is"}, {"end": 2402.24, "start": 2402.2, "text": "a"}, {"end": 2402.24, "start": 2402.24, "text": "very"}, {"end": 2403.16, "start": 2402.24, "text": "powerful"}, {"end": 2403.44, "start": 2403.16, "text": "design"}, {"end": 2403.92, "start": 2403.44, "text": "pattern"}, {"end": 2404.16, "start": 2403.92, "text": "and"}, {"end": 2404.48, "start": 2404.16, "text": "it's"}, {"end": 2405.0, "start": 2404.48, "text": "generalized"}, {"end": 2405.0, "start": 2405.0, "text": "to"}, {"end": 2405.24, "start": 2405.0, "text": "many"}, {"end": 2405.4, "start": 2405.24, "text": "different"}, {"end": 2405.88, "start": 2405.4, "text": "services."}, {"end": 2406.12, "start": 2405.88, "text": "That's"}, {"end": 2406.2, "start": 2406.12, "text": "a"}, {"end": 2406.28, "start": 2406.2, "text": "big"}, {"end": 2406.52, "start": 2406.28, "text": "pro."}, {"end": 2406.52, "start": 2406.52, "text": "But"}, {"end": 2407.16, "start": 2406.52, "text": "it"}, {"end": 2408.24, "start": 2407.16, "text": "actually"}, {"end": 2408.8, "start": 2408.24, "text": "limits"}, {"end": 2409.16, "start": 2408.8, "text": "how"}, {"end": 2409.2, "start": 2409.16, "text": "we"}, {"end": 2409.2, "start": 2409.2, "text": "can"}, {"end": 2409.4, "start": 2409.2, "text": "do"}, {"end": 2409.84, "start": 2409.4, "text": "distributed"}, {"end": 2410.6, "start": 2409.84, "text": "computation."}, {"end": 2410.84, "start": 2410.6, "text": "There's"}, {"end": 2411.0, "start": 2410.84, "text": "no"}, {"end": 2411.96, "start": 2411.0, "text": "branching."}, {"end": 2412.4, "start": 2411.96, "text": "There's"}, {"end": 2412.72, "start": 2412.4, "text": "a"}, {"end": 2413.08, "start": 2412.72, "text": "static"}, {"end": 2413.8, "start": 2413.08, "text": "partition"}, {"end": 2413.96, "start": 2413.8, "text": "of"}, {"end": 2413.96, "start": 2413.96, "text": "the"}, {"end": 2414.0, "start": 2413.96, "text": "data,"}, {"end": 2414.44, "start": 2414.0, "text": "basically"}, {"end": 2414.76, "start": 2414.44, "text": "defining"}, {"end": 2415.0, "start": 2414.76, "text": "a"}, {"end": 2415.56, "start": 2415.0, "text": "static"}, {"end": 2416.04, "start": 2415.56, "text": "balance"}, {"end": 2416.8, "start": 2416.04, "text": "point."}, {"end": 2417.04, "start": 2416.8, "text": "And"}, {"end": 2417.36, "start": 2417.04, "text": "data"}, {"end": 2417.68, "start": 2417.36, "text": "is"}, {"end": 2418.48, "start": 2417.68, "text": "pre-replicated"}, {"end": 2418.56, "start": 2418.48, "text": "anywhere"}, {"end": 2419.28, "start": 2418.56, "text": "that"}, {"end": 2419.84, "start": 2419.28, "text": "it"}, {"end": 2420.08, "start": 2419.84, "text": "might"}, {"end": 2420.16, "start": 2420.08, "text": "be"}, {"end": 2420.28, "start": 2420.16, "text": "needed"}, {"end": 2421.16, "start": 2420.28, "text": "because"}, {"end": 2421.28, "start": 2421.16, "text": "it"}, {"end": 2422.2, "start": 2421.28, "text": "requires"}, {"end": 2423.04, "start": 2422.2, "text": "careful"}, {"end": 2423.76, "start": 2423.04, "text": "per-application"}, {"end": 2424.36, "start": 2423.76, "text": "tuning."}, {"end": 2424.6, "start": 2424.36, "text": "And"}, {"end": 2424.84, "start": 2424.6, "text": "again,"}, {"end": 2424.96, "start": 2424.84, "text": "if"}, {"end": 2425.08, "start": 2424.96, "text": "your"}, {"end": 2425.52, "start": 2425.08, "text": "code"}, {"end": 2425.76, "start": 2425.52, "text": "or"}, {"end": 2425.84, "start": 2425.76, "text": "your"}, {"end": 2426.36, "start": 2425.84, "text": "needs"}, {"end": 2426.76, "start": 2426.36, "text": "change,"}, {"end": 2426.92, "start": 2426.76, "text": "it"}, {"end": 2427.92, "start": 2426.92, "text": "requires"}, {"end": 2428.2, "start": 2427.92, "text": "some"}, {"end": 2428.2, "start": 2428.2, "text": "of"}, {"end": 2428.24, "start": 2428.2, "text": "the"}, {"end": 2428.48, "start": 2428.24, "text": "best"}, {"end": 2428.64, "start": 2428.48, "text": "engineers"}, {"end": 2428.64, "start": 2428.64, "text": "in"}, {"end": 2429.0, "start": 2428.64, "text": "the"}, {"end": 2429.4, "start": 2429.0, "text": "world"}, {"end": 2429.96, "start": 2429.4, "text": "to"}], "text": " these snippets to compose an answer. This is a very powerful design pattern and it's generalized to many different services. That's a big pro. But it actually limits how we can do distributed computation. There's no branching. There's a static partition of the data, basically defining a static balance point. And data is pre-replicated anywhere that it might be needed because it requires careful per-application tuning. And again, if your code or your needs change, it requires some of the best engineers in the world to"}, {"chunks": [{"end": 2430.28, "start": 2430.0, "text": "consider"}, {"end": 2430.68, "start": 2430.28, "text": "how"}, {"end": 2431.04, "start": 2430.68, "text": "things"}, {"end": 2431.2, "start": 2431.04, "text": "would"}, {"end": 2431.2, "start": 2431.2, "text": "get"}, {"end": 2431.76, "start": 2431.2, "text": "repartitioned."}, {"end": 2431.76, "start": 2431.76, "text": "In"}, {"end": 2433.08, "start": 2431.76, "text": "Epoch"}, {"end": 2433.16, "start": 2433.08, "text": "5,"}, {"end": 2434.48, "start": 2433.16, "text": "to"}, {"end": 2435.16, "start": 2434.48, "text": "drive"}, {"end": 2435.52, "start": 2435.16, "text": "the"}, {"end": 2436.48, "start": 2435.52, "text": "efficiencies"}, {"end": 2436.92, "start": 2436.48, "text": "and"}, {"end": 2437.0, "start": 2436.92, "text": "the"}, {"end": 2437.88, "start": 2437.0, "text": "productivity"}, {"end": 2437.92, "start": 2437.88, "text": "from"}, {"end": 2438.12, "start": 2437.92, "text": "a"}, {"end": 2438.4, "start": 2438.12, "text": "developer"}, {"end": 2438.84, "start": 2438.4, "text": "perspective"}, {"end": 2439.12, "start": 2438.84, "text": "that"}, {"end": 2439.24, "start": 2439.12, "text": "we"}, {"end": 2439.28, "start": 2439.24, "text": "need"}, {"end": 2439.4, "start": 2439.28, "text": "to"}, {"end": 2439.44, "start": 2439.4, "text": "be"}, {"end": 2440.12, "start": 2439.44, "text": "able"}, {"end": 2440.12, "start": 2440.12, "text": "to"}, {"end": 2440.16, "start": 2440.12, "text": "move"}, {"end": 2440.36, "start": 2440.16, "text": "at"}, {"end": 2440.72, "start": 2440.36, "text": "the"}, {"end": 2441.04, "start": 2440.72, "text": "requisite"}, {"end": 2441.88, "start": 2441.04, "text": "speed,"}, {"end": 2442.28, "start": 2441.88, "text": "imagine"}, {"end": 2442.6, "start": 2442.28, "text": "being"}, {"end": 2443.0, "start": 2442.6, "text": "able"}, {"end": 2443.4, "start": 2443.0, "text": "to"}, {"end": 2443.4, "start": 2443.4, "text": "move"}, {"end": 2444.16, "start": 2443.4, "text": "from"}, {"end": 2444.96, "start": 2444.16, "text": "a"}, {"end": 2445.2, "start": 2444.96, "text": "very"}, {"end": 2445.72, "start": 2445.2, "text": "partitioned"}, {"end": 2445.92, "start": 2445.72, "text": "view"}, {"end": 2446.16, "start": 2445.92, "text": "of"}, {"end": 2446.48, "start": 2446.16, "text": "your"}, {"end": 2446.68, "start": 2446.48, "text": "data"}, {"end": 2447.04, "start": 2446.68, "text": "to"}, {"end": 2447.28, "start": 2447.04, "text": "a"}, {"end": 2447.72, "start": 2447.28, "text": "more"}, {"end": 2447.84, "start": 2447.72, "text": "global"}, {"end": 2447.84, "start": 2447.84, "text": "view"}, {"end": 2447.84, "start": 2447.84, "text": "of"}, {"end": 2448.2, "start": 2447.84, "text": "your"}, {"end": 2448.36, "start": 2448.2, "text": "data."}, {"end": 2448.8, "start": 2448.36, "text": "Essentially,"}, {"end": 2449.16, "start": 2448.8, "text": "can"}, {"end": 2449.6, "start": 2449.16, "text": "code"}, {"end": 2450.28, "start": 2449.6, "text": "run"}, {"end": 2450.84, "start": 2450.28, "text": "where"}, {"end": 2451.08, "start": 2450.84, "text": "and"}, {"end": 2451.08, "start": 2451.08, "text": "when"}, {"end": 2451.12, "start": 2451.08, "text": "it"}, {"end": 2451.64, "start": 2451.12, "text": "needs"}, {"end": 2451.64, "start": 2451.64, "text": "to"}, {"end": 2452.2, "start": 2451.64, "text": "run"}, {"end": 2452.68, "start": 2452.2, "text": "without"}, {"end": 2453.08, "start": 2452.68, "text": "having"}, {"end": 2453.44, "start": 2453.08, "text": "to"}, {"end": 2453.64, "start": 2453.44, "text": "think"}, {"end": 2454.44, "start": 2453.64, "text": "statically"}, {"end": 2454.68, "start": 2454.44, "text": "about"}, {"end": 2454.8, "start": 2454.68, "text": "what"}, {"end": 2454.8, "start": 2454.8, "text": "the"}, {"end": 2455.28, "start": 2454.8, "text": "partition"}, {"end": 2455.32, "start": 2455.28, "text": "is?"}, {"end": 2455.6, "start": 2455.32, "text": "This"}, {"end": 2456.2, "start": 2455.6, "text": "is"}, {"end": 2456.36, "start": 2456.2, "text": "going"}, {"end": 2456.56, "start": 2456.36, "text": "to"}, {"end": 2456.96, "start": 2456.56, "text": "require,"}, {"end": 2457.24, "start": 2456.96, "text": "again,"}, {"end": 2457.32, "start": 2457.24, "text": "a"}, {"end": 2457.8, "start": 2457.32, "text": "distributed"}, {"end": 2458.28, "start": 2457.8, "text": "runtime."}, {"end": 2458.68, "start": 2458.28, "text": "Can"}, {"end": 2458.72, "start": 2458.68, "text": "we"}, {"end": 2459.04, "start": 2458.72, "text": "have"}, {"end": 2459.2, "start": 2459.04, "text": "a"}, {"end": 2459.96, "start": 2459.2, "text": "declarative,"}], "text": " consider how things would get repartitioned. In Epoch 5, to drive the efficiencies and the productivity from a developer perspective that we need to be able to move at the requisite speed, imagine being able to move from a very partitioned view of your data to a more global view of your data. Essentially, can code run where and when it needs to run without having to think statically about what the partition is? This is going to require, again, a distributed runtime. Can we have a declarative,"}, {"chunks": [{"end": 2460.68, "start": 2460.0, "text": "spec"}, {"end": 2460.84, "start": 2460.68, "text": "of"}, {"end": 2461.24, "start": 2460.84, "text": "your"}, {"end": 2462.32, "start": 2461.24, "text": "computation?"}, {"end": 2462.68, "start": 2462.32, "text": "Can"}, {"end": 2462.68, "start": 2462.68, "text": "we"}, {"end": 2463.16, "start": 2462.68, "text": "maintain"}, {"end": 2463.56, "start": 2463.16, "text": "dynamic"}, {"end": 2463.92, "start": 2463.56, "text": "runtime"}, {"end": 2464.56, "start": 2463.92, "text": "state"}, {"end": 2464.72, "start": 2464.56, "text": "and"}, {"end": 2464.88, "start": 2464.72, "text": "be"}, {"end": 2465.12, "start": 2464.88, "text": "able"}, {"end": 2465.52, "start": 2465.12, "text": "to"}, {"end": 2466.12, "start": 2465.52, "text": "perhaps"}, {"end": 2466.92, "start": 2466.12, "text": "replicate"}, {"end": 2467.36, "start": 2466.92, "text": "and"}, {"end": 2467.64, "start": 2467.36, "text": "move"}, {"end": 2468.24, "start": 2467.64, "text": "data"}, {"end": 2468.72, "start": 2468.24, "text": "as"}, {"end": 2469.08, "start": 2468.72, "text": "well"}, {"end": 2469.2, "start": 2469.08, "text": "as"}, {"end": 2469.24, "start": 2469.2, "text": "the"}, {"end": 2469.44, "start": 2469.24, "text": "code"}, {"end": 2469.56, "start": 2469.44, "text": "in"}, {"end": 2470.2, "start": 2469.56, "text": "response"}, {"end": 2470.68, "start": 2470.2, "text": "to"}, {"end": 2470.92, "start": 2470.68, "text": "the"}, {"end": 2471.04, "start": 2470.92, "text": "current"}, {"end": 2472.72, "start": 2471.04, "text": "access"}, {"end": 2473.2, "start": 2472.72, "text": "patterns?"}, {"end": 2474.12, "start": 2473.2, "text": "So"}, {"end": 2474.36, "start": 2474.12, "text": "many,"}, {"end": 2474.6, "start": 2474.36, "text": "many"}, {"end": 2474.64, "start": 2474.6, "text": "open"}, {"end": 2474.64, "start": 2474.64, "text": "heart"}, {"end": 2474.64, "start": 2474.64, "text": "problems"}, {"end": 2474.64, "start": 2474.64, "text": "in"}, {"end": 2474.72, "start": 2474.64, "text": "the"}, {"end": 2474.84, "start": 2474.72, "text": "space."}, {"end": 2475.28, "start": 2474.84, "text": "One"}, {"end": 2475.56, "start": 2475.28, "text": "of"}, {"end": 2475.72, "start": 2475.56, "text": "the"}, {"end": 2476.32, "start": 2475.72, "text": "things"}, {"end": 2476.44, "start": 2476.32, "text": "that"}, {"end": 2477.12, "start": 2476.44, "text": "I'll"}, {"end": 2477.64, "start": 2477.12, "text": "argue"}, {"end": 2477.96, "start": 2477.64, "text": "for"}, {"end": 2478.12, "start": 2477.96, "text": "is"}, {"end": 2478.72, "start": 2478.12, "text": "that"}, {"end": 2478.72, "start": 2478.72, "text": "actually"}, {"end": 2478.76, "start": 2478.72, "text": "to"}, {"end": 2479.2, "start": 2478.76, "text": "date,"}, {"end": 2479.44, "start": 2479.2, "text": "we"}, {"end": 2479.48, "start": 2479.44, "text": "have"}, {"end": 2479.96, "start": 2479.48, "text": "gotten"}, {"end": 2480.44, "start": 2479.96, "text": "away"}, {"end": 2480.64, "start": 2480.44, "text": "in"}, {"end": 2481.2, "start": 2480.64, "text": "the"}, {"end": 2481.64, "start": 2481.2, "text": "networking"}, {"end": 2481.76, "start": 2481.64, "text": "community"}, {"end": 2482.52, "start": 2481.76, "text": "without"}, {"end": 2483.2, "start": 2482.52, "text": "common"}, {"end": 2484.04, "start": 2483.2, "text": "benchmarks."}, {"end": 2484.36, "start": 2484.04, "text": "And"}, {"end": 2484.6, "start": 2484.36, "text": "as"}, {"end": 2484.6, "start": 2484.6, "text": "we"}, {"end": 2485.2, "start": 2484.6, "text": "transition,"}, {"end": 2485.24, "start": 2485.2, "text": "I"}, {"end": 2485.4, "start": 2485.24, "text": "believe"}, {"end": 2485.48, "start": 2485.4, "text": "that"}, {"end": 2485.48, "start": 2485.48, "text": "this"}, {"end": 2485.48, "start": 2485.48, "text": "is"}, {"end": 2485.88, "start": 2485.48, "text": "going"}, {"end": 2486.28, "start": 2485.88, "text": "to"}, {"end": 2486.64, "start": 2486.28, "text": "have"}, {"end": 2486.88, "start": 2486.64, "text": "to"}, {"end": 2487.2, "start": 2486.88, "text": "change."}, {"end": 2487.8, "start": 2487.2, "text": "So"}, {"end": 2487.96, "start": 2487.8, "text": "I"}, {"end": 2487.96, "start": 2487.96, "text": "would"}, {"end": 2488.48, "start": 2487.96, "text": "call"}, {"end": 2488.56, "start": 2488.48, "text": "on"}, {"end": 2489.36, "start": 2488.56, "text": "us"}, {"end": 2489.36, "start": 2489.36, "text": "to"}, {"end": 2489.52, "start": 2489.36, "text": "put"}, {"end": 2489.96, "start": 2489.52, "text": "together"}], "text": " spec of your computation? Can we maintain dynamic runtime state and be able to perhaps replicate and move data as well as the code in response to the current access patterns? So many, many open heart problems in the space. One of the things that I'll argue for is that actually to date, we have gotten away in the networking community without common benchmarks. And as we transition, I believe that this is going to have to change. So I would call on us to put together"}, {"chunks": [{"end": 2490.44, "start": 2490.0, "text": "A"}, {"end": 2490.72, "start": 2490.44, "text": "common"}, {"end": 2491.36, "start": 2490.72, "text": "benchmarks"}, {"end": 2491.76, "start": 2491.36, "text": "that"}, {"end": 2492.04, "start": 2491.76, "text": "we"}, {"end": 2492.56, "start": 2492.04, "text": "can"}, {"end": 2492.56, "start": 2492.56, "text": "all"}, {"end": 2492.56, "start": 2492.56, "text": "use"}, {"end": 2492.56, "start": 2492.56, "text": "to"}, {"end": 2492.64, "start": 2492.56, "text": "track"}, {"end": 2492.8, "start": 2492.64, "text": "our"}, {"end": 2493.36, "start": 2492.8, "text": "progress"}, {"end": 2493.48, "start": 2493.36, "text": "and"}, {"end": 2493.48, "start": 2493.48, "text": "I'm"}, {"end": 2493.96, "start": 2493.48, "text": "inspired"}, {"end": 2494.24, "start": 2493.96, "text": "by"}, {"end": 2494.24, "start": 2494.24, "text": "the"}, {"end": 2494.44, "start": 2494.24, "text": "quote"}, {"end": 2494.56, "start": 2494.44, "text": "from"}, {"end": 2495.04, "start": 2494.56, "text": "Patterson"}, {"end": 2495.12, "start": 2495.04, "text": "and"}, {"end": 2495.4, "start": 2495.12, "text": "Hennessy,"}, {"end": 2495.64, "start": 2495.4, "text": "for"}, {"end": 2495.84, "start": 2495.64, "text": "better"}, {"end": 2496.16, "start": 2495.84, "text": "or"}, {"end": 2496.76, "start": 2496.16, "text": "worse,"}, {"end": 2497.32, "start": 2496.76, "text": "benchmarks"}, {"end": 2497.48, "start": 2497.32, "text": "shape"}, {"end": 2497.68, "start": 2497.48, "text": "the"}, {"end": 2498.24, "start": 2497.68, "text": "field."}, {"end": 2498.64, "start": 2498.24, "text": "We"}, {"end": 2499.12, "start": 2498.64, "text": "will"}, {"end": 2499.76, "start": 2499.12, "text": "absolutely"}, {"end": 2500.04, "start": 2499.76, "text": "need"}, {"end": 2500.16, "start": 2500.04, "text": "new"}, {"end": 2500.6, "start": 2500.16, "text": "programming"}, {"end": 2501.04, "start": 2500.6, "text": "models"}, {"end": 2501.44, "start": 2501.04, "text": "for"}, {"end": 2501.6, "start": 2501.44, "text": "the"}, {"end": 2501.64, "start": 2501.6, "text": "fifth"}, {"end": 2501.88, "start": 2501.64, "text": "epoch"}, {"end": 2502.16, "start": 2501.88, "text": "of"}, {"end": 2502.52, "start": 2502.16, "text": "distributed"}, {"end": 2503.2, "start": 2502.52, "text": "systems."}, {"end": 2503.68, "start": 2503.2, "text": "I"}, {"end": 2504.16, "start": 2503.68, "text": "find"}, {"end": 2504.32, "start": 2504.16, "text": "it"}, {"end": 2504.6, "start": 2504.32, "text": "both"}, {"end": 2505.12, "start": 2504.6, "text": "interesting"}, {"end": 2505.56, "start": 2505.12, "text": "and"}, {"end": 2505.92, "start": 2505.56, "text": "scary"}, {"end": 2506.08, "start": 2505.92, "text": "that"}, {"end": 2506.44, "start": 2506.08, "text": "many"}, {"end": 2506.84, "start": 2506.44, "text": "are"}, {"end": 2507.24, "start": 2506.84, "text": "still"}, {"end": 2508.76, "start": 2507.24, "text": "performance"}, {"end": 2509.24, "start": 2508.76, "text": "and"}, {"end": 2509.8, "start": 2509.24, "text": "correctness"}, {"end": 2510.12, "start": 2509.8, "text": "debugging"}, {"end": 2510.2, "start": 2510.12, "text": "the"}, {"end": 2511.0, "start": 2510.2, "text": "distributed"}, {"end": 2511.28, "start": 2511.0, "text": "systems"}, {"end": 2511.52, "start": 2511.28, "text": "with"}, {"end": 2512.04, "start": 2511.52, "text": "32x"}, {"end": 2512.44, "start": 2512.04, "text": "terms,"}, {"end": 2512.52, "start": 2512.44, "text": "get"}, {"end": 2512.88, "start": 2512.52, "text": "time"}, {"end": 2512.88, "start": 2512.88, "text": "of"}, {"end": 2513.32, "start": 2512.88, "text": "day"}, {"end": 2513.44, "start": 2513.32, "text": "and"}, {"end": 2514.08, "start": 2513.44, "text": "printf,"}, {"end": 2514.2, "start": 2514.08, "text": "which"}, {"end": 2514.24, "start": 2514.2, "text": "is"}, {"end": 2514.8, "start": 2514.24, "text": "how"}, {"end": 2515.24, "start": 2514.8, "text": "I"}, {"end": 2515.92, "start": 2515.24, "text": "was"}, {"end": 2516.24, "start": 2515.92, "text": "debugging"}, {"end": 2516.4, "start": 2516.24, "text": "my"}, {"end": 2517.16, "start": 2516.4, "text": "distributed"}, {"end": 2517.76, "start": 2517.16, "text": "systems"}, {"end": 2518.08, "start": 2517.76, "text": "certainly"}, {"end": 2519.44, "start": 2518.08, "text": "25"}, {"end": 2519.6, "start": 2519.44, "text": "years"}, {"end": 2519.96, "start": 2519.6, "text": "ago."}], "text": " A common benchmarks that we can all use to track our progress and I'm inspired by the quote from Patterson and Hennessy, for better or worse, benchmarks shape the field. We will absolutely need new programming models for the fifth epoch of distributed systems. I find it both interesting and scary that many are still performance and correctness debugging the distributed systems with 32x terms, get time of day and printf, which is how I was debugging my distributed systems certainly 25 years ago."}, {"chunks": [{"end": 2520.68, "start": 2520.0, "text": "Rack"}, {"end": 2520.92, "start": 2520.68, "text": "scale"}, {"end": 2521.6, "start": 2520.92, "text": "disaggregation,"}, {"end": 2521.84, "start": 2521.6, "text": "click"}, {"end": 2522.12, "start": 2521.84, "text": "scale"}, {"end": 2522.96, "start": 2522.12, "text": "disaggregation"}, {"end": 2523.36, "start": 2522.96, "text": "is"}, {"end": 2523.4, "start": 2523.36, "text": "an"}, {"end": 2523.48, "start": 2523.4, "text": "open"}, {"end": 2523.48, "start": 2523.48, "text": "heart"}, {"end": 2524.36, "start": 2523.48, "text": "problem."}, {"end": 2524.72, "start": 2524.36, "text": "And"}, {"end": 2524.92, "start": 2524.72, "text": "I"}, {"end": 2525.08, "start": 2524.92, "text": "think"}, {"end": 2525.28, "start": 2525.08, "text": "the"}, {"end": 2525.56, "start": 2525.28, "text": "biggest"}, {"end": 2525.92, "start": 2525.56, "text": "aspect"}, {"end": 2525.92, "start": 2525.92, "text": "of"}, {"end": 2526.16, "start": 2525.92, "text": "it"}, {"end": 2526.56, "start": 2526.16, "text": "actually"}, {"end": 2526.84, "start": 2526.56, "text": "is"}, {"end": 2527.04, "start": 2526.84, "text": "how"}, {"end": 2527.04, "start": 2527.04, "text": "we"}, {"end": 2527.48, "start": 2527.04, "text": "manage"}, {"end": 2527.84, "start": 2527.48, "text": "fault"}, {"end": 2528.16, "start": 2527.84, "text": "and"}, {"end": 2529.4, "start": 2528.16, "text": "performance"}, {"end": 2529.88, "start": 2529.4, "text": "isolation."}, {"end": 2530.32, "start": 2529.88, "text": "Basically"}, {"end": 2530.68, "start": 2530.32, "text": "as"}, {"end": 2530.92, "start": 2530.68, "text": "we"}, {"end": 2531.0, "start": 2530.92, "text": "move"}, {"end": 2531.32, "start": 2531.0, "text": "beyond"}, {"end": 2531.36, "start": 2531.32, "text": "the"}, {"end": 2531.72, "start": 2531.36, "text": "boundary"}, {"end": 2531.72, "start": 2531.72, "text": "of"}, {"end": 2531.8, "start": 2531.72, "text": "a"}, {"end": 2532.12, "start": 2531.8, "text": "single"}, {"end": 2532.56, "start": 2532.12, "text": "box"}, {"end": 2532.96, "start": 2532.56, "text": "for"}, {"end": 2533.04, "start": 2532.96, "text": "the"}, {"end": 2533.8, "start": 2533.04, "text": "basics"}, {"end": 2534.0, "start": 2533.8, "text": "of"}, {"end": 2534.48, "start": 2534.0, "text": "server"}, {"end": 2535.28, "start": 2534.48, "text": "computation,"}, {"end": 2535.56, "start": 2535.28, "text": "how"}, {"end": 2535.56, "start": 2535.56, "text": "do"}, {"end": 2535.56, "start": 2535.56, "text": "you"}, {"end": 2536.0, "start": 2535.56, "text": "protect"}, {"end": 2536.44, "start": 2536.0, "text": "against"}, {"end": 2536.64, "start": 2536.44, "text": "individual"}, {"end": 2537.92, "start": 2536.64, "text": "failures?"}, {"end": 2538.28, "start": 2537.92, "text": "Certainly"}, {"end": 2538.48, "start": 2538.28, "text": "from"}, {"end": 2538.48, "start": 2538.48, "text": "the"}, {"end": 2539.2, "start": 2538.48, "text": "perspective"}, {"end": 2539.48, "start": 2539.2, "text": "of"}, {"end": 2539.56, "start": 2539.48, "text": "the"}, {"end": 2541.24, "start": 2539.56, "text": "developer."}, {"end": 2541.64, "start": 2541.24, "text": "And"}, {"end": 2541.76, "start": 2541.64, "text": "then"}, {"end": 2542.2, "start": 2541.76, "text": "finally,"}, {"end": 2542.64, "start": 2542.2, "text": "I"}, {"end": 2543.04, "start": 2542.64, "text": "think"}, {"end": 2543.32, "start": 2543.04, "text": "we're"}, {"end": 2543.72, "start": 2543.32, "text": "going"}, {"end": 2543.72, "start": 2543.72, "text": "to"}, {"end": 2543.72, "start": 2543.72, "text": "have"}, {"end": 2543.8, "start": 2543.72, "text": "to"}, {"end": 2543.84, "start": 2543.8, "text": "increasingly"}, {"end": 2543.84, "start": 2543.84, "text": "move"}, {"end": 2544.24, "start": 2543.84, "text": "beyond"}, {"end": 2544.6, "start": 2544.24, "text": "flows"}, {"end": 2544.88, "start": 2544.6, "text": "and"}, {"end": 2545.68, "start": 2544.88, "text": "connections"}, {"end": 2545.96, "start": 2545.68, "text": "to"}, {"end": 2546.68, "start": 2545.96, "text": "ensembles"}, {"end": 2546.96, "start": 2546.68, "text": "and"}, {"end": 2547.68, "start": 2546.96, "text": "services."}, {"end": 2548.2, "start": 2547.68, "text": "We're"}, {"end": 2548.4, "start": 2548.2, "text": "gonna"}, {"end": 2548.4, "start": 2548.4, "text": "have"}, {"end": 2548.4, "start": 2548.4, "text": "to"}, {"end": 2548.56, "start": 2548.4, "text": "think"}, {"end": 2549.16, "start": 2548.56, "text": "all"}, {"end": 2549.56, "start": 2549.16, "text": "the"}, {"end": 2549.56, "start": 2549.56, "text": "way"}, {"end": 2549.56, "start": 2549.56, "text": "up"}, {"end": 2549.56, "start": 2549.56, "text": "to"}, {"end": 2549.56, "start": 2549.56, "text": "the"}, {"end": 2549.96, "start": 2549.56, "text": "application"}], "text": " Rack scale disaggregation, click scale disaggregation is an open heart problem. And I think the biggest aspect of it actually is how we manage fault and performance isolation. Basically as we move beyond the boundary of a single box for the basics of server computation, how do you protect against individual failures? Certainly from the perspective of the developer. And then finally, I think we're going to have to increasingly move beyond flows and connections to ensembles and services. We're gonna have to think all the way up to the application"}, {"chunks": [{"end": 2550.56, "start": 2550.0, "text": "Developers,"}, {"end": 2550.92, "start": 2550.56, "text": "the"}, {"end": 2551.68, "start": 2550.92, "text": "vast,"}, {"end": 2552.2, "start": 2551.68, "text": "vast,"}, {"end": 2552.76, "start": 2552.2, "text": "vast"}, {"end": 2553.12, "start": 2552.76, "text": "majority"}, {"end": 2553.12, "start": 2553.12, "text": "of"}, {"end": 2553.84, "start": 2553.12, "text": "developers,"}, {"end": 2553.88, "start": 2553.84, "text": "near"}, {"end": 2554.8, "start": 2553.88, "text": "100%"}, {"end": 2555.0, "start": 2554.8, "text": "of"}, {"end": 2555.08, "start": 2555.0, "text": "them,"}, {"end": 2555.24, "start": 2555.08, "text": "do"}, {"end": 2555.36, "start": 2555.24, "text": "not"}, {"end": 2555.84, "start": 2555.36, "text": "care"}, {"end": 2556.36, "start": 2555.84, "text": "about"}, {"end": 2556.52, "start": 2556.36, "text": "or"}, {"end": 2556.6, "start": 2556.52, "text": "know"}, {"end": 2557.04, "start": 2556.6, "text": "about"}, {"end": 2557.16, "start": 2557.04, "text": "IP"}, {"end": 2557.28, "start": 2557.16, "text": "or"}, {"end": 2558.0, "start": 2557.28, "text": "TCP."}, {"end": 2558.16, "start": 2558.0, "text": "The"}, {"end": 2558.48, "start": 2558.16, "text": "entry"}, {"end": 2558.48, "start": 2558.48, "text": "point"}, {"end": 2558.68, "start": 2558.48, "text": "for"}, {"end": 2559.04, "start": 2558.68, "text": "them"}, {"end": 2559.12, "start": 2559.04, "text": "is"}, {"end": 2559.28, "start": 2559.12, "text": "the"}, {"end": 2559.44, "start": 2559.28, "text": "remote"}, {"end": 2559.8, "start": 2559.44, "text": "procedure"}, {"end": 2560.04, "start": 2559.8, "text": "call,"}, {"end": 2560.36, "start": 2560.04, "text": "and"}, {"end": 2560.56, "start": 2560.36, "text": "even"}, {"end": 2560.96, "start": 2560.56, "text": "that"}, {"end": 2560.96, "start": 2560.96, "text": "might"}, {"end": 2560.96, "start": 2560.96, "text": "be"}, {"end": 2561.16, "start": 2560.96, "text": "too"}, {"end": 2561.48, "start": 2561.16, "text": "low"}, {"end": 2562.48, "start": 2561.48, "text": "level."}, {"end": 2563.52, "start": 2562.48, "text": "So"}, {"end": 2563.84, "start": 2563.52, "text": "we"}, {"end": 2564.04, "start": 2563.84, "text": "in"}, {"end": 2564.44, "start": 2564.04, "text": "the"}, {"end": 2564.56, "start": 2564.44, "text": "networking"}, {"end": 2564.88, "start": 2564.56, "text": "community"}, {"end": 2564.88, "start": 2564.88, "text": "need"}, {"end": 2565.28, "start": 2564.88, "text": "to"}, {"end": 2565.72, "start": 2565.28, "text": "help."}, {"end": 2565.8, "start": 2565.72, "text": "We"}, {"end": 2565.88, "start": 2565.8, "text": "need"}, {"end": 2565.96, "start": 2565.88, "text": "new"}, {"end": 2566.72, "start": 2565.96, "text": "primitives"}, {"end": 2567.32, "start": 2566.72, "text": "around"}, {"end": 2567.64, "start": 2567.32, "text": "application"}, {"end": 2567.64, "start": 2567.64, "text": "data"}, {"end": 2567.96, "start": 2567.64, "text": "units"}, {"end": 2568.24, "start": 2567.96, "text": "that"}, {"end": 2568.4, "start": 2568.24, "text": "are"}, {"end": 2568.92, "start": 2568.4, "text": "transferred"}, {"end": 2569.28, "start": 2568.92, "text": "among"}, {"end": 2569.6, "start": 2569.28, "text": "many"}, {"end": 2570.36, "start": 2569.6, "text": "endpoints."}, {"end": 2572.16, "start": 2570.36, "text": "So"}, {"end": 2572.16, "start": 2572.16, "text": "technical"}, {"end": 2573.12, "start": 2572.16, "text": "conclusions"}, {"end": 2573.12, "start": 2573.12, "text": "of"}, {"end": 2573.6, "start": 2573.12, "text": "this"}, {"end": 2574.04, "start": 2573.6, "text": "talk,"}, {"end": 2575.28, "start": 2574.04, "text": "exponential"}, {"end": 2575.88, "start": 2575.28, "text": "growth"}, {"end": 2576.28, "start": 2575.88, "text": "in"}, {"end": 2576.68, "start": 2576.28, "text": "the"}, {"end": 2577.24, "start": 2576.68, "text": "efficiency"}, {"end": 2577.84, "start": 2577.24, "text": "of"}, {"end": 2578.4, "start": 2577.84, "text": "distributed"}, {"end": 2579.12, "start": 2578.4, "text": "systems"}, {"end": 2579.36, "start": 2579.12, "text": "have"}, {"end": 2579.96, "start": 2579.36, "text": "transformed"}], "text": " Developers, the vast, vast, vast majority of developers, near 100% of them, do not care about or know about IP or TCP. The entry point for them is the remote procedure call, and even that might be too low level. So we in the networking community need to help. We need new primitives around application data units that are transferred among many endpoints. So technical conclusions of this talk, exponential growth in the efficiency of distributed systems have transformed"}, {"chunks": [{"end": 2580.96, "start": 2580.0, "text": "At"}, {"end": 2581.52, "start": 2580.96, "text": "the"}, {"end": 2581.8, "start": 2581.52, "text": "same"}, {"end": 2582.12, "start": 2581.8, "text": "time,"}, {"end": 2582.28, "start": 2582.12, "text": "the"}, {"end": 2582.92, "start": 2582.28, "text": "historical"}, {"end": 2583.52, "start": 2582.92, "text": "drivers"}, {"end": 2583.84, "start": 2583.52, "text": "for"}, {"end": 2584.04, "start": 2583.84, "text": "this"}, {"end": 2584.56, "start": 2584.04, "text": "exponential"}, {"end": 2585.12, "start": 2584.56, "text": "growth"}, {"end": 2585.6, "start": 2585.12, "text": "are"}, {"end": 2586.08, "start": 2585.6, "text": "slowing"}, {"end": 2586.32, "start": 2586.08, "text": "or"}, {"end": 2587.08, "start": 2586.32, "text": "stalling."}, {"end": 2587.6, "start": 2587.08, "text": "At"}, {"end": 2587.84, "start": 2587.6, "text": "the"}, {"end": 2588.12, "start": 2587.84, "text": "same"}, {"end": 2588.44, "start": 2588.12, "text": "time,"}, {"end": 2588.6, "start": 2588.44, "text": "the"}, {"end": 2589.32, "start": 2588.6, "text": "demand"}, {"end": 2589.48, "start": 2589.32, "text": "for"}, {"end": 2589.52, "start": 2589.48, "text": "compute"}, {"end": 2590.0, "start": 2589.52, "text": "storage"}, {"end": 2590.36, "start": 2590.0, "text": "and"}, {"end": 2590.48, "start": 2590.36, "text": "networking"}, {"end": 2591.0, "start": 2590.48, "text": "continues"}, {"end": 2591.08, "start": 2591.0, "text": "to"}, {"end": 2591.36, "start": 2591.08, "text": "grow"}, {"end": 2592.16, "start": 2591.36, "text": "exponentially"}, {"end": 2592.28, "start": 2592.16, "text": "if"}, {"end": 2592.6, "start": 2592.28, "text": "nothing"}, {"end": 2592.92, "start": 2592.6, "text": "else"}, {"end": 2593.16, "start": 2592.92, "text": "is"}, {"end": 2593.4, "start": 2593.16, "text": "actually"}, {"end": 2594.68, "start": 2593.4, "text": "accelerating."}, {"end": 2595.2, "start": 2594.68, "text": "So"}, {"end": 2595.52, "start": 2595.2, "text": "we're"}, {"end": 2596.0, "start": 2595.52, "text": "left"}, {"end": 2596.04, "start": 2596.0, "text": "with"}, {"end": 2596.12, "start": 2596.04, "text": "a"}, {"end": 2596.68, "start": 2596.12, "text": "wonderful"}, {"end": 2597.56, "start": 2596.68, "text": "opportunity"}, {"end": 2597.92, "start": 2597.56, "text": "actually,"}, {"end": 2598.0, "start": 2597.92, "text": "and"}, {"end": 2598.4, "start": 2598.0, "text": "I'll"}, {"end": 2598.4, "start": 2598.4, "text": "repeat"}, {"end": 2598.52, "start": 2598.4, "text": "a"}, {"end": 2598.96, "start": 2598.52, "text": "once"}, {"end": 2598.96, "start": 2598.96, "text": "in"}, {"end": 2599.0, "start": 2598.96, "text": "a"}, {"end": 2599.64, "start": 2599.0, "text": "generation"}, {"end": 2600.52, "start": 2599.64, "text": "opportunity,"}, {"end": 2601.04, "start": 2600.52, "text": "where"}, {"end": 2601.68, "start": 2601.04, "text": "the"}, {"end": 2602.2, "start": 2601.68, "text": "conventional"}, {"end": 2602.44, "start": 2602.2, "text": "wisdom"}, {"end": 2602.68, "start": 2602.44, "text": "that"}, {"end": 2602.68, "start": 2602.68, "text": "we've"}, {"end": 2602.96, "start": 2602.68, "text": "built"}, {"end": 2603.48, "start": 2602.96, "text": "up"}, {"end": 2603.84, "start": 2603.48, "text": "over"}, {"end": 2604.44, "start": 2603.84, "text": "decades"}, {"end": 2604.56, "start": 2604.44, "text": "is"}, {"end": 2604.92, "start": 2604.56, "text": "breaking"}, {"end": 2605.32, "start": 2604.92, "text": "down"}, {"end": 2605.48, "start": 2605.32, "text": "and"}, {"end": 2605.56, "start": 2605.48, "text": "we're"}, {"end": 2605.76, "start": 2605.56, "text": "going"}, {"end": 2605.88, "start": 2605.76, "text": "to"}, {"end": 2605.92, "start": 2605.88, "text": "need"}, {"end": 2606.04, "start": 2605.92, "text": "to"}, {"end": 2606.32, "start": 2606.04, "text": "develop"}, {"end": 2606.68, "start": 2606.32, "text": "new"}, {"end": 2607.4, "start": 2606.68, "text": "paradigms"}, {"end": 2607.44, "start": 2607.4, "text": "for"}, {"end": 2608.0, "start": 2607.44, "text": "how"}, {"end": 2608.08, "start": 2608.0, "text": "we"}, {"end": 2608.76, "start": 2608.08, "text": "build"}, {"end": 2609.96, "start": 2608.76, "text": "scale"}], "text": " At the same time, the historical drivers for this exponential growth are slowing or stalling. At the same time, the demand for compute storage and networking continues to grow exponentially if nothing else is actually accelerating. So we're left with a wonderful opportunity actually, and I'll repeat a once in a generation opportunity, where the conventional wisdom that we've built up over decades is breaking down and we're going to need to develop new paradigms for how we build scale"}, {"chunks": [{"end": 2610.16, "start": 2610.0, "text": "our"}, {"end": 2610.68, "start": 2610.16, "text": "distributed"}, {"end": 2612.04, "start": 2610.68, "text": "infrastructure."}, {"end": 2612.36, "start": 2612.04, "text": "The"}, {"end": 2612.92, "start": 2612.36, "text": "networking"}, {"end": 2613.72, "start": 2612.92, "text": "community,"}, {"end": 2614.0, "start": 2613.72, "text": "I"}, {"end": 2614.0, "start": 2614.0, "text": "think,"}, {"end": 2614.0, "start": 2614.0, "text": "is"}, {"end": 2614.0, "start": 2614.0, "text": "incredibly"}, {"end": 2614.68, "start": 2614.0, "text": "fortunate"}, {"end": 2614.68, "start": 2614.68, "text": "to"}, {"end": 2614.68, "start": 2614.68, "text": "have"}, {"end": 2614.96, "start": 2614.68, "text": "this"}, {"end": 2615.96, "start": 2614.96, "text": "opportunity."}, {"end": 2616.4, "start": 2615.96, "text": "So"}, {"end": 2616.72, "start": 2616.4, "text": "what"}, {"end": 2617.12, "start": 2616.72, "text": "community"}, {"end": 2617.52, "start": 2617.12, "text": "can"}, {"end": 2617.8, "start": 2617.52, "text": "look"}, {"end": 2618.2, "start": 2617.8, "text": "at"}, {"end": 2618.52, "start": 2618.2, "text": "its"}, {"end": 2619.0, "start": 2618.52, "text": "first"}, {"end": 2619.32, "start": 2619.0, "text": "act,"}, {"end": 2619.72, "start": 2619.32, "text": "bringing"}, {"end": 2620.24, "start": 2619.72, "text": "ubiquitous"}, {"end": 2620.36, "start": 2620.24, "text": "communication"}, {"end": 2620.36, "start": 2620.36, "text": "to"}, {"end": 2620.4, "start": 2620.36, "text": "the"}, {"end": 2620.96, "start": 2620.4, "text": "planet"}, {"end": 2621.56, "start": 2620.96, "text": "and"}, {"end": 2622.04, "start": 2621.56, "text": "enabling"}, {"end": 2622.48, "start": 2622.04, "text": "large-scale"}, {"end": 2622.84, "start": 2622.48, "text": "distributed"}, {"end": 2623.2, "start": 2622.84, "text": "systems"}, {"end": 2623.44, "start": 2623.2, "text": "that"}, {"end": 2623.52, "start": 2623.44, "text": "have"}, {"end": 2623.76, "start": 2623.52, "text": "truly"}, {"end": 2624.28, "start": 2623.76, "text": "transformed"}, {"end": 2625.64, "start": 2624.28, "text": "society?"}, {"end": 2625.8, "start": 2625.64, "text": "The"}, {"end": 2626.28, "start": 2625.8, "text": "second"}, {"end": 2626.48, "start": 2626.28, "text": "act"}, {"end": 2626.8, "start": 2626.48, "text": "is"}, {"end": 2627.04, "start": 2626.8, "text": "actually"}, {"end": 2627.28, "start": 2627.04, "text": "going"}, {"end": 2627.48, "start": 2627.28, "text": "to"}, {"end": 2627.68, "start": 2627.48, "text": "be"}, {"end": 2627.84, "start": 2627.68, "text": "as"}, {"end": 2628.36, "start": 2627.84, "text": "exciting,"}, {"end": 2628.84, "start": 2628.36, "text": "where"}, {"end": 2628.84, "start": 2628.84, "text": "we"}, {"end": 2629.76, "start": 2628.84, "text": "transition"}, {"end": 2630.28, "start": 2629.76, "text": "from"}, {"end": 2630.52, "start": 2630.28, "text": "general"}, {"end": 2630.96, "start": 2630.52, "text": "purpose"}, {"end": 2631.28, "start": 2630.96, "text": "hardware"}, {"end": 2632.04, "start": 2631.28, "text": "to"}, {"end": 2632.04, "start": 2632.04, "text": "drive"}, {"end": 2632.44, "start": 2632.04, "text": "the"}, {"end": 2632.96, "start": 2632.44, "text": "next"}, {"end": 2634.0, "start": 2632.96, "text": "1,000x"}, {"end": 2634.4, "start": 2634.0, "text": "improvement"}, {"end": 2634.48, "start": 2634.4, "text": "in"}, {"end": 2634.8, "start": 2634.48, "text": "scale"}, {"end": 2634.92, "start": 2634.8, "text": "and"}, {"end": 2635.44, "start": 2634.92, "text": "efficiency"}, {"end": 2636.24, "start": 2635.44, "text": "for"}, {"end": 2636.44, "start": 2636.24, "text": "our"}, {"end": 2637.28, "start": 2636.44, "text": "computation"}, {"end": 2639.64, "start": 2637.28, "text": "infrastructure."}, {"end": 2639.96, "start": 2639.64, "text": "OK."}], "text": " our distributed infrastructure. The networking community, I think, is incredibly fortunate to have this opportunity. So what community can look at its first act, bringing ubiquitous communication to the planet and enabling large-scale distributed systems that have truly transformed society? The second act is actually going to be as exciting, where we transition from general purpose hardware to drive the next 1,000x improvement in scale and efficiency for our computation infrastructure. OK."}, {"chunks": [{"end": 2640.36, "start": 2640.0, "text": "Before"}, {"end": 2641.24, "start": 2640.36, "text": "concluding"}, {"end": 2641.52, "start": 2641.24, "text": "the"}, {"end": 2642.0, "start": 2641.52, "text": "thought,"}, {"end": 2642.4, "start": 2642.0, "text": "I"}, {"end": 2643.0, "start": 2642.4, "text": "thought"}, {"end": 2643.4, "start": 2643.0, "text": "I"}, {"end": 2643.48, "start": 2643.4, "text": "would"}, {"end": 2643.64, "start": 2643.48, "text": "share"}, {"end": 2643.84, "start": 2643.64, "text": "some"}, {"end": 2644.36, "start": 2643.84, "text": "closing"}, {"end": 2644.84, "start": 2644.36, "text": "thoughts"}, {"end": 2645.24, "start": 2644.84, "text": "more"}, {"end": 2645.92, "start": 2645.24, "text": "broadly,"}, {"end": 2646.72, "start": 2645.92, "text": "maybe"}, {"end": 2646.92, "start": 2646.72, "text": "mostly"}, {"end": 2648.52, "start": 2646.92, "text": "non-technically"}, {"end": 2648.88, "start": 2648.52, "text": "as"}, {"end": 2649.2, "start": 2648.88, "text": "well."}, {"end": 2649.6, "start": 2649.2, "text": "So"}, {"end": 2650.4, "start": 2649.6, "text": "some"}, {"end": 2650.8, "start": 2650.4, "text": "idle"}, {"end": 2651.0, "start": 2650.8, "text": "perspectives"}, {"end": 2651.08, "start": 2651.0, "text": "from"}, {"end": 2651.4, "start": 2651.08, "text": "my"}, {"end": 2651.64, "start": 2651.4, "text": "own"}, {"end": 2652.32, "start": 2651.64, "text": "career."}, {"end": 2652.96, "start": 2652.32, "text": "In"}, {"end": 2653.56, "start": 2652.96, "text": "no"}, {"end": 2654.44, "start": 2653.56, "text": "particular"}, {"end": 2655.24, "start": 2654.44, "text": "order"}, {"end": 2656.16, "start": 2655.24, "text": "necessarily."}, {"end": 2656.72, "start": 2656.16, "text": "I'll"}, {"end": 2657.2, "start": 2656.72, "text": "start"}, {"end": 2657.6, "start": 2657.2, "text": "with"}, {"end": 2657.72, "start": 2657.6, "text": "the"}, {"end": 2658.28, "start": 2657.72, "text": "first."}, {"end": 2658.44, "start": 2658.28, "text": "Pick"}, {"end": 2659.12, "start": 2658.44, "text": "a"}, {"end": 2659.56, "start": 2659.12, "text": "great"}, {"end": 2660.36, "start": 2659.56, "text": "advisor"}, {"end": 2660.48, "start": 2660.36, "text": "and"}, {"end": 2661.48, "start": 2660.48, "text": "team,"}, {"end": 2661.72, "start": 2661.48, "text": "then"}, {"end": 2661.88, "start": 2661.72, "text": "stay"}, {"end": 2661.96, "start": 2661.88, "text": "in"}, {"end": 2662.56, "start": 2661.96, "text": "school."}, {"end": 2663.08, "start": 2662.56, "text": "There's"}, {"end": 2663.44, "start": 2663.08, "text": "this"}, {"end": 2664.0, "start": 2663.44, "text": "asterisk"}, {"end": 2664.56, "start": 2664.0, "text": "that"}, {"end": 2664.92, "start": 2664.56, "text": "says,"}, {"end": 2665.0, "start": 2664.92, "text": "I"}, {"end": 2665.44, "start": 2665.0, "text": "assume"}, {"end": 2665.52, "start": 2665.44, "text": "you"}, {"end": 2665.72, "start": 2665.52, "text": "have"}, {"end": 2666.16, "start": 2665.72, "text": "intrinsic"}, {"end": 2666.68, "start": 2666.16, "text": "motivation."}, {"end": 2666.68, "start": 2666.68, "text": "And"}, {"end": 2667.04, "start": 2666.68, "text": "this"}, {"end": 2667.32, "start": 2667.04, "text": "is,"}, {"end": 2667.88, "start": 2667.32, "text": "of"}, {"end": 2668.28, "start": 2667.88, "text": "course,"}, {"end": 2668.56, "start": 2668.28, "text": "mostly"}, {"end": 2668.72, "start": 2668.56, "text": "for"}, {"end": 2668.72, "start": 2668.72, "text": "the"}, {"end": 2669.16, "start": 2668.72, "text": "graduate"}, {"end": 2669.56, "start": 2669.16, "text": "students"}, {"end": 2669.8, "start": 2669.56, "text": "that"}, {"end": 2669.92, "start": 2669.8, "text": "might"}, {"end": 2669.92, "start": 2669.92, "text": "be"}, {"end": 2669.96, "start": 2669.92, "text": "in"}], "text": " Before concluding the thought, I thought I would share some closing thoughts more broadly, maybe mostly non-technically as well. So some idle perspectives from my own career. In no particular order necessarily. I'll start with the first. Pick a great advisor and team, then stay in school. There's this asterisk that says, I assume you have intrinsic motivation. And this is, of course, mostly for the graduate students that might be in"}, {"chunks": [{"end": 2670.92, "start": 2670.0, "text": "audience."}, {"end": 2671.08, "start": 2670.92, "text": "If"}, {"end": 2671.12, "start": 2671.08, "text": "you"}, {"end": 2671.4, "start": 2671.12, "text": "truly"}, {"end": 2671.72, "start": 2671.4, "text": "love"}, {"end": 2671.96, "start": 2671.72, "text": "computer"}, {"end": 2672.6, "start": 2671.96, "text": "science,"}, {"end": 2672.68, "start": 2672.6, "text": "I"}, {"end": 2673.0, "start": 2672.68, "text": "think"}, {"end": 2673.44, "start": 2673.0, "text": "that"}, {"end": 2673.72, "start": 2673.44, "text": "there"}, {"end": 2674.0, "start": 2673.72, "text": "is"}, {"end": 2674.0, "start": 2674.0, "text": "a"}, {"end": 2674.24, "start": 2674.0, "text": "huge"}, {"end": 2674.76, "start": 2674.24, "text": "benefit"}, {"end": 2675.0, "start": 2674.76, "text": "for"}, {"end": 2675.36, "start": 2675.0, "text": "staying"}, {"end": 2675.4, "start": 2675.36, "text": "in"}, {"end": 2675.8, "start": 2675.4, "text": "school."}, {"end": 2676.08, "start": 2675.8, "text": "But"}, {"end": 2676.48, "start": 2676.08, "text": "maybe"}, {"end": 2676.92, "start": 2676.48, "text": "the"}, {"end": 2677.6, "start": 2676.92, "text": "underlying"}, {"end": 2678.64, "start": 2677.6, "text": "principle"}, {"end": 2679.08, "start": 2678.64, "text": "here"}, {"end": 2679.32, "start": 2679.08, "text": "is"}, {"end": 2679.56, "start": 2679.32, "text": "that"}, {"end": 2679.8, "start": 2679.56, "text": "people"}, {"end": 2680.2, "start": 2679.8, "text": "matter"}, {"end": 2680.48, "start": 2680.2, "text": "more"}, {"end": 2680.48, "start": 2680.48, "text": "than"}, {"end": 2681.4, "start": 2680.48, "text": "projects."}, {"end": 2681.84, "start": 2681.4, "text": "So"}, {"end": 2681.84, "start": 2681.84, "text": "pick"}, {"end": 2681.84, "start": 2681.84, "text": "a"}, {"end": 2682.0, "start": 2681.84, "text": "great"}, {"end": 2683.0, "start": 2682.0, "text": "advisor,"}, {"end": 2683.16, "start": 2683.0, "text": "pick"}, {"end": 2683.24, "start": 2683.16, "text": "a"}, {"end": 2683.44, "start": 2683.24, "text": "great"}, {"end": 2683.8, "start": 2683.44, "text": "team,"}, {"end": 2683.84, "start": 2683.8, "text": "pick"}, {"end": 2683.84, "start": 2683.84, "text": "people"}, {"end": 2684.04, "start": 2683.84, "text": "that"}, {"end": 2684.2, "start": 2684.04, "text": "you"}, {"end": 2684.24, "start": 2684.2, "text": "would"}, {"end": 2684.52, "start": 2684.24, "text": "love"}, {"end": 2684.6, "start": 2684.52, "text": "to"}, {"end": 2684.92, "start": 2684.6, "text": "work"}, {"end": 2684.96, "start": 2684.92, "text": "with."}, {"end": 2685.32, "start": 2684.96, "text": "But"}, {"end": 2685.6, "start": 2685.32, "text": "I'll"}, {"end": 2686.2, "start": 2685.6, "text": "say"}, {"end": 2686.44, "start": 2686.2, "text": "that"}, {"end": 2687.0, "start": 2686.44, "text": "your"}, {"end": 2688.08, "start": 2687.0, "text": "research"}, {"end": 2688.32, "start": 2688.08, "text": "may"}, {"end": 2688.52, "start": 2688.32, "text": "not"}, {"end": 2688.92, "start": 2688.52, "text": "change"}, {"end": 2689.0, "start": 2688.92, "text": "the"}, {"end": 2689.4, "start": 2689.0, "text": "world,"}, {"end": 2690.16, "start": 2689.4, "text": "but"}, {"end": 2690.36, "start": 2690.16, "text": "the"}, {"end": 2690.72, "start": 2690.36, "text": "discipline"}, {"end": 2690.92, "start": 2690.72, "text": "and"}, {"end": 2691.72, "start": 2690.92, "text": "rigor"}, {"end": 2692.2, "start": 2691.72, "text": "that"}, {"end": 2692.32, "start": 2692.2, "text": "you"}, {"end": 2692.56, "start": 2692.32, "text": "learn"}, {"end": 2692.68, "start": 2692.56, "text": "to"}, {"end": 2692.8, "start": 2692.68, "text": "bring"}, {"end": 2693.24, "start": 2692.8, "text": "structure"}, {"end": 2693.48, "start": 2693.24, "text": "to"}, {"end": 2694.0, "start": 2693.48, "text": "ambiguous"}, {"end": 2694.48, "start": 2694.0, "text": "problems"}, {"end": 2694.88, "start": 2694.48, "text": "and"}, {"end": 2694.88, "start": 2694.88, "text": "to"}, {"end": 2695.32, "start": 2694.88, "text": "communicate"}, {"end": 2695.36, "start": 2695.32, "text": "these"}, {"end": 2696.24, "start": 2695.36, "text": "trade-offs"}, {"end": 2696.32, "start": 2696.24, "text": "and"}, {"end": 2696.8, "start": 2696.32, "text": "design"}, {"end": 2697.16, "start": 2696.8, "text": "will"}, {"end": 2697.48, "start": 2697.16, "text": "benefit"}, {"end": 2697.64, "start": 2697.48, "text": "you"}, {"end": 2698.76, "start": 2697.64, "text": "for"}, {"end": 2698.84, "start": 2698.76, "text": "a"}, {"end": 2699.96, "start": 2698.84, "text": "lifetime."}], "text": " audience. If you truly love computer science, I think that there is a huge benefit for staying in school. But maybe the underlying principle here is that people matter more than projects. So pick a great advisor, pick a great team, pick people that you would love to work with. But I'll say that your research may not change the world, but the discipline and rigor that you learn to bring structure to ambiguous problems and to communicate these trade-offs and design will benefit you for a lifetime."}, {"chunks": [{"end": 2701.44, "start": 2700.0, "text": "Next,"}, {"end": 2702.08, "start": 2701.44, "text": "I'll"}, {"end": 2702.8, "start": 2702.08, "text": "say"}, {"end": 2703.24, "start": 2702.8, "text": "follow"}, {"end": 2703.68, "start": 2703.24, "text": "first"}, {"end": 2703.76, "start": 2703.68, "text": "and"}, {"end": 2704.56, "start": 2703.76, "text": "last"}, {"end": 2705.0, "start": 2704.56, "text": "and"}, {"end": 2705.32, "start": 2705.0, "text": "lead"}, {"end": 2705.36, "start": 2705.32, "text": "from"}, {"end": 2705.8, "start": 2705.36, "text": "behind."}, {"end": 2706.0, "start": 2705.8, "text": "Why"}, {"end": 2706.48, "start": 2706.0, "text": "I"}, {"end": 2706.68, "start": 2706.48, "text": "say"}, {"end": 2707.0, "start": 2706.68, "text": "this"}, {"end": 2707.12, "start": 2707.0, "text": "is"}, {"end": 2707.68, "start": 2707.12, "text": "that"}, {"end": 2707.84, "start": 2707.68, "text": "I"}, {"end": 2708.04, "start": 2707.84, "text": "see"}, {"end": 2708.36, "start": 2708.04, "text": "many"}, {"end": 2708.36, "start": 2708.36, "text": "people"}, {"end": 2708.8, "start": 2708.36, "text": "impatient"}, {"end": 2709.24, "start": 2708.8, "text": "to"}, {"end": 2709.24, "start": 2709.24, "text": "lead."}, {"end": 2709.24, "start": 2709.24, "text": "They"}, {"end": 2709.36, "start": 2709.24, "text": "want"}, {"end": 2709.36, "start": 2709.36, "text": "to"}, {"end": 2709.6, "start": 2709.36, "text": "be"}, {"end": 2710.48, "start": 2709.6, "text": "the"}, {"end": 2710.88, "start": 2710.48, "text": "leader."}, {"end": 2711.2, "start": 2710.88, "text": "They"}, {"end": 2711.52, "start": 2711.2, "text": "want"}, {"end": 2711.72, "start": 2711.52, "text": "to"}, {"end": 2711.72, "start": 2711.72, "text": "be"}, {"end": 2711.72, "start": 2711.72, "text": "the"}, {"end": 2712.08, "start": 2711.72, "text": "go-to"}, {"end": 2712.48, "start": 2712.08, "text": "person."}, {"end": 2713.08, "start": 2712.48, "text": "But"}, {"end": 2713.36, "start": 2713.08, "text": "I'll"}, {"end": 2713.72, "start": 2713.36, "text": "say"}, {"end": 2714.04, "start": 2713.72, "text": "the"}, {"end": 2715.04, "start": 2714.04, "text": "number"}, {"end": 2715.84, "start": 2715.04, "text": "one"}, {"end": 2716.64, "start": 2715.84, "text": "prerequisites"}, {"end": 2716.76, "start": 2716.64, "text": "and"}, {"end": 2716.76, "start": 2716.76, "text": "the"}, {"end": 2717.12, "start": 2716.76, "text": "most"}, {"end": 2717.36, "start": 2717.12, "text": "important"}, {"end": 2717.72, "start": 2717.36, "text": "thing"}, {"end": 2717.92, "start": 2717.72, "text": "for"}, {"end": 2718.16, "start": 2717.92, "text": "being"}, {"end": 2718.28, "start": 2718.16, "text": "a"}, {"end": 2718.36, "start": 2718.28, "text": "great"}, {"end": 2719.0, "start": 2718.36, "text": "leader"}, {"end": 2719.2, "start": 2719.0, "text": "is"}, {"end": 2719.48, "start": 2719.2, "text": "actually"}, {"end": 2719.56, "start": 2719.48, "text": "being"}, {"end": 2719.76, "start": 2719.56, "text": "a"}, {"end": 2720.0, "start": 2719.76, "text": "great"}, {"end": 2720.44, "start": 2720.0, "text": "follower."}, {"end": 2720.48, "start": 2720.44, "text": "Follower"}, {"end": 2720.76, "start": 2720.48, "text": "is"}, {"end": 2721.28, "start": 2720.76, "text": "almost"}, {"end": 2721.72, "start": 2721.28, "text": "considered"}, {"end": 2721.72, "start": 2721.72, "text": "a"}, {"end": 2722.4, "start": 2721.72, "text": "bad"}, {"end": 2723.04, "start": 2722.4, "text": "word,"}, {"end": 2723.48, "start": 2723.04, "text": "but"}, {"end": 2723.84, "start": 2723.48, "text": "I"}, {"end": 2724.56, "start": 2723.84, "text": "would"}, {"end": 2724.68, "start": 2724.56, "text": "say"}, {"end": 2725.28, "start": 2724.68, "text": "that"}, {"end": 2725.68, "start": 2725.28, "text": "for"}, {"end": 2725.68, "start": 2725.68, "text": "you"}, {"end": 2725.68, "start": 2725.68, "text": "to"}, {"end": 2725.68, "start": 2725.68, "text": "know"}, {"end": 2726.04, "start": 2725.68, "text": "how"}, {"end": 2726.04, "start": 2726.04, "text": "to"}, {"end": 2726.04, "start": 2726.04, "text": "lead,"}, {"end": 2726.04, "start": 2726.04, "text": "you"}, {"end": 2726.04, "start": 2726.04, "text": "have"}, {"end": 2726.16, "start": 2726.04, "text": "to"}, {"end": 2726.88, "start": 2726.16, "text": "know"}, {"end": 2727.16, "start": 2726.88, "text": "how"}, {"end": 2727.16, "start": 2727.16, "text": "to"}, {"end": 2727.68, "start": 2727.16, "text": "work"}, {"end": 2728.04, "start": 2727.68, "text": "well"}, {"end": 2728.12, "start": 2728.04, "text": "in"}, {"end": 2728.12, "start": 2728.12, "text": "a"}, {"end": 2728.16, "start": 2728.12, "text": "team."}, {"end": 2728.36, "start": 2728.16, "text": "And"}, {"end": 2728.76, "start": 2728.36, "text": "as"}, {"end": 2728.8, "start": 2728.76, "text": "a"}, {"end": 2728.84, "start": 2728.8, "text": "leader,"}, {"end": 2728.92, "start": 2728.84, "text": "you"}, {"end": 2729.12, "start": 2728.92, "text": "should"}, {"end": 2729.12, "start": 2729.12, "text": "know"}, {"end": 2729.56, "start": 2729.12, "text": "that"}, {"end": 2729.96, "start": 2729.56, "text": "actually"}], "text": " Next, I'll say follow first and last and lead from behind. Why I say this is that I see many people impatient to lead. They want to be the leader. They want to be the go-to person. But I'll say the number one prerequisites and the most important thing for being a great leader is actually being a great follower. Follower is almost considered a bad word, but I would say that for you to know how to lead, you have to know how to work well in a team. And as a leader, you should know that actually"}, {"chunks": [{"end": 2730.12, "start": 2730.0, "text": "And"}, {"end": 2730.16, "start": 2730.12, "text": "this"}, {"end": 2730.16, "start": 2730.16, "text": "is"}, {"end": 2730.16, "start": 2730.16, "text": "why"}, {"end": 2730.28, "start": 2730.16, "text": "I"}, {"end": 2730.8, "start": 2730.28, "text": "say"}, {"end": 2731.12, "start": 2730.8, "text": "follow"}, {"end": 2731.92, "start": 2731.12, "text": "last"}, {"end": 2732.36, "start": 2731.92, "text": "only"}, {"end": 2732.4, "start": 2732.36, "text": "lead"}, {"end": 2732.56, "start": 2732.4, "text": "when"}, {"end": 2732.6, "start": 2732.56, "text": "you"}, {"end": 2733.52, "start": 2732.6, "text": "must."}, {"end": 2733.6, "start": 2733.52, "text": "And"}, {"end": 2733.6, "start": 2733.6, "text": "when"}, {"end": 2733.8, "start": 2733.6, "text": "you"}, {"end": 2734.88, "start": 2733.8, "text": "must"}, {"end": 2735.36, "start": 2734.88, "text": "ideally"}, {"end": 2735.44, "start": 2735.36, "text": "lead"}, {"end": 2735.6, "start": 2735.44, "text": "from"}, {"end": 2736.0, "start": 2735.6, "text": "behind."}, {"end": 2736.52, "start": 2736.0, "text": "In"}, {"end": 2736.84, "start": 2736.52, "text": "other"}, {"end": 2737.44, "start": 2736.84, "text": "words,"}, {"end": 2737.48, "start": 2737.44, "text": "your"}, {"end": 2737.88, "start": 2737.48, "text": "goal"}, {"end": 2738.24, "start": 2737.88, "text": "isn't"}, {"end": 2738.48, "start": 2738.24, "text": "to"}, {"end": 2738.8, "start": 2738.48, "text": "tell"}, {"end": 2738.84, "start": 2738.8, "text": "people"}, {"end": 2739.12, "start": 2738.84, "text": "what"}, {"end": 2739.48, "start": 2739.12, "text": "to"}, {"end": 2739.72, "start": 2739.48, "text": "do."}, {"end": 2740.28, "start": 2739.72, "text": "Your"}, {"end": 2740.56, "start": 2740.28, "text": "goal"}, {"end": 2740.68, "start": 2740.56, "text": "is"}, {"end": 2740.68, "start": 2740.68, "text": "to"}, {"end": 2741.12, "start": 2740.68, "text": "ensure"}, {"end": 2741.12, "start": 2741.12, "text": "that"}, {"end": 2741.12, "start": 2741.12, "text": "the"}, {"end": 2741.12, "start": 2741.12, "text": "team"}, {"end": 2741.32, "start": 2741.12, "text": "that"}, {"end": 2741.96, "start": 2741.32, "text": "you're"}, {"end": 2741.96, "start": 2741.96, "text": "a"}, {"end": 2741.96, "start": 2741.96, "text": "part"}, {"end": 2742.24, "start": 2741.96, "text": "of"}, {"end": 2742.64, "start": 2742.24, "text": "is"}, {"end": 2742.92, "start": 2742.64, "text": "hugely"}, {"end": 2743.52, "start": 2742.92, "text": "productive"}, {"end": 2743.8, "start": 2743.52, "text": "and"}, {"end": 2744.32, "start": 2743.8, "text": "happy."}, {"end": 2745.84, "start": 2744.32, "text": "And"}, {"end": 2746.2, "start": 2745.84, "text": "this"}, {"end": 2747.24, "start": 2746.2, "text": "comes"}, {"end": 2747.84, "start": 2747.24, "text": "to"}, {"end": 2748.24, "start": 2747.84, "text": "the"}, {"end": 2748.6, "start": 2748.24, "text": "next"}, {"end": 2749.0, "start": 2748.6, "text": "point"}, {"end": 2749.2, "start": 2749.0, "text": "I'd"}, {"end": 2749.2, "start": 2749.2, "text": "like"}, {"end": 2749.2, "start": 2749.2, "text": "to"}, {"end": 2749.24, "start": 2749.2, "text": "make,"}, {"end": 2749.56, "start": 2749.24, "text": "which"}, {"end": 2750.12, "start": 2749.56, "text": "is"}, {"end": 2750.72, "start": 2750.12, "text": "invest"}, {"end": 2750.84, "start": 2750.72, "text": "in"}, {"end": 2751.0, "start": 2750.84, "text": "people"}, {"end": 2751.56, "start": 2751.0, "text": "first."}, {"end": 2752.68, "start": 2751.56, "text": "While"}, {"end": 2752.92, "start": 2752.68, "text": "we're"}, {"end": 2753.4, "start": 2752.92, "text": "all"}, {"end": 2753.8, "start": 2753.4, "text": "excited"}, {"end": 2754.04, "start": 2753.8, "text": "by"}, {"end": 2754.36, "start": 2754.04, "text": "the"}, {"end": 2754.96, "start": 2754.36, "text": "technical"}, {"end": 2755.6, "start": 2754.96, "text": "opportunities"}, {"end": 2755.6, "start": 2755.6, "text": "in"}, {"end": 2756.28, "start": 2755.6, "text": "front"}, {"end": 2756.48, "start": 2756.28, "text": "of"}, {"end": 2756.52, "start": 2756.48, "text": "us"}, {"end": 2756.96, "start": 2756.52, "text": "and"}, {"end": 2757.2, "start": 2756.96, "text": "the"}, {"end": 2757.2, "start": 2757.2, "text": "technical"}, {"end": 2757.36, "start": 2757.2, "text": "impact"}, {"end": 2757.96, "start": 2757.36, "text": "that"}, {"end": 2758.0, "start": 2757.96, "text": "we"}, {"end": 2758.44, "start": 2758.0, "text": "can"}, {"end": 2759.12, "start": 2758.44, "text": "make,"}, {"end": 2759.36, "start": 2759.12, "text": "certainly"}, {"end": 2759.68, "start": 2759.36, "text": "I"}, {"end": 2759.96, "start": 2759.68, "text": "am."}], "text": " And this is why I say follow last only lead when you must. And when you must ideally lead from behind. In other words, your goal isn't to tell people what to do. Your goal is to ensure that the team that you're a part of is hugely productive and happy. And this comes to the next point I'd like to make, which is invest in people first. While we're all excited by the technical opportunities in front of us and the technical impact that we can make, certainly I am."}, {"chunks": [{"end": 2760.08, "start": 2760.0, "text": "very"}, {"end": 2760.52, "start": 2760.08, "text": "high"}, {"end": 2761.4, "start": 2760.52, "text": "probability"}, {"end": 2761.68, "start": 2761.4, "text": "the"}, {"end": 2762.08, "start": 2761.68, "text": "legacy"}, {"end": 2762.36, "start": 2762.08, "text": "that"}, {"end": 2762.44, "start": 2762.36, "text": "we"}, {"end": 2762.52, "start": 2762.44, "text": "leave"}, {"end": 2762.88, "start": 2762.52, "text": "behind"}, {"end": 2762.88, "start": 2762.88, "text": "the"}, {"end": 2762.92, "start": 2762.88, "text": "mark"}, {"end": 2763.28, "start": 2762.92, "text": "that"}, {"end": 2763.68, "start": 2763.28, "text": "we"}, {"end": 2763.88, "start": 2763.68, "text": "leave"}, {"end": 2764.28, "start": 2763.88, "text": "is"}, {"end": 2764.32, "start": 2764.28, "text": "going"}, {"end": 2764.4, "start": 2764.32, "text": "to"}, {"end": 2765.04, "start": 2764.4, "text": "be"}, {"end": 2765.44, "start": 2765.04, "text": "defined"}, {"end": 2765.68, "start": 2765.44, "text": "much"}, {"end": 2765.88, "start": 2765.68, "text": "more"}, {"end": 2766.28, "start": 2765.88, "text": "by"}, {"end": 2766.28, "start": 2766.28, "text": "the"}, {"end": 2766.28, "start": 2766.28, "text": "impact"}, {"end": 2766.48, "start": 2766.28, "text": "positive"}, {"end": 2766.88, "start": 2766.48, "text": "impact"}, {"end": 2767.2, "start": 2766.88, "text": "that"}, {"end": 2767.4, "start": 2767.2, "text": "we"}, {"end": 2767.88, "start": 2767.4, "text": "have"}, {"end": 2768.16, "start": 2767.88, "text": "on"}, {"end": 2768.6, "start": 2768.16, "text": "people"}, {"end": 2768.72, "start": 2768.6, "text": "rather"}, {"end": 2769.28, "start": 2768.72, "text": "than"}, {"end": 2769.72, "start": 2769.28, "text": "our"}, {"end": 2770.24, "start": 2769.72, "text": "contributions"}, {"end": 2770.4, "start": 2770.24, "text": "to"}, {"end": 2771.24, "start": 2770.4, "text": "technology"}, {"end": 2771.92, "start": 2771.24, "text": "so"}, {"end": 2772.28, "start": 2771.92, "text": "uh"}, {"end": 2772.48, "start": 2772.28, "text": "think"}, {"end": 2772.8, "start": 2772.48, "text": "about"}, {"end": 2772.88, "start": 2772.8, "text": "people"}, {"end": 2773.6, "start": 2772.88, "text": "first"}, {"end": 2773.92, "start": 2773.6, "text": "and"}, {"end": 2774.04, "start": 2773.92, "text": "take"}, {"end": 2774.16, "start": 2774.04, "text": "a"}, {"end": 2774.52, "start": 2774.16, "text": "chance"}, {"end": 2774.56, "start": 2774.52, "text": "on"}, {"end": 2774.84, "start": 2774.56, "text": "someone"}, {"end": 2774.92, "start": 2774.84, "text": "would"}, {"end": 2775.08, "start": 2774.92, "text": "be"}, {"end": 2775.52, "start": 2775.08, "text": "my"}, {"end": 2776.0, "start": 2775.52, "text": "advice"}, {"end": 2776.04, "start": 2776.0, "text": "in"}, {"end": 2776.16, "start": 2776.04, "text": "other"}, {"end": 2776.68, "start": 2776.16, "text": "words"}, {"end": 2777.4, "start": 2776.68, "text": "basically"}, {"end": 2777.68, "start": 2777.4, "text": "to"}, {"end": 2777.96, "start": 2777.68, "text": "whom"}, {"end": 2778.2, "start": 2777.96, "text": "can"}, {"end": 2778.48, "start": 2778.2, "text": "you"}, {"end": 2778.52, "start": 2778.48, "text": "reach"}, {"end": 2778.52, "start": 2778.52, "text": "out"}, {"end": 2778.52, "start": 2778.52, "text": "a"}, {"end": 2779.04, "start": 2778.52, "text": "hand"}, {"end": 2779.56, "start": 2779.04, "text": "and"}, {"end": 2779.56, "start": 2779.56, "text": "not"}, {"end": 2779.56, "start": 2779.56, "text": "think"}, {"end": 2779.56, "start": 2779.56, "text": "in"}, {"end": 2779.84, "start": 2779.56, "text": "terms"}, {"end": 2780.32, "start": 2779.84, "text": "of"}, {"end": 2780.52, "start": 2780.32, "text": "uh"}, {"end": 2780.84, "start": 2780.52, "text": "how"}, {"end": 2781.8, "start": 2780.84, "text": "can"}, {"end": 2782.0, "start": 2781.8, "text": "this"}, {"end": 2782.24, "start": 2782.0, "text": "person"}, {"end": 2782.52, "start": 2782.24, "text": "help"}, {"end": 2782.88, "start": 2782.52, "text": "my"}, {"end": 2783.2, "start": 2782.88, "text": "technical"}, {"end": 2783.68, "start": 2783.2, "text": "goals"}, {"end": 2783.72, "start": 2783.68, "text": "the"}, {"end": 2784.12, "start": 2783.72, "text": "most"}, {"end": 2784.24, "start": 2784.12, "text": "but"}, {"end": 2785.2, "start": 2784.24, "text": "perhaps"}, {"end": 2785.44, "start": 2785.2, "text": "how"}, {"end": 2785.72, "start": 2785.44, "text": "much"}, {"end": 2785.8, "start": 2785.72, "text": "would"}, {"end": 2786.32, "start": 2785.8, "text": "this"}, {"end": 2786.76, "start": 2786.32, "text": "person"}, {"end": 2786.76, "start": 2786.76, "text": "benefit"}, {"end": 2786.96, "start": 2786.76, "text": "from"}, {"end": 2787.24, "start": 2786.96, "text": "working"}, {"end": 2787.32, "start": 2787.24, "text": "in"}, {"end": 2787.76, "start": 2787.32, "text": "this"}, {"end": 2788.2, "start": 2787.76, "text": "area"}, {"end": 2788.36, "start": 2788.2, "text": "how"}, {"end": 2788.68, "start": 2788.36, "text": "much"}, {"end": 2788.96, "start": 2788.68, "text": "can"}, {"end": 2788.96, "start": 2788.96, "text": "i"}, {"end": 2789.0, "start": 2788.96, "text": "help"}, {"end": 2789.52, "start": 2789.0, "text": "this"}, {"end": 2789.96, "start": 2789.52, "text": "person"}], "text": " very high probability the legacy that we leave behind the mark that we leave is going to be defined much more by the impact positive impact that we have on people rather than our contributions to technology so uh think about people first and take a chance on someone would be my advice in other words basically to whom can you reach out a hand and not think in terms of uh how can this person help my technical goals the most but perhaps how much would this person benefit from working in this area how much can i help this person"}, {"chunks": [{"end": 2795.16, "start": 2790.0, "text": "Persevere."}, {"end": 2795.2, "start": 2795.16, "text": "I'll"}, {"end": 2795.28, "start": 2795.2, "text": "say"}, {"end": 2796.04, "start": 2795.28, "text": "that"}, {"end": 2796.16, "start": 2796.04, "text": "how"}, {"end": 2796.48, "start": 2796.16, "text": "you"}, {"end": 2797.64, "start": 2796.48, "text": "handle"}, {"end": 2798.52, "start": 2797.64, "text": "adversity"}, {"end": 2798.92, "start": 2798.52, "text": "is"}, {"end": 2799.28, "start": 2798.92, "text": "much"}, {"end": 2799.4, "start": 2799.28, "text": "more"}, {"end": 2799.72, "start": 2799.4, "text": "important"}, {"end": 2799.88, "start": 2799.72, "text": "than"}, {"end": 2800.08, "start": 2799.88, "text": "how"}, {"end": 2800.28, "start": 2800.08, "text": "you"}, {"end": 2800.56, "start": 2800.28, "text": "handle"}, {"end": 2801.2, "start": 2800.56, "text": "success,"}, {"end": 2801.32, "start": 2801.2, "text": "and"}, {"end": 2801.68, "start": 2801.32, "text": "that"}, {"end": 2801.68, "start": 2801.68, "text": "in"}, {"end": 2801.92, "start": 2801.68, "text": "the"}, {"end": 2802.32, "start": 2801.92, "text": "end"}, {"end": 2802.68, "start": 2802.32, "text": "is"}, {"end": 2803.24, "start": 2802.68, "text": "what's"}, {"end": 2803.56, "start": 2803.24, "text": "going"}, {"end": 2804.04, "start": 2803.56, "text": "to"}, {"end": 2804.4, "start": 2804.04, "text": "define"}, {"end": 2804.8, "start": 2804.4, "text": "you."}, {"end": 2805.52, "start": 2804.8, "text": "And"}, {"end": 2805.76, "start": 2805.52, "text": "going"}, {"end": 2806.44, "start": 2805.76, "text": "back"}, {"end": 2806.44, "start": 2806.44, "text": "to"}, {"end": 2806.44, "start": 2806.44, "text": "the"}, {"end": 2806.44, "start": 2806.44, "text": "point"}, {"end": 2806.56, "start": 2806.44, "text": "on"}, {"end": 2806.84, "start": 2806.56, "text": "leading"}, {"end": 2807.04, "start": 2806.84, "text": "versus"}, {"end": 2807.52, "start": 2807.04, "text": "following,"}, {"end": 2808.16, "start": 2807.52, "text": "patience"}, {"end": 2808.4, "start": 2808.16, "text": "is"}, {"end": 2808.8, "start": 2808.4, "text": "absolutely"}, {"end": 2808.8, "start": 2808.8, "text": "a"}, {"end": 2809.56, "start": 2808.8, "text": "virtue."}, {"end": 2810.16, "start": 2809.56, "text": "Nothing"}, {"end": 2810.52, "start": 2810.16, "text": "comes"}, {"end": 2810.96, "start": 2810.52, "text": "quickly."}, {"end": 2811.12, "start": 2810.96, "text": "It"}, {"end": 2811.76, "start": 2811.12, "text": "takes"}, {"end": 2812.12, "start": 2811.76, "text": "a"}, {"end": 2812.16, "start": 2812.12, "text": "lot"}, {"end": 2812.56, "start": 2812.16, "text": "of"}, {"end": 2815.2, "start": 2812.56, "text": "time"}, {"end": 2815.88, "start": 2815.2, "text": "and"}, {"end": 2816.04, "start": 2815.88, "text": "effort."}, {"end": 2816.68, "start": 2816.04, "text": "Finally,"}, {"end": 2816.92, "start": 2816.68, "text": "and"}, {"end": 2817.56, "start": 2816.92, "text": "most"}, {"end": 2817.84, "start": 2817.56, "text": "importantly"}, {"end": 2818.16, "start": 2817.84, "text": "for"}, {"end": 2818.2, "start": 2818.16, "text": "me,"}, {"end": 2818.52, "start": 2818.2, "text": "what"}, {"end": 2819.16, "start": 2818.52, "text": "I"}, {"end": 2819.56, "start": 2819.16, "text": "want"}, {"end": 2819.84, "start": 2819.56, "text": "to"}, {"end": 2819.84, "start": 2819.84, "text": "say"}, {"end": 2819.84, "start": 2819.84, "text": "is"}, {"end": 2819.96, "start": 2819.84, "text": "that"}], "text": " Persevere. I'll say that how you handle adversity is much more important than how you handle success, and that in the end is what's going to define you. And going back to the point on leading versus following, patience is absolutely a virtue. Nothing comes quickly. It takes a lot of time and effort. Finally, and most importantly for me, what I want to say is that"}, {"chunks": [{"end": 2820.8, "start": 2820.0, "text": "Kindness"}, {"end": 2821.0, "start": 2820.8, "text": "is"}, {"end": 2821.32, "start": 2821.0, "text": "the"}, {"end": 2822.12, "start": 2821.32, "text": "ultimate"}, {"end": 2823.12, "start": 2822.12, "text": "nobility."}, {"end": 2823.56, "start": 2823.12, "text": "Don't"}, {"end": 2824.4, "start": 2823.56, "text": "underestimate"}, {"end": 2824.56, "start": 2824.4, "text": "the"}, {"end": 2824.84, "start": 2824.56, "text": "value"}, {"end": 2824.84, "start": 2824.84, "text": "that"}, {"end": 2825.0, "start": 2824.84, "text": "a"}, {"end": 2825.52, "start": 2825.0, "text": "kind"}, {"end": 2825.8, "start": 2825.52, "text": "word"}, {"end": 2826.56, "start": 2825.8, "text": "can"}, {"end": 2827.04, "start": 2826.56, "text": "have"}, {"end": 2827.32, "start": 2827.04, "text": "on"}, {"end": 2827.48, "start": 2827.32, "text": "someone."}, {"end": 2828.12, "start": 2827.48, "text": "Conversely,"}, {"end": 2828.56, "start": 2828.12, "text": "don't"}, {"end": 2829.28, "start": 2828.56, "text": "underestimate"}, {"end": 2829.68, "start": 2829.28, "text": "how"}, {"end": 2829.8, "start": 2829.68, "text": "a"}, {"end": 2830.12, "start": 2829.8, "text": "small"}, {"end": 2830.64, "start": 2830.12, "text": "malice"}, {"end": 2830.76, "start": 2830.64, "text": "or"}, {"end": 2830.96, "start": 2830.76, "text": "small"}, {"end": 2831.96, "start": 2830.96, "text": "microaggression"}, {"end": 2832.32, "start": 2831.96, "text": "can"}, {"end": 2832.52, "start": 2832.32, "text": "really"}, {"end": 2832.92, "start": 2832.52, "text": "take"}, {"end": 2833.12, "start": 2832.92, "text": "a"}, {"end": 2833.56, "start": 2833.12, "text": "toll"}, {"end": 2833.8, "start": 2833.56, "text": "on"}, {"end": 2833.84, "start": 2833.8, "text": "a"}, {"end": 2833.84, "start": 2833.84, "text": "colleague."}, {"end": 2833.96, "start": 2833.84, "text": "Let"}, {"end": 2834.24, "start": 2833.96, "text": "me"}, {"end": 2834.8, "start": 2834.24, "text": "share"}, {"end": 2834.8, "start": 2834.8, "text": "a"}, {"end": 2835.48, "start": 2834.8, "text": "personal"}, {"end": 2835.92, "start": 2835.48, "text": "anecdote,"}, {"end": 2836.28, "start": 2835.92, "text": "one"}, {"end": 2836.64, "start": 2836.28, "text": "of"}, {"end": 2837.04, "start": 2836.64, "text": "many,"}, {"end": 2838.08, "start": 2837.04, "text": "many."}, {"end": 2838.76, "start": 2838.08, "text": "As"}, {"end": 2839.0, "start": 2838.76, "text": "a"}, {"end": 2839.36, "start": 2839.0, "text": "graduate"}, {"end": 2839.68, "start": 2839.36, "text": "student,"}, {"end": 2840.16, "start": 2839.68, "text": "I"}, {"end": 2840.76, "start": 2840.16, "text": "had"}, {"end": 2841.28, "start": 2840.76, "text": "just"}, {"end": 2841.36, "start": 2841.28, "text": "had"}, {"end": 2841.4, "start": 2841.36, "text": "my"}, {"end": 2841.64, "start": 2841.4, "text": "signature"}, {"end": 2841.92, "start": 2841.64, "text": "thesis"}, {"end": 2841.96, "start": 2841.92, "text": "work"}, {"end": 2842.48, "start": 2841.96, "text": "rejected"}, {"end": 2842.72, "start": 2842.48, "text": "for"}, {"end": 2843.08, "start": 2842.72, "text": "the"}, {"end": 2843.48, "start": 2843.08, "text": "third"}, {"end": 2843.64, "start": 2843.48, "text": "or"}, {"end": 2844.04, "start": 2843.64, "text": "fourth"}, {"end": 2845.12, "start": 2844.04, "text": "time."}, {"end": 2845.4, "start": 2845.12, "text": "And"}, {"end": 2845.92, "start": 2845.4, "text": "I"}, {"end": 2846.32, "start": 2845.92, "text": "was"}, {"end": 2846.36, "start": 2846.32, "text": "feeling"}, {"end": 2846.8, "start": 2846.36, "text": "down"}, {"end": 2847.2, "start": 2846.8, "text": "at"}, {"end": 2847.44, "start": 2847.2, "text": "the"}, {"end": 2847.92, "start": 2847.44, "text": "time."}, {"end": 2848.2, "start": 2847.92, "text": "I"}, {"end": 2848.2, "start": 2848.2, "text": "gave"}, {"end": 2848.2, "start": 2848.2, "text": "a"}, {"end": 2848.8, "start": 2848.2, "text": "talk"}, {"end": 2849.12, "start": 2848.8, "text": "on"}, {"end": 2849.32, "start": 2849.12, "text": "the"}, {"end": 2849.96, "start": 2849.32, "text": "work."}], "text": " Kindness is the ultimate nobility. Don't underestimate the value that a kind word can have on someone. Conversely, don't underestimate how a small malice or small microaggression can really take a toll on a colleague. Let me share a personal anecdote, one of many, many. As a graduate student, I had just had my signature thesis work rejected for the third or fourth time. And I was feeling down at the time. I gave a talk on the work."}, {"chunks": [{"end": 2850.2, "start": 2850.0, "text": "research"}, {"end": 2850.6, "start": 2850.2, "text": "retreat,"}, {"end": 2850.76, "start": 2850.6, "text": "Jim"}, {"end": 2850.96, "start": 2850.76, "text": "Gray"}, {"end": 2851.28, "start": 2850.96, "text": "was"}, {"end": 2851.32, "start": 2851.28, "text": "in"}, {"end": 2851.88, "start": 2851.32, "text": "the"}, {"end": 2852.44, "start": 2851.88, "text": "audience."}, {"end": 2852.72, "start": 2852.44, "text": "And"}, {"end": 2852.84, "start": 2852.72, "text": "in"}, {"end": 2852.84, "start": 2852.84, "text": "the"}, {"end": 2853.04, "start": 2852.84, "text": "feedback"}, {"end": 2854.12, "start": 2853.04, "text": "session,"}, {"end": 2854.36, "start": 2854.12, "text": "Jim"}, {"end": 2854.72, "start": 2854.36, "text": "Gray"}, {"end": 2855.44, "start": 2854.72, "text": "said,"}, {"end": 2855.88, "start": 2855.44, "text": "called"}, {"end": 2856.48, "start": 2855.88, "text": "out"}, {"end": 2856.88, "start": 2856.48, "text": "my"}, {"end": 2857.4, "start": 2856.88, "text": "work"}, {"end": 2857.52, "start": 2857.4, "text": "and"}, {"end": 2857.84, "start": 2857.52, "text": "said,"}, {"end": 2858.24, "start": 2857.84, "text": "I"}, {"end": 2858.4, "start": 2858.24, "text": "mean,"}, {"end": 2858.48, "start": 2858.4, "text": "he"}, {"end": 2858.68, "start": 2858.48, "text": "out"}, {"end": 2859.08, "start": 2858.68, "text": "visioned"}, {"end": 2859.2, "start": 2859.08, "text": "the"}, {"end": 2860.12, "start": 2859.2, "text": "visionaries."}, {"end": 2860.48, "start": 2860.12, "text": "And"}, {"end": 2860.76, "start": 2860.48, "text": "it"}, {"end": 2861.68, "start": 2860.76, "text": "wasn't"}, {"end": 2861.8, "start": 2861.68, "text": "true."}, {"end": 2861.92, "start": 2861.8, "text": "It"}, {"end": 2862.72, "start": 2861.92, "text": "wasn't"}, {"end": 2862.84, "start": 2862.72, "text": "true"}, {"end": 2863.4, "start": 2862.84, "text": "by"}, {"end": 2863.68, "start": 2863.4, "text": "far,"}, {"end": 2863.84, "start": 2863.68, "text": "but"}, {"end": 2863.88, "start": 2863.84, "text": "it"}, {"end": 2864.44, "start": 2863.88, "text": "was"}, {"end": 2864.92, "start": 2864.44, "text": "kind."}, {"end": 2865.2, "start": 2864.92, "text": "And"}, {"end": 2865.68, "start": 2865.2, "text": "literally,"}, {"end": 2866.32, "start": 2865.68, "text": "though"}, {"end": 2866.6, "start": 2866.32, "text": "I"}, {"end": 2866.76, "start": 2866.6, "text": "don't"}, {"end": 2866.8, "start": 2866.76, "text": "think"}, {"end": 2866.84, "start": 2866.8, "text": "he"}, {"end": 2866.84, "start": 2866.84, "text": "knew"}, {"end": 2867.0, "start": 2866.84, "text": "it,"}, {"end": 2867.44, "start": 2867.0, "text": "that"}, {"end": 2867.68, "start": 2867.44, "text": "gave"}, {"end": 2867.8, "start": 2867.68, "text": "me"}, {"end": 2868.08, "start": 2867.8, "text": "the"}, {"end": 2868.44, "start": 2868.08, "text": "strength"}, {"end": 2868.6, "start": 2868.44, "text": "to"}, {"end": 2869.04, "start": 2868.6, "text": "carry"}, {"end": 2869.36, "start": 2869.04, "text": "forward."}, {"end": 2869.36, "start": 2869.36, "text": "I"}, {"end": 2869.36, "start": 2869.36, "text": "was"}, {"end": 2869.44, "start": 2869.36, "text": "truly"}, {"end": 2870.0, "start": 2869.44, "text": "doubting"}, {"end": 2870.32, "start": 2870.0, "text": "whether"}, {"end": 2870.56, "start": 2870.32, "text": "or"}, {"end": 2871.04, "start": 2870.56, "text": "not"}, {"end": 2871.28, "start": 2871.04, "text": "I"}, {"end": 2871.28, "start": 2871.28, "text": "was"}, {"end": 2871.28, "start": 2871.28, "text": "cut"}, {"end": 2871.28, "start": 2871.28, "text": "out"}, {"end": 2871.28, "start": 2871.28, "text": "for"}, {"end": 2871.56, "start": 2871.28, "text": "graduate"}, {"end": 2871.88, "start": 2871.56, "text": "school."}, {"end": 2872.16, "start": 2871.88, "text": "But"}, {"end": 2872.4, "start": 2872.16, "text": "it"}, {"end": 2873.0, "start": 2872.4, "text": "was"}, {"end": 2873.52, "start": 2873.0, "text": "that"}, {"end": 2873.8, "start": 2873.52, "text": "small"}, {"end": 2874.48, "start": 2873.8, "text": "kindness,"}, {"end": 2875.0, "start": 2874.48, "text": "among"}, {"end": 2875.24, "start": 2875.0, "text": "many"}, {"end": 2875.76, "start": 2875.24, "text": "others,"}, {"end": 2875.96, "start": 2875.76, "text": "that"}, {"end": 2876.4, "start": 2875.96, "text": "gave"}, {"end": 2876.68, "start": 2876.4, "text": "me"}, {"end": 2877.2, "start": 2876.68, "text": "the"}, {"end": 2877.76, "start": 2877.2, "text": "strength"}, {"end": 2878.16, "start": 2877.76, "text": "to"}, {"end": 2878.56, "start": 2878.16, "text": "continue"}, {"end": 2878.68, "start": 2878.56, "text": "and"}, {"end": 2878.92, "start": 2878.68, "text": "to"}, {"end": 2879.4, "start": 2878.92, "text": "finish,"}, {"end": 2879.68, "start": 2879.4, "text": "literally"}, {"end": 2879.76, "start": 2879.68, "text": "in"}, {"end": 2879.96, "start": 2879.76, "text": "that"}], "text": " research retreat, Jim Gray was in the audience. And in the feedback session, Jim Gray said, called out my work and said, I mean, he out visioned the visionaries. And it wasn't true. It wasn't true by far, but it was kind. And literally, though I don't think he knew it, that gave me the strength to carry forward. I was truly doubting whether or not I was cut out for graduate school. But it was that small kindness, among many others, that gave me the strength to continue and to finish, literally in that"}, {"chunks": [{"end": 2880.24, "start": 2880.0, "text": "So"}, {"end": 2881.08, "start": 2880.24, "text": "let"}, {"end": 2881.36, "start": 2881.08, "text": "me"}, {"end": 2882.8, "start": 2881.36, "text": "close"}, {"end": 2883.24, "start": 2882.8, "text": "this"}, {"end": 2883.76, "start": 2883.24, "text": "presentation"}, {"end": 2883.76, "start": 2883.76, "text": "on"}, {"end": 2884.08, "start": 2883.76, "text": "a"}, {"end": 2884.68, "start": 2884.08, "text": "personal"}, {"end": 2885.04, "start": 2884.68, "text": "note."}, {"end": 2885.52, "start": 2885.04, "text": "I"}, {"end": 2885.88, "start": 2885.52, "text": "stand"}, {"end": 2885.88, "start": 2885.88, "text": "here"}, {"end": 2886.4, "start": 2885.88, "text": "before"}, {"end": 2886.88, "start": 2886.4, "text": "you"}, {"end": 2887.4, "start": 2886.88, "text": "all"}, {"end": 2887.48, "start": 2887.4, "text": "deeply"}, {"end": 2888.12, "start": 2887.48, "text": "humbled,"}, {"end": 2888.32, "start": 2888.12, "text": "but"}, {"end": 2888.72, "start": 2888.32, "text": "I"}, {"end": 2889.12, "start": 2888.72, "text": "stand"}, {"end": 2889.68, "start": 2889.12, "text": "here"}, {"end": 2890.36, "start": 2889.68, "text": "for"}, {"end": 2890.68, "start": 2890.36, "text": "at"}, {"end": 2891.24, "start": 2890.68, "text": "least"}, {"end": 2891.48, "start": 2891.24, "text": "two"}, {"end": 2892.56, "start": 2891.48, "text": "reasons."}, {"end": 2893.2, "start": 2892.56, "text": "Secondarily,"}, {"end": 2893.4, "start": 2893.2, "text": "I"}, {"end": 2893.8, "start": 2893.4, "text": "think"}, {"end": 2894.08, "start": 2893.8, "text": "I"}, {"end": 2894.32, "start": 2894.08, "text": "am"}, {"end": 2894.32, "start": 2894.32, "text": "a"}, {"end": 2894.88, "start": 2894.32, "text": "reflection"}, {"end": 2895.16, "start": 2894.88, "text": "of"}, {"end": 2895.4, "start": 2895.16, "text": "the"}, {"end": 2895.72, "start": 2895.4, "text": "power"}, {"end": 2895.76, "start": 2895.72, "text": "of"}, {"end": 2896.16, "start": 2895.76, "text": "sustained"}, {"end": 2896.64, "start": 2896.16, "text": "exponential"}, {"end": 2897.72, "start": 2896.64, "text": "growth."}, {"end": 2898.16, "start": 2897.72, "text": "I"}, {"end": 2898.16, "start": 2898.16, "text": "take"}, {"end": 2898.16, "start": 2898.16, "text": "it"}, {"end": 2898.52, "start": 2898.16, "text": "upon"}, {"end": 2898.68, "start": 2898.52, "text": "myself"}, {"end": 2898.72, "start": 2898.68, "text": "every"}, {"end": 2898.88, "start": 2898.72, "text": "day"}, {"end": 2899.04, "start": 2898.88, "text": "to"}, {"end": 2900.04, "start": 2899.04, "text": "try"}, {"end": 2900.36, "start": 2900.04, "text": "to"}, {"end": 2900.4, "start": 2900.36, "text": "get"}, {"end": 2900.76, "start": 2900.4, "text": "a"}, {"end": 2901.08, "start": 2900.76, "text": "little"}, {"end": 2901.44, "start": 2901.08, "text": "bit"}, {"end": 2901.72, "start": 2901.44, "text": "better"}, {"end": 2902.2, "start": 2901.72, "text": "along"}, {"end": 2902.44, "start": 2902.2, "text": "some"}, {"end": 2902.84, "start": 2902.44, "text": "dimension."}, {"end": 2903.2, "start": 2902.84, "text": "But"}, {"end": 2903.6, "start": 2903.2, "text": "what"}, {"end": 2903.64, "start": 2903.6, "text": "I've"}, {"end": 2903.68, "start": 2903.64, "text": "learned"}, {"end": 2903.96, "start": 2903.68, "text": "and"}, {"end": 2904.8, "start": 2903.96, "text": "realized"}, {"end": 2905.0, "start": 2904.8, "text": "over"}, {"end": 2905.56, "start": 2905.0, "text": "the"}, {"end": 2906.32, "start": 2905.56, "text": "years"}, {"end": 2906.6, "start": 2906.32, "text": "is"}, {"end": 2906.8, "start": 2906.6, "text": "that"}, {"end": 2907.2, "start": 2906.8, "text": "that's"}, {"end": 2907.28, "start": 2907.2, "text": "not"}, {"end": 2907.96, "start": 2907.28, "text": "sufficient."}, {"end": 2908.08, "start": 2907.96, "text": "In"}, {"end": 2908.2, "start": 2908.08, "text": "other"}, {"end": 2908.52, "start": 2908.2, "text": "words,"}, {"end": 2908.52, "start": 2908.52, "text": "if"}, {"end": 2908.56, "start": 2908.52, "text": "you"}, {"end": 2908.64, "start": 2908.56, "text": "were"}, {"end": 2908.92, "start": 2908.64, "text": "to"}, {"end": 2909.08, "start": 2908.92, "text": "look"}, {"end": 2909.36, "start": 2909.08, "text": "back"}, {"end": 2909.72, "start": 2909.36, "text": "25"}, {"end": 2909.96, "start": 2909.72, "text": "years,"}], "text": " So let me close this presentation on a personal note. I stand here before you all deeply humbled, but I stand here for at least two reasons. Secondarily, I think I am a reflection of the power of sustained exponential growth. I take it upon myself every day to try to get a little bit better along some dimension. But what I've learned and realized over the years is that that's not sufficient. In other words, if you were to look back 25 years,"}, {"chunks": [{"end": 2910.36, "start": 2910.0, "text": "and"}, {"end": 2910.88, "start": 2910.36, "text": "ask"}, {"end": 2911.24, "start": 2910.88, "text": "any"}, {"end": 2911.4, "start": 2911.24, "text": "colleague"}, {"end": 2911.56, "start": 2911.4, "text": "or"}, {"end": 2911.88, "start": 2911.56, "text": "even"}, {"end": 2912.08, "start": 2911.88, "text": "any"}, {"end": 2912.48, "start": 2912.08, "text": "friend,"}, {"end": 2913.2, "start": 2912.48, "text": "what"}, {"end": 2913.52, "start": 2913.2, "text": "are"}, {"end": 2913.56, "start": 2913.52, "text": "the"}, {"end": 2914.04, "start": 2913.56, "text": "chances"}, {"end": 2914.44, "start": 2914.04, "text": "that"}, {"end": 2914.64, "start": 2914.44, "text": "I"}, {"end": 2914.64, "start": 2914.64, "text": "would"}, {"end": 2914.72, "start": 2914.64, "text": "be"}, {"end": 2915.04, "start": 2914.72, "text": "standing"}, {"end": 2915.04, "start": 2915.04, "text": "in"}, {"end": 2915.04, "start": 2915.04, "text": "front"}, {"end": 2915.04, "start": 2915.04, "text": "of"}, {"end": 2915.12, "start": 2915.04, "text": "you"}, {"end": 2915.6, "start": 2915.12, "text": "under"}, {"end": 2915.96, "start": 2915.6, "text": "such"}, {"end": 2916.72, "start": 2915.96, "text": "circumstance?"}, {"end": 2917.36, "start": 2916.72, "text": "They"}, {"end": 2917.52, "start": 2917.36, "text": "would"}, {"end": 2918.0, "start": 2917.52, "text": "laugh,"}, {"end": 2918.08, "start": 2918.0, "text": "and"}, {"end": 2918.4, "start": 2918.08, "text": "they"}, {"end": 2918.52, "start": 2918.4, "text": "would"}, {"end": 2918.8, "start": 2918.52, "text": "laugh"}, {"end": 2919.36, "start": 2918.8, "text": "for"}, {"end": 2919.6, "start": 2919.36, "text": "a"}, {"end": 2919.64, "start": 2919.6, "text": "good"}, {"end": 2920.0, "start": 2919.64, "text": "reason."}, {"end": 2920.36, "start": 2920.0, "text": "I'm"}, {"end": 2920.56, "start": 2920.36, "text": "a"}, {"end": 2920.56, "start": 2920.56, "text": "dreamer."}, {"end": 2920.56, "start": 2920.56, "text": "I"}, {"end": 2920.6, "start": 2920.56, "text": "like"}, {"end": 2920.64, "start": 2920.6, "text": "to"}, {"end": 2920.64, "start": 2920.64, "text": "dream"}, {"end": 2920.72, "start": 2920.64, "text": "big."}, {"end": 2921.08, "start": 2920.72, "text": "But"}, {"end": 2921.28, "start": 2921.08, "text": "never"}, {"end": 2922.12, "start": 2921.28, "text": "in"}, {"end": 2922.44, "start": 2922.12, "text": "my"}, {"end": 2923.52, "start": 2922.44, "text": "wildest"}, {"end": 2923.96, "start": 2923.52, "text": "dreams"}, {"end": 2924.12, "start": 2923.96, "text": "dared"}, {"end": 2924.48, "start": 2924.12, "text": "I"}, {"end": 2925.04, "start": 2924.48, "text": "have"}, {"end": 2926.08, "start": 2925.04, "text": "such"}, {"end": 2926.48, "start": 2926.08, "text": "ambition."}, {"end": 2926.88, "start": 2926.48, "text": "So"}, {"end": 2926.96, "start": 2926.88, "text": "what"}, {"end": 2927.4, "start": 2926.96, "text": "I"}, {"end": 2928.16, "start": 2927.4, "text": "realized,"}, {"end": 2928.64, "start": 2928.16, "text": "actually,"}, {"end": 2928.84, "start": 2928.64, "text": "as"}, {"end": 2929.16, "start": 2928.84, "text": "I"}, {"end": 2929.16, "start": 2929.16, "text": "thought"}, {"end": 2929.16, "start": 2929.16, "text": "about"}, {"end": 2929.56, "start": 2929.16, "text": "this"}, {"end": 2930.0, "start": 2929.56, "text": "is"}, {"end": 2930.0, "start": 2930.0, "text": "that"}, {"end": 2930.08, "start": 2930.0, "text": "this"}, {"end": 2930.52, "start": 2930.08, "text": "sort"}, {"end": 2931.28, "start": 2930.52, "text": "of"}, {"end": 2932.04, "start": 2931.28, "text": "self-serving,"}, {"end": 2933.76, "start": 2932.04, "text": "self-perpetuating,"}, {"end": 2934.92, "start": 2933.76, "text": "self-myth"}, {"end": 2935.4, "start": 2934.92, "text": "of"}, {"end": 2935.4, "start": 2935.4, "text": "me"}, {"end": 2935.92, "start": 2935.4, "text": "pulling"}, {"end": 2936.44, "start": 2935.92, "text": "myself"}, {"end": 2936.44, "start": 2936.44, "text": "up"}, {"end": 2936.76, "start": 2936.44, "text": "by"}, {"end": 2936.92, "start": 2936.76, "text": "my"}, {"end": 2938.32, "start": 2936.92, "text": "bootstraps"}, {"end": 2939.04, "start": 2938.32, "text": "through"}, {"end": 2939.96, "start": 2939.04, "text": "growth"}], "text": " and ask any colleague or even any friend, what are the chances that I would be standing in front of you under such circumstance? They would laugh, and they would laugh for a good reason. I'm a dreamer. I like to dream big. But never in my wildest dreams dared I have such ambition. So what I realized, actually, as I thought about this is that this sort of self-serving, self-perpetuating, self-myth of me pulling myself up by my bootstraps through growth"}, {"chunks": [{"end": 2940.08, "start": 2940.0, "text": "is"}, {"end": 2940.56, "start": 2940.08, "text": "part"}, {"end": 2940.84, "start": 2940.56, "text": "of"}, {"end": 2941.0, "start": 2940.84, "text": "the"}, {"end": 2941.8, "start": 2941.0, "text": "answer,"}, {"end": 2942.28, "start": 2941.8, "text": "but"}, {"end": 2942.48, "start": 2942.28, "text": "it's"}, {"end": 2942.92, "start": 2942.48, "text": "actually"}, {"end": 2942.92, "start": 2942.92, "text": "not"}, {"end": 2942.92, "start": 2942.92, "text": "the"}, {"end": 2943.36, "start": 2942.92, "text": "primary"}, {"end": 2943.76, "start": 2943.36, "text": "answer."}, {"end": 2944.12, "start": 2943.76, "text": "The"}, {"end": 2944.2, "start": 2944.12, "text": "primary"}, {"end": 2944.32, "start": 2944.2, "text": "reason"}, {"end": 2944.96, "start": 2944.32, "text": "I"}, {"end": 2945.32, "start": 2944.96, "text": "stand"}, {"end": 2945.48, "start": 2945.32, "text": "before"}, {"end": 2945.48, "start": 2945.48, "text": "you"}, {"end": 2945.88, "start": 2945.48, "text": "today"}, {"end": 2946.28, "start": 2945.88, "text": "is"}, {"end": 2946.64, "start": 2946.28, "text": "because"}, {"end": 2947.08, "start": 2946.64, "text": "of"}, {"end": 2947.16, "start": 2947.08, "text": "the"}, {"end": 2948.16, "start": 2947.16, "text": "kindness"}, {"end": 2948.44, "start": 2948.16, "text": "of"}, {"end": 2949.28, "start": 2948.44, "text": "others."}, {"end": 2949.4, "start": 2949.28, "text": "And"}, {"end": 2949.64, "start": 2949.4, "text": "the"}, {"end": 2949.68, "start": 2949.64, "text": "list"}, {"end": 2949.68, "start": 2949.68, "text": "is"}, {"end": 2949.76, "start": 2949.68, "text": "incomplete"}, {"end": 2949.76, "start": 2949.76, "text": "and"}, {"end": 2950.04, "start": 2949.76, "text": "the"}, {"end": 2950.32, "start": 2950.04, "text": "list"}, {"end": 2950.44, "start": 2950.32, "text": "is"}, {"end": 2950.84, "start": 2950.44, "text": "long,"}, {"end": 2950.96, "start": 2950.84, "text": "but"}, {"end": 2951.16, "start": 2950.96, "text": "what"}, {"end": 2951.36, "start": 2951.16, "text": "I"}, {"end": 2951.72, "start": 2951.36, "text": "can"}, {"end": 2952.16, "start": 2951.72, "text": "say"}, {"end": 2952.32, "start": 2952.16, "text": "is"}, {"end": 2952.52, "start": 2952.32, "text": "that"}, {"end": 2953.08, "start": 2952.52, "text": "through"}, {"end": 2953.32, "start": 2953.08, "text": "act"}, {"end": 2953.56, "start": 2953.32, "text": "of"}, {"end": 2954.56, "start": 2953.56, "text": "kindness"}, {"end": 2954.8, "start": 2954.56, "text": "of"}, {"end": 2955.2, "start": 2954.8, "text": "those"}, {"end": 2955.28, "start": 2955.2, "text": "who"}, {"end": 2955.76, "start": 2955.28, "text": "stood"}, {"end": 2955.96, "start": 2955.76, "text": "with"}, {"end": 2956.48, "start": 2955.96, "text": "me,"}, {"end": 2956.68, "start": 2956.48, "text": "stood"}, {"end": 2957.16, "start": 2956.68, "text": "behind"}, {"end": 2957.16, "start": 2957.16, "text": "me,"}, {"end": 2957.16, "start": 2957.16, "text": "and"}, {"end": 2957.4, "start": 2957.16, "text": "when"}, {"end": 2957.88, "start": 2957.4, "text": "I"}, {"end": 2958.08, "start": 2957.88, "text": "needed"}, {"end": 2958.48, "start": 2958.08, "text": "most,"}, {"end": 2959.04, "start": 2958.48, "text": "literally"}, {"end": 2959.64, "start": 2959.04, "text": "stood"}, {"end": 2959.8, "start": 2959.64, "text": "in"}, {"end": 2960.24, "start": 2959.8, "text": "front"}, {"end": 2960.6, "start": 2960.24, "text": "of"}, {"end": 2960.72, "start": 2960.6, "text": "me"}, {"end": 2961.0, "start": 2960.72, "text": "showing"}, {"end": 2961.0, "start": 2961.0, "text": "the"}, {"end": 2961.84, "start": 2961.0, "text": "path"}, {"end": 2962.16, "start": 2961.84, "text": "or"}, {"end": 2962.16, "start": 2962.16, "text": "clearing"}, {"end": 2962.16, "start": 2962.16, "text": "the"}, {"end": 2962.2, "start": 2962.16, "text": "path,"}, {"end": 2962.52, "start": 2962.2, "text": "that's"}, {"end": 2962.52, "start": 2962.52, "text": "the"}, {"end": 2962.92, "start": 2962.52, "text": "primary"}, {"end": 2963.2, "start": 2962.92, "text": "reason"}, {"end": 2963.4, "start": 2963.2, "text": "that"}, {"end": 2963.68, "start": 2963.4, "text": "I"}, {"end": 2964.08, "start": 2963.68, "text": "stand"}, {"end": 2964.16, "start": 2964.08, "text": "here"}, {"end": 2964.36, "start": 2964.16, "text": "before"}, {"end": 2964.4, "start": 2964.36, "text": "you"}, {"end": 2964.96, "start": 2964.4, "text": "today."}, {"end": 2965.4, "start": 2964.96, "text": "I've"}, {"end": 2965.76, "start": 2965.4, "text": "learned"}, {"end": 2965.76, "start": 2965.76, "text": "a"}, {"end": 2965.76, "start": 2965.76, "text": "lot"}, {"end": 2967.4, "start": 2965.76, "text": "from"}, {"end": 2967.8, "start": 2967.4, "text": "that,"}, {"end": 2968.12, "start": 2967.8, "text": "and"}, {"end": 2968.88, "start": 2968.12, "text": "while"}, {"end": 2969.16, "start": 2968.88, "text": "I"}, {"end": 2969.48, "start": 2969.16, "text": "know"}, {"end": 2969.72, "start": 2969.48, "text": "that"}, {"end": 2969.88, "start": 2969.72, "text": "I"}, {"end": 2969.96, "start": 2969.88, "text": "don't"}], "text": " is part of the answer, but it's actually not the primary answer. The primary reason I stand before you today is because of the kindness of others. And the list is incomplete and the list is long, but what I can say is that through act of kindness of those who stood with me, stood behind me, and when I needed most, literally stood in front of me showing the path or clearing the path, that's the primary reason that I stand here before you today. I've learned a lot from that, and while I know that I don't"}, {"chunks": [{"end": 2970.8, "start": 2970.0, "text": "the"}, {"end": 2971.36, "start": 2970.8, "text": "hope"}, {"end": 2971.76, "start": 2971.36, "text": "of"}, {"end": 2972.56, "start": 2971.76, "text": "necessarily"}, {"end": 2972.72, "start": 2972.56, "text": "repaying"}, {"end": 2973.04, "start": 2972.72, "text": "the"}, {"end": 2973.8, "start": 2973.04, "text": "kindness"}, {"end": 2974.08, "start": 2973.8, "text": "that"}, {"end": 2974.12, "start": 2974.08, "text": "I"}, {"end": 2974.52, "start": 2974.12, "text": "received"}, {"end": 2974.84, "start": 2974.52, "text": "from"}, {"end": 2975.36, "start": 2974.84, "text": "those"}, {"end": 2975.68, "start": 2975.36, "text": "I've"}, {"end": 2975.68, "start": 2975.68, "text": "received"}, {"end": 2975.68, "start": 2975.68, "text": "it"}, {"end": 2975.68, "start": 2975.68, "text": "from."}, {"end": 2975.76, "start": 2975.68, "text": "I"}, {"end": 2975.92, "start": 2975.76, "text": "do"}, {"end": 2976.2, "start": 2975.92, "text": "intend"}, {"end": 2976.4, "start": 2976.2, "text": "to"}, {"end": 2976.4, "start": 2976.4, "text": "pay"}, {"end": 2976.44, "start": 2976.4, "text": "it"}, {"end": 2977.0, "start": 2976.44, "text": "forward"}, {"end": 2977.24, "start": 2977.0, "text": "and"}, {"end": 2977.48, "start": 2977.24, "text": "with"}, {"end": 2977.84, "start": 2977.48, "text": "sufficient"}, {"end": 2978.36, "start": 2977.84, "text": "time"}, {"end": 2978.52, "start": 2978.36, "text": "my"}, {"end": 2978.84, "start": 2978.52, "text": "hope"}, {"end": 2978.96, "start": 2978.84, "text": "is"}, {"end": 2979.24, "start": 2978.96, "text": "that"}, {"end": 2979.4, "start": 2979.24, "text": "I"}, {"end": 2979.68, "start": 2979.4, "text": "can"}, {"end": 2979.96, "start": 2979.68, "text": "give"}, {"end": 2980.28, "start": 2979.96, "text": "almost"}, {"end": 2980.8, "start": 2980.28, "text": "as"}, {"end": 2981.2, "start": 2980.8, "text": "much"}, {"end": 2981.76, "start": 2981.2, "text": "as"}, {"end": 2981.84, "start": 2981.76, "text": "I've"}, {"end": 2982.2, "start": 2981.84, "text": "got."}, {"end": 2982.4, "start": 2982.2, "text": "Thank"}, {"end": 2982.4, "start": 2982.4, "text": "you"}, {"end": 2982.64, "start": 2982.4, "text": "very"}, {"end": 2985.48, "start": 2982.64, "text": "much."}], "text": " the hope of necessarily repaying the kindness that I received from those I've received it from. I do intend to pay it forward and with sufficient time my hope is that I can give almost as much as I've got. Thank you very much."}]}}