Форум программистов, компьютерный форум, киберфорум
Java: GUI, графика
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.88/25: Рейтинг темы: голосов - 25, средняя оценка - 4.88
6 / 6 / 3
Регистрация: 18.10.2010
Сообщений: 140

Построить линии уровня поверхности, используя библиотеку jfreeChart

25.10.2012, 06:17. Показов 5477. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Кто-нибудь юзал либу для построения графиков jfreeChart?
Необходимо построить линии уровня поверхности. Среди сэмплов нашел один пример, но исходного кода нет, и среди методов ChartFactory - класса содержащего методы, которые и определяют тип графика, нужного мне метода createXYBlockChart тоже нет. В общем может кто строил графики? Или предложите альтернативный быстрый вариант.

Добавлено через 8 часов 13 минут
Скажите а почему на этой строке
Java
1
XYDataset dataset = new XYSeriesCollection(series);
выполнение прерывается и компилятор выдает ошибку
Exception in thread "AWT-EventQueue-0" java.lang.NoClassDefFoundError: org/jfree/util/PublicCloneable
вот кусок кода
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
double maxRadius=10;
        double maxCorner=360;
        double corner,radius;
        double h1=0.1;
        double h2=1;
        corner=0;
        double z;
        double line=2;
        line=(float)f.func(x,y)+line;
        XYSeries series=new XYSeries("mydata");
        for(int i=0;i<=maxCorner/h1-1;i++){
            radius=0;
            for(int j=0;j<=maxRadius/h1;j++){
                z=(float)f.func(radius*java.lang.Math.cos(corner)+x,radius*java.lang.Math.sin(corner)+y);
                if(z>=line){
                    series.add(radius*java.lang.Math.cos(corner)+x, radius*java.lang.Math.sin(corner)+y);
                    break;
                }
                radius=radius+h1;
            }
            corner=corner+h1;
        }
        XYDataset dataset = new XYSeriesCollection(series);
        JFreeChart chart=ChartFactory.createPolarChart("График", dataset, true, true, true);
        
        jPanel12.add(new ChartPanel(chart));
Смотрел по примеру. И вроде все правильно - создаем объект класса XYSeriesCollection, который реализует интерфейс XYDataset. Вот ссылка на доку http://www.jfree.org/jfreechar... index.html

Добавлено через 26 минут
понял косяк - не все jar-файлы добавил
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
25.10.2012, 06:17
Ответы с готовыми решениями:

Помогите построить 3D bar chart в JFreeChart!!!!!
Всем здравствуйте! нет ли у кого примера построения 3D Bar Chart с использованием JFreeChart??? можно с Applet или Servlet...

График поверхности и линии уровня
Помогите построить график поверхности и линии уровня f(x,y) □(∶=) ( sin⁡ 2xy^3)/2+x

Линии (поверхности) уровня функций
Здравствуйте! Прошу помочь - как построить линии (поверхности) уровня функции: 1) u=x+4y+8z 2) z=x/y 3) z=min(4x,y)

6
6 / 6 / 3
Регистрация: 18.10.2010
Сообщений: 140
29.10.2012, 09:29  [ТС]
Попробовал пока использовать статический метод класса ChartFactory, то есть построил график с дефолтными настройками. Получилась вот такая вот ерунда

вот класс создания этого графика
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
public class MyChart {
    private double x;
    private double y;
    private myfunc f;
    private double beginX, beginY;
    //JFreeChart chart;
    public MyChart(double x,double y, double beginX, double beginY, myfunc f){
        this.x=x;
        this.y=y;
        this.beginX=beginX;
        this.beginY=beginY;
        this.f=f;
 
    }
    private XYDataset createDataset(){
        double maxCorner=360;
        double maxRadius=Math.sqrt(beginX*beginX+beginY*beginY)+Math.sqrt(beginX*beginX+beginY*beginY)/6;
        double corner,radius;
        XYSeries series;
        double line;
        double z;
        double h1=0.01;
        double h2=0.1;
        double fixline=(f.func(beginX,beginY)-f.func(x, y))/6;
        double summ=f.func(x, y);
        double[] arrFix=new double[6];
        for(int i=0;i<6;i++){
            summ=summ+fixline;
            arrFix[i]=summ;
        }
        XYSeriesCollection mainSeries=new XYSeriesCollection();
        for(int i=0;i<6;i++){
            corner=0;
            line=arrFix[i];
            if(i==0){
               series=new XYSeries("0-"+String.valueOf(arrFix[i]));
            }
            else{
                series=new XYSeries(String.valueOf(arrFix[i-1])+"-"+String.valueOf(arrFix[i]));
            }
            for(int j=0;j<=maxCorner/h1-1;j++){
            radius=0;
            for(int k=0;k<=maxRadius/h1;k++){
                z=(float)f.func(radius*java.lang.Math.cos(corner)+x,radius*java.lang.Math.sin(corner)+y);
                if(z>=line){
                    series.add(radius*java.lang.Math.cos(corner)+x, radius*java.lang.Math.sin(corner)+y);
                    break;
                }
                radius=radius+h1;
            }
            corner=corner+h1;
        }
            mainSeries.addSeries(series);
        }
        //XYDataset dataset=mainSeries;
        return mainSeries;
    }
    private JFreeChart createChart(XYDataset dataset){
        return ChartFactory.createScatterPlot("График", "x", "y", dataset, PlotOrientation.HORIZONTAL, true, true, true);
    }
    public JFreeChart NewChart(){
        return createChart(createDataset());
    }
 
}
Вообще в целом программа нужна для оптимизации многомерных функций различными методами. Она работает только с квадратичными функциями, так как методы используемые в проге с другими работать 100% не могут. Ну не в этом дело.
Как элемент интерфейса необходимо реализовать построение линий уровня и изобразить на этих графиках итерационный процесс выбранного пользователем метода.
Для построения линии уровня используется метод createScatterPlot (все я не смотрел, этот первый удовлетворительный оказался). В доке информации минимум.
В полученном графике меня не устраивает:
  • линии толстые из-за наличия маркеров и разноцветные, нужно сделать все одним цветом
  • желательно, чтобы был какой-то фон между каждыми линиями
  • график строится очень долго
Первые две проблемы думаю можно решить использованием AreaRenderer и прописыванием каждого компонента графика вручную
На счет третьей нет пока никаких идей. Процесс построения линий уровня заключается в том, что я выбираю определенным образом несколько значений функции (их количество равно количеству линий уровня), далее с использованием полярных координат, предварительно смещая начало координат в точку оптимума, я тупо пробегаю по поверхности (сканирую, последовательно увеличивая радиус и угол), до тех пор пока значение ф-ции в текущей точке не перевалит за выбранное мной заранее значение функции.
В чем сложности по поводу первых двух моментов... Потратил уже кучу времени, роясь в документации - так и не понял однозначно что использовать, чтобы построить более рационально график. Может кто-то более менее разбирается с JFreeChart и мог бы меня направить куда надо. (Примеры кода в инете можно на пальцах посчитать).
Как иначе выбирать данные для построения линий уровня тоже пока никаких идей.
Поэтому может мне лучше написать кусок касающийся графиков на чем-нибудь еще и тупо вставить сохраненную картинку в окно программы(например к Excel нельзя обратиться через Java).
Также после построения линий уровня мне нужно будет изобразить на том же графике ступенчатый итерационный процесс. То есть совместить в одном chart два разных render'a получается.
Надеюсь кто-нибудь все же откликнется...
0
6 / 6 / 3
Регистрация: 18.10.2010
Сообщений: 140
29.10.2012, 09:50  [ТС]
Хотя в ексель на одном графике вроде нельзя использовать различные типы диаграмм, ну я по крайней мере не сталкивался с этим
0
6 / 6 / 3
Регистрация: 18.10.2010
Сообщений: 140
31.10.2012, 07:46  [ТС]
Не знаю есть ли смысл продолжать писать в эту тему, так как глухо как в танке... ни одного ответа...(
Добился пока вот такого результата

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
package prihodko_lab;
//import java.lang.*;
import org.jfree.chart.JFreeChart;
//import org.jfree.chart.ChartFactory;
//import org.jfree.chart.ChartPanel;
//import org.jfree.chart.plot.PlotOrientation;
import org.jfree.data.xy.XYSeries;
import org.jfree.data.xy.XYSeriesCollection;
import org.jfree.data.xy.XYDataset;
import org.jfree.data.xy.XYZDataset;
//import org.jfree.data.xy.TableXYDataset;
//import org.jfree.chart.renderer.xy.XYBlockRenderer;
//import java.lang.Math;
//import org.jfree.data.xy.TableXYDataset;
//import org.jfree.data.xy.CategoryTableXYDataset;
import org.jfree.chart.axis.NumberAxis;
import org.jfree.chart.axis.NumberTickUnit;
import org.jfree.chart.renderer.xy.VectorRenderer;
import org.jfree.chart.plot.XYPlot;
import org.jfree.chart.renderer.xy.XYBlockRenderer;
//import org.jfree.chart.renderer.xy.XYBubbleRenderer;
import org.jfree.chart.plot.CombinedRangeXYPlot;
/**
 *
 * @author shepard90
 */
 
 
 
public class MyChart {
    private double x;
    private double y;
    private myfunc f;
    private double beginX, beginY;
    private double max;
    //JFreeChart chart;
    public MyChart(double x,double y, double beginX, double beginY, myfunc f){
        this.x=x;
        this.y=y;
        this.beginX=beginX;
        this.beginY=beginY;
        this.f=f;
 
    }
    private XYZDataset createDataset1(){
        double h=0.1;
        double diapX, diapY;
        diapX=2*Math.abs(beginX-x)+2;
        diapY=2*Math.abs(beginY-y)+2;
        double dx;
        double dy;
        dx=x-diapX/2;
        dy=y-diapY/2;
        int countX,countY;
        countX=Math.round((float)(diapX/h)+1);
        countY=Math.round((float)(diapY/h)+1);
        double[][] series=new double[3][countX*countY];
        double[] a=new double[countX];
        double[] b=new double[countY];
        for(int i=0;i<countX;i++){
            a[i]=dx;
            dx=dx+h;
        }
        for(int i=0;i<countY;i++){
            b[i]=dy;
            dy=dy+h;
        }
        max=f.func(a[0], b[0]);
 
        for(int i=0;i<countX;i++){
            for(int j=0;j<countY;j++){
                series[0][i*countY+j]=a[i];
                series[1][i*countY+j]=b[j];
                series[2][i*countY+j]=f.func(a[i], b[j]);
                if(max<f.func(a[i], b[j])){
                    max=f.func(a[i], b[j]);
                }
            }
            
        }
        java.lang.Comparable j=new java.lang.Integer(5);
        org.jfree.data.xy.DefaultXYZDataset ddataset=new org.jfree.data.xy.DefaultXYZDataset();
        ddataset.addSeries(j, series);
        XYZDataset dataset=ddataset;
        return dataset;
    }
    private XYDataset createDataset2(){
        double maxCorner=360;
        double maxRadius=Math.sqrt(beginX*beginX+beginY*beginY)+Math.sqrt(beginX*beginX+beginY*beginY)/6;
        double corner,radius;
        XYSeries series;
        double line;
        double z;
        double h1=0.1;
        double h2=1;
        double fixline=(f.func(beginX,beginY)-f.func(x, y))/6;
        double summ=f.func(x, y);
        double[] arrFix=new double[6];
        for(int i=0;i<6;i++){
            summ=summ+fixline;
            arrFix[i]=summ;
        }
        XYSeriesCollection mainSeries=new XYSeriesCollection();
        for(int i=0;i<6;i++){
            corner=0;
            line=arrFix[i];
            if(i==0){
               series=new XYSeries("0-"+String.valueOf(arrFix[i]));
            }
            else{
                series=new XYSeries(String.valueOf(arrFix[i-1])+"-"+String.valueOf(arrFix[i]));
            }
            for(int j=0;j<=maxCorner/h1-1;j++){
            radius=0;
            for(int k=0;k<=maxRadius/h1;k++){
                z=(float)f.func(radius*java.lang.Math.cos(corner)+x,radius*java.lang.Math.sin(corner)+y);
                if(z>=line){
                    series.add(radius*java.lang.Math.cos(corner)+x, radius*java.lang.Math.sin(corner)+y);
                    break;
                }
                radius=radius+h1;
            }
            corner=corner+h1;
        }
            mainSeries.addSeries(series);
        }
        //XYDataset dataset=mainSeries;
        return mainSeries;
    }
    private JFreeChart createChart(XYZDataset dataset1, XYDataset dataset2){
        //return ChartFactory.createScatterPlot("График", "x", "y", dataset, PlotOrientation.HORIZONTAL, true, true, true);
        NumberAxis axisX=new NumberAxis("x");
        axisX.setPositiveArrowVisible(true);
         axisX.setStandardTickUnits(NumberAxis.createStandardTickUnits());
        axisX.setTickUnit(new NumberTickUnit(1));
        NumberAxis axisY=new NumberAxis("y");
        axisY.setPositiveArrowVisible(true);
         axisY.setStandardTickUnits(NumberAxis.createStandardTickUnits());
        axisY.setTickUnit(new NumberTickUnit(1));
        //PaintScale
        org.jfree.chart.renderer.GrayPaintScale scale=new org.jfree.chart.renderer.GrayPaintScale(Math.round(f.func(x, y)),this.max);
        //renderer
        XYBlockRenderer renderer1=new XYBlockRenderer();
 
        renderer1.setPaintScale(scale);
        VectorRenderer renderer2=new VectorRenderer();
        for(int i=0;i<6;i++){
            renderer2.setSeriesPaint(i, java.awt.Color.BLACK);
        }
        /*for(int i=0;i<6;i++){
            renderer1.setSeriesPaint(i, java.awt.Color.BLACK);
        }*/
        //plot
        XYPlot subplot1=new XYPlot(dataset1,axisX,axisY,renderer1);
        XYPlot subplot2=new XYPlot(dataset2,axisX,axisY,renderer2);
        //subplot1.setBackgroundPaint(java.awt.Color.WHITE);
        CombinedRangeXYPlot plot=new CombinedRangeXYPlot();
        plot.add(subplot1);
        plot.add(subplot2);
        return new JFreeChart(plot);
    }
    public JFreeChart NewChart(){
        return createChart(createDataset1(),createDataset2());
    }
 
}
Использовал CombinedRangeXYPlot, то есть объединил два XYPlot'a, которым соответствуют свои рендереры и данные. для первого графика использовал XYBlockRenderer и XYZDataset, для второго - VectorRenderer и XYDataset.
Теперь вопрос: как слить два эти графика в один? Видел примеры в виде изображений, где в одном графике заключены несколько разных рендереров, но исходного кода к этим примерам не нашел.
Например вот
0
6 / 6 / 3
Регистрация: 18.10.2010
Сообщений: 140
31.10.2012, 10:27  [ТС]
вообще существует два класса для построения комбинированных графиков: CombinedRangeXYPlot и CombinedDomainXYPlot -объединение по оси y и по оси x соответственно. Вот как скомбинировать графики по двум осям???

Добавлено через 1 час 53 минуты
Мда... не в ту степь меня понесло, не заметил, что у XYPlot есть методы, которые позволяют добавлять renderer и dataset по индексу
0
 Аватар для mutagen
2587 / 2260 / 257
Регистрация: 14.09.2011
Сообщений: 5,185
Записей в блоге: 18
31.10.2012, 17:06
Глухо видимо потому что местные форумчане не пользуются этой библиотекой, Вам лучше поискать форум поближе к разработчикам, ссылку не даю - правила обязывают
0
6 / 6 / 3
Регистрация: 18.10.2010
Сообщений: 140
02.11.2012, 00:47  [ТС]
Цитата Сообщение от mutagen Посмотреть сообщение
Глухо видимо потому что местные форумчане не пользуются этой библиотекой, Вам лучше поискать форум поближе к разработчикам, ссылку не даю - правила обязывают
Специализированные форумы в основном на английском, а я им к сожалению не владею(
Ну в принципе уже разобрался, осталось только там да сям подправить и все
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
02.11.2012, 00:47
Помогаю со студенческими работами здесь

Построить линии равного уровня (линии контура)
Ребята нужна строчная помощь нужно построить линии уровня функции Z=100*(x2-x1^3)^2+(1-x1)^2; в интервале x1 x2 Буду по гроб...

Отображение поверхности с помощью surf и линии уровня ezcontour
В одном графическом окне отобразить поверхностью с помощью surf и линии уровня ezcontour. syms x y; a=4; b=5; z=...

Найти и построить линии уровня
Найти и построить линии уровня функции z=arcsin(xy).Помогите пожалуйсто,спасибо.

Найти и построить линии уровня функций
z=x*x*y z=ln(x*x+y*y)

Построить линии уровня исходя из данных в файле
Имеется текстовый файл, в котором через пробел записано X Y f(X,Y), можно ли в maple построить линии уровня исходя из данных в файле? если...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Программный контроль заполнения реквизита табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать контроль заполнения реквизита "ПричинаСписания". . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
Программное заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению. На форме документа создается. . .
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru