{"id":"https://openalex.org/W2161261746","doi":"https://doi.org/10.1145/2445196.2445319","title":"Pattern programming approach for teaching parallel and distributed computing","display_name":"Pattern programming approach for teaching parallel and distributed computing","publication_year":2013,"publication_date":"2013-03-06","ids":{"openalex":"https://openalex.org/W2161261746","doi":"https://doi.org/10.1145/2445196.2445319","mag":"2161261746"},"language":"en","primary_location":{"id":"doi:10.1145/2445196.2445319","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2445196.2445319","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceeding of the 44th ACM technical symposium on Computer science education","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/A5113740134","display_name":"Barry Wilkinson","orcid":null},"institutions":[{"id":"https://openalex.org/I102149020","display_name":"University of North Carolina at Charlotte","ror":"https://ror.org/04dawnj30","country_code":"US","type":"education","lineage":["https://openalex.org/I102149020"]}],"countries":["US"],"is_corresponding":true,"raw_author_name":"Barry Wilkinson","raw_affiliation_strings":["University of North Carolina Charlotte, Charlotte, NC, USA"],"affiliations":[{"raw_affiliation_string":"University of North Carolina Charlotte, Charlotte, NC, USA","institution_ids":["https://openalex.org/I102149020"]}]},{"author_position":"middle","author":{"id":"https://openalex.org/A5051559408","display_name":"Jeremy F. Villalobos","orcid":null},"institutions":[{"id":"https://openalex.org/I102149020","display_name":"University of North Carolina at Charlotte","ror":"https://ror.org/04dawnj30","country_code":"US","type":"education","lineage":["https://openalex.org/I102149020"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Jeremy Villalobos","raw_affiliation_strings":["Formerly of University of North Carolina Charlotte, Charlotte, NC, USA"],"affiliations":[{"raw_affiliation_string":"Formerly of University of North Carolina Charlotte, Charlotte, NC, USA","institution_ids":["https://openalex.org/I102149020"]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5016664214","display_name":"Clayton Ferner","orcid":"https://orcid.org/0000-0002-7822-6267"},"institutions":[{"id":"https://openalex.org/I153901656","display_name":"University of North Carolina Wilmington","ror":"https://ror.org/02t0qr014","country_code":"US","type":"education","lineage":["https://openalex.org/I153901656"]}],"countries":["US"],"is_corresponding":false,"raw_author_name":"Clayton Ferner","raw_affiliation_strings":["University of North Carolina Wilmington, Wilmington, NC, USA"],"affiliations":[{"raw_affiliation_string":"University of North Carolina Wilmington, Wilmington, NC, USA","institution_ids":["https://openalex.org/I153901656"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":3,"corresponding_author_ids":["https://openalex.org/A5113740134"],"corresponding_institution_ids":["https://openalex.org/I102149020"],"apc_list":null,"apc_paid":null,"fwci":3.987,"has_fulltext":false,"cited_by_count":18,"citation_normalized_percentile":{"value":0.94470385,"is_in_top_1_percent":false,"is_in_top_10_percent":true},"cited_by_percentile_year":{"min":89,"max":98},"biblio":{"volume":null,"issue":null,"first_page":"409","last_page":"414"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10715","display_name":"Distributed and Parallel Computing Systems","score":0.9998000264167786,"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/T10715","display_name":"Distributed and Parallel Computing Systems","score":0.9998000264167786,"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/T10054","display_name":"Parallel Computing and Optimization Techniques","score":0.9986000061035156,"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/T11181","display_name":"Advanced Data Storage Technologies","score":0.993399977684021,"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.8243611454963684},{"id":"https://openalex.org/keywords/parallel-computing","display_name":"Parallel computing","score":0.5739314556121826},{"id":"https://openalex.org/keywords/distributed-computing","display_name":"Distributed computing","score":0.4702759385108948},{"id":"https://openalex.org/keywords/programming-paradigm","display_name":"Programming paradigm","score":0.4249823987483978},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.34963858127593994}],"concepts":[{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8243611454963684},{"id":"https://openalex.org/C173608175","wikidata":"https://www.wikidata.org/wiki/Q232661","display_name":"Parallel computing","level":1,"score":0.5739314556121826},{"id":"https://openalex.org/C120314980","wikidata":"https://www.wikidata.org/wiki/Q180634","display_name":"Distributed computing","level":1,"score":0.4702759385108948},{"id":"https://openalex.org/C34165917","wikidata":"https://www.wikidata.org/wiki/Q188267","display_name":"Programming paradigm","level":2,"score":0.4249823987483978},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.34963858127593994}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1145/2445196.2445319","is_oa":false,"landing_page_url":"https://doi.org/10.1145/2445196.2445319","pdf_url":null,"source":null,"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Proceeding of the 44th ACM technical symposium on Computer science education","raw_type":"proceedings-article"}],"best_oa_location":null,"sustainable_development_goals":[{"score":0.5099999904632568,"display_name":"Industry, innovation and infrastructure","id":"https://metadata.un.org/sdg/9"}],"awards":[],"funders":[{"id":"https://openalex.org/F4320306076","display_name":"National Science Foundation","ror":"https://ror.org/021nxhr62"}],"has_content":{"grobid_xml":false,"pdf":false},"content_urls":null,"referenced_works_count":14,"referenced_works":["https://openalex.org/W66557379","https://openalex.org/W189545204","https://openalex.org/W1524429156","https://openalex.org/W1545099940","https://openalex.org/W1578415644","https://openalex.org/W1979841749","https://openalex.org/W2007200460","https://openalex.org/W2012891388","https://openalex.org/W2035704953","https://openalex.org/W2337491902","https://openalex.org/W2622427009","https://openalex.org/W4210826129","https://openalex.org/W4285719527","https://openalex.org/W4302374855"],"related_works":["https://openalex.org/W1513409726","https://openalex.org/W2379699742","https://openalex.org/W2369207165","https://openalex.org/W2117014006","https://openalex.org/W2370911386","https://openalex.org/W2358725432","https://openalex.org/W1604148295","https://openalex.org/W2354106728","https://openalex.org/W164750744","https://openalex.org/W1966767581"],"abstract_inverted_index":{"In":[0],"this":[1],"paper,":[2],"we":[3],"describe":[4],"an":[5],"approach":[6],"for":[7,28],"teaching":[8],"parallel":[9,29,33,87],"and":[10,31,36,75,78,99],"distributed":[11,49],"computing":[12],"at":[13],"the":[14,53],"undergraduate":[15,86],"level":[16,60],"using":[17,96],"computational":[18],"patterns.":[19,105],"The":[20],"goal":[21],"is":[22],"to":[23,46,55,90],"promote":[24],"higher-level":[25],"structured":[26],"design":[27],"programming":[30,34,41,88],"make":[32],"easier":[35],"more":[37],"scalable.":[38],"A":[39],"pattern":[40,94],"framework":[42,98],"has":[43],"been":[44,69],"developed":[45],"create":[47],"a":[48,83,93,101],"application":[50],"that":[51],"avoids":[52],"need":[54],"write":[56],"code":[57],"in":[58],"low":[59],"message--passing":[61],"APIs":[62],"such":[63],"as":[64],"MPI.":[65],"Several":[66],"patterns":[67],"have":[68,81],"implemented":[70],"including":[71],"workpool,":[72],"pipeline,":[73],"synchronous":[74],"iterative":[76],"all-to-all,":[77],"stencil.":[79],"We":[80],"redesigned":[82],"regular":[84],"senior":[85],"course":[89],"begin":[91],"with":[92],"strategy":[95],"our":[97],"provide":[100],"detailed":[102],"syllabus":[103],"around":[104]},"counts_by_year":[{"year":2023,"cited_by_count":2},{"year":2021,"cited_by_count":1},{"year":2020,"cited_by_count":2},{"year":2019,"cited_by_count":2},{"year":2016,"cited_by_count":2},{"year":2015,"cited_by_count":5},{"year":2014,"cited_by_count":3},{"year":2013,"cited_by_count":1}],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2025-10-10T00:00:00"}
