From 524fd9bde90fbe9c6e985ead5e6eac284192f427 Mon Sep 17 00:00:00 2001 From: Nick White Date: Fri, 25 Jan 2019 15:08:06 +0000 Subject: Add simple Otsu binarize tool (written a while ago) --- binarize/binarize.go | 38 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) create mode 100644 binarize/binarize.go (limited to 'binarize') diff --git a/binarize/binarize.go b/binarize/binarize.go new file mode 100644 index 0000000..0290ef4 --- /dev/null +++ b/binarize/binarize.go @@ -0,0 +1,38 @@ +package main + +import ( + "flag" + "fmt" + "log" + "os" + + "github.com/Ernyoke/Imger/threshold" + "github.com/Ernyoke/Imger/imgio" +) + +func main() { + flag.Usage = func() { + fmt.Fprintf(os.Stderr, "Usage: binarize inimg outimg\n") + flag.PrintDefaults() + } + flag.Parse() + if flag.NArg() < 2 { + flag.Usage() + os.Exit(1) + } + + img, err := imgio.ImreadGray(flag.Arg(0)) + if err != nil { + log.Fatalf("Could not read image %s\n", flag.Arg(0)) + } + + thresh, err := threshold.OtsuThreshold(img, threshold.ThreshBinary) + if err != nil { + log.Fatal("Error binarising image\n") + } + + err = imgio.Imwrite(thresh, flag.Arg(1)) + if err != nil { + log.Fatalf("Could not write image %s\n", flag.Arg(1)) + } +} -- cgit v1.2.1-24-ge1ad