{"id":"https://openalex.org/W4226225982","doi":"https://doi.org/10.2197/ipsjjip.30.269","title":"ComposableThreads: Rethinking User-level Threads with Composability and Parametricity in C++","display_name":"ComposableThreads: Rethinking User-level Threads with Composability and Parametricity in C++","publication_year":2022,"publication_date":"2022-01-01","ids":{"openalex":"https://openalex.org/W4226225982","doi":"https://doi.org/10.2197/ipsjjip.30.269"},"language":"en","primary_location":{"id":"doi:10.2197/ipsjjip.30.269","is_oa":true,"landing_page_url":"https://doi.org/10.2197/ipsjjip.30.269","pdf_url":"https://www.jstage.jst.go.jp/article/ipsjjip/30/0/30_269/_pdf","source":{"id":"https://openalex.org/S4210239267","display_name":"Journal of Information Processing","issn_l":"1882-6652","issn":["1882-6652"],"is_oa":true,"is_in_doaj":false,"is_core":true,"host_organization":null,"host_organization_name":null,"host_organization_lineage":[],"host_organization_lineage_names":[],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Journal of Information Processing","raw_type":"journal-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"diamond","oa_url":"https://www.jstage.jst.go.jp/article/ipsjjip/30/0/30_269/_pdf","any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5029899789","display_name":"Wataru Endo","orcid":null},"institutions":[],"countries":[],"is_corresponding":true,"raw_author_name":"Wataru Endo","raw_affiliation_strings":["No affiliation"],"affiliations":[{"raw_affiliation_string":"No affiliation","institution_ids":[]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5005891395","display_name":"Shigeyuki Sato","orcid":"https://orcid.org/0000-0002-1496-1422"},"institutions":[{"id":"https://openalex.org/I74801974","display_name":"The University of Tokyo","ror":"https://ror.org/057zh3y96","country_code":"JP","type":"education","lineage":["https://openalex.org/I74801974"]}],"countries":["JP"],"is_corresponding":false,"raw_author_name":"Shigeyuki Sato","raw_affiliation_strings":["Graduate School of Information Science and Technology, The University of Tokyo"],"affiliations":[{"raw_affiliation_string":"Graduate School of Information Science and Technology, The University of Tokyo","institution_ids":["https://openalex.org/I74801974"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5009359355","display_name":"Kenjiro Taura","orcid":"https://orcid.org/0000-0001-5224-382X"},"institutions":[{"id":"https://openalex.org/I74801974","display_name":"The University of Tokyo","ror":"https://ror.org/057zh3y96","country_code":"JP","type":"education","lineage":["https://openalex.org/I74801974"]}],"countries":["JP"],"is_corresponding":false,"raw_author_name":"Kenjiro Taura","raw_affiliation_strings":["Graduate School of Information Science and Technology, The University of Tokyo"],"affiliations":[{"raw_affiliation_string":"Graduate School of Information Science and Technology, The University of Tokyo","institution_ids":["https://openalex.org/I74801974"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":3,"corresponding_author_ids":["https://openalex.org/A5029899789"],"corresponding_institution_ids":[],"apc_list":null,"apc_paid":null,"fwci":0.2271,"has_fulltext":true,"cited_by_count":1,"citation_normalized_percentile":{"value":0.45896147,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":89,"max":94},"biblio":{"volume":"30","issue":"0","first_page":"269","last_page":"282"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10054","display_name":"Parallel Computing and Optimization Techniques","score":1.0,"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":1.0,"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/T10715","display_name":"Distributed and Parallel Computing Systems","score":0.9986000061035156,"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/T11181","display_name":"Advanced Data Storage Technologies","score":0.9965999722480774,"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"}}],"keywords":[{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.9045697450637817},{"id":"https://openalex.org/keywords/threading","display_name":"Threading (protein sequence)","score":0.641172468662262},{"id":"https://openalex.org/keywords/thread","display_name":"Thread (computing)","score":0.5936592221260071},{"id":"https://openalex.org/keywords/interfacing","display_name":"Interfacing","score":0.5583829879760742},{"id":"https://openalex.org/keywords/multithreading","display_name":"Multithreading","score":0.49031832814216614},{"id":"https://openalex.org/keywords/scheduling","display_name":"Scheduling (production processes)","score":0.447682648897171},{"id":"https://openalex.org/keywords/composability","display_name":"Composability","score":0.4426169693470001},{"id":"https://openalex.org/keywords/distributed-computing","display_name":"Distributed computing","score":0.3429586887359619},{"id":"https://openalex.org/keywords/operating-system","display_name":"Operating system","score":0.3423539996147156}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.9045697450637817},{"id":"https://openalex.org/C200307862","wikidata":"https://www.wikidata.org/wiki/Q7797175","display_name":"Threading (protein sequence)","level":3,"score":0.641172468662262},{"id":"https://openalex.org/C138101251","wikidata":"https://www.wikidata.org/wiki/Q213092","display_name":"Thread (computing)","level":2,"score":0.5936592221260071},{"id":"https://openalex.org/C2776303644","wikidata":"https://www.wikidata.org/wiki/Q1020499","display_name":"Interfacing","level":2,"score":0.5583829879760742},{"id":"https://openalex.org/C201410400","wikidata":"https://www.wikidata.org/wiki/Q1064412","display_name":"Multithreading","level":3,"score":0.49031832814216614},{"id":"https://openalex.org/C206729178","wikidata":"https://www.wikidata.org/wiki/Q2271896","display_name":"Scheduling (production processes)","level":2,"score":0.447682648897171},{"id":"https://openalex.org/C2778814252","wikidata":"https://www.wikidata.org/wiki/Q5156715","display_name":"Composability","level":2,"score":0.4426169693470001},{"id":"https://openalex.org/C120314980","wikidata":"https://www.wikidata.org/wiki/Q180634","display_name":"Distributed computing","level":1,"score":0.3429586887359619},{"id":"https://openalex.org/C111919701","wikidata":"https://www.wikidata.org/wiki/Q9135","display_name":"Operating system","level":1,"score":0.3423539996147156},{"id":"https://openalex.org/C21547014","wikidata":"https://www.wikidata.org/wiki/Q1423657","display_name":"Operations management","level":1,"score":0.0},{"id":"https://openalex.org/C46141821","wikidata":"https://www.wikidata.org/wiki/Q209402","display_name":"Nuclear magnetic resonance","level":1,"score":0.0},{"id":"https://openalex.org/C9390403","wikidata":"https://www.wikidata.org/wiki/Q3966","display_name":"Computer hardware","level":1,"score":0.0},{"id":"https://openalex.org/C121332964","wikidata":"https://www.wikidata.org/wiki/Q413","display_name":"Physics","level":0,"score":0.0},{"id":"https://openalex.org/C162324750","wikidata":"https://www.wikidata.org/wiki/Q8134","display_name":"Economics","level":0,"score":0.0},{"id":"https://openalex.org/C47701112","wikidata":"https://www.wikidata.org/wiki/Q735188","display_name":"Protein structure","level":2,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.2197/ipsjjip.30.269","is_oa":true,"landing_page_url":"https://doi.org/10.2197/ipsjjip.30.269","pdf_url":"https://www.jstage.jst.go.jp/article/ipsjjip/30/0/30_269/_pdf","source":{"id":"https://openalex.org/S4210239267","display_name":"Journal of Information Processing","issn_l":"1882-6652","issn":["1882-6652"],"is_oa":true,"is_in_doaj":false,"is_core":true,"host_organization":null,"host_organization_name":null,"host_organization_lineage":[],"host_organization_lineage_names":[],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Journal of Information Processing","raw_type":"journal-article"}],"best_oa_location":{"id":"doi:10.2197/ipsjjip.30.269","is_oa":true,"landing_page_url":"https://doi.org/10.2197/ipsjjip.30.269","pdf_url":"https://www.jstage.jst.go.jp/article/ipsjjip/30/0/30_269/_pdf","source":{"id":"https://openalex.org/S4210239267","display_name":"Journal of Information Processing","issn_l":"1882-6652","issn":["1882-6652"],"is_oa":true,"is_in_doaj":false,"is_core":true,"host_organization":null,"host_organization_name":null,"host_organization_lineage":[],"host_organization_lineage_names":[],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Journal of Information Processing","raw_type":"journal-article"},"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"grobid_xml":true,"pdf":true},"content_urls":{"pdf":"https://content.openalex.org/works/W4226225982.pdf","grobid_xml":"https://content.openalex.org/works/W4226225982.grobid-xml"},"referenced_works_count":15,"referenced_works":["https://openalex.org/W2035629624","https://openalex.org/W2107546372","https://openalex.org/W2130495724","https://openalex.org/W2133250609","https://openalex.org/W2133883933","https://openalex.org/W2146700739","https://openalex.org/W2763550552","https://openalex.org/W2765106570","https://openalex.org/W2784114077","https://openalex.org/W2921135130","https://openalex.org/W2955849675","https://openalex.org/W2978619376","https://openalex.org/W3127327396","https://openalex.org/W3132092631","https://openalex.org/W4235252000"],"related_works":["https://openalex.org/W2115561485","https://openalex.org/W4301271647","https://openalex.org/W1985089255","https://openalex.org/W2384903348","https://openalex.org/W2010970156","https://openalex.org/W2105895556","https://openalex.org/W2153202644","https://openalex.org/W4253890856","https://openalex.org/W2369027488","https://openalex.org/W4235861380"],"abstract_inverted_index":{"User-level":[0],"threading":[1,15,20,33,93,108,150],"or":[2,128],"task-parallel":[3],"systems":[4],"have":[5,79,103],"been":[6],"developed":[7],"over":[8],"decades":[9],"to":[10,37,44,46,144],"provide":[11,35],"efficient":[12],"and":[13,24,52,156,164,173],"flexible":[14,91],"features":[16],"missing":[17],"from":[18,49],"kernel-level":[19],"for":[21,89,135],"both":[22,50,161],"parallel":[23],"concurrent":[25],"programming.":[26],"Some":[27],"of":[28,41,57,65,85,133,148,166],"the":[29,39,82,116,122,130,162,171],"existing":[30],"state-of-the-art":[31],"user-level":[32,92,107,149],"libraries":[34],"interfaces":[36],"customize":[38],"implementation":[40],"thread":[42],"scheduling":[43],"adapt":[45],"different":[47],"workloads":[48],"applications":[51],"upper-level":[53],"systems.":[54],"However,":[55],"most":[56],"them":[58],"are":[59],"typically":[60],"built":[61],"as":[62],"huge":[63],"sets":[64],"monolithic":[66],"components":[67],"which":[68,111],"achieve":[69],"customizability":[70,113,163],"with":[71],"additional":[72],"costs":[73],"via":[74],"concrete":[75],"C":[76],"APIs.":[77],"We":[78,119,159],"noticed":[80],"that":[81,121],"zero-overhead":[83],"abstraction":[84],"C++":[86],"is":[87],"beneficial":[88],"assembling":[90],"in":[94],"a":[95,105],"clearer":[96],"manner.":[97],"To":[98],"demonstrate":[99],"our":[100,167],"ideas,":[101],"we":[102],"implemented":[104],"new":[106],"library":[109],"ComposableThreads":[110,134,139],"provides":[112],"while":[114],"minimizing":[115],"interfacing":[117],"costs.":[118],"show":[120],"users":[123],"can":[124],"pick":[125],"up,":[126],"insert,":[127],"replace":[129],"individual":[131],"classes":[132],"their":[136],"own":[137],"purposes.":[138],"offers":[140],"several":[141],"characteristic":[142],"abstractions":[143],"build":[145],"high-level":[146],"constructs":[147],"including":[151],"suspended":[152],"threads":[153],"(one-shot":[154],"continuations)":[155],"lock":[157],"delegators.":[158],"evaluate":[160],"performance":[165],"runtime":[168],"system":[169],"through":[170],"microbenchmark":[172],"application":[174],"results.":[175]},"counts_by_year":[{"year":2023,"cited_by_count":1}],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2025-10-10T00:00:00"}
