{"id":"https://openalex.org/W2751693130","doi":"https://doi.org/10.1145/3122955.3127333","title":"Ornaments: exploiting parametricity for safer, more automated code refactorization and code reuse (invited talk)","display_name":"Ornaments: exploiting parametricity for safer, more automated code refactorization and code reuse (invited talk)","publication_year":2017,"publication_date":"2017-09-01","ids":{"openalex":"https://openalex.org/W2751693130","doi":"https://doi.org/10.1145/3122955.3127333","mag":"2751693130"},"language":"en","primary_location":{"id":"doi:10.1145/3122955.3127333","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3122955.3127333","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 10th ACM SIGPLAN International Symposium on Haskell","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/A5085438928","display_name":"Didier R\u00e9my","orcid":"https://orcid.org/0000-0002-0693-6278"},"institutions":[{"id":"https://openalex.org/I1326498283","display_name":"Institut national de recherche en informatique et en automatique","ror":"https://ror.org/02kvxyf05","country_code":"FR","type":"funder","lineage":["https://openalex.org/I1326498283"]}],"countries":["FR"],"is_corresponding":true,"raw_author_name":"Didier R\u00e9my","raw_affiliation_strings":["Inria, France"],"affiliations":[{"raw_affiliation_string":"Inria, France","institution_ids":["https://openalex.org/I1326498283"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":1,"corresponding_author_ids":["https://openalex.org/A5085438928"],"corresponding_institution_ids":["https://openalex.org/I1326498283"],"apc_list":null,"apc_paid":null,"fwci":0.0,"has_fulltext":false,"cited_by_count":0,"citation_normalized_percentile":{"value":0.14130231,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":null,"biblio":{"volume":null,"issue":null,"first_page":"1","last_page":"1"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10317","display_name":"Advanced Database Systems and Queries","score":0.9916999936103821,"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"}},"topics":[{"id":"https://openalex.org/T10317","display_name":"Advanced Database Systems and Queries","score":0.9916999936103821,"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/T10260","display_name":"Software Engineering Research","score":0.9907000064849854,"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/T10054","display_name":"Parallel Computing and Optimization Techniques","score":0.9883000254631042,"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"}}],"keywords":[{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8941971659660339},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.8316832184791565},{"id":"https://openalex.org/keywords/haskell","display_name":"Haskell","score":0.6236618161201477},{"id":"https://openalex.org/keywords/type-safety","display_name":"Type safety","score":0.4836060106754303},{"id":"https://openalex.org/keywords/context","display_name":"Context (archaeology)","score":0.4463815987110138},{"id":"https://openalex.org/keywords/reuse","display_name":"Reuse","score":0.44594019651412964},{"id":"https://openalex.org/keywords/code","display_name":"Code (set theory)","score":0.4446215331554413},{"id":"https://openalex.org/keywords/safer","display_name":"SAFER","score":0.43936488032341003},{"id":"https://openalex.org/keywords/code-generation","display_name":"Code generation","score":0.43529778718948364},{"id":"https://openalex.org/keywords/structuring","display_name":"Structuring","score":0.4337931275367737},{"id":"https://openalex.org/keywords/code-reuse","display_name":"Code reuse","score":0.43119189143180847},{"id":"https://openalex.org/keywords/program-transformation","display_name":"Program transformation","score":0.4123404324054718},{"id":"https://openalex.org/keywords/key","display_name":"Key (lock)","score":0.4107055068016052},{"id":"https://openalex.org/keywords/functional-programming","display_name":"Functional programming","score":0.36037540435791016},{"id":"https://openalex.org/keywords/software","display_name":"Software","score":0.24514958262443542},{"id":"https://openalex.org/keywords/operating-system","display_name":"Operating system","score":0.1722467541694641}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8941971659660339},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.8316832184791565},{"id":"https://openalex.org/C2780624054","wikidata":"https://www.wikidata.org/wiki/Q34010","display_name":"Haskell","level":3,"score":0.6236618161201477},{"id":"https://openalex.org/C44779574","wikidata":"https://www.wikidata.org/wiki/Q736866","display_name":"Type safety","level":2,"score":0.4836060106754303},{"id":"https://openalex.org/C2779343474","wikidata":"https://www.wikidata.org/wiki/Q3109175","display_name":"Context (archaeology)","level":2,"score":0.4463815987110138},{"id":"https://openalex.org/C206588197","wikidata":"https://www.wikidata.org/wiki/Q846574","display_name":"Reuse","level":2,"score":0.44594019651412964},{"id":"https://openalex.org/C2776760102","wikidata":"https://www.wikidata.org/wiki/Q5139990","display_name":"Code (set theory)","level":3,"score":0.4446215331554413},{"id":"https://openalex.org/C2776654903","wikidata":"https://www.wikidata.org/wiki/Q2601463","display_name":"SAFER","level":2,"score":0.43936488032341003},{"id":"https://openalex.org/C133162039","wikidata":"https://www.wikidata.org/wiki/Q1061077","display_name":"Code generation","level":3,"score":0.43529778718948364},{"id":"https://openalex.org/C2775945657","wikidata":"https://www.wikidata.org/wiki/Q381442","display_name":"Structuring","level":2,"score":0.4337931275367737},{"id":"https://openalex.org/C2778583558","wikidata":"https://www.wikidata.org/wiki/Q771245","display_name":"Code reuse","level":3,"score":0.43119189143180847},{"id":"https://openalex.org/C2778361913","wikidata":"https://www.wikidata.org/wiki/Q7248437","display_name":"Program transformation","level":2,"score":0.4123404324054718},{"id":"https://openalex.org/C26517878","wikidata":"https://www.wikidata.org/wiki/Q228039","display_name":"Key (lock)","level":2,"score":0.4107055068016052},{"id":"https://openalex.org/C42383842","wikidata":"https://www.wikidata.org/wiki/Q193076","display_name":"Functional programming","level":2,"score":0.36037540435791016},{"id":"https://openalex.org/C2777904410","wikidata":"https://www.wikidata.org/wiki/Q7397","display_name":"Software","level":2,"score":0.24514958262443542},{"id":"https://openalex.org/C111919701","wikidata":"https://www.wikidata.org/wiki/Q9135","display_name":"Operating system","level":1,"score":0.1722467541694641},{"id":"https://openalex.org/C151730666","wikidata":"https://www.wikidata.org/wiki/Q7205","display_name":"Paleontology","level":1,"score":0.0},{"id":"https://openalex.org/C10138342","wikidata":"https://www.wikidata.org/wiki/Q43015","display_name":"Finance","level":1,"score":0.0},{"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/C177264268","wikidata":"https://www.wikidata.org/wiki/Q1514741","display_name":"Set (abstract data type)","level":2,"score":0.0},{"id":"https://openalex.org/C162324750","wikidata":"https://www.wikidata.org/wiki/Q8134","display_name":"Economics","level":0,"score":0.0},{"id":"https://openalex.org/C38652104","wikidata":"https://www.wikidata.org/wiki/Q3510521","display_name":"Computer security","level":1,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1145/3122955.3127333","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3122955.3127333","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 10th ACM SIGPLAN International Symposium on Haskell","raw_type":"proceedings-article"}],"best_oa_location":null,"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"pdf":false,"grobid_xml":false},"content_urls":null,"referenced_works_count":0,"referenced_works":[],"related_works":["https://openalex.org/W2112263414","https://openalex.org/W1602185604","https://openalex.org/W3004782279","https://openalex.org/W2028779182","https://openalex.org/W4242678340","https://openalex.org/W2140654465","https://openalex.org/W2129253059","https://openalex.org/W2017112188","https://openalex.org/W3006157134","https://openalex.org/W2561717017"],"abstract_inverted_index":{"Inductive":[0],"datatypes":[1],"and":[2,26,33,82],"parametric":[3],"polymorphism":[4],"are":[5,29],"two":[6],"key":[7],"features":[8],"introduced":[9],"in":[10,51,63],"the":[11,57],"ML":[12,27],"family":[13],"of":[14],"languages,":[15],"which":[16],"have":[17],"already":[18],"been":[19],"widely":[20],"exploited":[21],"for":[22,98],"structuring":[23],"programs:":[24],"Haskell":[25],"programs":[28],"often":[30],"more":[31,34,83],"elegant":[32],"correct":[35],"by":[36,66,85],"construction.":[37],"Still,":[38],"we":[39],"sometimes":[40],"need":[41],"code":[42,100],"to":[43,48],"be":[44,49,79],"refactored":[45],"or":[46,72],"adapted":[47],"reused":[50],"a":[52,91,96],"slightly":[53],"different":[54],"context.":[55],"While":[56],"type":[58],"system":[59],"is":[60],"considerably":[61],"helpful":[62],"these":[64],"situations,":[65],"automatically":[67],"locating":[68],"type-inconsistent":[69],"program":[70,93],"points":[71],"incomplete":[73],"pattern":[74],"matchings,":[75],"this":[76],"process":[77],"could":[78],"made":[80],"safer":[81],"automated":[84],"further":[86],"exploiting":[87],"parametricity.":[88],"We":[89],"propose":[90],"posteriori":[92],"abstraction":[94],"as":[95],"principle":[97],"such":[99],"transformations.":[101]},"counts_by_year":[],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2025-10-10T00:00:00"}
