{"id":"https://openalex.org/W2073603361","doi":"https://doi.org/10.1145/2658761.2658772","title":"Automatic locality-friendly interface extension of numerical functions","display_name":"Automatic locality-friendly interface extension of numerical functions","publication_year":2014,"publication_date":"2014-08-29","ids":{"openalex":"https://openalex.org/W2073603361","doi":"https://doi.org/10.1145/2658761.2658772","mag":"2073603361"},"language":"en","primary_location":{"id":"doi:10.1145/2658761.2658772","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2658761.2658772","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 2014 International Conference on Generative Programming: Concepts and Experiences","raw_type":"proceedings-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/A5010835890","display_name":"Benjamin Hess","orcid":null},"institutions":[{"id":"https://openalex.org/I35440088","display_name":"ETH Zurich","ror":"https://ror.org/05a28rw58","country_code":"CH","type":"education","lineage":["https://openalex.org/I2799323385","https://openalex.org/I35440088"]}],"countries":["CH"],"is_corresponding":true,"raw_author_name":"Benjamin Hess","raw_affiliation_strings":["ETH Zurich, Switzerland"],"affiliations":[{"raw_affiliation_string":"ETH Zurich, Switzerland","institution_ids":["https://openalex.org/I35440088"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5101575762","display_name":"Thomas R. Gross","orcid":"https://orcid.org/0000-0002-2038-2902"},"institutions":[{"id":"https://openalex.org/I35440088","display_name":"ETH Zurich","ror":"https://ror.org/05a28rw58","country_code":"CH","type":"education","lineage":["https://openalex.org/I2799323385","https://openalex.org/I35440088"]}],"countries":["CH"],"is_corresponding":false,"raw_author_name":"Thomas R. Gross","raw_affiliation_strings":["ETH Zurich, Switzerland"],"affiliations":[{"raw_affiliation_string":"ETH Zurich, Switzerland","institution_ids":["https://openalex.org/I35440088"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5076407181","display_name":"Markus P\u00fcschel","orcid":"https://orcid.org/0000-0001-8834-8551"},"institutions":[{"id":"https://openalex.org/I35440088","display_name":"ETH Zurich","ror":"https://ror.org/05a28rw58","country_code":"CH","type":"education","lineage":["https://openalex.org/I2799323385","https://openalex.org/I35440088"]}],"countries":["CH"],"is_corresponding":false,"raw_author_name":"Markus P\u00fcschel","raw_affiliation_strings":["ETH Zurich, Switzerland"],"affiliations":[{"raw_affiliation_string":"ETH Zurich, Switzerland","institution_ids":["https://openalex.org/I35440088"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":3,"corresponding_author_ids":["https://openalex.org/A5010835890"],"corresponding_institution_ids":["https://openalex.org/I35440088"],"apc_list":null,"apc_paid":null,"fwci":0.315,"has_fulltext":false,"cited_by_count":1,"citation_normalized_percentile":{"value":0.61196829,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":90,"max":94},"biblio":{"volume":null,"issue":null,"first_page":"83","last_page":"92"},"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.9998999834060669,"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.9998999834060669,"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/T11697","display_name":"Numerical Methods and Algorithms","score":0.9977999925613403,"subfield":{"id":"https://openalex.org/subfields/1703","display_name":"Computational Theory and Mathematics"},"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.9861999750137329,"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.9124044179916382},{"id":"https://openalex.org/keywords/programmer","display_name":"Programmer","score":0.7421356439590454},{"id":"https://openalex.org/keywords/compiler","display_name":"Compiler","score":0.637726902961731},{"id":"https://openalex.org/keywords/function","display_name":"Function (biology)","score":0.5820358991622925},{"id":"https://openalex.org/keywords/locality","display_name":"Locality","score":0.5068626999855042},{"id":"https://openalex.org/keywords/interface","display_name":"Interface (matter)","score":0.49908900260925293},{"id":"https://openalex.org/keywords/software","display_name":"Software","score":0.49363696575164795},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.49351298809051514},{"id":"https://openalex.org/keywords/abstraction-layer","display_name":"Abstraction layer","score":0.48069292306900024},{"id":"https://openalex.org/keywords/library-function","display_name":"Library function","score":0.43572166562080383},{"id":"https://openalex.org/keywords/optimizing-compiler","display_name":"Optimizing compiler","score":0.4307110607624054},{"id":"https://openalex.org/keywords/abstraction","display_name":"Abstraction","score":0.42930108308792114},{"id":"https://openalex.org/keywords/block","display_name":"Block (permutation group theory)","score":0.4144493341445923},{"id":"https://openalex.org/keywords/operating-system","display_name":"Operating system","score":0.2667747735977173}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.9124044179916382},{"id":"https://openalex.org/C2778514511","wikidata":"https://www.wikidata.org/wiki/Q1374194","display_name":"Programmer","level":2,"score":0.7421356439590454},{"id":"https://openalex.org/C169590947","wikidata":"https://www.wikidata.org/wiki/Q47506","display_name":"Compiler","level":2,"score":0.637726902961731},{"id":"https://openalex.org/C14036430","wikidata":"https://www.wikidata.org/wiki/Q3736076","display_name":"Function (biology)","level":2,"score":0.5820358991622925},{"id":"https://openalex.org/C2779808786","wikidata":"https://www.wikidata.org/wiki/Q6664603","display_name":"Locality","level":2,"score":0.5068626999855042},{"id":"https://openalex.org/C113843644","wikidata":"https://www.wikidata.org/wiki/Q901882","display_name":"Interface (matter)","level":4,"score":0.49908900260925293},{"id":"https://openalex.org/C2777904410","wikidata":"https://www.wikidata.org/wiki/Q7397","display_name":"Software","level":2,"score":0.49363696575164795},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.49351298809051514},{"id":"https://openalex.org/C147358964","wikidata":"https://www.wikidata.org/wiki/Q1200992","display_name":"Abstraction layer","level":3,"score":0.48069292306900024},{"id":"https://openalex.org/C2992306863","wikidata":"https://www.wikidata.org/wiki/Q188860","display_name":"Library function","level":2,"score":0.43572166562080383},{"id":"https://openalex.org/C190902152","wikidata":"https://www.wikidata.org/wiki/Q1325106","display_name":"Optimizing compiler","level":3,"score":0.4307110607624054},{"id":"https://openalex.org/C124304363","wikidata":"https://www.wikidata.org/wiki/Q673661","display_name":"Abstraction","level":2,"score":0.42930108308792114},{"id":"https://openalex.org/C2777210771","wikidata":"https://www.wikidata.org/wiki/Q4927124","display_name":"Block (permutation group theory)","level":2,"score":0.4144493341445923},{"id":"https://openalex.org/C111919701","wikidata":"https://www.wikidata.org/wiki/Q9135","display_name":"Operating system","level":1,"score":0.2667747735977173},{"id":"https://openalex.org/C138885662","wikidata":"https://www.wikidata.org/wiki/Q5891","display_name":"Philosophy","level":0,"score":0.0},{"id":"https://openalex.org/C86803240","wikidata":"https://www.wikidata.org/wiki/Q420","display_name":"Biology","level":0,"score":0.0},{"id":"https://openalex.org/C78458016","wikidata":"https://www.wikidata.org/wiki/Q840400","display_name":"Evolutionary biology","level":1,"score":0.0},{"id":"https://openalex.org/C2524010","wikidata":"https://www.wikidata.org/wiki/Q8087","display_name":"Geometry","level":1,"score":0.0},{"id":"https://openalex.org/C41895202","wikidata":"https://www.wikidata.org/wiki/Q8162","display_name":"Linguistics","level":1,"score":0.0},{"id":"https://openalex.org/C111472728","wikidata":"https://www.wikidata.org/wiki/Q9471","display_name":"Epistemology","level":1,"score":0.0},{"id":"https://openalex.org/C157915830","wikidata":"https://www.wikidata.org/wiki/Q2928001","display_name":"Bubble","level":2,"score":0.0},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.0},{"id":"https://openalex.org/C129307140","wikidata":"https://www.wikidata.org/wiki/Q6795880","display_name":"Maximum bubble pressure method","level":3,"score":0.0}],"mesh":[],"locations_count":2,"locations":[{"id":"doi:10.1145/2658761.2658772","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2658761.2658772","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 2014 International Conference on Generative Programming: Concepts and Experiences","raw_type":"proceedings-article"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.858.3292","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.858.3292","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://spiral.ece.cmu.edu:8080/pub-spiral/pubfile/paper_211.pdf","raw_type":"text"}],"best_oa_location":null,"sustainable_development_goals":[{"id":"https://metadata.un.org/sdg/9","display_name":"Industry, innovation and infrastructure","score":0.4699999988079071}],"awards":[],"funders":[],"has_content":{"pdf":false,"grobid_xml":false},"content_urls":null,"referenced_works_count":22,"referenced_works":["https://openalex.org/W52863793","https://openalex.org/W288065879","https://openalex.org/W1480928214","https://openalex.org/W1500250067","https://openalex.org/W1501652040","https://openalex.org/W1517760837","https://openalex.org/W1528098570","https://openalex.org/W2002257715","https://openalex.org/W2048847754","https://openalex.org/W2072800519","https://openalex.org/W2102182691","https://openalex.org/W2107232214","https://openalex.org/W2111334029","https://openalex.org/W2114067856","https://openalex.org/W2136952590","https://openalex.org/W2164197394","https://openalex.org/W2261238734","https://openalex.org/W2495617574","https://openalex.org/W2550790103","https://openalex.org/W2561675875","https://openalex.org/W4285719527","https://openalex.org/W6677084613"],"related_works":["https://openalex.org/W2379153735","https://openalex.org/W2046172023","https://openalex.org/W2972896947","https://openalex.org/W2170146914","https://openalex.org/W2355105570","https://openalex.org/W2059493407","https://openalex.org/W4234370346","https://openalex.org/W2167013139","https://openalex.org/W4254922645","https://openalex.org/W3146195437"],"abstract_inverted_index":{"Raising":[0],"the":[1,85,97,105,116,138,143,147,152,161,193,200,226,263],"level":[2],"of":[3,9,21,87,93,265],"abstraction":[4],"is":[5,247],"a":[6,19,22,27,70,76,79,88,91,121,172,176,185],"key":[7],"concern":[8],"software":[10,37],"engineering,":[11],"and":[12,34,114,182,197,215,238],"libraries":[13,41,56],"(either":[14],"used":[15],"directly":[16],"or":[17,63,90],"as":[18,220,222],"target":[20],"program":[23,71,107],"generation":[24],"system)":[25],"are":[26,260],"successful":[28,40],"technique":[29],"to":[30,35,73,149,164],"raise":[31],"programmer":[32],"productivity":[33],"improve":[36],"quality.":[38],"Unfortunately":[39],"may":[42,46],"contain":[43,57],"functions":[44,58,231],"that":[45,59,135,174,259],"not":[47,101,159],"be":[48,130],"general":[49,218],"enough.":[50],"For":[51],"example,":[52],"many":[53],"numeric":[54],"performance":[55,124],"work":[60],"on":[61,78,199,228],"one-":[62],"higher-dimensional":[64],"arrays.":[65],"A":[66,126],"problem":[67],"arises":[68],"if":[69],"wants":[72],"invoke":[74],"such":[75,184],"function":[77,118,134,178,187],"non-contiguous":[80],"subarray":[81,92],"(e.g.,":[82],"in":[83,180,211,248,262],"C":[84,181],"column":[86],"matrix":[89],"an":[94,131],"image).":[95],"If":[96],"library":[98,117,133,162,177,230],"developer":[99,163],"did":[100],"foresee":[102],"this":[103],"scenario,":[104],"client":[106],"must":[108],"include":[109],"explicit":[110],"copy":[111],"steps":[112],"before":[113],"after":[115],"call,":[119],"incurring":[120],"possibly":[122],"high":[123],"penalty.":[125],"better":[127],"solution":[128],"would":[129],"enhanced":[132],"allows":[136,146],"for":[137,151,188],"desired":[139],"access":[140,144,204],"pattern.":[141],"Exposing":[142],"pattern":[145],"compiler":[148],"optimize":[150],"intended":[153],"usage":[154],"scenario(s).":[155],"As":[156,202],"we":[157,170,206],"do":[158],"want":[160],"generate":[165],"all":[166],"interesting":[167],"versions":[168],"manually,":[169],"present":[171],"tool":[173,227],"takes":[175],"written":[179],"generates":[183],"customized":[186],"typical":[189],"accesses.":[190],"We":[191,224],"describe":[192],"approach,":[194],"discuss":[195],"limitations,":[196],"report":[198],"performance.":[201],"example":[203],"patterns":[205],"consider":[207],"those":[208],"most":[209,249],"common":[210],"numerical":[212],"applications:":[213],"striding":[214],"block":[216],"striding,":[217],"permutations,":[219],"well":[221],"scaling.":[223],"evaluate":[225],"various":[229],"including":[232],"filters,":[233],"scans,":[234],"reductions,":[235],"sorting,":[236],"FFTs,":[237],"linear":[239],"algebra":[240],"operations.":[241],"The":[242],"automatically":[243],"generated":[244],"custom":[245],"version":[246],"cases":[250],"significantly":[251],"faster":[252],"than":[253],"using":[254],"individual":[255],"steps,":[256],"offering":[257],"speed-ups":[258],"typically":[261],"range":[264],"1.2-1.8x.":[266]},"counts_by_year":[{"year":2017,"cited_by_count":1}],"updated_date":"2026-04-05T17:49:38.594831","created_date":"2025-10-10T00:00:00"}
