Difference between revisions of "User:Level zero/proposal"

From BRL-CAD
(BRL-CAD’s IPT(s) Information and Current Status)
(June 17 - Sep 2 suffling of components of Development Phase)
 
(20 intermediate revisions by 3 users not shown)
Line 11: Line 11:
 
|'''Phone Number'''||+91 9783582684
 
|'''Phone Number'''||+91 9783582684
 
|-
 
|-
|'''Mailing Address'''|| E#221 Ram Path, Shyam Nagar, Jaipur – 302019.(IN)  
+
|'''Mailing Address'''|| E#221 Ram Path, Shyam Nagar, Jaipur – 302019.(IN)  
 
|-
 
|-
 
|'''Time Zone'''||UTC +0530
 
|'''Time Zone'''||UTC +0530
 
|}
 
|}
  
 +
==Brief Background==
 +
I am an Undergraduate Student in Computer and Communication Engineering. Currently in my pre-final year, I have done diverse range of projects varying from Computer Systems, graphics, Image Processing and Learning.
  
===Link to Resumé===
 
 
===Brief Background===
 
I am an Undergraduate Student in Computer and Communication Engineering. Currently in my pre-final year, I have done diverse range of projects varying from Computer Systems, graphics, Image Processing and Learning. (details are in my Resume)
 
 
 
 
=Project Information=
 
=Project Information=
 
==Project Title==
 
==Project Title==
Consolidating and Adding the Image Processing tools to LIBICV
+
Consolidating and Adding the Image Processing Functions to LIBICV
 
==Brief summary of Project==
 
==Brief summary of Project==
BRL-CAD has a number of image processing tools. Currently all the tools are implemented in a modular fashion where in each tool is accessed as a module. The primitive task of this project is to combine the image processing tools to a library and advanced element of this project is to add additional relevant functions from CxImage library to the BRL-CAD’s image processing library (LIBICV).  
+
BRL-CAD has a number of image processing tools. Currently all the tools are implemented in a modular fashion where in each tool is accessed as a module. The primitive task of this project is to combine the image processing functionalities of these tools to a library. This task will ensure the re-usability of these functionalities by the application programmer through relevant API calls in the code and thus will be useful for building a proper GUI for BRL-CAD and helpful in other new tools/functions to be added to BRL-CAD in future.  
This task will ensure the reusability of these tools by the application programmer through relevant api calls in the code and thus will be useful for building a proper GUI for BRL-CAD and helpful in other new tools/functions to be added to BRL-CAD in future.  
 
 
 
I have identified the following list of the various tools (current '''IPTs''') which can be integrated with the CxImage
 
 
 
 
==Project Description (Detailed)==
 
==Project Description (Detailed)==
 
===Introduction===
 
===Introduction===
*This project aims at consolidating the Image Processing Tool (IPT) (around 100 in number) under a library (already initiated as LIBICV in BRL-CAD).  
+
*This project aims at consolidating the functionalities of the Image Processing Tool (IPT) (around 100 in number) under a library (already initiated as LIBICV in BRL-CAD).  
*Additionally this project will integrate features from the CxImage library to the current tools to enhance there usability.
+
*Additionally this project will emphasize its focus on the usability of the image processing functions.
  
 
===BRL-CAD’s IPT(s) Information and Current Status===
 
===BRL-CAD’s IPT(s) Information and Current Status===
BRL-CAD’s IPT(s) are extensively written for various Image Processing task. Apart from the other formats, it has support for the BRL-CAD pioneered '''.pix''' format and the unix plots. Thus BRL-CAD cannot use any other third party library for Image Processing without altering them. Therefore work is underway in strengthening and Consolidating BRL-CAD’s image Processing Library.  
+
Currently these tools are implemented as standalone applications where in each tool is a separate program and separate executable are compiled through these programs. To run any tool, currently we pass command line arguments to the executable file (separate for each tool) and the return arguments are received on standard output buffers or it could be done by saving the output at
 +
BRL-CAD’s IPT(s) are extensively written for various Image Processing task. Apart from the other formats, it has support for the BRL-CAD pioneered '''.pix''' format and the UNIX plots. Thus BRL-CAD cannot use any other third party library for Image Processing without altering them. Therefore work is underway in strengthening and Consolidating BRL-CAD’s image Processing Library and adding various Image Processing functionalities in it.  
  
Currently these tools are implemented as standalone applications where in each tool is a separate program and separate executable are compiled through these programs. To run any tool, currently we pass command line arguments to the executable file (separate for each tool) and the return arguments are received on standard output buffers or it could be done by saving the output at some location.
+
===Consolidating IPT(s) under LIBICV===
 +
This is the primary task of this project wherein the image processing functionalities of the current tools are to be arranged and consolidated to a  
 +
library lib_icv. It is possible to create our own library of function by writing the functions as subroutines and compiling them to link to a shared library.  
  
===Consolidating IPT(s) under LIBICV===
+
Any API caller just needs to include the said library and thus has access to the implemented functions of image processing.
This is the primary task of this project wherein the current tools are to be arranged and consolidated to a library lib_icv. It is possible to create our own library of function by writing the current function as subroutines. Any api caller just needs to include the said library and thus has access to the current modules which will be declared as functions in that library.  
+
 
 +
Among the current tools, image processing functions and there common groups will be identified which could enhance the usability of the tools. Proper Documentation will be done as discussed in later sections.
 +
 
 +
===Formats of Image to be supported===
 +
The current status of icv.h defines .PIX,.BW,.ALIAS,.BMP,.CI,.ORLE,.PNG,.PPM,.PS,.RLE,.SPM,.SUN,.YUV and looking at the conversion tools among the IPTs in
 +
src/util folder these seem to be the only relevant formats for BRLCAD. Very few formats among them are currently implemented for loading and saving of the
 +
images. This project will create functions for loading and saving of all these formats.
  
Libraries consist of a set of related functions to perform a common task.  In our case we have set of tools (in src/util) which are compiled separately. We can write these tools in modules (each containing one or more current tools) and compile (into objects) them individually to link that to a shared library. This could be done very easily using the make in unix which helps resolving dependencies and compile modules and link them to shared library.  
+
===Categories of Image Processing Functions===
 +
On analyzing the current status of the IPTs they involve usage of the following categories of image processing functionalities.
  
Among the current tools groups will be identified which could enhance the usability of the tools. Proper Documentation will be done as discussed in later sections.
+
*Crop or Rect
 +
*Differences and other arithmetic operations
 +
*Filters,
 +
*Histograms and Equalizations
 +
*Rotate
 +
*Scale or Shrink
 +
*Stats
 +
*Thresh
 +
*Interpolate
 +
*Dimensions and Image Information
 +
*Background
 +
*Borders
 +
*Fading
 +
*Merge or Split
 +
*Saturation
 +
*Morphing
  
===Addition of library function from CxImage===
+
In this project, I propose to add these functionalities in the ICV library. Further analysis will be done to identify other functionality (enough time is given for this in schedule). During the initial working stage details of these functions will be worked on, to identify the input and output arguments, usability and different methods to be incorporated in the functions.
==Introduction about CxImage==
 
[http://www.xdp.it/cximage.htm CxImage] is a C++ image processing library that can load, save, display, transform images in a very simple and fast way. CxImage is open source and licensed under the zlib license.  
 
  
This library implements various image processing algorithms which are not the part of the current utilities. As per the current digging of the source code of the utilities, I propose to integrate functions from this library to the current BRL-CAD IPTs (as per the attached index) This will give added functionalities with more parameter.  
+
===Implementation===
 +
The current tools present in the /src/util include usage of most of the above mentioned functionalities and the image format. The implementation
 +
task will include extracting these functionalities, finding common attributes to arrange them in common groups, improve usability and add multiple available methods.
  
For ''eg.'' the '''pixinterp2x''' reads and interpolates a .pix file tp double its resolution. After the project this will be integrated to the '''interpolation module''' of the '''CxImage library'''. This will make sure that the user can interpolate to arbitrary resolution using various methods thus it will enhance the usability of this interpolation function for BrlCad.
+
===Use of image containers and structures===
 +
The current structure for used in the icv library, for image details is as follows:
 +
    struct icv_image_file {
 +
    uint32_t magic;
 +
    char *filename;
 +
    int fd;
 +
    int format; /* ICV_IMAGE_* */
 +
    int width, height, depth; /* pixel, pixel, byte */
 +
    unsigned char *data;
 +
    unsigned long flags;
 +
    };
  
==Using the CxImage Library Function==
+
Like any other image processing library there will be a need of containers to keep the points, arrays etc. No, judgment is made at this stage about these
 +
structures. In the working schedule special time is devoted for this purpose. On discussion with the mentors and other developers decision will be taken
 +
about deciding the image container and other structures needed for this library.
  
To make this library useful with the current libICV, I propose to write a bridge functions to convert between the two formats (icv_image_file struct ⇔  CxImage class). These functions may look like the following
+
==Sample Codes and Tools==
icv_image_file* cvt_CxImage2icv(CxImage )
+
*Code Patch (A code containing functions to load .png, .bw and .pix files). https://sourceforge.net/p/brlcad/patches/176/
CxImage* cvt_icv2CxImage(icv_image_file* )
+
*Tools of Image Processing in /src/util.
 +
*gprof for Performance Analysis
 +
===After Application Deadline===
 +
Added a more robust patch which uses functions to implemneted load functions and thus converts to files from one format to other.
 +
====Details of Patch====
 +
https://sourceforge.net/p/brlcad/patches/178/
  
 
==Documentation==
 
==Documentation==
*Currently brlcad has man pages for all the tools in the utilities. I propose to change these man pages with the manuals of the functions implemented. This can be done with the sync of converting each function to the library function.
+
For any library the documentation defines the way it will be used by the users and other hackers. As per the current practice, Doxygen Markups will be added to the files in the library. This will include the input, output arguments. Details of the various methods in the functions. In detail documentation about method could also be done on BRLCAD wiki.
*Besides this since this will turn out to be a library which could be used as a third party library by users belonging to other fraternity therefore, I propose to create a complete documentation of all the functions parameters they take
+
 
 +
==Deliverables==
 +
A robust image processing library.
 +
 
 +
==Working Schedule==
 +
===upto June 17 (Analysis and Design Period)===
 +
*Exploring the code.
 +
*Make a short rough bio about each tool - ''the way they work''.
 +
*Find the Image Processing  functionalities used in them. Look at duplication in the functionalities.
 +
:(5-10 tools/day depending on varied length.
 +
*Preparation of rough ideas of each functionalities and the way they will be implemented with additional improvements in usability.
 +
*Discuss with mentor and other developers about the final plan for the design of the library. This includes :
 +
**the possible formats to be supported (In addition to the already started in include/icv.h)
 +
**Addition of Different functionalities and there usability improvements.
 +
**Discussion about common groups identified for different functionalities.
 +
*Learning usage from BRLCAD libraries like common.h libbu libbio
 +
 +
At the end of this period : '''A finalized plan to proceed for the development of the library'''.
 +
 
 +
===June 17 - Sep 2  (Development Phase)===
 +
====June 17 - July 1 [~2 Week] ====
 +
*Implementation of various Structures of the new library
 +
*Deciding about the functions to be included in different files based on categories.
 +
*Deciding the input parameters and return type of each function.
 +
*Identify error handling in each Function.
 +
*Witting Documentation of all the structures included. PDF+Wiki
 +
*Creating Patches all together.
 +
====July 1 - Aug 19 [~7 Week]====
 +
*Implementation of image processing functionalities focusing on categories identified during project analysis period.
 +
*Enough Time is allotted to this to follow up the implementation as decided during analysis step.
 +
*Implementation of 3-4 functions a week which includes unit-level testing and code coverage.
 +
*Documentation of the functions including input output arguments/methods etc.
 +
 
 +
To implement the image processing functionalities common groups have been identified details of which are given at http://brlcad.org/wiki/User:Level_zero/GSOC13/ImplemnetationDetails-1 .Further these groups have varied implementation load, Thus to balance the load for a particular following weekly plan has been chalked in.
 +
=====Sub Division=====
 +
*WEEK-1 
 +
**Crop or Rect (GROUP#1)
 +
**Differences and other arithmetic operations (GROUP#2)             
 +
*WEEK-2 
 +
**Filters, (GROUP#3) 
 +
*WEEK-3 
 +
**Histograms and Equalizations (GROUP#4)
 +
**Stats (GROUP#6)
 +
*WEEK-4 
 +
**Scale or Shrink (GROUP#5)
 +
**Interpolate/Decimate (GROUP#8)
 +
*WEEK-5 
 +
**Thresh (GROUP#7)
 +
**Background and Border (GROUP#9)
 +
*WEEK-6 
 +
**Merge or Split (GROUP#10)
 +
*WEEK-7 
 +
**Morphing and other Misc (GROUP#11)
 +
====Aug 19 - Sept 2 [~2 Week]====
 +
*Implimentation of Import/Export Modules.
 +
*Testing these Modules.
 +
*Documentation of these modules
 +
 
 +
===Sep 2 - Sep 27 (Final Wrap UP and Cleaning)===
 +
====Sep 2 - Sep 9 [~1 Week]====
 +
*Code Cleaning
 +
*System Level testing for the library.
 +
*Giving final structure to the documentation.
 +
====Sep9 - Sep16 [~1 Week]====
 +
*Creating Demos For each functionality and Final cleaning
 +
====Sep 16 - Sep 27 [~1 Week]====
 +
*Performance Analysis using gprof for different data.
 +
*Final code submission with Google.
 +
==Time Availability==
 +
*During summer holidays I am completely free. I like working infront of screens and reading all types of books.
 +
*I can devote 40-50 hrs/week .
 +
*Besides this I may have to take a weeks off for a meditation seminar and the dates are still not known. Even if this happens I have ability to work for late hours to complete work at hand.
  
===Why BRL-CAD?===
+
==Why BRL-CAD?==
 
In my final year at the university, I am due to work on my Under Graduate thesis. As per my background, my university has assigned me a faculty dealing in graphics and Image Processing.  
 
In my final year at the university, I am due to work on my Under Graduate thesis. As per my background, my university has assigned me a faculty dealing in graphics and Image Processing.  
This motivates me to utilise my summer holidays working with BRLCAD due to their large codebase dealing with Image Processing and Graphics and thus becoming a regular contributor with it in my final year which would help me to complete my thesis.  
+
This motivates me to utilize my summer holidays working with BRLCAD due to their large code base dealing with Image Processing and Graphics and thus becoming a regular contributor with it in my final year which would help me to complete my thesis.  
===Why you?===
+
==Why you?==
 
I am good in c, c++. I will not say that I possess excellent coding skills. But I have enough to work on this project. Besides this I am dedicated and have an inquisitiveness to learn new things.
 
I am good in c, c++. I will not say that I possess excellent coding skills. But I have enough to work on this project. Besides this I am dedicated and have an inquisitiveness to learn new things.
Anything else?
 

Latest revision as of 16:08, 7 June 2013

Personnel Information[edit]

Name Mohit Daga
Email Address mohit.daga@ieee.org
IRC(nick) zero_level
Phone Number +91 9783582684
Mailing Address E#221 Ram Path, Shyam Nagar, Jaipur – 302019.(IN)
Time Zone UTC +0530

Brief Background[edit]

I am an Undergraduate Student in Computer and Communication Engineering. Currently in my pre-final year, I have done diverse range of projects varying from Computer Systems, graphics, Image Processing and Learning.

Project Information[edit]

Project Title[edit]

Consolidating and Adding the Image Processing Functions to LIBICV

Brief summary of Project[edit]

BRL-CAD has a number of image processing tools. Currently all the tools are implemented in a modular fashion where in each tool is accessed as a module. The primitive task of this project is to combine the image processing functionalities of these tools to a library. This task will ensure the re-usability of these functionalities by the application programmer through relevant API calls in the code and thus will be useful for building a proper GUI for BRL-CAD and helpful in other new tools/functions to be added to BRL-CAD in future.

Project Description (Detailed)[edit]

Introduction[edit]

  • This project aims at consolidating the functionalities of the Image Processing Tool (IPT) (around 100 in number) under a library (already initiated as LIBICV in BRL-CAD).
  • Additionally this project will emphasize its focus on the usability of the image processing functions.

BRL-CAD’s IPT(s) Information and Current Status[edit]

Currently these tools are implemented as standalone applications where in each tool is a separate program and separate executable are compiled through these programs. To run any tool, currently we pass command line arguments to the executable file (separate for each tool) and the return arguments are received on standard output buffers or it could be done by saving the output at BRL-CAD’s IPT(s) are extensively written for various Image Processing task. Apart from the other formats, it has support for the BRL-CAD pioneered .pix format and the UNIX plots. Thus BRL-CAD cannot use any other third party library for Image Processing without altering them. Therefore work is underway in strengthening and Consolidating BRL-CAD’s image Processing Library and adding various Image Processing functionalities in it.

Consolidating IPT(s) under LIBICV[edit]

This is the primary task of this project wherein the image processing functionalities of the current tools are to be arranged and consolidated to a library lib_icv. It is possible to create our own library of function by writing the functions as subroutines and compiling them to link to a shared library.

Any API caller just needs to include the said library and thus has access to the implemented functions of image processing.

Among the current tools, image processing functions and there common groups will be identified which could enhance the usability of the tools. Proper Documentation will be done as discussed in later sections.

Formats of Image to be supported[edit]

The current status of icv.h defines .PIX,.BW,.ALIAS,.BMP,.CI,.ORLE,.PNG,.PPM,.PS,.RLE,.SPM,.SUN,.YUV and looking at the conversion tools among the IPTs in src/util folder these seem to be the only relevant formats for BRLCAD. Very few formats among them are currently implemented for loading and saving of the images. This project will create functions for loading and saving of all these formats.

Categories of Image Processing Functions[edit]

On analyzing the current status of the IPTs they involve usage of the following categories of image processing functionalities.

  • Crop or Rect
  • Differences and other arithmetic operations
  • Filters,
  • Histograms and Equalizations
  • Rotate
  • Scale or Shrink
  • Stats
  • Thresh
  • Interpolate
  • Dimensions and Image Information
  • Background
  • Borders
  • Fading
  • Merge or Split
  • Saturation
  • Morphing

In this project, I propose to add these functionalities in the ICV library. Further analysis will be done to identify other functionality (enough time is given for this in schedule). During the initial working stage details of these functions will be worked on, to identify the input and output arguments, usability and different methods to be incorporated in the functions.

Implementation[edit]

The current tools present in the /src/util include usage of most of the above mentioned functionalities and the image format. The implementation task will include extracting these functionalities, finding common attributes to arrange them in common groups, improve usability and add multiple available methods.

Use of image containers and structures[edit]

The current structure for used in the icv library, for image details is as follows:

   struct icv_image_file {
   uint32_t magic;
   char *filename;
   int fd;
   int format;			/* ICV_IMAGE_* */
   int width, height, depth;	/* pixel, pixel, byte */
   unsigned char *data;
   unsigned long flags; 
   };

Like any other image processing library there will be a need of containers to keep the points, arrays etc. No, judgment is made at this stage about these structures. In the working schedule special time is devoted for this purpose. On discussion with the mentors and other developers decision will be taken about deciding the image container and other structures needed for this library.

Sample Codes and Tools[edit]

After Application Deadline[edit]

Added a more robust patch which uses functions to implemneted load functions and thus converts to files from one format to other.

Details of Patch[edit]

https://sourceforge.net/p/brlcad/patches/178/

Documentation[edit]

For any library the documentation defines the way it will be used by the users and other hackers. As per the current practice, Doxygen Markups will be added to the files in the library. This will include the input, output arguments. Details of the various methods in the functions. In detail documentation about method could also be done on BRLCAD wiki.

Deliverables[edit]

A robust image processing library.

Working Schedule[edit]

upto June 17 (Analysis and Design Period)[edit]

  • Exploring the code.
  • Make a short rough bio about each tool - the way they work.
  • Find the Image Processing functionalities used in them. Look at duplication in the functionalities.
(5-10 tools/day depending on varied length.
  • Preparation of rough ideas of each functionalities and the way they will be implemented with additional improvements in usability.
  • Discuss with mentor and other developers about the final plan for the design of the library. This includes :
    • the possible formats to be supported (In addition to the already started in include/icv.h)
    • Addition of Different functionalities and there usability improvements.
    • Discussion about common groups identified for different functionalities.
  • Learning usage from BRLCAD libraries like common.h libbu libbio

At the end of this period : A finalized plan to proceed for the development of the library.

June 17 - Sep 2 (Development Phase)[edit]

June 17 - July 1 [~2 Week][edit]

  • Implementation of various Structures of the new library
  • Deciding about the functions to be included in different files based on categories.
  • Deciding the input parameters and return type of each function.
  • Identify error handling in each Function.
  • Witting Documentation of all the structures included. PDF+Wiki
  • Creating Patches all together.

July 1 - Aug 19 [~7 Week][edit]

  • Implementation of image processing functionalities focusing on categories identified during project analysis period.
  • Enough Time is allotted to this to follow up the implementation as decided during analysis step.
  • Implementation of 3-4 functions a week which includes unit-level testing and code coverage.
  • Documentation of the functions including input output arguments/methods etc.

To implement the image processing functionalities common groups have been identified details of which are given at http://brlcad.org/wiki/User:Level_zero/GSOC13/ImplemnetationDetails-1 .Further these groups have varied implementation load, Thus to balance the load for a particular following weekly plan has been chalked in.

Sub Division[edit]
  • WEEK-1
    • Crop or Rect (GROUP#1)
    • Differences and other arithmetic operations (GROUP#2)
  • WEEK-2
    • Filters, (GROUP#3)
  • WEEK-3
    • Histograms and Equalizations (GROUP#4)
    • Stats (GROUP#6)
  • WEEK-4
    • Scale or Shrink (GROUP#5)
    • Interpolate/Decimate (GROUP#8)
  • WEEK-5
    • Thresh (GROUP#7)
    • Background and Border (GROUP#9)
  • WEEK-6
    • Merge or Split (GROUP#10)
  • WEEK-7
    • Morphing and other Misc (GROUP#11)

Aug 19 - Sept 2 [~2 Week][edit]

  • Implimentation of Import/Export Modules.
  • Testing these Modules.
  • Documentation of these modules

Sep 2 - Sep 27 (Final Wrap UP and Cleaning)[edit]

Sep 2 - Sep 9 [~1 Week][edit]

  • Code Cleaning
  • System Level testing for the library.
  • Giving final structure to the documentation.

Sep9 - Sep16 [~1 Week][edit]

  • Creating Demos For each functionality and Final cleaning

Sep 16 - Sep 27 [~1 Week][edit]

  • Performance Analysis using gprof for different data.
  • Final code submission with Google.

Time Availability[edit]

  • During summer holidays I am completely free. I like working infront of screens and reading all types of books.
  • I can devote 40-50 hrs/week .
  • Besides this I may have to take a weeks off for a meditation seminar and the dates are still not known. Even if this happens I have ability to work for late hours to complete work at hand.

Why BRL-CAD?[edit]

In my final year at the university, I am due to work on my Under Graduate thesis. As per my background, my university has assigned me a faculty dealing in graphics and Image Processing. This motivates me to utilize my summer holidays working with BRLCAD due to their large code base dealing with Image Processing and Graphics and thus becoming a regular contributor with it in my final year which would help me to complete my thesis.

Why you?[edit]

I am good in c, c++. I will not say that I possess excellent coding skills. But I have enough to work on this project. Besides this I am dedicated and have an inquisitiveness to learn new things.