{"id":"https://openalex.org/W7106340604","doi":"https://doi.org/10.1016/j.scico.2025.103416","title":"Inferring non-failure conditions for declarative programs","display_name":"Inferring non-failure conditions for declarative programs","publication_year":2025,"publication_date":"2025-11-21","ids":{"openalex":"https://openalex.org/W7106340604","doi":"https://doi.org/10.1016/j.scico.2025.103416"},"language":"en","primary_location":{"id":"doi:10.1016/j.scico.2025.103416","is_oa":true,"landing_page_url":"https://doi.org/10.1016/j.scico.2025.103416","pdf_url":null,"source":{"id":"https://openalex.org/S21029587","display_name":"Science of Computer Programming","issn_l":"0167-6423","issn":["0167-6423","1872-7964"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310320990","host_organization_name":"Elsevier BV","host_organization_lineage":["https://openalex.org/P4310320990"],"host_organization_lineage_names":["Elsevier BV"],"type":"journal"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Science of Computer Programming","raw_type":"journal-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"hybrid","oa_url":"https://doi.org/10.1016/j.scico.2025.103416","any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":null,"display_name":"Michael Hanus","orcid":"https://orcid.org/0000-0002-4953-8202"},"institutions":[{"id":"https://openalex.org/I32021983","display_name":"Christian-Albrechts-Universit\u00e4t zu Kiel","ror":"https://ror.org/04v76ef78","country_code":"DE","type":"education","lineage":["https://openalex.org/I32021983"]}],"countries":["DE"],"is_corresponding":true,"raw_author_name":"Michael Hanus","raw_affiliation_strings":["Institut f\u00fcr Informatik, Kiel University, Germany"],"raw_orcid":"https://orcid.org/0000-0002-4953-8202","affiliations":[{"raw_affiliation_string":"Institut f\u00fcr Informatik, Kiel University, Germany","institution_ids":["https://openalex.org/I32021983"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":1,"corresponding_author_ids":[],"corresponding_institution_ids":["https://openalex.org/I32021983"],"apc_list":{"value":2460,"currency":"USD","value_usd":2460},"apc_paid":{"value":2460,"currency":"USD","value_usd":2460},"fwci":0.0,"has_fulltext":false,"cited_by_count":0,"citation_normalized_percentile":{"value":0.76540325,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":null,"biblio":{"volume":"250","issue":null,"first_page":"103416","last_page":"103416"},"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.4884999990463257,"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.4884999990463257,"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.19689999520778656,"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/T10772","display_name":"Distributed systems and fault tolerance","score":0.17919999361038208,"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"}}],"keywords":[{"id":"https://openalex.org/keywords/programmer","display_name":"Programmer","score":0.8414000272750854},{"id":"https://openalex.org/keywords/software","display_name":"Software","score":0.492900013923645},{"id":"https://openalex.org/keywords/declarative-programming","display_name":"Declarative programming","score":0.44119998812675476},{"id":"https://openalex.org/keywords/computation","display_name":"Computation","score":0.427700012922287},{"id":"https://openalex.org/keywords/logic-program","display_name":"Logic program","score":0.4020000100135803},{"id":"https://openalex.org/keywords/logic-programming","display_name":"Logic programming","score":0.39419999718666077},{"id":"https://openalex.org/keywords/symbolic-execution","display_name":"Symbolic execution","score":0.3797999918460846},{"id":"https://openalex.org/keywords/structured-programming","display_name":"Structured programming","score":0.3474999964237213}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.9024999737739563},{"id":"https://openalex.org/C2778514511","wikidata":"https://www.wikidata.org/wiki/Q1374194","display_name":"Programmer","level":2,"score":0.8414000272750854},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.6940000057220459},{"id":"https://openalex.org/C2777904410","wikidata":"https://www.wikidata.org/wiki/Q7397","display_name":"Software","level":2,"score":0.492900013923645},{"id":"https://openalex.org/C115903868","wikidata":"https://www.wikidata.org/wiki/Q80993","display_name":"Software engineering","level":1,"score":0.4616999924182892},{"id":"https://openalex.org/C146206909","wikidata":"https://www.wikidata.org/wiki/Q531152","display_name":"Declarative programming","level":4,"score":0.44119998812675476},{"id":"https://openalex.org/C45374587","wikidata":"https://www.wikidata.org/wiki/Q12525525","display_name":"Computation","level":2,"score":0.427700012922287},{"id":"https://openalex.org/C2987117450","wikidata":"https://www.wikidata.org/wiki/Q275603","display_name":"Logic program","level":3,"score":0.4020000100135803},{"id":"https://openalex.org/C128838566","wikidata":"https://www.wikidata.org/wiki/Q275603","display_name":"Logic programming","level":2,"score":0.39419999718666077},{"id":"https://openalex.org/C2779639559","wikidata":"https://www.wikidata.org/wiki/Q7661178","display_name":"Symbolic execution","level":3,"score":0.3797999918460846},{"id":"https://openalex.org/C77781355","wikidata":"https://www.wikidata.org/wiki/Q223335","display_name":"Structured programming","level":2,"score":0.3474999964237213},{"id":"https://openalex.org/C98183937","wikidata":"https://www.wikidata.org/wiki/Q2112188","display_name":"Program analysis","level":2,"score":0.34540000557899475},{"id":"https://openalex.org/C97686452","wikidata":"https://www.wikidata.org/wiki/Q7604153","display_name":"Static analysis","level":2,"score":0.32670000195503235},{"id":"https://openalex.org/C34165917","wikidata":"https://www.wikidata.org/wiki/Q188267","display_name":"Programming paradigm","level":2,"score":0.3190000057220459},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.3059999942779541},{"id":"https://openalex.org/C128099668","wikidata":"https://www.wikidata.org/wiki/Q573952","display_name":"Lazy evaluation","level":3,"score":0.28519999980926514},{"id":"https://openalex.org/C529173508","wikidata":"https://www.wikidata.org/wiki/Q638608","display_name":"Software development","level":3,"score":0.2802000045776367},{"id":"https://openalex.org/C2776889888","wikidata":"https://www.wikidata.org/wiki/Q1135789","display_name":"Unintended consequences","level":2,"score":0.2800999879837036},{"id":"https://openalex.org/C136979486","wikidata":"https://www.wikidata.org/wiki/Q773483","display_name":"Existential quantification","level":2,"score":0.2605000138282776},{"id":"https://openalex.org/C145428669","wikidata":"https://www.wikidata.org/wiki/Q471748","display_name":"Exception handling","level":2,"score":0.25270000100135803}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1016/j.scico.2025.103416","is_oa":true,"landing_page_url":"https://doi.org/10.1016/j.scico.2025.103416","pdf_url":null,"source":{"id":"https://openalex.org/S21029587","display_name":"Science of Computer Programming","issn_l":"0167-6423","issn":["0167-6423","1872-7964"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310320990","host_organization_name":"Elsevier BV","host_organization_lineage":["https://openalex.org/P4310320990"],"host_organization_lineage_names":["Elsevier BV"],"type":"journal"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Science of Computer Programming","raw_type":"journal-article"}],"best_oa_location":{"id":"doi:10.1016/j.scico.2025.103416","is_oa":true,"landing_page_url":"https://doi.org/10.1016/j.scico.2025.103416","pdf_url":null,"source":{"id":"https://openalex.org/S21029587","display_name":"Science of Computer Programming","issn_l":"0167-6423","issn":["0167-6423","1872-7964"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310320990","host_organization_name":"Elsevier BV","host_organization_lineage":["https://openalex.org/P4310320990"],"host_organization_lineage_names":["Elsevier BV"],"type":"journal"},"license":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Science of Computer Programming","raw_type":"journal-article"},"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"grobid_xml":false,"pdf":false},"content_urls":null,"referenced_works_count":11,"referenced_works":["https://openalex.org/W1963910234","https://openalex.org/W1980781982","https://openalex.org/W1992085465","https://openalex.org/W2063521547","https://openalex.org/W2116940213","https://openalex.org/W2127844749","https://openalex.org/W2145108549","https://openalex.org/W2166822586","https://openalex.org/W2608848276","https://openalex.org/W2755502551","https://openalex.org/W4283815499"],"related_works":[],"abstract_inverted_index":{"Unintended":[0],"failures":[1,90],"during":[2,9],"a":[3,34],"computation":[4],"are":[5,41,70,136],"painful":[6],"but":[7],"frequent":[8],"software":[10,51],"development.":[11],"Failures":[12],"due":[13,45],"to":[14,46,59,103,122],"external":[15],"reasons":[16],"(e.g.,":[17],"missing":[18],"files,":[19],"no":[20],"permissions,":[21],"etc.)":[22],"can":[23,119],"be":[24,120],"caught":[25,44],"by":[26],"exception":[27],"handlers.":[28],"Programming":[29],"failures,":[30],"such":[31,61,89],"as":[32],"calling":[33],"partially":[35,79],"defined":[36,80],"operation":[37],"with":[38],"unintended":[39],"arguments,":[40],"often":[42],"not":[43],"the":[47,50,83,86,94,97,101,110],"assumption":[48],"that":[49],"is":[52,91,115],"correct.":[53],"This":[54],"paper":[55],"presents":[56],"an":[57,129],"approach":[58],"verify":[60],"assumptions.":[62],"For":[63],"this":[64],"purpose,":[65],"non-failure":[66],"conditions":[67],"for":[68,131],"operations":[69],"inferred":[71],"and":[72,108,118],"then":[73],"checked":[74],"in":[75],"all":[76],"uses":[77],"of":[78,88,128],"operations.":[81],"In":[82,93],"positive":[84],"case,":[85,96],"absence":[87],"ensured.":[92],"negative":[95],"programmer":[98],"could":[99],"adapt":[100],"program":[102,111],"handle":[104],"possibly":[105],"failing":[106],"situations":[107],"check":[109],"again.":[112],"Our":[113],"method":[114],"fully":[116],"automatic":[117],"applied":[121],"larger":[123],"declarative":[124],"programs.":[125],"The":[126],"results":[127],"implementation":[130],"functional":[132],"logic":[133],"Curry":[134],"programs":[135],"presented.":[137]},"counts_by_year":[],"updated_date":"2026-02-22T13:39:03.778224","created_date":"2025-11-23T00:00:00"}
