⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 transformationtask.java

📁 一个数据挖掘软件ALPHAMINERR的整个过程的JAVA版源代码
💻 JAVA
字号:
/*
 *    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 2 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, write to the Free Software
 *    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 */

/**
 * Title: XELOPES Data Mining Library
 * Description: The XELOPES library is an open platform-independent and data-source-independent library for Embedded Data Mining.
 * Copyright: Copyright (c) 2002 Prudential Systems Software GmbH
 * Company: ZSoft (www.zsoft.ru), Prudsys (www.prudsys.com)
 * @author Valentine Stepanenko (valentine.stepanenko@zsoft.ru)
 * @version 1.0
 */

package com.prudsys.pdm.Cwm.Transformation;

import java.util.Collection;
import java.util.Iterator;

import com.prudsys.pdm.Cwm.SoftwareDeployment.Component;

/**
 * This represents a set of Transformations that must be executed together as a
 * single task (logical unit).
 *
 *
 *
 * A TransformationTask may have an inverse task. A transformation task that maps
 * a source set "A" into a target set "B" can be reversed by the inverse
 * transformation task that maps "B" into "A".
 */
public class TransformationTask extends Component implements org.omg.cwm.analysis.transformation.TransformationTask
{
   public TransformationStep step[];
   public TransformationTask originalTask[];
   public TransformationTask inverseTask[];
   public Transformation transformation[];

   public TransformationTask()
   {

   }

   public Collection getInverseTask() {
     return com.prudsys.pdm.Cwm.Core.CWMTools.ArrayToList(inverseTask);
   }

   public void setInverseTask(Collection inverseTask) {

     this.inverseTask = new TransformationTask[ inverseTask.size() ];
     Iterator it = inverseTask.iterator();
     for (int i = 0; i < inverseTask.size(); i++)
       this.inverseTask[i] = (TransformationTask) it.next();
   }

   public void addInverseTask( org.omg.cwm.analysis.transformation.TransformationTask input) {

     int size = (inverseTask == null) ? 0 : inverseTask.length;
     TransformationTask[] oldData = inverseTask;
     inverseTask = new TransformationTask[size+1];
     if (size > 0) System.arraycopy(oldData, 0, inverseTask, 0, size);
     inverseTask[size] = (TransformationTask) input;
   }

   public void removeInverseTask( org.omg.cwm.analysis.transformation.TransformationTask input) {

     int size = (inverseTask == null) ? 0 : inverseTask.length;
     if (size == 0)
       return;

     int ipos = -1;
     for (int i = 0; i < size; i++)
       if (inverseTask[i].equals(input)) {
         ipos = i;
         break;
       }
     if (ipos == -1)
       return;

     TransformationTask[] oldData = inverseTask;
     inverseTask = new TransformationTask[size-1];
     for (int i = 0; i < ipos; i++)
       inverseTask[i] = oldData[i];
     for (int i = ipos+1; i < size; i++)
       inverseTask[i-1] = oldData[i];
   }

   public Collection getOriginalTask() {
     return com.prudsys.pdm.Cwm.Core.CWMTools.ArrayToList(originalTask);
   }

   public void setOriginalTask(Collection originalTask) {

     this.originalTask = new TransformationTask[ originalTask.size() ];
     Iterator it = originalTask.iterator();
     for (int i = 0; i < originalTask.size(); i++)
       this.originalTask[i] = (TransformationTask) it.next();
   }

   public void addOriginalTask( org.omg.cwm.analysis.transformation.TransformationTask input) {

     int size = (originalTask == null) ? 0 : originalTask.length;
     TransformationTask[] oldData = originalTask;
     originalTask = new TransformationTask[size+1];
     if (size > 0) System.arraycopy(oldData, 0, originalTask, 0, size);
     originalTask[size] = (TransformationTask) input;
   }

   public void removeOriginalTask( org.omg.cwm.analysis.transformation.TransformationTask input) {

     int size = (originalTask == null) ? 0 : originalTask.length;
     if (size == 0)
       return;

     int ipos = -1;
     for (int i = 0; i < size; i++)
       if (originalTask[i].equals(input)) {
         ipos = i;
         break;
       }
     if (ipos == -1)
       return;

     TransformationTask[] oldData = originalTask;
     originalTask = new TransformationTask[size-1];
     for (int i = 0; i < ipos; i++)
       originalTask[i] = oldData[i];
     for (int i = ipos+1; i < size; i++)
       originalTask[i-1] = oldData[i];
   }

   public Collection getTransformation() {
     return com.prudsys.pdm.Cwm.Core.CWMTools.ArrayToList(transformation);
   }

   public void setTransformation(Collection transformation) {

     this.transformation = new Transformation[ transformation.size() ];
     Iterator it = transformation.iterator();
     for (int i = 0; i < transformation.size(); i++)
       this.transformation[i] = (Transformation) it.next();
   }

   public void addTransformation( org.omg.cwm.analysis.transformation.Transformation input) {

     int size = (transformation == null) ? 0 : transformation.length;
     Transformation[] oldData = transformation;
     transformation = new Transformation[size+1];
     if (size > 0) System.arraycopy(oldData, 0, transformation, 0, size);
     transformation[size] = (Transformation) input;
   }

   public void removeTransformation( org.omg.cwm.analysis.transformation.Transformation input) {

     int size = (transformation == null) ? 0 : transformation.length;
     if (size == 0)
       return;

     int ipos = -1;
     for (int i = 0; i < size; i++)
       if (transformation[i].equals(input)) {
         ipos = i;
         break;
       }
     if (ipos == -1)
       return;

     Transformation[] oldData = transformation;
     transformation = new Transformation[size-1];
     for (int i = 0; i < ipos; i++)
       transformation[i] = oldData[i];
     for (int i = ipos+1; i < size; i++)
       transformation[i-1] = oldData[i];
   }
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -