Skip to content

Commit

Permalink
Add reverse to count
Browse files Browse the repository at this point in the history
  • Loading branch information
kojix2 committed May 31, 2021
1 parent 49626d5 commit 4651c69
Show file tree
Hide file tree
Showing 7 changed files with 89 additions and 28 deletions.
36 changes: 22 additions & 14 deletions lib/youplot/backends/processing.rb
Original file line number Diff line number Diff line change
Expand Up @@ -6,22 +6,30 @@ module Backends
module Processing
module_function

def count_values(arr, tally: true)
def count_values(arr, tally: true, reverse: false)
# tally was added in Ruby 2.7
if tally && Enumerable.method_defined?(:tally)
arr.tally
else
# value_counts Enumerable::Statistics
arr.value_counts(dropna: false)
end
.sort do |a, b|
# compare values
r = b[1] <=> a[1]
# If the values are the same, compare by name
r = a[0] <=> b[0] if r == 0
r
result = \
if tally && Enumerable.method_defined?(:tally)
arr.tally
else
# value_counts Enumerable::Statistics
arr.value_counts(dropna: false)
end
.transpose

# sorting
result = result.sort do |a, b|
# compare values
r = b[1] <=> a[1]
# If the values are the same, compare by name
r = a[0] <=> b[0] if r == 0
r
end

# --reverse option
result.reverse! if reverse

# prepare for barplot
result.transpose
end
end
end
Expand Down
4 changes: 2 additions & 2 deletions lib/youplot/backends/unicode_plot.rb
Original file line number Diff line number Diff line change
Expand Up @@ -14,12 +14,12 @@ class Error < StandardError; end

module_function

def barplot(data, params, fmt = nil, count: false)
def barplot(data, params, fmt = nil, count: false, reverse: false)
headers = data.headers
series = data.series
# `uplot count`
if count
series = Processing.count_values(series[0])
series = Processing.count_values(series[0], reverse: reverse)
params.title = headers[0] if headers
end
if series.size == 1
Expand Down
2 changes: 1 addition & 1 deletion lib/youplot/command.rb
Original file line number Diff line number Diff line change
Expand Up @@ -146,7 +146,7 @@ def create_plot
when :bar, :barplot
@backend.barplot(data, params, options[:fmt])
when :count, :c
@backend.barplot(data, params, count: true)
@backend.barplot(data, params, count: true, reverse: options[:reverse])
when :hist, :histogram
@backend.histogram(data, params)
when :line, :lineplot
Expand Down
3 changes: 2 additions & 1 deletion lib/youplot/options.rb
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,8 @@ module YouPlot
:fmt,
:progressive,
:encoding,
:color_names,
:reverse, # count
:color_names, # color
:debug,
keyword_init: true
)
Expand Down
9 changes: 7 additions & 2 deletions lib/youplot/parser.rb
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ def initialize
fmt: 'xyy',
progressive: false,
encoding: nil,
reverse: false,
color_names: false,
debug: false
)
Expand Down Expand Up @@ -163,7 +164,8 @@ def sub_parser_add_xscale
end

def sub_parser_add_canvas
sub_parser.on_head('--canvas STR', String, 'type of canvas') do |v|
canvas_types = UnicodePlot::Canvas::CANVAS_CLASS_MAP.keys.join(", ")
sub_parser.on_head('--canvas STR', String, "type of canvas", "(#{canvas_types})") do |v|
params.canvas = v.to_sym
end
end
Expand Down Expand Up @@ -226,6 +228,9 @@ def create_sub_parser
sub_parser_add_xscale

when :count, :c
sub_parser.on_head('-r', '--reverse', TrueClass, 'reverse the result of comparisons') do |v|
options.reverse = v
end
sub_parser_add_symbol
sub_parser_add_xscale

Expand Down Expand Up @@ -270,7 +275,7 @@ def create_sub_parser
sub_parser_add_xlim

when :colors, :color, :colours, :colour
sub_parser.on_head('-n', '--names', 'show color names only', TrueClass) do |v|
sub_parser.on_head('-n', '--names', TrueClass, 'show color names only') do |v|
options[:color_names] = v
end

Expand Down
38 changes: 38 additions & 0 deletions test/fixtures/iris-count.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
sepal_length
┌ ┐
5.0 ┤■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■ 10.0
5.1 ┤■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■ 9.0
6.3 ┤■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■ 9.0
5.7 ┤■■■■■■■■■■■■■■■■■■■■■■■■■■■ 8.0
6.7 ┤■■■■■■■■■■■■■■■■■■■■■■■■■■■ 8.0
5.5 ┤■■■■■■■■■■■■■■■■■■■■■■■■ 7.0
5.8 ┤■■■■■■■■■■■■■■■■■■■■■■■■ 7.0
6.4 ┤■■■■■■■■■■■■■■■■■■■■■■■■ 7.0
4.9 ┤■■■■■■■■■■■■■■■■■■■■ 6.0
5.4 ┤■■■■■■■■■■■■■■■■■■■■ 6.0
5.6 ┤■■■■■■■■■■■■■■■■■■■■ 6.0
6.0 ┤■■■■■■■■■■■■■■■■■■■■ 6.0
6.1 ┤■■■■■■■■■■■■■■■■■■■■ 6.0
4.8 ┤■■■■■■■■■■■■■■■■■ 5.0
6.5 ┤■■■■■■■■■■■■■■■■■ 5.0
4.6 ┤■■■■■■■■■■■■■■ 4.0
5.2 ┤■■■■■■■■■■■■■■ 4.0
6.2 ┤■■■■■■■■■■■■■■ 4.0
6.9 ┤■■■■■■■■■■■■■■ 4.0
7.7 ┤■■■■■■■■■■■■■■ 4.0
4.4 ┤■■■■■■■■■■ 3.0
5.9 ┤■■■■■■■■■■ 3.0
6.8 ┤■■■■■■■■■■ 3.0
7.2 ┤■■■■■■■■■■ 3.0
4.7 ┤■■■■■■■ 2.0
6.6 ┤■■■■■■■ 2.0
4.3 ┤■■■ 1.0
4.5 ┤■■■ 1.0
5.3 ┤■■■ 1.0
7.0 ┤■■■ 1.0
7.1 ┤■■■ 1.0
7.3 ┤■■■ 1.0
7.4 ┤■■■ 1.0
7.6 ┤■■■ 1.0
7.9 ┤■■■ 1.0
└ ┘
25 changes: 17 additions & 8 deletions test/youplot/iris_test.rb
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,8 @@ def fixture(fname)
assert_equal fixture('iris-barplot.txt'), @stderr_file.read
end

# barplot doesn't make sense, but just to make sure it works.

test :bar do
YouPlot::Command.new(['bar', '-H', '-d,', '-t', 'IRIS-BARPLOT']).run
assert_equal fixture('iris-barplot.txt'), @stderr_file.read
Expand All @@ -55,6 +57,8 @@ def fixture(fname)
assert_equal fixture('iris-histogram.txt'), @stderr_file.read
end

# Yeah, lineplot/lineplots don't make sense too.

test :lineplot do
YouPlot::Command.new(['lineplot', '-H', '-d,', '-t', 'IRIS-LINEPLOT']).run
assert_equal fixture('iris-lineplot.txt'), @stderr_file.read
Expand Down Expand Up @@ -105,15 +109,20 @@ def fixture(fname)
assert_equal fixture('iris-boxplot.txt'), @stderr_file.read
end

# test :c do
# YouPlot::Command.new(['count', '-H', '-d,']).run
# assert_equal fixture('iris-count.txt'), @stderr_file.read
# end
# Yeah, lineplot/lineplots don't make sense too.
# Just checking the behavior.

test :c do
YouPlot::Command.new(['count', '-H', '-d,']).run
assert_equal fixture('iris-count.txt'), @stderr_file.read
end

test :count do
YouPlot::Command.new(['c', '-H', '-d,']).run
assert_equal fixture('iris-count.txt'), @stderr_file.read
end

# test :count do
# YouPlot::Command.new(['c', '-H', '-d,']).run
# assert_equal fixture('iris-count.txt'), @stderr_file.read
# end
# Output options.

test :plot_output_stdout do
YouPlot::Command.new(['bar', '-o', '-H', '-d,', '-t', 'IRIS-BARPLOT']).run
Expand Down

0 comments on commit 4651c69

Please sign in to comment.