{"id":"https://openalex.org/W2139710482","doi":"https://doi.org/10.1145/2491491.2491496","title":"Optimized code generation for finite element local assembly using symbolic manipulation","display_name":"Optimized code generation for finite element local assembly using symbolic manipulation","publication_year":2013,"publication_date":"2013-07-01","ids":{"openalex":"https://openalex.org/W2139710482","doi":"https://doi.org/10.1145/2491491.2491496","mag":"2139710482"},"language":"en","primary_location":{"id":"doi:10.1145/2491491.2491496","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2491491.2491496","pdf_url":null,"source":{"id":"https://openalex.org/S163326656","display_name":"ACM Transactions on Mathematical Software","issn_l":"0098-3500","issn":["0098-3500","1557-7295"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319798","host_organization_name":"Association for Computing Machinery","host_organization_lineage":["https://openalex.org/P4310319798"],"host_organization_lineage_names":["Association for Computing Machinery"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"ACM Transactions on Mathematical Software","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/A5069977488","display_name":"Francis P. Russell","orcid":"https://orcid.org/0000-0001-5831-2259"},"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":"Francis P. Russell","raw_affiliation_strings":["Imperial College London","Imperial College London,#TAB#"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Imperial College London","institution_ids":["https://openalex.org/I47508984"]},{"raw_affiliation_string":"Imperial College London,#TAB#","institution_ids":["https://openalex.org/I47508984"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5000319133","display_name":"Paul H. J. Kelly","orcid":"https://orcid.org/0000-0001-5905-1804"},"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":"Paul H. J. Kelly","raw_affiliation_strings":["Imperial College London","Imperial College London,#TAB#"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Imperial College London","institution_ids":["https://openalex.org/I47508984"]},{"raw_affiliation_string":"Imperial College London,#TAB#","institution_ids":["https://openalex.org/I47508984"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":1,"corresponding_author_ids":[],"corresponding_institution_ids":["https://openalex.org/I47508984"],"apc_list":null,"apc_paid":null,"fwci":0.6345,"has_fulltext":false,"cited_by_count":8,"citation_normalized_percentile":{"value":0.72042363,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":90,"max":95},"biblio":{"volume":"39","issue":"4","first_page":"1","last_page":"29"},"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.9980000257492065,"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.9980000257492065,"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.9905999898910522,"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/T11975","display_name":"Evolutionary Algorithms and Applications","score":0.9850999712944031,"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.8113017082214355},{"id":"https://openalex.org/keywords/benchmark","display_name":"Benchmark (surveying)","score":0.7680578231811523},{"id":"https://openalex.org/keywords/code-generation","display_name":"Code generation","score":0.6628714799880981},{"id":"https://openalex.org/keywords/compiler","display_name":"Compiler","score":0.6223129630088806},{"id":"https://openalex.org/keywords/code","display_name":"Code (set theory)","score":0.5429288148880005},{"id":"https://openalex.org/keywords/finite-element-method","display_name":"Finite element method","score":0.4927509129047394},{"id":"https://openalex.org/keywords/suite","display_name":"Suite","score":0.4888719916343689},{"id":"https://openalex.org/keywords/computer-engineering","display_name":"Computer engineering","score":0.43751978874206543},{"id":"https://openalex.org/keywords/generator","display_name":"Generator (circuit theory)","score":0.42580458521842957},{"id":"https://openalex.org/keywords/algorithm","display_name":"Algorithm","score":0.4062536358833313},{"id":"https://openalex.org/keywords/parallel-computing","display_name":"Parallel computing","score":0.3985980153083801},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.39622604846954346},{"id":"https://openalex.org/keywords/computational-science","display_name":"Computational science","score":0.3357072174549103},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.25665783882141113},{"id":"https://openalex.org/keywords/key","display_name":"Key (lock)","score":0.10206365585327148}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8113017082214355},{"id":"https://openalex.org/C185798385","wikidata":"https://www.wikidata.org/wiki/Q1161707","display_name":"Benchmark (surveying)","level":2,"score":0.7680578231811523},{"id":"https://openalex.org/C133162039","wikidata":"https://www.wikidata.org/wiki/Q1061077","display_name":"Code generation","level":3,"score":0.6628714799880981},{"id":"https://openalex.org/C169590947","wikidata":"https://www.wikidata.org/wiki/Q47506","display_name":"Compiler","level":2,"score":0.6223129630088806},{"id":"https://openalex.org/C2776760102","wikidata":"https://www.wikidata.org/wiki/Q5139990","display_name":"Code (set theory)","level":3,"score":0.5429288148880005},{"id":"https://openalex.org/C135628077","wikidata":"https://www.wikidata.org/wiki/Q220184","display_name":"Finite element method","level":2,"score":0.4927509129047394},{"id":"https://openalex.org/C79581498","wikidata":"https://www.wikidata.org/wiki/Q1367530","display_name":"Suite","level":2,"score":0.4888719916343689},{"id":"https://openalex.org/C113775141","wikidata":"https://www.wikidata.org/wiki/Q428691","display_name":"Computer engineering","level":1,"score":0.43751978874206543},{"id":"https://openalex.org/C2780992000","wikidata":"https://www.wikidata.org/wiki/Q17016113","display_name":"Generator (circuit theory)","level":3,"score":0.42580458521842957},{"id":"https://openalex.org/C11413529","wikidata":"https://www.wikidata.org/wiki/Q8366","display_name":"Algorithm","level":1,"score":0.4062536358833313},{"id":"https://openalex.org/C173608175","wikidata":"https://www.wikidata.org/wiki/Q232661","display_name":"Parallel computing","level":1,"score":0.3985980153083801},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.39622604846954346},{"id":"https://openalex.org/C459310","wikidata":"https://www.wikidata.org/wiki/Q117801","display_name":"Computational science","level":1,"score":0.3357072174549103},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.25665783882141113},{"id":"https://openalex.org/C26517878","wikidata":"https://www.wikidata.org/wiki/Q228039","display_name":"Key (lock)","level":2,"score":0.10206365585327148},{"id":"https://openalex.org/C163258240","wikidata":"https://www.wikidata.org/wiki/Q25342","display_name":"Power (physics)","level":2,"score":0.0},{"id":"https://openalex.org/C205649164","wikidata":"https://www.wikidata.org/wiki/Q1071","display_name":"Geography","level":0,"score":0.0},{"id":"https://openalex.org/C62520636","wikidata":"https://www.wikidata.org/wiki/Q944","display_name":"Quantum mechanics","level":1,"score":0.0},{"id":"https://openalex.org/C166957645","wikidata":"https://www.wikidata.org/wiki/Q23498","display_name":"Archaeology","level":1,"score":0.0},{"id":"https://openalex.org/C13280743","wikidata":"https://www.wikidata.org/wiki/Q131089","display_name":"Geodesy","level":1,"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/C121332964","wikidata":"https://www.wikidata.org/wiki/Q413","display_name":"Physics","level":0,"score":0.0},{"id":"https://openalex.org/C97355855","wikidata":"https://www.wikidata.org/wiki/Q11473","display_name":"Thermodynamics","level":1,"score":0.0},{"id":"https://openalex.org/C95457728","wikidata":"https://www.wikidata.org/wiki/Q309","display_name":"History","level":0,"score":0.0},{"id":"https://openalex.org/C177264268","wikidata":"https://www.wikidata.org/wiki/Q1514741","display_name":"Set (abstract data type)","level":2,"score":0.0}],"mesh":[],"locations_count":2,"locations":[{"id":"doi:10.1145/2491491.2491496","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2491491.2491496","pdf_url":null,"source":{"id":"https://openalex.org/S163326656","display_name":"ACM Transactions on Mathematical Software","issn_l":"0098-3500","issn":["0098-3500","1557-7295"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319798","host_organization_name":"Association for Computing Machinery","host_organization_lineage":["https://openalex.org/P4310319798"],"host_organization_lineage_names":["Association for Computing Machinery"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"ACM Transactions on Mathematical Software","raw_type":"journal-article"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.364.529","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.364.529","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://www.doc.ic.ac.uk/~fpr02/excafe/acm_toms_paper.pdf","raw_type":"text"}],"best_oa_location":null,"sustainable_development_goals":[],"awards":[{"id":"https://openalex.org/G2249403966","display_name":null,"funder_award_id":"EP/I00677X/1","funder_id":"https://openalex.org/F4320334627","funder_display_name":"Engineering and Physical Sciences Research Council"},{"id":"https://openalex.org/G5861081951","display_name":"Multi-layered abstractions for PDEs","funder_award_id":"EP/I00677X/1","funder_id":"https://openalex.org/F4320334627","funder_display_name":"Engineering and Physical Sciences Research Council"},{"id":"https://openalex.org/G731814487","display_name":null,"funder_award_id":"EP/I006761/1","funder_id":"https://openalex.org/F4320334627","funder_display_name":"Engineering and Physical Sciences Research Council"}],"funders":[{"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":22,"referenced_works":["https://openalex.org/W321261355","https://openalex.org/W1556081769","https://openalex.org/W1656664476","https://openalex.org/W1971894908","https://openalex.org/W1976584147","https://openalex.org/W1979836673","https://openalex.org/W1983655899","https://openalex.org/W1991644160","https://openalex.org/W1995104390","https://openalex.org/W2002132376","https://openalex.org/W2052628540","https://openalex.org/W2061217545","https://openalex.org/W2087956422","https://openalex.org/W2091260418","https://openalex.org/W2100418324","https://openalex.org/W2102295719","https://openalex.org/W2108956554","https://openalex.org/W2160578790","https://openalex.org/W2160630227","https://openalex.org/W3098240653","https://openalex.org/W3102364864","https://openalex.org/W4242472899"],"related_works":["https://openalex.org/W4231704780","https://openalex.org/W2083794993","https://openalex.org/W352609212","https://openalex.org/W650988184","https://openalex.org/W2162410319","https://openalex.org/W2137356287","https://openalex.org/W4321184925","https://openalex.org/W60915090","https://openalex.org/W2025840053","https://openalex.org/W2161692994"],"abstract_inverted_index":{"Automated":[0],"code":[1,40,61,107],"generators":[2],"for":[3,20,32,146,160,176],"finite":[4],"element":[5],"local":[6,33,59,148],"assembly":[7,34,60,149],"have":[8,190],"facilitated":[9],"exploration":[10],"of":[11,57,83,105,131,140,172,196],"alternative":[12,132],"implementation":[13,56],"strategies":[14,159],"within":[15],"generated":[16],"code.":[17],"However,":[18],"even":[19],"a":[21,39,58,80],"theoretical":[22],"performance":[23,103,130],"indicator":[24],"such":[25],"as":[26],"operation":[27,72],"count,":[28,73],"an":[29],"optimal":[30],"strategy":[31,42],"is":[35,114,150],"unknown.":[36],"We":[37,53,66,110,168],"explore":[38],"generation":[41,108],"based":[43],"on":[44],"symbolic":[45,142,174],"integration":[46,143],"and":[47,76,125,144,164,180],"polynomial":[48],"common":[49,166],"subexpression":[50],"elimination":[51],"(CSE).":[52],"present":[54],"our":[55,155,158],"generator":[62],"using":[63,79,141],"these":[64],"techniques.":[65],"systematically":[67],"evaluate":[68],"the":[69,89,102,129,138,170,173,182],"approach,":[70],"measuring":[71],"execution":[74],"time":[75],"numerical":[77,162,178],"error":[78],"benchmark":[81,95],"suite":[82],"synthetic":[84],"variational":[85],"forms,":[86],"comparing":[87],"against":[88],"FEniCS":[90],"Form":[91],"Compiler":[92],"(FFC).":[93],"Our":[94],"forms":[96],"span":[97],"complexities":[98],"chosen":[99],"to":[100,120,184],"expose":[101],"characteristics":[104],"different":[106],"approaches.":[109],"show":[111],"that":[112],"it":[113],"possible":[115],"with":[116],"additional":[117],"computational":[118,192],"cost,":[119],"consistently":[121],"achieve":[122],"much":[123],"of,":[124],"sometimes":[126],"substantially":[127],"exceed,":[128],"approaches":[133],"without":[134],"compromising":[135],"precision.":[136],"Although":[137],"approach":[139,175],"CSE":[145],"optimizing":[147],"not":[151],"new,":[152],"we":[153],"distinguish":[154],"work":[156],"through":[157],"maintaining":[161],"precision":[163],"detecting":[165],"subexpressions.":[167],"discuss":[169],"benefits":[171],"inferring":[177],"relationships,":[179],"analyze":[181],"relationship":[183],"other":[185],"proposed":[186],"techniques":[187],"which":[188],"also":[189],"greater":[191],"complexity":[193],"than":[194],"those":[195],"FFC.":[197]},"counts_by_year":[{"year":2025,"cited_by_count":1},{"year":2023,"cited_by_count":1},{"year":2022,"cited_by_count":1},{"year":2019,"cited_by_count":1},{"year":2018,"cited_by_count":1},{"year":2017,"cited_by_count":1},{"year":2016,"cited_by_count":1},{"year":2015,"cited_by_count":1}],"updated_date":"2026-06-26T08:34:08.712188","created_date":"2025-10-10T00:00:00"}
