{"id":"https://openalex.org/W2287408962","doi":"https://doi.org/10.1017/s1471068415000204","title":"Horn clauses as an intermediate representation for program analysis and transformation","display_name":"Horn clauses as an intermediate representation for program analysis and transformation","publication_year":2015,"publication_date":"2015-07-01","ids":{"openalex":"https://openalex.org/W2287408962","doi":"https://doi.org/10.1017/s1471068415000204","mag":"2287408962"},"language":"en","primary_location":{"id":"doi:10.1017/s1471068415000204","is_oa":true,"landing_page_url":"https://doi.org/10.1017/s1471068415000204","pdf_url":"https://www.cambridge.org/core/services/aop-cambridge-core/content/view/1AC5860B4094AAD0EA1213FB85853DFA/S1471068415000204a.pdf/div-class-title-horn-clauses-as-an-intermediate-representation-for-program-analysis-and-transformation-a-href-fn01-ref-type-fn-a-div.pdf","source":{"id":"https://openalex.org/S59670734","display_name":"Theory and Practice of Logic Programming","issn_l":"1471-0684","issn":["1471-0684","1475-3081"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310311721","host_organization_name":"Cambridge University Press","host_organization_lineage":["https://openalex.org/P4310311721","https://openalex.org/P4310311702"],"host_organization_lineage_names":["Cambridge University Press","University of Cambridge"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Theory and Practice of Logic Programming","raw_type":"journal-article"},"type":"article","indexed_in":["arxiv","crossref"],"open_access":{"is_oa":true,"oa_status":"bronze","oa_url":"https://www.cambridge.org/core/services/aop-cambridge-core/content/view/1AC5860B4094AAD0EA1213FB85853DFA/S1471068415000204a.pdf/div-class-title-horn-clauses-as-an-intermediate-representation-for-program-analysis-and-transformation-a-href-fn01-ref-type-fn-a-div.pdf","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":null,"display_name":"GRAEME GANGE","orcid":null},"institutions":[{"id":"https://openalex.org/I165779595","display_name":"University of Melbourne","ror":"https://ror.org/01ej9dk98","country_code":"AU","type":"education","lineage":["https://openalex.org/I165779595"]}],"countries":["AU"],"is_corresponding":true,"raw_author_name":"GRAEME GANGE","raw_affiliation_strings":["Department of Computing and Information Systems, The University of Melbourne, Victoria 3010, Australia (e-mail:"],"affiliations":[{"raw_affiliation_string":"Department of Computing and Information Systems, The University of Melbourne, Victoria 3010, Australia (e-mail:","institution_ids":["https://openalex.org/I165779595"]}]},{"author_position":"middle","author":{"id":null,"display_name":"JORGE A. NAVAS","orcid":null},"institutions":[{"id":"https://openalex.org/I1280536761","display_name":"Ames Research Center","ror":"https://ror.org/02acart68","country_code":"US","type":"facility","lineage":["https://openalex.org/I1280536761","https://openalex.org/I4210124779"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"JORGE A. NAVAS","raw_affiliation_strings":["NASA Ames Research Center, Moffet Field CA, (e-mail:"],"affiliations":[{"raw_affiliation_string":"NASA Ames Research Center, Moffet Field CA, (e-mail:","institution_ids":["https://openalex.org/I1280536761"]}]},{"author_position":"middle","author":{"id":null,"display_name":"PETER SCHACHTE","orcid":null},"institutions":[{"id":"https://openalex.org/I165779595","display_name":"University of Melbourne","ror":"https://ror.org/01ej9dk98","country_code":"AU","type":"education","lineage":["https://openalex.org/I165779595"]}],"countries":["AU"],"is_corresponding":false,"raw_author_name":"PETER SCHACHTE","raw_affiliation_strings":["Department of Computing and Information Systems, The University of Melbourne, Victoria 3010, Australia (e-mail:"],"affiliations":[{"raw_affiliation_string":"Department of Computing and Information Systems, The University of Melbourne, Victoria 3010, Australia (e-mail:","institution_ids":["https://openalex.org/I165779595"]}]},{"author_position":"middle","author":{"id":null,"display_name":"HARALD S\u00d8NDERGAARD","orcid":null},"institutions":[{"id":"https://openalex.org/I165779595","display_name":"University of Melbourne","ror":"https://ror.org/01ej9dk98","country_code":"AU","type":"education","lineage":["https://openalex.org/I165779595"]}],"countries":["AU"],"is_corresponding":false,"raw_author_name":"HARALD S\u00d8NDERGAARD","raw_affiliation_strings":["Department of Computing and Information Systems, The University of Melbourne, Victoria 3010, Australia (e-mail:"],"affiliations":[{"raw_affiliation_string":"Department of Computing and Information Systems, The University of Melbourne, Victoria 3010, Australia (e-mail:","institution_ids":["https://openalex.org/I165779595"]}]},{"author_position":"last","author":{"id":null,"display_name":"PETER J. STUCKEY","orcid":null},"institutions":[{"id":"https://openalex.org/I165779595","display_name":"University of Melbourne","ror":"https://ror.org/01ej9dk98","country_code":"AU","type":"education","lineage":["https://openalex.org/I165779595"]}],"countries":["AU"],"is_corresponding":false,"raw_author_name":"PETER J. STUCKEY","raw_affiliation_strings":["Department of Computing and Information Systems, The University of Melbourne, Victoria 3010, Australia (e-mail:"],"affiliations":[{"raw_affiliation_string":"Department of Computing and Information Systems, The University of Melbourne, Victoria 3010, Australia (e-mail:","institution_ids":["https://openalex.org/I165779595"]}]}],"institutions":[],"countries_distinct_count":2,"institutions_distinct_count":5,"corresponding_author_ids":[],"corresponding_institution_ids":["https://openalex.org/I165779595"],"apc_list":null,"apc_paid":null,"fwci":3.1157,"has_fulltext":true,"cited_by_count":19,"citation_normalized_percentile":{"value":0.93101692,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":89,"max":98},"biblio":{"volume":"15","issue":"4-5","first_page":"526","last_page":"542"},"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.8568999767303467,"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.8568999767303467,"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/T11010","display_name":"Logic, Reasoning, and Knowledge","score":0.05779999867081642,"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.028699999675154686,"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"}}],"keywords":[{"id":"https://openalex.org/keywords/horn-clause","display_name":"Horn clause","score":0.8248999714851379},{"id":"https://openalex.org/keywords/program-analysis","display_name":"Program analysis","score":0.710099995136261},{"id":"https://openalex.org/keywords/simple","display_name":"Simple (philosophy)","score":0.6572999954223633},{"id":"https://openalex.org/keywords/representation","display_name":"Representation (politics)","score":0.6414999961853027},{"id":"https://openalex.org/keywords/program-transformation","display_name":"Program transformation","score":0.6407999992370605},{"id":"https://openalex.org/keywords/semantics","display_name":"Semantics (computer science)","score":0.570900022983551},{"id":"https://openalex.org/keywords/logic-program","display_name":"Logic program","score":0.5616000294685364},{"id":"https://openalex.org/keywords/transformation","display_name":"Transformation (genetics)","score":0.4713999927043915},{"id":"https://openalex.org/keywords/logic-programming","display_name":"Logic programming","score":0.45579999685287476}],"concepts":[{"id":"https://openalex.org/C189790780","wikidata":"https://www.wikidata.org/wiki/Q933932","display_name":"Horn clause","level":3,"score":0.8248999714851379},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8219000101089478},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.7300999760627747},{"id":"https://openalex.org/C98183937","wikidata":"https://www.wikidata.org/wiki/Q2112188","display_name":"Program analysis","level":2,"score":0.710099995136261},{"id":"https://openalex.org/C2780586882","wikidata":"https://www.wikidata.org/wiki/Q7520643","display_name":"Simple (philosophy)","level":2,"score":0.6572999954223633},{"id":"https://openalex.org/C2776359362","wikidata":"https://www.wikidata.org/wiki/Q2145286","display_name":"Representation (politics)","level":3,"score":0.6414999961853027},{"id":"https://openalex.org/C2778361913","wikidata":"https://www.wikidata.org/wiki/Q7248437","display_name":"Program transformation","level":2,"score":0.6407999992370605},{"id":"https://openalex.org/C184337299","wikidata":"https://www.wikidata.org/wiki/Q1437428","display_name":"Semantics (computer science)","level":2,"score":0.570900022983551},{"id":"https://openalex.org/C2987117450","wikidata":"https://www.wikidata.org/wiki/Q275603","display_name":"Logic program","level":3,"score":0.5616000294685364},{"id":"https://openalex.org/C204241405","wikidata":"https://www.wikidata.org/wiki/Q461499","display_name":"Transformation (genetics)","level":3,"score":0.4713999927043915},{"id":"https://openalex.org/C128838566","wikidata":"https://www.wikidata.org/wiki/Q275603","display_name":"Logic programming","level":2,"score":0.45579999685287476},{"id":"https://openalex.org/C192183473","wikidata":"https://www.wikidata.org/wiki/Q131133","display_name":"Determinism","level":2,"score":0.4503999948501587},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.44190001487731934},{"id":"https://openalex.org/C77660490","wikidata":"https://www.wikidata.org/wiki/Q244916","display_name":"Intermediate language","level":3,"score":0.4221000075340271},{"id":"https://openalex.org/C102993220","wikidata":"https://www.wikidata.org/wiki/Q387196","display_name":"Description logic","level":2,"score":0.3808000087738037},{"id":"https://openalex.org/C97686452","wikidata":"https://www.wikidata.org/wiki/Q7604153","display_name":"Static analysis","level":2,"score":0.3781000077724457},{"id":"https://openalex.org/C11413529","wikidata":"https://www.wikidata.org/wiki/Q8366","display_name":"Algorithm","level":1,"score":0.3517000079154968},{"id":"https://openalex.org/C81721847","wikidata":"https://www.wikidata.org/wiki/Q163468","display_name":"Prolog","level":2,"score":0.3499999940395355},{"id":"https://openalex.org/C2780654840","wikidata":"https://www.wikidata.org/wiki/Q333341","display_name":"Abstract interpretation","level":2,"score":0.34689998626708984},{"id":"https://openalex.org/C161301231","wikidata":"https://www.wikidata.org/wiki/Q3478658","display_name":"Knowledge representation and reasoning","level":2,"score":0.32170000672340393},{"id":"https://openalex.org/C156325763","wikidata":"https://www.wikidata.org/wiki/Q1930895","display_name":"Operational semantics","level":3,"score":0.3176000118255615},{"id":"https://openalex.org/C15077461","wikidata":"https://www.wikidata.org/wiki/Q7248507","display_name":"Programming language specification","level":5,"score":0.2924000024795532},{"id":"https://openalex.org/C19024347","wikidata":"https://www.wikidata.org/wiki/Q211496","display_name":"High-level programming language","level":3,"score":0.27219998836517334},{"id":"https://openalex.org/C185954173","wikidata":"https://www.wikidata.org/wiki/Q4347052","display_name":"Object language","level":3,"score":0.2648000121116638},{"id":"https://openalex.org/C195701839","wikidata":"https://www.wikidata.org/wiki/Q4008398","display_name":"Partial evaluation","level":2,"score":0.26440000534057617},{"id":"https://openalex.org/C2780589192","wikidata":"https://www.wikidata.org/wiki/Q7285140","display_name":"Raising (metalworking)","level":2,"score":0.26190000772476196},{"id":"https://openalex.org/C206674616","wikidata":"https://www.wikidata.org/wiki/Q7038222","display_name":"Program Design Language","level":2,"score":0.25369998812675476}],"mesh":[],"locations_count":3,"locations":[{"id":"doi:10.1017/s1471068415000204","is_oa":true,"landing_page_url":"https://doi.org/10.1017/s1471068415000204","pdf_url":"https://www.cambridge.org/core/services/aop-cambridge-core/content/view/1AC5860B4094AAD0EA1213FB85853DFA/S1471068415000204a.pdf/div-class-title-horn-clauses-as-an-intermediate-representation-for-program-analysis-and-transformation-a-href-fn01-ref-type-fn-a-div.pdf","source":{"id":"https://openalex.org/S59670734","display_name":"Theory and Practice of Logic Programming","issn_l":"1471-0684","issn":["1471-0684","1475-3081"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310311721","host_organization_name":"Cambridge University Press","host_organization_lineage":["https://openalex.org/P4310311721","https://openalex.org/P4310311702"],"host_organization_lineage_names":["Cambridge University Press","University of Cambridge"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Theory and Practice of Logic Programming","raw_type":"journal-article"},{"id":"pmh:oai:arXiv.org:1507.05762","is_oa":true,"landing_page_url":"http://arxiv.org/abs/1507.05762","pdf_url":"https://arxiv.org/pdf/1507.05762","source":{"id":"https://openalex.org/S4306400194","display_name":"arXiv (Cornell University)","issn_l":null,"issn":null,"is_oa":true,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I205783295","host_organization_name":"Cornell University","host_organization_lineage":["https://openalex.org/I205783295"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":null,"raw_type":"text"},{"id":"pmh:oai:jupiter.its.unimelb.edu.au:11343/55735","is_oa":false,"landing_page_url":"http://hdl.handle.net/11343/55735","pdf_url":null,"source":{"id":"https://openalex.org/S4377196259","display_name":"Minerva Access (University of Melbourne)","issn_l":null,"issn":null,"is_oa":false,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I165779595","host_organization_name":"The University of Melbourne","host_organization_lineage":["https://openalex.org/I165779595"],"host_organization_lineage_names":[],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false,"raw_source_name":"","raw_type":"Journal Article"}],"best_oa_location":{"id":"doi:10.1017/s1471068415000204","is_oa":true,"landing_page_url":"https://doi.org/10.1017/s1471068415000204","pdf_url":"https://www.cambridge.org/core/services/aop-cambridge-core/content/view/1AC5860B4094AAD0EA1213FB85853DFA/S1471068415000204a.pdf/div-class-title-horn-clauses-as-an-intermediate-representation-for-program-analysis-and-transformation-a-href-fn01-ref-type-fn-a-div.pdf","source":{"id":"https://openalex.org/S59670734","display_name":"Theory and Practice of Logic Programming","issn_l":"1471-0684","issn":["1471-0684","1475-3081"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310311721","host_organization_name":"Cambridge University Press","host_organization_lineage":["https://openalex.org/P4310311721","https://openalex.org/P4310311702"],"host_organization_lineage_names":["Cambridge University Press","University of Cambridge"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Theory and Practice of Logic Programming","raw_type":"journal-article"},"sustainable_development_goals":[],"awards":[{"id":"https://openalex.org/G2844943510","display_name":null,"funder_award_id":"DP140102194","funder_id":"https://openalex.org/F4320334704","funder_display_name":"Australian Research Council"}],"funders":[{"id":"https://openalex.org/F4320334704","display_name":"Australian Research Council","ror":"https://ror.org/05mmh0f86"}],"has_content":{"grobid_xml":true,"pdf":true},"content_urls":{"pdf":"https://content.openalex.org/works/W2287408962.pdf","grobid_xml":"https://content.openalex.org/works/W2287408962.grobid-xml"},"referenced_works_count":25,"referenced_works":["https://openalex.org/W36793001","https://openalex.org/W52244296","https://openalex.org/W190459065","https://openalex.org/W1499526127","https://openalex.org/W1569188499","https://openalex.org/W1671718115","https://openalex.org/W1727650458","https://openalex.org/W1854012871","https://openalex.org/W1982205631","https://openalex.org/W1982243747","https://openalex.org/W1990087033","https://openalex.org/W1996245589","https://openalex.org/W1996543446","https://openalex.org/W2078314687","https://openalex.org/W2094712524","https://openalex.org/W2101430044","https://openalex.org/W2101811680","https://openalex.org/W2122599614","https://openalex.org/W2129086731","https://openalex.org/W2149127686","https://openalex.org/W2154087241","https://openalex.org/W2158493209","https://openalex.org/W2280666326","https://openalex.org/W3158747708","https://openalex.org/W4246798589"],"related_works":[],"abstract_inverted_index":{"Abstract":[0],"Many":[1],"recent":[2],"analyses":[3,19],"for":[4,70,95],"conventional":[5],"imperative":[6],"programs":[7,11,28],"begin":[8],"by":[9],"transforming":[10],"into":[12],"logic":[13,27,45],"programs,":[14],"capitalising":[15],"on":[16],"existing":[17],"LP":[18,22,79],"and":[20,42,73,84,86,97],"simple":[21,61,78],"semantics.":[23],"We":[24,75],"propose":[25],"using":[26],"as":[29,67],"an":[30],"intermediate":[31],"program":[32,46,71,93],"representation":[33,94],"throughout":[34],"the":[35,60],"compilation":[36],"process.":[37],"With":[38],"restrictions":[39],"ensuring":[40],"determinism":[41,83],"single-modedness,":[43,85],"a":[44,68,77,91],"can":[47],"easily":[48],"be":[49],"transformed":[50],"to":[51],"machine":[52],"language":[53,69,80],"or":[54],"other":[55],"low-level":[56],"language,":[57],"while":[58],"maintaining":[59],"semantics":[62],"that":[63,81,88],"makes":[64,90],"it":[65,89],"suitable":[66],"analysis":[72,96],"transformation.":[74,98],"present":[76],"enforces":[82],"show":[87],"convenient":[92]},"counts_by_year":[{"year":2025,"cited_by_count":1},{"year":2024,"cited_by_count":2},{"year":2023,"cited_by_count":1},{"year":2022,"cited_by_count":1},{"year":2021,"cited_by_count":1},{"year":2020,"cited_by_count":5},{"year":2019,"cited_by_count":1},{"year":2018,"cited_by_count":2},{"year":2017,"cited_by_count":3},{"year":2016,"cited_by_count":2}],"updated_date":"2026-04-10T15:06:20.359241","created_date":"2016-06-24T00:00:00"}
