From 8e8995d2fcf524d6cc69a6a964c708e36f4ed919 Mon Sep 17 00:00:00 2001 From: jamesroutley Date: Mon, 23 Dec 2024 09:18:23 +0000 Subject: [PATCH] Build website (automatic) --- docs/index.html | 38 +- docs/log.txt | 76 +- docs/posts/cuda-moat-still-alive.html | 957 ------------------ .../in-praise-of-the-hundred-page-idea.html | 49 - ...r-data-infrastructure-in-one-ruby-gem.html | 332 ++++++ .../posts/long-term-software-development.html | 10 + ...-essays-of-michel-de-montaigne-online.html | 22 - ...-legacy-of-next-lives-on-in-os-x-2012.html | 405 ++++++++ ...l-report-and-twenty-twenty-five-goals.html | 2 +- ...ist-microblogging-service-for-hackers.html | 4 +- docs/posts/weeknotes-28.html | 2 +- .../what-s-making-me-happy-2024-12-21.html | 4 +- ...n-giant-hornet-from-the-united-states.html | 218 ++++ 13 files changed, 1028 insertions(+), 1091 deletions(-) delete mode 100644 docs/posts/cuda-moat-still-alive.html delete mode 100644 docs/posts/in-praise-of-the-hundred-page-idea.html create mode 100644 docs/posts/litestack-all-your-data-infrastructure-in-one-ruby-gem.html delete mode 100644 docs/posts/the-essays-of-michel-de-montaigne-online.html create mode 100644 docs/posts/the-legacy-of-next-lives-on-in-os-x-2012.html create mode 100644 docs/posts/wsda-usda-announce-eradication-of-northern-giant-hornet-from-the-united-states.html diff --git a/docs/index.html b/docs/index.html index fc41999584c..f7d01b4c983 100644 --- a/docs/index.html +++ b/docs/index.html @@ -18,7 +18,7 @@

News

  • - Ask HN: Predictions for 2025? (news.ycombinator.com) + WSDA, USDA announce eradication of northern giant hornet from the United States (agr.wa.gov)
  • @@ -27,7 +27,16 @@

    News

  • - Classified fighter jet specs leaked on War Thunder forums (ukdefencejournal.org.uk) + Litestack: All your data infrastructure, in one Ruby gem (github.com) +
  • + + + + + + +
  • + Ask HN: Predictions for 2025? (news.ycombinator.com)
  • @@ -36,7 +45,7 @@

    News

  • - CUDA Moat Still Alive (semianalysis.com) + Classified fighter jet specs leaked on War Thunder forums (ukdefencejournal.org.uk)
  • @@ -178,15 +187,6 @@

    News

    - -
  • - The essays of Michel de Montaigne online (hyperessays.net) -
  • - - - - -
  • A Brief Review of My Audio Plugins (tinylogger.com)
  • @@ -297,7 +297,7 @@

    News

  • - Go Developer Survey 2024 H2 Results (go.dev) + The legacy of NeXT lives on in OS X (2012) (arstechnica.com)
  • @@ -306,7 +306,7 @@

    News

  • - Holiday Planning Q+A (anewsletter.alisoneroman.com) + Go Developer Survey 2024 H2 Results (go.dev)
  • @@ -315,7 +315,7 @@

    News

  • - Engineering team growth part 7: Dealing with a growing organization (bjorg.bjornroche.com) + Holiday Planning Q+A (anewsletter.alisoneroman.com)
  • @@ -324,7 +324,7 @@

    News

  • - Bugasnoo: rock your baby to sleep with Lego (pepijndevos.nl) + Engineering team growth part 7: Dealing with a growing organization (bjorg.bjornroche.com)
  • @@ -333,7 +333,7 @@

    News

  • - Fractal Overdrive: An Aesthetic Evaluation of Numeric Error (cceckman.com) + Bugasnoo: rock your baby to sleep with Lego (pepijndevos.nl)
  • @@ -342,7 +342,7 @@

    News

  • - Why is multithreading Selenium lousy on MacOS? (mclare.blog) + Fractal Overdrive: An Aesthetic Evaluation of Numeric Error (cceckman.com)
  • @@ -351,7 +351,7 @@

    News

  • - In praise of the hundred page idea (tracydurnell.com) + Why is multithreading Selenium lousy on MacOS? (mclare.blog)
  • diff --git a/docs/log.txt b/docs/log.txt index e62ef31a3de..00cce12afae 100644 --- a/docs/log.txt +++ b/docs/log.txt @@ -1,38 +1,38 @@ -2024/12/23 08:22:08 error parsing https://highgrowthengineering.substack.com/feed: http error: 403 Forbidden -2024/12/23 08:22:08 Fetched posts from https://highgrowthengineering.substack.com/feed, took 43.677135ms -2024/12/23 08:22:08 Fetched posts from https://macwright.com/rss.xml, took 49.301103ms -2024/12/23 08:22:08 error parsing https://mikehudack.substack.com/feed: http error: 403 Forbidden -2024/12/23 08:22:08 Fetched posts from https://mikehudack.substack.com/feed, took 52.633295ms -2024/12/23 08:22:08 error parsing https://themargins.substack.com/feed.xml: http error: 403 Forbidden -2024/12/23 08:22:08 Fetched posts from https://themargins.substack.com/feed.xml, took 67.990097ms -2024/12/23 08:22:08 Fetched posts from https://www.slowernews.com/rss.xml, took 94.332132ms -2024/12/23 08:22:08 Fetched posts from https://www.benkuhn.net/index.xml, took 140.668017ms -2024/12/23 08:22:08 Fetched posts from https://anewsletter.alisoneroman.com/feed, took 150.191045ms -2024/12/23 08:22:08 Fetched posts from https://twobithistory.org/feed.xml, took 163.175586ms -2024/12/23 08:22:08 Fetched posts from https://joy.recurse.com/feed.atom, took 179.093106ms -2024/12/23 08:22:08 Fetched posts from https://danluu.com/atom.xml, took 266.049717ms -2024/12/23 08:22:08 Fetched posts from https://blog.golang.org/feed.atom?format=xml, took 282.538918ms -2024/12/23 08:22:08 Fetched posts from https://scattered-thoughts.net/rss.xml, took 411.114171ms -2024/12/23 08:22:08 Fetched posts from https://www.wildlondon.org.uk/blog/all/rss.xml, took 536.169554ms -2024/12/23 08:22:08 Fetched posts from https://blog.veitheller.de/feed.rss, took 671.031137ms -2024/12/23 08:22:09 Fetched posts from https://routley.io/reserialised/great-expectations/2022-08-24/index.xml, took 829.758223ms -2024/12/23 08:22:09 Fetched posts from https://solar.lowtechmagazine.com/feeds/all-en.atom.xml, took 996.227273ms -2024/12/23 08:22:09 Fetched posts from http://tonsky.me/blog/atom.xml, took 1.083871475s -2024/12/23 08:22:09 Get "https://www.npr.org/2024/12/22/nx-s1-5233033/holidays-loneliness-cure-stammtisch": stream error: stream ID 1; INTERNAL_ERROR; received from peer -2024/12/23 08:22:10 Fetched posts from https://commoncog.com/blog/rss/, took 1.782785436s -2024/12/23 08:22:10 Content still empty after HTML reader: http://tinylogger.com/max/wnTJ9xu3fw5UiXLp -2024/12/23 08:22:11 Fetched posts from https://gochugarugirl.com/feed/, took 2.962818395s -2024/12/23 08:22:12 Content still empty after HTML reader: https://codemic.io/ -2024/12/23 08:22:13 Content still empty after HTML reader: https://clarionsong.substack.com/p/intention-setting -2024/12/23 08:22:13 Fetched posts from https://hnrss.org/frontpage?points=50, took 5.12540691s -2024/12/23 08:22:14 Content still empty after HTML reader: http://tinylogger.com/max/4GfJDcuv32uMVeSy -2024/12/23 08:22:14 Fetched posts from https://blaggregator.recurse.com/atom.xml?token=4c4c4e40044244aab4a36e681dfb8fb0, took 6.376349952s -2024/12/23 08:22:18 error parsing https://jvns.ca/atom.xml: Get "https://jvns.ca/atom.xml": net/http: TLS handshake timeout -2024/12/23 08:22:18 Fetched posts from https://jvns.ca/atom.xml, took 10.104439463s -2024/12/23 08:22:38 error parsing https://rachelbythebay.com/w/atom.xml: Get "https://rachelbythebay.com/w/atom.xml": dial tcp 216.218.228.215:443: i/o timeout -2024/12/23 08:22:38 Fetched posts from https://rachelbythebay.com/w/atom.xml, took 30.006632693s -2024/12/23 08:22:38 Skipping writing post, no content: https://codemic.io/ -2024/12/23 08:22:38 Skipping writing post, no content: http://tinylogger.com/max/wnTJ9xu3fw5UiXLp -2024/12/23 08:22:38 Skipping writing post, no content: https://clarionsong.substack.com/p/intention-setting -2024/12/23 08:22:38 Skipping writing post, no content: http://tinylogger.com/max/4GfJDcuv32uMVeSy -2024/12/23 08:22:38 Templated 52 posts, took 6.74902ms +2024/12/23 09:17:53 error parsing https://mikehudack.substack.com/feed: http error: 403 Forbidden +2024/12/23 09:17:53 Fetched posts from https://mikehudack.substack.com/feed, took 34.673993ms +2024/12/23 09:17:53 error parsing https://themargins.substack.com/feed.xml: http error: 403 Forbidden +2024/12/23 09:17:53 Fetched posts from https://themargins.substack.com/feed.xml, took 35.035278ms +2024/12/23 09:17:53 Fetched posts from https://macwright.com/rss.xml, took 39.240961ms +2024/12/23 09:17:53 Fetched posts from https://www.benkuhn.net/index.xml, took 71.067846ms +2024/12/23 09:17:53 error parsing https://highgrowthengineering.substack.com/feed: http error: 403 Forbidden +2024/12/23 09:17:53 Fetched posts from https://highgrowthengineering.substack.com/feed, took 102.613957ms +2024/12/23 09:17:53 Fetched posts from https://anewsletter.alisoneroman.com/feed, took 107.556396ms +2024/12/23 09:17:53 error parsing https://www.slowernews.com/rss.xml: Get "https://www.slowernews.com/rss.xml": read tcp 10.1.0.120:38800->100.28.201.155:443: read: connection reset by peer +2024/12/23 09:17:53 Fetched posts from https://www.slowernews.com/rss.xml, took 143.776199ms +2024/12/23 09:17:53 Fetched posts from https://twobithistory.org/feed.xml, took 149.480029ms +2024/12/23 09:17:53 Fetched posts from https://joy.recurse.com/feed.atom, took 204.579519ms +2024/12/23 09:17:53 Fetched posts from https://www.wildlondon.org.uk/blog/all/rss.xml, took 221.254297ms +2024/12/23 09:17:53 Fetched posts from https://danluu.com/atom.xml, took 271.078125ms +2024/12/23 09:17:53 Fetched posts from https://scattered-thoughts.net/rss.xml, took 318.182933ms +2024/12/23 09:17:53 Fetched posts from https://blog.golang.org/feed.atom?format=xml, took 334.718742ms +2024/12/23 09:17:53 Fetched posts from https://routley.io/reserialised/great-expectations/2022-08-24/index.xml, took 364.633704ms +2024/12/23 09:17:54 Fetched posts from https://blog.veitheller.de/feed.rss, took 571.925726ms +2024/12/23 09:17:54 Fetched posts from http://tonsky.me/blog/atom.xml, took 950.17064ms +2024/12/23 09:17:54 Fetched posts from https://solar.lowtechmagazine.com/feeds/all-en.atom.xml, took 955.785549ms +2024/12/23 09:17:55 Fetched posts from https://commoncog.com/blog/rss/, took 2.066935889s +2024/12/23 09:17:55 Fetched posts from https://jvns.ca/atom.xml, took 2.14649951s +2024/12/23 09:17:55 Content still empty after HTML reader: http://tinylogger.com/max/wnTJ9xu3fw5UiXLp +2024/12/23 09:17:55 Get "https://www.npr.org/2024/12/22/nx-s1-5233033/holidays-loneliness-cure-stammtisch": stream error: stream ID 1; INTERNAL_ERROR; received from peer +2024/12/23 09:17:56 Fetched posts from https://gochugarugirl.com/feed/, took 2.607833032s +2024/12/23 09:17:58 Content still empty after HTML reader: https://clarionsong.substack.com/p/intention-setting +2024/12/23 09:17:58 Content still empty after HTML reader: https://codemic.io/ +2024/12/23 09:17:58 Fetched posts from https://hnrss.org/frontpage?points=50, took 5.335449888s +2024/12/23 09:17:59 Content still empty after HTML reader: http://tinylogger.com/max/4GfJDcuv32uMVeSy +2024/12/23 09:17:59 Fetched posts from https://blaggregator.recurse.com/atom.xml?token=4c4c4e40044244aab4a36e681dfb8fb0, took 5.986992159s +2024/12/23 09:18:23 error parsing https://rachelbythebay.com/w/atom.xml: Get "https://rachelbythebay.com/w/atom.xml": dial tcp 216.218.228.215:443: i/o timeout +2024/12/23 09:18:23 Fetched posts from https://rachelbythebay.com/w/atom.xml, took 30.006865147s +2024/12/23 09:18:23 Skipping writing post, no content: https://codemic.io/ +2024/12/23 09:18:23 Skipping writing post, no content: http://tinylogger.com/max/wnTJ9xu3fw5UiXLp +2024/12/23 09:18:23 Skipping writing post, no content: https://clarionsong.substack.com/p/intention-setting +2024/12/23 09:18:23 Skipping writing post, no content: http://tinylogger.com/max/4GfJDcuv32uMVeSy +2024/12/23 09:18:23 Templated 52 posts, took 8.348382ms diff --git a/docs/posts/cuda-moat-still-alive.html b/docs/posts/cuda-moat-still-alive.html deleted file mode 100644 index c54b28d39eb..00000000000 --- a/docs/posts/cuda-moat-still-alive.html +++ /dev/null @@ -1,957 +0,0 @@ - - - - - - - James Routley | Feed - - - - Back - Original -

    CUDA Moat Still Alive

    - -
    -

    Intro

    - - - -

    SemiAnalysis has been on a five-month long quest to settle the reality of MI300X. In theory, the MI300X should be at a huge advantage over Nvidia’s H100 and H200 in terms of specifications and Total Cost of Ownership (TCO). However, the reality is that the on paper specs as given below are not representative of performance that can be expected in a real-world environment. If AMD could deliver the below marketed performance with this memory, it would be a very strong competitor in the market. 

    - - - -
    Source: SemiAnalysis, Nvidia, AMD
    - - - -

    Today we are going to talk through our five-month journey conducting independent analysis and training-focused benchmarking of the MI300X, the H100 and the H200, engaging with both NVIDIA and AMD. We will do a detailed overview of the numerous low-level benchmarks that we ran, see the table of contents for summary. Furthermore, we will compare the total cost of ownership of Nvidia and AMD GPUs and factor in performance. Ultimately much of what we are doing is openly giving a comprehensive public recommendation to AMD on what they need to do to be competitive and fix their software issues after five months of submitting and squashing bugs. It’s not just that it’s immature software, they need to change how they do development. 

    - - - -

    In short, when comparing Nvidia’s GPUs to AMD’s MI300X, we found that the potential on paper advantage of the MI300X was not realized due to a lack within AMD public release software stack and the lack of testing from AMD.

    - - - -

    AMD’s software experience is riddled with bugs rendering out of the box training with AMD is impossible. We were hopeful that AMD could emerge as a strong competitor to NVIDIA in training workloads, but, as of today, this is unfortunately not the case. The CUDA moat has yet to be crossed by AMD due to AMD’s weaker-than-expected software Quality Assurance (QA) culture and its challenging out of the box experience. As fast as AMD tries to fill in the CUDA moat, NVIDIA engineers are working overtime to deepen said moat with new features, libraries, and performance updates.

    - - - -

    We shared benchmark source code and intermediate test results for GEMM benchmark and Single Node Training with both Nvidia and AMD and held calls and discussions to solicit feedback and implement improvements to the benchmarks, and we worked with AMD to implement bug fixes for the software stacks. 

    - - - -

    Our goal with this highly iterative interaction was to ensure that our tests are an unbiased evaluation of what real-world users would experience. 

    - - - -

    We initially planned to publish this article a few months ago but wanted to take the extra time to engage with the AMD team and explore possible fixes or development work. We spent a considerable time identifying and fixing AMD software bugs so that we could give AMD every chance to show MI300X unhindered by AMD software stack bugs as opposed to only showing problematic performance out of the box. To give a fair impression, we also explain the considerable amount of work on tuning and bug-squashing that it took to get there. We think this approach provides users with the best possible level of transparency.  

    - - - -

    We wanted to contribute in any way we could to try to improve the AMD ecosystem. Though AMD software is much better now due to our bug reports and tire-kicking, its public software stack still falls short. We have open-sourced many of the benchmarks and created simple one-liner commands to reproduce them.

    - - - -

    If Lisa Su and the AMD Leadership redouble their investment with a focus on their software and testing stack, they have a chance to be competitive with Nvidia on training. We think the engineers at AMD are extremely capable and are doing their best to advance the AMD ecosystem – and indeed support from these engineers in the form of bug fixes, configuration help and custom images improved the results we were able to get from the MI300X. 

    - - - -

    To bring our benchmarking process to a coda, on November 15th, 2024 we sent Nvidia and AMD a draft of most of our major GEMM and single node benchmarking code and results for comments, verification, and fine-tuning. We asked that any final comments, fixes, feedback and any performance improvements be submitted by November 25th. We set this time frame to crystallize test results to allow time to write an in-depth analysis and commentary and carry out multiple rounds of internal and external reviews, all steps that can take a variable and often unknowable amount of time, typically from 2-4 weeks. 

    - - - -

    A few days ago, after we informed both that we had confirmed an article publication date of December 20th, AMD requested that we delay publication to include results based on a beta WIP development build on an AMD developer’s branch. All of our benchmarking on Nvidia was conducted on publicly available stable release builds. In the spirit of transparency and fairness, we include these results as well as updated testing harness results on as the original November 25th deadline image and the latest publicly available software. However, we believe that the correct way to interpret the results is to look at the performance of the public stable release of AMD/Nvidia software. 

    - - - -

    Below are the list of software builds that we have used for benchmarking:

    - - - -
      -
    • H100 Public Stable Release – Out of Box experience for Nvidia H100.
    • - - - -
    • H200 Public Stable Release – Out of Box experience for Nvidia H200.
    • - - - -
    • MI300X Nov 25th Custom Build – This is a custom VIP docker image hand-crafted that builds all dependencies from source code written by AMD principal engineers.
    • - - - -
    • MI300X Stable Public Release PyTorch 2.5.1 – Out of Box experience for AMD MI300X.
    • - - - -
    • MI300X Public Nightly Dec 19th – This can indicate where AMD performance can be by January 2025, when PyTorch 2.6 is released, over 1 year after launch.
    • - - - -
    • MI300X Dec 21st WIP dev build – This is the image that AMD submitted to us after we agreed to delay publication of the article. It is an experimental development build that has not yet been merged into AMD’s internal main branch, and it does not use the native PyTorch flash attention API. Performance with this image can indicate where AMD public stable release performance will be in 1-2 quarters from now.
    • -
    - - - -

    We are very thankful for the technical support provided by AMD and Nvidia throughout this process, but we maintain our independence in the results we publish. We want to shout out to and thank our AMD counterparties, Anush Elangovan (AMD VP of AI), Hui Liu and many dozens of amazing AMD Principal/Senior engineers, AMD VPs of Engineering, AMD Engineering Fellows, AMD CVPs of Engineering and AMD Directors of Engineering, AMD Software Library Leads, for triaging and fixing our various bug reports. On the Nvidia side, we are grateful to Kedar Potdar, Ian Buck, Sylvain Jeaugey and the NCCL team from NVIDIA for their amazing support. 

    - - - -

    Thank you to CrusoeTensorWave (AMD Ventures Portco), NebiusLambdaHot Aisle and Sustainable Metal Cloud (SMC) / Firmus for the compute and for being supporters of open-source benchmarking. Crusoe, Nebius, SMC / Firmus and Lambda support managed SLURM and shared home directories out of the box. TensorWave currently has managed SLURM in beta and this feature will come to general availability (GA) at the start of next year. Sustainable Metal Cloud is one of the few neoclouds that has official MLPerf GPT-3 175B Training results.

    - - - -

    We will be releasing a follow up article on inferencing for the H100, H200 and MI300X. We may also release a follow-up article in a few months to follow up on AMD training performance to see if out of box experience has improved and test other models such as LlaVa & Mamba.

    - - - -
    Source: SemiAnalysis
    - - - -

    Key Findings

    - - - -
      -
    1. Comparing on paper FLOP/s and HBM Bandwidth/Capacity is akin to comparing cameras by merely examining megapixel count. The only way to tell the actual performance is to run benchmarking.
    2. - - - -
    3. Nvidia’s Out of the Box Performance & Experience is amazing, and we did not run into any Nvidia specific bugs during our benchmarks. Nvidia tasked a single engineer to us for technical support, but we didn’t run into any Nvidia software bugs as such we didn’t need much support.
    4. - - - -
    5. AMD’s Out of the Box Experience is very difficult to work with and can require considerable patience and elbow grease to move towards a usable state. On most of our benchmarks, Public AMD stable releases of AMD PyTorch is still broken and we needed workarounds.
    6. - - - -
    7. If we weren’t supported by multiple teams of AMD engineers triaging and fixing bugs in AMD software that we ran into, AMD’s results would have been much lower than Nvidia’s.
    8. - - - -
    9. We ran unofficial MLPerf Training GPT-3 175B on 256 H100 in collaboration with Sustainable Metal Cloud to test the effects of different VBoost setting
    10. - - - -
    11. For AMD, Real World Performance on public stable released software is nowhere close to its on paper marketed TFLOP/s. Nvidia’s real world performance also undershoots its marketing TFLOP/s, but not by nearly as much.
    12. - - - -
    13. The MI300X has a lower total cost of ownership (TCO) compared to the H100/H200, but training performance per TCO is worse on the MI300X on public stable releases of AMD software. This changes if one uses custom development builds of AMD software. 
    14. - - - -
    15. Training performance is weaker, as demonstrated by the MI300X ‘s matrix multiplication micro-benchmarks, and AMD public release software on single-node training throughput still lags that of Nvidia’s H100 and H200.
    16. - - - -
    17. MI300X performance is held back by AMD softwareAMD MI300X software on BF16 development branches have better performance but has not yet merged into the main branch of AMD’s internal repos. By the time it gets merged into the main branch and into the PyTorch stable release, Nvidia Blackwell will have already been available to everyone.
    18. - - - -
    19. AMD’s training performance is also held back as the MI300X does not deliver strong scale out performance. This is due to its weaker ROCm Compute Communication Library (RCCL) and AMD’s lower degree of vertical integration with networking and switching hardware compared to Nvidia’s strong integration of its Nvidia Collective Communications Library (NCCL), InfiniBand/Spectrum-X network fabric and switches.
    20. - - - -
    21. Many of AMD AI Libraries are forks of NVIDIA AI Libraries, leading to suboptimal outcomes and compatibility issues.
    22. - - - -
    23. AMD customers tend to use hand crafted kernels only for inference, which means their performance outside of very narrow well defined use cases is poor, and their flexibility to rapidly shifting workloads is non-existent.
    24. -
    - - - -

    Executive Recommendation to AMD

    - - - -

    We genuinely want to see another effective competitor to Nvidia and want to help AMD get to that spot, but, unfortunately, there is still much work to be done on that front. At the bottom of this article, we have a detailed list of feedback for the Lisa Su and the AMD Leadership Team, but provide a summary here:

    - - - -
      -
    1. Give AMD Engineers more compute and engineering resources to fix and improve the AMD ecosystem, they have very few internal gpu boxes relative to what Nvidia provides to their engineers. Tensorwave, the largest AMD GPU Cloud has given GPU time for free to a team at AMD to fix software issues, which is insane given they paid for the GPUs.
    2. - - - -
    3. AMD needs to hook up thousands more of MI300X, MI325X to PyTorch CI/CD for automated testing to ensure there is no AMD performance regressions & functional AMD bugs. Nvidia has given thousands of GPUs for PyTorch CI/CD to ensure an amazing out of box experience
    4. - - - -
    5. The AMD Executive Team should personally and intensively internally test (i.e., “dogfood”) products that are being shipped to the public rather than focus on testing internal builds. Preferably dogfood during livestream (twitch.tv) to show the authentic out of box experience. This is like how geohotz livestreams
    6. - - - -
    7. AMD should collaborate with Meta to get production LLM training workloads working as soon as possible on PyTorch ROCm, AMD’s answer to CUDA, as commonly, PyTorch code paths that Meta isn’t using have numerous bugs.
    8. - - - -
    9. Move away from over-reliance on properly setting numerous environment flags (up to dozens) to make an AMD deployment usable. Instead, bake these settings into the default configuration. Make the out of the box experience usable!
    10. - - - -
    11. Focus on making out of box experience good instead of over-reliance on custom VIP images that build all dependencies from source code main@specificcommit and take 5 hours to build.
    12. - - - -
    13. Stop expecting end users to use PYTORCH_TUNABLE_OPS which is a prototype buggy feature and is not respectful of the end users time as it takes ~1 hour for the end user to tune every time an end user wants to make any changes to their code. 
    14. - - - -
    15. AMD should submit MLPerf Training GPT-3 175B results. MLPerf is an apples-to-apples benchmarking methodology that uses time to convergence as the north star.
    16. - - - -
    17. We want AMD to be competitive and are open to meet with more detailed feedback on how to fix the AMD Datacenter GPU Ecosystem for the better.
    18. -
    - - - -

    A Summary of the AMD vs Nvidia Narrative

    - - - -

    Before we dive into various facets of AMD’s software stack that hold AMD back, we will discuss the MI300X’s basic specifications, its comparative total cost of ownership, and how most analysts and investors have evaluated its competitiveness.

    - - - -

    The MI300X launched in late 2023 with an exciting set of on paper specifications—featuring 1,307 TFLOP/s of FP16 compute (stronger than the H100’s 989 TFLOP/s), 5.3 TB/s of memory bandwidth, and 192GB of HBM3, 3.35 TB/s of memory bandwidth, and 80GB of HBM3. These specs outstrip those of the H200, which itself is, effectively, a memory-spec bumped version of the H100, delivering 4.8TB/s of memory bandwidth and 141GB of HBM3e. 

    - - - -
    Source: SemiAnalysis, Nvidia, AMD
    - - - -

    On paper total cost of ownership for an MI300X deployment is extremely compelling, not only due to the lower ASP of the MI300X, but also because it is typically deployed using cheaper Ethernet networking. Comparing a cluster of 16k H200s vs a 16k MI300X ethernet cluster leads to nearly 40% of the cost savings coming from networking alone, with the remainder of the savings from a lower accelerator cost. The use of Whitebox Ethernet switches is a substantial cost savings compared to using Nvidia’s Quantum-2 switches, but the real difference is cheaper transceivers, as Nvidia branded transceivers cost as much as 2-3x over what a typical transceiver OEM charges.

    - - - -

    At face value, the MI300X seems the best of both worlds: higher performance and lower total cost of ownership. At the time of its launch, it was logical to expect share gains to the underdog AMD from this compelling combination. The table below shows total upfront cluster capex – we present a more detailed breakdown of cluster capex components as well as a detailed networking BoM analysis in the sections at near the bottom of the article.

    - - - -
    Source: SemiAnalysis AI TCO Model
    - - - -

    As orders solidified, excitement built up for potential of the MI300X, helped along by bullish commentary and guidance from AMD. With a compelling spec advantage, it was easy to argue for further upside to AMD’s guidance, which most investors assumed management was sandbagging. AMD had a strong hand, in theory. After all they have mid-single digit market share in datacenter GPUs for 2024 and, logically, a glide path towards even 10-12% market share by 2027 could be conservative while offering considerable earnings upside for AMD.

    - - - - - - - -

    The earlier bullish line of reasoning was like purchasing a certain car model from a magazine without a test drive or soliciting feedback from owners of that model or reading any reviews. But fear not – SemiAnalysis has put the MI300X, H100, and H200 through their paces at scale and can show why AMD’s current software stack issues decisively disprove this line of reasoning. 

    - - - -

    General Matrix Multiply (GEMM) Performance

    - - - -

    Most FLOPS in a transformer-based architecture (i.e. ChatGPT, Llama, etc.) go towards matrix multiplication, also known as GEMMs. For this reason, GEMM performance is a good proxy for how well frontier transformers, such as ChatGPT, Llama, Claude, Grok, etc. will train on the hardware

    - - - -

    GEMMs take two input matrices, Matrix A and Matrix B, with Matrix A having the shape of (M, K), M rows and K columns, and Matrix B having the shape of (K,N) to produce an output matrix of shape (M,N). 

    - - - -
    Source: Nvidia
    - - - -

    Conceptually, each element of the resulting matrix is a sum of element-wise multiplications along the “K” dimension of the inputs. For this matter, the K dimension is also known as the reduction dimension.

    - - - -
    Source: SemiAnalysis
    - - - -

    Below, we have tested the following real-world shapes, given in the form (M,N,K)—which is short for multiplying a matrix of dimensions (M,K) and (K,N) together. 

    - - - -

    These following matrix shapes were actually used in Meta’s Llama 70B production training:

    - - - -
      -
    • (16384, 8192, 1280) – Fused QKV Projection GEMM shape
    • - - - -
    • (16384, 1024, 8192) – Attention Output Projection shape
    • - - - -
    • (16384, 8192, 7168) – FFN GEMM shape
    • - - - -
    • (16384, 3584, 8192) – FFN GEMM shape
    • - - - -
    • (8192, 8192, 8192) – Standard GEMM shape for benchmarking
    • -
    - - - -

    We used OpenAI’s do_bench function for the benchmark setup, an industry standard method of benchmarking PyTorch. The do_bench function provides cache clearing between runs as a default and provides ways to warmup and execute the benchmark multiple times, taking the median result as the given accuracy.  We used warmup=30 and rep=200 for these tests. Both input tensor A and B were randomly initialized with a normal distribution with mean 0 and variance 1. This is because a normal distribution comes the closest to matching the actual distribution of weights and activations in modern neural networks. The distribution of the input tensors will affect the results of the TFLOP/s performance benchmark. We will discuss the reasons why the input distribution effects TFLOP/s performance later in the article.

    - - - -

    For BF16, we can see that the H100 and H200 achieves roughly 720 TFLOP/s against their marketed 989.5 TFLOP/s, while the MI300X reaches a mere ~620 TFLOP/s compared with their marketed 1,307 TFLOP/s. 

    - - - -

    This means that, despite a much higher marketed BF16 TFLOP/s, the MI300X is 14% slower than the H100 and H200. This AMD result used a custom docker image that was hand crafted by an AMD principal engineer yet still achieved slower performance than Nvidia’s GPUs. For our out of the box testing of the MI300X, the TFLOP/s throughput even slower than this! In addition to a custom image, AMD also requires the user to set numerous environment flags that aren’t set by default to reach these performance results. 

    - - - -
    Source: SemiAnalysis
    - - - -

    Unfortunately, the story is worse for FP8. The H100/H200 achieves ~1,280 TFLOP/s out of the marketed 1979 TFLOP/s. The MI300X, in comparison, only reaches ~990 TFLOP/s. Thus, for FP8, the MI300X is 22% slower than H100. This is for both inputs being of the e4m3 FP8 (i.e. 4 exponent bits and 3 mantissa bits) datatype. 

    - - - -
    Source: SemiAnalysis
    - - - -

    It is important to note that calling GEMM is a simple task, and we shouldn’t expect to run into AMD software bugs. Unfortunately, a major bug that we encountered is that the torch.matmul and F.Linear APIs have been delivering different performances on AMD for a couple of months during the summer. One would expect the torch.matmul and F.Linear APIs to have the same performance, but, surprisingly, F.Linear is much slower!

    - - - -

    This is a strange bug as torch.matmul and F.Linear are both wrappers around the hardware vendor GEMM libraries, so they should achieve the same level of performance. F.Linear, in particular, is important, as this is the way most end users in PyTorch launch the GEMM kernels. 

    - - - -

    When we started testing AMD five months ago, the public AMD PyTorch still had this bug. The root cause was that AMD in fact has two different underlying GEMM libraries, rocBLAS and hipBLASLt, with HipBLASLt being more optimized for the MI300X. The bug was that torch.matmul uses the optimized hipBLASLt, but AMD had not changed F.Linear by default, leaving it to use the unoptimized rocBLAS library. 

    - - - -

    This major bug was ultimately fixed by AMD a few months ago after our bug reports, and we hope it doesn’t reappear due to a lack of proper regression testing. AMD’s usability could improve considerably if it boosted its testing efforts instead of waiting for users to discover these critical issues.

    - - - -

    We have open sourced the GEMM benchmark used in our tests into a simple three liner that anyone can easily run:

    - - - -
    Source: SemiAnalysis
    - - - - - - - -

    Recently, a benchmark has been floating around the internet that claims that, on GEMMs, AMD MI300X’s performance is close to that of the H100.

    - - - -
    Source: Github
    - - - -

    There are two main issues with the benchmark: it isn’t properly carrying out L2 Cache clearing and also is simply taking the max performance, instead of the median/mean TFLOP/s over the course of the iterations for a specific shape. Without L2 Cache clearing between iterations, the benchmark does not accurately reflect real-world GEMM performance. Furthermore, since the TFLOP/s change based on which iteration it is on, you need to use a mean/median over at least 100 iterations as the basis for an accurate GEMM benchmark. OpenAI’s do_bench provides L2 cache and mean/median out of the box by default, so we recommend that engineers use it for micro-benchmarking. Below, we have simplified the benchmark into pseudocode and have commented on the issues mentioned above.

    - - - -
    Source: SemiAnalysis
    - - - -

    HBM Memory Bandwidth Performance

    - - - -

    It is widely known that AMD MI300X has better memory bandwidth than the Nvidia H100 and H200, offering 5.3 TB/s of bandwidth vs 4.8 TB/s for the H200 and 3.35 TB/s for the H100. Improved HBM memory bandwidth is very useful in inferencing and is sometimes useful in training. In training, users can set a larger batch size if they have more HBM memory capacity and memory bandwidth. Although if a larger global batch size is used, after a certain size, the model will take longer to convergence. It is easy to run fast with big global batch size but at a high level, it will hurt time to convergence.

    - - - -

    From our HBM memory bandwidth benchmarking, we see that that MI300X indeed has way better memory bandwidth than both the H200 and the H100. We tested memory bandwidth in Pytorch with Tensor.copy_ & used the industry standard OpenAI do_bench to ensure accuracy.

    - - - -

    As you will see in our upcoming H100 vs H200 vs MI300X inference article, memory bandwidth is very important for inferencing.

    - - - -
    Source: SemiAnalysis
    - - - -
    Source: SemiAnalysis
    - - - -

    AMD Hand-Crafted VIP Custom Builds and WIP Development Builds

    - - - -

    The only reason we have been able to get AMD performance within 75% of H100/H200 performance is because we have been supported by multiple teams at AMD in fixing numerous AMD software bugs. To get AMD to a usable state with somewhat reasonable performance, a giant ~60 command Dockerfile that builds dependencies from source, hand crafted by an AMD principal engineer, was specifically provided for us, since the Pytorch Nightly and public PyTorch AMD images functioned poorly and had version differences. This docker image requires ~5 hours to build from source and installs dependencies and sub-dependencies (hipBLASLt, Triton, PyTorch, TransformerEngine), a huge difference compared to Nvidia, which offers a pre-built, out of the box experience and takes but a single line of code. Most users do not build Pytorch, hipBLASLt from source code but instead use the stable release.

    - - - -

    When using public PyTorch, users have the choice of working with the latest stable images or a nightly PyTorch upload. So, although a nightly PyTorch upload may have the latest commits that could potentially lead to better performance or could fix some bugs, but users must accept that the upload may not be fully tested and could contain new bugs from Meta/AMD/Nvidia or other PyTorch contributors that have not been discovered yet. Note that most end users are using the stable release of PyTorch.

    - - - -
    Source: SemiAnalysis, AMD
    - - - -
    Source: Nvidia
    - - - -

    Delightfully, Nvidia’s Docker images contain the complete set of developer tools needed for profiling and debugging, like Nsight Compute and Nsight Systems. AMD, in contrast, does not include their OmniTrace developer tool out of the box. 

    - - - -

    Until a couple weeks ago, the AMD docker images only supported PyTorch 2.3, which released 8 months ago. Mainline PyTorch 2.4 and PyTorch 2.5 have also since released and PyTorch 2.6 is about to come out in Q1 2025. We recommended to an AMD Principal Engineer and to AMD’s VP of AI that AMD should have the latest AMD PyTorch version – AMD has since started publishing containers for some of these AMD PyTorch versions. Docker image for AMD PyTorch 2.5 is still missing.

    - - - -
    Source: Nvidia
    - - - -

    Dec 21st AMD Development Builds

    - - - -

    Below is AMD’s December 21st development build docker image. As you can see, it uses a number of non stable devlopment branches for dependencies such as hipBLASLt, AOTriton, ROCm Attention and installs everything including PyTorch from source code, taking upwards of 5 hours to build. These versions of the dependencies haven’t even been merged into AMD’s own main branch yet.  99.9% of users will not be installing PyTorch from source code and all of its dependencies from source code on development branches but will instead use the public stable PyPi PyTorch.

    - - - -

    Furthermore, instead of using Flash Attention through the PyTorch native user friendly torch. scaled_dot_product_attention API, this AMD Development build imports another library (development branch as well) attention implementation. We have seen more users use Flash Attention through PyTorch native torch. scaled_dot_product_attention API since it is more user friendly and bundled into out of box PyTorch. Even AMD’s own public documentation recommends using Flash Attention through torch.scaled_dot_product_attention API. We hope that these kernels get merged into PyTorch flash attention instead of making the end user install a separate library taking hours of their time to build. This is not a user-friendly experience. Furthermore, AMD must support FlexAttention as it has quickly become the go to in the industry. 

    - - - -

    AMD’s December 21st Dev build is on a hanging development branch. That means it is a branch that has not been fully QA’ed and is at use only at a risk branch. There are many concerns about the validity of the results from using a development build and branches and building from source code, as most users are not doing this in real life. Most users will be installing AMD/Nvidia PyTorch from PyPI stable release mostly so we recommend readers keep this in mend when analyzing these results.

    - - - -

    That being said, we are including these development build results as it is an indication of where AMD public stable release software will be 1-2 quarters from now. However, at the same time, when it comes to compete, 1-2 quarters from now, Nvidia Blackwell will already be widely deployed, while AMD MI355X will not commence shipments until H2 2025. 

    - - - -
    Source: SemiAnalysis, AMD
    - - - -

    Training Testing Methodology (GPT1.5B, Llama 8B, Llama 70B, Mistral)

    - - - -

    There are many ways to test training performance. The most accurate way is to take a medium-sized AI startup model’s internal codebases and run them on a 512-1024 GPU cluster. This way, the test run has all the optimizations that a typical user would have. Everything else is just a proxy for the performance of these training runs. Training performance takes into account HBM bandwidth, HBM capacity, TFLOP/s, networking, and system architecture. Comparing on paper HBM bandwidth/capacity is just like comparing on paper camera megapixels.

    - - - -

    MLPerf GPT3 175B Training is also a good proxy to measure the time it takes to train to a specific convergence. MLPerf benchmark considers global batch sizes and whether a mixed precision implementation incurs a convergence penalty. Unfortunately, MLPerf is quite difficult to run due to a lack of user-friendly documentation and instructions, and the performance is often min-maxed via a custom tuned configuration specifically concocted for MLPerf that an average user would not adopt. Note that Nvidia has submitted MLPerf Training results with over 11k H100s, while AMD runs MLPerf Training internally. AMD’s results are likely weak, so they have never submitted any MLPerf Training, let alone the MLPerf GPT3 175B benchmark.

    - - - -

    When designing our SemiAnalysis benchmark, we wanted to reflect the average user’s model implementation, and so opted for torch. scaled_dot_product_attention API (which uses flash attention backend), PyTorch Distributed Data Parallel (DDP) and/or Fully Sharded Data Parallel (FSDP) with torch.compileAlso note that AMD recommends users use torch.scaled_dot_product_attention in their own documentation. We believe this is the most representative of a typical user workload. Further, we used a generic PyTorch native implementation of these models to keep it close to a typical ML Scientist user and make it easy to run with a single line of code. In contrast to MLPerf, the goal of our benchmark is to be as simple to run as possible, while still being a good proxy for performance. Note, since we don’t take into account time to convergence, this benchmark has a slight bias towards AMD as we set the micro batch size higher on AMD vs on Nvidia. When taking time to convergence into account, AMD results will be worse than what is stated.

    - - - -

    As an aside, many AI practitioners have said they are not using Megatron or NeMo or 3D Parallelism due to the high level of complexity and lack of flexibility associated with those libraries, whose rigidity and complexity make their usage for ML Research effectively impossible. Note that in terms of 3D Parallelism, both Nvidia and AMD will get higher performance, assuming their software stack works, which is a big assumption for AMD. AMD Megatron is a fork of Nvidia Megatron and has less than 10 stars which means that it is probably not dogfooded well. Submitting bug reports would take extra months to get AMD Megatron working for simple models. 

    - - - -

    For our SemiAnalysis model training benchmark, we will test four models, with the first being a simple GPT 1.5B DDP, as we believe this is representative of what small-scale experiments/ablations would look like before scale-out to bigger model sizes. DDP is a much simpler and less network-intensive form of parallelism. Next, we tested the standard Llama3 8B and Llama3 70B 4 Layer Proxy as a baseline for a popular model’s performance. Third, we tested Mistral 7B v0.1, which evaluates if hardware will perform well when adding a bit of complexity, as Mistral uses sliding window attention instead of the standard causal attention. Modern models such as ChatGPT, Claude, Genimi, o1, o3 do not use standard causal attention & use a complex attention mechanism.

    - - - -

    A Modern GPT/Llama/Transformer model is built by stacking the same transformer layer over & over again. As such, measuring the performance of just 4 layers is a great proxy for the overall performance of the model.

    - - - -
    Source: Imgur
    - - - -

    Furthermore, in modern LLM training for all frontier LLM models, pipeline parallelism is used which means that a couple of transformer layers are placed in each GPU server. Never in modern pretraining is a whole model placed on a single node.

    - - - -
    Source: SemiAnalysis
    - - - -

    The model FLOP for each token trained is defined by the following formula:

    - - - -

    6 * non_input_embedding_params + 12 * num_layers * num_heads * head_dim * max_seq_len * density

    - - - -

    With density being how sparse the attention is relative to a full mask. Causal attention has, for example, a 50% sparsity, while sliding window attention has even lower sparsity.

    - - - -

    Note that originally our testing harness used 6 * params instead of 6 * non_input_embedding_params which is the wrong way of calculating model FLOP per token. Furthermore, there was another bug in regard to the way we used FSDP. We have since updated our testing harness and retroactively retested as well as updated all of benchmark results across all versions of software for both H100, H200, MI300X, public stable, public nightly, VIP images and AMD development builds. All results listed below are with the updated testing harness.

    - - - -

    Single Node Training Performance

    - - - -

    Note that the H100/H200 performance we present in this report reflects an out of the box performance without any hand-crafted tuning from Nvidia engineers, while the results for the MI300X comes after many months of tuning and bug fixes from AMD’s engineers. We did not run into any Nvidia-specific bugs compared to AMD training, which was comparatively bug-filled. Five months ago, many models couldn’t run at more than 150 TFLOP/s on the AMD MI300X due to an AMD software bug in attention backwards and torch compile, which forced the user to manually mark a region of the model as non-compliable instead of having a full graph compile.

    - - - -

    We see that, for all models, the H100/H200 wins relative to MI300X public releases/public nightly releases/Nov 25thbuild from source VIP image. It is interesting that the MI300X does not perform well on smaller models such as GPT 1.5B or on any model that uses a non-causal attention layer, like Mistral 7B v0.1. This is due to FlexAttention not being fully operational at the time of the deadline, while, on Nvidia GPUs, it has been working since August 2024. As such, the H100/H200 beats MI300X by more than 2.5x in terms of TFLOP/s for MI300X public release/public nightly release/Nov25th VIP build.

    - - - -

    For the Dec 21st MI300X internal WIP development branches build, we still see it perform worse than H100/H200 on GPT 1.5B. Furthermore, it performs slightly worse than H100 on Mistral 7B. For Llama3 8B and Llama3 70B Proxy, the Dec 21st MI300X WIP development build performs better than H100/H200, but note that this is due to MI300X WIP development using an AMD engineer’s development branch that has not even been merged to the AMD main branch. 

    - - - -
    Source: SemiAnalysis
    - - - -

    Three months ago, attempting to do FP8 Training on AMD led to segfaults and hard errors. On the off chance it did work, it was, in fact, slower than the same run using BF16. We worked with AMD’s FP8 team to fix this issue, as well as the AMD hipBLASLt team, which created tuning for fixing MI300X FP8 performance. FP8 Training is important as it speeds up training compared to BF16 & most frontier labs use FP8 Training.

    - - - -

    After many fixes, we can see that the MI300X’s Nov 25th throughput for Llama3 8B and GPT 1.5B is somewhat competitive with H100’s. As usual, H200 wins in this category. However, for Llama3 70B 4 Layer Proxy, AMD Nov 25th’s results are sorely beaten.

    - - - -

    For Mistral 7B which has a non-causal attention layer, AMD Nov 25th performance is close to half that of an H100. This shows that, for anything that isn’t a simple model, even after months of tuning, AMD is still not competitive due to a slight tweak in the model structure. Many frontier models and AI training startups are using complex attention layers for long context spans and efficient attention, but, AMD is still far behind on those.

    - - - -

    Unfortunately, FP8 training on AMD only works on custom images such as our November 25th VIP image and December 21st WIP development branch image. When we first started trying AMD FP8 Training, it was slower than AMD BF16 Training on public releases.

    - - - -
    Source: SemiAnalysis
    - - - -

    For AMD’s WIP development builds, we see that on Llama3 8B, it wins against H100 but is still slower than H200’s public stable software release. H200 performance completely beats MI300X even on their Dec 21st WIP development branches.

    - - - -

    It is interesting that the MI300X does not perform well on non-causal attention layer, like Mistral 7B v0.1 even for their internal builds. Mistral using sliding window attention which some of the frontier models uses. It seems that if you want to train a model that doesn’t use causal attention, AMD MI300X will automatically lose.

    - - - -

    While a lot of people putting out performance comparisons between hardware, most do not open source their testing code and they do not make easily reproducible. We took an open source approach, and we have open-sourced our single node training benchmark and made it easy to run with only a couple of lines:

    - - - -
    Source: SemiAnalysis
    - - - -

    Multi-Node Training Performance

    - - - -

    For multi-node, we benchmarked two nodes of H100 and two nodes of MI300X. Unfortunately, we didn’t get access to a multi-node H200 deployment in time for the article.

    - - - -

    H100 wins again by a big margin in this benchmark compared to MI300X, with the H100 ranging from 10-25% faster. This gap widens as you add more nodes working together into a single training workload. This is a known problem, which AMD is attempting to fix next year by deploying their new in house 400G AI focused NIC.

    - - - -

    AMD PYTORCH_TUNABLE_OPS FLAG is a Bad User Experience

    - - - -

    In order to get AMD training working decently, users need to use PYTORCH_TUNABLE_OPS which is an AMD specific prototype flag for the end user to tune GEMMs. Since this is a prototype feature (i.e. not stable), in the past a lot of bugs with this feature cropped up including but not limited to seg faults, HBM memory leaks, and a whole host of otherissues such as many unit tests being disabled. These known tunable ops bugs have been fixed now but there are likely a many more unknown AMD software bugs. 

    - - - -

    Furthermore, even if users do not encounter any bugs and thus the runway is clear for this prototype AMD flag to work, it still takes users anywhere from 1-2 hours to tune any modern LLM model. Although these GEMMs can be cached by the end user, any minor changes to the end user’s code results in the need for the user to spend another 1-2 hours tuning. As you can imagine, this will slow down an ML Scientist’s iteration cycle speed when trying to conduct model R&D and ablations experiments. 

    - - - -

    On Nvidia, this flag isn’t needed as their GEMM library (cuBLASLt) comes tuned out of the box and cuBLASLt’s heuristic model out of the box picks the correct algorithm for most shapes on H100/H200. In contrast, AMD hipBLASLt/rocBLAS’s heuristic model picks the wrong algorithm for most shapes out of the box, which is why so much time-consuming tuning is required by the end user.

    - - - -

    We recommend that AMD to fix their GEMM libraries’ heuristic model such that it picks the correct algorithm out of the box instead of wasting the end user’s time doing tuning on their end. Users often iterate quickly when doing research and therefore rerunning tunable ops will slow down research velocity significantly.

    - - - -

    Scale Up NVLink/xGMI  Topology

    - - - -

    Scale up fabric is extremely important for GPU Clusters, as it provides an extremely fast path for tensor and expert parallelism used in frontier model training. For this reason, we have conducted benchmarks to measure scale up fabric performance.

    - - - -

    The scale up fabric on H100 and H200 is called NVLink and provides 450GByte/s of bandwidth per GPU and connects 8 GPUs together. On the MI300X, the scale up fabric is called xGMI and, on paper, it connects 8 GPUs, providing 448GByte/s of bandwidth per GPU. On the surface, MI300X’s scale up network is extremely similar and close in performance to that of the H100/H200, providing just 0.5% less on paper bandwidth. Unfortunately, the reality of the situation differs sharply.

    - - - -

    First, MI300X’s xGMI is a point-to-point fabric, which means that it isn’t actually providing 448GByte/s of bandwidth between GPUs pairs. Instead, each GPU can only talk to one another at 64GByte/s. A GPU can only reach the stated 448GByte/s if one GPU addresses all 7 other GPUs simultaneously. That means that, for Tensor Parallelism TP=2, the maximum bandwidth is 64GByte/s and 189GByte/s for TP=4.

    - - - -
    Source: SemiAnalysis
    - - - -

    In contrast, since Nvidia’s NVLink uses a switched topography, one GPU can talk to another GPU at the full 450GByte/s. Furthermore, the four NVSwitches in H100/H200 support in-network reduction (referred to as NVLink SHARP (NVLS), enabled by default), a technique to reduce data movements by carrying out collectives/reductions inside the switch itself.

    - - - -
    Source: SemiAnalysis
    - - - -

    All Reduce/All to All/Reduce Scatter/All Gather Collectives Overview

    - - - -

    We will showcase benchmarks across scale-up and scale-out networks for both the Nvidia H100/H200 and AMD’s MI300. The collectives that we will be testing are the main set of collectives used in frontier LLM training: all_reduce, all_gather, reduce_scatter, and all to all. All reduce is for data parallelism and tensor parallelism, all gather is used for ZeRO/FSDP parallelism (as well as for tensor parallelism), and Reduce Scatter is used for ZeRO/FSDP parallelism. 

    - - - -

    Due to the way that compute-communication overlapping works, real-world message sizes range from 16MiB to 256MiB, with the default PyTorch DDP size being 25MiB (NVIDIA’s MLPerf 11,000 H100 GPT-3 175B run used a message size of max 200MiB). We also test 8GiB and 16GiB just to see what the peak bus bandwidth is, though these message sizes are not used in the real world. All these collectives discussed above are used during 3D Parallelism and FSDP/ZeRO Parallelism, which are common techniques for training frontier models.

    - - - -
    Source: DeepSpeed
    - - - -
    Source: Meta
    - - - -

    Single Node NCCL Collective

    - - - -

    We see that Nvidia does much better than AMD across all the real-world messages for every single collective. This is not surprising due to the H100/H200’s superior 450GByte/s NVLink switched topology with in-network reduction (NVLS), compared to MI300X’s 7x64GByte/s xGMI point-to-point topology.

    - - - -
    Source: SemiAnalysis
    - - - -
    Source: SemiAnalysis
    - - - -
    Source: SemiAnalysis
    - - - -
    Source: SemiAnalysis
    - - - -

    To reproduce this test, you can use our open source ClusterMax-NCCL/RCCL benchmark, which we developed to be easily run with one line of Bash. ClusterMax is our upcoming evaluation quantitative performance and qualitative user experience for ranking H100/B200/GB200/MI300X Neocloud clusters. Look forward to our upcoming “ClusterMax Neocloud Evaluation | How to Rent GPUs” article. 

    - - - -
    Source: SemiAnalysis
    - - - -

    Multi Node RCCL/NCCL Collectives and Scale Out Network Benchmarks

    - - - -

    On both Nvidia’s H100/H200 and the MI300X, each GPU is connected to other nodes over the scale out network using a 400G Network Interface Card (NIC), connected directly every GPU. The H100/H200 reference design typically uses ConnectX-7 NICs for InfiniBand NDR or BlueField-3 for Spectrum-X Ethernet. Spectrum-X is NVIDIA’s custom Ethernet solution purpose-built for AI workloads. On the MI300X, the reference design recommends using RoCEv2 Ethernet with Broadcom Thor-2 NIC. 

    - - - -
    Source: Nvidia
    - - - -

    A typical GPU cluster almost always requires more layers than a single tier network, as a single-tier network can only support 128 GPUs (in the case of Broadcom Ethernet or Nvidia Spectrum X Ethernet) and 64 GPUs (for H100/H200 InfiniBand). In such a multi-tier network, deployments typically use an 8-rail optimized fat tree, where each one of the 8 GPU is connected to a separate switch (such a connection is called a “rail”). In our AI Neocloud Playbook and Anatomy article, we explained in detail how a rail optimized network works.

    - - - -
    Source: SemiAnalysis
    - - - -

    Just as Nvidia’s NVLink offers NVLS for its scale-up network, Nvidia’s H100/H200 InfiniBand scale out network also offers InfiniBand SHARP In-network Reduction which is, again, exclusive to Nvidia. AMD does not have an analogous product for the MI300X. InfiniBand SHARP works similarly to NVLink SHARP In-network Reduction as they both provide a way to reduce the amount of traffic going through the network, with the reductions carried out inside of Quantum-2 InfiniBand switches in the case of InfiniBand SHARP. 

    - - - -

    Unfortunately, unlike NVLink SHARP, which is enabled by default, InfiniBand SHARP is not enabled by default in the UFM/IB subnet manager. We have spoken to many Neoclouds, H100 cluster operators, and AI frontier labs, and most have said that they have not enabled SHARP due to increased NCCL_TIMEOUT rates and difficulties installing and configuring the network. We asked NVIDIA which AI customers use InfiniBand SHARP, but they declined to answer in specifics. One could speculate that if InfiniBand SHARP was useful in AI production workloads, NVIDIA marketing would shout at the top of their lungs to promote its successful deployment. Given the apparently limited adoption of InfiniBand SHARP for now, we show here collective performance for Nvidia both when SHARP is and is not enabled.

    - - - -

    For some of the benchmarks, we have also collected Nvidia Spectrum-X Ethernet data on an Nvidia internal cluster called Israel-1. Nvidia Spectrum-X is used in xAI’s 200k H100/H200 cluster and can support clusters up to 100k GPUs in the Spectrum-X reference architecture version 1.2, but could potentially support up to 512k GPUs with a non-reference custom design.

    - - - -

    We are also in the process of testing Google Cloud (GCP) H100’s in-house ethernet, as well as AWS’ H100 and H200s that are deployed on AWS’s in-house Ethernet (called EFAv2/EFAv3). We will be sharing the results in our upcoming “Collective Deep Dive” article, which will provide visualizations of  the different types of collectives, explain the different NCCL protocols (SIMPLE, LL, LL128), different NCCL algorithms (NVLS, NVLSTREE, RING, TREE, COLNETDIRECT, COLNETCHAIN, PAT), and how collectives run on GCP H100 Ethernet, AWS H100/H200 EFA, InfiniBand H100, Spectrum-X, etc.

    - - - -

    Below we show a 32 GPU all reduce collective test. You can see that MI300X RoCEv2 is in last place compared to normal InfiniBand H100 and InfiniBand H100 with SHARP enabled. Simply put, poor all reduce performance leads to poor scale-out training.  

    - - - -
    Source: SemiAnalysis
    - - - -

    The MI300X’s performance decreases if you scale out (i.e. increase) the number of GPUs participating in a collective. As you can imagine, modern frontier training is carried out on clusters of at least 100,000 GPUs. MI300X RoCEv2 runs at half the speed for all the real-world message sizes of 16MiB to 256MiB when compared to the baseline of InfiniBand Non-SHARP. As per the chart below, Nvidia Spectrum-X Ethernet performance is quite close to InfiniBand Non-SHARP’s performance, due to Spectrum-X’s vertical integration with the NCCL collective library as well as its use of good congestion control and adaptive routing. AMD is attempting to vertically integrate next year with their upcoming Pollara 400G NIC, which supports Ultra Ethernet, hopefully making AMD competitive with Nvidia. As always, Nvidia is not standing still and by late next year, it will be ready to go into production with its 800G ConnectX-8 NICs, which provide a line rate twice as fast as AMD’s Pollara NIC. 

    - - - -

    AMD RCCL is a fork of Nvidia NCCL. AMD’s RCCL Team and many other teams at AMD are resource limited and don’t have enough of either compute or headcount to improve the AMD ecosystem. AMD’s RCCL Team currently has stable access to less than 32 MI300Xs for R&D, which is ironic, as improving collective operations is all about having access to many GPUs. This is frankly silly, AMD should spend more on their software teams having access to more GPUs.

    - - - -

    This contrasts with Nvidia’s NCCL team, which has access to R&D resources on Nvidia’s 11,000 H100 internal EOS cluster. Furthermore, Nvidia has Sylvain Jeaugey, who is the subject matter expert on collective communication. There are a lot of other world class collective experts working at Nvidia as well, and, unfortunately, AMD has largely failed to attract collective library talent due to less attractive compensation and resources – as opposed to engineers at Nvidia, where it is not uncommon to see engineers make greater than a million dollars per year thanks to appreciation in the value of RSUs. 

    - - - -

    To help alleviate these issues, TensorWave and SemiAnalysis are currently working with the AMD RCCL Team to improve collective performance. TensorWave has generously sponsored AMD a medium-sized cluster in order help the RCCL Team have greater resources to do their jobs. The fact that Tensorwave after buying many GPUs has to give AMD GPUs for them to fix their software is insane.

    - - - -

    Another trend to notice is that for non-SHARP networks, all reduce collective’s speed will reduce logarithmically as you double the number of GPUs. In contrast, with SHARP, the speed/completion time stays the same. We have results for up to 1,024 H100s showing that IB SHARP all reduce is constant time across any number of GPUs in a collective. We will publish this in our upcoming “Collective Deep Dive” article.

    - - - -
    Source: SemiAnalysis
    - - - -

    For all gather, all to all, and reduce scatter collectives, MI300X is anywhere from 2-4 times slower than InfiniBand. Unfortunately, we did not have access to Spectrum-X or InfiniBand SHARP benchmark data for all gather or reduce scatter. 

    - - - -
    Source: SemiAnalysis
    - - - -
    Source: SemiAnalysis
    - - - -
    Source: SemiAnalysis
    - - - -

    Below, we provide our nccl/rccl benchmarking script. Unfortunately, due to the nature of cluster-specific setups, it is not as simple as a one-liner. It does require you to follow the README.md of nccl/rccl and nccl-tests/rccl-tests to run properly. On AWS and Google Cloud, there may also be custom nccl adapters that you will need to install.

    - - - -
    Source: SemiAnalysis
    - - - -

    AMD’s User Experience is Suboptimal and the MI300X is Not Usable Out of the Box

    - - - -

    Due to poor internal testing (i.e. “dogfooding”) and a lack of automated testing on AMD’s part, the MI300 is not usable out of the box and requires considerable amounts of work and tuning. In November 2024 at AMD’s “Advancing AI”, AMD’s SVP of AI stated that are over 200k tests running every evening internally at AMD. However, this seems to have done little to ameliorate the many AMD software bugs we ran into, and we doubt AMD is doing proper CI/CD tests include proper performance regression, or functional and convergence/numerics testing. We will outline a few examples here for readers to understand the nature of the AMD software bugs we have encountered and why we feel they have been very obstructive to a good user experience on AMD. 

    - - - -

    Although AMD’s own documentation recommends using PyTorch native Flash Attention, for a couple months this summer, AMD’s PyTorch native Flash Attention kernel ran at less than 20 TFLOP/s, meaning that a modern CPU would have calculated the attention backwards layer faster than an MI300X GPU. For a time, basically all Transformer/GPT model training using PyTorch on the MI300X ran at a turtle’s pace. Nobody at AMD noticed this until a bug report was filed following deep PyTorch/Perfetto profiling showing the backwards pass (purple/brown kernels) took up far more time than the forward pass (dark green section). Normally, the backwards section should take up just ~2x as much time as the forward pass (slightly more if using activation checkpointing). 

    - - - -
    Source: SemiAnalysis
    - - - -

    Another issue we encountered was that the AMD PyTorch attention layer led to a hard error when used with torch.compile due to the rank of the longsumexp Tensor being incorrect. What was frustrating is that this had already been fixed in internal builds of AMD PyTorch on May 30th, but did not reach any AMD PyTorch distributions or even any PyTorch nightly builds until October when it was pointed out to them that there was a bug. This demonstrates a lack of testing and dogfooding on the packages AMD puts out to the public. Another core reason for this problem is that the lead maintainer of PyTorch (Meta) does not currently use MI300X internally for production LLM training, leading to code paths not used internally at Meta being buggy and not dogfooded properly. We believe AMD should partner with Meta to get their internal LLM training working on MI300X.

    - - - -
    Source: SemiAnalysis
    - - - -

    On August 8th, Horace He and the Meta PyTorch Team released FlexAttention, a critical API for creating non-causal attention layers without losing speed. To previously use attention variants like document masking, sliding window attention, softcap, and Alibi, a user would need to spend weeks handcrafting their own kernel in CUDA/HIP language, and subsequently pybinding it to PyTorch. However, with FlexAttention, a user can quickly generate all the attention variants using the API. FlexAttention achieves great performance by using block sparsity by only calculating the blocks of the mask where needed, ignoring the rest.

    - - - -
    Source: SemiAnalysis
    - - - -
    Source: Meta
    - - - -

    With sliding window attention, FlexAttention can improve performance by 10-20x! This is amazing for the end user, but unfortunately, MI300X FlexAttention was in a poor state and suffers from numerous AMD software bugs (including convergence issues) until but a couple days ago. While the latest PyTorch nightly now fixes for convergence issues, this contrasts starkly with FlexAttention on Nvidia, which has been available since August. That means a ~6 month gap exists between the availability of these fantastic Pytorch features on Nvidia and AMD’s platforms. For frontier AI labs, six months is a lifetime, with OpenAI, Anthropic, and Google having released numerous models in such a span. 

    - - - -
    Source: SemiAnalysis
    - - - -

    Exploring Ideas for Better Performance on AMD

    - - - -

    AMD recommended we try PYTORCH_ TUNABLE_OPS to improve GEMM performance by sweeping through GEMM algorithms at runtime. However, as we mentioned earlier, this API works poorly because GEMMs should be tuned when compiling the hipBLASLt/RoCBLAS/cuBLASLt and not during the users’ runtime. Users of Nvidia H100s do not need to use PYTORCH_ TUNABLE_OPS for most shapes because cuBLAS heuristic model will pick the correct algorithmn. This contrasts with AMD’s heuristic model, which never seems to pick the correct algorithm for most shapes. We recommend that AMD stop suggesting that users try tunable ops and instead focus on properly tuning their GEMM libraries internally. 

    - - - -

    When we tried PYTORCH_ TUNABLE_OPS on AMD, it led to an HBM memory leak of over 25 GByte out of the total MI300X capacity of 192GBytes, essentially wiping out the MI300’s HBM capacity advantage over the H100. The fix for this is to set a default hipBLASLt and rocBLAS workspace to prevent memory leaks.

    - - - -
    Source: PyTorch/AMD
    - - - -

    As we mentioned earlier in this article, another issue we ran into was that there was a plethora of environment flags needed on MI300X to make it actually usable. We recommend to AMD that they stop putting users in the position of having to set these environment flags themselves and, instead, set default flags that lead to a usable environment. It is not simply their number, but also the complex interactions between the flags, making troubleshooting difficult. Getting reasonable training performance out of AMD MI300X is an NP-Hard problem. 

    - - - -

    Another issue is that certain AMD ROCm libraries could not be installed inside Docker due to AMD software CMake bugs leading to hard errors. This has since been fixed. On AMD GPUs, you need to pass in a convoluted set of flags to get the GPUs to be able to work inside a container, whereas with docker, getting GPUs to work is as simple as passing in “—gpus=all”. We recommend to AMD that they partner with Docker and ensure that Docker can autodetect GPUs for AMD as well, making the workflow as streamlined as when working with Nvidia GPUs.

    - - - -
    Source: SemiAnalysis
    - - - -

    AMD’s Forked Libraries

    - - - -

    Many of AMD’s libraries are forked off Nvidia’s open-source or ecosystem libraries. AMD uses a tool called Hipify to carry out source-to-source translation of Nvidia CUDA to AMD HIP. While the motivation is understandable, they arenevertheless building on top of their competitor’s platform and cannot expect to match or surpass Nvidia’s user experience with this software development strategy. They need to contribute their software to the AMD ecosystem. For example, instead of supporting FP8 training by forking Nvidia/TransformerEngine and source-to-source translation, they should attempt PyTorch native FP8 training to work well on their own hardware. Currently, AMD PyTorch native FP8 training recipes don’t work on AMD and the unit tests don’t even pass yet, there is no CI/CD for AMD PyTorch native FP8 training.

    - - - -
    Source: SemiAnalysis
    - - - -

    Detailed Recommendations to AMD on How to Fix Their Software

    - - - -

    First, AMD needs to focus on attracting more software engineering resources and improving compensation for current engineers. The current compensation gap between AMD and Nvidia means that top talent is lured to Nvidia over AMD. This top talent is also attracted to Nvidia as it has far more compute/resources for engineers. AMD should procure more GPUs for their in-house development work and submit an MLPerf GPT3 175B result as soon as possible. Even if the result is not competitive with Nvidia right now, submitting such a benchmark will kick off the process for iterative improvement. 

    - - - -

    We also notice that AMD frequently gives their customers custom images, and, in fact, AMD developers themselves often work on top of such bespoke images. This is not best practice, as this means that AMD engineers have a different experience vs. images available to the public. AMD should instead lift the standard of public images by using these images internally and with its customers, and the AMD executive team should personally internally test (i.e. “dogfood”) what is getting shipped publicly.

    - - - -

    We recommend that AMD create a public dashboard that runs every night, showing the performance of their hardware on benchmarks such as MLPerf or TorchBench. This dashboard should also include H100/H200 performance as a baseline.

    - - - -

    Finally, AMD needs to completely transform its approach to environmental flags. Instead of setting a myriad of flags to get running out of the box, it should set them to recommended defaults so users can get started quickly. 

    - - - -

    AMD should collaborate with Meta to get production training workloads working on ROCm, as it is well-known amongst PyTorch users that PyTorch code paths tend to have tons of bugs unless Meta uses it internally. Meta currently hand writes HIP Kernels for their production MI300X inferencing but does not use MI300X for real training. It would be a fantastic improvement for the AMD ecosystem, and a marketing victory, if a smaller version of the next Llama is trained on AMD. Not to mention that this would open the door to AMD progressively moving towards larger models/clusters with Meta. Meta using AMD GPUs for actual model training would be a win-win for both companies as Meta is also looking for alternative training chips to Nvidia.

    - - - -

    Currently Nvidia offers well over 1,000 GPUs for Continuous improvement and development of Pytorch externally and many more internally. AMD doesn’t. AMD needs to work with an AMD focused GPU Neocloud to have ~10,000 GPUs of each generation for internal development purposes and Pytorch. This will still be 1/8th that of Nvidia with their coming huge Blackwell clusters, but it’s a start. These can be dedicated to internal development and CICD for Pytorch.

    - - - -

    Lisa, we are open to a meeting on how to fix AMD’s Datacenter GPU User Experience for the better!

    - - - -

    H100/H200/MI300X Networking BoM Analysis and Performance per TCO

    - - - -

    In addition to our benchmarking of collectives and GEMM throughput, we have conducted several experiments exploring insightful topics for conducting further benchmarks and running real-world workloads on clusters. These experiments cover benchmarking warmup and repeat effects, VBoost Power Shifting, MLPerf Training GPT-3, BF16 vs FP16 throughput, throughput by GEMM input distribution, power per FLOP, and throughput for the PyTorch PyPi distribution vs Nvidia NGC Stable PyTorch images. 

    - - - -

    We also present a detailed networking bill of materials (BoM) analysis for the 1k GPU Ethernet, 1k GPU InfiniBand, 16k GPU Ethernet, and 16k GPU InfiniBand clusters. We also discuss the impact of using 51.2T Radix vs. 25.6T Radix switches for back-end networking.

    - - - -

    Lastly – we present a performance per TCO analysis that shows how the H100/H200/MI300X stacks up in terms of $/hr per effective training petaflop. These items are available below to all SemiAnalysis subscribers and will be of great interest to datacenter operators, ML scientists, and investors.

    - - - -
    - - -
    -
    -
    Subscribe for full access to this article
    - - - -

    With a SemiAnalysis subscription you get full access to all articles, Data Explorer graphs, article discussions, and further insight into deep dives.

    - - - - - - - -
    - - - - - - - -

    Please verify your email address to proceed.

    - - - -
    - - - -

    By subscribing, you agree to the Privacy Policy and Terms and Conditions.

    -
    -
    - - -
    - - - - -
    - - diff --git a/docs/posts/in-praise-of-the-hundred-page-idea.html b/docs/posts/in-praise-of-the-hundred-page-idea.html deleted file mode 100644 index 1691f487d35..00000000000 --- a/docs/posts/in-praise-of-the-hundred-page-idea.html +++ /dev/null @@ -1,49 +0,0 @@ - - - - - - - James Routley | Feed - - - - Back - Original -

    In praise of the hundred page idea

    - -
    - -
    - -
    cat sniffing a handful of slim volumes
    a handful of hundredish page ideas from my collection
    -

    (Ed. note: hello Hacker News folks! Since you may be new to my work, I wanted to provide a bit of context; for more of my thoughts on reading, please see My Reading Philosophy in 17 Guidelines)

    -

    I prefer a lightweight nonfiction book to a detailed tome. I’m a dilettante of many interests, so my attention for any given topic is more likely to sustain 100 pages than 600. The sweet spot is longer than a longread internet article, but that doesn’t demand a months-long commitment: a 2-3 hour text.

    -

    At about 100 pages, the idea must be substantial, but not substantiated to death. There’s room to fully explain one idea, but not enough to get lost in tangents. This is manifesto territory; far from being forgettable for being short, their intensity makes them more powerful. A single idea, distilled.

    - -

    Timothy Snyder’s On Tyranny is an eminently reasonable 127 pages; I read the graphic version, and it’s one of the most valuable works I’ve read in the past decade. (Unfortunately 😬) The 72-page 2k to 10k by Rachel Aaron also punches above its class in terms of impact — it made me change the way I write. Strunk and White’s svelte Elements of Style is a classic over a hundred years later. I appreciate an author’s restraint, when they can value a gem of an idea and recognize how to present it simply, without elaborate fittings.

    -

    Some ideas warrant 300 pages. A very few justify 600. But many 100-page ideas are bloated into the 300-page form factor — from my understanding (which may well be wrong), because Americans want to feel like we’ve gotten our money’s worth? Perhaps this desire for brevity makes me sound unfocused, but the seeming depth of a 300-pager is often illusory. I suspect I’m not the only one who’d like more 100-page ideas without the padding.

    -

    The other thing that happens with hundred -page ideas is packaging them up with a bunch of smaller ones in an essay collection. I’d rather have a single meatier essay in a slim volume than several jammed together in a thicker book. “Here’s that one essay you want to read and five others you’ve never heard of!” As if I didn’t already have enough things to read — it’s like the free bag that companies throw in to online orders once you’ve spent enough — can I pay you more to keep the damn tote, of which I already possess more than I need for a lifetime, and not burden me with your unwanted brandware? A bouquet benefits from filler; an idea does not.

    -

    Part of why I dislike essay collections is their neverendingness; I’ll read two, three, four essays in a volume and I still can’t cross it off my list. An incomplete task, it becomes a mental weight, an obligation. I’m deprived of the satisfaction of finishing.

    -

    Binding essays as one implies that they are of a kind, when so often they are not. This detracts from the essays I do read from a volume, diminishing them as incomplete ideas in the context of their placement. Or the format invites me to treat it as a sampler, an amuse-bouche of 30-minute ideas, and since I think of it as the type of book to read an essay in one sitting, I never get around to reading the longest (and probably most valuable) essay in the bunch.

    -

    This shorter form factor does exist, but seems more limited in number (or I’m bad at finding them 😅). Two works I’ve recently picked up from 1973 fit the bill: Barthes’ The Pleasure of the Text, at an idyllic 67 pages, and Illich’s Tools for Conviviality, at 110. The more recent Care Manifesto lands at 114 pages. I’m very much looking forward to reading Robin Wall Kimmerer’s The Serviceberry, 128 pages, which I assume is expanded from her spectacular essay that I read last year.

    -

    Some other short nonfiction I’ve read in the past few years:

    - -

    I regard long books, both fiction and nonfiction, with a bit of an economist’s eye: are the ideas in the 600-page book that much better than those in 300- or 100- page books, such that the opportunity cost is worth trading six 100-page ideas for a single 600-pager? My reading time is limited and since I’m not an academic, I don’t need works so referenced that the footnotes run to a hundred pages themselves. For me, the value in ideas is connection and synthesis: it’s more useful to my type of thinking to have a slightly shallower understanding of more ideas, so I can build a mental web between all of them.

    - -
    - -
    - - diff --git a/docs/posts/litestack-all-your-data-infrastructure-in-one-ruby-gem.html b/docs/posts/litestack-all-your-data-infrastructure-in-one-ruby-gem.html new file mode 100644 index 00000000000..ed694c2e671 --- /dev/null +++ b/docs/posts/litestack-all-your-data-infrastructure-in-one-ruby-gem.html @@ -0,0 +1,332 @@ + + + + + + + James Routley | Feed + + + + Back + Original +

    Litestack: All your data infrastructure, in one Ruby gem

    + +

    litestack

    +

    Gem Version +RubyGems Downloads

    +

    All your data infrastructure, in a gem!

    +

    Litestack is a Ruby gem that provides both Ruby and Ruby on Rails applications an all-in-one solution for web application data infrastructure. It exploits the power and embeddedness of SQLite to deliver a full-fledged SQL database, a fast cache , a robust job queue, a reliable message broker, a full text search engine and a metrics platform all in a single package.

    +

    Compared to conventional approaches that require separate servers and databases, Litestack offers superior performance, efficiency, ease of use, and cost savings. Its embedded database and cache reduce memory and CPU usage, while its simple interface streamlines the development process. Overall, Litestack sets a new standard for web application development and is an excellent choice for those who demand speed, efficiency, and simplicity.

    +

    You can read more about why litestack can be a good choice for your next web application here, you might also be interested in litestack benchmarks.

    +

    With litestack you only need to add a single gem to your app which would replace a host of other gems and services, for example, a typical Rails app using litestack will no longer need the following services:

    +
      +
    • Database Server (e.g. PostgreSQL, MySQL)
    • +
    • Cache Server (e.g. Redis, Memcached)
    • +
    • Job Processor (e.g. Sidekiq, Goodjob)
    • +
    • Pubsub Server (e.g. Redis, PostgreSQL)
    • +
    • Fulltext Search Server (e.g. Elasticsearch, Meilisearch)
    • +
    +

    To make it even more efficient, litestack will detect the presence of Fiber based IO frameworks like Async (e.g. when you use the Falcon web server) or Polyphony. It will then switch its background workers for caches and queues to fibers (using the semantics of the existing framework). This is done transparently and will generally lead to lower CPU and memory utilization. +litestack

    + +

    Add the litestack gem line to your application's Gemfile:

    + +

    To configure a Rails application to run the full litestack, run:

    +
    $ rails generate litestack:install
    +
    + +

    litestack currently offers six main components

    +
      +
    • litedb
    • +
    • litecache
    • +
    • litejob
    • +
    • litecable
    • +
    • litesearch
    • +
    • litemetric
    • +
    +
    +

    litedb

    +
    +

    litedb is a wrapper around SQLite3, offering a better default configuration that is tuned for concurrency and performance. Out of the box, litedb works seamlessly between multiple processes without database locking errors. litedb can be used in multiple ways, including:

    + +

    litedb can be used exactly as the SQLite3 gem, since litedb inherits from SQLite3

    +
    require 'litestack'
    +db = Litedb.new(path_to_db)
    +db.execute("create table users(id integer primary key, name text)")
    +db.execute("insert into users(name) values (?)", "Hamada")
    +db.query("select count(*) from users") # => [[1]]
    + +

    litedb provides tight Rails/ActiveRecord integration and can be configured as follows

    +

    In database.yml

    +
    adapter: litedb
    +# normal sqlite3 configuration follows
    + +

    litedb offers integration with the Sequel database toolkit and can be configured as follows

    +
    DB = Sequel.connect("litedb://path_to_db_file")
    +
    +

    litecache

    +
    +

    litecache is a high speed, low overhead caching library that uses SQLite as its backend. litecache can be accessed from multiple processes on the same machine seamlessly. It also has features like key expiry, LRU based eviction and increment/decrement of integer values.

    + +
    require 'litestack'
    +cache = Litecache.new(path: "path_to_file")
    +cache.set("key", "value")
    +cache.get("key") #=> "value"
    + +

    In your desired environment file (e.g. production.rb)

    +
    config.cache_store = :litecache, {path: './path/to/your/cache/file'}
    +

    This provides a transparent integration that uses the Rails caching interface

    +

    litecache spawns a background thread for cleanup purposes. In case it detects that the current environment has Fiber::Scheduler or Polyphony loaded it will spawn a fiber instead, saving on both memory and CPU cycles.

    +
    +

    litejob

    +
    +

    More info about Litejob can be found in the litejob guide

    +

    litejob is a fast and very efficient job queue processor for Ruby applications. It builds on top of SQLite as well, which provides transactional guarantees, persistence and exceptional performance.

    + +
    require 'litestack'
    +# define your job class
    +class MyJob
    +  include ::Litejob
    +      
    +  queue = :default
    +      
    +  # must implement perform, with any number of params
    +  def perform(params)
    +    # do stuff
    +  end
    +end
    +    
    +#schedule a job asynchronusly
    +MyJob.perform_async(params)
    +    
    +#schedule a job at a certain time
    +MyJob.perform_at(time, params)
    +    
    +#schedule a job after a certain delay
    +MyJob.perform_after(delay, params)
    + +

    In your desired environment file (e.g. production.rb)

    +
    config.active_job.queue_adapter = :litejob
    + +

    You can add more configuration in litejob.yml (or config/litejob.yml if you are integrating with Rails)

    +
    queues:
    +    - [default, 1]
    +    - [urgent, 5]
    +    - [critical, 10, "spawn"]
    +

    The queues need to include a name and a priority (a number between 1 and 10) and can also optionally add the token "spawn", which means every job will run it its own concurrency context (thread or fiber)

    +
    +

    litecable

    +
    + +

    This is a drop in replacement adapter for actioncable that replaces async and other production adapters (e.g. PostgreSQL, Redis). This adapter is currently only tested in local (inline) mode.

    +

    Getting up and running with litecable requires configuring your cable.yaml file under the config/ directory

    +

    cable.yaml

    +
    development:
    +  adapter: litecable
    +
    +test:
    +  adapter: test
    +
    +staging:
    +  adapter: litecable
    +
    +production:
    +  adapter: litecable
    +
    +

    litesearch

    +
    + +

    Litesearch adds full text search capabilities to Litedb, you can use it in standalone mode as follows:

    +
    require 'litestack/litedb'
    +db = Litedb.new(":memory:")
    +# create the index
    +idx = db.search_index('index_name') do |schema|
    +    schema.fields [:sender, :receiver, :body]
    +    schema.field :subject, weight: 10
    +    schema.tokenizer :trigram
    +end
    +# add documents
    +idx.add({sender: 'Kamal', receiver: 'Laila', subject: 'Are the girls awake?', body: 'I got them the new phones they asked for, are they awake?'})
    +# search the index, all fields
    +idx.search('kamal')
    +# search the index, specific field, partial workd (trigram)
    +idx.search('subject: awa') 
    +

    Litesearch integrates tightly with ActiveRecord and Sequel, here are integration examples

    + +
    class Author < ActiveRecord::Base
    +    has_many :books
    +end
    +
    +class Book < ActiveRecord::Base
    +    belongs_to :author
    +
    +    include Litesearch::Model
    +
    +    litesearch do |schema|
    +        schema.fields [:title, :description]
    +        schema.field :author, target: 'authors.name'
    +        schema.tokenizer :porter
    +    end
    +end
    +# insert records
    +Author.create(name: 'Adam A. Writer') 
    +Book.create(title: 'The biggest stunt', author_id: 1, description: 'a description') 
    +# search the index, the search method integrates with AR's query interface
    +Book.search('author: writer').limit(1).all
    + +
    class Author < Sequel::Model
    +    one_to_many :books
    +end
    +
    +class Book < Sequel::Model
    +    many_to_one :author
    +
    +    include Litesearch::Model
    +    litesearch do |schema|
    +        schema.fields [:title, :description]
    +        schema.field :author, target: 'authors.name'
    +        schema.tokenizer :porter
    +    end
    +end
    +# insert records
    +Author.create(name: 'Adam A. Writer') 
    +Book.create(title: 'The biggest stunt', author_id: 1, description: 'a description') 
    +# search the index, the search method integrates with Sequel's query interface
    +Book.search('author: writer').limit(1).all
    +
    +

    litemetric

    +
    + +

    Litestack comes with a module that can collect useful metrics for its different components, in each component, you need to add the following to the respective .yml file (database.yml in case of Litedb)

    +
        metrics: true # default is false
    +

    If you have the metrics enabled, it will start collecting data from the various modules and will store them in a database file called metric.db located in the Litesupport.root folder

    +

    Litemetric has an API that would enable collecting arbitrary metrics for non-litestack classes. The metrics will be in the database but currently the Liteboard is only able to show correct data for Litestack modules, displaying arbitrary metrics for other components will be included later.

    + +

    Liteboard is a simple web server that provides a web interface for the collected metrics, it should be available globally, for usage instructions type

    + +

    It allows you to point to a specific metrics database file or a config file and then it will display the data in that metrics database

    +

    Example metrics views:

    + +

    litedb

    +
      +
    • Database size, number of tables & indexes
    • +
    • Number of read/write queries
    • +
    • Read/Write query ratio over time
    • +
    • Read/Write query time over time
    • +
    • Slowest queries
    • +
    • Most expensive queries (total run time = frequency * cost)
    • +
    + +

    litecache

    +
      +
    • Cache size, % of size limit
    • +
    • Number of entries
    • +
    • Reads/Writes over time
    • +
    • Read hits/misses over time
    • +
    • Most written entries
    • +
    • Most read entries
    • +
    + +

    Bug reports and pull requests are welcome on GitHub at https://github.com/oldmoe/litestack.

    + +

    The gem is available as open source under the terms of the MIT License.

    +
    + + diff --git a/docs/posts/long-term-software-development.html b/docs/posts/long-term-software-development.html index d5ea771da1c..1c52c7f8ea6 100644 --- a/docs/posts/long-term-software-development.html +++ b/docs/posts/long-term-software-development.html @@ -143,6 +143,16 @@

    Runtime dependencies

  • A philosophy of software design, John Ousterhout - a modern take by a seasoned professional.
  • Large Scale C++ Software Design, John Lakos - I would not specifically recommend buying this book since much of what it describes is quite specific to old-style C++. However, if you chance on this work, its stories on very large scale software development are illustrative of the art. Has valuable words on how circular dependencies crop up, and how much they suck.
  • +

    Hacker News users cpeterso, rramadass and cratermoon have also suggested the following (thanks!):

    +

    Overwhelmingly, these are the recommendations for long-term software development:

    -

    Last updated 2 days, 8 hours ago

    +

    Last updated 2 days, 9 hours ago


    If you liked this post, please message, email, or follow me online, check out my work in progress, share this post or subscribe to my posts by RSS!

    diff --git a/docs/posts/what-s-making-me-happy-2024-12-21.html b/docs/posts/what-s-making-me-happy-2024-12-21.html index e7242d54b41..59c77fa24bc 100644 --- a/docs/posts/what-s-making-me-happy-2024-12-21.html +++ b/docs/posts/what-s-making-me-happy-2024-12-21.html @@ -17,7 +17,7 @@ Original

    What's making me happy 2024-12-21

    -

    Ugh, totally failed at getting these #happy posts out. But here is one more post before the year is over. Some of these links are from recent, and some are from drafts I created but never published.

    +

    Ugh, totally failed at getting these #happy posts out. But here is one more post before the year is over. Some of these links are from recent, and some are from drafts I created but never published.

    Listening

    • @@ -43,7 +43,7 @@

      Watching

      Reading

        diff --git a/docs/posts/wsda-usda-announce-eradication-of-northern-giant-hornet-from-the-united-states.html b/docs/posts/wsda-usda-announce-eradication-of-northern-giant-hornet-from-the-united-states.html new file mode 100644 index 00000000000..fcdb05934af --- /dev/null +++ b/docs/posts/wsda-usda-announce-eradication-of-northern-giant-hornet-from-the-united-states.html @@ -0,0 +1,218 @@ + + + + + + + James Routley | Feed + + + + Back + Original +

        WSDA, USDA announce eradication of northern giant hornet from the United States

        + +
        + + + + + + + + + +
        + +
        +
        + +
        + +
        + +
        +
        +
        +
        +
        +
        +
        +
        +

        Back +

        +
        +
        +
        +
        +
        +
        +
        +
        +
        + +
        +
        +
        + +
        +
        + +
        + +
        + + + +
        +
        +
        +

        +

        What do you need today?

        +

        + +
        +
        +
        + + + + +
        +
        +
        +
        +
        +

        +

        What do you need today?

        +

        + +
        +
        + + + +
        + + +
        + + + + +
        + +
        + +
        + +
        + + + + +
        + +
        + +
        +
        + +
        +

        Select your preferred language from the list:

        +
        + +
        + + +
        +
        +
        + + + + + +
        +
        +
        + +
        +
        + +
        + +
        +

        + 12/18/2024 +

        +
        +

        + Karla Salp +

        +
        + +
        +

        + 360-480-5397 +

        +
        + +
        +

        + +

        +
        + + + +
        + + + +
        +
        +

        + OLYMPIA – After three years without confirmed detections, the Washington State Department of Agriculture (WSDA) and the United States Department of Agriculture (USDA) have declared the northern giant hornet (Vespa mandarinia) eradicated from Washington and the United States.  

        ###

        +
        +
        + + +
        +
        +
        +
        +
        +
        + +
        +
        +
        +
        + + + + + + +
        + +