{"id":"https://openalex.org/W2753285689","doi":"https://doi.org/10.1145/3122975.3122976","title":"Type-directed diffing of structured data","display_name":"Type-directed diffing of structured data","publication_year":2017,"publication_date":"2017-08-30","ids":{"openalex":"https://openalex.org/W2753285689","doi":"https://doi.org/10.1145/3122975.3122976","mag":"2753285689"},"language":"en","primary_location":{"id":"doi:10.1145/3122975.3122976","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3122975.3122976","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 2nd ACM SIGPLAN International Workshop on Type-Driven Development","raw_type":"proceedings-article"},"type":"preprint","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"green","oa_url":"https://dspace.library.uu.nl/handle/1874/355261","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5082086181","display_name":"Victor Cacciari Miraldo","orcid":null},"institutions":[{"id":"https://openalex.org/I193662353","display_name":"Utrecht University","ror":"https://ror.org/04pp8hn57","country_code":"NL","type":"education","lineage":["https://openalex.org/I193662353"]}],"countries":["NL"],"is_corresponding":true,"raw_author_name":"Victor Cacciari Miraldo","raw_affiliation_strings":["Utrecht University, Netherlands","Department of Computer Science [Utrecht]"],"affiliations":[{"raw_affiliation_string":"Utrecht University, Netherlands","institution_ids":["https://openalex.org/I193662353"]},{"raw_affiliation_string":"Department of Computer Science [Utrecht]","institution_ids":[]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5047227539","display_name":"Pierre-\u00c9variste Dagand","orcid":null},"institutions":[{"id":"https://openalex.org/I4210124483","display_name":"Laboratoire M\u00e9moire et Cognition","ror":"https://ror.org/036ydxy43","country_code":"FR","type":"facility","lineage":["https://openalex.org/I154526488","https://openalex.org/I204730241","https://openalex.org/I204730241","https://openalex.org/I4210124483","https://openalex.org/I4210150564","https://openalex.org/I4210163442"]}],"countries":["FR"],"is_corresponding":false,"raw_author_name":"Pierre-\u00c9variste Dagand","raw_affiliation_strings":["UPMC, France","Well Honed Infrastructure Software for Programming Environments and Runtimes"],"affiliations":[{"raw_affiliation_string":"UPMC, France","institution_ids":["https://openalex.org/I4210124483"]},{"raw_affiliation_string":"Well Honed Infrastructure Software for Programming Environments and Runtimes","institution_ids":[]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5019085361","display_name":"Wouter Swierstra","orcid":"https://orcid.org/0000-0002-0295-7944"},"institutions":[{"id":"https://openalex.org/I193662353","display_name":"Utrecht University","ror":"https://ror.org/04pp8hn57","country_code":"NL","type":"education","lineage":["https://openalex.org/I193662353"]}],"countries":["NL"],"is_corresponding":false,"raw_author_name":"Wouter Swierstra","raw_affiliation_strings":["Utrecht University, Netherlands","Department of Computer Science [Utrecht]"],"affiliations":[{"raw_affiliation_string":"Utrecht University, Netherlands","institution_ids":["https://openalex.org/I193662353"]},{"raw_affiliation_string":"Department of Computer Science [Utrecht]","institution_ids":[]}]}],"institutions":[],"countries_distinct_count":2,"institutions_distinct_count":3,"corresponding_author_ids":["https://openalex.org/A5082086181"],"corresponding_institution_ids":["https://openalex.org/I193662353"],"apc_list":null,"apc_paid":null,"fwci":4.5523,"has_fulltext":false,"cited_by_count":9,"citation_normalized_percentile":{"value":0.95333073,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":90,"max":98},"biblio":{"volume":null,"issue":null,"first_page":"2","last_page":"15"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10260","display_name":"Software Engineering Research","score":0.9994999766349792,"subfield":{"id":"https://openalex.org/subfields/1710","display_name":"Information Systems"},"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/T10260","display_name":"Software Engineering Research","score":0.9994999766349792,"subfield":{"id":"https://openalex.org/subfields/1710","display_name":"Information Systems"},"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/T10126","display_name":"Logic, programming, and type systems","score":0.9951000213623047,"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"}},{"id":"https://openalex.org/T10639","display_name":"Advanced Software Engineering Methodologies","score":0.9882000088691711,"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.8002080917358398},{"id":"https://openalex.org/keywords/unix","display_name":"Unix","score":0.7261085510253906},{"id":"https://openalex.org/keywords/granularity","display_name":"Granularity","score":0.6762374639511108},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.6200852394104004},{"id":"https://openalex.org/keywords/representation","display_name":"Representation (politics)","score":0.5990974307060242},{"id":"https://openalex.org/keywords/syntax","display_name":"Syntax","score":0.5829277038574219},{"id":"https://openalex.org/keywords/abstract-data-type","display_name":"Abstract data type","score":0.5513970255851746},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.5460295081138611},{"id":"https://openalex.org/keywords/data-type","display_name":"Data type","score":0.5122296214103699},{"id":"https://openalex.org/keywords/algebraic-number","display_name":"Algebraic number","score":0.47170138359069824},{"id":"https://openalex.org/keywords/code","display_name":"Code (set theory)","score":0.4387649893760681},{"id":"https://openalex.org/keywords/abstract-syntax","display_name":"Abstract syntax","score":0.42125025391578674},{"id":"https://openalex.org/keywords/data-structure","display_name":"Data structure","score":0.42032772302627563},{"id":"https://openalex.org/keywords/external-data-representation","display_name":"External Data Representation","score":0.4128819704055786},{"id":"https://openalex.org/keywords/artificial-intelligence","display_name":"Artificial intelligence","score":0.21236789226531982},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.0969814658164978},{"id":"https://openalex.org/keywords/software","display_name":"Software","score":0.09612900018692017}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8002080917358398},{"id":"https://openalex.org/C112968700","wikidata":"https://www.wikidata.org/wiki/Q11368","display_name":"Unix","level":3,"score":0.7261085510253906},{"id":"https://openalex.org/C177774035","wikidata":"https://www.wikidata.org/wiki/Q1246948","display_name":"Granularity","level":2,"score":0.6762374639511108},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.6200852394104004},{"id":"https://openalex.org/C2776359362","wikidata":"https://www.wikidata.org/wiki/Q2145286","display_name":"Representation (politics)","level":3,"score":0.5990974307060242},{"id":"https://openalex.org/C60048249","wikidata":"https://www.wikidata.org/wiki/Q37437","display_name":"Syntax","level":2,"score":0.5829277038574219},{"id":"https://openalex.org/C175971053","wikidata":"https://www.wikidata.org/wiki/Q827335","display_name":"Abstract data type","level":2,"score":0.5513970255851746},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.5460295081138611},{"id":"https://openalex.org/C138958017","wikidata":"https://www.wikidata.org/wiki/Q190087","display_name":"Data type","level":2,"score":0.5122296214103699},{"id":"https://openalex.org/C9376300","wikidata":"https://www.wikidata.org/wiki/Q168817","display_name":"Algebraic number","level":2,"score":0.47170138359069824},{"id":"https://openalex.org/C2776760102","wikidata":"https://www.wikidata.org/wiki/Q5139990","display_name":"Code (set theory)","level":3,"score":0.4387649893760681},{"id":"https://openalex.org/C114408938","wikidata":"https://www.wikidata.org/wiki/Q333373","display_name":"Abstract syntax","level":3,"score":0.42125025391578674},{"id":"https://openalex.org/C162319229","wikidata":"https://www.wikidata.org/wiki/Q175263","display_name":"Data structure","level":2,"score":0.42032772302627563},{"id":"https://openalex.org/C116409475","wikidata":"https://www.wikidata.org/wiki/Q1385056","display_name":"External Data Representation","level":2,"score":0.4128819704055786},{"id":"https://openalex.org/C154945302","wikidata":"https://www.wikidata.org/wiki/Q11660","display_name":"Artificial intelligence","level":1,"score":0.21236789226531982},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.0969814658164978},{"id":"https://openalex.org/C2777904410","wikidata":"https://www.wikidata.org/wiki/Q7397","display_name":"Software","level":2,"score":0.09612900018692017},{"id":"https://openalex.org/C177264268","wikidata":"https://www.wikidata.org/wiki/Q1514741","display_name":"Set (abstract data type)","level":2,"score":0.0},{"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/C199539241","wikidata":"https://www.wikidata.org/wiki/Q7748","display_name":"Law","level":1,"score":0.0},{"id":"https://openalex.org/C17744445","wikidata":"https://www.wikidata.org/wiki/Q36442","display_name":"Political science","level":0,"score":0.0},{"id":"https://openalex.org/C94625758","wikidata":"https://www.wikidata.org/wiki/Q7163","display_name":"Politics","level":2,"score":0.0}],"mesh":[],"locations_count":3,"locations":[{"id":"doi:10.1145/3122975.3122976","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3122975.3122976","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 2nd ACM SIGPLAN International Workshop on Type-Driven Development","raw_type":"proceedings-article"},{"id":"pmh:oai:HAL:hal-01673541v1","is_oa":false,"landing_page_url":"https://hal.science/hal-01673541","pdf_url":null,"source":{"id":"https://openalex.org/S4306402512","display_name":"HAL (Le Centre pour la Communication Scientifique Directe)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I1294671590","host_organization_name":"Centre National de la Recherche Scientifique","host_organization_lineage":["https://openalex.org/I1294671590"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"TyDe 2017 - 2nd ACM SIGPLAN International Workshop on Type-Driven Development, Sep 2017, Oxford, United Kingdom. pp.2-15, &#x27E8;10.1145/3122975.3122976&#x27E9;","raw_type":"Conference papers"},{"id":"pmh:oai:dspace.library.uu.nl:1874/355261","is_oa":true,"landing_page_url":"https://dspace.library.uu.nl/handle/1874/355261","pdf_url":null,"source":{"id":"https://openalex.org/S4306401649","display_name":"Utrecht University Repository (Utrecht University)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I193662353","host_organization_name":"Utrecht University","host_organization_lineage":["https://openalex.org/I193662353"],"host_organization_lineage_names":[],"type":"repository"},"license":"other-oa","license_id":"https://openalex.org/licenses/other-oa","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"","raw_type":"Part of book"}],"best_oa_location":{"id":"pmh:oai:dspace.library.uu.nl:1874/355261","is_oa":true,"landing_page_url":"https://dspace.library.uu.nl/handle/1874/355261","pdf_url":null,"source":{"id":"https://openalex.org/S4306401649","display_name":"Utrecht University Repository (Utrecht University)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I193662353","host_organization_name":"Utrecht University","host_organization_lineage":["https://openalex.org/I193662353"],"host_organization_lineage_names":[],"type":"repository"},"license":"other-oa","license_id":"https://openalex.org/licenses/other-oa","version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"","raw_type":"Part of book"},"sustainable_development_goals":[{"id":"https://metadata.un.org/sdg/4","display_name":"Quality Education","score":0.46000000834465027}],"awards":[],"funders":[],"has_content":{"pdf":false,"grobid_xml":false},"content_urls":null,"referenced_works_count":39,"referenced_works":["https://openalex.org/W205472424","https://openalex.org/W1509213251","https://openalex.org/W1576624296","https://openalex.org/W1578634556","https://openalex.org/W1605903931","https://openalex.org/W1751016442","https://openalex.org/W1768450951","https://openalex.org/W1866266163","https://openalex.org/W1891773423","https://openalex.org/W1963502491","https://openalex.org/W1966139659","https://openalex.org/W1976263585","https://openalex.org/W1978478796","https://openalex.org/W1981899763","https://openalex.org/W1982209843","https://openalex.org/W1993230497","https://openalex.org/W2005230371","https://openalex.org/W2012619465","https://openalex.org/W2014995396","https://openalex.org/W2019388039","https://openalex.org/W2053930497","https://openalex.org/W2058137890","https://openalex.org/W2062887328","https://openalex.org/W2065489029","https://openalex.org/W2089243009","https://openalex.org/W2109227373","https://openalex.org/W2114980032","https://openalex.org/W2116813111","https://openalex.org/W2116910575","https://openalex.org/W2143275903","https://openalex.org/W2156400381","https://openalex.org/W2167268698","https://openalex.org/W2284321857","https://openalex.org/W2405986976","https://openalex.org/W2518564811","https://openalex.org/W2572495066","https://openalex.org/W2912949875","https://openalex.org/W4285719527","https://openalex.org/W6731756010"],"related_works":["https://openalex.org/W1996169556","https://openalex.org/W4213129642","https://openalex.org/W624617926","https://openalex.org/W1718424146","https://openalex.org/W4237938900","https://openalex.org/W4239656342","https://openalex.org/W1586440961","https://openalex.org/W1559059528","https://openalex.org/W2066369805","https://openalex.org/W108680433"],"abstract_inverted_index":{"The":[0],"Unix":[1],"diff":[2],"utility":[3],"that":[4],"compares":[5],"lines":[6,34],"of":[7,30,35,87,100],"text":[8],"is":[9],"used":[10,80],"pervasively":[11],"by":[12],"version":[13],"control":[14],"systems.":[15],"Yet":[16],"certain":[17],"changes":[18,41],"to":[19,25,32,49,81,90,108],"a":[20,38,44,58,69,83],"program":[21],"may":[22,47],"be":[23,79],"difficult":[24],"describe":[26],"accurately":[27],"in":[28,103],"terms":[29],"modifications":[31,88,111],"individual":[33],"code.":[36],"As":[37],"result,":[39],"observing":[40],"at":[42],"such":[43,74],"fixed":[45],"granularity":[46],"lead":[48],"unnecessary":[50],"conflicts":[51],"between":[52,64,112],"different":[53],"edits.":[54],"This":[55],"paper":[56],"presents":[57],"generic":[59],"representation":[60],"for":[61,72],"describing":[62],"transformations":[63],"algebraic":[65,91],"data":[66,92],"types":[67],"and":[68,95],"non-deterministic":[70],"algorithm":[71],"computing":[73],"representations.":[75,115],"These":[76],"representations":[77],"can":[78],"give":[82],"more":[84],"accurate":[85],"account":[86],"made":[89],"structures":[93],"-":[94,105],"the":[96],"abstract":[97],"syntax":[98],"trees":[99],"computer":[101],"programs":[102],"particular":[104],"as":[106],"opposed":[107],"only":[109],"considering":[110],"their":[113],"textual":[114]},"counts_by_year":[{"year":2020,"cited_by_count":2},{"year":2019,"cited_by_count":2},{"year":2018,"cited_by_count":4},{"year":2017,"cited_by_count":1}],"updated_date":"2026-04-05T17:49:38.594831","created_date":"2025-10-10T00:00:00"}
