power_unitary_divisors.sf 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. #!/usr/bin/ruby
  2. # Generate the k-th power unitary divisors of n.
  3. # See also:
  4. # https://oeis.org/A056624
  5. func power_udivisors(n, k=1) {
  6. var d = [1]
  7. for p,e in (n.factor_exp) {
  8. d << with(p**e) {|r| d.map {|u| u*r }... } if (e % k == 0)
  9. }
  10. return d.sort
  11. }
  12. for n in (1..20) {
  13. say "2-power unitary divisors of #{n} = #{power_udivisors(n, 2)}"
  14. assert_eq(power_udivisors(n, 2).len, 2.power_usigma0(n))
  15. assert_eq(power_udivisors(n, 2).sum, 2.power_usigma(n))
  16. assert_eq(power_udivisors(n, 3).len, 3.power_usigma0(n))
  17. assert_eq(power_udivisors(n, 3).sum, 3.power_usigma(n))
  18. assert_eq(power_udivisors(n, 2), 2.power_udivisors(n))
  19. assert_eq(power_udivisors(n, 3), 3.power_udivisors(n))
  20. }
  21. __END__
  22. 2-power unitary divisors of 1 = [1]
  23. 2-power unitary divisors of 2 = [1]
  24. 2-power unitary divisors of 3 = [1]
  25. 2-power unitary divisors of 4 = [1, 4]
  26. 2-power unitary divisors of 5 = [1]
  27. 2-power unitary divisors of 6 = [1]
  28. 2-power unitary divisors of 7 = [1]
  29. 2-power unitary divisors of 8 = [1]
  30. 2-power unitary divisors of 9 = [1, 9]
  31. 2-power unitary divisors of 10 = [1]
  32. 2-power unitary divisors of 11 = [1]
  33. 2-power unitary divisors of 12 = [1, 4]
  34. 2-power unitary divisors of 13 = [1]
  35. 2-power unitary divisors of 14 = [1]
  36. 2-power unitary divisors of 15 = [1]
  37. 2-power unitary divisors of 16 = [1, 16]
  38. 2-power unitary divisors of 17 = [1]
  39. 2-power unitary divisors of 18 = [1, 9]
  40. 2-power unitary divisors of 19 = [1]
  41. 2-power unitary divisors of 20 = [1, 4]