Technology,
a means to
an end.
Thibault Imbert
1996 - Discovered BASIC on my dad’s T07.


1998 - Started playing with Flash in my bedroom
!
2004 - Teaching programming
!...
CSS Shapes
Blend modes
Masking
justinjackson.ca/words.html
Technology
to serve a goal.
Focus on the goal, implementation is a detail.
detail.
C++, Objective-C, ActionScript, JavaScript, Java, C#…
Don’t place a technology.
Use the best one to do the best job.
DHTML!
Flash
Ajax!
Flash
Silverlight!
Flash
Familiar?
Native!
HTML/JS!
It is about the result, the end goal.
Technologies, come and go.
So I should not care?
Be passionate, stay curious,
and always assume you don’t know.
"The most dangerous thought you can have as a creative
person is to think you know what you're doing.” - Bret Victor
JavaScript will win.
C++ will win.
Obj-C will win.
Dart will win.
Why should one win?
There is no safe bet.
By being religious, you barricade yourself.
You stop learning and start having
preconceived ideas.
JavaScript is for “scripting” only.
asmjs.org
an extraordinarily optimizable, low-level subset of JavaScript
JavaScript is not object-oriented.
ES6
//	
  entities.js	
  
module	
  entities	
  {	
  
	
  	
  	
  	
  	
  
	
  	
  	
  	
  export	
  class	
  Person	
  {	
  
...
But what if I want static-typing?
www.typescriptlang.org
//	
  entities.js	
  
module	
  entities	
  {	
  
	
  	
  	
  	
  	
  
	
  	
  	
  	
  export	
  class	
  Person	
  {	
  
...
Which will generate plain ES5 compatible JS
var	
  Person	
  =	
  (function	
  ()	
  {	
  
	
  	
  	
  	
  function	
  Person(name,	
  age,	
  town)	
  {	
  
	
  	
  ...
Challenge, run the original Space Invaders ROM in JS
Ported in an hour to JavaScript
Chose the best option (for me)
to get the job done.
C# is for Windows developers only
Xamarin
C++ is way too low-level.
C++11
#include	
  <iostream>	
  
#include	
  <stdint.h>	
  
#include	
  <iostream>	
  
#include	
  <vector>	
  
#include	
  <alg...
I am a web guy, doing scripting, cool
native stuff is hard.
Starry Night by Petros Vrellis
openFrameworks
Functional programming languages are not for real world usage.
Imperative programming is:
I want a latte.
Heat some milk.
Put it into a cup.
Brew some coffee with a stovetop Moka pot.
Po...
Functional programming is:
I want a latte.
Thank you.
Have a look at F#
let numbers = [ 0..2..20 ]
!
val numbers : int list = [0; 2; 4; 6; 8; 10; 12; 14; 16; 18; 20]
var value = Math.abs ( Math.round ( Math.sqrt ( 3.56 ) ) );
let result =
3.56
|> System.Math.Sqrt
|> System.Math.Round
|> ...
let numbers = [ 0..3..30 ]
let square x = x * x
!
let sumSquare nums =
let mutable buffer = 0
for i in nums do
buffer <- buff...
let sumSquare nums =
nums
|> Seq.map ( fun x -> x * x )
|> Seq.sum
Multicore and web apps? No way.
&
myPA	
  =	
  [1,	
  2,	
  3];	
  
	
  	
  
//	
  incrementation	
  is	
  parallelized	
  on	
  the	
  GPU	
  
myPlusPA	
  ...
myPA	
  =	
  [1,	
  2,	
  3];	
  
	
  	
  
//	
  incrementation	
  is	
  parallelized	
  on	
  the	
  GPU	
  
myPlusPA	
  ...
OpenCL (behind the scene)
Multicore and web apps? No way.
River Trail
bit.ly/qme8BY
You may never use these, but they will
make you a better developer, so keep
learning new stuff.
Creativity, but stepping back from technology.
Goal
Experiment
Fail
Iterate
Not good!
Not good
Looks good!
Looks good!
Success is not an event, it is a process.
James Clear.
@thibault_imbert
Thank you!
FITC '14 Toronto - Technology, a means to an end
FITC '14 Toronto - Technology, a means to an end
FITC '14 Toronto - Technology, a means to an end
FITC '14 Toronto - Technology, a means to an end
FITC '14 Toronto - Technology, a means to an end
FITC '14 Toronto - Technology, a means to an end
FITC '14 Toronto - Technology, a means to an end
FITC '14 Toronto - Technology, a means to an end
FITC '14 Toronto - Technology, a means to an end
FITC '14 Toronto - Technology, a means to an end
FITC '14 Toronto - Technology, a means to an end
FITC '14 Toronto - Technology, a means to an end
FITC '14 Toronto - Technology, a means to an end
FITC '14 Toronto - Technology, a means to an end
FITC '14 Toronto - Technology, a means to an end
FITC '14 Toronto - Technology, a means to an end
FITC '14 Toronto - Technology, a means to an end
FITC '14 Toronto - Technology, a means to an end
FITC '14 Toronto - Technology, a means to an end
FITC '14 Toronto - Technology, a means to an end
Upcoming SlideShare
Loading in...5
×

FITC '14 Toronto - Technology, a means to an end

6,222

Published on

Technology is fascinating, but should this be what drives us? What are the things you can do to differentiate yourself today? With all that noise, what are things you should be looking at?

In this talk, Thibault Imbert will look at the different technologies available today to build amazing experiences and what’s coming tomorrow. He will focus on the importance of learning, crafting and getting out of your comfort zone and most importantly, to never be religious about a technology.

Published in: Technology
1 Comment
72 Likes
Statistics
Notes
No Downloads
Views
Total Views
6,222
On Slideshare
0
From Embeds
0
Number of Embeds
8
Actions
Shares
0
Downloads
79
Comments
1
Likes
72
Embeds 0
No embeds

No notes for slide

FITC '14 Toronto - Technology, a means to an end

  1. 1. Technology, a means to an end. Thibault Imbert
  2. 2. 1996 - Discovered BASIC on my dad’s T07. 
 1998 - Started playing with Flash in my bedroom ! 2004 - Teaching programming ! 2008 - Joined Adobe (France) ! 2010 - Moved to San Francisco (PM for Flash Player) ! 2014 - Working on next-gen web authoring tools/services projectparfait.adobe.com
  3. 3. CSS Shapes
  4. 4. Blend modes
  5. 5. Masking
  6. 6. justinjackson.ca/words.html
  7. 7. Technology to serve a goal.
  8. 8. Focus on the goal, implementation is a detail.
  9. 9. detail.
  10. 10. C++, Objective-C, ActionScript, JavaScript, Java, C#…
  11. 11. Don’t place a technology. Use the best one to do the best job.
  12. 12. DHTML! Flash
  13. 13. Ajax! Flash
  14. 14. Silverlight! Flash
  15. 15. Familiar? Native! HTML/JS!
  16. 16. It is about the result, the end goal.
  17. 17. Technologies, come and go.
  18. 18. So I should not care?
  19. 19. Be passionate, stay curious, and always assume you don’t know.
  20. 20. "The most dangerous thought you can have as a creative person is to think you know what you're doing.” - Bret Victor
  21. 21. JavaScript will win. C++ will win. Obj-C will win. Dart will win. Why should one win? There is no safe bet.
  22. 22. By being religious, you barricade yourself.
  23. 23. You stop learning and start having preconceived ideas.
  24. 24. JavaScript is for “scripting” only.
  25. 25. asmjs.org an extraordinarily optimizable, low-level subset of JavaScript
  26. 26. JavaScript is not object-oriented.
  27. 27. ES6
  28. 28. //  entities.js   module  entities  {                    export  class  Person  {   !            private  message  =  "Hi  my  name  is  ";   !            constructor  (public  name,  public  age,  public  town){                      this.name  =  name;                      this.age  -­‐  age;                      this.town  =  town;              }   !            talk(){                      return  this.message  +  this.name;              }   !            get  isAbove18(){                      return  this.age  >=  18;              }   }
  29. 29. But what if I want static-typing?
  30. 30. www.typescriptlang.org
  31. 31. //  entities.js   module  entities  {                    export  class  Person  {   !            private  message  :string  =  "Hi  my  name  is  ";   !            constructor  (public  name:  string,  public  age:  number,  public     town:  string){                      this.name  =  name;                      this.age  =  age;                      this.town  =  town;              }   !            talk(){                      return  this.message  +  this.name;              }   !            get  isAbove18(){                      return  this.age  >=  18;              }   }
  32. 32. Which will generate plain ES5 compatible JS
  33. 33. var  Person  =  (function  ()  {          function  Person(name,  age,  town)  {                  this.name  =  name;                  this.age  =  age;                  this.town  =  town;                  this.message  =  "Hi  my  name  is  ";                  this.name  =  name;                  this.age  -­‐  age;                  this.town  =  town;          }          Person.prototype.talk  =  function  ()  {                  return  this.message  +  this.name;          };   !        Object.defineProperty(Person.prototype,  "isAbove18",  {                  get:  function  ()  {                          return  this.age  >=  18;                  },                  enumerable:  true,                  configurable:  true          });          return  Person;   })();  
  34. 34. Challenge, run the original Space Invaders ROM in JS
  35. 35. Ported in an hour to JavaScript
  36. 36. Chose the best option (for me) to get the job done.
  37. 37. C# is for Windows developers only
  38. 38. Xamarin
  39. 39. C++ is way too low-level.
  40. 40. C++11
  41. 41. #include  <iostream>   #include  <stdint.h>   #include  <iostream>   #include  <vector>   #include  <algorithm>   ! int  main(int  argc,  const  char  *  argv[])   {          std::vector<uint32_t>  data  =  {  234,  76767,  43,  343,  4322,  33,  122  };                    std::sort(data.begin(),  data.end(),  []  (uint32_t  a,  uint32_t  b)  {  return  a  <  b;  });                    for  (auto  i  =  data.begin();  i  <  data.end();  i++)  {                  std::cout  <<  *i  <<  std::endl;          }                    class  MyClass  {                  public:                          MyClass(size_t  size)  :  m_size(size)  {  }                          MyClass(const  char  *str)  :  MyClass(strlen(str))  {  }                          size_t  Size()  {  return  m_size;  }                  private:                          size_t  m_size;          };                    MyClass  obj("Hello!");          std::cout  <<  obj.Size()  <<  std::endl;          return  0;   }
  42. 42. I am a web guy, doing scripting, cool native stuff is hard.
  43. 43. Starry Night by Petros Vrellis
  44. 44. openFrameworks
  45. 45. Functional programming languages are not for real world usage.
  46. 46. Imperative programming is: I want a latte. Heat some milk. Put it into a cup. Brew some coffee with a stovetop Moka pot. Pour the coffee into the heated milk. Thank you.
  47. 47. Functional programming is: I want a latte. Thank you.
  48. 48. Have a look at F#
  49. 49. let numbers = [ 0..2..20 ] ! val numbers : int list = [0; 2; 4; 6; 8; 10; 12; 14; 16; 18; 20]
  50. 50. var value = Math.abs ( Math.round ( Math.sqrt ( 3.56 ) ) ); let result = 3.56 |> System.Math.Sqrt |> System.Math.Round |> System.Math.Abs
  51. 51. let numbers = [ 0..3..30 ] let square x = x * x ! let sumSquare nums = let mutable buffer = 0 for i in nums do buffer <- buffer + square i buffer ! let result = sumSquare numbers
  52. 52. let sumSquare nums = nums |> Seq.map ( fun x -> x * x ) |> Seq.sum
  53. 53. Multicore and web apps? No way.
  54. 54. &
  55. 55. myPA  =  [1,  2,  3];       //  incrementation  is  parallelized  on  the  GPU   myPlusPA  =  myPA.mapPar(val  =>  val  +  1);  
  56. 56. myPA  =  [1,  2,  3];       //  incrementation  is  parallelized  on  the  GPU   myPlusPA  =  myPA.mapPar(val  =>  val  +  1);  
  57. 57. OpenCL (behind the scene)
  58. 58. Multicore and web apps? No way.
  59. 59. River Trail bit.ly/qme8BY
  60. 60. You may never use these, but they will make you a better developer, so keep learning new stuff.
  61. 61. Creativity, but stepping back from technology.
  62. 62. Goal Experiment Fail Iterate
  63. 63. Not good! Not good Looks good! Looks good!
  64. 64. Success is not an event, it is a process. James Clear.
  65. 65. @thibault_imbert Thank you!
  1. A particular slide catching your eye?

    Clipping is a handy way to collect important slides you want to go back to later.

×