language language vi virtua rtualization lization fo for
play

Language Language Vi Virtua rtualization lization fo for r - PowerPoint PPT Presentation

Language Language Vi Virtua rtualization lization fo for r Heterogeneo Heterogeneous us Par Parallel allel Computing Computing Hassan Chafi, Arvind Sujeeth, Zach DeVito, Pat Hanrahan, Kunle Olukotun Stanford University Adriaan


  1. Language Language Vi Virtua rtualization lization fo for r Heterogeneo Heterogeneous us Par Parallel allel Computing Computing Hassan Chafi, Arvind Sujeeth, Zach DeVito, Pat Hanrahan, Kunle Olukotun Stanford University Adriaan Moors, Tiark Rompf, Martin Odersky EPFL

  2. Er Era a of of Pow Power er Li Limited Computing mited Computing  Mobile  Data center  Battery operated  Energy costs  Passively cooled  Infrastructure costs

  3. Computing Computing Sy Syst stem em Po Power wer Ops  Op  Power Energy second

  4. He Heterogeneous terogeneous Ha Hardware rdware Heterogeneous HW for energy efficiency  Multi-core, ILP, threads, data-parallel engines, custom engines  H.264 encode study  1000 Performance Energy Savings Future performance gains will mainly come from heterogeneous 100 hardware with different specialized resources 10 1 4 cores + ILP + SIMD + custom ASIC inst Source: Understanding Sources of Inefficiency in General-Purpose Chips (ISCA’10)

  5. DE DE Shaw Shaw Re Research: search: Anton Anton Molecular dynamics computer 100 times more power efficient D. E. Shaw et al. SC 2009, Best Paper and Gordon Bell Prize

  6. Ap Apple ple A4 A4 in in the i{ the i{Pad|Phone Pad|Phone} Contains CPU and GPU and …

  7. He Heterogeneous terogeneous Pa Parallel rallel Com Computing puting Uniprocessor  Intel Sequential programming  Pentium 4 C  CMP (Multicore)  Sun Threads and locks  T2 C + (Pthreads, OpenMP)  GPU  Nvidia Data parallel programming  Fermi C + (Pthreads, OpenMP) + (CUDA, OpenCL)  Cluster  Message passing  Cray C + (Pthreads, OpenMP) + (CUDA, OpenCL) + MPI  Jaguar Too many different programming models

  8. It’s all About Energy (Ul Ultimately: timately: Mo Money) ney)  Human effort just like electrical power  Aim: reduce development effort, increase performance  Increase performance now means:  reduce energy per op  increase # of targets  Need to reduce effort per target!

  9. A Sol A Solution ution For or Pe Pervasi vasive ve Pa Paralle rallelism lism  Domain Specific Languages (DSLs) Programming language with restricted expressiveness for a particular  domain

  10. The The Hol Holy y Gr Grail ail of of Pe Performance rformance Oriented Or iented La Languages nguages Performance Productivity Completeness

  11. The The Hol Holy y Gr Grail ail of of Pe Performance rformance Or Oriented iented La Languages nguages Performance Target DSLs Productivity Completeness

  12. Be Bene nefits fits of Us of Usin ing g DS DSLs Ls for Par for Paralle allelis lism Productivity • Shield average programmers from the difficulty of parallel programming • Focus on developing algorithms and applications and not on low level implementation details Performance • Match generic parallel execution patterns to high level domain abstraction • Restrict expressiveness to more easily and fully extract available parallelism • Use domain knowledge for static/dynamic optimizations Portability and forward scalability • DSL & Runtime can be evolved to take advantage of latest hardware features • Applications remain unchanged • Allows HW vendors to innovate without worrying about application portability

  13. New New Pro Problem blem We need to develop all these DSLs Current DSL methods are unsatisfactory

  14. Cu Curre rrent nt DS DSL De L Deve velo lopm pment ent Ap Approa proache ches  Stand-alone DSLs Can include extensive optimizations  Enormous effort to develop to a sufficient degree of maturity   Actual Compiler/Optimizations  Tooling (IDE, Debuggers,…) Interoperation between multiple DSLs is very difficult   Purely embedded DSLs ⇒ “just a library” Easy to develop (can reuse full host language)  Easier to learn DSL  Can Combine multiple DSLs in one program  Can Share DSL infrastructure among several DSLs  Hard to optimize using domain knowledge  Target same architecture as host language  Need to do better

  15. Need to Need to Do Do Better Better  Goal: Develop embedded DSLs that perform as well as stand-alone ones  Intuition: General-purpose languages should be designed with DSL embedding in mind  Can we make this intuition more tangible?

  16. Vi Virtualization rtualization Analogy Analogy Want to have a range of differently configured machines • Not practical to run as many physical machines • Hardware Virtualization: run the logical machines on virtualizable physical hardware Want to have a range of different languages • Not practical to implement as many compilers • Language Virtualization: embed the logical languages into a virtualizable host language

  17. La Lang nguage uage Vi Virt rtua ualiz lizat atio ion Req n Requi uirem rement ents Expressiveness • Encompasses syntax, semantics and general ease of use for domain experts Performance • Embedded language must me amenable to extensive static and dynamic analysis, optimization and code generation Safety • Preserve type safety of embedded language • No loosened guarantees about program behavior Modest Effort • Virtualization is only useful if it reduces effort to embed high performance DSL

  18. Ac Achi hiev evin ing g Vi Virt rtua ualiz lizat atio ion: n: Ex Expre pressi ssiven veness ess  OOP allowed higher level of abstractions  Add your own types and define operations on them  But how about custom type interaction with language features  Overload all relevant embedding language constructs for (x <- elems if x % 2 == 0) p(x) maps to elems.withFilter(x => x % 2 == 0).foreach(x => p(x))  DSL developer can control how loops over domain collection should be represented and executed by implementing withFilter and foreach for their DSL type

  19. Ac Achi hiev evin ing g Vi Virt rtua ualiz lizat atio ion: n: Ex Expre pressi ssiven veness ess  For full virtualization, need to apply similar techniques to all other relevant constructs of the embedding language (for example) if (cond) something else somethingElse maps to __ifThenElse(cond, something, somethingElse)  DSL developer can control the meaning of conditionals by providing overloaded variants specialized to DSL types

  20. Out Outli line ne  Introduction  Using DSLs for parallel programming  Language Virtualization  Enhancing the power of DSL embedding languages  Polymorphic Embedding and Modular Staging  Enhancing the power of embedded DSLs  Example DSLs  OptiML – targets machine learning applications  Liszt – targets scientific computing simulations  Conclusion

  21. Li Ligh ghtw twei eigh ght Mod t Modul ular Sta ar Stagin ging g Ap Appro proach ach Embedded DSL gets it all for free, Modular Staging provides a hybrid approach but can’t change any of it DSLs adopt front-end from Stand-alone DSL but can customize IR and highly expressive implements everything participate in backend phases embedding language Type Code Lexer Parser Analysis Optimization checker gen Typical Compiler GPCE’10: Lightweight modular staging: a pragmatic approach to runtime code generation and compiled DSLs

  22. Linear Linear Al Algebra gebra Ex Example ample trait TestMatrix { def example(a: Matrix, b: Matrix, c: Matrix, d: Matrix) = { val x = a*b + a*c val y = a*c + a*d println(x+y) } } a*b + a*c + a*c + a*d = a * ( b + c + c + d)

  23. Ab Abstract stract Ma Matrix trix Us Usage age this : MatrixArith => trait TestMatrix { def example(a: Rep[Matrix], b: Rep[Matrix], c: Rep[Matrix] , d: Rep[Matrix]) = { val x = a*b + a*c val y = a*c + a*d println(x+y) } }  Rep[Matrix]: abstract type constructor ⇒ range of possible implementations of Matrix  Operations on Rep[Matrix] defined in MatrixArith trait

  24. Li Liftin fting g Ma Matrix trix to A to Abstract bstract Re Representation presentation  DSL interface building blocks structured as traits Expressions of type Rep[T] represent expressions of type T  Can plug in different representation  Need to be able to convert (lift) Matrix to abstract  representation Need to define an interface for our DSL type  trait MatrixArith { type Rep[T] implicit def liftMatrixToRep(x: Matrix): Rep[Matrix] def infix_+(x:Rep[Matrix], y: Rep[Matrix]): Rep[Matrix] def infix_*(x:Rep[Matrix] , y: Rep[Matrix]): Rep[Matrix] } Now can plugin different implementations and representations  for the DSL

  25. Now Can Now Can Bui Build ld an IR an IR  Start with common IR structure to be shared among DSLs trait Expressions { // constants/symbols (atomic) abstract class Exp[T] case class Const[T](x: T) extends Exp[T] case class Sym[T](n: Int) extends Exp[T] // operations (composite, defined in subtraits) abstract class Op[T] // additional members for managing encountered definitions def findOrCreateDefinition[T](op: Op[T]): Sym[T] implicit def toExp[T](d: Op[T]): Exp[T] = findOrCreateDefinition(d) }  Generic optimizations (e.g. common subexpression and dead code elimination) handled once and for all

Recommend


More recommend