All Downloads are FREE. Search and download functionalities are using the official Maven repository.

edu.sc.seis.TauP.SlownessPlot Maven / Gradle / Ivy

/*
 * The TauP Toolkit: Flexible Seismic Travel-Time and Raypath Utilities.
 * Copyright (C) 1998-2000 University of South Carolina
 * 
 * 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., 59 Temple
 * Place - Suite 330, Boston, MA 02111-1307, USA.
 * 
 * The current version can be found at http://www.seis.sc.edu
 * 
 * Bug reports and comments should be directed to H. Philip Crotwell,
 * [email protected] or Tom Owens, [email protected]
 * 
 */
package edu.sc.seis.TauP;

import java.awt.Container;
import java.awt.Graphics;
import java.util.Vector;

/**
 * plots slowness versus depth.
 * 
 * @version 1.1.3 Wed Jul 18 15:00:35 GMT 2001
 * 
 * 
 * 
 * @author H. Philip Crotwell
 * 
 */
public class SlownessPlot extends XYPlot {

    public SlownessPlot(Container parent) {
        super(parent);
        title = "Slowness";
        xLabel = "p (sec/km or km-sec/km)";
        yLabel = "depth (km)";
        yTickWidth = 500;
    }

    public SlownessPlot(Container parent, int width, int height) {
        super(parent, width, height);
        title = "Slowness";
        xLabel = "p (sec/km or km-sec/km)";
        yLabel = "depth (km)";
        yTickWidth = 500;
    }

    public void plot(SlownessModel sModel, boolean isPWave) {
        SlownessLayer ss;
        xSegments = new Vector();
        ySegments = new Vector();
        xData = new double[2 * sModel.getNumLayers(isPWave)];
        yData = new double[2 * sModel.getNumLayers(isPWave)];
        if(!isPWave) {
            minX = 0.0;
            zoomMinX = minX;
            maxX = 2500.0;
            zoomMaxX = maxX;
            minY = 0.0;
            zoomMinY = minY;
            maxY = sModel.getRadiusOfEarth();
            zoomMaxY = maxY;
        } else {
            minX = 0.0;
            zoomMinX = minX;
            maxX = 1300.0;
            zoomMaxX = maxX;
            minY = 0.0;
            zoomMinY = minY;
            maxY = sModel.getRadiusOfEarth();
            zoomMaxY = maxY;
        }
        int j = 0;
        for(int i = 0; i < sModel.getNumLayers(isPWave); i++) {
            ss = sModel.getSlownessLayer(i, isPWave);
            yData[j] = sModel.getRadiusOfEarth() - ss.getTopDepth();
            xData[j] = ss.getTopP();
            if(DEBUG)
                System.out.println("x " + xData[j] + " y " + yData[j]);
            j++;
            yData[j] = sModel.getRadiusOfEarth() - ss.getBotDepth();
            xData[j] = ss.getBotP();
            if(DEBUG)
                System.out.println("x " + xData[j] + " y " + yData[j]);
            j++;
        }
        xSegments.addElement(xData);
        ySegments.addElement(yData);
        repaint();
    }

    public void paint(Graphics g) {
        super.paint(g);
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy