mathtools/cmd/convergents.go

75 lines
2.3 KiB
Go
Raw Permalink Normal View History

2025-08-19 03:18:10 +00:00
/*
Copyright © 2025 filifa
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
package cmd
import (
"fmt"
"math/big"
"github.com/spf13/cobra"
2025-09-06 04:19:56 +00:00
"scm.dairydemon.net/filifa/mathtools/internal/lib"
2025-08-19 03:18:10 +00:00
)
2025-09-06 00:35:10 +00:00
func convergents(cmd *cobra.Command, args []string) {
2025-08-19 03:18:10 +00:00
a0, ok := new(big.Int).SetString(args[0], 10)
if !ok {
2025-08-28 01:33:44 +00:00
cobra.CheckErr("invalid input " + args[0])
2025-08-19 03:18:10 +00:00
}
2025-09-06 00:35:10 +00:00
denoms := make([]*big.Int, len(args[1:]))
2025-08-19 03:18:10 +00:00
for i, d := range args[1:] {
2025-09-06 00:35:10 +00:00
denoms[i] = new(big.Int)
_, ok := denoms[i].SetString(d, 10)
2025-08-19 03:18:10 +00:00
if !ok {
2025-08-28 01:33:44 +00:00
cobra.CheckErr("invalid input " + d)
2025-08-19 03:18:10 +00:00
}
}
2025-09-06 04:19:56 +00:00
for r := range lib.CFracConvergents(a0, denoms) {
2025-08-19 03:50:19 +00:00
fmt.Println(r)
2025-08-19 03:18:10 +00:00
}
}
2025-08-19 03:50:19 +00:00
// FIXME: should support an initial block of non-periodic denominators (will need flags)
2025-08-19 03:18:10 +00:00
// convergentsCmd represents the convergents command
var convergentsCmd = &cobra.Command{
Use: "convergents N N [N ...]",
Short: "Compute convergents of a periodic continued fraction",
2025-09-18 01:02:05 +00:00
Long: `Compute convergents of a periodic continued fraction.
The first number given is the integer part. The following numbers give the repetend of the continued fraction.
This will output convergents infinitely. Try piping to head to only output a certain number of convergents, like this:
mathtools convergents 3 2 6 | head -n 5`,
Args: cobra.MinimumNArgs(2),
Run: convergents,
2025-08-19 03:18:10 +00:00
}
func init() {
rootCmd.AddCommand(convergentsCmd)
// Here you will define your flags and configuration settings.
// Cobra supports Persistent Flags which will work for this command
// and all subcommands, e.g.:
// convergentsCmd.PersistentFlags().String("foo", "", "A help for foo")
// Cobra supports local flags which will only run when this command
// is called directly, e.g.:
// convergentsCmd.Flags().BoolP("toggle", "t", false, "Help message for toggle")
}