JHepWork

JHepWork
jHepWork
Ejemplo de histograma jHepWork y función
Desarrollador
principalmente, el Dr. S. Chekanov
http://jwork.org/jhepwork
Información general
Última versión estable 2.8b
diciembre de 2010
Género Análisis de datos
Programado en Java, Jython
Sistema operativo multiplataforma
Plataforma Java
Licencia código fuente (jhplot) bajo licencia GNU, el resto tiene restricciones para el uso comercial, pues se encuentra bajo licencia para uso no comercial (Creative commons); véase abajo
Idiomas inglés
En español No. 

JHepWork es un marco de trabajo gratuito de análisis de datos para científicos, ingenieros y estudiantes escrito en Java. El programa está diseñado para áreas de gráficas científicas interactivas en 2D y 3D y contiene bibliotecas numéricas científicas implementadas en Java para funciones matemáticas, números aleatorios, análisis estadístico, ajuste de curvas de regresión y otras actividades de minería de datos. jHepWork se basa en un lenguaje de programación de alto nivel, Jython (Python implementado en Java), pero puede utilizarse también codificación Java para llamar a bibliotecas jHepWork numéricas y gráficas.

jHepWork es un intento de crear un entorno de análisis de datos usando paquetes de código abierto con una interfaz de usuario coherente y para crear una herramienta competitiva a los programas comerciales. La idea detrás del proyecto es la incorporación de código abierto paquetes de software matemático y numérico con interfaz de usuario de tipo gráfico en un programa coherente en el cual la interfaz de usuario principal se basa en clases de nombre corto llamado Java/Python. Esto es necesario para construir un ambiente de análisis utilizando el concepto de secuencias de comandos de Java. Un ejemplo típico se muestra más adelante.

HepWork funciona en cualquier plataforma (Windows, Macintosh, Linux, etc) donde se pueda instalar Máquina virtual Java. Las secuencias de comandos (scripts) y el código de Java (en el caso de la programación Java) se puede ejecutar tanto en un editor de interfaz gráfica de usuario de jHepWork como en |programas por lotes. Las bibliotecas gráficas de jHepWork se pueden utilizar para crear applets. Todas las gráficas (o "lienzos") utilizadas para la representación de datos pueden ser embebidos en navegadores web.

jHepWork se puede utilizar en todo lugar donde el análisis de grandes volúmenes de datos numéricos, de minería de datos, análisis de datos estadísticos y matemáticos son esenciales. El programa puede ser utilizado en ciencias naturales, ingeniería, y modelado y análisis de mercados financieros, entre otros. jHepWork es considerado entre los cinco mejores paquetes de software de minería de datos libre y código abierto.[1] Hay varios comentarios (reseñas) más sobre jHepWork disponibles.[2] [3] Si bien el programa entra en la categoría de software de código abierto, no es completamente libre para uso comercial (ver más abajo).

Contenido

Resumen

jHepWork tiene varias características útiles para el análisis de datos:

  • Puede utilizar secuencias de comandos Jython, BeanShell, o el estándar de Java;
  • Al estar basado en Java, es verdaderamente multiplataforma;
  • Puede ser integrado con la Web en forma de applets o aplicaciones Java Web Start, por lo que es adecuado para ambientes de análisis distribuido a través de Internet;
  • jHepWork ha sido diseñado desde cero para aguantar la programación con varios subprocesos;
  • Tiene un IDE multifuncional, con resaltado de sintaxis, verificador de sintaxis, completador de código y analizador;
  • Incluye un sistema de ayuda con completado de código basado en la tecnología Java de reflexión;
  • Utiliza una plataforma de I/O neutral basada en Protocol Buffers de Google. Los datos pueden ser escritos en C++ y analizados mediante Java/Jython;
  • Bases de datos (bases de datos OO y bases de datos basadas en SQL)
  • Tiene un navegador para objetos serializados y objetos creados con Google Protocol Buffers;
  • Incluye paquetes para cálculos estadísticos;
  • Los cálculos simbólicos similares a los encontrados en el proyecto GNU Octave, pero reescrita en Java.

Características de análisis de datos

El paquete es compatible con varias características matemáticas, de análisis de datos, y de minería de datos:

Términos de licencia

El código fuente del núcleo de jHepWork (jhplot) se encuentra bajo licencia GNU General Public License, pero el proyecto tiene algunas restricciones para el uso comercial dado que los archivos de idioma, los archivos de documentación, los ejemplos, el instalador, las bases de datos code-assist, y la ayuda interactiva tienen licencia para uso no comercial (licencias Creative Commons). Miembros del proyecto jHepWork tienen varias ventajas (licencia para uso comercial, acceso al repositorio de código fuente Doxygen, sistema de ayuda extendida, repositorio de scripts de usuario, etc).

Ejemplos de scripts Jython

A continuación se muestra un ejemplo sencillo que ilustra cómo llenar un histograma 2D y mostrarlo en un lienzo o área de gráfica. El script (secuencia de comandos) también crea una figura en formato PDF. Este script muestra cómo pegar y mezclar clases Java nativas (del paquete java.util) y clases jHepWork (el paquete jhplot) dentro de un script escrito con la sintaxis de Python.

from java.util import Random
from jhplot  import *

c1 = HPlot3D("Canvas")
c1.setGTitle("Global title")
c1.setNameX("X")
c1.setNameY("Y")
c1.visible()
c1.setAutoRange()

h1 = H2D("2D histogram",25,-3.0, 3.0,25,-3.0, 3.0)
rand = Random();
for i in range(200):
     h1.fill(rand.nextGaussian(),rand.nextGaussian())
c1.draw(h1);
c1.export("jhplot3d.png")

Este script puede ser ejecutado bien usando jHepWork IDE o un Jython independiente después de especificar la ruta de clases (classpath) a las bibliotecas jHepWork. En el sisguiente enlace se ve la salida que proporciona este script:

jHepWork tiene sus raíces en la física de partículas, donde la minería de datos es una tarea primordial. jHepWork fue escrito inicialmente para el análisis de los datos de partículas físicas[4] utilizando el concepto de software Java del Colisionador Lineal Internacional del proyecto desarrollado en SLAC. Las versiones posteriores de jHepWork fueron modificadas para uso público en general (es decir, para científicos, ingenieros, estudiantes con fines educativos, etc) ya que el proyecto del Colisionador Lineal Internacional se ha estancado. En la actualidad, jHepWork es un programa apoyado por la comunidad. La principal fuente de referencia es el libro "El análisis científico de datos mediante secuencias de comandos Jython y Java"(V.O. "Scientific Data analysis using Jython Scripting and Java"),[5] que analiza en profundidad los métodos de análisis de datos usando scripts Java y Jython.

Notas

Bibliografía

Manual técnico:

Enlaces internos

  • Ver el portal sobre Software libre Portal:Software libre. Contenido relacionado con Software libre.
  • ROOT – C++ framework de análisis de datos desarrollado en el CERN
  • Java Analysis Studio — un sistema basado en Java de análisis de datos compatible con AIDA

Enlaces externos


Wikimedia foundation. 2010.

Игры ⚽ Нужна курсовая?

Mira otros diccionarios:

  • JHepWork — is a data analysis framework written in Java. The program includes many tools for interactive scientific plots in 2D and 3D. Data structures and data manipulation methods integrated with Java and JAIDA classes. Programs written using jHepWork are …   Wikipedia

  • Comparison of numerical analysis software — This list is incomplete; you can help by expanding it. The following tables provide a comparison of numerical analysis software. Contents 1 Applications 1.1 General …   Wikipedia

  • Comparison of TeX editors — This page shows a table contrasting the features of the text editors that interface to TeX (or LaTeX or its other incarnations). Table of editor properties Properties of TeX editors Editing style[1] Native operating systems[2] …   Wikipedia

  • Data mining — Not to be confused with analytics, information extraction, or data analysis. Data mining (the analysis step of the knowledge discovery in databases process,[1] or KDD), a relatively young and interdisciplinary field of computer science[2][3] is… …   Wikipedia

  • Scientific visualization — A scientific visualization of an extremely large simulation of a Rayleigh–Taylor instability caused by two mixing fluids.[1] Scientific visualization (also spelled scientific visualisation) is an interdisciplinary branch of science according to… …   Wikipedia

  • Data analysis — Analysis of data is a process of inspecting, cleaning, transforming, and modeling data with the goal of highlighting useful information, suggesting conclusions, and supporting decision making. Data analysis has multiple facets and approaches,… …   Wikipedia

  • Comparison of statistical packages — The following tables compare general and technical information for a number of statistical analysis packages. Contents 1 General information 2 Operating system support 3 ANOVA 4 Regression …   Wikipedia

  • Computational particle physics — refers to the methods and computing tools developed in and used by particle physics research. Like computational chemistry or computational biology, it is, for particle physics both a specific branch and an interdisciplinary field relying on… …   Wikipedia

  • List of free and open source software packages — This article is about software free to be modified and distributed. For examples of software free in the monetary sense, see List of freeware. This is a list of free and open source software packages: computer software licensed under free… …   Wikipedia

  • ROOT (CERN) — У этого термина существуют и другие значения, см. Root. ROOT …   Википедия

Compartir el artículo y extractos

Link directo
Do a right-click on the link above
and select “Copy Link”