Processing math: 1%
スキップしてメイン コンテンツに移動

Theorem of SVM part 1

Introduction  

I will explain theorem of SVM.
Please look at my implementation of SVM.
Implement linear SVM
Implement kernel SVM
Today, I will explain about SVM until deriving the objective function.


Overview  
  • Generalized linear model  
  • Explain SVM
  • hard margin  
  • soft margin  



Generalized linear model  

SVM is used generalized linear model. Generalized linear model is following function
f(x) = w^T\phi(x) + b
b is called bias.
0 = w^T\phi(x) + bis hyper plane. This hyper plane separate two class of \phi(x).
hyper plance is n-dimensional plane. if n = 1, hyper plane is line. if n = 2, hyper plane is normal plane.
\phi(x) have effect of converting x to data which can be separated by a line.
image of \phi(x) is



the left image has nonlinear data.
right image has linear data.
\phi(x) convert from left image to right image.
I will handle w^T \phi(x) + b as line in feature space.

Next, I will explain the object of SVM

Explain SVM
    the label is 1 or -1 in SVM. Let label is y \in \{1,-1\}. Let dataset is X.
    We want to make decisions function which \forall x \in X

    f(x_i) > 0 \implies y_i = 1
    f(x_i) < 0 \implies y_i = -1

    Let f(x) is w^T \phi(x) + b, I will optimize w and b of parametor.
    However, optimization needs a standard of a good boundary. Its standard is magin. Next, I will explain hard margin.

    Hard margin
      SVM decide a boundary line by a value called margin.
      What is margin? I will explain.

      pick up data which exist nearest from w^T \phi(x) +b = 0. Margin is the distance between the data and w^T \phi(x) +b = 0.
      Look at following image of margin in 2-dimensional.



      this distance of green line is margin. SVM decide w^T \phi(x) + b= 0 to depend on only data which exist nearest from w^T \phi(x) + b = 0. This data called sopport vector.

      We decide w and b of the parameter by a maximum margin.

      Let dataset is X, \forall x_i \in X, distance between x and w^T \phi(x) + b = 0 is
      \frac{|w^T \phi(x_i) + b|}{||W||}

      Now, Assume linear hyperplane is enabled to complicately classify.


      this image is data which complicately separated hyperplane.

      this image is else data.

      Thus,
      f(x_i) > 0 \implies y_i = 1
      f(x_i) < 0 \implies y_i = -1
      is complitely practical.

      Therefore,
      \forall i \in N,~~~~~~~y_i(w^T \phi(x_i) + b) > 0

      Therefore
      \frac{|w^T \phi(x_i) + b|}{||W||} = \frac{y(w^T \phi(x_i) + b)}{||W||}
      Next, Let i_0 as follow.

      \forall i_0 \in \arg_{n \in N} \min_{x \in X} \frac{|w^T \phi(x_n) + b|}{||W||},
      Let M is
      M = y_{i_0}(w^T \phi(x_{i_0}) + b)
      Because \forall i \in N,~y_i(w^T \phi(x_i) + b) > 0, M > 0 is practical.

      M is value of distance between w^T \phi(x) + b = 0 and data which exist nearest w^T \phi(x) + b = 0

      The objective function in SVM is expressed as follow.

      \max_{w,b,M} \frac{M}{||W||} ~~s.t~~ \forall i \in N ~, y_i(w^T \phi(x_i) + b) \geq M

      Here, when w^{\star}  = \frac{w}{M}, b^{\star}  = \frac{b}{M}, the objective function is expressed as follow.
      \max_{w^{\star},b^{\star}} \frac{1}{||W^{\star}||}
      ~~s.t~~ \forall i \in N, y_i (w^{\star} \phi(x_i) + b^{\star}) \geq 1

      I convert this from. because ||W^{\star}|| > 0,
      \max_{w^{\star},b^{\star}} \frac{1}{||W^{\star}||}
      \iff \min_{w^{\star},b^{\star}}  ||W^{\star}||
      \iff \min_{w^{\star},b^{\star}}  ||W^{\star}||^2

      therefore, the objectice function in SVM is
      \min_{w,b}  ||W||^2
      ~~s.t~~ \forall i \in N, y_i (w^T \phi(x_i) + b) \geq 1

      I define W^{\star} = W, b^{\star} = b again.

      We assume data is completely separated by a hyperplane. This method is called hard margin.

      However this assumption is strict in the real world, so the soft margin is invented.
      Next, I will explain soft margin.

      Soft margin
        I introduce \epsilon_i \geq 0 the objective function.

        I loosen \forall i \in N, y_i (w^T \phi(x_i) + b) \geq 1. This condition is rewrited as follow.

        \forall i \in N, y_i (w^T \phi(x_i) + b) \geq 1 - \epsilon_i

        if x_i is beyond w^T \phi(x) + b = 0, \epsilon_i > 0 is practical.

        x_5 and x_8 and x_9 is beyond w^T \phi(x) + b = 0.
        This distance of black line is \epsilon_i

        I rewrite the objective function.
        \min_{w,b}  \frac{1}{2}||W||^2 + C\sum_{i \in N} \epsilon_i
        ~~s.t~~ \forall i \in N, y_i (w^T \phi(x_i) + b) \geq 1 - \epsilon_i ,~~~~\epsilon \geq 0 , \forall i \in N

        C is called regulation parameter.
        This parameter is a hyperparameter, so We decide before computing SVM algorithm.
        C has the role which adjusts degree of suppression of misclassification.
        The smaller C is, The smaller effect of \sum_{i \in N}\epsilon_i is. Thus, it is easy to accept misclassification. On the other hand, the bigger C is, The bigger effect of \sum_{i \in N}\epsilon_i is.
        When C = \infty, It become hard margin.

        Reference
          https://www.amazon.co.jp/%E3%82%B5%E3%83%9D%E3%83%BC%E3%83%88%E3%83%99%E3%82%AF%E3%83%88%E3%83%AB%E3%83%9E%E3%82%B7%E3%83%B3-%E6%A9%9F%E6%A2%B0%E5%AD%A6%E7%BF%92%E3%83%97%E3%83%AD%E3%83%95%E3%82%A7%E3%83%83%E3%82%B7%E3%83%A7%E3%83%8A%E3%83%AB%E3%82%B7%E3%83%AA%E3%83%BC%E3%82%BA-%E7%AB%B9%E5%86%85-%E4%B8%80%E9%83%8E/dp/4061529064

          コメント

          このブログの人気の投稿

          カーネルk-meansの実装

          Introduction   English ver 今日はカーネルk-meansの実装をしました。k-menasアルゴリズムはクラスタリングのためのアルゴリズムです。僕がカーネルk-meansを実装しようと思ったのには一つ理由があります。それは僕の友人がk-meansのプレゼンを、僕がカーネルのプレゼンをしていた時に、k-meansにカーネルを適応できないかと思ったからです。そこで、カーネルk-meansについての論文を探しました。 ここのpdf を主に参考にさせていただきました。うまくカーネルk-meansを実装できたと思います。ここでは、普通のk-meansとカーネルを用いた,kernel k-meansについての実装の結果を紹介します。 また、この記事では実装結果のみ書きますが、理論のほうも別の記事で書くつもりです。書き終えたらリンクをこの記事にも貼っておきます。 #  理論編書きました。K-means 理論編 概要 dataset   ちょっとだけ理論の説明  k-means    kernel k-means   Dataset   English ver 今回使うのは二つのデータセットです。一つ目は、普通のk-means用のデータです。二つ目はkernel k-means用のデータセットです。 一つ目のデータは、三つのグループで構成されており、次元は2で、サンプル数は300です。以下のような分布になっています。 二つ目のデータは二つのグループで構成されており、次元は2でサンプル数は300です。   this page にデータセットを作ったコードを載せています。 ちょっとだけ理論の説明 k-meansとは、k-平均法とも呼ばれています。初めに、適当なクラスに分け、各クラスの中で平均となるベクトルを求めます。そして、各データに対して、すべての平均ベクトルとの距離を求めます。そして、最小となる距離になるクラスに改めて、そのデータをクラスタリングします。そして、新たに得られたクラスの中でそれぞれ平均ベクトルを求め、これを繰り返し、平均ベクトルが動かな...

          ダイクストラ法

          Introduction English ver 今日は、ダイクストラ法について書きます。ダイクストラ法とは最短距離を求めるアルゴリズムです。地図はグラフで表されます。もし、まだ this page を見ていない方は先にこちらをご覧ください。今回はこの記事を前提としています。このページでは、グラフの定義と、ヒープ構造について書いています。ダイクストラ法ではヒープ構造を使って、かなりの計算量を落とします。 この スライド はダイクストラ法を説明したスライドです。 Overview アルゴリズム 実装 アルゴリズム このアルゴリズムは スタート始点のノードを決める。そして、それをAと名付ける。 各ノードにd=\inftyを割り当てる。ただし、スタート地点はd=0 Aの隣接ノードのリストをadj_listと名付ける。  For adj in adj_list:  If d of adj > d of A + weight to adj -> d = A + weight to adj. グラフnetworkからAを取り除く グラフnetworkの中で最初のdを持っているノードをAとし、4に戻る。 となっています。 このアルゴリズムを図を用いて説明します。  このグラフを使って説明します。  初めに、スタート地点を決めます。そして、各ノードにd=\inftyを割り当てます。  Aから始まります。Aの隣接ノードであるBのdを更新します。もし、現在のBよりもAのdとA->Bへの重みを足したもののほうが小さいならdをその値に更新します。同じようにCnのdを更新します。 次にAを取り除きます。  次はBから始まります。Aと同じことをやります。 このダイクストラ法では今のような操作をグラフの全てのノードに×がつくまで続きます。 実装 このアルゴリズムではO(log(|V|^2))という計算量を持っています。最小のdを持つノードを探すのに時間がかかります。 しかし、ヒープ構造を使えばO((E+V)log(V))に減らせます。ヒープ構造で現時点での...

          Implementation of Robbins monro

          Robbins monro の実装 sorry, this page is Japanese only.   今回はRobbins monro の実装をしてみました。 Robbins monroは確率勾配降下法の学習率を入りテーション回数の逆数で割っていくものです。 使っているprogram言語はpython 3です。osはwindowsです。(macほしい...) アルゴリズム 確率勾配降下方とは目的関数の最適解を求めるアルゴリズムです。目的関数をf(X)とすると、手順は以下のようになっています。 初期学習率n_0を決めます。訓練データDを用意します。この訓練データは複数の初期値の集まりです。 訓練データから一つ初期値をランダムに取り出し、これをx_0とし、最初の予測値とします。 次の式に現在の予測値x_0を代入し、新たな予測値x_{n+1}を得ます。x_{n+1} = x_{n} - \frac{n_0}{n} grad f(X_n) 収束して入れば4へ、収束していなければ2で得られた値x{n+1}を新たにx_nとしてもう一度2を行う。 訓練データを一周していなければ2へ、一周していれば各初期値から得られた解の中から目的関数を最も小さくするものを選ぶ。   実装例 以下の目的関数を最小化させてみましょう。 f(x,y) = (x-2)^2 + (y-3)^2 コマンドラインでpythonを実行していきます。 予想通り、(2,3)という解を導き出してくれました。目的関数が簡単だったので、初期値をどの値でとってもばっちり正解にたどり着いてくれました。 CODE 以下にRobbins monroの関数だけ置いておきます。 こちら にすべてのコードを載せています。 def Robbins_monro(function,grad,number_variable_gradient): init_learning_rate = 1.5 stepsize = 1000 init_value = np.array([range(-1000,1020,20) for i in range(number_v...