the ag_deck
+ - 0:00:00
Notes for current slide
Notes for next slide

earth

1 / 141

earth
turtle

2 / 141

earth
turtle turtle turtle turtle turtle turtle turtle turtle turtle turtle turtle turtle turtle turtle turtle turtle turtle turtle

3 / 141
4 / 141

nyan turtle

5 / 141

> typeof universe

'recursive space turtles'

> universe instanceof RecursiveSpaceTurtles

'who's to say really?'

6 / 141

hi my name is @ag_dubs

7 / 141

real eyes

8 / 141

i am developer

9 / 141

npm install

ag_dubs

10 / 141

npm install

a-brief-history

11 / 141

i like to think about thinking

13 / 141

i like to think about thinking

especially the type of thinking that happens when people write code

14 / 141

why ideas

15 / 141

teaching is nature's way of letting you know how sloppy your thinking is

16 / 141

nodetogether

17 / 141

nodetogether

18 / 141

nodetogether

19 / 141

nodetogether

@node_together

20 / 141

howpublish

21 / 141

how do you decide what goes in a module?

22 / 141

testing

testing

24 / 141

reuse

25 / 141

garyjoke spicyjan

26 / 141

reuse

27 / 141

throw dart

28 / 141

haverbeke1 haverbeke2

29 / 141

people got mad

30 / 141

modularity seemed, as both concept and physical reality, similar to time

31 / 141

too many

32 / 141

explore

33 / 141

a brief history of time

34 / 141

our picture of the universe

turtle

35 / 141

packages people 'npm install' a lot

http://npmjs.com. Accessed 7 September 2016.
37 / 141

module counts

http://modulecounts.com. Accessed 7 September 2016.
38 / 141

npm is the LARGEST MODULE REPOSITORY IN THE WORLD.

39 / 141

npm is the LARGEST MODULE REPOSITORY IN THE WORLD.

but why?

40 / 141

why so many modules?

41 / 141

require('dijkstra');

dijkstra

42 / 141

The programmer is in the unique position... They have to be able to think in terms of conceptual hierarchies that are much deeper than a single mind ever needed to face before... the automatic computer confronts us with a radically new intellectual challenge that has no precedent in our history.

Edsgar Dijkstra

On the cruelty of really teaching computing science, EWD1036-0.
43 / 141

modularity is a way of addressing this challenge

44 / 141

what is modularity?

turtle

45 / 141

Modular programming is a software design technique that emphasizes separating the functionality of a program into independent, interchangeable modules, such that each contains everything necessary to execute only one aspect of the desired functionality.

Modular Programming. Wikipedia. https://en.wikipedia.org/wiki/Modular_programming. Accessed 9 May 2016.
46 / 141

"one aspect"

47 / 141

small modules philosophy

48 / 141

It's all about containing complexity... By making small focused modules you can easily build large complex systems without having to know every single detail of how everything works. Our short term memory is finite.

Sindre Sorhus

https://github.com/sindresorhus/ama/issues/10#issuecomment-117766328
49 / 141

how small is too small?

50 / 141

one-line-node-modules

51 / 141

left-pad

52 / 141

warning

53 / 141

left-pad

54 / 141

left-pad

55 / 141

left-pag

56 / 141

shit

57 / 141

shit

58 / 141

left-pad

59 / 141

did we forget to program when we stopped writing C?

60 / 141

did we forget to program when we stopped writing C?

... or when we stopped writing assembly?

61 / 141

did we forget to program when we stopped writing C?

... or when we stopped writing assembly?

... or when we stopped doing electrical engineering?

62 / 141

no true programmer!

63 / 141

no true scotsman!

64 / 141

no true programmer

65 / 141

no true programmer

no

66 / 141

When applications are done well, they are just the really application-specific, brackish residue that can't be so easily abstracted away. All the nice, reusable components sublimate away onto github and npm where everybody can collaborate to advance the commons.

substack

http://substack.net/how_I_write_modules
67 / 141

communism all the way down

68 / 141

commons are Hard...

69 / 141

rollingweekly

70 / 141

require('gall');

gall systemantics

71 / 141

A complex system that works is invariably found to have evovled from a simple system that worked. A complex system designed from scratch never works and cannot be patched up to make it work. You have to start over with a simple system.

John Gall

72 / 141

what is simplicity?

turtle

73 / 141

simpleeasy

Rich Hickey, "Simple, Made Easy" http://www.infoq.com/presentations/Simple-Made-Easy Strangeloop 2011
74 / 141

what is information?

75 / 141

require('cesar');

hidalgo

76 / 141

why information grows

77 / 141

why can order in the universe deteriorate even as it grows on Earth?

78 / 141

Information is not a thing; rather it is the arrangement of physical things. It is physical order, like what distinguishes different shuffles of a deck of cards. What is surprising to most people, however, is that information is meaningless.

79 / 141

it's not what the modules contain

it's how we put them together

80 / 141

the trouble with modularity

turtle

81 / 141

The more I modularize my code. The bigger it gets.

Nolan Lawson

"The cost of small modules". Read the Tea Leaves. 15 August 2016.
82 / 141

Over 400ms is being spent simply walking the Browserify tree.

Sam Saccone

"The cost of small modules". Read the Tea Leaves. 15 August 2016.
83 / 141

the cost of small modules

84 / 141

duckhorse

85 / 141

How many modules are in a typical web application?

  • requirebin.com: 91 modules

  • keybase.io: 365 modules

  • m.reddit.com: 1050 modules

  • Apple.com: 1060 modules

https://nolanlawson.com/2016/08/15/the-cost-of-small-modules/
86 / 141

loadtime

87 / 141

it's not the size of the modules, it's the sheer number of them

88 / 141

Yes, small modules are easier to write. Yes, they’re easier to test. Yes, it’s easier to adhere to semver. These are all things that make your life as a library author easier. As we’ve seen, they come at a cost for others.

Rich Harris

https://medium.com/@Rich_Harris/small-modules-it-s-not-quite-that-simple-3ca532d65de4#.9qtsjcmd6
89 / 141

the small modules philosophy:

90 / 141

the small modules philosophy:

  • benefits the library writers

91 / 141

the small modules philosophy:

  • benefits the library writers

  • disadvantages application writes

92 / 141

the small modules philosophy:

  • benefits the library writers

  • disadvantages application writes

  • harms end users

93 / 141

how did we end up here?

94 / 141

require('kuhn');

kuhn

95 / 141

Scientists work from models acquired through education and through subsequent exposure to the literature often without quite knowing or needing to know what characteristics have given these models the status of community paradigms.

Thomas Kuhn

Kuhn, Thomas. "The Structure of Scientific Revolutions", pg 46 (1962)
96 / 141

inconvenience

97 / 141

require('ceejbot');

ceejbot

98 / 141

Your monolith is complex. A split system is more complex.

CJ Silverio

99 / 141

solution

100 / 141

require('hickey');

hickey

101 / 141

Most of the big problems in software are problems of misconception.

Rich Hickey

"Hammock Driven Development". Clojure Conj, 2010. https://www.youtube.com/watch?v=f84n5oFoZBc.
102 / 141

software development is change management

turtle

103 / 141

require('hawking');

hawking

104 / 141

It is an interesting reflection on the general climate of thought before the twentieth century that no one had suggested that the universe was expanding or contracting.

Steven Hawking

A Brief History of Time. Bantam Books Trade Paperbacks: 6, 1988.
105 / 141

require('parnas');

david parnas decomposing criteria paper

106 / 141

[Start] with a list of difficult design decisions or design decisions which are likely to change. Each module is then designed to hide such a decision from the others.

David Parnas

Parnas, D. L. 1972 On the Criteria To Be Used in Decomposing Systems into Modules. Association for Computing Machinery, Inc: Programming Techniques, 1053-1058.
107 / 141

the goal of modularity is not to make things easier but to hide the things that are hard

108 / 141

evolutionary origins of modularity header

109 / 141

Here we demonstrate that the ubiquitous, direct selection pressure to reduce the cost of connections between network nodes causes the emergence of modular networks.

Clune J, Mouret J-B, Lipson H. 2013 The evolutionary origins of modularity. Proc R Soc B 280: 20122863. http://dx.doi.org/10.1098/rspb.2012.2863
110 / 141
111 / 141

how to computer?

turtle hiding

112 / 141

None of us are born knowing how to write software.

Rich Hickey

113 / 141

failure

114 / 141

all is not lost, dogs know calculus

115 / 141

dogcalc

116 / 141

dogcalc

117 / 141

dogcalc

118 / 141

corgis are made of star stuff

119 / 141

corgis are made of star stuff

and so are we

120 / 141

dylan

121 / 141

despair?

122 / 141

require('sartre');

sartre

123 / 141

tef tweet

124 / 141

require('tef');

tef

125 / 141

Write code that is easy to delete, not easy to extend. Instead of building re-usable software, we should try to build disposable software. I don’t need to tell you that deleting code is more fun than writing it.

Tef

http://programmingisterrible.com/post/139222674273/write-code-that-is-easy-to-delete-not-easy-to
126 / 141

repeat yourself to avoid creating dependencies, but don’t repeat yourself to manage them

127 / 141

layer your code too: build simple-to-use APIs out of simpler-to-implement but clumsy-to-use parts.

128 / 141

split your code: isolate the hard-to-write and the likely-to-change parts from the rest of the code, and each other.

129 / 141

don’t try to do all of these things at the same time, and maybe don’t write so much code in the first place.

130 / 141

what is spacetime?

131 / 141

spacetime

refers to whatever external reality underlies our collective experiences of the space between things and the time between events.

"Are Space and Time An Illusion" PBS Space Time, https://www.youtube.com/watch?v=YycAzdtUIko.
132 / 141

why not just time? why not just space?

133 / 141

why add space time as an extra concept?

134 / 141

Suppose 2 observers are moving at relative speeds to each other...

  • they can't agree on how much time passes between events

  • they can't agree on how much space

  • they can't EVEN agree on the chronological order of events

135 / 141

... yet neither of them is wrong.

136 / 141

what is time is a tough question, it's not even the full question

137 / 141

what is modularity is a tough question, it's not even the full question

138 / 141

julia how to be a wizerd

Julia Evans, @b0rk

139 / 141

npm install

a-brief-history

{ "name": "a brief history and mishistory of modularity", "author": "ashley williams @ag_dubs", "version": "1.0.0", "dependencies" : { "Edsger Dijkstra": "On the Cruelty of Really Teaching Computer Science", "Stephen Hawking": "A Brief History of Time", "Rich Hickey": "Hammock Driven Development", "Rich Hickey": "Design, Composition, Performance", "Tef": "Write code that is easy to delete, not easy to extend.", "CJ Silverio": "Cheating Gall's Law", "Nolan Lawson": "The cost of small modules", "Substack": "How I write modules", "Sindre Sohrus": "Small Modules: Tales from a Serial Module Author" }

140 / 141

squirtle

141 / 141

earth
turtle

2 / 141
Paused

Help

Keyboard shortcuts

, , Pg Up, k Go to previous slide
, , Pg Dn, Space, j Go to next slide
Home Go to first slide
End Go to last slide
b / m / f Toggle blackout / mirrored / fullscreen mode
c Clone slideshow
p Toggle presenter mode
t Restart the presentation timer
?, h Toggle this help
Esc Back to slideshow