{"id":29,"date":"2017-01-09T16:42:34","date_gmt":"2017-01-09T16:42:34","guid":{"rendered":"http:\/\/www.sqrlab.ca\/csci4060u\/?page_id=29"},"modified":"2020-04-01T14:19:45","modified_gmt":"2020-04-01T14:19:45","slug":"resources-links","status":"publish","type":"page","link":"http:\/\/www.sqrlab.ca\/csci4060u\/resources-links\/","title":{"rendered":"Resources &#038; Links"},"content":{"rendered":"<p><strong>General Multicore &amp; Many-core<\/strong><\/p>\n<ul>\n<li><a href=\"https:\/\/blogs.nvidia.com\/blog\/2009\/12\/16\/whats-the-difference-between-a-cpu-and-a-gpu\/\">What&#8217;s the Difference Between a CPU and a GPU?<\/a><\/li>\n<li><a href=\"http:\/\/www.futurechips.org\/tips-for-power-coders\/parallel-programming.html\">What Makes Parallel Programming Hard?<\/a><\/li>\n<li><a href=\"http:\/\/www.gotw.ca\/publications\/concurrency-ddj.htm\">The Free Lunch Is Over: A Fundamental Turn Toward Concurrency in Software<\/a><\/li>\n<\/ul>\n<p><strong>C Programming<\/strong><\/p>\n<ul>\n<li><a href=\"https:\/\/matt.sh\/howto-c\">How to C (as of 2016)<\/a><\/li>\n<li><a href=\"https:\/\/web.stanford.edu\/~nwh\/cme212\/files\/c-refcard.pdf\">C Reference Card<\/a><\/li>\n<li><a href=\"https:\/\/www.gnu.org\/software\/gnu-c-manual\/gnu-c-manual.pdf\">The GNU C Reference Manual<\/a><\/li>\n<li><a href=\"http:\/\/cslibrary.stanford.edu\/101\/EssentialC.pdf\">Essential C<\/a><\/li>\n<\/ul>\n<p><strong>OpenMP<\/strong><\/p>\n<ul>\n<li><a href=\"http:\/\/www.openmp.org\/\">OpenMP.org<\/a><\/li>\n<li><a href=\"http:\/\/www.openmp.org\/wp-content\/uploads\/openmp-4.5.pdf\">OpenMP Application Programming Interface<\/a>&nbsp;and&nbsp;<a href=\"http:\/\/www.openmp.org\/wp-content\/uploads\/openmp-examples-4.0.2.pdf\">Examples<\/a><\/li>\n<li><a href=\"http:\/\/www.openmp.org\/wp-content\/uploads\/Intro_To_OpenMP_Mattson.pdf\">A \u201cHands-on\u201d Introduction to OpenMP<\/a><\/li>\n<li><a href=\"https:\/\/computing.llnl.gov\/tutorials\/openMP\/\">OpenMP Tutorial<\/a><\/li>\n<li><a href=\"http:\/\/bisqwit.iki.fi\/story\/howto\/openmp\/\">A Guide into OpenMP: Easy multithreading programming for C++<\/a><\/li>\n<li><a href=\"http:\/\/jakascorner.com\/blog\/2016\/07\/omp-barrier.html\">OpenMP: Barrier<\/a><\/li>\n<li><strong>Recommended textbook:<\/strong> <a href=\"https:\/\/mitpress.mit.edu\/books\/using-openmp\">Using OpenMP: Portable Shared Memory Parallel Programming<\/a>&nbsp;by&nbsp;Barbara Chapman, Gabriele Jost and Ruud van der Pas<br \/>\n<img decoding=\"async\" class=\"size-thumbnail wp-image-59 alignnone\" src=\"http:\/\/www.sqrlab.ca\/csci4060u\/wp-content\/uploads\/sites\/14\/2017\/01\/openmp.jpg\" alt=\"Using OpenMP book cover\" width=\"150\" srcset=\"http:\/\/www.sqrlab.ca\/csci4060u\/wp-content\/uploads\/sites\/14\/2017\/01\/openmp.jpg 444w, http:\/\/www.sqrlab.ca\/csci4060u\/wp-content\/uploads\/sites\/14\/2017\/01\/openmp-266x300.jpg 266w\" sizes=\"(max-width: 444px) 100vw, 444px\" \/><\/li>\n<\/ul>\n<p><strong>POSIX Threads<\/strong><\/p>\n<ul>\n<li><a href=\"https:\/\/computing.llnl.gov\/tutorials\/pthreads\/\">POSIX Threads Programming<\/a><\/li>\n<li><a href=\"https:\/\/gcc.gnu.org\/wiki\/cauldron2015?action=AttachFile&amp;do=get&amp;target=Torvald+Riegel_+Modern+concurrent+code+in+C.pdf\">Modern C\/C++ Concurrency<\/a><\/li>\n<\/ul>\n<p><strong>OpenCL<\/strong><\/p>\n<ul>\n<li><a href=\"https:\/\/www.khronos.org\/opencl\/\">OpenCL: The Open Standard for Parallel Programming of Heterogeneous Systems<\/a><\/li>\n<li><a href=\"https:\/\/www.khronos.org\/registry\/OpenCL\/sdk\/2.1\/docs\/man\/xhtml\/\">OpenCL Reference Pages<\/a><\/li>\n<li><a href=\"https:\/\/www.khronos.org\/files\/opencl21-reference-guide.pdf\">OpenCL Reference Card<\/a><\/li>\n<li><a href=\"https:\/\/www.khronos.org\/registry\/OpenCL\/specs\/opencl-2.0-openclc.pdf\">The OpenCL C Specification<\/a><\/li>\n<li><a href=\"http:\/\/developer.amd.com\/wordpress\/media\/2013\/07\/AMD_Accelerated_Parallel_Processing_OpenCL_Programming_Guide-rev-2.7.pdf\">OpenCL Programming Guide<\/a><\/li>\n<li><a href=\"https:\/\/streamcomputing.eu\/blog\/2016-04-05\/comparing-syntax-cuda-opencl-hip\/\">Comparing Syntax for CUDA, OpenCL and HiP<\/a><\/li>\n<li><a href=\"http:\/\/www.slideshare.net\/vladimirstarostenkov\/hands-on-opencl\">Hands On OpenCL<\/a><\/li>\n<li><a href=\"http:\/\/developer.amd.com\/partners\/university-programs\/\">OpenCL University Programs &amp; Resources<\/a> (from AMD)<\/li>\n<li><strong>Recommended textbook:<\/strong>&nbsp;<a href=\"https:\/\/www.elsevier.com\/books\/heterogeneous-computing-with-opencl\/gaster\/978-0-12-405894-1\">Heterogeneous Computing with OpenCL: Revised OpenCL 1.2 Edition<\/a> by&nbsp;Benedict Gaster, Lee Howes, David R. Kaeli, Perhaad Mistry, Dana Schaa <em>[Note a newer version of this book for OpenCL 2.0 is available but we will be covering OpenCL 1.2 in this course]<\/em><br \/>\n<img decoding=\"async\" class=\"alignnone wp-image-61\" src=\"http:\/\/www.sqrlab.ca\/csci4060u\/wp-content\/uploads\/sites\/14\/2017\/01\/opencl.jpg\" alt=\"Heterogeneous Computing with OpenCL book cover\" width=\"150\" srcset=\"http:\/\/www.sqrlab.ca\/csci4060u\/wp-content\/uploads\/sites\/14\/2017\/01\/opencl.jpg 260w, http:\/\/www.sqrlab.ca\/csci4060u\/wp-content\/uploads\/sites\/14\/2017\/01\/opencl-244x300.jpg 244w\" sizes=\"(max-width: 260px) 100vw, 260px\" \/><\/li>\n<\/ul>\n<p><strong>Java Concurrency<\/strong><\/p>\n<ul>\n<li><a href=\"http:\/\/docs.oracle.com\/javase\/tutorial\/essential\/concurrency\/\">The Java Tutorials &#8211; Concurrency<\/a><\/li>\n<li><a href=\"https:\/\/docs.oracle.com\/javase\/8\/docs\/api\/java\/lang\/Thread.html\">java.lang.thread<\/a>&nbsp;&#8211; Java thread objects with run, start, sleep, wait, notify, notifyAll, join methods and more. Also discussed synchronized method\/blocks and implicit monitor locks.<\/li>\n<li><a href=\"https:\/\/docs.oracle.com\/javase\/8\/docs\/api\/?java\/util\/concurrent\/package-summary.html\">java.util.concurrent<\/a>&nbsp;&#8211; Semaphore, CountDownLatch, CyclicBarrier, &nbsp;thread pools (e.g., ForkJoinPool), Java data structures (e.g., BlockingQueue, ConcurrentMap) and more<\/li>\n<li><a href=\"https:\/\/docs.oracle.com\/javase\/8\/docs\/api\/?java\/util\/concurrent\/atomic\/package-summary.html\">java.util.concurrent.atomic<\/a>&nbsp;&#8211; Java atomic variables including AtomicBoolean, AtomicInteger, AtomicIntegerArray, AtomicLong and more.<\/li>\n<li><a href=\"https:\/\/docs.oracle.com\/javase\/8\/docs\/api\/java\/util\/concurrent\/locks\/package-summary.html\">java.util.concurrent.locks<\/a> &#8211; Java locks<\/li>\n<\/ul>\n","protected":false},"excerpt":{"rendered":"<p>General Multicore &amp; Many-core What&#8217;s the Difference Between a CPU and a GPU? What Makes Parallel Programming Hard? The Free Lunch Is Over: A Fundamental Turn Toward Concurrency in Software C Programming How to C (as of 2016) C Reference &hellip; <a href=\"http:\/\/www.sqrlab.ca\/csci4060u\/resources-links\/\">Continue reading <span class=\"meta-nav\">&rarr;<\/span><\/a><\/p>\n","protected":false},"author":1,"featured_media":246,"parent":0,"menu_order":0,"comment_status":"closed","ping_status":"closed","template":"sidebar-page.php","meta":{"jetpack_post_was_ever_published":false,"footnotes":""},"class_list":["post-29","page","type-page","status-publish","has-post-thumbnail","hentry"],"jetpack_sharing_enabled":true,"jetpack_shortlink":"https:\/\/wp.me\/P739Pv-t","_links":{"self":[{"href":"http:\/\/www.sqrlab.ca\/csci4060u\/wp-json\/wp\/v2\/pages\/29","targetHints":{"allow":["GET"]}}],"collection":[{"href":"http:\/\/www.sqrlab.ca\/csci4060u\/wp-json\/wp\/v2\/pages"}],"about":[{"href":"http:\/\/www.sqrlab.ca\/csci4060u\/wp-json\/wp\/v2\/types\/page"}],"author":[{"embeddable":true,"href":"http:\/\/www.sqrlab.ca\/csci4060u\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"http:\/\/www.sqrlab.ca\/csci4060u\/wp-json\/wp\/v2\/comments?post=29"}],"version-history":[{"count":16,"href":"http:\/\/www.sqrlab.ca\/csci4060u\/wp-json\/wp\/v2\/pages\/29\/revisions"}],"predecessor-version":[{"id":252,"href":"http:\/\/www.sqrlab.ca\/csci4060u\/wp-json\/wp\/v2\/pages\/29\/revisions\/252"}],"wp:featuredmedia":[{"embeddable":true,"href":"http:\/\/www.sqrlab.ca\/csci4060u\/wp-json\/wp\/v2\/media\/246"}],"wp:attachment":[{"href":"http:\/\/www.sqrlab.ca\/csci4060u\/wp-json\/wp\/v2\/media?parent=29"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}