{"id":"https://openalex.org/W2759550170","doi":"https://doi.org/10.1145/3133917","title":"Automated testing of graphics shader compilers","display_name":"Automated testing of graphics shader compilers","publication_year":2017,"publication_date":"2017-10-12","ids":{"openalex":"https://openalex.org/W2759550170","doi":"https://doi.org/10.1145/3133917","mag":"2759550170"},"language":"en","primary_location":{"id":"doi:10.1145/3133917","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3133917","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3133917","source":{"id":"https://openalex.org/S4210216081","display_name":"Proceedings of the ACM on Programming Languages","issn_l":"2475-1421","issn":["2475-1421"],"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":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the ACM on Programming Languages","raw_type":"journal-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"hybrid","oa_url":"https://dl.acm.org/doi/pdf/10.1145/3133917","any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5080781439","display_name":"Alastair F. Donaldson","orcid":"https://orcid.org/0000-0002-7448-7961"},"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":"Alastair F. Donaldson","raw_affiliation_strings":["Imperial College London, UK"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Imperial College London, UK","institution_ids":["https://openalex.org/I47508984"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5087459870","display_name":"Hugues Evrard","orcid":"https://orcid.org/0009-0001-7956-0371"},"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":"Hugues Evrard","raw_affiliation_strings":["Imperial College London, UK"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Imperial College London, UK","institution_ids":["https://openalex.org/I47508984"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5007080779","display_name":"Andrei Lascu","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":false,"raw_author_name":"Andrei Lascu","raw_affiliation_strings":["Imperial College London, UK"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Imperial College London, UK","institution_ids":["https://openalex.org/I47508984"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5017019571","display_name":"Paul Thomson","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":false,"raw_author_name":"Paul Thomson","raw_affiliation_strings":["Imperial College London, UK"],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Imperial College London, UK","institution_ids":["https://openalex.org/I47508984"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":4,"corresponding_author_ids":["https://openalex.org/A5080781439"],"corresponding_institution_ids":["https://openalex.org/I47508984"],"apc_list":null,"apc_paid":null,"fwci":12.3677,"has_fulltext":true,"cited_by_count":117,"citation_normalized_percentile":{"value":0.98809288,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":96,"max":100},"biblio":{"volume":"1","issue":"OOPSLA","first_page":"1","last_page":"29"},"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.9998999834060669,"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.9998999834060669,"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/T11241","display_name":"Advanced Malware Detection Techniques","score":0.9980999827384949,"subfield":{"id":"https://openalex.org/subfields/1711","display_name":"Signal Processing"},"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.9898999929428101,"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/shader","display_name":"Shader","score":0.9726302623748779},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8639600276947021},{"id":"https://openalex.org/keywords/compiler","display_name":"Compiler","score":0.7376039624214172},{"id":"https://openalex.org/keywords/rendering","display_name":"Rendering (computer graphics)","score":0.648082971572876},{"id":"https://openalex.org/keywords/graphics-pipeline","display_name":"Graphics pipeline","score":0.5429911017417908},{"id":"https://openalex.org/keywords/graphics","display_name":"Graphics","score":0.47790154814720154},{"id":"https://openalex.org/keywords/computer-graphics","display_name":"Computer graphics (images)","score":0.46575766801834106},{"id":"https://openalex.org/keywords/3d-computer-graphics","display_name":"3D computer graphics","score":0.35083264112472534},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.346599817276001}],"concepts":[{"id":"https://openalex.org/C177681979","wikidata":"https://www.wikidata.org/wiki/Q633182","display_name":"Shader","level":3,"score":0.9726302623748779},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8639600276947021},{"id":"https://openalex.org/C169590947","wikidata":"https://www.wikidata.org/wiki/Q47506","display_name":"Compiler","level":2,"score":0.7376039624214172},{"id":"https://openalex.org/C205711294","wikidata":"https://www.wikidata.org/wiki/Q176953","display_name":"Rendering (computer graphics)","level":2,"score":0.648082971572876},{"id":"https://openalex.org/C173552908","wikidata":"https://www.wikidata.org/wiki/Q1366289","display_name":"Graphics pipeline","level":4,"score":0.5429911017417908},{"id":"https://openalex.org/C21442007","wikidata":"https://www.wikidata.org/wiki/Q1027879","display_name":"Graphics","level":2,"score":0.47790154814720154},{"id":"https://openalex.org/C121684516","wikidata":"https://www.wikidata.org/wiki/Q7600677","display_name":"Computer graphics (images)","level":1,"score":0.46575766801834106},{"id":"https://openalex.org/C66629338","wikidata":"https://www.wikidata.org/wiki/Q189177","display_name":"3D computer graphics","level":3,"score":0.35083264112472534},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.346599817276001}],"mesh":[],"locations_count":2,"locations":[{"id":"doi:10.1145/3133917","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3133917","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3133917","source":{"id":"https://openalex.org/S4210216081","display_name":"Proceedings of the ACM on Programming Languages","issn_l":"2475-1421","issn":["2475-1421"],"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":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the ACM on Programming Languages","raw_type":"journal-article"},{"id":"pmh:oai:spiral.imperial.ac.uk:10044/1/50407","is_oa":false,"landing_page_url":"http://hdl.handle.net/10044/1/50407","pdf_url":null,"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":"Object-oriented Programming, Systems, Languages, and Applications (OOPSLA)","raw_type":"Conference Paper"}],"best_oa_location":{"id":"doi:10.1145/3133917","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3133917","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3133917","source":{"id":"https://openalex.org/S4210216081","display_name":"Proceedings of the ACM on Programming Languages","issn_l":"2475-1421","issn":["2475-1421"],"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":"cc-by","license_id":"https://openalex.org/licenses/cc-by","version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the ACM on Programming Languages","raw_type":"journal-article"},"sustainable_development_goals":[{"display_name":"Peace, Justice and strong institutions","id":"https://metadata.un.org/sdg/16","score":0.7099999785423279}],"awards":[{"id":"https://openalex.org/G3133118961","display_name":null,"funder_award_id":"EP/N026314/1","funder_id":"https://openalex.org/F4320334627","funder_display_name":"Engineering and Physical Sciences Research Council"},{"id":"https://openalex.org/G5201431165","display_name":"EPSRC Centre for Doctoral Training in High Performance Embedded and Distributed Systems","funder_award_id":"EP/L016796/1","funder_id":"https://openalex.org/F4320334627","funder_display_name":"Engineering and Physical Sciences Research Council"},{"id":"https://openalex.org/G6371186435","display_name":"Reliable Many-Core Programming","funder_award_id":"EP/N026314/1","funder_id":"https://openalex.org/F4320334627","funder_display_name":"Engineering and Physical Sciences Research Council"}],"funders":[{"id":"https://openalex.org/F4320320283","display_name":"Imperial College London","ror":"https://ror.org/041kmwe10"},{"id":"https://openalex.org/F4320334627","display_name":"Engineering and Physical Sciences Research Council","ror":"https://ror.org/0439y7842"}],"has_content":{"pdf":true,"grobid_xml":true},"content_urls":{"pdf":"https://content.openalex.org/works/W2759550170.pdf","grobid_xml":"https://content.openalex.org/works/W2759550170.grobid-xml"},"referenced_works_count":29,"referenced_works":["https://openalex.org/W109452506","https://openalex.org/W148958015","https://openalex.org/W190884830","https://openalex.org/W1482603307","https://openalex.org/W1966021031","https://openalex.org/W2007632507","https://openalex.org/W2019793857","https://openalex.org/W2025898372","https://openalex.org/W2041713059","https://openalex.org/W2068034551","https://openalex.org/W2071952624","https://openalex.org/W2095445208","https://openalex.org/W2098456636","https://openalex.org/W2110441383","https://openalex.org/W2130746431","https://openalex.org/W2155877593","https://openalex.org/W2170224888","https://openalex.org/W2290583408","https://openalex.org/W2295658119","https://openalex.org/W2296333508","https://openalex.org/W2313752879","https://openalex.org/W2324595780","https://openalex.org/W2370472429","https://openalex.org/W2532737545","https://openalex.org/W2563180316","https://openalex.org/W2617809069","https://openalex.org/W2997653900","https://openalex.org/W4238083723","https://openalex.org/W6606106986"],"related_works":["https://openalex.org/W2384885138","https://openalex.org/W2403188927","https://openalex.org/W2132794636","https://openalex.org/W574209047","https://openalex.org/W2058044347","https://openalex.org/W2045602725","https://openalex.org/W2941789004","https://openalex.org/W2273884611","https://openalex.org/W2911411200","https://openalex.org/W584835857"],"abstract_inverted_index":{"We":[0,116],"present":[1],"an":[2,23,27,106,232],"automated":[3],"technique":[4],"for":[5,10,59,235],"finding":[6,152],"defects":[7,224],"in":[8,16,37,99],"compilers":[9,40],"graphics":[11,38,70],"shading":[12,128],"languages.":[13],"key":[14],"challenge":[15],"compiler":[17,60,114,223],"testing":[18,230],"is":[19,34,44,49],"the":[20,42,119,126,143,192],"lack":[21],"of":[22,75,88,136,194,213],"oracle":[24],"that":[25,48,78,110,174,221,228],"classifies":[26],"output":[28,43],"as":[29,121,166],"correct":[30],"or":[31],"incorrect;":[32],"this":[33],"particularly":[35],"pertinent":[36],"shader":[39,89,109,113,222],"where":[41,185],"a":[45,102,112,122,134,178,186,199,203,210],"rendered":[46],"image":[47],"typically":[50],"under-specified.":[51],"Our":[52,131,218],"method":[53],"builds":[54],"on":[55,63],"recent":[56],"successful":[57],"techniques":[58],"validation":[61],"based":[62],"metamorphic":[64,229],"testing,":[65],"and":[66,139,153,198,227],"leverages":[67],"existing":[68],"high-value":[69,108],"shaders":[71,77,93],"to":[72,97,105,150,209],"create":[73],"sets":[74],"transformed":[76],"should":[79],"be":[80],"semantically":[81],"equivalent.":[82],"Rendering":[83],"mismatches":[84],"are":[85,94,225],"then":[86],"indicative":[87],"compilation":[90],"bugs.":[91],"Deviant":[92],"automatically":[95],"minimized":[96],"identify,":[98],"each":[100],"case,":[101],"minimal":[103],"change":[104],"original":[107],"induces":[111],"bug.":[115],"have":[117,148],"implemented":[118],"approach":[120],"tool,":[123],"GLFuzz,":[124],"targeting":[125],"OpenGL":[127],"language,":[129],"GLSL.":[130],"experiments":[132],"over":[133],"set":[135],"17":[137],"GPU":[138,146],"driver":[140],"configurations,":[141],"spanning":[142],"main":[144],"7":[145],"designers,":[147],"led":[149],"us":[151],"reporting":[154],"more":[155],"than":[156],"60":[157],"distinct":[158],"bugs,":[159],"covering":[160],"all":[161],"tested":[162],"configurations.":[163],"As":[164],"well":[165],"defective":[167],"rendering,":[168],"these":[169],"issues":[170],"identify":[171],"security-critical":[172],"vulnerabilities":[173],"affect":[175],"WebGL,":[176],"including":[177],"significant":[179],"remote":[180],"information":[181],"leak":[182],"security":[183],"bug":[184,200],"malicious":[187,204],"web":[188,205],"page":[189,206],"can":[190,207],"capture":[191],"contents":[193],"other":[195],"browser":[196],"tabs,":[197],"whereby":[201],"visiting":[202],"lead":[208],"``blue":[211],"screen":[212],"death''":[214],"under":[215],"Windows":[216],"10.":[217],"findings":[219],"show":[220],"prevalent,":[226],"provides":[231],"effective":[233],"means":[234],"detecting":[236],"them":[237],"automatically.":[238]},"counts_by_year":[{"year":2026,"cited_by_count":1},{"year":2025,"cited_by_count":15},{"year":2024,"cited_by_count":12},{"year":2023,"cited_by_count":27},{"year":2022,"cited_by_count":12},{"year":2021,"cited_by_count":15},{"year":2020,"cited_by_count":17},{"year":2019,"cited_by_count":11},{"year":2018,"cited_by_count":7}],"updated_date":"2026-04-26T08:31:28.666265","created_date":"2025-10-10T00:00:00"}
