{"id":"https://openalex.org/W2072644784","doi":"https://doi.org/10.1145/1017472.1017485","title":"Type-safe, self inspecting code","display_name":"Type-safe, self inspecting code","publication_year":2004,"publication_date":"2004-09-22","ids":{"openalex":"https://openalex.org/W2072644784","doi":"https://doi.org/10.1145/1017472.1017485","mag":"2072644784"},"language":"en","primary_location":{"id":"doi:10.1145/1017472.1017485","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1017472.1017485","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 2004 ACM SIGPLAN workshop 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/A5041379959","display_name":"Arthur I. Baars","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":"Arthur I. Baars","raw_affiliation_strings":["Utrecht University, Utrecht, The Netherlands"],"affiliations":[{"raw_affiliation_string":"Utrecht University, Utrecht, The Netherlands","institution_ids":["https://openalex.org/I193662353"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5060098926","display_name":"S. Doaitse Swierstra","orcid":"https://orcid.org/0000-0001-6758-4280"},"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":"S. Doaitse Swierstra","raw_affiliation_strings":["Utrecht University, Utrecht, The Netherlands"],"affiliations":[{"raw_affiliation_string":"Utrecht University, Utrecht, The Netherlands","institution_ids":["https://openalex.org/I193662353"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":2,"corresponding_author_ids":["https://openalex.org/A5041379959"],"corresponding_institution_ids":["https://openalex.org/I193662353"],"apc_list":null,"apc_paid":null,"fwci":2.7728,"has_fulltext":false,"cited_by_count":23,"citation_normalized_percentile":{"value":0.91042404,"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":"69","last_page":"79"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10126","display_name":"Logic, programming, and type systems","score":0.9994000196456909,"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"}},"topics":[{"id":"https://openalex.org/T10126","display_name":"Logic, programming, and type systems","score":0.9994000196456909,"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/T10142","display_name":"Formal Methods in Verification","score":0.9973999857902527,"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/T10260","display_name":"Software Engineering Research","score":0.9955999851226807,"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"}}],"keywords":[{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.8194125890731812},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8184511661529541},{"id":"https://openalex.org/keywords/haskell","display_name":"Haskell","score":0.8136748671531677},{"id":"https://openalex.org/keywords/correctness","display_name":"Correctness","score":0.7939309477806091},{"id":"https://openalex.org/keywords/parsing","display_name":"Parsing","score":0.5999725461006165},{"id":"https://openalex.org/keywords/recursion","display_name":"Recursion (computer science)","score":0.5605101585388184},{"id":"https://openalex.org/keywords/program-transformation","display_name":"Program transformation","score":0.5150556564331055},{"id":"https://openalex.org/keywords/functional-programming","display_name":"Functional programming","score":0.48596107959747314},{"id":"https://openalex.org/keywords/program-analysis","display_name":"Program analysis","score":0.44704559445381165},{"id":"https://openalex.org/keywords/combinatory-logic","display_name":"Combinatory logic","score":0.42190372943878174},{"id":"https://openalex.org/keywords/type","display_name":"Type (biology)","score":0.41971880197525024},{"id":"https://openalex.org/keywords/generic-programming","display_name":"Generic programming","score":0.41537702083587646},{"id":"https://openalex.org/keywords/abstract-syntax-tree","display_name":"Abstract syntax tree","score":0.41042810678482056}],"concepts":[{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.8194125890731812},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8184511661529541},{"id":"https://openalex.org/C2780624054","wikidata":"https://www.wikidata.org/wiki/Q34010","display_name":"Haskell","level":3,"score":0.8136748671531677},{"id":"https://openalex.org/C55439883","wikidata":"https://www.wikidata.org/wiki/Q360812","display_name":"Correctness","level":2,"score":0.7939309477806091},{"id":"https://openalex.org/C186644900","wikidata":"https://www.wikidata.org/wiki/Q194152","display_name":"Parsing","level":2,"score":0.5999725461006165},{"id":"https://openalex.org/C168773036","wikidata":"https://www.wikidata.org/wiki/Q264164","display_name":"Recursion (computer science)","level":2,"score":0.5605101585388184},{"id":"https://openalex.org/C2778361913","wikidata":"https://www.wikidata.org/wiki/Q7248437","display_name":"Program transformation","level":2,"score":0.5150556564331055},{"id":"https://openalex.org/C42383842","wikidata":"https://www.wikidata.org/wiki/Q193076","display_name":"Functional programming","level":2,"score":0.48596107959747314},{"id":"https://openalex.org/C98183937","wikidata":"https://www.wikidata.org/wiki/Q2112188","display_name":"Program analysis","level":2,"score":0.44704559445381165},{"id":"https://openalex.org/C79678938","wikidata":"https://www.wikidata.org/wiki/Q1481571","display_name":"Combinatory logic","level":2,"score":0.42190372943878174},{"id":"https://openalex.org/C2777299769","wikidata":"https://www.wikidata.org/wiki/Q3707858","display_name":"Type (biology)","level":2,"score":0.41971880197525024},{"id":"https://openalex.org/C7051814","wikidata":"https://www.wikidata.org/wiki/Q1051282","display_name":"Generic programming","level":2,"score":0.41537702083587646},{"id":"https://openalex.org/C58646249","wikidata":"https://www.wikidata.org/wiki/Q127380","display_name":"Abstract syntax tree","level":3,"score":0.41042810678482056},{"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}],"mesh":[],"locations_count":2,"locations":[{"id":"doi:10.1145/1017472.1017485","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1017472.1017485","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 2004 ACM SIGPLAN workshop on Haskell","raw_type":"proceedings-article"},{"id":"pmh:oai:CiteSeerX.psu:10.1.1.885.1576","is_oa":false,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.885.1576","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"http://www.staff.science.uu.nl/%7Eswier101/Papers/2004/p1210-baars.pdf","raw_type":"text"}],"best_oa_location":null,"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"pdf":false,"grobid_xml":false},"content_urls":null,"referenced_works_count":33,"referenced_works":["https://openalex.org/W35144087","https://openalex.org/W124381426","https://openalex.org/W1485908855","https://openalex.org/W1488750823","https://openalex.org/W1490215723","https://openalex.org/W1494460511","https://openalex.org/W1508259349","https://openalex.org/W1523648047","https://openalex.org/W1572387991","https://openalex.org/W1827112781","https://openalex.org/W1967061556","https://openalex.org/W1976020328","https://openalex.org/W1997644097","https://openalex.org/W2002988345","https://openalex.org/W2009775190","https://openalex.org/W2057052623","https://openalex.org/W2057292961","https://openalex.org/W2064138295","https://openalex.org/W2116435685","https://openalex.org/W2119717320","https://openalex.org/W2128580729","https://openalex.org/W2145287505","https://openalex.org/W2149935768","https://openalex.org/W2163201987","https://openalex.org/W2591126073","https://openalex.org/W2618896829","https://openalex.org/W2911969993","https://openalex.org/W3004785238","https://openalex.org/W4242126179","https://openalex.org/W6638774856","https://openalex.org/W6683959968","https://openalex.org/W6734238029","https://openalex.org/W6758725702"],"related_works":["https://openalex.org/W2155480936","https://openalex.org/W2952185493","https://openalex.org/W2162766176","https://openalex.org/W1734457603","https://openalex.org/W4240871092","https://openalex.org/W2521829344","https://openalex.org/W2951199257","https://openalex.org/W4302391323","https://openalex.org/W1580128549","https://openalex.org/W2478906578"],"abstract_inverted_index":{"We":[0],"present":[1],"techniques":[2,33],"for":[3,18],"representing":[4],"typed":[5],"abstract":[6],"syntax":[7],"trees":[8],"in":[9,28,38,72,75],"the":[10,22,47,63,77,87,90,95,99],"presence":[11],"of":[12,51,62,89,98],"observable":[13],"recursive":[14],"structures.":[15],"The":[16,32,59],"need":[17],"this":[19],"arose":[20],"from":[21],"desire":[23],"to":[24,66,84],"cope":[25],"with":[26],"left-recursion":[27],"combinator":[29],"based":[30],"parsers.":[31],"employed":[34],"can":[35],"be":[36],"used":[37],"a":[39,73],"much":[40],"wider":[41],"setting":[42,74],"however,":[43],"since":[44],"it":[45],"enables":[46],"inspection":[48],"and":[49,70,93],"transformation":[50],"any":[52],"program":[53,91],"structure,":[54],"which":[55,76],"contains":[56],"internal":[57],"references.":[58],"hard":[60],"part":[61],"work":[64],"is":[65,81],"perform":[67],"such":[68],"analyses":[69],"transformations":[71],"Haskell":[78],"type":[79,96],"checker":[80],"still":[82],"able":[83],"statically":[85],"check":[86],"correctness":[88,97],"representations,":[92],"hence":[94],"transformed":[100],"program.":[101]},"counts_by_year":[{"year":2020,"cited_by_count":2},{"year":2018,"cited_by_count":1},{"year":2013,"cited_by_count":5}],"updated_date":"2026-04-04T16:13:02.066488","created_date":"2025-10-10T00:00:00"}
