diff options
| -rw-r--r-- | cmd/pagegraph/main.go | 82 | ||||
| -rw-r--r-- | graph.go | 28 | 
2 files changed, 103 insertions, 7 deletions
| diff --git a/cmd/pagegraph/main.go b/cmd/pagegraph/main.go new file mode 100644 index 0000000..fb2648f --- /dev/null +++ b/cmd/pagegraph/main.go @@ -0,0 +1,82 @@ +package main + +import ( +	"flag" +	"fmt" +	"log" +	"os" +	"path/filepath" +	"strings" + +	"rescribe.xyz/bookpipeline" +	"rescribe.xyz/utils/pkg/hocr" +) + +func walker(confs *[]*bookpipeline.Conf) filepath.WalkFunc { +	return func(path string, info os.FileInfo, err error) error { +		if info.IsDir() { +			return nil +		} +		if !strings.HasSuffix(path, ".hocr") { +			return nil +		} +		avg, err := hocr.GetAvgConf(path) +		if err != nil { +			if err.Error() == "No words found" { +				return nil +			} +			return err +		} +		c := bookpipeline.Conf{ +			Conf: avg, +			Path: path, +		} +		*confs = append(*confs, &c) +		return nil +	} +} + +func main() { +	flag.Usage = func() { +		fmt.Fprintln(flag.CommandLine.Output(), "Usage: pagegraph file.hocr graph.png") +		flag.PrintDefaults() +	} +	flag.Parse() + +	if flag.NArg() != 2 { +		flag.Usage() +		return +	} + +	wordconfs, err := hocr.GetWordConfs(flag.Arg(0)) +	if err != nil { +		log.Fatal(err) +	} +	var confs []*bookpipeline.Conf +	for n, wc := range wordconfs { +		c := bookpipeline.Conf{ +			Conf: wc, +			//Path: "fakepath", +			Path: fmt.Sprintf("word_%d", n), +		} +		confs = append(confs, &c) +	} + +	// Structure to fit what bookpipeline.Graph needs +	// TODO: probably reorganise bookpipeline to just need []*Conf +	cconfs := make(map[string]*bookpipeline.Conf) +	for _, c := range confs { +		cconfs[c.Path] = c +	} + +	fn := flag.Arg(1) +	f, err := os.Create(fn) +	if err != nil { +		log.Fatalln("Error creating file", fn, err) +	} +	defer f.Close() +	err = bookpipeline.GraphOpts(cconfs, filepath.Base(flag.Arg(0)), "Word number", false, f) +	if err != nil { +		log.Fatalln("Error creating graph", err) +	} +} @@ -43,6 +43,10 @@ func createLine(xvalues []float64, y float64, c drawing.Color) chart.ContinuousS  }  func Graph(confs map[string]*Conf, bookname string, w io.Writer) error { +	return GraphOpts(confs, bookname, "Page number", true, w) +} + +func GraphOpts(confs map[string]*Conf, bookname string, xaxis string, guidelines bool, w io.Writer) error {  	if len(confs) == 0 {  		return errors.New("No valid confidences")  	} @@ -98,12 +102,16 @@ func Graph(confs map[string]*Conf, bookname string, w io.Writer) error {  	// Make last tick the final page  	final := graphconf[len(graphconf)-1]  	ticks[len(ticks)-1] = chart.Tick{final.Pgnum, fmt.Sprintf("%.0f", final.Pgnum)} -	for i := 1; i <= yticknum; i++ { +	for i := 0; i <= yticknum; i++ {  		n := float64(i * 100) / yticknum  		yticks = append(yticks, chart.Tick{n, fmt.Sprintf("%.1f", n)})  	}  	mainSeries := chart.ContinuousSeries{ +		Style: chart.Style{ +			StrokeColor:     chart.ColorBlue, +			FillColor:       chart.ColorAlternateBlue, +		},  		XValues: xvalues,  		YValues: yvalues,  	} @@ -145,7 +153,7 @@ func Graph(confs map[string]*Conf, bookname string, w io.Writer) error {  	// Create annotations  	var annotations []chart.Value2  	for _, c := range graphconf { -		if c.Conf > highconf || c.Conf < lowconf { +		if !guidelines || (c.Conf > highconf || c.Conf < lowconf) {  			annotations = append(annotations, chart.Value2{Label: fmt.Sprintf("%.0f", c.Pgnum), XValue: c.Pgnum, YValue: c.Conf})  		}  	} @@ -157,7 +165,7 @@ func Graph(confs map[string]*Conf, bookname string, w io.Writer) error {  		Width:      3840,  		Height:     2160,  		XAxis: chart.XAxis{ -			Name:      "Page number", +			Name:      xaxis,  			Range: &chart.ContinuousRange{  				Min: 0.0,  			}, @@ -173,15 +181,21 @@ func Graph(confs map[string]*Conf, bookname string, w io.Writer) error {  		},  		Series: []chart.Series{  			mainSeries, +			chart.AnnotationSeries{ +				Annotations: annotations, +			}, +		}, +	} +	if guidelines { +		for _, s := range []chart.Series{  			minSeries,  			maxSeries,  			goodCutoffSeries,  			mediumCutoffSeries,  			badCutoffSeries, -			chart.AnnotationSeries{ -				Annotations: annotations, -			}, -		}, +		} { +			graph.Series = append(graph.Series, s) +		}  	}  	return graph.Render(chart.PNG, w)  } | 
