{"id":"https://openalex.org/W2006185325","doi":"https://doi.org/10.1142/s0129626412400075","title":"SPOC: GPGPU PROGRAMMING THROUGH STREAM PROCESSING WITH OCAML","display_name":"SPOC: GPGPU PROGRAMMING THROUGH STREAM PROCESSING WITH OCAML","publication_year":2012,"publication_date":"2012-05-14","ids":{"openalex":"https://openalex.org/W2006185325","doi":"https://doi.org/10.1142/s0129626412400075","mag":"2006185325"},"language":"en","primary_location":{"id":"doi:10.1142/s0129626412400075","is_oa":false,"landing_page_url":"https://doi.org/10.1142/s0129626412400075","pdf_url":null,"source":{"id":"https://openalex.org/S18360026","display_name":"Parallel Processing Letters","issn_l":"0129-6264","issn":["0129-6264","1793-642X"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319815","host_organization_name":"World Scientific","host_organization_lineage":["https://openalex.org/P4310319815"],"host_organization_lineage_names":["World Scientific"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Parallel Processing Letters","raw_type":"journal-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"green","oa_url":"https://hal.science/hal-00697257","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5038107163","display_name":"Mathias Bourgoin","orcid":null},"institutions":[{"id":"https://openalex.org/I39804081","display_name":"Sorbonne Universit\u00e9","ror":"https://ror.org/02en5vm52","country_code":"FR","type":"education","lineage":["https://openalex.org/I39804081"]},{"id":"https://openalex.org/I4210159731","display_name":"LIP6","ror":"https://ror.org/05krcen59","country_code":"FR","type":"facility","lineage":["https://openalex.org/I1294671590","https://openalex.org/I1294671590","https://openalex.org/I39804081","https://openalex.org/I4210159245","https://openalex.org/I4210159731"]}],"countries":["FR"],"is_corresponding":false,"raw_author_name":"MATHIAS BOURGOIN","raw_affiliation_strings":["Laboratoire d'Informatique de Paris 6 (LIP6 \u2013 UMR 7606), Universit\u00e9 Pierre et Marie Curie (UPMC \u2013 Paris 6), Sorbonne Universit\u00e9s, 4 place Jussieu, 75005 Paris, France"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Laboratoire d'Informatique de Paris 6 (LIP6 \u2013 UMR 7606), Universit\u00e9 Pierre et Marie Curie (UPMC \u2013 Paris 6), Sorbonne Universit\u00e9s, 4 place Jussieu, 75005 Paris, France","institution_ids":["https://openalex.org/I39804081","https://openalex.org/I4210159731"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5007537498","display_name":"Emmanuel Chailloux","orcid":"https://orcid.org/0000-0002-2400-9523"},"institutions":[{"id":"https://openalex.org/I39804081","display_name":"Sorbonne Universit\u00e9","ror":"https://ror.org/02en5vm52","country_code":"FR","type":"education","lineage":["https://openalex.org/I39804081"]},{"id":"https://openalex.org/I4210159731","display_name":"LIP6","ror":"https://ror.org/05krcen59","country_code":"FR","type":"facility","lineage":["https://openalex.org/I1294671590","https://openalex.org/I1294671590","https://openalex.org/I39804081","https://openalex.org/I4210159245","https://openalex.org/I4210159731"]}],"countries":["FR"],"is_corresponding":false,"raw_author_name":"EMMANUEL CHAILLOUX","raw_affiliation_strings":["Laboratoire d'Informatique de Paris 6 (LIP6 \u2013 UMR 7606), Universit\u00e9 Pierre et Marie Curie (UPMC \u2013 Paris 6), Sorbonne Universit\u00e9s, 4 place Jussieu, 75005 Paris, France"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Laboratoire d'Informatique de Paris 6 (LIP6 \u2013 UMR 7606), Universit\u00e9 Pierre et Marie Curie (UPMC \u2013 Paris 6), Sorbonne Universit\u00e9s, 4 place Jussieu, 75005 Paris, France","institution_ids":["https://openalex.org/I39804081","https://openalex.org/I4210159731"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5000940869","display_name":"Jean\u2013Luc Lamotte","orcid":"https://orcid.org/0000-0001-6493-1769"},"institutions":[{"id":"https://openalex.org/I39804081","display_name":"Sorbonne Universit\u00e9","ror":"https://ror.org/02en5vm52","country_code":"FR","type":"education","lineage":["https://openalex.org/I39804081"]},{"id":"https://openalex.org/I4210159731","display_name":"LIP6","ror":"https://ror.org/05krcen59","country_code":"FR","type":"facility","lineage":["https://openalex.org/I1294671590","https://openalex.org/I1294671590","https://openalex.org/I39804081","https://openalex.org/I4210159245","https://openalex.org/I4210159731"]}],"countries":["FR"],"is_corresponding":false,"raw_author_name":"JEAN-LUC LAMOTTE","raw_affiliation_strings":["Laboratoire d'Informatique de Paris 6 (LIP6 \u2013 UMR 7606), Universit\u00e9 Pierre et Marie Curie (UPMC \u2013 Paris 6), Sorbonne Universit\u00e9s, 4 place Jussieu, 75005 Paris, France"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Laboratoire d'Informatique de Paris 6 (LIP6 \u2013 UMR 7606), Universit\u00e9 Pierre et Marie Curie (UPMC \u2013 Paris 6), Sorbonne Universit\u00e9s, 4 place Jussieu, 75005 Paris, France","institution_ids":["https://openalex.org/I39804081","https://openalex.org/I4210159731"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":3,"corresponding_author_ids":[],"corresponding_institution_ids":[],"apc_list":null,"apc_paid":null,"fwci":1.7575,"has_fulltext":false,"cited_by_count":13,"citation_normalized_percentile":{"value":0.83904512,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":90,"max":97},"biblio":{"volume":"22","issue":"02","first_page":"1240007","last_page":"1240007"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10054","display_name":"Parallel Computing and Optimization Techniques","score":0.9997000098228455,"subfield":{"id":"https://openalex.org/subfields/1708","display_name":"Hardware and Architecture"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},"topics":[{"id":"https://openalex.org/T10054","display_name":"Parallel Computing and Optimization Techniques","score":0.9997000098228455,"subfield":{"id":"https://openalex.org/subfields/1708","display_name":"Hardware and Architecture"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},{"id":"https://openalex.org/T11181","display_name":"Advanced Data Storage Technologies","score":0.9997000098228455,"subfield":{"id":"https://openalex.org/subfields/1705","display_name":"Computer Networks and Communications"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},{"id":"https://openalex.org/T11269","display_name":"Algorithms and Data Compression","score":0.9951000213623047,"subfield":{"id":"https://openalex.org/subfields/1702","display_name":"Artificial Intelligence"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}}],"keywords":[{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8691728115081787},{"id":"https://openalex.org/keywords/general-purpose-computing-on-graphics-processing-units","display_name":"General-purpose computing on graphics processing units","score":0.8332349061965942},{"id":"https://openalex.org/keywords/software-portability","display_name":"Software portability","score":0.7688523530960083},{"id":"https://openalex.org/keywords/parallel-computing","display_name":"Parallel computing","score":0.7197554111480713},{"id":"https://openalex.org/keywords/cuda","display_name":"CUDA","score":0.648409366607666},{"id":"https://openalex.org/keywords/garbage-collection","display_name":"Garbage collection","score":0.573685884475708},{"id":"https://openalex.org/keywords/stream-processing","display_name":"Stream processing","score":0.5491901636123657},{"id":"https://openalex.org/keywords/graphics","display_name":"Graphics","score":0.5275301933288574},{"id":"https://openalex.org/keywords/usable","display_name":"USable","score":0.5004749298095703},{"id":"https://openalex.org/keywords/programming-paradigm","display_name":"Programming paradigm","score":0.45130595564842224},{"id":"https://openalex.org/keywords/supercomputer","display_name":"Supercomputer","score":0.4400450587272644},{"id":"https://openalex.org/keywords/operating-system","display_name":"Operating system","score":0.3932894468307495},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.33004236221313477},{"id":"https://openalex.org/keywords/garbage","display_name":"Garbage","score":0.21362808346748352}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8691728115081787},{"id":"https://openalex.org/C50630238","wikidata":"https://www.wikidata.org/wiki/Q971505","display_name":"General-purpose computing on graphics processing units","level":3,"score":0.8332349061965942},{"id":"https://openalex.org/C63000827","wikidata":"https://www.wikidata.org/wiki/Q3080428","display_name":"Software portability","level":2,"score":0.7688523530960083},{"id":"https://openalex.org/C173608175","wikidata":"https://www.wikidata.org/wiki/Q232661","display_name":"Parallel computing","level":1,"score":0.7197554111480713},{"id":"https://openalex.org/C2778119891","wikidata":"https://www.wikidata.org/wiki/Q477690","display_name":"CUDA","level":2,"score":0.648409366607666},{"id":"https://openalex.org/C105122174","wikidata":"https://www.wikidata.org/wiki/Q322202","display_name":"Garbage collection","level":3,"score":0.573685884475708},{"id":"https://openalex.org/C107027933","wikidata":"https://www.wikidata.org/wiki/Q2006448","display_name":"Stream processing","level":2,"score":0.5491901636123657},{"id":"https://openalex.org/C21442007","wikidata":"https://www.wikidata.org/wiki/Q1027879","display_name":"Graphics","level":2,"score":0.5275301933288574},{"id":"https://openalex.org/C2780615836","wikidata":"https://www.wikidata.org/wiki/Q2471869","display_name":"USable","level":2,"score":0.5004749298095703},{"id":"https://openalex.org/C34165917","wikidata":"https://www.wikidata.org/wiki/Q188267","display_name":"Programming paradigm","level":2,"score":0.45130595564842224},{"id":"https://openalex.org/C83283714","wikidata":"https://www.wikidata.org/wiki/Q121117","display_name":"Supercomputer","level":2,"score":0.4400450587272644},{"id":"https://openalex.org/C111919701","wikidata":"https://www.wikidata.org/wiki/Q9135","display_name":"Operating system","level":1,"score":0.3932894468307495},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.33004236221313477},{"id":"https://openalex.org/C75403996","wikidata":"https://www.wikidata.org/wiki/Q5521979","display_name":"Garbage","level":2,"score":0.21362808346748352},{"id":"https://openalex.org/C136764020","wikidata":"https://www.wikidata.org/wiki/Q466","display_name":"World Wide Web","level":1,"score":0.0}],"mesh":[],"locations_count":3,"locations":[{"id":"doi:10.1142/s0129626412400075","is_oa":false,"landing_page_url":"https://doi.org/10.1142/s0129626412400075","pdf_url":null,"source":{"id":"https://openalex.org/S18360026","display_name":"Parallel Processing Letters","issn_l":"0129-6264","issn":["0129-6264","1793-642X"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319815","host_organization_name":"World Scientific","host_organization_lineage":["https://openalex.org/P4310319815"],"host_organization_lineage_names":["World Scientific"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Parallel Processing Letters","raw_type":"journal-article"},{"id":"pmh:oai:HAL:hal-00697257v1","is_oa":true,"landing_page_url":"https://hal.science/hal-00697257","pdf_url":null,"source":{"id":"https://openalex.org/S4306402512","display_name":"HAL (Le Centre pour la Communication Scientifique Directe)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I1294671590","host_organization_name":"Centre National de la Recherche Scientifique","host_organization_lineage":["https://openalex.org/I1294671590"],"host_organization_lineage_names":[],"type":"repository"},"license":"other-oa","license_id":"https://openalex.org/licenses/other-oa","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"Parallel Processing Letters, 2012, 22 (2), pp.1240007. &#x27E8;10.1142/S0129626412400075&#x27E9;","raw_type":"Journal articles"},{"id":"pmh:oai:HAL:hal-01273213v1","is_oa":false,"landing_page_url":"https://hal.science/hal-01273213","pdf_url":null,"source":{"id":"https://openalex.org/S4306402512","display_name":"HAL (Le Centre pour la Communication Scientifique Directe)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I1294671590","host_organization_name":"Centre National de la Recherche Scientifique","host_organization_lineage":["https://openalex.org/I1294671590"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"HLPGPU2012 workshop, Jan 2012, Paris, France. pp.1-8","raw_type":"Conference papers"}],"best_oa_location":{"id":"pmh:oai:HAL:hal-00697257v1","is_oa":true,"landing_page_url":"https://hal.science/hal-00697257","pdf_url":null,"source":{"id":"https://openalex.org/S4306402512","display_name":"HAL (Le Centre pour la Communication Scientifique Directe)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I1294671590","host_organization_name":"Centre National de la Recherche Scientifique","host_organization_lineage":["https://openalex.org/I1294671590"],"host_organization_lineage_names":[],"type":"repository"},"license":"other-oa","license_id":"https://openalex.org/licenses/other-oa","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"Parallel Processing Letters, 2012, 22 (2), pp.1240007. &#x27E8;10.1142/S0129626412400075&#x27E9;","raw_type":"Journal articles"},"sustainable_development_goals":[{"display_name":"Decent work and economic growth","score":0.47999998927116394,"id":"https://metadata.un.org/sdg/8"}],"awards":[],"funders":[],"has_content":{"pdf":false,"grobid_xml":false},"content_urls":null,"referenced_works_count":3,"referenced_works":["https://openalex.org/W2061094895","https://openalex.org/W2087197945","https://openalex.org/W4250290707"],"related_works":["https://openalex.org/W1963859303","https://openalex.org/W2364044215","https://openalex.org/W2389600408","https://openalex.org/W240129890","https://openalex.org/W3048701459","https://openalex.org/W2149078538","https://openalex.org/W2080146221","https://openalex.org/W2370314112","https://openalex.org/W1912958759","https://openalex.org/W2792081825"],"abstract_inverted_index":{"General":[0],"purpose":[1],"computing":[2],"on":[3,27,35],"graphics":[4],"processing":[5],"units":[6],"(GPGPU)":[7],"consists":[8],"of":[9],"using":[10],"GPUs":[11,28],"to":[12,25,43,60,77,112],"handle":[13],"computations":[14],"commonly":[15],"handled":[16],"by":[17,30],"CPUs.":[18],"GPGPU":[19,127],"programming":[20,128],"implies":[21,42],"developing":[22],"specific":[23,72],"programs":[24],"run":[26],"managed":[29],"a":[31,88],"host":[32],"program":[33],"running":[34],"the":[36,103,108],"CPU.":[37,84],"To":[38],"achieve":[39],"high":[40],"performance":[41,124],"explicitly":[44],"organize":[45],"memory":[46],"transfers":[47,80,114],"between":[48,81,105],"devices.":[49],"Besides,":[50],"different":[51],"incompatible":[52],"frameworks":[53,94],"exist":[54],"making":[55,96],"productivity":[56],"and":[57,83,95,107],"portability":[58],"difficult":[59],"achieve.":[61],"In":[62],"this":[63],"paper,":[64],"we":[65],"describe":[66,102],"SPOC,":[67],"an":[68],"OCaml":[69,109],"library,":[70],"defining":[71],"data":[73],"sets":[74],"in":[75],"order":[76],"automatically":[78],"manage":[79],"GPU":[82],"SPOC":[85,106,116,120],"also":[86,101],"offers":[87],"runtime":[89],"library":[90],"looking":[91],"for":[92],"multiple":[93],"them":[97],"usable":[98],"transparently.":[99],"We":[100],"link":[104],"garbage":[110],"collector":[111],"optimize":[113],"dynamically.":[115],"benchmarks":[117],"show":[118],"that":[119],"can":[121],"offer":[122],"great":[123],"while":[125],"simplifying":[126]},"counts_by_year":[{"year":2019,"cited_by_count":1},{"year":2018,"cited_by_count":1},{"year":2017,"cited_by_count":2},{"year":2016,"cited_by_count":3},{"year":2014,"cited_by_count":3},{"year":2013,"cited_by_count":3}],"updated_date":"2026-06-11T09:08:48.828518","created_date":"2025-10-10T00:00:00"}
