0.0
No commit activity in last 3 years
No release in over 3 years
FeatureSet is a Ruby library for generating feature vectors from textual data. It can output in ARFF format for experimentation with Weka.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

>= 0

Runtime

 Project Readme

This library is alpha and is not yet finished.

FeatureSet

A Ruby library for building machine learning datasets.

In machine learning, feature selection is often more difficult than algorithm selection. For many classes of problems, any reasonably modern algorithm can be used (i.e., a SVM, decision tree, etc.). However, all of these algorithms require information-rich features to learn from, and finding and constructing those features can is often its own engineering challenge. FeatureSet is a library that makes it easy to construct features from your data as a pre-processing step before applying a modern machine learning library such as Weka or libsvm.

FeatureSet takes a dataset consisting of hashes, with any any object as the value of each key, and builds features from these values as appropriate. For example, a string value could be expanded into a number of new features- a count of cuss words in the string, a count of slang, a sentiment score, and/or a complete word vector with TF-IDF values.

FeatureSet is extensible, so anyone can write new FeatureBuilders that know to which datatypes they can be applied. The set of included feature builders expands as the community submits new ones.

FeatureBuilders

Example Code

data_set = FeatureSet::DataSet.new
data_set.add_feature_builder FeatureSet::FeatureBuilders::WordVector.new(:word_limit => 2000, :idf_cutoff => 8.0)
data_set.add_feature_builder FeatureSet::FeatureBuilders::Cuss.new
data_set.add_data :status => "This is a spam email", :class => :spam
data_set.add_data :status => "This is a not spam", :class => :not_spam
data_set.build_features_from_data!(:include_original => false) #do not include :status as it's own column in the output

# The following ARFF can be imported into Weka
puts data_set.to_rarff.to_s

serialized_builders = data_set.dump_feature_builders

... later ...

data_set = FeatureSet::DataSet.new
data_set.load_feature_builders(serialized_builders)
features = data_set.build_features_for({ :status => "Is this spam?" })

See the specs for more usage examples.