{"id":"https://openalex.org/W2029074074","doi":"https://doi.org/10.1145/1596638.1596654","title":"Finding the needle","display_name":"Finding the needle","publication_year":2009,"publication_date":"2009-09-03","ids":{"openalex":"https://openalex.org/W2029074074","doi":"https://doi.org/10.1145/1596638.1596654","mag":"2029074074"},"language":"en","primary_location":{"id":"doi:10.1145/1596638.1596654","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1596638.1596654","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 symposium on Haskell","raw_type":"proceedings-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"green","oa_url":"http://hdl.handle.net/10044/1/5764","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5012006988","display_name":"Tristan O.R. Allwood","orcid":null},"institutions":[{"id":"https://openalex.org/I47508984","display_name":"Imperial College London","ror":"https://ror.org/041kmwe10","country_code":"GB","type":"education","lineage":["https://openalex.org/I47508984"]}],"countries":["GB"],"is_corresponding":true,"raw_author_name":"Tristan O.R. Allwood","raw_affiliation_strings":["Imperial College, London, United Kingdom"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Imperial College, London, United Kingdom","institution_ids":["https://openalex.org/I47508984"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5027817074","display_name":"Simon Peyton Jones","orcid":"https://orcid.org/0000-0002-6085-1435"},"institutions":[{"id":"https://openalex.org/I1290206253","display_name":"Microsoft (United States)","ror":"https://ror.org/00d0nc645","country_code":"US","type":"company","lineage":["https://openalex.org/I1290206253"]},{"id":"https://openalex.org/I4210164937","display_name":"Microsoft Research (United Kingdom)","ror":"https://ror.org/05k87vq12","country_code":"GB","type":"company","lineage":["https://openalex.org/I1290206253","https://openalex.org/I4210164937"]}],"countries":["GB","US"],"is_corresponding":false,"raw_author_name":"Simon Peyton Jones","raw_affiliation_strings":["Microsoft Research, Cambridge, United Kingdom","Microsoft Research, Cambridge, United Kingdom ("],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Microsoft Research, Cambridge, United Kingdom","institution_ids":["https://openalex.org/I4210164937"]},{"raw_affiliation_string":"Microsoft Research, Cambridge, United Kingdom (","institution_ids":["https://openalex.org/I1290206253"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5060800643","display_name":"Susan Eisenbach","orcid":"https://orcid.org/0000-0001-9072-6689"},"institutions":[{"id":"https://openalex.org/I47508984","display_name":"Imperial College London","ror":"https://ror.org/041kmwe10","country_code":"GB","type":"education","lineage":["https://openalex.org/I47508984"]}],"countries":["GB"],"is_corresponding":false,"raw_author_name":"Susan Eisenbach","raw_affiliation_strings":["Imperial College, London, United Kingdom"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Imperial College, London, United Kingdom","institution_ids":["https://openalex.org/I47508984"]}]}],"institutions":[],"countries_distinct_count":2,"institutions_distinct_count":3,"corresponding_author_ids":["https://openalex.org/A5012006988"],"corresponding_institution_ids":["https://openalex.org/I47508984"],"apc_list":null,"apc_paid":null,"fwci":3.3175,"has_fulltext":true,"cited_by_count":14,"citation_normalized_percentile":{"value":0.91655186,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":89,"max":98},"biblio":{"volume":null,"issue":null,"first_page":"129","last_page":"140"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10743","display_name":"Software Testing and Debugging Techniques","score":0.9966999888420105,"subfield":{"id":"https://openalex.org/subfields/1712","display_name":"Software"},"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/T10743","display_name":"Software Testing and Debugging Techniques","score":0.9966999888420105,"subfield":{"id":"https://openalex.org/subfields/1712","display_name":"Software"},"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.9950000047683716,"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.9950000047683716,"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/haskell","display_name":"Haskell","score":0.9455209970474243},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8423640727996826},{"id":"https://openalex.org/keywords/heap","display_name":"Heap (data structure)","score":0.8127435445785522},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.6650314331054688},{"id":"https://openalex.org/keywords/program-transformation","display_name":"Program transformation","score":0.5533589124679565},{"id":"https://openalex.org/keywords/call-stack","display_name":"Call stack","score":0.5329234600067139},{"id":"https://openalex.org/keywords/extension","display_name":"Extension (predicate logic)","score":0.5153071880340576},{"id":"https://openalex.org/keywords/functional-programming","display_name":"Functional programming","score":0.5033203959465027},{"id":"https://openalex.org/keywords/stack","display_name":"Stack (abstract data type)","score":0.48206406831741333},{"id":"https://openalex.org/keywords/bounded-function","display_name":"Bounded function","score":0.42249464988708496},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.3336198329925537},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.09323981404304504}],"concepts":[{"id":"https://openalex.org/C2780624054","wikidata":"https://www.wikidata.org/wiki/Q34010","display_name":"Haskell","level":3,"score":0.9455209970474243},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8423640727996826},{"id":"https://openalex.org/C134757568","wikidata":"https://www.wikidata.org/wiki/Q274089","display_name":"Heap (data structure)","level":2,"score":0.8127435445785522},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.6650314331054688},{"id":"https://openalex.org/C2778361913","wikidata":"https://www.wikidata.org/wiki/Q7248437","display_name":"Program transformation","level":2,"score":0.5533589124679565},{"id":"https://openalex.org/C119024030","wikidata":"https://www.wikidata.org/wiki/Q759899","display_name":"Call stack","level":3,"score":0.5329234600067139},{"id":"https://openalex.org/C2778029271","wikidata":"https://www.wikidata.org/wiki/Q5421931","display_name":"Extension (predicate logic)","level":2,"score":0.5153071880340576},{"id":"https://openalex.org/C42383842","wikidata":"https://www.wikidata.org/wiki/Q193076","display_name":"Functional programming","level":2,"score":0.5033203959465027},{"id":"https://openalex.org/C9395851","wikidata":"https://www.wikidata.org/wiki/Q177929","display_name":"Stack (abstract data type)","level":2,"score":0.48206406831741333},{"id":"https://openalex.org/C34388435","wikidata":"https://www.wikidata.org/wiki/Q2267362","display_name":"Bounded function","level":2,"score":0.42249464988708496},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.3336198329925537},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.09323981404304504},{"id":"https://openalex.org/C134306372","wikidata":"https://www.wikidata.org/wiki/Q7754","display_name":"Mathematical analysis","level":1,"score":0.0}],"mesh":[],"locations_count":2,"locations":[{"id":"doi:10.1145/1596638.1596654","is_oa":false,"landing_page_url":"https://doi.org/10.1145/1596638.1596654","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 symposium on Haskell","raw_type":"proceedings-article"},{"id":"pmh:oai:spiral.imperial.ac.uk:10044/1/5764","is_oa":true,"landing_page_url":"http://hdl.handle.net/10044/1/5764","pdf_url":"http://hdl.handle.net/10044/1/5764","source":{"id":"https://openalex.org/S4306401396","display_name":"Spiral (Imperial College London)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I47508984","host_organization_name":"Imperial College London","host_organization_lineage":["https://openalex.org/I47508984"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"2nd ACM SIGPLAN symposium on Haskell","raw_type":"Conference Paper"}],"best_oa_location":{"id":"pmh:oai:spiral.imperial.ac.uk:10044/1/5764","is_oa":true,"landing_page_url":"http://hdl.handle.net/10044/1/5764","pdf_url":"http://hdl.handle.net/10044/1/5764","source":{"id":"https://openalex.org/S4306401396","display_name":"Spiral (Imperial College London)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I47508984","host_organization_name":"Imperial College London","host_organization_lineage":["https://openalex.org/I47508984"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"2nd ACM SIGPLAN symposium on Haskell","raw_type":"Conference Paper"},"sustainable_development_goals":[],"awards":[],"funders":[{"id":"https://openalex.org/F4320308943","display_name":"Microsoft Research","ror":"https://ror.org/00d0nc645"},{"id":"https://openalex.org/F4320334627","display_name":"Engineering and Physical Sciences Research Council","ror":"https://ror.org/0439y7842"}],"has_content":{"grobid_xml":true,"pdf":true},"content_urls":{"pdf":"https://content.openalex.org/works/W2029074074.pdf","grobid_xml":"https://content.openalex.org/works/W2029074074.grobid-xml"},"referenced_works_count":9,"referenced_works":["https://openalex.org/W1483817851","https://openalex.org/W1986497413","https://openalex.org/W2074789981","https://openalex.org/W2092408876","https://openalex.org/W2116827712","https://openalex.org/W2125690388","https://openalex.org/W2550953148","https://openalex.org/W6629054655","https://openalex.org/W6677111848"],"related_works":["https://openalex.org/W2112263414","https://openalex.org/W3004782279","https://openalex.org/W1602185604","https://openalex.org/W2028779182","https://openalex.org/W4242678340","https://openalex.org/W2140654465","https://openalex.org/W2129253059","https://openalex.org/W4296274916","https://openalex.org/W1504459189","https://openalex.org/W1488646450"],"abstract_inverted_index":{"Even":[0],"Haskell":[1],"programs":[2,107],"can":[3,19,56],"occasionally":[4],"go":[5],"wrong.Programs":[6],"calling":[7],"head":[8,41,53,78],"on":[9,62],"an":[10],"empty":[11],"list,":[12],"and":[13,115],"incomplete":[14],"patterns":[15],"in":[16,43],"function":[17,42],"definitions":[18],"cause":[20],"program":[21,45],"crashes,":[22],"reporting":[23],"little":[24],"more":[25],"than":[26],"the":[27,40,64,82,90,96,125],"precise":[28],"location":[29],"where":[30],"error":[31],"was":[32,79,87],"ultimately":[33],"called.Being":[34],"told":[35],"that":[36,75,103,110,119],"one":[37],"application":[38],"of":[39,52,71,84,92,98,129],"your":[44],"went":[46,54],"wrong,":[47],"without":[48],"knowing":[49],"which":[50,86],"use":[51],"wrong":[55],"be":[57],"infuriating.We":[58],"present":[59],"our":[60,76,132],"work":[61],"adding":[63],"ability":[65],"to":[66,134],"get":[67],"stack":[68,113,117],"traces":[69],"out":[70],"GHC,":[72],"for":[73],"example":[74],"crashing":[77],"used":[80],"during":[81,89,95],"evaluation":[83,91,97],"foo,":[85],"called":[88],"bar":[93],",":[94],"main.We":[99],"provide":[100],"a":[101,112,116],"transformation":[102],"converts":[104],"GHC":[105,135],"Core":[106],"into":[108],"ones":[109],"pass":[111],"around,":[114],"library":[118],"ensures":[120],"bounded":[121],"heap":[122],"usage":[123],"despite":[124],"highly":[126],"recursive":[127],"nature":[128],"Haskell.We":[130],"call":[131],"extension":[133],"StackTrace.":[136]},"counts_by_year":[{"year":2026,"cited_by_count":1},{"year":2023,"cited_by_count":1},{"year":2021,"cited_by_count":1},{"year":2015,"cited_by_count":4},{"year":2012,"cited_by_count":1}],"updated_date":"2026-05-12T08:28:47.272897","created_date":"2016-06-24T00:00:00"}
