{"id":"https://openalex.org/W4315630753","doi":"https://doi.org/10.1145/3571236","title":"You Only Linearize Once: Tangents Transpose to Gradients","display_name":"You Only Linearize Once: Tangents Transpose to Gradients","publication_year":2023,"publication_date":"2023-01-09","ids":{"openalex":"https://openalex.org/W4315630753","doi":"https://doi.org/10.1145/3571236"},"language":"en","primary_location":{"id":"doi:10.1145/3571236","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3571236","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3571236","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/3571236","any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5055832270","display_name":"Alexey Radul","orcid":"https://orcid.org/0000-0002-7251-4057"},"institutions":[{"id":"https://openalex.org/I1291425158","display_name":"Google (United States)","ror":"https://ror.org/00njsd438","country_code":"US","type":"company","lineage":["https://openalex.org/I1291425158","https://openalex.org/I4210128969"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Alexey Radul","raw_affiliation_strings":["Google Research, USA"],"raw_orcid":"https://orcid.org/0000-0002-7251-4057","affiliations":[{"raw_affiliation_string":"Google Research, USA","institution_ids":["https://openalex.org/I1291425158"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5004759214","display_name":"Adam Paszke","orcid":"https://orcid.org/0000-0002-7665-4559"},"institutions":[],"countries":[],"is_corresponding":false,"raw_author_name":"Adam Paszke","raw_affiliation_strings":["Google Research, Poland"],"raw_orcid":"https://orcid.org/0000-0002-7665-4559","affiliations":[{"raw_affiliation_string":"Google Research, Poland","institution_ids":[]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5069963995","display_name":"Roy Frostig","orcid":"https://orcid.org/0000-0002-1055-3261"},"institutions":[{"id":"https://openalex.org/I1291425158","display_name":"Google (United States)","ror":"https://ror.org/00njsd438","country_code":"US","type":"company","lineage":["https://openalex.org/I1291425158","https://openalex.org/I4210128969"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Roy Frostig","raw_affiliation_strings":["Google Research, USA"],"raw_orcid":"https://orcid.org/0000-0002-1055-3261","affiliations":[{"raw_affiliation_string":"Google Research, USA","institution_ids":["https://openalex.org/I1291425158"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5101657686","display_name":"Matthew Johnson","orcid":"https://orcid.org/0000-0003-4349-1578"},"institutions":[{"id":"https://openalex.org/I1291425158","display_name":"Google (United States)","ror":"https://ror.org/00njsd438","country_code":"US","type":"company","lineage":["https://openalex.org/I1291425158","https://openalex.org/I4210128969"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Matthew J. Johnson","raw_affiliation_strings":["Google Research, USA"],"raw_orcid":"https://orcid.org/0000-0003-4349-1578","affiliations":[{"raw_affiliation_string":"Google Research, USA","institution_ids":["https://openalex.org/I1291425158"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5044804484","display_name":"Dougal Maclaurin","orcid":"https://orcid.org/0000-0003-0122-1377"},"institutions":[{"id":"https://openalex.org/I1291425158","display_name":"Google (United States)","ror":"https://ror.org/00njsd438","country_code":"US","type":"company","lineage":["https://openalex.org/I1291425158","https://openalex.org/I4210128969"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Dougal Maclaurin","raw_affiliation_strings":["Google Research, USA"],"raw_orcid":"https://orcid.org/0000-0003-0122-1377","affiliations":[{"raw_affiliation_string":"Google Research, USA","institution_ids":["https://openalex.org/I1291425158"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":5,"corresponding_author_ids":[],"corresponding_institution_ids":[],"apc_list":null,"apc_paid":null,"fwci":2.4216,"has_fulltext":true,"cited_by_count":13,"citation_normalized_percentile":{"value":0.90275095,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":95,"max":98},"biblio":{"volume":"7","issue":"POPL","first_page":"1246","last_page":"1274"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10142","display_name":"Formal Methods in Verification","score":0.995199978351593,"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/T10142","display_name":"Formal Methods in Verification","score":0.995199978351593,"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/T11697","display_name":"Numerical Methods and Algorithms","score":0.9911999702453613,"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/T10791","display_name":"Advanced Control Systems Optimization","score":0.9822999835014343,"subfield":{"id":"https://openalex.org/subfields/2207","display_name":"Control and Systems 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/transpose","display_name":"Transpose","score":0.8612095713615417},{"id":"https://openalex.org/keywords/corollary","display_name":"Corollary","score":0.6970891952514648},{"id":"https://openalex.org/keywords/automatic-differentiation","display_name":"Automatic differentiation","score":0.6877807378768921},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.6022171974182129},{"id":"https://openalex.org/keywords/mode","display_name":"Mode (computer interface)","score":0.5323646068572998},{"id":"https://openalex.org/keywords/computation","display_name":"Computation","score":0.5133659243583679},{"id":"https://openalex.org/keywords/function","display_name":"Function (biology)","score":0.4944725036621094},{"id":"https://openalex.org/keywords/decomposition","display_name":"Decomposition","score":0.46776291728019714},{"id":"https://openalex.org/keywords/linear-system","display_name":"Linear system","score":0.4317435324192047},{"id":"https://openalex.org/keywords/divergence","display_name":"Divergence (linguistics)","score":0.4142572581768036},{"id":"https://openalex.org/keywords/algorithm","display_name":"Algorithm","score":0.4103415608406067},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.3397901654243469},{"id":"https://openalex.org/keywords/mathematical-optimization","display_name":"Mathematical optimization","score":0.3241890072822571},{"id":"https://openalex.org/keywords/algebra-over-a-field","display_name":"Algebra over a field","score":0.3226779103279114},{"id":"https://openalex.org/keywords/pure-mathematics","display_name":"Pure mathematics","score":0.20137789845466614},{"id":"https://openalex.org/keywords/mathematical-analysis","display_name":"Mathematical analysis","score":0.09498104453086853}],"concepts":[{"id":"https://openalex.org/C200106649","wikidata":"https://www.wikidata.org/wiki/Q223683","display_name":"Transpose","level":3,"score":0.8612095713615417},{"id":"https://openalex.org/C2780012671","wikidata":"https://www.wikidata.org/wiki/Q1343870","display_name":"Corollary","level":2,"score":0.6970891952514648},{"id":"https://openalex.org/C133512626","wikidata":"https://www.wikidata.org/wiki/Q787371","display_name":"Automatic differentiation","level":3,"score":0.6877807378768921},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.6022171974182129},{"id":"https://openalex.org/C48677424","wikidata":"https://www.wikidata.org/wiki/Q6888088","display_name":"Mode (computer interface)","level":2,"score":0.5323646068572998},{"id":"https://openalex.org/C45374587","wikidata":"https://www.wikidata.org/wiki/Q12525525","display_name":"Computation","level":2,"score":0.5133659243583679},{"id":"https://openalex.org/C14036430","wikidata":"https://www.wikidata.org/wiki/Q3736076","display_name":"Function (biology)","level":2,"score":0.4944725036621094},{"id":"https://openalex.org/C124681953","wikidata":"https://www.wikidata.org/wiki/Q339062","display_name":"Decomposition","level":2,"score":0.46776291728019714},{"id":"https://openalex.org/C6802819","wikidata":"https://www.wikidata.org/wiki/Q1072174","display_name":"Linear system","level":2,"score":0.4317435324192047},{"id":"https://openalex.org/C207390915","wikidata":"https://www.wikidata.org/wiki/Q1230525","display_name":"Divergence (linguistics)","level":2,"score":0.4142572581768036},{"id":"https://openalex.org/C11413529","wikidata":"https://www.wikidata.org/wiki/Q8366","display_name":"Algorithm","level":1,"score":0.4103415608406067},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.3397901654243469},{"id":"https://openalex.org/C126255220","wikidata":"https://www.wikidata.org/wiki/Q141495","display_name":"Mathematical optimization","level":1,"score":0.3241890072822571},{"id":"https://openalex.org/C136119220","wikidata":"https://www.wikidata.org/wiki/Q1000660","display_name":"Algebra over a field","level":2,"score":0.3226779103279114},{"id":"https://openalex.org/C202444582","wikidata":"https://www.wikidata.org/wiki/Q837863","display_name":"Pure mathematics","level":1,"score":0.20137789845466614},{"id":"https://openalex.org/C134306372","wikidata":"https://www.wikidata.org/wiki/Q7754","display_name":"Mathematical analysis","level":1,"score":0.09498104453086853},{"id":"https://openalex.org/C18903297","wikidata":"https://www.wikidata.org/wiki/Q7150","display_name":"Ecology","level":1,"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/C158693339","wikidata":"https://www.wikidata.org/wiki/Q190524","display_name":"Eigenvalues and eigenvectors","level":2,"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/C111919701","wikidata":"https://www.wikidata.org/wiki/Q9135","display_name":"Operating system","level":1,"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/C138885662","wikidata":"https://www.wikidata.org/wiki/Q5891","display_name":"Philosophy","level":0,"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/C62520636","wikidata":"https://www.wikidata.org/wiki/Q944","display_name":"Quantum mechanics","level":1,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1145/3571236","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3571236","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3571236","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"}],"best_oa_location":{"id":"doi:10.1145/3571236","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3571236","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3571236","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":[],"awards":[],"funders":[],"has_content":{"pdf":true,"grobid_xml":true},"content_urls":{"pdf":"https://content.openalex.org/works/W4315630753.pdf","grobid_xml":"https://content.openalex.org/works/W4315630753.grobid-xml"},"referenced_works_count":21,"referenced_works":["https://openalex.org/W1556604985","https://openalex.org/W1912157869","https://openalex.org/W1965256357","https://openalex.org/W1967058818","https://openalex.org/W2004667183","https://openalex.org/W2024545411","https://openalex.org/W2156468295","https://openalex.org/W2295743822","https://openalex.org/W2478429860","https://openalex.org/W2914196042","https://openalex.org/W2966177220","https://openalex.org/W2976069993","https://openalex.org/W2988918532","https://openalex.org/W3005174853","https://openalex.org/W3021448353","https://openalex.org/W3098464136","https://openalex.org/W3115524557","https://openalex.org/W3122093772","https://openalex.org/W3123526065","https://openalex.org/W3195241200","https://openalex.org/W4206834996"],"related_works":["https://openalex.org/W2376029318","https://openalex.org/W2388301251","https://openalex.org/W3013941779","https://openalex.org/W1998659141","https://openalex.org/W3195376785","https://openalex.org/W2370435933","https://openalex.org/W2003786218","https://openalex.org/W2354500408","https://openalex.org/W1968158126","https://openalex.org/W4315630753"],"abstract_inverted_index":{"Automatic":[0],"differentiation":[1,169,181],"(AD)":[2],"is":[3],"conventionally":[4],"understood":[5],"as":[6],"a":[7,44,75,83,135,143,164],"family":[8],"of":[9,46,66,85,167,180,186,197],"distinct":[10],"algorithms,":[11],"rooted":[12],"in":[13,36,138],"two":[14],"\u201cmodes\u201d\u2014forward":[15],"and":[16,39,59,62,101,106,115,170],"reverse\u2014which":[17],"are":[18,87,93,147],"typically":[19],"presented":[20],"(and":[21],"implemented)":[22],"separately.":[23],"Can":[24],"there":[25],"be":[26],"only":[27],"one?":[28],"Following":[29],"up":[30],"on":[31,129],"the":[32,37,57,67,178,184,191,195],"AD":[33,48,52,96],"systems":[34],"developed":[35],"JAX":[38],"Dex":[40],"projects,":[41],"we":[42,73,103],"formalize":[43],"decomposition":[45,125],"reverse-mode":[47,122],"into":[49],"(i)":[50],"forward-mode":[51,95],"followed":[53],"by":[54,176],"(ii)":[55],"unzipping":[56,139],"linear":[58,68,77,99,110],"non-linear":[60],"parts":[61],"then":[63],"(iii)":[64],"transposition":[65],"part.":[69],"To":[70],"that":[71,80,94,102,158,171],"end,":[72],"define":[74],"(substructurally)":[76],"type":[78],"system":[79],"can":[81,104],"prove":[82],"class":[84],"functions":[86],"(algebraically)":[88],"linear.":[89],"Our":[90],"main":[91],"results":[92],"produces":[97],"such":[98,109],"functions,":[100],"unzip":[105],"transpose":[107],"any":[108],"function,":[111],"conserving":[112],"cost,":[113],"size,":[114],"linearity.":[116],"Composing":[117],"these":[118],"three":[119],"transformations":[120],"recovers":[121],"AD.":[123,155],"This":[124],"also":[126],"sheds":[127],"light":[128],"checkpointing,":[130],"which":[131],"emerges":[132],"naturally":[133],"from":[134,183,194],"free":[136],"choice":[137],"let":[140],"expressions.":[141],"As":[142],"corollary,":[144],"checkpointing":[145],"techniques":[146],"applicable":[148],"to":[149,163],"general-purpose":[150],"partial":[151],"evaluation,":[152],"not":[153],"just":[154],"We":[156],"hope":[157],"our":[159],"formalization":[160],"will":[161,173],"lead":[162],"deeper":[165],"understanding":[166],"automatic":[168],"it":[172,199],"simplify":[174],"implementations,":[175],"separating":[177,190],"concerns":[179,185],"proper":[182],"gaining":[187],"efficiency":[188],"(namely,":[189],"derivative":[192],"computation":[193],"act":[196],"running":[198],"backward).":[200]},"counts_by_year":[{"year":2026,"cited_by_count":1},{"year":2025,"cited_by_count":2},{"year":2024,"cited_by_count":6},{"year":2023,"cited_by_count":4}],"updated_date":"2026-06-11T09:08:48.828518","created_date":"2025-10-10T00:00:00"}
