{"id":"https://openalex.org/W3183056907","doi":"https://doi.org/10.1109/tc.2021.3096429","title":"Enhancing High-Level Synthesis Using a Meta-Programming Approach","display_name":"Enhancing High-Level Synthesis Using a Meta-Programming Approach","publication_year":2021,"publication_date":"2021-01-01","ids":{"openalex":"https://openalex.org/W3183056907","doi":"https://doi.org/10.1109/tc.2021.3096429","mag":"3183056907"},"language":"en","primary_location":{"id":"doi:10.1109/tc.2021.3096429","is_oa":false,"landing_page_url":"https://doi.org/10.1109/tc.2021.3096429","pdf_url":null,"source":{"id":"https://openalex.org/S157670870","display_name":"IEEE Transactions on Computers","issn_l":"0018-9340","issn":["0018-9340","1557-9956","2326-3814"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319808","host_organization_name":"Institute of Electrical and Electronics Engineers","host_organization_lineage":["https://openalex.org/P4310319808"],"host_organization_lineage_names":["Institute of Electrical and Electronics Engineers"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"IEEE Transactions on Computers","raw_type":"journal-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":false,"oa_status":"closed","oa_url":null,"any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5046131209","display_name":"Jessica Vandebon","orcid":"https://orcid.org/0000-0002-1327-9712"},"institutions":[{"id":"https://openalex.org/I47508984","display_name":"Imperial College London","ror":"https://ror.org/041kmwe10","country_code":"GB","type":"education","lineage":["https://openalex.org/I47508984"]}],"countries":["GB"],"is_corresponding":true,"raw_author_name":"Jessica Vandebon","raw_affiliation_strings":["Imperial College London, London, U.K"],"affiliations":[{"raw_affiliation_string":"Imperial College London, London, U.K","institution_ids":["https://openalex.org/I47508984"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5091831140","display_name":"Jos\u00e9 Gabriel de F. Coutinho","orcid":null},"institutions":[],"countries":[],"is_corresponding":false,"raw_author_name":"Jose Gabriel De Figueiredo Coutinho","raw_affiliation_strings":[],"affiliations":[]},{"author_position":"middle","author":{"id":"https://openalex.org/A5057940557","display_name":"Wayne Luk","orcid":"https://orcid.org/0000-0002-6750-927X"},"institutions":[{"id":"https://openalex.org/I47508984","display_name":"Imperial College London","ror":"https://ror.org/041kmwe10","country_code":"GB","type":"education","lineage":["https://openalex.org/I47508984"]}],"countries":["GB"],"is_corresponding":false,"raw_author_name":"Wayne Luk","raw_affiliation_strings":["Imperial College London, London, U.K"],"affiliations":[{"raw_affiliation_string":"Imperial College London, London, U.K","institution_ids":["https://openalex.org/I47508984"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5084078152","display_name":"Eriko Nurvitadhi","orcid":"https://orcid.org/0000-0002-2347-9590"},"institutions":[{"id":"https://openalex.org/I1343180700","display_name":"Intel (United States)","ror":"https://ror.org/01ek73717","country_code":"US","type":"company","lineage":["https://openalex.org/I1343180700"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Eriko Nurvitadhi","raw_affiliation_strings":["Intel Corporation, San Jose, CA, USA"],"affiliations":[{"raw_affiliation_string":"Intel Corporation, San Jose, CA, USA","institution_ids":["https://openalex.org/I1343180700"]}]}],"institutions":[],"countries_distinct_count":2,"institutions_distinct_count":4,"corresponding_author_ids":["https://openalex.org/A5046131209"],"corresponding_institution_ids":["https://openalex.org/I47508984"],"apc_list":null,"apc_paid":null,"fwci":1.8768,"has_fulltext":false,"cited_by_count":8,"citation_normalized_percentile":{"value":0.85275979,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":94,"max":98},"biblio":{"volume":null,"issue":null,"first_page":"1","last_page":"1"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10904","display_name":"Embedded Systems Design Techniques","score":0.9995999932289124,"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/T10904","display_name":"Embedded Systems Design Techniques","score":0.9995999932289124,"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/T10054","display_name":"Parallel Computing and Optimization Techniques","score":0.9994999766349792,"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/T10639","display_name":"Advanced Software Engineering Methodologies","score":0.9987999796867371,"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.8564850687980652},{"id":"https://openalex.org/keywords/exploit","display_name":"Exploit","score":0.7523550987243652},{"id":"https://openalex.org/keywords/python","display_name":"Python (programming language)","score":0.7052356004714966},{"id":"https://openalex.org/keywords/orchestration","display_name":"Orchestration","score":0.6793966293334961},{"id":"https://openalex.org/keywords/speedup","display_name":"Speedup","score":0.5955683588981628},{"id":"https://openalex.org/keywords/metaprogramming","display_name":"Metaprogramming","score":0.474712997674942},{"id":"https://openalex.org/keywords/software","display_name":"Software","score":0.47406405210494995},{"id":"https://openalex.org/keywords/software-engineering","display_name":"Software engineering","score":0.46812382340431213},{"id":"https://openalex.org/keywords/programming-paradigm","display_name":"Programming paradigm","score":0.4666125178337097},{"id":"https://openalex.org/keywords/focus","display_name":"Focus (optics)","score":0.4621734023094177},{"id":"https://openalex.org/keywords/domain","display_name":"Domain (mathematical analysis)","score":0.4567995071411133},{"id":"https://openalex.org/keywords/design-flow","display_name":"Design flow","score":0.43050479888916016},{"id":"https://openalex.org/keywords/computer-architecture","display_name":"Computer architecture","score":0.39963498711586},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.3643017113208771},{"id":"https://openalex.org/keywords/embedded-system","display_name":"Embedded system","score":0.21247878670692444},{"id":"https://openalex.org/keywords/parallel-computing","display_name":"Parallel computing","score":0.1985197365283966}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8564850687980652},{"id":"https://openalex.org/C165696696","wikidata":"https://www.wikidata.org/wiki/Q11287","display_name":"Exploit","level":2,"score":0.7523550987243652},{"id":"https://openalex.org/C519991488","wikidata":"https://www.wikidata.org/wiki/Q28865","display_name":"Python (programming language)","level":2,"score":0.7052356004714966},{"id":"https://openalex.org/C199168358","wikidata":"https://www.wikidata.org/wiki/Q3367000","display_name":"Orchestration","level":3,"score":0.6793966293334961},{"id":"https://openalex.org/C68339613","wikidata":"https://www.wikidata.org/wiki/Q1549489","display_name":"Speedup","level":2,"score":0.5955683588981628},{"id":"https://openalex.org/C35390924","wikidata":"https://www.wikidata.org/wiki/Q661075","display_name":"Metaprogramming","level":2,"score":0.474712997674942},{"id":"https://openalex.org/C2777904410","wikidata":"https://www.wikidata.org/wiki/Q7397","display_name":"Software","level":2,"score":0.47406405210494995},{"id":"https://openalex.org/C115903868","wikidata":"https://www.wikidata.org/wiki/Q80993","display_name":"Software engineering","level":1,"score":0.46812382340431213},{"id":"https://openalex.org/C34165917","wikidata":"https://www.wikidata.org/wiki/Q188267","display_name":"Programming paradigm","level":2,"score":0.4666125178337097},{"id":"https://openalex.org/C192209626","wikidata":"https://www.wikidata.org/wiki/Q190909","display_name":"Focus (optics)","level":2,"score":0.4621734023094177},{"id":"https://openalex.org/C36503486","wikidata":"https://www.wikidata.org/wiki/Q11235244","display_name":"Domain (mathematical analysis)","level":2,"score":0.4567995071411133},{"id":"https://openalex.org/C37135326","wikidata":"https://www.wikidata.org/wiki/Q931942","display_name":"Design flow","level":2,"score":0.43050479888916016},{"id":"https://openalex.org/C118524514","wikidata":"https://www.wikidata.org/wiki/Q173212","display_name":"Computer architecture","level":1,"score":0.39963498711586},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.3643017113208771},{"id":"https://openalex.org/C149635348","wikidata":"https://www.wikidata.org/wiki/Q193040","display_name":"Embedded system","level":1,"score":0.21247878670692444},{"id":"https://openalex.org/C173608175","wikidata":"https://www.wikidata.org/wiki/Q232661","display_name":"Parallel computing","level":1,"score":0.1985197365283966},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"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/C120665830","wikidata":"https://www.wikidata.org/wiki/Q14620","display_name":"Optics","level":1,"score":0.0},{"id":"https://openalex.org/C558565934","wikidata":"https://www.wikidata.org/wiki/Q2743","display_name":"Musical","level":2,"score":0.0},{"id":"https://openalex.org/C142362112","wikidata":"https://www.wikidata.org/wiki/Q735","display_name":"Art","level":0,"score":0.0},{"id":"https://openalex.org/C38652104","wikidata":"https://www.wikidata.org/wiki/Q3510521","display_name":"Computer security","level":1,"score":0.0},{"id":"https://openalex.org/C153349607","wikidata":"https://www.wikidata.org/wiki/Q36649","display_name":"Visual arts","level":1,"score":0.0},{"id":"https://openalex.org/C134306372","wikidata":"https://www.wikidata.org/wiki/Q7754","display_name":"Mathematical analysis","level":1,"score":0.0}],"mesh":[],"locations_count":2,"locations":[{"id":"doi:10.1109/tc.2021.3096429","is_oa":false,"landing_page_url":"https://doi.org/10.1109/tc.2021.3096429","pdf_url":null,"source":{"id":"https://openalex.org/S157670870","display_name":"IEEE Transactions on Computers","issn_l":"0018-9340","issn":["0018-9340","1557-9956","2326-3814"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319808","host_organization_name":"Institute of Electrical and Electronics Engineers","host_organization_lineage":["https://openalex.org/P4310319808"],"host_organization_lineage_names":["Institute of Electrical and Electronics Engineers"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"IEEE Transactions on Computers","raw_type":"journal-article"},{"id":"pmh:oai:spiral.imperial.ac.uk:10044/1/90426","is_oa":false,"landing_page_url":"http://hdl.handle.net/10044/1/90426","pdf_url":null,"source":{"id":"https://openalex.org/S4306401396","display_name":"Spiral (Imperial College London)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I47508984","host_organization_name":"Imperial College London","host_organization_lineage":["https://openalex.org/I47508984"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"1","raw_type":"Journal Article"}],"best_oa_location":null,"sustainable_development_goals":[],"awards":[{"id":"https://openalex.org/G2784140359","display_name":"Application Customisation: Enhancing Design Quality and Developer Productivity","funder_award_id":"EP/P010040/1","funder_id":"https://openalex.org/F4320334627","funder_display_name":"Engineering and Physical Sciences Research Council"},{"id":"https://openalex.org/G3496335909","display_name":"Centre for Spatial Computational Learning","funder_award_id":"EP/S030069/1","funder_id":"https://openalex.org/F4320334627","funder_display_name":"Engineering and Physical Sciences Research Council"},{"id":"https://openalex.org/G4587427570","display_name":null,"funder_award_id":"EP/S030069/1","funder_id":"https://openalex.org/F4320334627","funder_display_name":"Engineering and Physical Sciences Research Council"},{"id":"https://openalex.org/G5201431165","display_name":"EPSRC Centre for Doctoral Training in High Performance Embedded and Distributed Systems","funder_award_id":"EP/L016796/1","funder_id":"https://openalex.org/F4320334627","funder_display_name":"Engineering and Physical Sciences Research Council"},{"id":"https://openalex.org/G5248561189","display_name":"Event-based parallel computing - partially ordered event-triggered systems (POETS)","funder_award_id":"EP/N031768/1","funder_id":"https://openalex.org/F4320334627","funder_display_name":"Engineering and Physical Sciences Research Council"},{"id":"https://openalex.org/G600182179","display_name":null,"funder_award_id":"EP/L00058X/1","funder_id":"https://openalex.org/F4320334627","funder_display_name":"Engineering and Physical Sciences Research Council"},{"id":"https://openalex.org/G6968114954","display_name":"Exploiting Parallelism through Type Transformations for Hybrid Manycore Systems","funder_award_id":"EP/L00058X/1","funder_id":"https://openalex.org/F4320334627","funder_display_name":"Engineering and Physical Sciences Research Council"},{"id":"https://openalex.org/G7493804148","display_name":null,"funder_award_id":"EP/N031768/1","funder_id":"https://openalex.org/F4320334627","funder_display_name":"Engineering and Physical Sciences Research Council"},{"id":"https://openalex.org/G774180880","display_name":null,"funder_award_id":"EP/P010040/1","funder_id":"https://openalex.org/F4320334627","funder_display_name":"Engineering and Physical Sciences Research Council"}],"funders":[{"id":"https://openalex.org/F4320307102","display_name":"Intel Corporation","ror":"https://ror.org/01ek73717"},{"id":"https://openalex.org/F4320334627","display_name":"Engineering and Physical Sciences Research Council","ror":"https://ror.org/0439y7842"}],"has_content":{"pdf":false,"grobid_xml":false},"content_urls":null,"referenced_works_count":16,"referenced_works":["https://openalex.org/W1610570299","https://openalex.org/W1965742121","https://openalex.org/W1989988531","https://openalex.org/W2048471930","https://openalex.org/W2079942837","https://openalex.org/W2143609451","https://openalex.org/W2164056230","https://openalex.org/W2782050458","https://openalex.org/W2788211964","https://openalex.org/W2898373684","https://openalex.org/W2905135312","https://openalex.org/W2906737788","https://openalex.org/W2949967139","https://openalex.org/W3034348009","https://openalex.org/W3105115110","https://openalex.org/W3108085245"],"related_works":["https://openalex.org/W2058965144","https://openalex.org/W2164382479","https://openalex.org/W79913212","https://openalex.org/W98480971","https://openalex.org/W2150291671","https://openalex.org/W2027972911","https://openalex.org/W2146343568","https://openalex.org/W2013643406","https://openalex.org/W2094884983","https://openalex.org/W1614272845"],"abstract_inverted_index":{"In":[0,136],"today's":[1],"increasingly":[2],"heterogeneous":[3,55],"compute":[4],"landscape,":[5],"there":[6],"is":[7],"high":[8],"demand":[9],"for":[10,133],"design":[11],"tools":[12],"that":[13,21,102],"offer":[14],"seemingly":[15],"contradictory":[16],"features:":[17],"portable":[18],"programming":[19,88],"abstractions":[20],"hide":[22],"underlying":[23],"architectural":[24,33],"detail,":[25],"and":[26,31,72,78,114,119],"the":[27,47,142],"capability":[28],"to":[29,45,94,107,126,153],"optimise":[30,128],"exploit":[32],"features.":[34],"Our":[35],"meta-programming":[36],"approach,":[37],"Artisan,":[38,63],"decouples":[39],"application":[40,52,64,109],"functionality":[41],"from":[42,57],"optimisation":[43,77,100],"concerns":[44],"address":[46],"complexity":[48],"of":[49,98,122,145],"mapping":[50],"high-level":[51,108],"descriptions":[53],"onto":[54],"platforms":[56],"which":[58],"they":[59],"are":[60],"abstracted.":[61],"With":[62],"experts":[65,74],"focus":[66,75],"on":[67,76,91],"algorithmic":[68],"behaviour,":[69],"while":[70],"platform":[71],"domain":[73],"mapping.":[79],"Artisan":[80,117],"offers":[81],"complete":[82],"design-flow":[83],"orchestration":[84],"in":[85],"a":[86,120],"unified":[87],"environment":[89],"based":[90],"Python":[92],"3":[93],"enable":[95],"accessible":[96],"codification":[97],"reusable":[99],"strategies":[101],"can":[103],"be":[104],"automatically":[105,127],"applied":[106],"descriptions.":[110],"We":[111],"have":[112],"developed":[113],"evaluated":[115],"an":[116],"prototype":[118],"set":[121],"customised":[123],"meta-programs":[124],"used":[125],"six":[129],"case":[130],"study":[131],"applications":[132],"CPU+FPGA":[134],"targets.":[135],"our":[137],"experiments,":[138],"Artisan-optimised":[139],"designs":[140,151],"achieve":[141],"same":[143],"order":[144],"magnitude":[146],"speedup":[147],"as":[148],"manually":[149],"optimised":[150],"compared":[152],"corresponding":[154],"unoptimised":[155],"software.":[156]},"counts_by_year":[{"year":2024,"cited_by_count":4},{"year":2023,"cited_by_count":2},{"year":2022,"cited_by_count":2}],"updated_date":"2026-03-20T23:20:44.827607","created_date":"2025-10-10T00:00:00"}
