missing NULL terminator in set_config_x
[geda-gaf.git] / docs / wiki / gwave-projects.html
blobd964356e0a73bff0d449878d1cf53400678e9ea6
1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
2 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
3 <html>
4 <head>
5 <link rel="stylesheet" media="screen" type="text/css" href="./style.css" />
6 <link rel="stylesheet" media="screen" type="text/css" href="./design.css" />
7 <link rel="stylesheet" media="print" type="text/css" href="./print.css" />
9 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
10 </head>
11 <body>
13 <h3 class="sectionedit1" id="gwave_--_analog_waveform_viewer">Gwave -- analog waveform viewer</h3>
14 <div class="level3">
16 <p>
17 Gwave is an analog waveform viewer which is used to view the output files produced by ngspice or gnucap. Here are some feature suggestions. You might choose a large handful of features to implement as your GSoC project.
18 </p>
20 </div>
22 <h5 id="geda_integration">gEDA integration</h5>
23 <div class="level5">
25 <p>
26 This project involves improving the integration of gwave into the
27 interprocess-communication to and from the other tools, especialy gschem
28 and gnucap. While gwave has an X11-based remote mechanism, Dbus is now the
29 standard, and should probably be used instead.
30 </p>
32 </div>
34 <h5 id="developing_unit_tests_for_gtk_-20">Developing unit tests for GTK+-2.0</h5>
35 <div class="level5">
37 <p>
38 Gwave has been ported to Gtk2. As part of this effort, developing a battery of unit tests for gwave would be useful. The idea is to create a variety of different input files which exercise gwave&#039;s ability to import and display waveforms. An important feature for testing will be to compare the displayed waveform against a “golden” waveform to verify rendering correctness.
39 </p>
41 </div>
43 <h5 id="user_interface">User Interface</h5>
44 <div class="level5">
45 <ul>
46 <li class="level1"><div class="li"> Replace the existing variable-list with a tree-style variable-selector. allow multiple ways of organizing the tree: file/sweep/variable vs. file/variable/sweep, extract circuit heirarchy from variable names, etc. Perhaps a two-pane tree browser, with the internal nodes of the tree in one pane, and the leaf nodes (variables that can be displayed) in another.</div>
47 </li>
48 <li class="level1"><div class="li"> Add icons to the toolbar elements</div>
49 </li>
50 <li class="level1"><div class="li"> Enhance use of Gtk2.0 file chooser: wildcards for selecting particular types of files,</div>
51 </li>
52 <li class="level1"><div class="li"> Accept drag-and-drop from a file manager to add files, run scripts </div>
53 </li>
54 <li class="level1"><div class="li"> Allow drag-and-drop from one wavepanel to another to move wave</div>
55 </li>
56 <li class="level1"><div class="li"> Remember/restore the position of the windows, both most-recent-session, and also save it in the scripts.</div>
57 </li>
58 <li class="level1"><div class="li"> Add keybinding mechanism</div>
59 </li>
60 <li class="level1"><div class="li"> An undo stack for operations that change the view</div>
61 </li>
62 <li class="level1"><div class="li"> Add a guile console window, where expressions can be typed to query/manipulate/debug gwave objects and variable data.</div>
63 </li>
64 </ul>
66 </div>
68 <h5 id="data_visualization_and_analysis">Data visualization and analysis</h5>
69 <div class="level5">
70 <ul>
71 <li class="level1"><div class="li"> Draw a real graticule in wave panels, including a grid of faint/dotted lines and numeric scales</div>
72 </li>
73 <li class="level1"><div class="li"> Add ability to customize measurements</div>
74 </li>
75 <li class="level1"><div class="li"> Add additional drawing styles: dotted/dashed lines, symbols showing actual datapoints, </div>
76 </li>
77 <li class="level1"><div class="li"> Add user-configurable colors</div>
78 </li>
79 <li class="level1 node"><div class="li"> waveform calculations (Requires some of the infrastructure work below)</div>
80 <ul>
81 <li class="level2"><div class="li"> display-functions of a single wavevar and scalars</div>
82 </li>
83 <li class="level2"><div class="li"> display-functions of wavevars sharing the same independent var</div>
84 </li>
85 <li class="level2"><div class="li"> more general stuff that computes a new wavevar</div>
86 </li>
87 </ul>
88 </li>
89 <li class="level1"><div class="li"> Additional types of wavepanels for different types of viewing/analsis. (best done after refactoring the wavepanel UI elements into a class heirarchy of proper Gtk widgets)</div>
90 </li>
91 </ul>
93 </div>
95 <h5 id="datafile_variable_infrastructure">Datafile/Variable Infrastructure</h5>
96 <div class="level5">
97 <ul>
98 <li class="level1"><div class="li"> Readers for additional file-formats: wdf, sst2, psf have been mentioned</div>
99 </li>
100 </ul>
101 <ul>
102 <li class="level1"><div class="li"> Convert from ad-hoc data structures to a glib/GObject class heirarchy</div>
103 </li>
104 </ul>
105 <ul>
106 <li class="level1"><div class="li"> Ability to add a variable to a file after it is read in, to support computing a new variable as a function of existing ones</div>
107 </li>
108 </ul>
109 <ul>
110 <li class="level1"><div class="li"> Deferred read: initialy read only the independent variable from a datafile, then read the others when they are first displayed.</div>
111 </li>
112 </ul>
113 <ul>
114 <li class="level1"><div class="li"> Add a new class of variable, which is a function of other variables and constants to computed on the fly as it is displayed</div>
115 </li>
116 </ul>
117 <ul>
118 <li class="level1"><div class="li"> New class of variable for digital data; reader and display capability for verilog vcd</div>
119 </li>
120 </ul>
121 <ul>
122 <li class="level1"><div class="li"> Ability to create new datafile-like constructs programaticly, to hold the result of computations involving variables in two or more exisiting files. </div>
123 </li>
124 </ul>
125 <ul>
126 <li class="level1"><div class="li"> Handle creation of the independent-variable intelligently.</div>
127 </li>
128 </ul>
130 </div>
132 <h5 id="other_infrastructure">Other infrastructure</h5>
133 <div class="level5">
134 <ul>
135 <li class="level1"><div class="li"> convert other data structure from ad-hoc structures wrapped as custom SMOBs to GObject wrapped with guile-gobject.</div>
136 </li>
137 </ul>
138 <ul>
139 <li class="level1"><div class="li"> Convert the wavepanel drawing-area code into a new Gtk widget type</div>
140 </li>
141 </ul>
143 </div>
144 </body>
145 </html>