{"id":"https://openalex.org/W2170181173","doi":"https://doi.org/10.1145/2220365.2220366","title":"Partially Evaluating Finite-State Runtime Monitors Ahead of Time","display_name":"Partially Evaluating Finite-State Runtime Monitors Ahead of Time","publication_year":2012,"publication_date":"2012-06-01","ids":{"openalex":"https://openalex.org/W2170181173","doi":"https://doi.org/10.1145/2220365.2220366","mag":"2170181173"},"language":"en","primary_location":{"is_oa":true,"landing_page_url":"https://doi.org/10.1145/2220365.2220366","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/2220365.2220366","source":{"id":"https://openalex.org/S41449414","display_name":"ACM Transactions on Programming Languages and Systems","issn_l":"0164-0925","issn":["0164-0925","1558-4593"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319798","host_organization_name":"Association for Computing Machinery","host_organization_lineage":["https://openalex.org/P4310319798"],"host_organization_lineage_names":["Association for Computing Machinery"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true},"type":"article","type_crossref":"journal-article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"bronze","oa_url":"https://dl.acm.org/doi/pdf/10.1145/2220365.2220366","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5076678278","display_name":"Eric Bodden","orcid":"https://orcid.org/0000-0003-3470-3647"},"institutions":[{"id":"https://openalex.org/I31512782","display_name":"Technical University of Darmstadt","ror":"https://ror.org/05n911h24","country_code":"DE","type":"education","lineage":["https://openalex.org/I31512782"]}],"countries":["DE"],"is_corresponding":false,"raw_author_name":"Eric Bodden","raw_affiliation_strings":["Technische Universit\u00e4t Darmstadt"],"affiliations":[{"raw_affiliation_string":"Technische Universit\u00e4t Darmstadt","institution_ids":["https://openalex.org/I31512782"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5016375266","display_name":"Patrick Lam","orcid":"https://orcid.org/0000-0001-8278-5400"},"institutions":[{"id":"https://openalex.org/I151746483","display_name":"University of Waterloo","ror":"https://ror.org/01aff2v68","country_code":"CA","type":"education","lineage":["https://openalex.org/I151746483"]}],"countries":["CA"],"is_corresponding":false,"raw_author_name":"Patrick Lam","raw_affiliation_strings":["University of Waterloo"],"affiliations":[{"raw_affiliation_string":"University of Waterloo","institution_ids":["https://openalex.org/I151746483"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5039974849","display_name":"Laurie Hendren","orcid":"https://orcid.org/0000-0001-6755-9632"},"institutions":[{"id":"https://openalex.org/I5023651","display_name":"McGill University","ror":"https://ror.org/01pxwe438","country_code":"CA","type":"education","lineage":["https://openalex.org/I5023651"]}],"countries":["CA"],"is_corresponding":false,"raw_author_name":"Laurie Hendren","raw_affiliation_strings":["McGill University"],"affiliations":[{"raw_affiliation_string":"McGill University","institution_ids":["https://openalex.org/I5023651"]}]}],"institution_assertions":[],"countries_distinct_count":2,"institutions_distinct_count":3,"corresponding_author_ids":[],"corresponding_institution_ids":[],"apc_list":null,"apc_paid":null,"fwci":2.889,"has_fulltext":true,"fulltext_origin":"pdf","cited_by_count":19,"citation_normalized_percentile":{"value":0.930282,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":89,"max":90},"biblio":{"volume":"34","issue":"2","first_page":"1","last_page":"52"},"is_retracted":false,"is_paratext":false,"primary_topic":{"id":"https://openalex.org/T10126","display_name":"Logic, programming, and type systems","score":0.9996,"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.9996,"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/T10743","display_name":"Software Testing and Debugging Techniques","score":0.9992,"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/T11424","display_name":"Security and Verification in Computing","score":0.9984,"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/runtime-verification","display_name":"Runtime Verification","score":0.75420725},{"id":"https://openalex.org/keywords/aspectj","display_name":"AspectJ","score":0.75282407},{"id":"https://openalex.org/keywords/compile-time","display_name":"Compile time","score":0.60417634},{"id":"https://openalex.org/keywords/runtime-system","display_name":"Runtime system","score":0.5273265},{"id":"https://openalex.org/keywords/implementation","display_name":"Implementation","score":0.46841732}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.880411},{"id":"https://openalex.org/C202973057","wikidata":"https://www.wikidata.org/wiki/Q7380130","display_name":"Runtime verification","level":3,"score":0.75420725},{"id":"https://openalex.org/C2781009160","wikidata":"https://www.wikidata.org/wiki/Q735604","display_name":"AspectJ","level":4,"score":0.75282407},{"id":"https://openalex.org/C200833197","wikidata":"https://www.wikidata.org/wiki/Q333707","display_name":"Compile time","level":3,"score":0.60417634},{"id":"https://openalex.org/C48103436","wikidata":"https://www.wikidata.org/wiki/Q599031","display_name":"State (computer science)","level":2,"score":0.5621223},{"id":"https://openalex.org/C189950617","wikidata":"https://www.wikidata.org/wiki/Q937228","display_name":"Property (philosophy)","level":2,"score":0.54269195},{"id":"https://openalex.org/C548217200","wikidata":"https://www.wikidata.org/wiki/Q251","display_name":"Java","level":2,"score":0.53057045},{"id":"https://openalex.org/C2780870223","wikidata":"https://www.wikidata.org/wiki/Q1004415","display_name":"Runtime system","level":2,"score":0.5273265},{"id":"https://openalex.org/C169590947","wikidata":"https://www.wikidata.org/wiki/Q47506","display_name":"Compiler","level":2,"score":0.5147205},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.4879684},{"id":"https://openalex.org/C167822520","wikidata":"https://www.wikidata.org/wiki/Q176452","display_name":"Finite-state machine","level":2,"score":0.47744828},{"id":"https://openalex.org/C26713055","wikidata":"https://www.wikidata.org/wiki/Q245962","display_name":"Implementation","level":2,"score":0.46841732},{"id":"https://openalex.org/C177264268","wikidata":"https://www.wikidata.org/wiki/Q1514741","display_name":"Set (abstract data type)","level":2,"score":0.44342366},{"id":"https://openalex.org/C97686452","wikidata":"https://www.wikidata.org/wiki/Q7604153","display_name":"Static analysis","level":2,"score":0.44088203},{"id":"https://openalex.org/C120314980","wikidata":"https://www.wikidata.org/wiki/Q180634","display_name":"Distributed computing","level":1,"score":0.3898178},{"id":"https://openalex.org/C2777904410","wikidata":"https://www.wikidata.org/wiki/Q7397","display_name":"Software","level":2,"score":0.21430403},{"id":"https://openalex.org/C111498074","wikidata":"https://www.wikidata.org/wiki/Q173326","display_name":"Formal verification","level":2,"score":0.17857829},{"id":"https://openalex.org/C60051680","wikidata":"https://www.wikidata.org/wiki/Q30267","display_name":"Aspect-oriented programming","level":3,"score":0.16769639},{"id":"https://openalex.org/C138885662","wikidata":"https://www.wikidata.org/wiki/Q5891","display_name":"Philosophy","level":0,"score":0.0},{"id":"https://openalex.org/C111472728","wikidata":"https://www.wikidata.org/wiki/Q9471","display_name":"Epistemology","level":1,"score":0.0}],"mesh":[],"locations_count":2,"locations":[{"is_oa":true,"landing_page_url":"https://doi.org/10.1145/2220365.2220366","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/2220365.2220366","source":{"id":"https://openalex.org/S41449414","display_name":"ACM Transactions on Programming Languages and Systems","issn_l":"0164-0925","issn":["0164-0925","1558-4593"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319798","host_organization_name":"Association for Computing Machinery","host_organization_lineage":["https://openalex.org/P4310319798"],"host_organization_lineage_names":["Association for Computing Machinery"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true},{"is_oa":true,"landing_page_url":"http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.348.4501","pdf_url":"http://patricklam.ca/papers/12.toplas.tm.pdf","source":{"id":"https://openalex.org/S4306400349","display_name":"CiteSeer X (The Pennsylvania State University)","issn_l":null,"issn":null,"is_oa":true,"is_in_doaj":false,"is_core":false,"host_organization":"https://openalex.org/I130769515","host_organization_name":"Pennsylvania State University","host_organization_lineage":["https://openalex.org/I130769515"],"host_organization_lineage_names":["Pennsylvania State University"],"type":"repository"},"license":null,"license_id":null,"version":"submittedVersion","is_accepted":false,"is_published":false}],"best_oa_location":{"is_oa":true,"landing_page_url":"https://doi.org/10.1145/2220365.2220366","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/2220365.2220366","source":{"id":"https://openalex.org/S41449414","display_name":"ACM Transactions on Programming Languages and Systems","issn_l":"0164-0925","issn":["0164-0925","1558-4593"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310319798","host_organization_name":"Association for Computing Machinery","host_organization_lineage":["https://openalex.org/P4310319798"],"host_organization_lineage_names":["Association for Computing Machinery"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true},"sustainable_development_goals":[{"id":"https://metadata.un.org/sdg/16","display_name":"Peace, justice, and strong institutions","score":0.59}],"grants":[],"datasets":[],"versions":[],"referenced_works_count":47,"referenced_works":["https://openalex.org/W108479562","https://openalex.org/W1493925387","https://openalex.org/W1511982475","https://openalex.org/W1517245127","https://openalex.org/W1536098516","https://openalex.org/W1593942753","https://openalex.org/W1610570299","https://openalex.org/W1792369775","https://openalex.org/W1971327145","https://openalex.org/W1982205631","https://openalex.org/W1986453394","https://openalex.org/W1995350708","https://openalex.org/W1996804992","https://openalex.org/W2021875003","https://openalex.org/W2034691511","https://openalex.org/W2044269998","https://openalex.org/W2044590882","https://openalex.org/W2053519844","https://openalex.org/W2073620032","https://openalex.org/W2084315690","https://openalex.org/W2091712774","https://openalex.org/W2098645109","https://openalex.org/W2103714221","https://openalex.org/W2107406536","https://openalex.org/W2111141292","https://openalex.org/W2115725211","https://openalex.org/W2121613673","https://openalex.org/W2125249627","https://openalex.org/W2133497528","https://openalex.org/W2134311998","https://openalex.org/W2134429122","https://openalex.org/W2135522367","https://openalex.org/W2136033258","https://openalex.org/W2150308295","https://openalex.org/W2150593762","https://openalex.org/W2156881251","https://openalex.org/W2157971737","https://openalex.org/W2162126440","https://openalex.org/W2164119561","https://openalex.org/W2166091242","https://openalex.org/W2167363133","https://openalex.org/W2168130140","https://openalex.org/W2169589594","https://openalex.org/W2278011425","https://openalex.org/W2339217994","https://openalex.org/W2561675875","https://openalex.org/W4243644740"],"related_works":["https://openalex.org/W4230726766","https://openalex.org/W2970439648","https://openalex.org/W2460107372","https://openalex.org/W2304655730","https://openalex.org/W2170181173","https://openalex.org/W2007846881","https://openalex.org/W1968932663","https://openalex.org/W1748160142","https://openalex.org/W1593942753","https://openalex.org/W1506559138"],"abstract_inverted_index":{"Finite-state":[0],"properties":[1,34,46,224],"account":[2],"for":[3,207],"an":[4],"important":[5],"class":[6],"of":[7,15,32,44,50,62,88,98,211,234],"program":[8,77,84,133,169],"properties,":[9],"typically":[10,65],"related":[11],"to":[12,29,175,222,257],"the":[13,41,53,60,83,124,132,136,149,152,156,172,180,200,208,235,254,267],"order":[14],"operations":[16],"invoked":[17],"on":[18,138],"objects.":[19],"Many":[20],"library":[21],"implementations":[22],"therefore":[23,94],"include":[24],"manually":[25],"written":[26],"finite-state":[27,33,45,223],"monitors":[28,51,107],"detect":[30],"violations":[31,145,195],"at":[35,108,196],"runtime.":[36,197],"Researchers":[37],"have":[38],"recently":[39],"proposed":[40],"explicit":[42],"specification":[43],"and":[47,64,114,215],"automatic":[48],"generation":[49],"from":[52,168],"specification.":[54],"However,":[55],"runtime":[56,73,106,157,213],"monitoring":[57,255],"only":[58,165],"shows":[59],"presence":[61],"violations,":[63],"cannot":[66,134],"prove":[67,130,143,176],"their":[68],"absence.":[69],"Moreover,":[70],"inserting":[71],"a":[72,76,96,160,187,204],"monitor":[74,125,158,164,182],"into":[75,159],"under":[78],"test":[79],"can":[80,121],"slow":[81],"down":[82],"by":[85,219],"several":[86,226,263],"orders":[87],"magnitude.":[89],"In":[90,148],"this":[91],"work,":[92],"we":[93,117],"present":[95],"set":[97],"four":[99],"static":[100],"whole-program":[101],"analyses":[102,173,201],"that":[103,131,144,171,232,262],"partially":[104],"evaluate":[105,123],"compile":[109],"time,":[110],"with":[111],"increasing":[112],"cost":[113],"precision.":[115],"As":[116],"show,":[118],"ahead-of-time":[119],"evaluation":[120,154,210],"often":[122,252],"completely":[126],"statically.":[127],"This":[128,163,178],"may":[129,142],"violate":[135,238,266],"property":[137,194],"any":[139],"execution":[140],"or":[141],"do":[146],"exist.":[147],"remaining":[150],"cases,":[151],"partial":[153,209],"converts":[155],"residual":[161,181],"monitor.":[162],"receives":[166],"events":[167],"locations":[170],"failed":[174],"irrelevant.":[177],"makes":[179],"much":[183],"more":[184],"efficient":[185],"than":[186],"full":[188],"monitor,":[189],"while":[190],"still":[191],"capturing":[192],"all":[193],"We":[198,260],"implemented":[199],"in":[202,247],"Clara,":[203],"novel":[205],"framework":[206],"AspectJ-based":[212],"monitors,":[214],"validated":[216],"our":[217,239],"approach":[218],"applying":[220],"Clara":[221,230,250],"over":[225],"large-scale":[227],"Java":[228],"programs.":[229],"proved":[231],"most":[233],"programs":[236,243,264],"never":[237],"example":[240],"properties.":[241,269],"Some":[242],"required":[244],"monitoring,":[245],"but":[246],"those":[248],"cases":[249],"could":[251],"reduce":[253],"overhead":[256],"below":[258],"10%.":[259],"observed":[261],"did":[265],"stated":[268]},"cited_by_api_url":"https://api.openalex.org/works?filter=cites:W2170181173","counts_by_year":[{"year":2024,"cited_by_count":1},{"year":2023,"cited_by_count":3},{"year":2022,"cited_by_count":1},{"year":2019,"cited_by_count":1},{"year":2018,"cited_by_count":2},{"year":2017,"cited_by_count":2},{"year":2016,"cited_by_count":1},{"year":2015,"cited_by_count":2},{"year":2014,"cited_by_count":4},{"year":2013,"cited_by_count":1},{"year":2012,"cited_by_count":1}],"updated_date":"2025-01-16T01:21:38.644083","created_date":"2016-06-24"}