Mahout-クイックガイド

私たちは、情報が豊富にある時代に生きています。情報過多は、小さなメールボックスの管理が困難になるほどの高さにまで拡大しています。人気のあるウェブサイト(Facebook、Twitter、Youtubeなど)のいくつかが毎日収集および管理しなければならないデータと記録の量を想像してみてください。あまり知られていないWebサイトでも、大量の情報を大量に受け取ることは珍しくありません。

通常、データマイニングアルゴリズムに頼ってバルクデータを分析し、傾向を特定して結論を​​導き出します。ただし、計算タスクがクラウド上に分散された複数のマシンで実行されない限り、非常に大きなデータセットを処理して結果を迅速に提供するのに十分な効率のデータマイニングアルゴリズムはありません。

これで、計算タスクを複数のセグメントに分割し、各セグメントを異なるマシンで実行できる新しいフレームワークができました。 Mahout は、通常、バックグラウンドでHadoopインフラストラクチャと組み合わせて実行され、大量のデータを管理するデータマイニングフレームワークです。

Apache Mahoutとは何ですか?

象使いは、そのマスターとして象を駆動するものです。この名前は、象をロゴとして使用するApacheHadoopとの密接な関係に由来しています。

Hadoop はApacheのオープンソースフレームワークであり、単純なプログラミングモデルを使用して、コンピューターのクラスター全体の分散環境でビッグデータを保存および処理できます。

Apache Mahoutは、主にスケーラブルな機械学習アルゴリズムを作成するために使用されるオープンソースプロジェクトです。次のような一般的な機械学習手法を実装しています。

  • Recommendation
  • Classification
  • Clustering

Apache Mahoutは、2008年にApacheのLuceneのサブプロジェクトとして開始されました。2010年に、MahoutはApacheのトップレベルプロジェクトになりました。

マハウトの特徴

ApacheMahoutの基本的な機能を以下に示します。

  • MahoutのアルゴリズムはHadoopの上に記述されているため、分散環境でうまく機能します。Mahoutは、Apache Hadoopライブラリを使用して、クラウドで効果的にスケーリングします。

  • Mahoutは、大量のデータに対してデータマイニングタスクを実行するためのすぐに使用できるフレームワークをコーダーに提供します。

  • Mahoutを使用すると、アプリケーションは大量のデータセットを効果的かつ迅速に分析できます。

  • k-means、ファジーk-means、Canopy、Dirichlet、Mean-ShiftなどのMapReduce対応のクラスタリング実装がいくつか含まれています。

  • 分散型ナイーブベイズおよび補完型ナイーブベイズ分類の実装をサポートします。

  • 進化的プログラミングのための分散型適応度関数機能が付属しています。

  • 行列およびベクトルライブラリが含まれています。

Mahoutのアプリケーション

  • Adobe、Facebook、LinkedIn、Foursquare、Twitter、Yahooなどの企業はMahoutを社内で使用しています。

  • Foursquareは、特定の地域で利用できる場所、食べ物、娯楽を見つけるのに役立ちます。Mahoutのレコメンダーエンジンを使用しています。

  • Twitterは、ユーザーインタレストモデリングにMahoutを使用しています。

  • Yahoo! パターンマイニングにMahoutを使用します。

Apache Mahoutは、開発者が最適化されたアルゴリズムを使用できるようにする、拡張性の高い機械学習ライブラリです。Mahoutは、推奨、分類、クラスタリングなどの一般的な機械学習手法を実装しています。したがって、先に進む前に、機械学習に関する簡単なセクションを用意しておくことをお勧めします。

機械学習とは何ですか?

機械学習は、システムが自動的に学習し、経験を積んで改善するようにシステムをプログラミングする科学の一分野です。ここで、学習とは、入力データを認識して理解し、提供されたデータに基づいて賢明な決定を下すことを意味します。

考えられるすべての入力に基づいてすべての決定に対応することは非常に困難です。この問題に取り組むために、アルゴリズムが開発されています。これらのアルゴリズムは、特定のデータと、統計、確率論、論理、組み合わせ最適化、検索、強化学習、および制御理論の原則に関する過去の経験から知識を構築します。

開発されたアルゴリズムは、次のようなさまざまなアプリケーションの基礎を形成します。

  • 視覚処理
  • 言語処理
  • 予測(例、株式市場の動向)
  • パターン認識
  • Games
  • データマイニング
  • エキスパートシステム
  • Robotics

機械学習は広大な領域であり、そのすべての機能を網羅することはこのチュートリアルの範囲をはるかに超えています。機械学習手法を実装する方法はいくつかありますが、最も一般的に使用される方法は次のとおりです。supervised そして unsupervised learning

教師あり学習

教師あり学習は、利用可能なトレーニングデータから関数を学習することを扱います。教師あり学習アルゴリズムは、トレーニングデータを分析し、新しい例のマッピングに使用できる推定関数を生成します。教師あり学習の一般的な例は次のとおりです。

  • 電子メールをスパムとして分類し、
  • コンテンツに基づいてWebページにラベルを付ける、および
  • 音声認識。

ニューラルネットワーク、サポートベクターマシン(SVM)、単純ベイズ分類器など、多くの教師あり学習アルゴリズムがあります。Mahoutは、単純ベイズ分類器を実装しています。

教師なし学習

教師なし学習は、トレーニング用の事前定義されたデータセットがなくても、ラベルのないデータを理解できます。教師なし学習は、利用可能なデータを分析し、パターンや傾向を探すための非常に強力なツールです。これは、同様の入力を論理グループにクラスタリングするために最も一般的に使用されます。教師なし学習への一般的なアプローチは次のとおりです。

  • k-means
  • 自己組織化マップ、および
  • 階層的クラスタリング

勧告

推奨は、以前の購入、クリック、評価などのユーザー情報に基づいて詳細な推奨を提供する一般的な手法です。

  • Amazonはこの手法を使用して、過去のアクションから情報を引き出し、興味があると思われる推奨アイテムのリストを表示します。Amazonの背後で機能するレコメンダーエンジンがあり、ユーザーの行動をキャプチャし、以前のアクションに基づいて選択したアイテムを推奨します。

  • Facebookは、レコメンダー手法を使用して、「知っている可能性のあるリスト」を識別して推奨します。

分類

分類、別名 categorizationは、既知のデータを使用して、新しいデータを既存のカテゴリのセットに分類する方法を決定する機械学習手法です。分類は、教師あり学習の一形態です。

  • Yahoo!などのメールサービスプロバイダー Gmailはこの手法を使用して、新着メールをスパムとして分類するかどうかを決定します。分類アルゴリズムは、特定のメールをスパムとしてマークするユーザーの習慣を分析することにより、それ自体をトレーニングします。これに基づいて、分類子は、将来のメールを受信トレイに入れるか、スパムフォルダに入れるかを決定します。

  • iTunesアプリケーションは、分類を使用してプレイリストを準備します。

クラスタリング

クラスタリングは、共通の特性に基づいて類似したデータのグループまたはクラスターを形成するために使用されます。クラスタリングは、教師なし学習の一形態です。

  • GoogleやYahoo!などの検索エンジン クラスタリング手法を使用して、同様の特性を持つデータをグループ化します。

  • ニュースグループは、クラスタリング手法を使用して、関連トピックに基づいてさまざまな記事をグループ化します。

クラスタリングエンジンは、入力データを完全に調べ、データの特性に基づいて、グループ化するクラスターを決定します。次の例を見てください。

チュートリアルのライブラリには、さまざまなテーマに関するトピックが含まれています。TutorialsPointで新しいチュートリアルを受け取ると、コンテンツに基づいてグループ化する場所を決定するクラスタリングエンジンによって処理されます。

この章では、mahoutの設定方法について説明します。JavaとHadoopはmahoutの前提条件です。以下に、Java、Hadoop、およびMahoutをダウンロードしてインストールする手順を示します。

インストール前のセットアップ

Linux環境にHadoopをインストールする前に、を使用してLinuxをセットアップする必要があります。 ssh(セキュアシェル)。Linux環境をセットアップするには、以下の手順に従ってください。

ユーザーの作成

HadoopファイルシステムをUnixファイルシステムから分離するために、Hadoop用に別のユーザーを作成することをお勧めします。以下の手順に従って、ユーザーを作成します。

  • コマンド「su」を使用してrootを開きます。

  • コマンドを使用してrootアカウントからユーザーを作成します “useradd username”

  • これで、コマンドを使用して既存のユーザーアカウントを開くことができます “su username”

  • Linuxターミナルを開き、次のコマンドを入力してユーザーを作成します。

$ su
password:
# useradd hadoop
# passwd hadoop
New passwd:
Retype new passwd

SSHセットアップとキー生成

SSHセットアップは、開始、停止、分散デーモンシェル操作など、クラスターでさまざまな操作を実行するために必要です。Hadoopのさまざまなユーザーを認証するには、Hadoopユーザーに公開鍵と秘密鍵のペアを提供し、それをさまざまなユーザーと共有する必要があります。

次のコマンドは、SSHを使用してキーと値のペアを生成し、id_rsa.pubからauthorized_keysに公開キーをコピーし、authorized_keysファイルにそれぞれ所有者、読み取り、および書き込みのアクセス許可を与えるために使用されます。

$ ssh-keygen -t rsa
$ cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys
$ chmod 0600 ~/.ssh/authorized_keys

sshの検証

ssh localhost

Javaのインストール

JavaはHadoopとHBaseの主な前提条件です。まず、「java-version」を使用してシステム内のJavaの存在を確認する必要があります。Javaバージョンコマンドの構文を以下に示します。

$ java -version

次の出力が生成されます。

java version "1.7.0_71"
Java(TM) SE Runtime Environment (build 1.7.0_71-b13)
Java HotSpot(TM) Client VM (build 25.0-b02, mixed mode)

システムにJavaがインストールされていない場合は、以下の手順に従ってJavaをインストールしてください。

Step 1

次のリンクにアクセスして、Java(JDK <最新バージョン> -X64.tar.gz)をダウンロードします。Oracle

次に jdk-7u71-linux-x64.tar.gz is downloaded あなたのシステムに。

Step 2

通常、ダウンロードしたJavaファイルはDownloadsフォルダーにあります。それを確認し、抽出しますjdk-7u71-linux-x64.gz 次のコマンドを使用してファイルします。

$ cd Downloads/
$ ls
jdk-7u71-linux-x64.gz
$ tar zxf jdk-7u71-linux-x64.gz
$ ls
jdk1.7.0_71 jdk-7u71-linux-x64.gz

Step 3

すべてのユーザーがJavaを使用できるようにするには、Javaを「/ usr / local /」の場所に移動する必要があります。rootを開き、次のコマンドを入力します。

$ su
password:
# mv jdk1.7.0_71 /usr/local/
# exit

Step 4

設定用 PATH そして JAVA_HOME 変数については、次のコマンドを追加してください ~/.bashrc file

export JAVA_HOME=/usr/local/jdk1.7.0_71
export PATH= $PATH:$JAVA_HOME/bin

次に、 java -version 上で説明したように端末からのコマンド。

Hadoopのダウンロード

Javaをインストールした後、最初にHadoopをインストールする必要があります。以下に示すように、「Hadoopバージョン」コマンドを使用してHadoopの存在を確認します。

hadoop version

次の出力が生成されます。

Hadoop 2.6.0
Compiled by jenkins on 2014-11-13T21:10Z
Compiled with protoc 2.5.0
From source with checksum 18e43357c8f927c0695f1e9522859d6a
This command was run using /home/hadoop/hadoop/share/hadoop/common/hadoopcommon-2.6.0.jar

システムがHadoopを見つけられない場合は、Hadoopをダウンロードして、システムにインストールしてください。これを行うには、以下のコマンドに従います。

次のコマンドを使用して、Apache SoftwareFoundationからhadoop-2.6.0をダウンロードして抽出します。

$ su
password:
# cd /usr/local
# wget http://mirrors.advancedhosters.com/apache/hadoop/common/hadoop-
2.6.0/hadoop-2.6.0-src.tar.gz
# tar xzf hadoop-2.6.0-src.tar.gz
# mv hadoop-2.6.0/* hadoop/
# exit

Hadoopのインストール

必要なモードのいずれかでHadoopをインストールします。ここでは、疑似分散モードでのHBase機能を示しているため、Hadoopを疑似分散モードでインストールします。

以下の手順に従ってインストールしてください Hadoop 2.4.1 システム上で。

ステップ1:Hadoopを設定する

次のコマンドをに追加することで、Hadoop環境変数を設定できます。 ~/.bashrc ファイル。

export HADOOP_HOME=/usr/local/hadoop
export HADOOP_MAPRED_HOME=$HADOOP_HOME
export HADOOP_COMMON_HOME=$HADOOP_HOME
export HADOOP_HDFS_HOME=$HADOOP_HOME

export YARN_HOME=$HADOOP_HOME
export HADOOP_COMMON_LIB_NATIVE_DIR=$HADOOP_HOME/lib/native

export PATH=$PATH:$HADOOP_HOME/sbin:$HADOOP_HOME/bin
export HADOOP_INSTALL=$HADOOP_HOME

ここで、現在実行中のシステムにすべての変更を適用します。

$ source ~/.bashrc

ステップ2:Hadoop構成

すべてのHadoop構成ファイルは、「$ HADOOP_HOME / etc / hadoop」の場所にあります。Hadoopインフラストラクチャに応じて、これらの構成ファイルを変更する必要があります。

$ cd $HADOOP_HOME/etc/hadoop

JavaでHadoopプログラムを開発するには、Java環境変数をリセットする必要があります。 hadoop-env.sh 置き換えることによってファイル JAVA_HOME システム内のJavaの場所を含む値。

export JAVA_HOME=/usr/local/jdk1.7.0_71

以下に、Hadoopを構成するために編集する必要のあるファイルのリストを示します。

core-site.xml

ザ・ core-site.xml fileには、Hadoopインスタンスに使用されるポート番号、ファイルシステムに割り当てられたメモリ、データを格納するためのメモリ制限、読み取り/書き込みバッファのサイズなどの情報が含まれています。

core-site.xmlを開き、<configuration>、</ configuration>タグの間に次のプロパティを追加します。

<configuration>
   <property>
      <name>fs.default.name</name>
      <value>hdfs://localhost:9000</value>
   </property>
</configuration>

hdfs-site.xm

ザ・ hdfs-site.xmlファイルには、ローカルファイルシステムのレプリケーションデータの値、ネームノードパス、データノードパスなどの情報が含まれています。これは、Hadoopインフラストラクチャを保存する場所を意味します。

次のデータを想定します。

dfs.replication (data replication value) = 1

(In the below given path /hadoop/ is the user name.
hadoopinfra/hdfs/namenode is the directory created by hdfs file system.)
namenode path = //home/hadoop/hadoopinfra/hdfs/namenode

(hadoopinfra/hdfs/datanode is the directory created by hdfs file system.)
datanode path = //home/hadoop/hadoopinfra/hdfs/datanode

このファイルを開き、このファイルの<configuration>、</ configuration>タグの間に次のプロパティを追加します。

<configuration>
   <property>
      <name>dfs.replication</name>
      <value>1</value>
   </property>
	
   <property>
      <name>dfs.name.dir</name>
      <value>file:///home/hadoop/hadoopinfra/hdfs/namenode</value>
   </property>
	
   <property>
      <name>dfs.data.dir</name>
      <value>file:///home/hadoop/hadoopinfra/hdfs/datanode</value>
   </property>
</configuration>

Note:上記のファイルでは、すべてのプロパティ値はユーザー定義です。Hadoopインフラストラクチャに応じて変更を加えることができます。

mapred-site.xml

このファイルは、Hadoopにyarnを構成するために使用されます。mapred-site.xmlファイルを開き、このファイルの<configuration>、</ configuration>タグの間に次のプロパティを追加します。

<configuration>
   <property>
      <name>yarn.nodemanager.aux-services</name>
      <value>mapreduce_shuffle</value>
   </property>
</configuration>

mapred-site.xml

このファイルは、使用しているMapReduceフレームワークを指定するために使用されます。デフォルトでは、Hadoopにはmapred-site.xmlのテンプレートが含まれています。まず、ファイルをコピーする必要がありますmapred-site.xml.templatemapred-site.xml 次のコマンドを使用してファイルします。

$ cp mapred-site.xml.template mapred-site.xml

開いた mapred-site.xml ファイルを作成し、このファイルの<configuration>、</ configuration>タグの間に次のプロパティを追加します。

<configuration>
   <property>
      <name>mapreduce.framework.name</name>
      <value>yarn</value>
   </property>
</configuration>

Hadoopのインストールの確認

次の手順は、Hadoopのインストールを確認するために使用されます。

ステップ1:ノードのセットアップに名前を付ける

次のように、コマンド「hdfsnamenode-format」を使用してnamenodeを設定します。

$ cd ~
$ hdfs namenode -format

期待される結果は次のとおりです。

10/24/14 21:30:55 INFO namenode.NameNode: STARTUP_MSG:
/************************************************************
STARTUP_MSG: Starting NameNode
STARTUP_MSG: host = localhost/192.168.1.11
STARTUP_MSG: args = [-format]
STARTUP_MSG: version = 2.4.1
...
...
10/24/14 21:30:56 INFO common.Storage: Storage directory
/home/hadoop/hadoopinfra/hdfs/namenode has been successfully formatted.
10/24/14 21:30:56 INFO namenode.NNStorageRetentionManager: Going to retain
1 images with txid >= 0
10/24/14 21:30:56 INFO util.ExitUtil: Exiting with status 0
10/24/14 21:30:56 INFO namenode.NameNode: SHUTDOWN_MSG:
/************************************************************
SHUTDOWN_MSG: Shutting down NameNode at localhost/192.168.1.11
************************************************************/

ステップ2:Hadoopdfsを確認する

次のコマンドは、dfsを開始するために使用されます。このコマンドは、Hadoopファイルシステムを起動します。

$ start-dfs.sh

期待される出力は次のとおりです。

10/24/14 21:37:56
Starting namenodes on [localhost]
localhost: starting namenode, logging to /home/hadoop/hadoop-
2.4.1/logs/hadoop-hadoop-namenode-localhost.out
localhost: starting datanode, logging to /home/hadoop/hadoop-
2.4.1/logs/hadoop-hadoop-datanode-localhost.out
Starting secondary namenodes [0.0.0.0]

ステップ3:糸スクリプトを確認する

次のコマンドは、yarnスクリプトを開始するために使用されます。このコマンドを実行すると、ヤーンデーモンが起動します。

$ start-yarn.sh

期待される出力は次のとおりです。

starting yarn daemons
starting resource manager, logging to /home/hadoop/hadoop-2.4.1/logs/yarn-
hadoop-resourcemanager-localhost.out
localhost: starting node manager, logging to /home/hadoop/hadoop-
2.4.1/logs/yarn-hadoop-nodemanager-localhost.out

ステップ4:ブラウザーでHadoopにアクセスする

hadoopにアクセスするためのデフォルトのポート番号は50070です。ブラウザーでHadoopサービスを取得するには、次のURLを使用します。

http://localhost:50070/

手順5:クラスターのすべてのアプリケーションを確認する

クラスタのすべてのアプリケーションにアクセスするためのデフォルトのポート番号は8088です。このサービスにアクセスするには、次のURLを使用してください。

http://localhost:8088/

Mahoutのダウンロード

Mahoutは、MahoutのWebサイトで入手できます。Webサイトで提供されているリンクからMahoutをダウンロードします。これがウェブサイトのスクリーンショットです。

ステップ1

リンクからApachemahoutをダウンロードします http://mirror.nexcess.net/apache/mahout/ 次のコマンドを使用します。

[Hadoop@localhost ~]$ wget
http://mirror.nexcess.net/apache/mahout/0.9/mahout-distribution-0.9.tar.gz

次に mahout-distribution-0.9.tar.gz システムにダウンロードされます。

ステップ2

フォルダーを参照します。 mahout-distribution-0.9.tar.gz を保存し、ダウンロードしたjarファイルを以下のように抽出します。

[Hadoop@localhost ~]$ tar zxvf mahout-distribution-0.9.tar.gz

Mavenリポジトリ

以下に示すのは、Eclipseを使用してApacheMahoutをビルドするためのpom.xmlです。

<dependency>
   <groupId>org.apache.mahout</groupId>
   <artifactId>mahout-core</artifactId>
   <version>0.9</version>
</dependency>

<dependency>
   <groupId>org.apache.mahout</groupId>
   <artifactId>mahout-math</artifactId>
   <version>${mahout.version}</version>
</dependency>

<dependency>
   <groupId>org.apache.mahout</groupId>
   <artifactId>mahout-integration</artifactId>
   <version>${mahout.version}</version>
</dependency>

この章では、と呼ばれる一般的な機械学習手法について説明します。 recommendation, そのメカニズム、およびMahout推奨を実装するアプリケーションの作成方法。

勧告

あなたが興味を持っているかもしれない特定の製品にあなたの注意を引くために、Amazonがどのように推奨アイテムのリストを思い付くのか疑問に思ったことはありません!

Amazonから「MahoutinAction」という本を購入したいとします。

選択した商品に加えて、Amazonは以下に示すように関連する推奨アイテムのリストも表示します。

このような推奨リストは、 recommender engines。Mahoutは、次のようないくつかのタイプのレコメンダーエンジンを提供します。

  • ユーザーベースの推奨者、
  • アイテムベースの推奨者、および
  • 他のいくつかのアルゴリズム。

Mahoutレコメンダーエンジン

Mahoutには、非分散型、非Hadoopベースのレコメンダーエンジンがあります。アイテムのユーザー設定を含むテキストドキュメントを渡す必要があります。そして、このエンジンの出力は、他のアイテムに対する特定のユーザーの推定された好みになります。

携帯電話、ガジェット、およびそれらのアクセサリなどの消費財を販売するWebサイトについて考えてみます。そのようなサイトにMahoutの機能を実装したい場合は、レコメンダーエンジンを構築できます。このエンジンは、ユーザーの過去の購入データを分析し、それに基づいて新製品を推奨します。

レコメンダーエンジンを構築するためにMahoutが提供するコンポーネントは次のとおりです。

  • DataModel
  • UserSimilarity
  • ItemSimilarity
  • UserNeighborhood
  • Recommender

データストアからデータモデルが準備され、レコメンダーエンジンへの入力として渡されます。レコメンダーエンジンは、特定のユーザーのレコメンデーションを生成します。以下に、レコメンダーエンジンのアーキテクチャを示します。

レコメンダーエンジンのアーキテクチャ

Mahoutを使用してレコメンダーを構築する

簡単なレコメンダーを開発する手順は次のとおりです。

ステップ1:DataModelオブジェクトを作成する

のコンストラクタ PearsonCorrelationSimilarityクラスには、製品のユーザー、アイテム、および設定の詳細を含むファイルを保持するデータモデルオブジェクトが必要です。サンプルデータモデルファイルは次のとおりです。

1,00,1.0
1,01,2.0
1,02,5.0
1,03,5.0
1,04,5.0

2,00,1.0
2,01,2.0
2,05,5.0
2,06,4.5
2,02,5.0

3,01,2.5
3,02,5.0
3,03,4.0
3,04,3.0

4,00,5.0
4,01,5.0
4,02,5.0
4,03,0.0

ザ・ DataModelオブジェクトには、入力ファイルのパスを含むファイルオブジェクトが必要です。を作成しますDataModel 以下に示すオブジェクト。

DataModel datamodel = new FileDataModel(new File("input file"));

ステップ2:UserSimilarityオブジェクトを作成する

作成する UserSimilarity 使用するオブジェクト PearsonCorrelationSimilarity 以下に示すクラス:

UserSimilarity similarity = new PearsonCorrelationSimilarity(datamodel);

ステップ3:UserNeighborhoodオブジェクトを作成する

このオブジェクトは、特定のユーザーのようなユーザーの「近隣」を計算します。近隣には2つのタイプがあります。

  • NearestNUserNeighborhood-このクラスは、特定のユーザーに最も近いn人のユーザーで構成される近隣を計算します。「最も近い」は、指定されたUserSimilarityによって定義されます。

  • ThresholdUserNeighborhood-このクラスは、特定のユーザーとの類似性が特定のしきい値を満たすか超えるすべてのユーザーで構成される近隣を計算します。類似性は、指定されたUserSimilarityによって定義されます。

ここでは使用しています ThresholdUserNeighborhood 優先順位の制限を3.0に設定します。

UserNeighborhood neighborhood = new ThresholdUserNeighborhood(3.0, similarity, model);

ステップ4:レコメンダーオブジェクトを作成する

作成する UserbasedRecomenderオブジェクト。以下に示すように、上記で作成したすべてのオブジェクトをコンストラクターに渡します。

UserBasedRecommender recommender = new GenericUserBasedRecommender(model, neighborhood, similarity);

ステップ5:ユーザーにアイテムを推奨する

のrecommend()メソッドを使用してユーザーに製品を推奨します Recommenderインターフェース。この方法には2つのパラメーターが必要です。1つ目は、推奨事項を送信する必要があるユーザーのユーザーIDを表し、2つ目は送信する推奨事項の数を表します。これがの使用法ですrecommender() 方法:

List<RecommendedItem> recommendations = recommender.recommend(2, 3);

for (RecommendedItem recommendation : recommendations) {
   System.out.println(recommendation);
 }

Example Program

以下に、推奨事項を設定するためのプログラムの例を示します。ユーザーID2のユーザー向けの推奨事項を準備します。

import java.io.File;
import java.util.List;

import org.apache.mahout.cf.taste.impl.model.file.FileDataModel;
import org.apache.mahout.cf.taste.impl.neighborhood.ThresholdUserNeighborhood;
import org.apache.mahout.cf.taste.impl.recommender.GenericUserBasedRecommender;
import org.apache.mahout.cf.taste.impl.similarity.PearsonCorrelationSimilarity;
import org.apache.mahout.cf.taste.model.DataModel;
import org.apache.mahout.cf.taste.neighborhood.UserNeighborhood;
import org.apache.mahout.cf.taste.recommender.RecommendedItem;
import org.apache.mahout.cf.taste.recommender.UserBasedRecommender;
import org.apache.mahout.cf.taste.similarity.UserSimilarity;

public class Recommender {
   public static void main(String args[]){
      try{
         //Creating data model
         DataModel datamodel = new FileDataModel(new File("data")); //data
      
         //Creating UserSimilarity object.
         UserSimilarity usersimilarity = new PearsonCorrelationSimilarity(datamodel);
      
         //Creating UserNeighbourHHood object.
         UserNeighborhood userneighborhood = new ThresholdUserNeighborhood(3.0, usersimilarity, datamodel);
      
         //Create UserRecomender
         UserBasedRecommender recommender = new GenericUserBasedRecommender(datamodel, userneighborhood, usersimilarity);
        
         List<RecommendedItem> recommendations = recommender.recommend(2, 3);
			
         for (RecommendedItem recommendation : recommendations) {
            System.out.println(recommendation);
         }
      
      }catch(Exception e){}
      
   }
  }

次のコマンドを使用してプログラムをコンパイルします。

javac Recommender.java
java Recommender

次の出力が生成されます。

RecommendedItem [item:3, value:4.5]
RecommendedItem [item:4, value:4.0]

クラスタリングは、特定のコレクションの要素またはアイテムを、アイテム間の類似性に基づいてグループに編成する手順です。たとえば、オンラインニュース発行に関連するアプリケーションは、クラスタリングを使用してニュース記事をグループ化します。

クラスタリングのアプリケーション

  • クラスタリングは、市場調査、パターン認識、データ分析、画像処理など、多くのアプリケーションで広く使用されています。

  • クラスタリングは、マーケターが顧客ベースで個別のグループを発見するのに役立ちます。また、購入パターンに基づいて顧客グループを特徴付けることができます。

  • 生物学の分野では、植物や動物の分類法を導き出し、同様の機能を持つ遺伝子を分類し、集団に固有の構造への洞察を得るのに使用できます。

  • クラスタリングは、地球観測データベースで同様の土地利用の領域を特定するのに役立ちます。

  • クラスタリングは、情報発見のためにWeb上のドキュメントを分類するのにも役立ちます。

  • クラスタリングは、クレジットカード詐欺の検出などの外れ値検出アプリケーションで使用されます。

  • データマイニング機能として、クラスター分析は、各クラスターの特性を観察するためのデータの分布に関する洞察を得るためのツールとして機能します。

Mahoutを使用すると、特定のデータセットをクラスター化できます。必要な手順は次のとおりです。

  • Algorithm クラスターの要素をグループ化するには、適切なクラスタリングアルゴリズムを選択する必要があります。

  • Similarity and Dissimilarity 新しく検出された要素とグループ内の要素との類似性を検証するためのルールを設定する必要があります。

  • Stopping Condition クラスタリングが不要なポイントを定義するには、停止条件が必要です。

クラスタリングの手順

特定のデータをクラスター化するには、次のことを行う必要があります-

  • Hadoopサーバーを起動します。Hadoopファイルシステムにファイルを保存するために必要なディレクトリを作成します。(キャノピーの場合は、入力ファイル、シーケンスファイル、およびクラスター化された出力用のディレクトリを作成します)。

  • 入力ファイルをUnixファイルシステムからHadoopファイルシステムにコピーします。

  • 入力データからシーケンスファイルを作成します。

  • 利用可能なクラスタリングアルゴリズムのいずれかを実行します。

  • クラスター化されたデータを取得します。

Hadoopの開始

MahoutはHadoopと連携するため、Hadoopサーバーが稼働していることを確認してください。

$ cd HADOOP_HOME/bin
$ start-all.sh

入力ファイルディレクトリの準備

次のコマンドを使用して、Hadoopファイルシステムにディレクトリを作成し、入力ファイル、シーケンスファイル、およびクラスター化されたデータを保存します。

$ hadoop fs -p mkdir /mahout_data
$ hadoop fs -p mkdir /clustered_data
$ hadoop fs -p mkdir /mahout_seq

次のURLのhadoopWebインターフェイスを使用してディレクトリが作成されているかどうかを確認できます- http://localhost:50070/

以下に示すような出力が得られます。

入力ファイルをHDFSにコピーする

次に、以下に示すように、入力データファイルをLinuxファイルシステムからHadoopファイルシステムのmahout_dataディレクトリにコピーします。入力ファイルがmydata.txtであり、/ home / Hadoop / data /ディレクトリにあると想定します。

$ hadoop fs -put /home/Hadoop/data/mydata.txt /mahout_data/

シーケンスファイルの準備

Mahoutは、指定された入力ファイルをシーケンスファイル形式に変換するユーティリティを提供します。このユーティリティには2つのパラメータが必要です。

  • 元のデータが存在する入力ファイルディレクトリ。
  • クラスタ化されたデータが保存される出力ファイルディレクトリ。

以下に、mahoutのヘルププロンプトを示します。 seqdirectory ユーティリティ。

Step 1:Mahoutホームディレクトリを参照します。以下に示すように、ユーティリティのヘルプを取得できます。

[Hadoop@localhost bin]$ ./mahout seqdirectory --help
Job-Specific Options:
--input (-i) input Path to job input directory.
--output (-o) output The directory pathname for output.
--overwrite (-ow) If present, overwrite the output directory

次の構文を使用して、ユーティリティを使用してシーケンスファイルを生成します。

mahout seqdirectory -i <input file path> -o <output directory>

Example

mahout seqdirectory
-i hdfs://localhost:9000/mahout_seq/
-o hdfs://localhost:9000/clustered_data/

クラスタリングアルゴリズム

Mahoutは、クラスタリングの2つの主要なアルゴリズムをサポートしています。

  • キャノピークラスタリング
  • K-meansクラスタリング

キャノピークラスタリング

キャノピークラスタリングは、Mahoutがクラスタリングの目的で使用するシンプルで高速な手法です。オブジェクトは、プレーンスペース内のポイントとして扱われます。この手法は、k-meansクラスタリングなどの他のクラスタリング手法の最初のステップとしてよく使用されます。次の構文を使用して、Canopyジョブを実行できます。

mahout canopy -i <input vectors directory>
-o <output directory>
-t1 <threshold value 1>
-t2 <threshold value 2>

キャノピージョブには、シーケンスファイルを含む入力ファイルディレクトリと、クラスタ化されたデータが保存される出力ディレクトリが必要です。

Example

mahout canopy -i hdfs://localhost:9000/mahout_seq/mydata.seq
-o hdfs://localhost:9000/clustered_data
-t1 20
-t2 30

指定された出力ディレクトリで生成されたクラスター化されたデータを取得します。

K-meansクラスタリング

K-meansクラスタリングは、重要なクラスタリングアルゴリズムです。k-meansクラスタリングアルゴリズムのkは、データが分割されるクラスターの数を表します。たとえば、このアルゴリズムに指定されたk値は3として選択され、アルゴリズムはデータを3つのクラスターに分割します。

各オブジェクトは、空間内のベクトルとして表されます。最初に、k個のポイントがアルゴリズムによってランダムに選択され、中心として扱われます。各中心に最も近いすべてのオブジェクトがクラスター化されます。距離測定にはいくつかのアルゴリズムがあり、ユーザーは必要なものを選択する必要があります。

Creating Vector Files

  • キャノピーアルゴリズムとは異なり、k-meansアルゴリズムでは入力としてベクターファイルが必要であるため、ベクターファイルを作成する必要があります。

  • シーケンスファイル形式からベクターファイルを生成するために、Mahoutは seq2parse ユーティリティ。

以下に示すオプションのいくつかは seq2parseユーティリティ。これらのオプションを使用してベクターファイルを作成します。

$MAHOUT_HOME/bin/mahout seq2sparse
--analyzerName (-a) analyzerName  The class name of the analyzer
--chunkSize (-chunk) chunkSize    The chunkSize in MegaBytes.
--output (-o) output              The directory pathname for o/p
--input (-i) input                Path to job input directory.

ベクトルを作成した後、k-meansアルゴリズムに進みます。k-meansジョブを実行するための構文は次のとおりです。

mahout kmeans -i <input vectors directory>
-c  <input clusters directory>
-o  <output working directory>
-dm <Distance Measure technique>
-x  <maximum number of iterations>
-k  <number of initial clusters>

K-meansクラスタリングジョブには、入力ベクトルディレクトリ、出力クラスターディレクトリ、距離測定、実行される最大反復回数、および入力データが分割されるクラスターの数を表す整数値が必要です。

分類とは何ですか?

分類は、既知のデータを使用して、新しいデータを既存のカテゴリのセットに分類する方法を決定する機械学習手法です。例えば、

  • iTunesアプリケーションは、分類を使用してプレイリストを準備します。

  • Yahoo!などのメールサービスプロバイダー Gmailはこの手法を使用して、新着メールをスパムとして分類するかどうかを決定します。分類アルゴリズムは、特定のメールをスパムとしてマークするユーザーの習慣を分析することにより、それ自体をトレーニングします。これに基づいて、分類子は、将来のメールを受信トレイに入れるか、スパムフォルダに入れるかを決定します。

分類のしくみ

特定のデータセットを分類している間、分類システムは次のアクションを実行します。

  • 最初に、学習アルゴリズムのいずれかを使用して新しいデータモデルが準備されます。
  • 次に、準備されたデータモデルがテストされます。
  • その後、このデータモデルを使用して、新しいデータを評価し、そのクラスを決定します。

分類の応用

  • Credit card fraud detection-分類メカニズムは、クレジットカード詐欺を予測するために使用されます。分類器は、以前の不正の履歴情報を使用して、将来のどのトランザクションが不正に変わる可能性があるかを予測できます。

  • Spam e-mails -以前のスパムメールの特性に応じて、分類子は、新しく検出された電子メールをスパムフォルダに送信するかどうかを決定します。

単純ベイズ分類器

Mahoutは、単純ベイズ分類器アルゴリズムを使用します。2つの実装を使用します。

  • 分散型単純ベイズ分類
  • 補完的な単純ベイズ分類

ナイーブベイズは、分類器を構築するための簡単な手法です。これは、そのような分類器をトレーニングするための単一のアルゴリズムではなく、一連のアルゴリズムです。ベイズ分類器は、問題のインスタンスを分類するためのモデルを構築します。これらの分類は、入手可能なデータを使用して行われます。

単純ベイズの利点は、分類に必要なパラメーターを推定するために必要なトレーニングデータが少量であるということです。

一部のタイプの確率モデルでは、単純ベイズ分類器を教師あり学習環境で非常に効率的にトレーニングできます。

その過度に単純化された仮定にもかかわらず、単純ベイズ分類器は多くの複雑な現実世界の状況で非常にうまく機能しました。

分類の手順

分類を実装するには、次の手順に従います。

  • サンプルデータを生成する
  • データからシーケンスファイルを作成する
  • シーケンスファイルをベクトルに変換する
  • ベクトルをトレーニングする
  • ベクトルをテストする

ステップ1:サンプルデータを生成する

分類するデータを生成またはダウンロードします。たとえば、あなたは得ることができます20 newsgroups 次のリンクからのサンプルデータ: http://people.csail.mit.edu/jrennie/20Newsgroups/20news-bydate.tar.gz

入力データを保存するためのディレクトリを作成します。以下に示すように例をダウンロードします。

$ mkdir classification_example
$ cd classification_example
$tar xzvf 20news-bydate.tar.gz
wget http://people.csail.mit.edu/jrennie/20Newsgroups/20news-bydate.tar.gz

ステップ2:シーケンスファイルを作成する

を使用して例からシーケンスファイルを作成します seqdirectoryユーティリティ。シーケンスを生成するための構文を以下に示します。

mahout seqdirectory -i <input file path> -o <output directory>

ステップ3:シーケンスファイルをベクトルに変換する

を使用してシーケンスファイルからベクターファイルを作成する seq2parseユーティリティ。のオプションseq2parse ユーティリティは以下のとおりです。

$MAHOUT_HOME/bin/mahout seq2sparse
--analyzerName (-a) analyzerName  The class name of the analyzer
--chunkSize (-chunk) chunkSize    The chunkSize in MegaBytes.
--output (-o) output              The directory pathname for o/p
--input (-i) input                Path to job input directory.

ステップ4:ベクトルをトレーニングする

を使用して生成されたベクトルをトレーニングします trainnbユーティリティ。使用するオプションtrainnb ユーティリティは以下のとおりです。

mahout trainnb
 -i ${PATH_TO_TFIDF_VECTORS}
 -el
 -o ${PATH_TO_MODEL}/model
 -li ${PATH_TO_MODEL}/labelindex
 -ow
 -c

ステップ5:ベクトルをテストする

を使用してベクトルをテストします testnbユーティリティ。使用するオプションtestnb ユーティリティは以下のとおりです。

mahout testnb
 -i ${PATH_TO_TFIDF_TEST_VECTORS}
 -m ${PATH_TO_MODEL}/model
 -l ${PATH_TO_MODEL}/labelindex
 -ow
 -o ${PATH_TO_OUTPUT}
 -c
 -seq