<?xml version="1.0" encoding="UTF-8" standalone="no"?><rss xmlns:itunes="http://www.itunes.com/dtds/podcast-1.0.dtd" version="2.0"><channel><title>Perl Weekly newsletter</title><description>A free, once a week e-mail round-up of hand-picked news and articles about Perl.</description><link>https://perlweekly.com/</link><copyright>Copyright 2011-2026, Gabor Szabo</copyright><dc:language xmlns:dc="http://purl.org/dc/elements/1.1/">en-us</dc:language><dc:rights xmlns:dc="http://purl.org/dc/elements/1.1/">Copyright 2011-2026, Gabor Szabo</dc:rights><dc:publisher xmlns:dc="http://purl.org/dc/elements/1.1/">szabgab@gmail.com</dc:publisher><syn:updateBase xmlns:syn="http://purl.org/rss/1.0/modules/syndication/">2011-08-01T00:00+00:00</syn:updateBase><syn:updateFrequency xmlns:syn="http://purl.org/rss/1.0/modules/syndication/">1</syn:updateFrequency><syn:updatePeriod xmlns:syn="http://purl.org/rss/1.0/modules/syndication/">weekly</syn:updatePeriod><language>en-us</language><item><title>The Perl and Raku Conference 2026</title><link>https://tprc.us/tprc-2026-gsp/</link><pubDate>2026-05-04T10:00:30Z</pubDate><guid isPermaLink="true">https://tprc.us/tprc-2026-gsp/</guid><description>June 26-29, 2026, Greenville, SC, USA</description><dc:subject xmlns:dc="http://purl.org/dc/elements/1.1/">Events</dc:subject></item><item><title>Boston Perl Mongers virtual monthly</title><link>https://boston.pm.org/</link><pubDate>2026-05-04T10:00:29Z</pubDate><guid isPermaLink="true">https://boston.pm.org/</guid><description>May 12, 2026</description><dc:subject xmlns:dc="http://purl.org/dc/elements/1.1/">Events</dc:subject></item><item><title>Exploring Perl Modules</title><link>https://luma.com/perl-maven</link><pubDate>2026-05-04T10:00:28Z</pubDate><guid isPermaLink="true">https://luma.com/perl-maven</guid><description>May 7, 2026</description><dc:subject xmlns:dc="http://purl.org/dc/elements/1.1/">Events</dc:subject></item><item><title>Perl Toolchain Summit in Vienna</title><link>https://domm.plix.at/perl/2026_04_perl_toolchain_summit.html</link><pubDate>2026-05-04T10:00:27Z</pubDate><guid isPermaLink="true">https://domm.plix.at/perl/2026_04_perl_toolchain_summit.html</guid><description>A little review by the local orga.</description><dc:subject xmlns:dc="http://purl.org/dc/elements/1.1/">Event reports</dc:subject></item><item><title>Welcome to the Perl Toolchain Summit 2026!</title><link>https://blogs.perl.org/users/book/2026/04/welcome-to-the-perl-toolchain-summit-2026.html</link><pubDate>2026-05-04T10:00:26Z</pubDate><guid isPermaLink="true">https://blogs.perl.org/users/book/2026/04/welcome-to-the-perl-toolchain-summit-2026.html</guid><description>That's how it started</description><dc:subject xmlns:dc="http://purl.org/dc/elements/1.1/">Event reports</dc:subject></item><item><title>NICEPERL's lists</title><link>http://niceperl.blogspot.com/</link><pubDate>2026-05-04T10:00:25Z</pubDate><guid isPermaLink="true">http://niceperl.blogspot.com/</guid><description>&lt;a href="https://niceperl.blogspot.com/2026/05/dxcviii-17-great-cpan-modules-released.html"&gt;Great CPAN modules released last week&lt;/a&gt;.</description><dc:subject xmlns:dc="http://purl.org/dc/elements/1.1/">Weekly collections</dc:subject></item><item><title>Question the bits</title><link>https://dev.to/simongreennet/weekly-challenge-question-the-bits-4lnd</link><pubDate>2026-05-04T10:00:24Z</pubDate><guid isPermaLink="true">https://dev.to/simongreennet/weekly-challenge-question-the-bits-4lnd</guid><description>Using bit manipulation, this solution works well to create all combinations of subsets by iterating through all integers from 1 to 2^n-2, thus avoiding the empty and full subsets. The inner loop adds pos+1 because the indices in a array have a base index of 1, while the implementation does not require any third-party modules, making it portable and easy to use for individuals who are already comfortable using bit mask manipulation.</description><dc:subject xmlns:dc="http://purl.org/dc/elements/1.1/">The Weekly Challenge</dc:subject></item><item><title>Missing Equilibrium</title><link>https://blog.firedrake.org/archive/2026/05/The_Weekly_Challenge_371__Missing_Equilibrium.html</link><pubDate>2026-05-04T10:00:23Z</pubDate><guid isPermaLink="true">https://blog.firedrake.org/archive/2026/05/The_Weekly_Challenge_371__Missing_Equilibrium.html</guid><description>Roger demonstrates a very clever way of optimizing the solution through the precomputation of one list of differences so that only the check for the sum of the selected differences equals zero must occur, which substantially reduces the amount of computing needed within the combinatorial loops. Roger does a great job of providing a perspective of how to write this in many programming languages (Raku, Kotlin, Crystal, etc.) and provides many practical examples (like sorting the list to create a consistent order for output), thereby making this solution efficient and easily transferable across many different programming languages.</description><dc:subject xmlns:dc="http://purl.org/dc/elements/1.1/">The Weekly Challenge</dc:subject></item><item><title>The Weekly Challenge #371</title><link>https://hatley-software.blogspot.com/2026/05/robbie-hatleys-solutions-in-perl-for.html</link><pubDate>2026-05-04T10:00:22Z</pubDate><guid isPermaLink="true">https://hatley-software.blogspot.com/2026/05/robbie-hatleys-solutions-in-perl-for.html</guid><description>This document offers an innovative and realistic perspective on the subset equilibrium issue by acknowledging there is no "smart" optimisation to the subset equilibrium solution and then using a simple combination-based search on the two to n-1 sizes. The solution was implemented correctly with a summation on 1-indexed values for each of those combinations.</description><dc:subject xmlns:dc="http://purl.org/dc/elements/1.1/">The Weekly Challenge</dc:subject></item><item><title>The Weekly Challenge - 371: Subset Equilibrium</title><link>https://reiniermaliepaard.nl/pwc/index.php?id=pwc371-2</link><pubDate>2026-05-04T10:00:21Z</pubDate><guid isPermaLink="true">https://reiniermaliepaard.nl/pwc/index.php?id=pwc371-2</guid><description>This document includes an excellent comparison of two CPAN modules (Algorithm::Combinatorics and Data::PowerSet) that correctly identifies the combinatorically generated subsets by size (2 to n) are more efficient than generating the power set and filtering out the subsets to produce the same result for this specific task. The code base is very clean and well-structured; it also does a great job of utilising list slicing (@nums[@$subset]) and map to convert from 0-based to 1-based position, while making use of the helper function print_result to ensure that all output for all test cases is consistent and easy to read.</description><dc:subject xmlns:dc="http://purl.org/dc/elements/1.1/">The Weekly Challenge</dc:subject></item><item><title>The Weekly Challenge - 371: Missing Value</title><link>https://reiniermaliepaard.nl/pwc/index.php?id=pwc371-1</link><pubDate>2026-05-04T10:00:20Z</pubDate><guid isPermaLink="true">https://reiniermaliepaard.nl/pwc/index.php?id=pwc371-1</guid><description>This solution requires formalization of the detection of repeating patterns through a comprehensive and well-documented approach by treating them as a repeating two-stage model (i.e., d1 = d3 and d2 = d4). Special consideration is given to both constant and alternating sequences. The use of defined-or (i.e., //=) to unify step values, along with the straightforward relationship between each possible question mark position and its simple arithmetic reconstruction, contributes to creating a code that is highly reliable and easy to follow. Additionally, the thorough input validation provided demonstrates significant consideration for actually implementing in a real world scenario.</description><dc:subject xmlns:dc="http://purl.org/dc/elements/1.1/">The Weekly Challenge</dc:subject></item><item><title>Solve the question and balance the subset</title><link>http://ccgi.campbellsmiths.force9.co.uk/challenge/371</link><pubDate>2026-05-04T10:00:19Z</pubDate><guid isPermaLink="true">http://ccgi.campbellsmiths.force9.co.uk/challenge/371</guid><description>By using established neighboring letter pairs, the algorithm determines the steps $a and $b in an efficient manner by deducing which are the next alternately patterned letter combinations in relation to each of the five positions for question marks. The entire algorithm utilises a single conditional expression to account for all five possible question mark positions. Additionally, the use of the modulus operator and the mapping of the patterning logic from the analysis to the assignment of steps makes this implementation both very efficient and very easy to read.</description><dc:subject xmlns:dc="http://purl.org/dc/elements/1.1/">The Weekly Challenge</dc:subject></item><item><title>My subset is-a missing a letter…</title><link>https://packy.dardan.com/b/of</link><pubDate>2026-05-04T10:00:18Z</pubDate><guid isPermaLink="true">https://packy.dardan.com/b/of</guid><description>The solution has a nice, clean, multi-language implementation (Raku, Perl, Python, Elixir) and uses indexed pairs of values to keep track of the relationship between the two elements and the index position of the two elements, thus having no off-by-one errors. The solution meets the "proper subset" constraints by filtering out empty sets, singletons, and the full set as well as providing lots of detail in verbose output to help educate the user by giving exact values and sums of values for each match.</description><dc:subject xmlns:dc="http://purl.org/dc/elements/1.1/">The Weekly Challenge</dc:subject></item><item><title>The Missing Equilibrium</title><link>https://github.com/MatthiasMuth/perlweeklychallenge-club/tree/muthm-371/challenge-371/matthias-muth#readme</link><pubDate>2026-05-04T10:00:17Z</pubDate><guid isPermaLink="true">https://github.com/MatthiasMuth/perlweeklychallenge-club/tree/muthm-371/challenge-371/matthias-muth#readme</guid><description>By mathematically restructuring the main condition in the problem, i.e. equality of the total values for elements and their corresponding indices. Additionally, utilising the combination iterators from Algorithm::Combinatorics with subset sizes of 2 through n-1 provides a memory efficient approach to solving this exponential complexity problem while utilizing an optimally prepared array of pre-computed offsets, or at least the offsets for an individual index, gives evidence of thoughtful programming.</description><dc:subject xmlns:dc="http://purl.org/dc/elements/1.1/">The Weekly Challenge</dc:subject></item><item><title>Perl Weekly Challenge 371</title><link>https://wlmb.github.io/2026/04/27/PWC371/</link><pubDate>2026-05-04T10:00:16Z</pubDate><guid isPermaLink="true">https://wlmb.github.io/2026/04/27/PWC371/</guid><description>The post describes a simple yet effective way to generate all proper subsets of a set. It uses the subset function of the Algorithm::Combinatorics module to create all proper subsets, and then filters them based on a very concise expression written as a single line. The script contains both a command-line version for easy use and a complete version that includes error handling and has been thoroughly tested.</description><dc:subject xmlns:dc="http://purl.org/dc/elements/1.1/">The Weekly Challenge</dc:subject></item><item><title>Missing Equilibria</title><link>https://github.sommrey.de/the-bears-den/2026/05/01/ch-371.html</link><pubDate>2026-05-04T10:00:15Z</pubDate><guid isPermaLink="true">https://github.sommrey.de/the-bears-den/2026/05/01/ch-371.html</guid><description>This new solution offers an evaluation of the subset equilibrium problem that is a new and interesting technical perspective and acknowledges the shared views of the two demonstrated examples, while not overlooking those cases where the two may have disagreement along the edges of each set of criteria. The Perl code produced using Math::Prime::Util::forcomb and List::Gather is exceptionally simple but has an artistic style as well.</description><dc:subject xmlns:dc="http://purl.org/dc/elements/1.1/">The Weekly Challenge</dc:subject></item><item><title>Perl Weekly Challenge: Week 371</title><link>https://www.braincells.com/perl/2026/05/perl_weekly_challenge_week_371.html</link><pubDate>2026-05-04T10:00:14Z</pubDate><guid isPermaLink="true">https://www.braincells.com/perl/2026/05/perl_weekly_challenge_week_371.html</guid><description>This solution gives a clean, efficient implementation that fulfills both the requirement of a proper subset and utilising 1-based indexing by adding + @combo.elems to the index sum. By making use of combinations from Algorithm::Combinatorics in Perl (and using built-in combinations in Raku), only the necessary subset sizes are generated; the output formatting handles both the non-empty and empty result cases in a very clean manner via a clear ternary expression.</description><dc:subject xmlns:dc="http://purl.org/dc/elements/1.1/">The Weekly Challenge</dc:subject></item><item><title>Subset Equilibrium (Just nod if you can hear me)</title><link>https://dev.to/boblied/pwc-371-subset-equilibrium-just-nod-if-you-can-hear-me-14im</link><pubDate>2026-05-04T10:00:13Z</pubDate><guid isPermaLink="true">https://dev.to/boblied/pwc-371-subset-equilibrium-just-nod-if-you-can-hear-me-14im</guid><description>Bob addressed the exponential number of complex solutions from the outset and provided a practical implementation based on Algorithm::Combinatorics. The use of a positional-based iterator with zero-index compensation allowed him to effectively handle the off-by-one requirement. In addition to that, Bob supplied practical testing strategies using the Test2::Tools::Compare package.</description><dc:subject xmlns:dc="http://purl.org/dc/elements/1.1/">The Weekly Challenge</dc:subject></item><item><title>Missing Equilibrium</title><link>https://raku-musings.com/missing-equilibrium.html</link><pubDate>2026-05-04T10:00:12Z</pubDate><guid isPermaLink="true">https://raku-musings.com/missing-equilibrium.html</guid><description>The Raku Solution implements this approach using combinations to easily create subsets in an idiomatic and very readable way. It also provides an elegant way of compensating for zero-based indices when calculating the sum of the positions in each subset by the calculated subsets.</description><dc:subject xmlns:dc="http://purl.org/dc/elements/1.1/">The Weekly Challenge</dc:subject></item><item><title>Perl Weekly Challenge 371: Subset Equilibrium</title><link>https://abigail.github.io/HTML/Perl-Weekly-Challenge/week-371-2.html</link><pubDate>2026-05-04T10:00:11Z</pubDate><guid isPermaLink="true">https://abigail.github.io/HTML/Perl-Weekly-Challenge/week-371-2.html</guid><description>This solution is a well-organised that defines the NP-complete status of this problem and also implements an efficient bitmasking solution in numerous programming languages (e.g., Perl, Python, AWK, C, etc.) and serves as an excellent reference for other programmers to learn about and use for comparison purposes.</description><dc:subject xmlns:dc="http://purl.org/dc/elements/1.1/">The Weekly Challenge</dc:subject></item><item><title>Perl Weekly Challenge 371: Missing Letter</title><link>https://abigail.github.io/HTML/Perl-Weekly-Challenge/week-371-1.html</link><pubDate>2026-05-04T10:00:10Z</pubDate><guid isPermaLink="true">https://abigail.github.io/HTML/Perl-Weekly-Challenge/week-371-1.html</guid><description>Abigail gives us an efficient solution, O(n), to the missing letter problem by determining the difference between the sum of all letters in a full range of letters and the sum of the letters in the given array. This eliminates unnecessary loops, which is a big advantage over an iterative search.</description><dc:subject xmlns:dc="http://purl.org/dc/elements/1.1/">The Weekly Challenge</dc:subject></item><item><title>RECAP - The Weekly Challenge - 371</title><link>https://theweeklychallenge.org/blog/recap-challenge-371</link><pubDate>2026-05-04T10:00:09Z</pubDate><guid isPermaLink="true">https://theweeklychallenge.org/blog/recap-challenge-371</guid><description>Enjoy a quick recap of last week's contributions by Team PWC dealing with the "Missing Letter" and "Subset Equilibrium" tasks in Perl and Raku. You will find plenty of solutions to keep you busy.</description><dc:subject xmlns:dc="http://purl.org/dc/elements/1.1/">The Weekly Challenge</dc:subject></item><item><title>The Weekly Challenge - 372</title><link>https://theweeklychallenge.org/blog/perl-weekly-challenge-372</link><pubDate>2026-05-04T10:00:08Z</pubDate><guid isPermaLink="true">https://theweeklychallenge.org/blog/perl-weekly-challenge-372</guid><description>Welcome to a new week with a couple of fun tasks "Rearrange Spaces" and "Largest Substring". If you are new to the weekly challenge then why not join us and have fun every week. For more information, please read the &lt;a href="https://theweeklychallenge.org/faq"&gt;FAQ&lt;/a&gt;.</description><dc:subject xmlns:dc="http://purl.org/dc/elements/1.1/">The Weekly Challenge</dc:subject></item><item><title>Perl in Ubuntu 26-04 LTS (vs 24-04 LTS) </title><link>https://www.reddit.com/r/perl/comments/1sz3521/perl_in_ubuntu_2604_lts_vs_2404_lts/</link><pubDate>2026-05-04T10:00:07Z</pubDate><guid isPermaLink="true">https://www.reddit.com/r/perl/comments/1sz3521/perl_in_ubuntu_2604_lts_vs_2404_lts/</guid><description>Some Perl modules need a dev package to be installed using 'apt'.</description><dc:subject xmlns:dc="http://purl.org/dc/elements/1.1/">Discussion</dc:subject></item><item><title>Module naming vs CPAN conventions</title><link>https://www.reddit.com/r/perl/comments/1t0lpjf/module_naming_vs_cpan_conventions/</link><pubDate>2026-05-04T10:00:06Z</pubDate><guid isPermaLink="true">https://www.reddit.com/r/perl/comments/1t0lpjf/module_naming_vs_cpan_conventions/</guid><description></description><dc:subject xmlns:dc="http://purl.org/dc/elements/1.1/">Discussion</dc:subject></item><item><title>sending matrix messages</title><link>https://www.reddit.com/r/perl/comments/1t0yrko/sending_matrix_messages/</link><pubDate>2026-05-04T10:00:05Z</pubDate><guid isPermaLink="true">https://www.reddit.com/r/perl/comments/1t0yrko/sending_matrix_messages/</guid><description></description><dc:subject xmlns:dc="http://purl.org/dc/elements/1.1/">Discussion</dc:subject></item><item><title>Reading CPAN Testers Reports Using AI Agents</title><link>https://blogs.perl.org/users/preaction/2026/04/reading-cpan-testers-reports-using-ai-agents.html</link><pubDate>2026-05-04T10:00:04Z</pubDate><guid isPermaLink="true">https://blogs.perl.org/users/preaction/2026/04/reading-cpan-testers-reports-using-ai-agents.html</guid><description>A very interesting and useful use of AI.</description><dc:subject xmlns:dc="http://purl.org/dc/elements/1.1/">Articles</dc:subject></item><item><title>Who tests the tester? Me !!!</title><link>https://blogs.perl.org/users/lichtkind/2026/04/who-tests-the-tester-me.html</link><pubDate>2026-05-04T10:00:03Z</pubDate><guid isPermaLink="true">https://blogs.perl.org/users/lichtkind/2026/04/who-tests-the-tester-me.html</guid><description>I was just showing the participants of the 'Testing in Perl' course how to write and test a Test::* module. It is nice to see that about the same time Lichtkind wrote an article about the same topic.</description><dc:subject xmlns:dc="http://purl.org/dc/elements/1.1/">Articles</dc:subject></item><item><title>TPRC Announces Post Conference Class</title><link>https://news.perlfoundation.org/post/tprc-post-conference-class</link><pubDate>2026-05-04T10:00:02Z</pubDate><guid isPermaLink="true">https://news.perlfoundation.org/post/tprc-post-conference-class</guid><description>Steven Lembark is presenting: Teaching AI New Tricks: Perly MCP's for Claude.</description><dc:subject xmlns:dc="http://purl.org/dc/elements/1.1/">Articles</dc:subject></item><item><title>ANNOUNCE: Perl.Wiki V 1.45 etc</title><link>https://blogs.perl.org/users/ron_savage/2026/05/announce-perlwiki-v-145-etc.html</link><pubDate>2026-05-04T10:00:01Z</pubDate><guid isPermaLink="true">https://blogs.perl.org/users/ron_savage/2026/05/announce-perlwiki-v-145-etc.html</guid><description></description><dc:subject xmlns:dc="http://purl.org/dc/elements/1.1/">Articles</dc:subject></item><item><title>#771 - Exploring Perl Modules</title><link>https://perlweekly.com/archive/771.html</link><pubDate>2026-05-04T10:00:00Z</pubDate><guid isPermaLink="true">https://perlweekly.com/archive/771.html</guid><description>&lt;p&gt;Hi there,&lt;/p&gt;
&lt;p&gt;I put the 'Testing in Perl' course on hold for now. Instead of that we are going to explore the use of some of the mocking libraries we saw during the course. In the next session we'll pick one of the Perl modules used for mocking and we'll look for modules that use it. We'll try to understand how it is being used and we'll try to contribute something to at least one of the modules.&lt;/p&gt;
&lt;p&gt;For background you can check the &lt;a href="https://osdc.code-maven.com/perl"&gt;OSDC Perl&lt;/a&gt; page where we have a listing of modules for 'Code reading'.&lt;/p&gt;
&lt;p&gt;You can also watch the recording of the &lt;a href="https://academy.code-maven.com/c/perl-testing-2026"&gt;Testing in Perl course&lt;/a&gt;. (Registration required but these videos are currently free of charge.)&lt;/p&gt;
&lt;p&gt;Enjoy your week!&lt;/p&gt;</description><dc:subject xmlns:dc="http://purl.org/dc/elements/1.1/">Editorial</dc:subject></item></channel></rss>