{"id":"https://openalex.org/W3040174379","doi":"https://doi.org/10.1145/3412932.3412939","title":"Type debugging with counter-factual type error messages using an existing type checker","display_name":"Type debugging with counter-factual type error messages using an existing type checker","publication_year":2019,"publication_date":"2019-09-25","ids":{"openalex":"https://openalex.org/W3040174379","doi":"https://doi.org/10.1145/3412932.3412939","mag":"3040174379"},"language":"en","primary_location":{"id":"doi:10.1145/3412932.3412939","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3412932.3412939","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 31st Symposium on Implementation and Application of Functional Languages","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/A5016964464","display_name":"Kanae Tsushima","orcid":"https://orcid.org/0000-0002-3383-3389"},"institutions":[{"id":"https://openalex.org/I184597095","display_name":"National Institute of Informatics","ror":"https://ror.org/04ksd4g47","country_code":"JP","type":"facility","lineage":["https://openalex.org/I1319490839","https://openalex.org/I184597095","https://openalex.org/I4210158934"]}],"countries":["JP"],"is_corresponding":true,"raw_author_name":"Kanae Tsushima","raw_affiliation_strings":["National Institute of Informatics, Japan"],"affiliations":[{"raw_affiliation_string":"National Institute of Informatics, Japan","institution_ids":["https://openalex.org/I184597095"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5018345365","display_name":"Olaf Chitil","orcid":"https://orcid.org/0000-0001-7986-9929"},"institutions":[{"id":"https://openalex.org/I20581793","display_name":"University of Kent","ror":"https://ror.org/00xkeyj56","country_code":"GB","type":"education","lineage":["https://openalex.org/I20581793"]}],"countries":["GB"],"is_corresponding":false,"raw_author_name":"Olaf Chitil","raw_affiliation_strings":["University of Kent, United Kingdom"],"affiliations":[{"raw_affiliation_string":"University of Kent, United Kingdom","institution_ids":["https://openalex.org/I20581793"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5065892309","display_name":"Joanna Sharrad","orcid":null},"institutions":[{"id":"https://openalex.org/I20581793","display_name":"University of Kent","ror":"https://ror.org/00xkeyj56","country_code":"GB","type":"education","lineage":["https://openalex.org/I20581793"]}],"countries":["GB"],"is_corresponding":false,"raw_author_name":"Joanna Sharrad","raw_affiliation_strings":["University of Kent, United Kingdom"],"affiliations":[{"raw_affiliation_string":"University of Kent, United Kingdom","institution_ids":["https://openalex.org/I20581793"]}]}],"institutions":[],"countries_distinct_count":2,"institutions_distinct_count":3,"corresponding_author_ids":["https://openalex.org/A5016964464"],"corresponding_institution_ids":["https://openalex.org/I184597095"],"apc_list":null,"apc_paid":null,"fwci":0.14,"has_fulltext":false,"cited_by_count":4,"citation_normalized_percentile":{"value":0.61215196,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":89,"max":97},"biblio":{"volume":"31","issue":null,"first_page":"1","last_page":"12"},"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.9997000098228455,"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.9997000098228455,"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/T10260","display_name":"Software Engineering Research","score":0.9947999715805054,"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/T11424","display_name":"Security and Verification in Computing","score":0.9922000169754028,"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/debugging","display_name":"Debugging","score":0.8131144046783447},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8128581643104553},{"id":"https://openalex.org/keywords/debugger","display_name":"Debugger","score":0.763622522354126},{"id":"https://openalex.org/keywords/type-inference","display_name":"Type inference","score":0.7180898189544678},{"id":"https://openalex.org/keywords/type","display_name":"Type (biology)","score":0.6566053628921509},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.6281323432922363},{"id":"https://openalex.org/keywords/subroutine","display_name":"Subroutine","score":0.4687502682209015},{"id":"https://openalex.org/keywords/type-theory","display_name":"Type theory","score":0.4355373978614807},{"id":"https://openalex.org/keywords/data-type","display_name":"Data type","score":0.4334682822227478},{"id":"https://openalex.org/keywords/state","display_name":"State (computer science)","score":0.4260830283164978},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.4006669223308563},{"id":"https://openalex.org/keywords/artificial-intelligence","display_name":"Artificial intelligence","score":0.17595642805099487},{"id":"https://openalex.org/keywords/inference","display_name":"Inference","score":0.09699994325637817}],"concepts":[{"id":"https://openalex.org/C168065819","wikidata":"https://www.wikidata.org/wiki/Q845566","display_name":"Debugging","level":2,"score":0.8131144046783447},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8128581643104553},{"id":"https://openalex.org/C2778485113","wikidata":"https://www.wikidata.org/wiki/Q193231","display_name":"Debugger","level":3,"score":0.763622522354126},{"id":"https://openalex.org/C198370458","wikidata":"https://www.wikidata.org/wiki/Q586459","display_name":"Type inference","level":3,"score":0.7180898189544678},{"id":"https://openalex.org/C2777299769","wikidata":"https://www.wikidata.org/wiki/Q3707858","display_name":"Type (biology)","level":2,"score":0.6566053628921509},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.6281323432922363},{"id":"https://openalex.org/C96147967","wikidata":"https://www.wikidata.org/wiki/Q190686","display_name":"Subroutine","level":2,"score":0.4687502682209015},{"id":"https://openalex.org/C93682546","wikidata":"https://www.wikidata.org/wiki/Q1056428","display_name":"Type theory","level":3,"score":0.4355373978614807},{"id":"https://openalex.org/C138958017","wikidata":"https://www.wikidata.org/wiki/Q190087","display_name":"Data type","level":2,"score":0.4334682822227478},{"id":"https://openalex.org/C48103436","wikidata":"https://www.wikidata.org/wiki/Q599031","display_name":"State (computer science)","level":2,"score":0.4260830283164978},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.4006669223308563},{"id":"https://openalex.org/C154945302","wikidata":"https://www.wikidata.org/wiki/Q11660","display_name":"Artificial intelligence","level":1,"score":0.17595642805099487},{"id":"https://openalex.org/C2776214188","wikidata":"https://www.wikidata.org/wiki/Q408386","display_name":"Inference","level":2,"score":0.09699994325637817},{"id":"https://openalex.org/C86803240","wikidata":"https://www.wikidata.org/wiki/Q420","display_name":"Biology","level":0,"score":0.0},{"id":"https://openalex.org/C18903297","wikidata":"https://www.wikidata.org/wiki/Q7150","display_name":"Ecology","level":1,"score":0.0}],"mesh":[],"locations_count":2,"locations":[{"id":"doi:10.1145/3412932.3412939","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3412932.3412939","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 31st Symposium on Implementation and Application of Functional Languages","raw_type":"proceedings-article"},{"id":"pmh:oai:kar.kent.ac.uk:81976","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3412932.3412939>)","pdf_url":null,"source":{"id":"https://openalex.org/S4377196264","display_name":"Kent Academic Repository (University of Kent)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I20581793","host_organization_name":"University of Kent","host_organization_lineage":["https://openalex.org/I20581793"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"acceptedVersion","is_accepted":true,"is_published":false,"raw_source_name":null,"raw_type":"PeerReviewed"}],"best_oa_location":null,"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"pdf":false,"grobid_xml":false},"content_urls":null,"referenced_works_count":23,"referenced_works":["https://openalex.org/W33252908","https://openalex.org/W1434978938","https://openalex.org/W1534993236","https://openalex.org/W2068336423","https://openalex.org/W2086055875","https://openalex.org/W2087272670","https://openalex.org/W2098374496","https://openalex.org/W2134093956","https://openalex.org/W2168280960","https://openalex.org/W2926633993","https://openalex.org/W6601315810","https://openalex.org/W6603113247","https://openalex.org/W6628218556","https://openalex.org/W6632181881","https://openalex.org/W6635159564","https://openalex.org/W6649667503","https://openalex.org/W6653268252","https://openalex.org/W6661734376","https://openalex.org/W6679785980","https://openalex.org/W6683928090","https://openalex.org/W6684845498","https://openalex.org/W6685397617","https://openalex.org/W6760512695"],"related_works":["https://openalex.org/W3130884665","https://openalex.org/W2112150205","https://openalex.org/W4384648301","https://openalex.org/W2949482260","https://openalex.org/W1550049051","https://openalex.org/W1557199137","https://openalex.org/W4287025197","https://openalex.org/W2076653850","https://openalex.org/W4296000674","https://openalex.org/W3110513392"],"abstract_inverted_index":{"The":[0,106],"cause":[1],"of":[2,108,131],"a":[3,33,50,64,91,99],"type":[4,15,39,65,88,116,119,126,133],"error":[5,40],"can":[6],"be":[7],"very":[8],"difficult":[9],"to":[10,56,62],"find":[11],"for":[12],"the":[13,57,129,132],"Hindley-Milner":[14],"system.":[16],"Consequently":[17],"many":[18],"solutions":[19],"have":[20,53],"been":[21],"proposed,":[22],"but":[23],"they":[24,59],"are":[25,69,73],"hardly":[26],"used":[27],"in":[28,49],"practice.":[29],"Here":[30],"we":[31],"propose":[32],"new":[34],"solution":[35,80],"that":[36],"provides":[37],"counter-factual":[38,115],"messages;":[41],"these":[42,109],"messages":[43,68],"state":[44],"what":[45],"types":[46,58,107,123],"specific":[47],"subexpressions":[48],"program":[51,97,101],"should":[52],"(in":[54],"contrast":[55],"actually":[60],"have)":[61],"remove":[63],"error.":[66],"Such":[67],"easy-to-understand,":[70],"because":[71,83],"programers":[72],"already":[74],"familiar":[75],"with":[76,102],"them.":[77],"Furthermore,":[78],"our":[79],"is":[81],"easy-to-implement,":[82],"it":[84],"reuses":[85],"an":[86,95],"existing":[87],"checker":[89],"as":[90,125],"subroutine.":[92],"We":[93],"transform":[94],"ill-typed":[96],"into":[98],"well-typed":[100],"additional":[103],"\u03bb-bound":[104,110],"variables.":[105],"variables":[111],"yield":[112],"actual":[113],"and":[114],"information.":[117],"That":[118],"information":[120],"plus":[121],"intended":[122],"added":[124],"annotations":[127],"direct":[128],"search":[130],"debugger.":[134]},"counts_by_year":[{"year":2023,"cited_by_count":3},{"year":2022,"cited_by_count":1}],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2025-10-10T00:00:00"}
