/*
* SVM.NET Library
* Copyright (C) 2008 Matthew Johnson
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
*/
using System;
using System.Collections.Generic;
namespace SVM
{
///
/// Class encapsulating a precomputed kernel, where each position indicates the similarity score for two items in the training data.
///
[Serializable]
public class PrecomputedKernel
{
private float[,] _similarities;
private int _rows;
private int _columns;
///
/// Constructor.
///
/// The similarity scores between all items in the training data
public PrecomputedKernel(float[,] similarities)
{
_similarities = similarities;
_rows = _similarities.GetLength(0);
_columns = _similarities.GetLength(1);
}
///
/// Constructs a object using the labels provided. If a label is set to "0" that item is ignored.
///
/// The labels for the row items
/// The labels for the column items
/// A object
public Problem Compute(double[] rowLabels, double[] columnLabels)
{
List X = new List();
List Y = new List();
int maxIndex = 0;
for (int i = 0; i < columnLabels.Length; i++)
if (columnLabels[i] != 0)
maxIndex++;
maxIndex++;
for (int r = 0; r < _rows; r++)
{
if (rowLabels[r] == 0)
continue;
List nodes = new List();
nodes.Add(new Node(0, X.Count + 1));
for (int c = 0; c < _columns; c++)
{
if (columnLabels[c] == 0)
continue;
double value = _similarities[r, c];
nodes.Add(new Node(nodes.Count, value));
}
X.Add(nodes.ToArray());
Y.Add(rowLabels[r]);
}
return new Problem(X.Count, Y.ToArray(), X.ToArray(), maxIndex);
}
}
}