{"id":"https://openalex.org/W2763924051","doi":"https://doi.org/10.1145/3149869.3149871","title":"Efficient Pattern Matching in Python","display_name":"Efficient Pattern Matching in Python","publication_year":2017,"publication_date":"2017-11-03","ids":{"openalex":"https://openalex.org/W2763924051","doi":"https://doi.org/10.1145/3149869.3149871","mag":"2763924051"},"language":"en","primary_location":{"id":"doi:10.1145/3149869.3149871","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3149869.3149871","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 7th Workshop on Python for High-Performance and Scientific Computing","raw_type":"proceedings-article"},"type":"preprint","indexed_in":["arxiv","crossref","datacite"],"open_access":{"is_oa":true,"oa_status":"green","oa_url":"https://arxiv.org/pdf/1710.00077","any_repository_has_fulltext":true},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5038134201","display_name":"Manuel Krebber","orcid":null},"institutions":[{"id":"https://openalex.org/I887968799","display_name":"RWTH Aachen University","ror":"https://ror.org/04xfq0f34","country_code":"DE","type":"education","lineage":["https://openalex.org/I887968799"]}],"countries":["DE"],"is_corresponding":true,"raw_author_name":"Manuel Krebber","raw_affiliation_strings":["Aachen Institute for Advanced Study in Computational Engineering Science, High-Performance and Automatic Computing Group, RWTH Aachen University","Aachen Institute for Advanced Study in Computational Engineering Science, High-Performance and Automatic Computing Group, RWTH Aachen University#TAB#"],"affiliations":[{"raw_affiliation_string":"Aachen Institute for Advanced Study in Computational Engineering Science, High-Performance and Automatic Computing Group, RWTH Aachen University","institution_ids":["https://openalex.org/I887968799"]},{"raw_affiliation_string":"Aachen Institute for Advanced Study in Computational Engineering Science, High-Performance and Automatic Computing Group, RWTH Aachen University#TAB#","institution_ids":["https://openalex.org/I887968799"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5047788967","display_name":"Henrik Barthels","orcid":"https://orcid.org/0000-0001-6744-3605"},"institutions":[{"id":"https://openalex.org/I887968799","display_name":"RWTH Aachen University","ror":"https://ror.org/04xfq0f34","country_code":"DE","type":"education","lineage":["https://openalex.org/I887968799"]}],"countries":["DE"],"is_corresponding":false,"raw_author_name":"Henrik Barthels","raw_affiliation_strings":["Aachen Institute for Advanced Study in Computational Engineering Science, High-Performance and Automatic Computing Group, RWTH Aachen University","Aachen Institute for Advanced Study in Computational Engineering Science, High-Performance and Automatic Computing Group, RWTH Aachen University#TAB#"],"affiliations":[{"raw_affiliation_string":"Aachen Institute for Advanced Study in Computational Engineering Science, High-Performance and Automatic Computing Group, RWTH Aachen University","institution_ids":["https://openalex.org/I887968799"]},{"raw_affiliation_string":"Aachen Institute for Advanced Study in Computational Engineering Science, High-Performance and Automatic Computing Group, RWTH Aachen University#TAB#","institution_ids":["https://openalex.org/I887968799"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5048393932","display_name":"Paolo Bientinesi","orcid":"https://orcid.org/0000-0002-4972-7097"},"institutions":[{"id":"https://openalex.org/I887968799","display_name":"RWTH Aachen University","ror":"https://ror.org/04xfq0f34","country_code":"DE","type":"education","lineage":["https://openalex.org/I887968799"]}],"countries":["DE"],"is_corresponding":false,"raw_author_name":"Paolo Bientinesi","raw_affiliation_strings":["Aachen Institute for Advanced Study in Computational Engineering Science, High-Performance and Automatic Computing Group, RWTH Aachen University","Aachen Institute for Advanced Study in Computational Engineering Science, High-Performance and Automatic Computing Group, RWTH Aachen University#TAB#"],"affiliations":[{"raw_affiliation_string":"Aachen Institute for Advanced Study in Computational Engineering Science, High-Performance and Automatic Computing Group, RWTH Aachen University","institution_ids":["https://openalex.org/I887968799"]},{"raw_affiliation_string":"Aachen Institute for Advanced Study in Computational Engineering Science, High-Performance and Automatic Computing Group, RWTH Aachen University#TAB#","institution_ids":["https://openalex.org/I887968799"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":3,"corresponding_author_ids":["https://openalex.org/A5038134201"],"corresponding_institution_ids":["https://openalex.org/I887968799"],"apc_list":null,"apc_paid":null,"fwci":0.0,"has_fulltext":true,"cited_by_count":0,"citation_normalized_percentile":{"value":0.15470383,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":null,"biblio":{"volume":null,"issue":null,"first_page":"1","last_page":"9"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10054","display_name":"Parallel Computing and Optimization Techniques","score":0.9976000189781189,"subfield":{"id":"https://openalex.org/subfields/1708","display_name":"Hardware and Architecture"},"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/T10054","display_name":"Parallel Computing and Optimization Techniques","score":0.9976000189781189,"subfield":{"id":"https://openalex.org/subfields/1708","display_name":"Hardware and Architecture"},"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.994700014591217,"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/T11269","display_name":"Algorithms and Data Compression","score":0.9896000027656555,"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/python","display_name":"Python (programming language)","score":0.8264679312705994},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.7909300327301025},{"id":"https://openalex.org/keywords/pattern-matching","display_name":"Pattern matching","score":0.7389874458312988},{"id":"https://openalex.org/keywords/rewriting","display_name":"Rewriting","score":0.7246526479721069},{"id":"https://openalex.org/keywords/json","display_name":"JSON","score":0.6837963461875916},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.6140527725219727},{"id":"https://openalex.org/keywords/associative-property","display_name":"Associative property","score":0.6103876829147339},{"id":"https://openalex.org/keywords/xml","display_name":"XML","score":0.6022655963897705},{"id":"https://openalex.org/keywords/commutative-property","display_name":"Commutative property","score":0.556471586227417},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.5198938846588135},{"id":"https://openalex.org/keywords/syntax","display_name":"Syntax","score":0.4992861747741699},{"id":"https://openalex.org/keywords/abstract-syntax","display_name":"Abstract syntax","score":0.4599316418170929},{"id":"https://openalex.org/keywords/symbolic-computation","display_name":"Symbolic computation","score":0.4404946565628052},{"id":"https://openalex.org/keywords/matching","display_name":"Matching (statistics)","score":0.4127552807331085},{"id":"https://openalex.org/keywords/algorithm","display_name":"Algorithm","score":0.34628134965896606},{"id":"https://openalex.org/keywords/artificial-intelligence","display_name":"Artificial intelligence","score":0.21667605638504028},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.14668750762939453},{"id":"https://openalex.org/keywords/semantics","display_name":"Semantics (computer science)","score":0.11335000395774841},{"id":"https://openalex.org/keywords/discrete-mathematics","display_name":"Discrete mathematics","score":0.08626231551170349}],"concepts":[{"id":"https://openalex.org/C519991488","wikidata":"https://www.wikidata.org/wiki/Q28865","display_name":"Python (programming language)","level":2,"score":0.8264679312705994},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.7909300327301025},{"id":"https://openalex.org/C68859911","wikidata":"https://www.wikidata.org/wiki/Q1503724","display_name":"Pattern matching","level":2,"score":0.7389874458312988},{"id":"https://openalex.org/C154690210","wikidata":"https://www.wikidata.org/wiki/Q1668499","display_name":"Rewriting","level":2,"score":0.7246526479721069},{"id":"https://openalex.org/C2780416260","wikidata":"https://www.wikidata.org/wiki/Q2063","display_name":"JSON","level":2,"score":0.6837963461875916},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.6140527725219727},{"id":"https://openalex.org/C159423971","wikidata":"https://www.wikidata.org/wiki/Q177251","display_name":"Associative property","level":2,"score":0.6103876829147339},{"id":"https://openalex.org/C8797682","wikidata":"https://www.wikidata.org/wiki/Q2115","display_name":"XML","level":2,"score":0.6022655963897705},{"id":"https://openalex.org/C183778304","wikidata":"https://www.wikidata.org/wiki/Q165474","display_name":"Commutative property","level":2,"score":0.556471586227417},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.5198938846588135},{"id":"https://openalex.org/C60048249","wikidata":"https://www.wikidata.org/wiki/Q37437","display_name":"Syntax","level":2,"score":0.4992861747741699},{"id":"https://openalex.org/C114408938","wikidata":"https://www.wikidata.org/wiki/Q333373","display_name":"Abstract syntax","level":3,"score":0.4599316418170929},{"id":"https://openalex.org/C110812573","wikidata":"https://www.wikidata.org/wiki/Q175515","display_name":"Symbolic computation","level":2,"score":0.4404946565628052},{"id":"https://openalex.org/C165064840","wikidata":"https://www.wikidata.org/wiki/Q1321061","display_name":"Matching (statistics)","level":2,"score":0.4127552807331085},{"id":"https://openalex.org/C11413529","wikidata":"https://www.wikidata.org/wiki/Q8366","display_name":"Algorithm","level":1,"score":0.34628134965896606},{"id":"https://openalex.org/C154945302","wikidata":"https://www.wikidata.org/wiki/Q11660","display_name":"Artificial intelligence","level":1,"score":0.21667605638504028},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.14668750762939453},{"id":"https://openalex.org/C184337299","wikidata":"https://www.wikidata.org/wiki/Q1437428","display_name":"Semantics (computer science)","level":2,"score":0.11335000395774841},{"id":"https://openalex.org/C118615104","wikidata":"https://www.wikidata.org/wiki/Q121416","display_name":"Discrete mathematics","level":1,"score":0.08626231551170349},{"id":"https://openalex.org/C202444582","wikidata":"https://www.wikidata.org/wiki/Q837863","display_name":"Pure mathematics","level":1,"score":0.0},{"id":"https://openalex.org/C111919701","wikidata":"https://www.wikidata.org/wiki/Q9135","display_name":"Operating system","level":1,"score":0.0},{"id":"https://openalex.org/C134306372","wikidata":"https://www.wikidata.org/wiki/Q7754","display_name":"Mathematical analysis","level":1,"score":0.0},{"id":"https://openalex.org/C105795698","wikidata":"https://www.wikidata.org/wiki/Q12483","display_name":"Statistics","level":1,"score":0.0}],"mesh":[],"locations_count":4,"locations":[{"id":"doi:10.1145/3149869.3149871","is_oa":false,"landing_page_url":"https://doi.org/10.1145/3149869.3149871","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceedings of the 7th Workshop on Python for High-Performance and Scientific Computing","raw_type":"proceedings-article"},{"id":"pmh:oai:arXiv.org:1710.00077","is_oa":true,"landing_page_url":"http://arxiv.org/abs/1710.00077","pdf_url":"https://arxiv.org/pdf/1710.00077","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":"","raw_type":"text"},{"id":"mag:2763924051","is_oa":true,"landing_page_url":"https://arxiv.org/pdf/1710.00077.pdf","pdf_url":null,"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":"arXiv (Cornell University)","raw_type":null},{"id":"doi:10.48550/arxiv.1710.00077","is_oa":true,"landing_page_url":"https://doi.org/10.48550/arxiv.1710.00077","pdf_url":null,"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":null,"is_accepted":false,"is_published":null,"raw_source_name":null,"raw_type":"article"}],"best_oa_location":{"id":"pmh:oai:arXiv.org:1710.00077","is_oa":true,"landing_page_url":"http://arxiv.org/abs/1710.00077","pdf_url":"https://arxiv.org/pdf/1710.00077","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":"","raw_type":"text"},"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"grobid_xml":true,"pdf":true},"content_urls":{"pdf":"https://content.openalex.org/works/W2763924051.pdf","grobid_xml":"https://content.openalex.org/works/W2763924051.grobid-xml"},"referenced_works_count":31,"referenced_works":["https://openalex.org/W113905406","https://openalex.org/W1518546215","https://openalex.org/W1583295953","https://openalex.org/W1676038580","https://openalex.org/W1868982956","https://openalex.org/W1928673936","https://openalex.org/W1988425770","https://openalex.org/W1993260645","https://openalex.org/W2002257715","https://openalex.org/W2016416448","https://openalex.org/W2038469228","https://openalex.org/W2038646777","https://openalex.org/W2052951585","https://openalex.org/W2056737359","https://openalex.org/W2063655645","https://openalex.org/W2076438039","https://openalex.org/W2117504940","https://openalex.org/W2153146517","https://openalex.org/W2153598190","https://openalex.org/W2157529519","https://openalex.org/W2324840415","https://openalex.org/W2334295053","https://openalex.org/W2345999607","https://openalex.org/W2417863416","https://openalex.org/W2568865948","https://openalex.org/W2611457894","https://openalex.org/W2754180346","https://openalex.org/W3022794709","https://openalex.org/W3098073656","https://openalex.org/W4230919050","https://openalex.org/W4289127653"],"related_works":["https://openalex.org/W2964022412","https://openalex.org/W1849112070","https://openalex.org/W2011532774","https://openalex.org/W1802397955","https://openalex.org/W1979785613","https://openalex.org/W2123976282","https://openalex.org/W1523742561","https://openalex.org/W1579833858","https://openalex.org/W2520543580","https://openalex.org/W282741717","https://openalex.org/W1541203659","https://openalex.org/W2251621662","https://openalex.org/W2024895705","https://openalex.org/W3006496683","https://openalex.org/W2320849189","https://openalex.org/W2788844568","https://openalex.org/W1495923762","https://openalex.org/W2914268814","https://openalex.org/W1485727503","https://openalex.org/W2765974293"],"abstract_inverted_index":{"Pattern":[0],"matching":[1,62,75,84],"is":[2,110],"a":[3],"powerful":[4],"tool":[5],"for":[6,33,76,97],"symbolic":[7,20],"computations.":[8],"Applications":[9],"include":[10],"term":[11],"rewriting":[12],"systems,":[13],"as":[14,16,72,74],"well":[15,73],"the":[17,40,47,60],"manipulation":[18],"of":[19,37,42,108],"expressions,":[21],"abstract":[22],"syntax":[23],"trees,":[24],"and":[25,27,56,83,90],"XML":[26],"JSON":[28],"data.":[29],"It":[30],"also":[31],"allows":[32],"an":[34],"intuitive":[35],"description":[36],"algorithms":[38,92],"in":[39,63],"form":[41],"rewrite":[43],"rules.":[44],"We":[45],"present":[46],"open":[48],"source":[49],"Python":[50],"module":[51],"MatchPy,":[52],"which":[53],"offers":[54],"functionality":[55],"expressiveness":[57],"similar":[58],"to":[59,93],"pattern":[61,70,99],"Mathematica.":[64],"In":[65],"particular,":[66],"it":[67],"includes":[68],"syntactic":[69],"matching,":[71],"commutative":[77],"and/or":[78],"associative":[79],"functions,":[80],"sequence":[81],"variables,":[82],"with":[85],"constraints.":[86],"MatchPy":[87,109],"uses":[88],"new":[89],"improved":[91],"efficiently":[94],"find":[95],"matches":[96],"large":[98],"sets":[100],"by":[101],"exploiting":[102],"similarities":[103],"between":[104],"patterns.":[105],"The":[106],"performance":[107],"investigated":[111],"on":[112],"several":[113],"real-world":[114],"problems.":[115]},"counts_by_year":[],"updated_date":"2026-03-10T16:38:18.471706","created_date":"2025-10-10T00:00:00"}
