X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fgui%2FRedundancyPanel.java;h=59ee1e743897f139f9ae9d873d881f6b39bd0e77;hb=b2f9a8d7bce642ff4011bc6d49e02bb0569fbb11;hp=c4d7e3b366da37054c023dd8fb31291da349add2;hpb=797df64fa2a0a30773d0f48f5494d4155e5a8be3;p=jalview.git diff --git a/src/jalview/gui/RedundancyPanel.java b/src/jalview/gui/RedundancyPanel.java index c4d7e3b..59ee1e7 100755 --- a/src/jalview/gui/RedundancyPanel.java +++ b/src/jalview/gui/RedundancyPanel.java @@ -1,19 +1,20 @@ /* - * Jalview - A Sequence Alignment Editor and Viewer (Version 2.7) - * Copyright (C) 2011 J Procter, AM Waterhouse, J Engelhardt, LM Lui, G Barton, M Clamp, S Searle + * Jalview - A Sequence Alignment Editor and Viewer (Version 2.8.1) + * Copyright (C) 2014 The Jalview Authors * * 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 * PURPOSE. See the GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along with Jalview. If not, see . + * The Jalview Authors are detailed in the 'AUTHORS' file. */ package jalview.gui; @@ -23,10 +24,11 @@ import java.awt.event.*; import javax.swing.*; import javax.swing.event.*; +import jalview.analysis.AlignSeq; import jalview.commands.*; import jalview.datamodel.*; import jalview.jbgui.*; -import jalview.util.*; +import jalview.util.MessageManager; /** * DOCUMENT ME! @@ -73,7 +75,7 @@ public class RedundancyPanel extends GSliderPanel implements Runnable } }); - applyButton.setText("Remove"); + applyButton.setText(MessageManager.getString("action.remove")); allGroupsCheck.setVisible(false); slider.setMinimum(0); slider.setMaximum(100); @@ -84,7 +86,7 @@ public class RedundancyPanel extends GSliderPanel implements Runnable frame = new JInternalFrame(); frame.setContentPane(this); - Desktop.addInternalFrame(frame, "Redundancy threshold selection", 400, + Desktop.addInternalFrame(frame, MessageManager.getString("label.redundancy_threshold_selection"), 400, 100, false); frame.addInternalFrameListener(new InternalFrameAdapter() { @@ -114,7 +116,7 @@ public class RedundancyPanel extends GSliderPanel implements Runnable progress.setIndeterminate(true); southPanel.add(progress, java.awt.BorderLayout.SOUTH); - label.setText("Calculating...."); + label.setText(MessageManager.getString("label.calculating")); slider.setVisible(false); applyButton.setEnabled(false); @@ -131,68 +133,24 @@ public class RedundancyPanel extends GSliderPanel 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) + if (ap.av.hasHiddenColumns()) { omitHidden = ap.av.getViewAsString(sg != null); } - - // 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 = 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); progress.setIndeterminate(false); progress.setVisible(false); @@ -204,6 +162,7 @@ public class RedundancyPanel extends GSliderPanel implements Runnable valueField.setVisible(true); validate(); + sliderValueChanged(); // System.out.println((System.currentTimeMillis()-start)); } @@ -215,21 +174,15 @@ public class RedundancyPanel extends GSliderPanel implements Runnable } float value = slider.getValue(); - + List redundantSequences = new ArrayList(); for (int i = 0; i < redundancy.length; i++) { - if (value > redundancy[i]) - { - redundantSeqs.remove(originalSequences[i]); - } - else if (!redundantSeqs.contains(originalSequences[i])) + if (value <= redundancy[i]) { - redundantSeqs.add(originalSequences[i]); + redundantSequences.add(originalSequences[i]); } - } - - ap.idPanel.idCanvas.setHighlighted(redundantSeqs); + ap.idPanel.idCanvas.setHighlighted(redundantSequences); } /** @@ -273,12 +226,11 @@ public class RedundancyPanel extends GSliderPanel implements Runnable } EditCommand cut = new EditCommand("Remove Redundancy", - EditCommand.CUT, deleted, 0, width, ap.av.alignment); + EditCommand.CUT, deleted, 0, width, 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); + ap.av.getAlignment().deleteSequence(deleted[i]); if (sg != null) { sg.deleteSequence(deleted[i], false); @@ -289,8 +241,9 @@ public class RedundancyPanel extends GSliderPanel 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()); } }