2020-07-29 16:01:39 +08:00
|
|
|
module Uplot
|
|
|
|
class Command
|
|
|
|
def initialize(argv)
|
|
|
|
@params = {}
|
|
|
|
@ptype = nil
|
|
|
|
parse_options(argv)
|
|
|
|
end
|
|
|
|
|
2020-07-30 11:44:31 +08:00
|
|
|
def opt_new
|
|
|
|
OptionParser.new do |opt|
|
2020-07-30 11:47:02 +08:00
|
|
|
opt.on('-o', '--output', TrueClass) { |v| @output = v }
|
2020-07-30 11:44:31 +08:00
|
|
|
opt.on('-t', '--title VAL', String) { |v| @params[:title] = v }
|
|
|
|
opt.on('-w', '--width VAL', Numeric) { |v| @params[:width] = v }
|
|
|
|
opt.on('-h', '--height VAL', Numeric) { |v| @params[:height] = v }
|
|
|
|
opt.on('-b', '--border VAL', Numeric) { |v| @params[:border] = v }
|
|
|
|
opt.on('-m', '--margin VAL', Numeric) { |v| @params[:margin] = v }
|
|
|
|
opt.on('-p', '--padding VAL', Numeric) { |v| @params[:padding] = v }
|
|
|
|
opt.on('-l', '--labels', TrueClass) { |v| @params[:labels] = v }
|
2020-07-29 18:01:10 +08:00
|
|
|
end
|
2020-07-30 11:44:31 +08:00
|
|
|
end
|
2020-07-29 16:01:39 +08:00
|
|
|
|
2020-07-30 11:44:31 +08:00
|
|
|
def parse_options(argv)
|
|
|
|
main_parser = opt_new
|
|
|
|
parsers = {}
|
|
|
|
parsers['hist'] = opt_new.on('--nbins VAL', Numeric) { |v| @params[:nbins] = v }
|
|
|
|
parsers['histogram'] = parsers['hist']
|
|
|
|
parsers['line'] = opt_new
|
|
|
|
parsers['lineplot'] = parsers['line']
|
|
|
|
parsers['lines'] = opt_new
|
|
|
|
|
|
|
|
main_parser.banner = <<~MSG
|
2020-07-30 10:48:27 +08:00
|
|
|
Usage:\tuplot <command> [options]
|
2020-07-30 11:44:31 +08:00
|
|
|
Command:\t#{parsers.keys.join(' ')}
|
2020-07-30 10:48:27 +08:00
|
|
|
MSG
|
2020-07-30 11:44:31 +08:00
|
|
|
main_parser.order!(argv)
|
2020-07-30 10:48:27 +08:00
|
|
|
@ptype = argv.shift
|
2020-07-29 16:01:39 +08:00
|
|
|
|
2020-07-30 11:44:31 +08:00
|
|
|
unless parsers.has_key?(@ptype)
|
|
|
|
warn "unrecognized command '#{@ptype}'"
|
|
|
|
exit 1
|
|
|
|
end
|
|
|
|
parser = parsers[@ptype]
|
|
|
|
parser.parse!(argv) unless argv.empty?
|
2020-07-30 10:48:27 +08:00
|
|
|
end
|
|
|
|
|
2020-07-29 16:01:39 +08:00
|
|
|
def run
|
2020-07-30 09:37:20 +08:00
|
|
|
# Sometimes the input file does not end with a newline code.
|
|
|
|
while input = Kernel.gets(nil)
|
|
|
|
input_lines = input.split(/\R/)
|
|
|
|
case @ptype
|
|
|
|
when 'hist', 'histogram'
|
|
|
|
histogram(input_lines)
|
|
|
|
when 'line', 'lineplot'
|
|
|
|
line(input_lines)
|
|
|
|
when 'lines'
|
|
|
|
lines(input_lines)
|
|
|
|
end.render($stderr)
|
2020-07-29 16:01:39 +08:00
|
|
|
|
2020-07-30 11:47:02 +08:00
|
|
|
print input if @output
|
2020-07-30 09:37:20 +08:00
|
|
|
end
|
2020-07-29 16:01:39 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
def histogram(input_lines)
|
|
|
|
series = input_lines.map(&:to_f)
|
2020-07-30 10:08:36 +08:00
|
|
|
UnicodePlot.histogram(series, **@params.compact)
|
2020-07-29 16:01:39 +08:00
|
|
|
end
|
2020-07-29 17:24:08 +08:00
|
|
|
|
|
|
|
def line(input_lines)
|
|
|
|
x = []
|
|
|
|
y = []
|
|
|
|
input_lines.each_with_index do |l, i|
|
|
|
|
x[i], y[i] = l.split("\t")[0..1].map(&:to_f)
|
|
|
|
end
|
2020-07-30 10:08:36 +08:00
|
|
|
UnicodePlot.lineplot(x, y, **@params.compact)
|
2020-07-29 17:24:08 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
def lines(input_lines)
|
|
|
|
n_cols = input_lines[0].split("\t").size
|
2020-07-30 09:37:20 +08:00
|
|
|
cols = Array.new(n_cols) { [] }
|
2020-07-29 17:24:08 +08:00
|
|
|
input_lines.each_with_index do |row, i|
|
|
|
|
row.split("\t").each_with_index do |v, j|
|
|
|
|
cols[j][i] = v.to_f
|
|
|
|
end
|
|
|
|
end
|
2020-07-30 10:08:36 +08:00
|
|
|
plot = UnicodePlot.lineplot(cols[0], cols[1], **@params.compact)
|
2020-07-29 17:24:08 +08:00
|
|
|
2.upto(n_cols - 1) do |i|
|
|
|
|
UnicodePlot.lineplot!(plot, cols[0], cols[i])
|
|
|
|
end
|
|
|
|
plot
|
|
|
|
end
|
2020-07-29 16:01:39 +08:00
|
|
|
end
|
|
|
|
end
|