{"id":"https://openalex.org/W4390604942","doi":"https://doi.org/10.1145/3632874","title":"Implementation and Synthesis of Math Library Functions","display_name":"Implementation and Synthesis of Math Library Functions","publication_year":2024,"publication_date":"2024-01-02","ids":{"openalex":"https://openalex.org/W4390604942","doi":"https://doi.org/10.1145/3632874"},"language":"en","primary_location":{"id":"doi:10.1145/3632874","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3632874","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3632874","source":{"id":"https://openalex.org/S4210216081","display_name":"Proceedings of the ACM on Programming Languages","issn_l":"2475-1421","issn":["2475-1421"],"is_oa":true,"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":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the ACM on Programming Languages","raw_type":"journal-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"diamond","oa_url":"https://dl.acm.org/doi/pdf/10.1145/3632874","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5011013917","display_name":"Ian Briggs","orcid":"https://orcid.org/0000-0003-2454-2317"},"institutions":[{"id":"https://openalex.org/I223532165","display_name":"University of Utah","ror":"https://ror.org/03r0ha626","country_code":"US","type":"education","lineage":["https://openalex.org/I223532165"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Ian Briggs","raw_affiliation_strings":["University of Utah, Salt Lake City, USA"],"raw_orcid":"https://orcid.org/0000-0003-2454-2317","affiliations":[{"raw_affiliation_string":"University of Utah, Salt Lake City, USA","institution_ids":["https://openalex.org/I223532165"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5093211842","display_name":"Yash Lad","orcid":"https://orcid.org/0009-0002-1266-312X"},"institutions":[{"id":"https://openalex.org/I223532165","display_name":"University of Utah","ror":"https://ror.org/03r0ha626","country_code":"US","type":"education","lineage":["https://openalex.org/I223532165"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Yash Lad","raw_affiliation_strings":["University of Utah, Salt Lake City, USA"],"raw_orcid":"https://orcid.org/0009-0002-1266-312X","affiliations":[{"raw_affiliation_string":"University of Utah, Salt Lake City, USA","institution_ids":["https://openalex.org/I223532165"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5022031348","display_name":"Pavel Panchekha","orcid":"https://orcid.org/0000-0003-2621-3592"},"institutions":[{"id":"https://openalex.org/I223532165","display_name":"University of Utah","ror":"https://ror.org/03r0ha626","country_code":"US","type":"education","lineage":["https://openalex.org/I223532165"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Pavel Panchekha","raw_affiliation_strings":["University of Utah, Salt Lake City, USA"],"raw_orcid":"https://orcid.org/0000-0003-2621-3592","affiliations":[{"raw_affiliation_string":"University of Utah, Salt Lake City, USA","institution_ids":["https://openalex.org/I223532165"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":3,"corresponding_author_ids":[],"corresponding_institution_ids":[],"apc_list":null,"apc_paid":null,"fwci":1.6023,"has_fulltext":true,"cited_by_count":5,"citation_normalized_percentile":{"value":0.83535994,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":90,"max":98},"biblio":{"volume":"8","issue":"POPL","first_page":"942","last_page":"969"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T11697","display_name":"Numerical Methods and Algorithms","score":0.9995999932289124,"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"}},"topics":[{"id":"https://openalex.org/T11697","display_name":"Numerical Methods and Algorithms","score":0.9995999932289124,"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/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/T10363","display_name":"Low-power high-performance VLSI design","score":0.9911999702453613,"subfield":{"id":"https://openalex.org/subfields/2208","display_name":"Electrical and Electronic Engineering"},"field":{"id":"https://openalex.org/fields/22","display_name":"Engineering"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}}],"keywords":[{"id":"https://openalex.org/keywords/implementation","display_name":"Implementation","score":0.9280694723129272},{"id":"https://openalex.org/keywords/modular-design","display_name":"Modular design","score":0.7537028789520264},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.6915062665939331},{"id":"https://openalex.org/keywords/software-implementation","display_name":"Software implementation","score":0.4785207509994507},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.4563884735107422},{"id":"https://openalex.org/keywords/code","display_name":"Code (set theory)","score":0.45158132910728455},{"id":"https://openalex.org/keywords/scratch","display_name":"Scratch","score":0.4443618059158325},{"id":"https://openalex.org/keywords/range","display_name":"Range (aeronautics)","score":0.44193077087402344},{"id":"https://openalex.org/keywords/speedup","display_name":"Speedup","score":0.43039774894714355},{"id":"https://openalex.org/keywords/domain","display_name":"Domain (mathematical analysis)","score":0.41645243763923645},{"id":"https://openalex.org/keywords/software","display_name":"Software","score":0.3702447712421417},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.3366318941116333},{"id":"https://openalex.org/keywords/computer-engineering","display_name":"Computer engineering","score":0.3360450267791748},{"id":"https://openalex.org/keywords/parallel-computing","display_name":"Parallel computing","score":0.19885167479515076},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.18175983428955078},{"id":"https://openalex.org/keywords/set","display_name":"Set (abstract data type)","score":0.12227752804756165},{"id":"https://openalex.org/keywords/engineering","display_name":"Engineering","score":0.10194501280784607}],"concepts":[{"id":"https://openalex.org/C26713055","wikidata":"https://www.wikidata.org/wiki/Q245962","display_name":"Implementation","level":2,"score":0.9280694723129272},{"id":"https://openalex.org/C101468663","wikidata":"https://www.wikidata.org/wiki/Q1620158","display_name":"Modular design","level":2,"score":0.7537028789520264},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.6915062665939331},{"id":"https://openalex.org/C2983609787","wikidata":"https://www.wikidata.org/wiki/Q10534782","display_name":"Software implementation","level":3,"score":0.4785207509994507},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.4563884735107422},{"id":"https://openalex.org/C2776760102","wikidata":"https://www.wikidata.org/wiki/Q5139990","display_name":"Code (set theory)","level":3,"score":0.45158132910728455},{"id":"https://openalex.org/C2781235140","wikidata":"https://www.wikidata.org/wiki/Q275131","display_name":"Scratch","level":2,"score":0.4443618059158325},{"id":"https://openalex.org/C204323151","wikidata":"https://www.wikidata.org/wiki/Q905424","display_name":"Range (aeronautics)","level":2,"score":0.44193077087402344},{"id":"https://openalex.org/C68339613","wikidata":"https://www.wikidata.org/wiki/Q1549489","display_name":"Speedup","level":2,"score":0.43039774894714355},{"id":"https://openalex.org/C36503486","wikidata":"https://www.wikidata.org/wiki/Q11235244","display_name":"Domain (mathematical analysis)","level":2,"score":0.41645243763923645},{"id":"https://openalex.org/C2777904410","wikidata":"https://www.wikidata.org/wiki/Q7397","display_name":"Software","level":2,"score":0.3702447712421417},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.3366318941116333},{"id":"https://openalex.org/C113775141","wikidata":"https://www.wikidata.org/wiki/Q428691","display_name":"Computer engineering","level":1,"score":0.3360450267791748},{"id":"https://openalex.org/C173608175","wikidata":"https://www.wikidata.org/wiki/Q232661","display_name":"Parallel computing","level":1,"score":0.19885167479515076},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.18175983428955078},{"id":"https://openalex.org/C177264268","wikidata":"https://www.wikidata.org/wiki/Q1514741","display_name":"Set (abstract data type)","level":2,"score":0.12227752804756165},{"id":"https://openalex.org/C127413603","wikidata":"https://www.wikidata.org/wiki/Q11023","display_name":"Engineering","level":0,"score":0.10194501280784607},{"id":"https://openalex.org/C134306372","wikidata":"https://www.wikidata.org/wiki/Q7754","display_name":"Mathematical analysis","level":1,"score":0.0},{"id":"https://openalex.org/C146978453","wikidata":"https://www.wikidata.org/wiki/Q3798668","display_name":"Aerospace engineering","level":1,"score":0.0}],"mesh":[],"locations_count":2,"locations":[{"id":"doi:10.1145/3632874","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3632874","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3632874","source":{"id":"https://openalex.org/S4210216081","display_name":"Proceedings of the ACM on Programming Languages","issn_l":"2475-1421","issn":["2475-1421"],"is_oa":true,"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":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the ACM on Programming Languages","raw_type":"journal-article"},{"id":"pmh:oai:osti.gov:2338155","is_oa":true,"landing_page_url":"https://www.osti.gov/biblio/2338155","pdf_url":"https://www.osti.gov/servlets/purl/2338155","source":{"id":"https://openalex.org/S4306402487","display_name":"OSTI OAI (U.S. Department of Energy Office of Scientific and Technical Information)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I139351228","host_organization_name":"Office of Scientific and Technical Information","host_organization_lineage":["https://openalex.org/I139351228"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":null,"raw_type":null}],"best_oa_location":{"id":"doi:10.1145/3632874","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3632874","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3632874","source":{"id":"https://openalex.org/S4210216081","display_name":"Proceedings of the ACM on Programming Languages","issn_l":"2475-1421","issn":["2475-1421"],"is_oa":true,"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":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the ACM on Programming Languages","raw_type":"journal-article"},"sustainable_development_goals":[{"score":0.5099999904632568,"display_name":"Peace, Justice and strong institutions","id":"https://metadata.un.org/sdg/16"}],"awards":[{"id":"https://openalex.org/G3391073721","display_name":null,"funder_award_id":"10061193","funder_id":"https://openalex.org/F4320306078","funder_display_name":"U.S. Department of Defense"},{"id":"https://openalex.org/G505076752","display_name":"SHF: Medium: Collab Research: Synthesizing Verified Analyzers for Critical Software","funder_award_id":"2119939","funder_id":"https://openalex.org/F4320306076","funder_display_name":"National Science Foundation"}],"funders":[{"id":"https://openalex.org/F4320306076","display_name":"National Science Foundation","ror":"https://ror.org/021nxhr62"},{"id":"https://openalex.org/F4320306078","display_name":"U.S. Department of Defense","ror":"https://ror.org/0447fe631"},{"id":"https://openalex.org/F4320306084","display_name":"U.S. Department of Energy","ror":"https://ror.org/01bj3aw27"}],"has_content":{"grobid_xml":true,"pdf":true},"content_urls":{"pdf":"https://content.openalex.org/works/W4390604942.pdf","grobid_xml":"https://content.openalex.org/works/W4390604942.grobid-xml"},"referenced_works_count":45,"referenced_works":["https://openalex.org/W65339224","https://openalex.org/W321484226","https://openalex.org/W581104972","https://openalex.org/W1608397552","https://openalex.org/W1969213662","https://openalex.org/W1969777579","https://openalex.org/W1976677460","https://openalex.org/W2012407419","https://openalex.org/W2020804487","https://openalex.org/W2056595762","https://openalex.org/W2061091230","https://openalex.org/W2081368694","https://openalex.org/W2122738744","https://openalex.org/W2179627363","https://openalex.org/W2334723383","https://openalex.org/W2552835512","https://openalex.org/W2566629575","https://openalex.org/W2743322459","https://openalex.org/W2747658086","https://openalex.org/W2772436979","https://openalex.org/W2797985644","https://openalex.org/W2838756705","https://openalex.org/W2904117297","https://openalex.org/W2914694172","https://openalex.org/W2951163580","https://openalex.org/W2964731543","https://openalex.org/W2974127045","https://openalex.org/W3011856193","https://openalex.org/W3033741081","https://openalex.org/W3037623668","https://openalex.org/W3091359231","https://openalex.org/W3099525000","https://openalex.org/W3110699689","https://openalex.org/W3115377313","https://openalex.org/W3117137355","https://openalex.org/W3129647355","https://openalex.org/W3190695173","https://openalex.org/W3208558373","https://openalex.org/W3217797300","https://openalex.org/W4225503996","https://openalex.org/W4281782829","https://openalex.org/W4281835144","https://openalex.org/W4283740820","https://openalex.org/W4312283640","https://openalex.org/W4321496292"],"related_works":["https://openalex.org/W1500978221","https://openalex.org/W2741776607","https://openalex.org/W150283939","https://openalex.org/W3124070457","https://openalex.org/W2792138874","https://openalex.org/W2380651582","https://openalex.org/W623781850","https://openalex.org/W1872937274","https://openalex.org/W125619821","https://openalex.org/W2138463053"],"abstract_inverted_index":{"Achieving":[0],"speed":[1,139,182],"and":[2,13,40,73,82,99,125,140,153,157,162,168,183,190,195],"accuracy":[3,184],"for":[4,54,70],"math":[5,28,75,145,177],"library":[6,29,76,146,178],"functions":[7,50],"like":[8,23,92,101,122,160],"exp":[9],",":[10,12],"sin":[11],"log":[14],"is":[15,18,79,118],"difficult.":[16],"This":[17,44],"because":[19],"low-level":[20,41],"implementation":[21],"languages":[22],"C":[24,188],"do":[25],"not":[26],"help":[27],"developers":[30,147],"catch":[31],"mathematical":[32,90],"errors,":[33],"build":[34],"implementations":[35,156,179,198],"incrementally,":[36],"or":[37],"separate":[38],"high-level":[39,116],"decision":[42],"making.":[43],"ultimately":[45],"puts":[46],"development":[47],"of":[48,52],"such":[49],"out":[51],"reach":[53],"all":[55],"but":[56],"the":[57,115,137,186],"most":[58],"experienced":[59],"experts.":[60],"To":[61],"address":[62],"this,":[63],"we":[64],"introduce":[65],"MegaLibm,":[66],"a":[67,108],"domain-specific":[68],"language":[69],"implementing,":[71],"testing,":[72,152],"tuning":[74,120,133,154],"implementations.":[77,113,171],"MegaLibm":[78,86,142,172],"safe,":[80],"modular,":[81,109],"tunable.":[83],"Implementations":[84],"in":[85,107],"can":[87,104,128,173,191],"automatically":[88],"detect":[89],"mistakes":[91],"sign":[93],"flips":[94],"via":[95],"semantic":[96],"wellformedness":[97],"checks,":[98],"components":[100,167],"range":[102],"reductions":[103],"be":[105,129],"implemented":[106],"composable":[110],"way,":[111],"simplifying":[112],"Once":[114],"algorithm":[117],"done,":[119],"parameters":[121,134],"working":[123],"precisions":[124],"evaluation":[126],"schemes":[127],"adjusted":[130],"through":[131],"orthogonal":[132],"to":[135,148,165,185],"achieve":[136],"desired":[138],"accuracy.":[141],"also":[143],"enables":[144],"work":[149],"interactively,":[150],"compiling,":[151],"their":[155],"invoking":[158],"tools":[159],"Sollya":[161],"type-directed":[163],"synthesis":[164],"complete":[166],"synthesize":[169,192],"entire":[170],"express":[174],"8":[175],"state-of-the-art":[176],"with":[180,199],"comparable":[181],"original":[187],"code,":[189],"5":[193],"variations":[194],"3":[196],"from-scratch":[197],"minimal":[200],"guidance.":[201]},"counts_by_year":[{"year":2026,"cited_by_count":1},{"year":2025,"cited_by_count":3},{"year":2024,"cited_by_count":1}],"updated_date":"2026-06-11T09:08:48.828518","created_date":"2025-10-10T00:00:00"}
