home *** CD-ROM | disk | FTP | other *** search
/ NetNews Usenet Archive 1992 #31 / NN_1992_31.iso / spool / comp / parallel / 2845 < prev    next >
Encoding:
Text File  |  1992-12-31  |  33.8 KB  |  1,022 lines

  1. Newsgroups: comp.parallel
  2. Path: sparky!uunet!zaphod.mps.ohio-state.edu!swrinde!gatech!hubcap!fpst
  3. From: paster@dna.lth.se (Christian S. Collberg)
  4. Subject: Parallelizing Compilers (Summary)
  5. Message-ID: <1992Dec31.103348.3081@lth.se>
  6. Sender: news@lth.se
  7. Organization: Department of Computer Science, Lund University
  8. Date: Thu, 31 Dec 1992 10:33:48 GMT
  9. Approved: parallel@hubcap.clemson.edu
  10. Lines: 1010
  11.  
  12.  
  13. Here is a (belated) summary of the replies I received to my request
  14. for information on parallelizing compilers. Thanks to the following 
  15. people who provided information:
  16.  
  17.       Simon N Smith <Simon.N.Smith@computing-maths.cardiff.ac.uk>
  18.       nadkarni@cse.uta.edu (Sachit R. Nadkarni)
  19.       Qiang Alex Zhao <azhao@cs.arizona.edu>
  20.       maniattb@cs.rpi.edu
  21.       lorie@cs.rice.edu (Lorie Liebrock)
  22.       subhas@cs.wm.edu (Subhas Roy)
  23.       Christian Lengauer <lengauer@fmi.uni-passau.de>
  24.       Joe Hummel <jhummel@esp.ICS.UCI.EDU>
  25.       dcp79807@csie.nctu.edu.tw
  26.       good@enuxha.eas.asu.edu (David R. Good)
  27.       Jean-Louis.Pazat@irisa.fr (Jean Louis Pazat)
  28.       kremer@cs.rice.edu (Uli Kremer)
  29.       kumar@cat.syr.edu (Pankaj Kumar)
  30.       <J.C.Highfield@lut.ac.uk>
  31.       lilja@everest.ee.umn.edu (David Lilja)
  32.       chialing@iti.gov.sg (Lee Chia Ling)
  33.       Rudi Hackenberg <hackenbe@informatik.tu-muenchen.de>
  34.       Gholamali Hedayat (JRG ra) <gholam@cs.man.ac.uk>
  35.       cch@dcs.edinburgh.ac.uk
  36.       Suresh Damodaran Kamal <skd@cacs.usl.edu>
  37.       Steven Collins <scollins@lookout.it.uswc.uswest.com>
  38.       paco@cs.rice.edu (Paul Havlak)
  39.       Ramakumar Kosuru <kosuru@point.cs.uwm.edu>
  40.       wismuell@Informatik.TU-Muenchen.DE (Roland Wismueller)
  41.       Roger Peel <R.Peel@ee.surrey.ac.uk>
  42.  
  43. Here's the original request:
  44.  
  45. |> I have found lots of articles on vectorizing compilers. I have not, 
  46. |> however, been able to find any information on compilers which try to
  47. |> discover parallelizable code and then attempt to map it to processes 
  48. |> on a distributed memory machine. Can someone help me to find the
  49. |> relevant references?
  50.  
  51. And here are the replies. The first section contains concrete bibliographic
  52. references, mostly in BibTeX format. I have not checked for duplicates. The
  53. subsequent sections contain general comments. They have been edited down for
  54. brevity.
  55.  
  56. ---------------------------------------------------------------------------
  57.  
  58. "Compile Time Techniques for Data Distribution in Distributed Memory
  59. Machines," Ramanujam and Sadayappan, IEEE PDS, vol2,No.4, October 1991.
  60.  
  61. /A/ Chapman, B. M.
  62. /A/ Herbeck, H.
  63. /A/ Zima, H. P.
  64. Automatic Support for Data Distribution
  65. Proceedings of the Sixth Distributed Memory Computing Conference, April 28 -
  66. May 1, 1991, Portland, Oregon, IEEE Computer Society Press, 51-57
  67.  
  68.  
  69. /A/ Zima, H. P.
  70. /A/ Bast, H. J.
  71. /A/ Gerndt M.
  72. SUPERB: A tool for semi-automatic MIMD/SIMD parallelization
  73. Parallel Computing, No. 6, 1988, 1-18
  74.  
  75.  
  76. /A/ Gerndt, M.
  77. Parallelization of Multigrid Programs in SUPERB
  78. Proc. of the International Workshop on Compilers for Parallel Computers,
  79. Dec. 3-5, 1990, Paris, France, 347 - 356
  80.  
  81. On the Serialisation of Parallel Programs
  82. P.H. Welch & G.R.R. Justo,
  83. in "Occam and the Transputer - Current Developments",
  84. (proceedings of the 14th World Occam and Transputer User Group 
  85. Technical Meeting, Loughborough, September 1991).
  86. J. Edwards (ed),
  87. IOS Press (Amsterdam) 1991.
  88. ISBN 90 5199 063 4
  89.  
  90.     @InProceedings{Parafrase2,
  91.         Author = {C. Polychronopoulos and M. Girkar and M. Haghighat
  92.                 and C. Lee and B. Leung and D. Schouten},
  93.         Title = {The structure of {Parafrase-2}:  An advanced
  94.                 parallelizing compiler for {C} and {Fortran}},
  95.         BookTitle = LCPC,
  96.         Editor = {D. Gelernter and A. Nicolau and D. Padua},
  97.         Year = 1990,
  98.         Publisher = MIT-P}
  99.  
  100.     @InCollection{ABCC:Overview,
  101.         Author={F. Allen and M. Burke and P. Charles and R. Cytron and 
  102.         J. Ferrante},
  103.         Title={An Overview of the {PTRAN} Analysis System for Multiprocessing},
  104.         BookTitle={Proceedings of the First
  105.                 International Conference on Supercomputing},
  106.         Publisher={Springer-Verlag},
  107.         Address={Athens, Greece},
  108.         Year={1987}}
  109.  
  110.     @Article{AlKe:Automatic,
  111.         Author = {J. R. Allen and K. Kennedy},
  112.         Title = {Automatic Translation of {Fortran} Programs to Vector Form},
  113.         Journal = TOPLAS,
  114.         Volume = 9,
  115.         Number = 4,
  116.         Pages = {491--542},
  117.         Month = Oct,
  118.         Year = 1987}
  119.  
  120.     @InProceedings{AlCK:Automatic,
  121.         Author = {J. R. Allen and D. Callahan and K. Kennedy},
  122.         Title = {Automatic Decomposition of Scientific
  123.                 Programs for Parallel Execution},
  124.         BookTitle = POPL87,
  125.         Address = {Munich, Germany},
  126.         Month = Jan,
  127.         Year = 1987}
  128.  
  129.     @string {JOS = "The Journal of Supercomputing"}
  130.  
  131.     @Article{Hend:PTOOL,
  132.         Author = {L. Henderson and R. Hiromoto and O. Lubeck and M. Simmons},
  133.         Title = {On The Use of Diagnostic Dependency-Analysis Tools in Parallel
  134.             Programming: Experiences Using {PTOOL}},
  135.         Journal = JOS,
  136.         Volume = 4,
  137.         Pages = {83-96},
  138.         Year = 1990}
  139.  
  140.     @string {TOPDS = "{IEEE} Transactions on Parallel and 
  141.         Distributed Systems"}
  142.  
  143.     @Article{PEDJ2,
  144.         Author = {K. Kennedy and K. S. M\raisebox{.2em}{c}Kinley and C. Tseng},
  145.         Title = {Interactive Parallel Programming Using the {ParaScope Editor}},
  146.         Journal = TOPDS,
  147.         Volume = 2,
  148.         Number = 3,
  149.         Pages = {329--341},
  150.         Month = Jul,
  151.         Year = 1991}
  152.  
  153.     @string {ICS91 = "Proceedings of the 1991 ACM International Conference
  154.                 on Supercomputing"}
  155.  
  156.     @InProceedings{KMT:A+T2,
  157.         Author = {K. Kennedy and K. S. M\raisebox{.2em}{c}Kinley and C. Tseng},
  158.         Title = {Analysis and Transformation in the {ParaScope Editor}},
  159.         BookTitle = ICS91,
  160.         Address = Cologne,
  161.         Month = Jun,
  162.         Year = 1991}
  163.  
  164.     @string {LCPC91 = "Proceedings of the Fourth Workshop on Languages
  165.                 and Compilers for Parallel Computing"}
  166.  
  167.     @InProceedings{HKK:Overview,
  168.         Author = {S. Hiranandani and K. Kennedy and C. Koelbel
  169.                 and U. Kremer and C. Tseng},
  170.         Title = {An Overview of the {Fortran D} Programming System},
  171.         BookTitle = LCPC91,
  172.         Address = SC,
  173.         Month = Aug,
  174.         Year = 1991}
  175.  
  176.     @InCollection{HKT:icase,
  177.         Author = {S. Hiranandani and K. Kennedy and C. Tseng},
  178.         Title = {Compiler Support for Machine-Independent Parallel
  179.                 Programming in {Fortran D}},
  180.         BookTitle = {Compilers and Runtime Software for Scalable 
  181.         Multiprocessors},
  182.         Editor = {J. Saltz and P. Mehrotra},
  183.         Publisher = {Elsevier},
  184.         Address = Amsterdam,
  185.         Year = {to appear 1991}}
  186.  
  187.     @string {SC91 = "Proceedings of Supercomputing '91"}
  188.  
  189.     Proceedings{HKT:SC91,
  190.     Author = {S. Hiranandani and K. Kennedy and C. Tseng},
  191.     Title = {Compiler Optimizations for {Fortran D} on {MIMD}
  192.             Distributed-Memory Machines},
  193.     BookTitle = SC91,
  194.     Address = Albuquerque,
  195.     Month = Nov,
  196.     Year = 1991}
  197.  
  198. @Article{Nickhil89,
  199.   author =     "A. S. Nickhil and R. S. Nickhil and K. K. Pingali",
  200.   title =     "{I}-structures: Data Structures for Parallel Computing",
  201.   journal =     "ACM trans. on Programming Languages and Systems",
  202.   year =     "1989",
  203.   volume =      "11",
  204.   number =     "4",
  205.   pages =     "598--632"
  206. }
  207. @InProceedings{Rogers89,
  208.   author =     "A. Rogers and K. Pingali",
  209.   title =     "Process Decomposition Through Locality of Reference",
  210.   booktitle =     "Conference on Programming Language Design and Implementation",
  211.   year =     "1989",
  212.   pages =     "69--80",
  213.   organization =     "ACM",
  214.   month =     "June 21--23"
  215. }
  216.  
  217. @TechReport{Reeves89,
  218.   author =     "A. P. Reeves",
  219.   title =     "Paragon: A Programming Paradigm for Multicomputer Systems",
  220.   institution =     "Cornell University",
  221.   year =     "1989",
  222.   number =     "EE-CEG-89-3",
  223.   month =     "January"
  224. }
  225. @TechReport{Reeves89b,
  226.   author =     "A. L. Cheung and A. P. Reeves",
  227.   title =  "The Paragon Multicomputer Environment: A First Implementation",
  228.   institution =     "Cornell University",
  229.   year =     "1989",
  230.   number =     "EE-CEG-89-9",
  231.   month =     "July"
  232. }
  233. @TechReport{Reeves90,
  234.   author =     "A. P. Reeves",
  235.   title =     "The Paragon Programming Paradigm and Distributed
  236.          Memory Multicomputers",
  237.   institution =     "Cornell University",
  238.   year =     "1990",
  239.   number =     "EE-CEG-90-7",
  240.   month =     "June"
  241. }
  242.  
  243. @article{Hatcher88,
  244.     AUTHOR=    "M. J. Quinn and P. J. Hatcher and K. C. Jourdenais",    
  245.     TITLE =    "Compiling {C}$^*$ Programs for a Hypercube Multicomputer",
  246.         BOOKTITLE="ICCL90",
  247.     YEAR=    1990
  248.     }
  249. @InProceedings{Hatcher90,
  250.   author =     "M. J. Quinn and P. J. Hatcher",    
  251.   title =     "Compiling {SIMD} Programs for {MIMD} Architectures",
  252.   booktitle =     "ACM Sigplan (PPEALS)",
  253.   year =     "1990",
  254.   OPTpages =     "57--65"
  255.   }
  256. @article{Hatcher90b,
  257.     AUTHOR=    "M. J. Quinn and P. J. Hatcher",    
  258.     TITLE =    "Data Parallel Programming on Multicomputers",
  259.     JOURNAL="IEEE Trans. on Software Engineering",
  260.         volume= " ",
  261.         number= " ",
  262.     YEAR=    1990,
  263.         month=  "September"
  264.     }
  265.  
  266. @InProceedings{Rosing88,
  267.   author =      "M. Rosing and R. B. Schnabel and R. Weaver",
  268.   title =       "Dino: Summary and Examples",
  269.   booktitle =   "3' Conference on Hypercubes Concurrent Computers and 
  270.                  Applications",
  271.   year =        "1988",
  272.   pages =       "472--481"
  273. }
  274. @inproceedings{Rosing90,
  275.     AUTHOR=    "M. Rosing and R. P. Weaver",
  276.     TITLE =    "Mapping Data to Processors in Distributed Memory
  277.         Computations",
  278.     BOOKTITLE= "5' International Conference on Distributed Memory
  279.         Computing", 
  280.     YEAR=    1990,    
  281.     month=    "April"
  282.     }
  283. @techreport{Rosing90b,
  284.     AUTHOR=    "M. Rosing and R. B. Schnabel and R. P. Weaver",
  285.     TITLE =    "The {DINO} Parallel Programming Language",        
  286.     INSTITUTION=    "University of Colorado at Boulder",
  287.     YEAR=        1990,
  288.     number=        "CU-CS-457-90"
  289.     }
  290. @techreport{Rosing92,
  291.     AUTHOR=    "M. Rosing and R. B. Schnabel",
  292.     TITLE =    "Efficient Language Constructs for Large Parallel
  293.          Programs - An Overview of Dino2",        
  294.     INSTITUTION=    "University of Colorado at Boulder",
  295.     YEAR=        1992,
  296.     number=        "CU-CS-578-92"
  297.     }
  298.  
  299. @techreport{Mehrotra89,
  300.     AUTHOR=    "P. Mehrotra and J. {Van Rosendale}",    
  301.     TITLE =    "Parallel Language Constructs for Tensor Product
  302.         Computations on Loosely Coupled Architectures",
  303.     INSTITUTION= "ICASE",
  304.     YEAR=    1989,
  305.     number=    "89-41",
  306.     month=    "September"
  307.     }
  308. %KALI90a
  309. @Techreport{Koelbel90, 
  310.   author =    "C. Koelbel and P. Mehrotra",
  311.   title =    "Supporting Shared Data Structures on Distributed Memory
  312.         Architectures", 
  313.   institution=    "Department of Computer Science, Purdue University",
  314.   year=        1990,
  315.   number=    "csd-tr 915"
  316. }
  317. % KALI90b
  318. @inproceedings{Koelbel90b,
  319.     AUTHOR=    "C. Koelbel and P. Mehrotra and J. Saltz and H. Berryman",
  320.     TITLE =    "Parallel Loops on Distributed Machines",
  321.     BOOKTITLE= "5' International Conference on Distributed Memory
  322.         Computing", 
  323.     YEAR=    1990,    
  324.     month=    "April"
  325.     }
  326. % KALI90c
  327. @techreport{Mehrotra90,
  328.     AUTHOR=    "P. Mehrotra, J. {Van Rosendale}",
  329.     TITLE =    "Programming Distributed Memory Architectures Using Kali",
  330.     INSTITUTION= "ICASE",
  331.     YEAR=    "1990",
  332.     number=    " ",
  333.     note=    "Draft"
  334.     }
  335. @article{Saltz90,
  336.     AUTHOR=    "J. Saltz and K. Crowley and R. Mirchandaney and H.
  337.         Berryman", 
  338.     TITLE =    "Run-Time Scheduling and Execution of Loops on Message
  339.         Passing Machines"    ,
  340.     JOURNAL="Journal of Parallel and Distributed Computing",
  341.     YEAR=    "1990",
  342.     volume=    8,
  343.     month=    "April"    
  344.     }
  345.  
  346. %Kennedy88,
  347. @article{Callahan88,
  348.     AUTHOR=    "D. Callahan and K. Kennedy",    
  349.     TITLE =    "Compiling Programs for Distributed-Memory Multiprocessors", 
  350.     JOURNAL="Journal of Supercomputing",
  351.     YEAR=    "1988",    
  352.     volume=    2,    
  353.     pages=    "151--169"
  354.     }
  355. @TechReport{FortranD91,
  356.   author =     "S. Hirananandani and K. Kennedy and C. Koelbel and U.Kremer
  357.                  and C-W. Tseng",
  358.   title =     "{An Overview of Fortran D Programming System}",
  359.   year =     "1991",
  360.   number =     "TR91121",
  361.   institution = "CRPC",
  362.   address =     "RICE University",
  363.   month =     "March"
  364. }
  365.  
  366. %SUPERB88,
  367. @Article{Zima88,
  368.   author =     "H. P. Zima and H.-J. Bast and M. Gerndt",
  369.   title =     "{SUPERB}: A Tool for Semi-Automatic {MIMD/SIMD}
  370.          Parallelization",
  371.   journal =     "Parallel Computing",
  372.   year =     "1988",
  373.   volume =      " ",
  374.   number =     "6",
  375.   pages =     "1-18"
  376. }
  377. @article{Gerndt90b,
  378.    author = {Michael Gerndt},
  379.    journal = {Concurrency Practice and Experience},
  380.    title = {Updating Distributed Variables in Local Computations},
  381.    year = {1990}
  382. }
  383. @TechReport{Vienna91,
  384.   author =     "B. Chapman and P. Mehrotra and H. Zima",
  385.   title =     "{Vienna Fortran: A Fortran Language Extension for
  386.          Distributed Memory Multiprocessors}",
  387.   institution = "ICASE",
  388.   year =     "1991",
  389.   number =     "91-72",
  390.   month =     "September"
  391. }
  392.  
  393. %BOOSTER90,
  394. @inproceedings{Paalvast90,
  395.     AUTHOR=    "E. M. Paalvast and A. J. {Van Gemund}",
  396.     TITLE =    "A Method for Parallel Program Generation with an
  397.         Application to the {\sl Booster} Language",
  398.     BOOKTITLE="International Conference on Supercomputing",
  399.     pages= "457--469",
  400.     YEAR=    1990,    
  401.     month=    "June"
  402.     }
  403. %Booster90b,
  404. @techreport{Paalvast90b,
  405.    author = "Edwin M.R. Paalvast and Leo C. Breebaart and Henk J. Sips",
  406.    address = "Delft University of Tecnology -- The Netherlands",
  407.    institution = "TNO Institute of applied science",
  408.    number = "90 ITI 1864",
  409.    title = "The {\sc {Booster}} Language: a User Language Reference",
  410.    year = "1990"
  411. }
  412.  
  413. @Misc{poster-ifip89,
  414.   author =     "Fran{\c c}oise Andr{\'e} and Henry Thomas",
  415.   title =     "{The Pandore System}",
  416.   howpublished =     "IFIP working conference on Decentralized Systems",
  417.   year =     "1989",
  418.   month =     "December",
  419.   note =     "Poster Presentation"
  420. }
  421.  
  422. @InProceedings{dmcc5-90,
  423.   author =     "Fran{\c c}oise Andr{\'e} and Jean-Louis Pazat and
  424.          Henry Thomas",
  425.   title =     "{Data Distribution with Pandore}",
  426.   booktitle =     "The Fifth Distributed Memory Computing Conference",
  427.   year =     "1990",
  428.   month =     "April"
  429. }
  430.  
  431. @TechReport{publi-inria90,
  432.   author =     "Fran{\c c}oise Andr\'{e} and Jean-Louis Pazat and
  433.          Henry Thomas",
  434.   title =     "{Pandore: A System to Manage Data Distribution}",
  435.   institution =     "INRIA",
  436.   year =     "1990",
  437.   type =     "Rapport de Recherche",
  438.   number =     "1195",
  439.   month =     "March"
  440. }
  441.  
  442. @TechReport{publi-interne90,
  443.   author =     "Fran{\c c}oise Andr\'{e} and Jean-Louis Pazat and
  444.          Henry Thomas",
  445.   title =     "{Pandore: A System to Manage Data Distribution}",
  446.   institution =     "IRISA",
  447.   year =     "1990",
  448.   number =     "519",
  449.   month =     "February"
  450. }
  451.  
  452.  
  453. @InProceedings{amsterdam90,
  454.   author =     "Fran{\c c}oise Andr\'{e} and Jean-Louis Pazat and
  455.          Henry Thomas",
  456.   title =     "{Pandore: A System to Manage Data Distribution}",
  457.   booktitle =     "International Conference on Supercomputing",
  458.   year =     "1990",
  459.   organization =     "ACM",
  460.   month =     "June 11-15"
  461. }
  462.  
  463. @InProceedings{amsterdam90b,
  464.   author =     "F. Andr\'{e} and J.L. Pazat and
  465.          H. Thomas",
  466.   title =     "{Pandore: A System to Manage Data Distribution}",
  467.   booktitle =     "International Conference on Supercomputing",
  468.   year =     "1990",
  469.   organization =     "ACM",
  470.   month =     "June 11-15"
  471. }
  472.  
  473.  
  474. @InProceedings{icase90,
  475.   author =     "Fran\c{c}oise Andr\'e and Jean-Louis Pazat and Henry Thomas",
  476.   title =     "{PANDORE}: A System to Manage Data Distribution",
  477.   booktitle =     "Workshop on Compiler for Distributed Memory Machines",
  478.   year =     "1990",
  479.   organization =     "ICASE (NASA Langley Research Center)",
  480.   month =     "May"
  481. }
  482.  
  483.  
  484. @InProceedings{paris90,
  485.   author =     "Fran\c{c}oise Andr\'e and Claude Jard and Jean-Louis Pazat 
  486.         and Henry Thomas", 
  487.   title =     "Data-driven Distribution of Programs",
  488.   booktitle =     "International Workshop on Compiler for Parallel Computers",
  489.   year =     "1990",
  490.   organization =     "Ecoles des Mines de Paris",
  491.   month =     "December"
  492. }
  493.  
  494.  
  495. @InProceedings{munich91,
  496.   author =     "Jean-Louis Pazat",
  497.   title =     "Code Generation for Data Parallel Programs on DMPCs",
  498.   booktitle =     "European Distributed Memory Computers Conference",
  499.   year =     "1991",
  500.   OPTorganization =     "",
  501.   OPTpublisher =     "",
  502.   OPTaddress =     "",
  503.   OPTmonth =     "April",
  504.   OPTnote =     ""
  505. }
  506.  
  507. @PhdThesis{hthomas91,
  508.   author =     "H. Thomas",
  509.   title =     "Une approche de la compilation de programmes
  510.          s\'{e}quentiels pour machines \`{a} m\'{e}moire
  511.          distribu\'{e}e",
  512.   school =     "IFSIC/Universit\'{e} de Rennes I",
  513.   year =     "1991",
  514.   month =     "June"
  515. }
  516.  
  517. @TechReport{publi-interne91,
  518.   author =     "Fran{\c c}oise Andr\'{e} and Olivier Ch\'{e}ron and
  519.                  Jean-Louis Pazat and Henry Thomas",
  520.   title =     "Efficient Code Generation for Distributed Memory Machines",
  521.   institution =     "IRISA",
  522.   year =     "1991",
  523.   number =     "596",
  524.   month =     "July"
  525. }
  526.  
  527.  
  528. @InProceedings{londres91,
  529.   author =      "Fran{\c c}oise Andr\'{e} and Olivier Ch\'{e}ron and
  530.                   Jean-Louis Pazat and Henry Thomas",
  531.   title =      "Efficient Code Generation for Distributed Memory Machines",
  532.   booktitle =      "Parallel Computing '91",
  533.   year =      "1992",
  534.   organization = "Parallel Computing Society",
  535.   publisher =    "Elsevier Science Publishers B.V.",
  536.   month =      "September"
  537. }
  538.  
  539. @TechReport{publi-interne92,
  540.   author =      "Fran{\c c}oise Andr\'{e} and Olivier Ch\'{e}ron and
  541.                  Jean-Louis Pazat",
  542.   title =       "Compiling Sequential Programs for Distributed Memory
  543.                  Parallel Computers with Pandore II",
  544.   institution = "IRISA/INRIA",
  545.   year =        "1992",
  546.   number =      "651",
  547.   month =       "April"
  548. }
  549.  
  550.  
  551. @phdthesis{Tseng89,
  552.     AUTHOR=    "P.-S. Tseng",
  553.     TITLE="A Parallelizing Compiler for Distributed-Memory Parallel
  554.            Computers",    
  555.     SCHOOL=    "CMU",    
  556.     YEAR=    1989    
  557.     }
  558. %POSC90,
  559. @inproceedings{Sarkar90,
  560.     AUTHOR=    "V. Sarkar and D. Cann",
  561.     TITLE =    "A Partitioning and Optimizing {{\large S}ISAL} Compiler",
  562.     BOOKTITLE="Int. Conf. on Supercomputing",
  563.     YEAR=    1990,    
  564.     pages=    "148--163",
  565.     month=    "June"
  566.     }
  567. %OXYGEN90,
  568. @inproceedings{Ruhl90,
  569.     AUTHOR=    "R. Ruhl and M. Annaratone",
  570.     TITLE =    "Parallelization of {FORTRAN} {C}ode on Distributed
  571.          Memory Parallel Processors",
  572.     BOOKTITLE="Int. Conf. on Supercomputing",
  573.     pages= "342--353",
  574.     YEAR=    1990,    
  575.     month=    "June"
  576.     }
  577. %ASPAR90,
  578. @inproceedings{Ikudome90,
  579.     AUTHOR=    "K. Ikudome and G. C. Fox and A. Kolawa and J. W. Flower",
  580.     TITLE =    "An Automatic and Symbolic Parallelization System for
  581.         Distributed Memory Parallel Computers",
  582.     BOOKTITLE="5' Distributed Memory Computing Conference",
  583.     YEAR=    1990,    
  584.     month=    "April"
  585.     }
  586. %SPOT90,
  587. @inproceedings{Socha90,
  588.     AUTHOR=    "D. G. Socha",
  589.     TITLE =    "An Approach to Compiling Single-point Iterative Programs
  590.         for Distributed Memory Computers",
  591.     BOOKTITLE="5' Distributed Memory Computing Conference",
  592.     YEAR=    1990,    
  593.     month=    "April"
  594.     }
  595. %HYPERTASKING90,
  596. @inproceedings{Barber90,
  597.     AUTHOR=    "M. Barber",
  598.     TITLE =    "Hypertasking: Automatic Data Parallel Domain Decomposition
  599.         on the Intel Supercomputer",
  600.     BOOKTITLE="5' Distributed Memory Computing Conference",
  601.     YEAR=    1990,    
  602.     month=    "April"
  603.     }
  604. %MIMDIZER90,
  605. @inproceedings{Sawdayi90,
  606.     AUTHOR=    "R. Sawdayi and G. Wagenbreth and J. Williamson",
  607.     TITLE =    "{MIMD}izer: Functional and Data Decomposition; Creating
  608.         Parallel Programs from Scratch, Transforming Existing Fortran
  609.          Programs to Parallel ",
  610.     BOOKTITLE="Icase Workshop",
  611.     YEAR=    1990,
  612.     month=    "May"
  613.     }
  614.  
  615.  
  616. @InProceedings{pri92a,
  617.   author =      "T. Priol and Z. Lahjomri",
  618.   title =       "Experiments With Shared Virtual Memory and
  619.                  Message-Passing on iPSC/2 Hypercube",
  620.   booktitle =   "International Conference on Parallel Processing",
  621.   year =        "1992",
  622.   pages =       "To appear",
  623.   month =       "August"
  624. }
  625.  
  626. @InProceedings{lah92,
  627.   author =      "Z. Lahjomri and T. Priol",
  628.   title =       "KOAN: a Shared Virtual Memory for the iPSC/2 hypercube",
  629.   booktitle =   "CONPAR/VAPP92",
  630.   year =        "1992",
  631.   month =       "September"
  632. }
  633.  
  634. @InProceedings{bod92,
  635.   author =      "F. Bodin and T. Priol",
  636.   title =       "Overview of the KOAN Programming Environment for the iPSC/2 and Performance evaluation of the BECAUSE Test Program 2.5.1",
  637.   booktitle =   "Because Workshop",
  638.   year =        "1992",
  639.   month =       "October"
  640. }
  641.  
  642. @book{zima:compilers,
  643.    author = "Barbara Chapman and Hans Zima",
  644.    publisher = "Addison-{W}esley",
  645.    series = "Frontier Series",
  646.    title = "Supercompilers for {P}arallel and {V}ector {C}omputers",
  647.    year = "1990",
  648.    isbn = "0-201-17560-6"
  649. }
  650.  
  651. @Book{szymanski:91,
  652.   editor =      "B. K. Szymanski",
  653.   title =       "Parallel Functional Programming Languages and Environments",
  654.   publisher =   "ACM Press",
  655.   address =     "New York",
  656.   year =         1991
  657. }
  658.  
  659.  
  660. @Unpublished{mckenney:szymanski,
  661.   author =    "B. McKenney and B. K. Szymanski",
  662.   title =    "Generating Parallel Code for SIMD Machines",
  663.   note =    "Submitted to ACM LOPAS" % may be published by now, check
  664. }
  665.  
  666.  
  667. @Article{szymanski:prywes:88,
  668.   author =    "Szymanski, B. and Prywes, N.",
  669.   title =    "Efficient Handling of Data Structures in
  670.          Definitional Languages",
  671.   journal =    "Science of Computer Programming",
  672.   number =    3,
  673.   year =    1988,
  674.   pages =    "221-45"
  675. }
  676.  
  677.  
  678. @TechReport{sinharoy:szymanski:91,
  679.   author =    "B. Sinharoy and B. K. Szymanski",
  680.   title =    "Complexity Issues of the Alignment Problem and the
  681.         Closest Vectors in a Lattice",
  682.   institution =    "Dept. of Comp. Sc., Rensselaer Polytechnic Institute",
  683.   number =    "91-10",
  684.   month =    "May",
  685.   year =     1991
  686. }
  687.  
  688. @Book{szymanski:91,
  689.   editor =    "B. K. Szymanski",
  690.   title =    "Parallel Functional Programming Languages and Environments",
  691.   publisher =    "ACM Press",
  692.   address =    "New York",
  693.   year =      1991
  694. }
  695.  
  696. @InProceedings{lu:chen:90,
  697.   author =     "Lee-Chung Lu and Marina C. Chen",
  698.   title =     "Subdomain Dependence Test for Massive Parallelism",
  699.   booktitle =     "Proceedings of the Supercomputing '90 Conference",
  700.   year =     1990,
  701.   publisher =     "IEEE Computer Society Press",
  702.   address =     "Los Alamitos, CA"
  703. }
  704.  
  705. @Article{li:chen:91a,
  706.   author =     "Jinke Li and Marina Chen",
  707.   title =     "The Data Alignment Phase in Compiling Programs for
  708.          Distributed Memory Machines",
  709.   journal =     "J. of Parallel and Distributed Computing",
  710.   year =     1991,
  711.   volume =     13,
  712.   pages =     "213--221"
  713. }
  714.  
  715. @Article{le:chen:91b,
  716.   author =     "Jinke Li and Marina Chen",
  717.   title =     "Compiling Communication-Efficient Programs for
  718.          Massively Parallel Machines",
  719.   journal =     "IEEE Transactions on Parallel and Distributed Systems",
  720.   year =     1991,
  721.   volume =     2,
  722.   number =     3,
  723.   pages =     "361--376",
  724.   month =     "July"
  725. }
  726.  
  727. @InBook{chen:choo:li,
  728.   author =     "Marina Chen and Young-il Choo and Jingke Li",
  729.   title =     "Parallel Functional Programming Languages and Environments",
  730.   chapter =     "Crystal: Theory and Pragmatics of Compiling Efficient
  731.          Parallel Code",
  732.   publisher =     "ACM Press",
  733.   year =     1991,
  734.   editor =     "B. Szymanski"
  735. }
  736.  
  737. @InProceedings{yang:choo:91,
  738.   author =     "Allan Yang and Young-il Choo",
  739.   title =     "Parallel-Program Transformation Using a Metalanguage",
  740.   booktitle =     "Proc.~of the Third ACM SIGPLAN Symposium on Principles and
  741.          Practice of Parallel Programming",
  742.   year =     1991
  743. }
  744.  
  745. @InProceedings{chen:choo:91,
  746.   author =     "Marina Chen and Young-il Choo",
  747.   title =     "Compiling Crystal for Massively Parallel Machines",
  748.   booktitle =     "Proceedings of the Workshop on Compilation of (Symbolic)
  749.          Languages for Parallel Computers",
  750.   year =     1991,
  751.   publisher =     "Argonne National Laboratory Report ANL-91/34",
  752.   month =     "November"
  753. }
  754.  
  755. @InProceedings{yang:choo:92a,
  756.   author =     "Allan Yang and Young-il Choo",
  757.   title =     "Formal Derivation of an Efficient Parallel Gauss-Seidel
  758.          Method on a Mesh of Processors",
  759.   booktitle =     "Proceedings of the 6th International Parallel Processing
  760.          Symposium",
  761.   year =     1992,
  762.   publisher =     "IEEE Computer Society Press",
  763.   month =     "March"
  764. }
  765.   
  766. @InProceedings{yang:choo:92b,
  767.   author =     "Allan Yang and Young-il Choo",
  768.   title =     "Metalinguistic Features for Formal Parallel-Program
  769.          Transformation", 
  770.   booktitle =     "Proceedings of the 4th IEEE International Conference on
  771.          Computer Languages",
  772.   year =     1992,
  773.   publisher =     "IEEE Computer Society Press",
  774.   month =     "April"
  775. }
  776.  
  777. @TechReport{li:chen:89,
  778.   author =    "J. Li and M. Chen",
  779.   title =     "Index Domain Alignment: Minimizing Cost of Cross-Referencing
  780.             Between Distributed Arrays",
  781.   institution =    "Dept. of Comp. Sc., Yale, Univ.",
  782.   number =    "YALEU/DCS/TR-725",
  783.   month =    "Nov.",
  784.   year =     1989
  785. }
  786.  
  787. @TechReport{gilbert:schreiber:90,
  788.   author =    "J. R. Gilbert and R. Schreiber", 
  789.   title =    "Optimal Expression Evaluation for Data parallel Architectures",
  790.   institution =    "RIACS",
  791.   number =     "90.15",
  792.   month =    "April",
  793.   year =    1990
  794. }
  795.  
  796. @Article{knobe:lukas:steele:90,
  797.   author =    "K. Knobe, J. D. Lukas and G. L. Steele Jr.",
  798.   title =    "Data Optimization: Allocation of Arrays to Reduce
  799.         Communication on SIMD Machines",
  800.   journal =     "Journal of Parallel and Distributed Computing",
  801.   volume =    8,
  802.   year =    1990,
  803.   pages =    "102-118"
  804. }
  805.  
  806. -------------------------------------------------------------------------------
  807.  
  808. >From lorie@cs.rice.edu Fri Nov 20 23:05:24 1992
  809.  
  810. What you probably need to look for is automatic alignment and 
  811. distribution for distributed memory architectures.
  812.  
  813. There are a number of parallel compilers that require
  814. alignment and distribution information then convert
  815. the program to SPMD form.  For example the Rice
  816. distributed memory compiler does this.  If you want a
  817. reference on this compiler send email to tlc@cs.rice.edu
  818. and ask for the tech reports CRPC-TR91121 and CRPC-TR91132.
  819.  
  820. My dissertation deals with automatic alignment and 
  821. distribution in Fortran D for a large class of applications.
  822. An early description of the work (before we really 
  823. started into the guts of the research) is available in
  824. CRPC-TR91166 from the above source.
  825.  
  826. You will find in these references pointers to other related
  827. work.
  828.  
  829. -------------------------------------------------------------------------------
  830.  
  831. >From jhummel@esp.ICS.UCI.EDU Sun Nov 22 00:35:08 1992
  832.   
  833.   1.  Look at Fortran D work by Kennedy, et al., at Rice University.
  834.       This is fortran for distributed memory machines (now called
  835.       high-performance fortran or HPF).
  836.   2.  Rogers and Pingali at Cornell did some compiler work.
  837.   3.  A system called Kali, authors ?.
  838.   4.  A system called Pandore, authors ?.
  839.  
  840. You should be able to look in ICPP, Supercomputing, or Sigplan
  841. PLDI conferences for this and related stuff. 
  842.  
  843. -------------------------------------------------------------------------------
  844.  
  845. >From Jean-Louis.Pazat@irisa.fr Mon Nov 23 17:06:15 1992
  846.  
  847. There are many projects  about "parallelizing compilers" for distributed
  848. memory machines. Ther are two kinds of compilers:
  849. Data distribution directed compilers (DDD): FortranD, Pandore, Vienna Fortran,
  850.      HPF compilers
  851. Code distribution directed compilers:  (CDD)
  852.  
  853. DDD Compilers parallelize and distribute sequential code according to a data
  854. distribution specified by the user; CDD compilers try to distribute
  855. independent iterations among processors, most of them use a global memory; but
  856. this memory can be a virtual memory (see KOAN for example).
  857.  
  858. At IRISA, we are working on a DDD Compiler PANDORE II (see the bib. part of
  859. this message)
  860.  
  861.  
  862. 2) About profiling information:
  863.  
  864. We are also working in this area. Yves MAHEO (PhD student), (maheo@irisa.fr) is
  865. working with me in this field.  We have used profiling techniques to find why in
  866. some cases the parallelization is not efficient. Informations are collected by
  867. the run-time designed for our compiler (PANDORE II -> C (NX/2) ) on an iPSC/2.
  868.  
  869. We also use a sophisticated trace analysis system (ECHIDNA) wich uses the
  870. ESTELLE language. (We also have a code generator for the ESTELLE language).
  871. Theses informations are of interest to find where are tight synchronizations in
  872. the generated code. Cyrille Bareau (PhD student), (bareau@irisa.fr)is working
  873. with Claude Jard (jard@irisa.fr) on this subject.
  874.  
  875. We think that it seems very difficult to have a precise enough feed back from
  876. theses tools to drive a compiler. Work is in progress to show some global
  877. information to the user, driving the compiler is the next step.
  878.  
  879. -------------------------------------------------------------------------------
  880.  
  881. >From kremer@cs.rice.edu Mon Nov 23 19:00:24 1992
  882.  
  883.   you might want to look at work done here at Rice in the
  884.   context of the Fortran D programming system. 
  885.  
  886.   Several other groups are/have been looking at the problem of compiling 
  887.   programs for distributed memory multiprocessors. Just go 
  888.   through the Proceedings of the following conferences:
  889.     - International Conference of Supercomputing (ICS)
  890.     - Supercomputing
  891.     - HCCA4, DMCC5, DMCC6, ...
  892.     - Sigplan PLDI
  893.     - Sigplan PPOPP
  894. -------------------------------------------------------------------------------
  895.  
  896. >From kumar@cat.syr.edu Mon Nov 23 20:36:10 1992
  897.  
  898. In the most recent conference on supercomputing "SUPERCOMPUTING 92"
  899. just held in Minnesota, USA there was a paper on compiling
  900. fortran programs for distributed memory machines. The paper is from
  901. NPAC, Syracuse University, Syracuse NY 13210 USA. 
  902.  
  903. We at Syracuse University are developing a Fortran compiler for
  904. MIMD machines. There are lot of technical reports, and you
  905. should get in touch with Lisa Deo (lsd@nova.npac.syr.edu) to 
  906. get the technical reports and their listings.
  907.  
  908. Other places which are also working is CRPC, Rice University,
  909. Houston, Texax, USA. Contact Ken Kennedy or Charles Koelbel.
  910.  
  911. Also, you can contact Piyush Mehrotra or Joel Saltz at 
  912. ICASE, NASA Langley Research Center, Hampton, VA 23665, USA.
  913.  
  914. Most of the papers for compiling techniques for MIMD parallel
  915. computers are from these people only.
  916.  
  917. -------------------------------------------------------------------------------
  918.  
  919. >From J.C.Highfield@lut.ac.uk Mon Nov 23 21:36:58 1992
  920.  
  921.    I suggest you try looking at
  922. stuff relating to the SUPRENUM (spelling?) machine - I think it
  923. is a parallel vector-processor machine. Hence its compilers
  924. need just about every technique you can think of.
  925.    I recall there is a book by H. Zima and B. Chapman on the
  926. subject of vector and parallel compilers (Supercompilers for
  927. parallel and vector computers??), so you could start searching
  928. on their names. The book is heavily into dependence relations
  929. etc., covers vector machines, but for parallel machines I
  930. think it only considers loop-parallelism.
  931.  
  932. -------------------------------------------------------------------------------
  933. From: paco@cs.rice.edu (Paul Havlak)
  934.  
  935.     Parafrase is a vectorizing/parallelizing Fortran-to-Fortran
  936. compiler developed at the University of Illinois CSRD.  Subsequent
  937. projects at CSRD include Parafrase-2 (an interactive programming
  938. environment), Cedar (a parallel computer with shared-memory clusters,
  939. with its own KAP-based compiler), and several Lisp-oriented projects.
  940.     Parafrase-2 (at least) has some PDG-based intermediate
  941. representations.
  942.  
  943.     The PTRAN group at IBM Watson Research Center also uses a
  944. PDG-based representation for partitioning.
  945.  
  946.     Of the two major projects at Rice, PFC did not use control
  947. dependences, but ParaScope uses the PDG and additional information.
  948.     In the early-to-mid 1980s, Kennedy and Allen's group at Rice
  949. developed a vectorizing/parallelizing Fortran-to-Fortran compiler
  950. (Parallel Fortan Converter == PFC) and a dependence browser (PTOOL),
  951. running on IBM mainframes.  PTOOL is now defunct.  PFC relied on
  952. IF-conversion to convert control dependences to data dependences.
  953.     The ParaScope programming environment builds control and data
  954. dependences for interactive transformation of sequential and parallel
  955. Fortran.  The ParaScope editor can use dependence graphs from
  956. PFC/PSERVE.
  957.     Recent work at Rice on compilation of Fortran D (a precursor to
  958. High Performance Fortran) uses the same ParaScope infrastructure.
  959. -------------------------------------------------------------------------------
  960.  
  961. >From kosuru@point.cs.uwm.edu Fri Dec  4 01:04:44 1992
  962.  
  963.  IEEE transactions on Distributed Systems is a good starting place to look
  964.  for articles on parallel Comp on Distributed architectures. There are
  965.  several articles on this topic.
  966.  
  967.  There exists good books:
  968.     Parallel Programming and Compilers (Polychronopolous)
  969.     SuperCompilers for Parallel and Vector Computers 
  970.            (Hans Zima and Barbara Chapman)
  971.  Both are good Summary books.
  972.  
  973. -------------------------------------------------------------------------------
  974. From: "Qiang Alex Zhao" <azhao@cs.arizona.edu>
  975.  
  976. Have you tried SR? Here's a description of SR:
  977.  
  978. SR (Synchronizing Resources) is a language for writing concurrent programs.
  979. It is described in "The SR Programming Language: Concurrency in Practice"
  980. by Gregory R. Andrews and Ronald A. Olsson (Benjamin/Cummings, 1993, ISBN
  981. 0-8053-0088-0).  An overview of Version 1 of the language and implementation
  982. appeared in the January, 1988, issue of TOPLAS (ACM Transactions on
  983. Programming Languages and Systems 10,1, 51-86).
  984.  
  985. The main language constructs are resources and operations.  Resources
  986. encapsulate processes and variables they share; operations provide the
  987. primary mechanism for process interaction.  SR provides a novel integration
  988. of the mechanisms for invoking and servicing operations.  Consequently, all
  989. of local and remote procedure call, rendezvous, message passing, dynamic
  990. process creation, multicast, and semaphores are supported.
  991.  
  992. New features in Version 2 include shared global variables and operations,
  993. circular imports, real numbers and math functions, formatted I/O, a more
  994. general syntax with fewer special cases, a more robust system with better
  995. error checking, true multiprocessing when run on a Silicon Graphics Iris
  996. or Sequent Symmetry, and many additional enhancements.
  997.  
  998. SR has been used at a number of universities and labs for course work and
  999. research projects involving concurrent programming.  It has been used in
  1000. concurrent programming courses to reinforce concepts with small programming
  1001. projects and with larger projects such as experiments with parallel
  1002. algorithms,  replicated databases, distributed simulations, and parts of
  1003. distributed operating systems such as file systems and command interpreters.
  1004. SR has also been used as a tool in several masters theses and doctoral
  1005. dissertations to conduct experiments in parallel and distributed programming
  1006. and to implement larger systems such as a system for mixed language
  1007. programming, one for distributed implementation of graph algorithms,
  1008. experiments with load balancing algorithms, and experiments with upcall
  1009. program structures.
  1010.  
  1011. Version 2 is tested on Sun4, Sun3, DECstation, SGI Iris, HP RISC and 9000/300,
  1012. NeXT, and Sequent Symmetry platforms.  Code is also included for the DG AViiON,
  1013. IBM RS/6000, DEC VAX, Encore Multimax, Apollo DN, and others.
  1014.  
  1015. FTP: cs.arizona.edu: /sr
  1016.  
  1017. ----------------------------------------------------------------------------
  1018. -- 
  1019. Christian.Collberg@dna.lth.se
  1020. Department of Computer Science, Lund University, BOX 118, S-221 00 LUND, Sweden
  1021.  
  1022.