X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fappletgui%2FRedundancyPanel.java;h=ef00017d6fa6b6f1b73c4dc9dab3a420f23a025c;hb=69dd054a99ba910b138e84c8db62a11ee7c3ef37;hp=adcd180842a7613016c15125fa78dd174e24bb17;hpb=d423f22792e47dbc800ae220a58677f988971d06;p=jalview.git diff --git a/src/jalview/appletgui/RedundancyPanel.java b/src/jalview/appletgui/RedundancyPanel.java index adcd180..ef00017 100755 --- a/src/jalview/appletgui/RedundancyPanel.java +++ b/src/jalview/appletgui/RedundancyPanel.java @@ -1,13 +1,13 @@ /* - * Jalview - A Sequence Alignment Editor and Viewer (Version 2.5) - * Copyright (C) 2010 J Procter, AM Waterhouse, G Barton, M Clamp, S Searle + * Jalview - A Sequence Alignment Editor and Viewer (Version 2.8) + * Copyright (C) 2012 J Procter, AM Waterhouse, LM Lui, J Engelhardt, G Barton, M Clamp, S Searle * * This file is part of Jalview. * * Jalview 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. - * + * * Jalview 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 @@ -22,14 +22,13 @@ import java.util.*; import java.awt.*; import java.awt.event.*; +import jalview.analysis.AlignSeq; import jalview.commands.*; import jalview.datamodel.*; public class RedundancyPanel extends SliderPanel implements Runnable, WindowListener { - AlignmentPanel ap; - Stack historyList = new Stack(); // simpler than synching with alignFrame. float[] redundancy; @@ -109,68 +108,21 @@ public class RedundancyPanel extends SliderPanel implements Runnable, if ((sg != null) && (sg.getSize() >= 1)) { - originalSequences = sg.getSequencesInOrder(ap.av.alignment); + originalSequences = sg.getSequencesInOrder(ap.av.getAlignment()); start = sg.getStartRes(); end = sg.getEndRes(); } else { - originalSequences = ap.av.alignment.getSequencesArray(); + originalSequences = ap.av.getAlignment().getSequencesArray(); start = 0; - end = ap.av.alignment.getWidth(); + end = ap.av.getAlignment().getWidth(); } height = originalSequences.length; - redundancy = new float[height]; - for (int i = 0; i < height; i++) - { - redundancy[i] = 0f; - } - - // if (ap.av.hasHiddenColumns) - { - // omitHidden = ap.av.getSelectionAsString(); - } - - // long start = System.currentTimeMillis(); - - float pid; - String seqi, seqj; - for (int i = 0; i < height; i++) - { - for (int j = 0; j < i; j++) - { - if (i == j) - { - continue; - } - - if (omitHidden == null) - { - seqi = originalSequences[i].getSequenceAsString(start, end); - seqj = originalSequences[j].getSequenceAsString(start, end); - } - else - { - seqi = omitHidden[i]; - seqj = omitHidden[j]; - } - - pid = jalview.util.Comparison.PID(seqi, seqj); - - if (seqj.length() < seqi.length()) - { - redundancy[j] = Math.max(pid, redundancy[j]); - } - else - { - redundancy[i] = Math.max(pid, redundancy[i]); - } - - } - } - + redundancy = AlignSeq.computeRedundancyMatrix(originalSequences, + omitHidden, start, end, false); label.setText("Enter the redundancy threshold"); slider.setVisible(true); applyButton.setEnabled(true); @@ -241,12 +193,11 @@ public class RedundancyPanel extends SliderPanel implements Runnable, } EditCommand cut = new EditCommand("Remove Redundancy", - EditCommand.CUT, deleted, 0, width, ap.av.alignment); - + EditCommand.CUT, deleted, 0, width, ap.av.getAlignment()); + AlignmentI alignment = ap.av.getAlignment(); for (int i = 0; i < del.size(); i++) { - ap.av.alignment.deleteSequence(deleted[i]); - PaintRefresher.Refresh(this, ap.av.getSequenceSetId(), true, true); + alignment.deleteSequence(deleted[i]); if (sg != null) { sg.deleteSequence(deleted[i], false); @@ -257,8 +208,9 @@ public class RedundancyPanel extends SliderPanel implements Runnable, ap.alignFrame.addHistoryItem(cut); - ap.av.firePropertyChange("alignment", null, ap.av.getAlignment() - .getSequences()); + PaintRefresher.Refresh(this, ap.av.getSequenceSetId(), true, true); + // ap.av.firePropertyChange("alignment", null, ap.av.getAlignment() + // .getSequences()); } }