Sha256: 2409d8dc2d7b9a046289e650ee91a85c49da424e2c5c22ba43605074b56eb2f2

Contents?: true

Size: 1.18 KB

Versions: 1

Compression:

Stored size: 1.18 KB

Contents

require 'spec_helper'

describe "Basic usage" do
	before do
		@problem = Problem.new
		@parameter = SvmParameter.new
		@parameter.cache_size = 1 # mb

		# "eps is the stopping criterion (we usually use 0.00001 in nu-SVC,
		# 0.001 in others)." (from README)
		@parameter.eps = 0.001 

		@parameter.c = 10
	end

	it "has a nice API" do
		example = {11 => 0.11, 21 => 0.21, 101 => 0.99 }.to_example
		example.should == Node.features({11 => 0.11, 21 => 0.21, 101 => 0.99 })
	end

	it "is as in [PCI,217]" do
		examples = [ [1,0,1], [-1,0,-1] ].map {|ary| Node.features(ary) }
		labels = [1, -1]
		@problem.set_examples(labels, examples)

		model = Model.train(@problem, @parameter)

		pred = model.predict(Node.features(1, 1, 1))
		pred.should == 1.0

		pred = model.predict(Node.features(-1, 1, -1))
		pred.should == -1.0

		pred = model.predict(Node.features(-1, 55, -1))
		pred.should == -1.0
	end

	it "kernel parameter use" do
		@parameter.kernel_type = SvmParameter::KernelType::RBF
		examples = [[1, 2, 3], [-2, -2, -2]].map {|ary| Node.features(ary) }
		@problem.set_examples([1, 2], examples)

		model = Model.train(@problem, @parameter)

		model.predict(Node.features(1, 2, 3)).should == 2
	end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
rb-libsvm-1.0.5 spec/usage_spec.rb