{"id":"https://openalex.org/W2899743513","doi":"https://doi.org/10.1109/icnp.2018.00060","title":"pcube: Primitives for Network Data Plane Programming","display_name":"pcube: Primitives for Network Data Plane Programming","publication_year":2018,"publication_date":"2018-09-01","ids":{"openalex":"https://openalex.org/W2899743513","doi":"https://doi.org/10.1109/icnp.2018.00060","mag":"2899743513"},"language":"en","primary_location":{"id":"doi:10.1109/icnp.2018.00060","is_oa":false,"landing_page_url":"https://doi.org/10.1109/icnp.2018.00060","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"2018 IEEE 26th International Conference on Network Protocols (ICNP)","raw_type":"proceedings-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":false,"oa_status":"closed","oa_url":null,"any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5004714221","display_name":"Rinku Shah","orcid":"https://orcid.org/0000-0001-9823-4515"},"institutions":[{"id":"https://openalex.org/I162827531","display_name":"Indian Institute of Technology Bombay","ror":"https://ror.org/02qyf5152","country_code":"IN","type":"education","lineage":["https://openalex.org/I162827531"]}],"countries":["IN"],"is_corresponding":true,"raw_author_name":"Rinku Shah","raw_affiliation_strings":["Department of Computer Science and Engineering, Indian Institute of Technology, Bombay"],"affiliations":[{"raw_affiliation_string":"Department of Computer Science and Engineering, Indian Institute of Technology, Bombay","institution_ids":["https://openalex.org/I162827531"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5068896437","display_name":"Aniket Shirke","orcid":null},"institutions":[{"id":"https://openalex.org/I162827531","display_name":"Indian Institute of Technology Bombay","ror":"https://ror.org/02qyf5152","country_code":"IN","type":"education","lineage":["https://openalex.org/I162827531"]}],"countries":["IN"],"is_corresponding":false,"raw_author_name":"Aniket Shirke","raw_affiliation_strings":["Department of Computer Science and Engineering, Indian Institute of Technology, Bombay"],"affiliations":[{"raw_affiliation_string":"Department of Computer Science and Engineering, Indian Institute of Technology, Bombay","institution_ids":["https://openalex.org/I162827531"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5076280094","display_name":"Akash Trehan","orcid":null},"institutions":[{"id":"https://openalex.org/I162827531","display_name":"Indian Institute of Technology Bombay","ror":"https://ror.org/02qyf5152","country_code":"IN","type":"education","lineage":["https://openalex.org/I162827531"]}],"countries":["IN"],"is_corresponding":false,"raw_author_name":"Akash Trehan","raw_affiliation_strings":["Department of Computer Science and Engineering, Indian Institute of Technology, Bombay"],"affiliations":[{"raw_affiliation_string":"Department of Computer Science and Engineering, Indian Institute of Technology, Bombay","institution_ids":["https://openalex.org/I162827531"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5005539276","display_name":"Mythili Vutukuru","orcid":"https://orcid.org/0000-0002-0039-595X"},"institutions":[{"id":"https://openalex.org/I162827531","display_name":"Indian Institute of Technology Bombay","ror":"https://ror.org/02qyf5152","country_code":"IN","type":"education","lineage":["https://openalex.org/I162827531"]}],"countries":["IN"],"is_corresponding":false,"raw_author_name":"Mythili Vutukuru","raw_affiliation_strings":["Department of Computer Science and Engineering, Indian Institute of Technology, Bombay"],"affiliations":[{"raw_affiliation_string":"Department of Computer Science and Engineering, Indian Institute of Technology, Bombay","institution_ids":["https://openalex.org/I162827531"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5111441567","display_name":"Purushottam Kulkarni","orcid":null},"institutions":[{"id":"https://openalex.org/I162827531","display_name":"Indian Institute of Technology Bombay","ror":"https://ror.org/02qyf5152","country_code":"IN","type":"education","lineage":["https://openalex.org/I162827531"]}],"countries":["IN"],"is_corresponding":false,"raw_author_name":"Purushottam Kulkarni","raw_affiliation_strings":["Department of Computer Science and Engineering, Indian Institute of Technology, Bombay"],"affiliations":[{"raw_affiliation_string":"Department of Computer Science and Engineering, Indian Institute of Technology, Bombay","institution_ids":["https://openalex.org/I162827531"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":5,"corresponding_author_ids":["https://openalex.org/A5004714221"],"corresponding_institution_ids":["https://openalex.org/I162827531"],"apc_list":null,"apc_paid":null,"fwci":0.5536,"has_fulltext":false,"cited_by_count":6,"citation_normalized_percentile":{"value":0.71210321,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":89,"max":97},"biblio":{"volume":null,"issue":null,"first_page":"430","last_page":"435"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10714","display_name":"Software-Defined Networks and 5G","score":1.0,"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"}},"topics":[{"id":"https://openalex.org/T10714","display_name":"Software-Defined Networks and 5G","score":1.0,"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"}},{"id":"https://openalex.org/T10829","display_name":"Interconnection Networks and Systems","score":0.9993000030517578,"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"}},{"id":"https://openalex.org/T12127","display_name":"Software System Performance and Reliability","score":0.9965000152587891,"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/computer-science","display_name":"Computer science","score":0.8654738664627075},{"id":"https://openalex.org/keywords/synchronization","display_name":"Synchronization (alternating current)","score":0.633819580078125},{"id":"https://openalex.org/keywords/preprocessor","display_name":"Preprocessor","score":0.6088686585426331},{"id":"https://openalex.org/keywords/network-packet","display_name":"Network packet","score":0.5794863700866699},{"id":"https://openalex.org/keywords/factor","display_name":"Factor (programming language)","score":0.5511698722839355},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.5418300628662109},{"id":"https://openalex.org/keywords/code","display_name":"Code (set theory)","score":0.5300872921943665},{"id":"https://openalex.org/keywords/forwarding-plane","display_name":"Forwarding plane","score":0.5271748304367065},{"id":"https://openalex.org/keywords/state","display_name":"State (computer science)","score":0.5227784514427185},{"id":"https://openalex.org/keywords/set","display_name":"Set (abstract data type)","score":0.4854060113430023},{"id":"https://openalex.org/keywords/domain","display_name":"Domain (mathematical analysis)","score":0.48367175459861755},{"id":"https://openalex.org/keywords/distributed-computing","display_name":"Distributed computing","score":0.44160035252571106},{"id":"https://openalex.org/keywords/source-lines-of-code","display_name":"Source lines of code","score":0.42243459820747375},{"id":"https://openalex.org/keywords/parallel-computing","display_name":"Parallel computing","score":0.4012783169746399},{"id":"https://openalex.org/keywords/software","display_name":"Software","score":0.39418068528175354},{"id":"https://openalex.org/keywords/computer-network","display_name":"Computer network","score":0.15777453780174255}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8654738664627075},{"id":"https://openalex.org/C2778562939","wikidata":"https://www.wikidata.org/wiki/Q1298791","display_name":"Synchronization (alternating current)","level":3,"score":0.633819580078125},{"id":"https://openalex.org/C34736171","wikidata":"https://www.wikidata.org/wiki/Q918333","display_name":"Preprocessor","level":2,"score":0.6088686585426331},{"id":"https://openalex.org/C158379750","wikidata":"https://www.wikidata.org/wiki/Q214111","display_name":"Network packet","level":2,"score":0.5794863700866699},{"id":"https://openalex.org/C2781039887","wikidata":"https://www.wikidata.org/wiki/Q1391724","display_name":"Factor (programming language)","level":2,"score":0.5511698722839355},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.5418300628662109},{"id":"https://openalex.org/C2776760102","wikidata":"https://www.wikidata.org/wiki/Q5139990","display_name":"Code (set theory)","level":3,"score":0.5300872921943665},{"id":"https://openalex.org/C10597312","wikidata":"https://www.wikidata.org/wiki/Q5473302","display_name":"Forwarding plane","level":3,"score":0.5271748304367065},{"id":"https://openalex.org/C48103436","wikidata":"https://www.wikidata.org/wiki/Q599031","display_name":"State (computer science)","level":2,"score":0.5227784514427185},{"id":"https://openalex.org/C177264268","wikidata":"https://www.wikidata.org/wiki/Q1514741","display_name":"Set (abstract data type)","level":2,"score":0.4854060113430023},{"id":"https://openalex.org/C36503486","wikidata":"https://www.wikidata.org/wiki/Q11235244","display_name":"Domain (mathematical analysis)","level":2,"score":0.48367175459861755},{"id":"https://openalex.org/C120314980","wikidata":"https://www.wikidata.org/wiki/Q180634","display_name":"Distributed computing","level":1,"score":0.44160035252571106},{"id":"https://openalex.org/C199519371","wikidata":"https://www.wikidata.org/wiki/Q942695","display_name":"Source lines of code","level":3,"score":0.42243459820747375},{"id":"https://openalex.org/C173608175","wikidata":"https://www.wikidata.org/wiki/Q232661","display_name":"Parallel computing","level":1,"score":0.4012783169746399},{"id":"https://openalex.org/C2777904410","wikidata":"https://www.wikidata.org/wiki/Q7397","display_name":"Software","level":2,"score":0.39418068528175354},{"id":"https://openalex.org/C31258907","wikidata":"https://www.wikidata.org/wiki/Q1301371","display_name":"Computer network","level":1,"score":0.15777453780174255},{"id":"https://openalex.org/C127162648","wikidata":"https://www.wikidata.org/wiki/Q16858953","display_name":"Channel (broadcasting)","level":2,"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/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1109/icnp.2018.00060","is_oa":false,"landing_page_url":"https://doi.org/10.1109/icnp.2018.00060","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"2018 IEEE 26th International Conference on Network Protocols (ICNP)","raw_type":"proceedings-article"}],"best_oa_location":null,"sustainable_development_goals":[{"score":0.41999998688697815,"id":"https://metadata.un.org/sdg/9","display_name":"Industry, innovation and infrastructure"}],"awards":[],"funders":[],"has_content":{"grobid_xml":false,"pdf":false},"content_urls":null,"referenced_works_count":18,"referenced_works":["https://openalex.org/W1994926493","https://openalex.org/W2072811945","https://openalex.org/W2134519279","https://openalex.org/W2283556750","https://openalex.org/W2465793152","https://openalex.org/W2551375806","https://openalex.org/W2605556239","https://openalex.org/W2605823630","https://openalex.org/W2743093301","https://openalex.org/W2743987472","https://openalex.org/W2744693751","https://openalex.org/W2746559355","https://openalex.org/W2748478525","https://openalex.org/W2761070740","https://openalex.org/W2761338514","https://openalex.org/W2951164894","https://openalex.org/W6736431059","https://openalex.org/W6763886807"],"related_works":["https://openalex.org/W116776481","https://openalex.org/W2125008614","https://openalex.org/W2926903444","https://openalex.org/W2039199837","https://openalex.org/W2612997776","https://openalex.org/W2051935741","https://openalex.org/W3013556266","https://openalex.org/W2953270859","https://openalex.org/W2137036704","https://openalex.org/W2073926975"],"abstract_inverted_index":{"P4":[0,67,94],"is":[1,16],"a":[2,17,32,36,114,137],"domain":[3],"specific":[4],"language":[5],"to":[6,40,79,96,141],"configure":[7],"packet":[8],"processing":[9],"pipelines":[10],"in":[11,85,118],"programmable":[12],"dataplane":[13,46,87,110],"switches,":[14],"and":[15,54,69,98,121],"powerful":[18],"idea":[19],"towards":[20],"realizing":[21],"the":[22,42,72,127],"goal":[23],"of":[24,38,44,132,134,139],"flexible":[25],"software-defined":[26],"networks.":[27],"This":[28],"paper":[29],"presents":[30],"pcube,":[31],"framework":[33],"that":[34,123],"provides":[35,49,77],"set":[37],"primitives":[39,50,78],"simplify":[41],"development":[43],"P4-based":[45],"applications.":[47],"pcube":[48,73,75,125],"for":[51],"loops,":[52],"summations,":[53],"other":[55],"common":[56],"operations":[57],"on":[58],"indexed":[59],"state":[60,81],"variables,":[61],"which":[62,89],"can":[63],"be":[64],"embedded":[65],"within":[66],"code":[68,95],"unrolled":[70],"by":[71,105],"preprocessor.":[74],"also":[76],"synchronize":[80],"variables":[82],"across":[83,102],"switches":[84,104],"distributed":[86,115],"applications,":[88],"are":[90],"automatically":[91],"translated":[92],"into":[93],"send":[97],"receive":[99],"synchronization":[100],"messages":[101],"multiple":[103],"pcube.":[106],"We":[107],"build":[108],"example":[109],"applications":[111],"such":[112],"as":[113],"load":[116],"balancer":[117],"our":[119],"framework,":[120],"show":[122],"using":[124],"reduces":[126],"programming":[128],"effort":[129],"(in":[130],"term":[131],"lines":[133],"code)":[135],"significantly-by":[136],"factor":[138],"up":[140],"5.4x.":[142]},"counts_by_year":[{"year":2022,"cited_by_count":3},{"year":2021,"cited_by_count":1},{"year":2019,"cited_by_count":2}],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2025-10-10T00:00:00"}
