{"id":"https://openalex.org/W4318617421","doi":"https://doi.org/10.1145/3580373","title":"Tridigpu: A GPU Library for Block Tridiagonal and Banded Linear Equation Systems","display_name":"Tridigpu: A GPU Library for Block Tridiagonal and Banded Linear Equation Systems","publication_year":2023,"publication_date":"2023-01-31","ids":{"openalex":"https://openalex.org/W4318617421","doi":"https://doi.org/10.1145/3580373"},"language":"en","primary_location":{"id":"doi:10.1145/3580373","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3580373","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3580373","source":{"id":"https://openalex.org/S2483380313","display_name":"ACM Transactions on Parallel Computing","issn_l":"2329-4949","issn":["2329-4949","2329-4957"],"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":"ACM Transactions on Parallel Computing","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/3580373","any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5007464024","display_name":"Christoph Klein","orcid":"https://orcid.org/0000-0003-2019-6074"},"institutions":[],"countries":[],"is_corresponding":true,"raw_author_name":"Christoph Klein","raw_affiliation_strings":["Institute of Computer Engineering (ZITI), Heidelberg, Germany"],"affiliations":[{"raw_affiliation_string":"Institute of Computer Engineering (ZITI), Heidelberg, Germany","institution_ids":[]}]},{"author_position":"last","author":{"id":"https://openalex.org/A5047006398","display_name":"Robert Strzodka","orcid":"https://orcid.org/0000-0003-0468-0472"},"institutions":[],"countries":[],"is_corresponding":false,"raw_author_name":"Robert Strzodka","raw_affiliation_strings":["Institute of Computer Engineering (ZITI), Heidelberg, Germany"],"affiliations":[{"raw_affiliation_string":"Institute of Computer Engineering (ZITI), Heidelberg, Germany","institution_ids":[]}]}],"institutions":[],"countries_distinct_count":0,"institutions_distinct_count":2,"corresponding_author_ids":["https://openalex.org/A5007464024"],"corresponding_institution_ids":[],"apc_list":null,"apc_paid":null,"fwci":0.2017,"has_fulltext":true,"cited_by_count":1,"citation_normalized_percentile":{"value":0.4899019,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":{"min":91,"max":95},"biblio":{"volume":"10","issue":"1","first_page":"1","last_page":"33"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T10792","display_name":"Matrix Theory and Algorithms","score":0.9997000098228455,"subfield":{"id":"https://openalex.org/subfields/1703","display_name":"Computational Theory and Mathematics"},"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/T10792","display_name":"Matrix Theory and Algorithms","score":0.9997000098228455,"subfield":{"id":"https://openalex.org/subfields/1703","display_name":"Computational Theory and Mathematics"},"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/T10339","display_name":"Advanced Numerical Methods in Computational Mathematics","score":0.9991000294685364,"subfield":{"id":"https://openalex.org/subfields/2206","display_name":"Computational Mechanics"},"field":{"id":"https://openalex.org/fields/22","display_name":"Engineering"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},{"id":"https://openalex.org/T11416","display_name":"Numerical methods for differential equations","score":0.9965000152587891,"subfield":{"id":"https://openalex.org/subfields/2612","display_name":"Numerical Analysis"},"field":{"id":"https://openalex.org/fields/26","display_name":"Mathematics"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}}],"keywords":[{"id":"https://openalex.org/keywords/tridiagonal-matrix","display_name":"Tridiagonal matrix","score":0.9518715143203735},{"id":"https://openalex.org/keywords/parallel-computing","display_name":"Parallel computing","score":0.6308103799819946},{"id":"https://openalex.org/keywords/scalar","display_name":"Scalar (mathematics)","score":0.6297568082809448},{"id":"https://openalex.org/keywords/solver","display_name":"Solver","score":0.6217654347419739},{"id":"https://openalex.org/keywords/factorization","display_name":"Factorization","score":0.6209092140197754},{"id":"https://openalex.org/keywords/block","display_name":"Block (permutation group theory)","score":0.5834490656852722},{"id":"https://openalex.org/keywords/cuda","display_name":"CUDA","score":0.5793336629867554},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.5503184795379639},{"id":"https://openalex.org/keywords/linear-system","display_name":"Linear system","score":0.5338687896728516},{"id":"https://openalex.org/keywords/block-size","display_name":"Block size","score":0.49885058403015137},{"id":"https://openalex.org/keywords/tridiagonal-matrix-algorithm","display_name":"Tridiagonal matrix algorithm","score":0.44885727763175964},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.3318057060241699},{"id":"https://openalex.org/keywords/algorithm","display_name":"Algorithm","score":0.2933882772922516},{"id":"https://openalex.org/keywords/combinatorics","display_name":"Combinatorics","score":0.09358400106430054},{"id":"https://openalex.org/keywords/physics","display_name":"Physics","score":0.08867087960243225},{"id":"https://openalex.org/keywords/mathematical-analysis","display_name":"Mathematical analysis","score":0.07301446795463562},{"id":"https://openalex.org/keywords/geometry","display_name":"Geometry","score":0.06243675947189331},{"id":"https://openalex.org/keywords/eigenvalues-and-eigenvectors","display_name":"Eigenvalues and eigenvectors","score":0.0504266619682312}],"concepts":[{"id":"https://openalex.org/C51647924","wikidata":"https://www.wikidata.org/wiki/Q1755277","display_name":"Tridiagonal matrix","level":3,"score":0.9518715143203735},{"id":"https://openalex.org/C173608175","wikidata":"https://www.wikidata.org/wiki/Q232661","display_name":"Parallel computing","level":1,"score":0.6308103799819946},{"id":"https://openalex.org/C57691317","wikidata":"https://www.wikidata.org/wiki/Q1289248","display_name":"Scalar (mathematics)","level":2,"score":0.6297568082809448},{"id":"https://openalex.org/C2778770139","wikidata":"https://www.wikidata.org/wiki/Q1966904","display_name":"Solver","level":2,"score":0.6217654347419739},{"id":"https://openalex.org/C187834632","wikidata":"https://www.wikidata.org/wiki/Q188804","display_name":"Factorization","level":2,"score":0.6209092140197754},{"id":"https://openalex.org/C2777210771","wikidata":"https://www.wikidata.org/wiki/Q4927124","display_name":"Block (permutation group theory)","level":2,"score":0.5834490656852722},{"id":"https://openalex.org/C2778119891","wikidata":"https://www.wikidata.org/wiki/Q477690","display_name":"CUDA","level":2,"score":0.5793336629867554},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.5503184795379639},{"id":"https://openalex.org/C6802819","wikidata":"https://www.wikidata.org/wiki/Q1072174","display_name":"Linear system","level":2,"score":0.5338687896728516},{"id":"https://openalex.org/C41431624","wikidata":"https://www.wikidata.org/wiki/Q1053357","display_name":"Block size","level":3,"score":0.49885058403015137},{"id":"https://openalex.org/C176603272","wikidata":"https://www.wikidata.org/wiki/Q1819156","display_name":"Tridiagonal matrix algorithm","level":4,"score":0.44885727763175964},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.3318057060241699},{"id":"https://openalex.org/C11413529","wikidata":"https://www.wikidata.org/wiki/Q8366","display_name":"Algorithm","level":1,"score":0.2933882772922516},{"id":"https://openalex.org/C114614502","wikidata":"https://www.wikidata.org/wiki/Q76592","display_name":"Combinatorics","level":1,"score":0.09358400106430054},{"id":"https://openalex.org/C121332964","wikidata":"https://www.wikidata.org/wiki/Q413","display_name":"Physics","level":0,"score":0.08867087960243225},{"id":"https://openalex.org/C134306372","wikidata":"https://www.wikidata.org/wiki/Q7754","display_name":"Mathematical analysis","level":1,"score":0.07301446795463562},{"id":"https://openalex.org/C2524010","wikidata":"https://www.wikidata.org/wiki/Q8087","display_name":"Geometry","level":1,"score":0.06243675947189331},{"id":"https://openalex.org/C158693339","wikidata":"https://www.wikidata.org/wiki/Q190524","display_name":"Eigenvalues and eigenvectors","level":2,"score":0.0504266619682312},{"id":"https://openalex.org/C62520636","wikidata":"https://www.wikidata.org/wiki/Q944","display_name":"Quantum mechanics","level":1,"score":0.0},{"id":"https://openalex.org/C38652104","wikidata":"https://www.wikidata.org/wiki/Q3510521","display_name":"Computer security","level":1,"score":0.0},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.0},{"id":"https://openalex.org/C26517878","wikidata":"https://www.wikidata.org/wiki/Q228039","display_name":"Key (lock)","level":2,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1145/3580373","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3580373","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3580373","source":{"id":"https://openalex.org/S2483380313","display_name":"ACM Transactions on Parallel Computing","issn_l":"2329-4949","issn":["2329-4949","2329-4957"],"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":"ACM Transactions on Parallel Computing","raw_type":"journal-article"}],"best_oa_location":{"id":"doi:10.1145/3580373","is_oa":true,"landing_page_url":"https://doi.org/10.1145/3580373","pdf_url":"https://dl.acm.org/doi/pdf/10.1145/3580373","source":{"id":"https://openalex.org/S2483380313","display_name":"ACM Transactions on Parallel Computing","issn_l":"2329-4949","issn":["2329-4949","2329-4957"],"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":"ACM Transactions on Parallel Computing","raw_type":"journal-article"},"sustainable_development_goals":[{"display_name":"Affordable and clean energy","score":0.5299999713897705,"id":"https://metadata.un.org/sdg/7"}],"awards":[],"funders":[],"has_content":{"pdf":true,"grobid_xml":true},"content_urls":{"pdf":"https://content.openalex.org/works/W4318617421.pdf","grobid_xml":"https://content.openalex.org/works/W4318617421.grobid-xml"},"referenced_works_count":33,"referenced_works":["https://openalex.org/W1629601946","https://openalex.org/W1974312429","https://openalex.org/W1990523337","https://openalex.org/W2018580582","https://openalex.org/W2033330000","https://openalex.org/W2035080386","https://openalex.org/W2036506377","https://openalex.org/W2043990347","https://openalex.org/W2045312373","https://openalex.org/W2047610878","https://openalex.org/W2058942559","https://openalex.org/W2098588961","https://openalex.org/W2102512593","https://openalex.org/W2113264898","https://openalex.org/W2141524575","https://openalex.org/W2161456019","https://openalex.org/W2278832816","https://openalex.org/W2319890895","https://openalex.org/W2342186056","https://openalex.org/W2461005004","https://openalex.org/W2621185017","https://openalex.org/W2731702594","https://openalex.org/W2738229363","https://openalex.org/W2806238950","https://openalex.org/W2883920724","https://openalex.org/W2899467728","https://openalex.org/W2966915191","https://openalex.org/W3013265033","https://openalex.org/W3107663002","https://openalex.org/W3159846083","https://openalex.org/W3188072034","https://openalex.org/W3204062674","https://openalex.org/W4239609053"],"related_works":["https://openalex.org/W3000091026","https://openalex.org/W808639126","https://openalex.org/W2047610878","https://openalex.org/W114476064","https://openalex.org/W2141339934","https://openalex.org/W2136415956","https://openalex.org/W2736602477","https://openalex.org/W2890252961","https://openalex.org/W2016422608","https://openalex.org/W4318617421"],"abstract_inverted_index":{"In":[0],"this":[1],"article,":[2],"we":[3,64],"present":[4],"a":[5,9,171],"CUDA":[6],"library":[7,24,95],"with":[8,30,45,60],"C":[10],"API":[11],"for":[12,73,100,114,162],"solving":[13],"block":[14,27,31,55],"cyclic":[15],"tridiagonal":[16,28,134,153],"and":[17,42,50,58,87,112,121],"banded":[18,43],"systems":[19,29,44,141],"on":[20,170],"one":[21],"GPU.":[22],"The":[23,124,147],"can":[25],"process":[26],"sizes":[32,165],"from":[33],"1":[34,36],"\u00d7":[35,40],"(scalar)":[37],"to":[38,47,70,81,143],"4":[39,41],"up":[46,142],"four":[48],"sub-":[49],"superdiagonals.":[51],"For":[52],"the":[53,74,77,84,89,94,132,138,150],"compute-intensive":[54],"size":[56],"cases":[57,59],"many":[61],"right-hand":[62,119],"sides,":[63],"write":[65],"out":[66],"an":[67],"explicit":[68],"factorization":[69],"memory;":[71],"however,":[72],"scalar":[75,152],"case,":[76],"fastest":[78],"approach":[79],"is":[80,128,157],"only":[82,129],"output":[83],"coarse":[85],"system":[86],"recompute":[88],"factorization.":[90],"Prominent":[91],"features":[92],"of":[93,131,140,149,155,166],"are":[96],"(scaled)":[97],"partial":[98],"pivoting":[99],"improved":[101],"numeric":[102],"stability;":[103],"highest-performance":[104],"kernels,":[105],"which":[106,136],"completely":[107],"utilize":[108],"GPU":[109,144],"memory":[110,126,145],"bandwidth;":[111],"support":[113],"multiple":[115],"sparse":[116],"or":[117],"dense":[118],"side":[120],"solution":[122,139],"vectors.":[123],"additional":[125],"consumption":[127],"5%":[130],"original":[133],"system,":[135],"enables":[137],"size.":[146],"performance":[148],"state-of-the-art":[151],"solver":[154],"cuSPARSE":[156],"outperformed":[158],"by":[159],"factor":[160],"5":[161],"large":[163],"problem":[164],"2":[167],"25":[168],"unknowns,":[169],"GeForce":[172],"RTX":[173],"2080":[174],"Ti.":[175]},"counts_by_year":[{"year":2025,"cited_by_count":1}],"updated_date":"2025-11-06T03:46:38.306776","created_date":"2025-10-10T00:00:00"}
