Project

General

Profile

SciQlop Status » History » Revision 20

Revision 19 (Anonymous, 06/09/2016 04:31 PM) → Revision 20/26 (Anonymous, 06/09/2016 04:39 PM)

h1. SciQlop Status 

 "Priorities : Google doc link":https://docs.google.com/spreadsheets/d/1fIQDHRDhKJtTxnRRDlmInM25QFDaEuZ8gctZ523m6wU/edit#gid=0 

 h2. Scientific Objectives and Performances 

 |_.Functionnality |_.Status(% done)| 
 |SciQLOP should be portable, and an executable/setup should be available for Linux, Mac, Windows|| 
 |Installing SciQLOP must be easy, must not require to read a documentation or install dependencies|| 
 |When opened SciQLOP should by default reload the previous state (data products, plots, plugins, etc.)|| 
 |SciQLOP comes with good user documentation, including galleries, examples and    tutorials including video tutorials.|| 
 |SciQLOP should propose the same functionalities on all platforms.|| 
 |SciQLOP should propose the same performances on all platforms.|| 
 |SciQLOP's GUI should remain light, beautiful and intuitive|| 
 |Exploring databases, browsing data should be easier/faster than with other existing softwares|| 
 |SciQLOP should provide efficient and transparent data browsing, access to user python routines, collaborative cataloging features with and without machine learning|| 
 |SciQLOP should remain responsive when plotting 10 millions of points on a standard machine.|| 
 |SciQLOP should have a limited list of data type it can handle and group them by common traits (scalars, vectors, image...).|| 
 |SciQLOP may be able to provide features depending on the data type, source, unit or any condition/property the user may define or program.|| 
 |Each modification of the data between the source (server) and the plot should be documented|| 
 |SciQLOP should be used by students as a formation tool : provide users with knowledge toolkits associated to used quantities|| 
 |SciQLOP should provide users with easy access to documentations on data, missions, instruments, etc.|| 
 |SciQLOP should allow users to access wikipedia plasma/mission-related articles and suggest users to edit/add content.|| 
 |SciQLOP should allow users to save and restore sessions.|| 
 |SciQLOP user session should contain all data to restore its previous state.|| 


 h2. Code redistribution 

 |_.Functionnality |_.Status(% done)| 
 |SciQLOP source code will be    GPLv2.|{background:green;color:white}. 100| 
 |SciQLOP source folder should contain the files:README, INSTALL, COPYING, CHANGELOG.|| 
 |All SciQLOP source files should contain GPLv2 header.|{background:green;color:white}. 100| 
 |All SciQLOP dependencies should be compatible with GPLv2.|| 


 h2. Code versioning 

 |_.Functionnality |_.Status(% done)| 
 |SciQLOP source code modifications should have a link between features or bug corrections and code revisions|| 
 |SciQLOP source code should be hosted on the laboratory server hephaistos1 with the mercurial version system.|| 


 h2.Code Writing 

 |_.Functionnality |_.Status(% done)| 
 |SciQLOP developer's documentation, roadmap, issues, etc. will be done on the Redmine application : https://hephaistos.lpp.polytechnique.fr/redmine/projects/sciqlop|| 
 |Unit test are developed for all modules and performed after each important merge|| 
 |SciQLOP's code is homogeneous in its syntax and philosophy to guarantee easy maintainability.|| 
 |SciQLOP's code is self-explanatory, comments are used to explain goals, methods rather than instructions. Comments record development flow (hacks, todos, etc.)|| 
 |SciQLOP's code is based on the Qt framework and plotting capabilities use the QcustomPlot1 API.|| 


 h2. SciQLop Modules 

 |_.Functionnality |_.Status(% done)| 
 |{background:grey;color:white}. Core        |{background:grey}. | 
 |{background:#ddd;color:grey}.Database       |{background:#ddd}. | 
 ||| 
 ||| 
 ||| 
 ||| 
 ||| 
 ||| 
 ||| 
 ||| 
 ||| 
 ||| 
 ||| 
 ||| 
 ||| 
 ||| 
 ||| 
 ||| 
 ||| 
 ||| 
 ||| 
 |{background:#ddd;color:grey}.Data Downloader       |{background:#ddd}. | 
 |{background:grey;color:white}.Plot        |{background:grey}. | 
 |{background:#ddd;color:grey}.General        |{background:#ddd}. | 
 |SciQLOP should be able to plot all kinds of data relevant to space plasma missions(scalar, vector, tensor, spectrogram|| 
 |Each plot element (context : colorbars, ticks, titles, labels etc. ; data : lines, style, dots, etc.) should be clickable and customizable|| 
 |Controls on figure items should be identical in all kinds of plots (e.g. changing title, labels etc. is done identically for all kinds of plots).|| 
 |A plot “style” (context and data style) can be copy/pasted onto another plot || 
 |Users may define custom plot styles and save/reload them as desired|| 
 |Plots should provide visualization of available metadata (instrument modes, etc.)|| 
 |Each plot/view should provide the context menu associated to the data type.|| 
 |Each plot/view should allow the user to select a portion of data and perform specific operations on it, such as labelling it, building new plots or applying data analysis methods on it (e.g. get statistical quantities such as mean/std, etc.).|| 
 |Data can be selected by dragging a zone onto the plot: Time interval as rectangle for time series for example. A box in 3d plot/view for example.|| 
 |For time dependent data the plot/view may ask for more data when the user scrolls to the borders of the plot/view. || 
 |Users should experience no significant lag related to downloading data associated with scrolling windows|| 
 |Each plot/view should allow the integration of custom controls (user defined gui widgets) provided by the current plotted data. The control may be provided as a QWidget.|| 
 |Each plot/view should be easily duplicable.|| 
 |Figures/plots can be linked together or not.|{background:green;color:white}. 100| 
 |Linked plots will zoom/unzoom, scroll together (horizontally)|{background:green;color:white}. 100| 
 |A Lens effect enables the user to zoom on a part of the data without changing the plot range (like a lens effect on Gimp-like software). This can be made by adding a plot window overlapped onto the plot.|| 
 |Any plot should come with a default legend, customizable by the user|| 
 |Any plot can be dragged to a folder and exported as an image (eps, png, jpg)|| 
 |User can select multiple plots holding shift key and drag them onto a folder to export images. SciQLOP ask the user whether multiple images or a summary plot should be done.|| 
 |Mouse wheel can be used to scroll in time when the figure is selected.|| 
 |Plot adjustments controls appear on specific locations on mouse hover. This keeps the interface clear but still customizable.|| 
 |{background:#ddd;color:grey}.Scalar Time series        |{background:#ddd}. | 
 |Contextual menu should give users rapid access to statistical functionalities such as mean(), std().|| 
 |Data holes are handled in line style mode as a line segment.|| 
 |Line width can be adjusting by clicking+mouse wheel|| 
 |{background:#ddd;color:grey}.Vector Time series        |{background:#ddd}. | 
 |SciQLOP can plot one or more components of a vector as a function of time|| 
 |SciQLOP is aware the quantity is part of a vector. If Bx is plotted it knows which products represent By and Bz and can easily add them on the plot.|| 
 |The contextual menu on a vector plot should allow users to easily transform their vector into another basis, user-provided and generic basis such as GSE, GSM, etc. or MVA.|| 
 |Vectors displayed on linked plots will be represented in the same basis dynamically (one change of basis on one of the linked plot will change all of them)|| 
 |Vectors can be plotted in 3D or 2D-projection as 3D vectors as a function of time. This representation will be useful for visualizing aspects specific to vectors such as change of direction (e.g. waves & discontinuities) not easily viewable in the time series format.|| 
 |{background:#ddd;color:grey}.Spectrograms        |{background:#ddd}. | 
 |SciQLOP should enable the same plot/context functionalities for all spectrograms, no matter the nature of the data (particles or waves), this include color range, colormaps, etc.|| 
 |Characteristic frequencies should be overplottable as time series.|| 
 |Using WAMP for theoretical wave frequencies and damping should be possible|| 
 |Plasma eigenmodes visualization toolkit can be called from the spectrograms contextual menu|| 
 |Data holes are handled by showing the background color/texture|| 
 |Colormap by clicking on the colorbar, color range can easily be adjusted from cursors appearing on the colorbar on mouse hover|| 
 |{background:#ddd;color:grey}.Orbits      |{background:#ddd}. | 
 |SciQLOP provides the user with three 2D projections of the magnetosphere/heliosphere and its key regions|| 
 |Heliosphere/Magnetospheric plot use different models (Tsyganenko, shue, Parker Spiral, etc.) easily interchangeable by the user.|| 
 |Orbits of the satellites from which data is currently being viewed appears overplotted on the three 2D magnetospheric/heliosphere projections|| 
 |The position of the spacecraft for the considered intervals must be clearly visible on the trajectory with a colored portion of the orbit, the color being associated to a particular plot (or set of linked plots).|| 
 |Changing the interval range of a spacecraft on its orbit must change the plot time range accordingly and dynamically.|| 
 |SciQLOP should offer an interoperability with CDPP/3DView to view orbits in 3D|| 
 |{background:grey;color:white}.SpaceData        |{background:grey}. | 
 |{background:grey;color:white}.App        |{background:grey}. |