 
                 Patent Application
 Patent Application
                     20250201015
 20250201015
                    The subject matter described herein relates to systems and methods for automatically digitizing figures and/or images. This technology has particular, but not exclusive, utility for extracting the underlying data from figures and/or images in materials science literature.
There are many scientific and academic publications available online and in print form. However, there is not currently an efficient and accurate method available for compiling a database of such publications that allows access to the full breadth of information contained in the publications. Specifically, many databases available today contain only information extracted from the text portions of the publications, wholly ignoring the image portion of the publications. Thus, many current databases for scientific and academic publications are lacking the often vital information and data that is contained in the image portion of the publications.
The lack of information and data contained in the image portion of publications being integrated into databases is based in part on the fact that there is not currently a method for quickly and efficiently digitizing the images in the publications. Digitization of images consists of recovering the actual data points from which the plot lines or other features of the image were generated. That is, digitization of an image allows for the extraction of the vital information from the image such that it may be analyzed or made searchable in a more usable format than originally presented. Current digitization methods are time-consuming and generally fail to correctly digitize figures present in scientific and academic publications.
One of the biggest issues with current digitization methods is the amount of user input required to complete the digitization process. For example, many of the current digitization methods require that the user input various key points, such as start and end points of a plot or where the x-axis is in the image, as necessary prior knowledge for the method to digitize an image. This presents an issue, as requiring user input is very time-consuming and is inherently inaccurate, as it is difficult for the user to select the key points with a cursor or some other implement with perfect accuracy. Additionally, many of the current digitization methods experience reduced performance based on the presence of noise in the image, such as annotations, vertical lines, and insertions. Further, the current digitization methods are generally trained on synthetically generated training data with fixed axis ranges and predefined image quality standards, which generally result in the methods being unable to extrapolate accurately onto images extracted from publications.
Even those current digitization methods that are able to reasonably accurately digitize an image are only able to do so for very simple images. For example, the current digitization methods are only able to digitize an image with a single two-dimensional plot line or curve. This is a major deficiency in the current methods, as many images in scientific and academic publications are complex and have many plot lines, curves, or other features that represent important information and data.
Even further, in current digitization methods where necessary user input is limited, the system will still make generalized assumptions about the image being processed, such as that the start and end points are within a range of 0 to 1. However, this assumption is does not extrapolate well onto real-world images, where the actual range may vary greatly. As such, these semi-automated digitization methods will generally produce digitized images with values that do not align with the data that was actually used to create the input image, greatly diminishing the utility of the digitized image.
Such shortcomings of the current image digitization methods have resulted in a scarcity of information and data in current databases of scientific and academic publications. This is especially true in the field of materials science, where the lack of a robust and easily searchable database containing both text and image information from scientific and academic publications has hindered researchers for years. Thus, a need exists for an improved method for digitizing images, and more specifically, digitizing images from scientific and academic publications.
The information included in this Background section of the specification, including any references cited herein and any description or discussion thereof, is included for technical reference purposes only and is not to be regarded as limiting.
The present disclosure provides a method and system for digitizing an image, utilizing three integrated modules-a segmentation module, a digitization module, and an indexing module, without requiring any user input for the digitization.
One general aspect of the present invention includes a computer implemented method for digitizing an image. The method includes receiving an input document containing one or more images and extracting the one or more images from the input document. The method also includes digitizing, without user input, the one or more images by a digitization module, where the digitization module generates a final digitization of the one or more images. The method also includes outputting the final digitization of the one or more digitized images.
Implementations may include one or more of the following features. In some embodiments of the method, digitizing the one or more images includes: fragmenting an image into a first section comprised of a set of one or more plot lines and a second section comprised of axis regions, including at least an x-axis and a y-axis; cleaning the image by removing noise from the first section of the image; identifying axis values in the axis regions of the second section of the image; generating a point-pixel coordinate table comprising locations of pixels and a corresponding numeric x-axis value and y-axis value for each pixel of the image; and creating a digitization of the image using the point-pixel coordinate table. In some embodiments, creating a digitization of the image includes: creating a preliminary digitization of the image by preparing the image, identifying the pixels of the image that correspond to the set of one or more plot lines, and using the point-pixel coordinate table, recording a set of y-coordinate values corresponding to each pixel of the set of one or more plot lines for a plurality of sampling points along the x-axis; and creating the final digitization of the image by separating the set of one or more plot lines into individual plot lines, and assigning the identified pixels of the set of one or more plot lines to one of the individual plot lines using a machine learning clustering method. In some embodiments, the method further includes after extracting the one or more images from the input document and prior to digitizing the one or more images by the digitization module, segmenting the one or more images such that one or more images are isolated from the other images. In some embodiments, fragmenting the image includes the use of a contour detection. In some embodiments, cleaning the image includes: removing vertical lines that are not part of the set of one or more plot lines; recovering any plot line information lost during the removal of the vertical lines; eliminating annotations and other text using an optical character recognition engine; detecting connected components left in the image; and removing connected components that are smaller than a standard plot line length for the image. In some embodiments, the machine learning clustering method is a DBSCAN clustering method. In some embodiments, the method further includes: extracting metadata from the input document; and storing, in a database, an original, undigitized version of the one or more images and the metadata extracted from the input document. Implementations of the described techniques may include hardware, a method or process, or computer software on a computer-accessible medium.
A system of one or more computers can be configured to perform particular operations or actions by virtue of having software, firmware, hardware, or a combination of them installed on the system that in operation causes or cause the system to perform the actions. One or more computer programs can be configured to perform particular operations or actions by virtue of including instructions that, when executed by data processing apparatus, cause the apparatus to perform the actions. One general aspect includes a system for digitizing an image. The system includes a processor comprising: a memory; a display; and a user interface configured to receive inputs from a user. The processor is configured to: receive an input document containing one or more images; extract the one or more images from the input document; digitize, without user input, the one or more images by a digitization module, wherein the digitization module generates a final digitization of the one or more images; and output the final digitization of the one or more digitized images. Other embodiments of this aspect include corresponding computer systems, apparatus, and computer programs recorded on one or more computer storage devices, each configured to perform the actions of the methods.
Implementations may include one or more of the following features. In some embodiments, the digitizing the one or more images by the digitization module includes: fragmenting an image into a first section comprised of a set of one or more plot lines and a second section comprised of axis regions, including at least an x-axis and a y-axis; cleaning the image by removing noise from the first section of the image; identifying axis values in the axis regions of the second section of the image; generating a point-pixel coordinate table comprising locations of pixels and a corresponding numeric x-axis value and y-axis value for each pixel of the image; and creating a digitization of the image using the point-pixel coordinate table. In some embodiments, creating a digitization of the image includes: creating a preliminary digitization of the image by preparing the image, identifying the pixels of the image that correspond to the set of one or more plot lines, and using the point-pixel coordinate table, recording a set of y-coordinate values corresponding to each pixel of the set of one or more plot lines for a plurality of sampling points along the x-axis; and creating the final digitization of the image by separating the set of one or more plot lines into individual plot lines, and assigning the identified pixels of the set of one or more plot lines to one of the individual plot lines using a machine learning clustering method. In some embodiments, the processor is further configured to, after extracting the one or more images from the input document and prior to digitizing the one or more images by the digitization module, segment the one or more images such that one or more images are isolated from the other images. In some embodiments, the processor segments the one or more images using an object detection model. In some embodiments, cleaning the image includes: removing vertical lines that are not part of the set of one or more plot lines; recovering any plot line information lost during the removal of the vertical lines; eliminating annotations and other text using an optical character recognition engine; detecting connected components left in the image; and removing connected components that are smaller than a standard plot line length for the image. In some embodiments, the processor is further configured to: extract metadata from the input document; and store, in a database, an original, undigitized version of the one or more images and the metadata extracted from the input document. Implementations of the described techniques may include hardware, a method or process, or computer software on a computer-accessible medium.
Another general aspect of the present invention includes a non-transitory computer readable storage medium storing instructions that, when executed by one or more computer processors, cause the one or more computer processors to perform series of operations. In one embodiment of this aspect, the operations include receiving an input document containing one or more images; extracting the one or more images from the input document; digitizing, without user input, the one or more images by a digitization module, where the digitization module generates a final digitization of the one or more images; and outputting the final digitization of the one or more digitized images.
Implementations may include one or more of the following features. In some embodiments, digitizing the one or more images by the digitization module includes: fragmenting an image into a first section comprised of a set of one or more plot lines and a second section comprised of axis regions, including at least an x-axis and a y-axis; cleaning the image by removing noise from the first section of the image; identifying axis values in the axis regions of the second section of the image; generating a point-pixel coordinate table comprising locations of pixels and a corresponding numeric x-axis value and y-axis value for each pixel of the image; and creating a digitization of the image using the point-pixel coordinate table. In some embodiments, creating the digitization of the image includes: creating a preliminary digitization of the image by preparing the image, identifying the pixels of the image that correspond to the set of one or more plot lines, and using the point-pixel coordinate table, recording a set of y-coordinate values corresponding to each pixel of the set of one or more plot lines for a plurality of sampling points along the x-axis; and creating the final digitization of the image by separating the set of one or more plot lines into individual plot lines, and assigning the identified pixels of the set of one or more plot lines to one of the individual plot lines using a machine learning clustering method. In some embodiments, the instructions stored on the non-transitory computer readable storage medium cause the one or more computer processors to perform operations including: after extracting the one or more images from the input document and prior to digitizing the one or more images by the digitization module, segmenting the one or more images such that one or more images are isolated from the other images. In some embodiments, segmenting the one or more images such that each image is isolated from the other images includes: separating the images into categories using an object detection model, wherein a first category comprises plots and a second category comprises non-plots, wherein a plot is an image containing one or more lines describing a trend or property; identifying a desired type of plot using a convolutional neural net; and isolating each plot of the desired types of plots from the other plots in the first category, such that the only images that are digitized via the digitization module are those images comprising a plot of the desired types. Implementations of the described techniques may include hardware, a method or process, or computer software on a computer-accessible medium.
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to limit the scope of the claimed subject matter. A more extensive presentation of features, details, utilities, and advantages of the fuel queue management system, as defined in the claims, is provided in the following written description of various embodiments of the disclosure and illustrated in the accompanying drawings.
Illustrative embodiments of the present disclosure will be described with reference to the accompanying drawings, of which:
    
    
    
    
    
    
    
    
    
    
    
In accordance with at least one embodiment of the present disclosure, a method is provided for digitizing an image from an input document, without the need for any user input, using integrated modules for the segmentation, digitization, and indexing of the image. The digitized images may be stored in a searchable database, for example a materials database, that makes it easier and more efficient for researchers, scientists, or other individuals to access the full breadth of information available in publications.
The present disclosure aids substantially in the digitization of images from input documents, improving the accuracy and efficiency of the digitization process by, among other things, eliminating the need for any user input beyond the original input document. The method for digitizing an image disclosed herein provides a unique, robust blend of machine learning and image processing to generate digitizations of images from an input document, allowing for the data described by the image to be readily accessible and searchable in a database or other storage medium. This improved method for digitization transforms a process currently based largely on user provided prior knowledge and imperfectly trained models that often are inefficient, prone to being affected by noise, and provide imperfect data when applied to real-life images, into an automated, end-to-end, efficient, and accurate process that reliably digitizes complex images without the need for any user input or intervention. This unconventional approach improves the digitization of images and, relatedly, the availability of easily accessible, robust, and useful data by automating the image digitization process and producing consistently high-quality digitizations.
The image digitization method may be implemented by a system made up of a combination of hardware and/or software modules, and operated by a control process executing on a processor circuit that accepts user inputs from a user. In that regard, the control process performs certain specific operations in response to different inputs made at different times. Certain structures, functions, and operations of the processor circuit, sensors, and user input systems are known in the art, while others are recited herein to enable novel features or aspects of the present disclosure with particularity.
These descriptions are provided for exemplary purposes only and should not be considered to limit the scope of the image digitization method. Certain features and/or operations may be added, removed, or modified without departing from the spirit of the claimed subject matter.
For the purposes of promoting an understanding of the principles of the present disclosure, reference will now be made to the embodiments illustrated in the drawings, and specific language will be used to describe the same. It is nevertheless understood that no limitation to the scope of the disclosure is intended. Any alterations and further modifications to the described devices, systems, and methods, and any further application of the principles of the present disclosure are fully contemplated and included within the present disclosure as would normally occur to one skilled in the art to which the disclosure relates. In particular, it is fully contemplated that the features, components, and/or operations described with respect to one embodiment may be combined with the features, components, and/or steps described with respect to other embodiments of the present disclosure. For the sake of brevity, however, the numerous iterations of these combinations will not be described separately.
  
In block 105, the system receives an input document containing one or more images. In some embodiments, one or more of the images are figures, such as a line graph or another type of plot that displays data trends or properties.
In block 110, the system extracts the one or more images from the input document. In some embodiments, this means that the images contained in the document are isolated from the text portions of the document, such that the one or more images are the only portion of the input document that are further processed in the following method steps.
In block 115, the system digitizes the one or more images by a digitization module, without user input. In some embodiments, digitizing an image refers to the recovery of the actual data points from which an image is generated. Importantly, aside from providing the input document received at block 105, no input or intervention is required from the user at any point during the method 100. This means that, in some embodiments, method 100 is fully end-to-end and automated, such that a user may input a document or multiple documents and receive an output of digitized images without any further action by the user. This feature is distinguished from conventional approaches which require the user to input various key points, such as start and end points of a plot or where the x-axis is in the image, as necessary prior inputs in order for the digitization to occur. This presents an issue, as requiring user input is very time-consuming and is inherently inaccurate, as it is difficult for the user to select the key points with a cursor or some other implement with perfect accuracy. Accordingly, the methods described herein overcome those limitations by providing methods that do not require user input in order to conduct the digitization.
In block 120, the outputs the one or more digitized images. In some embodiments, digitizing an image results in a tabular output containing the data that the input image was generated from. In other embodiments, digitizing an image results in an output that is a digital version of the input image with the underlying data presented in the same format that it was in the input image. The output of one or more digitized images may be displayed to the user in this block, or may be stored in a database, as further described in 
  
In some embodiments, the input document 205 consists of a document with text portions and image portions, for example, a scientific research paper or other academic or industry publication. In other embodiments, the input document 205 is a single image or a group of images with no text portion. In some examples, the image or images of the input document 205 are figures, such as a line graph or another type of plot which displays data trends like Raman Spectra, XRD, or FTIR plots.
In some embodiments, the input document 205 is input into segmentation module 220. In some examples, the input document 205 is processed prior to being input into segmentation module 220, such that the one or more images are extracted from input document 205. In some example embodiments, segmentation module 220 processes the images input into it by isolating individual images from other input images and passing the isolated images to digitization module 230 for further processing. In other example embodiments, segmentation module 220 processes the images input into it by isolating individual images from other input images, identifying images of a desired type, and selectively passing images of the desired type to digitization module 230 for further processing.
In some embodiments, digitization module 230 receives pre-processed images from segmentation module 220. In other embodiments, digitization module 230 receives images from other external sources, which may be pre-processed or not pre-processed, such as a direct input from a user or from a connected database. In some example embodiments, digitization module 230 performs a sequence of processes on the input image, without user input, such that a final digitization of the image is output. In some embodiments, digitization module 230 uses various image cleaning procedures and leverages machine learning to automate the digitization of the image, such that no user input or intervention is required aside from the input of an original input document 205 or other input image.
In some embodiments, indexing module 240 receives a final digitization of one or more images from digitization module 230. In other examples, indexing module 240 receives other input data or images from external sources, such as user input or a connected database. In yet another embodiment, indexing module 240 may receive pre-processed images directly from segmentation module 220, bypassing digitization module 230. In some example embodiments, indexing module 240 creates a database of the digitized images received from the digitization module 230. This database may be searchable. In some examples, the database also contains additional data about the digitized images, such as copies of the original, unprocessed image and metadata extracted from the original input document 205. In instances where additional data about the digitized images is also stored in the database, the digitized images may be indexed to match the additional data corresponding to each digitized image. Indexing the digitized images and the additional data in this way improves the searchability of the information in the database, making it simpler and more efficient for a researcher or other user to access desired data.
  
Image digitization method 300 begins with the system receiving an input document 205. Input document 205 may consist of a document with text portions and image portions, for example, a scientific research paper or other academic or industry publication. In other examples, the input document 205 is a single image or a group of images with no text portion. In some examples, the image or images of the input document 205 are figures, such as a line graph or another type of plot which displays data trends like Raman Spectra, XRD, or FTIR plots.
At block 305, the system extracts images from the input document 205. In some embodiments, this means that the images contained in the input document 205 are isolated from the text portions of the input document 205, such that the one or more images are the only portion of the input document 205 that are further processed in the following method blocks. In other embodiments, the input document 205 is comprised only of images. In such embodiments, this block 305 may be skipped, and the input document 205 fed immediately into segmentation module 220. In other embodiments, the input document 205 is comprised of only text portions. In such embodiments, the input document 205 may forgo processing via the remaining method blocks entirely and may immediately be stored in a database or other storage medium.
In some embodiments, method blocks 220a and 220b are performed as part of segmentation module 220 following the extraction of the images from input document 205 in block 305. First, the images extracted from the image document 205 at block 305 are received by the segmentation module 220. Then, at block 220a, the extracted images are segmented, such that each individual image is isolated from the others.
  
Next, at block 410, one or more types of plots are identified by the system as the types that are desired to be digitized. Reasons that a particular type of plot may be desired include, but are not limited to, the type of data presented in the plots of that type, the industry or field that the data displayed in the images originated, and the industry or field that the user is in. In some embodiments, the desired type of plot is determined and input by a user. In other embodiments, the desired type of plot is automatically identified by an image digitization system, such as image digitization system 200. In some examples, multiple types of plots may be identified as desired. In some example embodiments, the desired type of plot is all plots, such that all images that are plots will be digitized.
Once the one or more type of desired plot is identified, at block 415, the images that are the desired type of plot are isolated from the other images, including the non-plot images and images that are of an undesired plot type. In some embodiments, a Convolutional Neural Net is trained to identify images of the desired type of plot from the other images. In some embodiments, an input image may comprise a panel of individual images or images embedded in other images. In such embodiments, the method may further include cropping the individual images from the panel or cropping individual images embedded in other images. In some examples, the individual images are copped from the panel using predicted bounding boxes generated by an object detection model.
Returning now to 
Once the isolated or segmented images are passed from the segmentation module 220 to the digitization module 230, in some embodiments of the present disclosure, digitzation of the images begins. First, at block 230a, the system fragments an isolated image into multiple sections. In some embodiments, an isolated image/is fragmented into two sections-section P, which comprises the portions of the image the display a trend in or property of data, such as plot lines, without axis regions, and section I-P, which comprises only the axis regions. In some embodiments, the fragmentation of the isolated image is performed using image processing methods of contour detection. Contour detection identifies the biggest contours available in the image (generally the plot line or plot lines), which allows for the plot lines of section P to be separated from the rest of the image. Importantly, none of the techniques of block 230a of the present disclosure require label data or any outside information to be able to identify and separate out the plot lines.
Next, at block 230b, the system removes unwanted noise from the isolated image, such that the only remaining item(s) in section P are the plot lines. The cleaning of the image prior to undergoing the full digitization process ensures a more accurate digitization, unaffected by noise in the image. Common types of noise include annotations, vertical lines, gridlines, and text, such as titles.
  
First, at block 505, the vertical lines that are not part of the plot lines of section P of the isolated image are removed by the system. In some embodiments, the vertical lines are removed using image processing techniques of thresholding, erosion, and dilation. Next, at block 510, any plot line information that was lost during the removal of the vertical lines at block 505 is recovered. Next, at block 515, annotations and other text are removed from section P of the isolated image. In some embodiments, annotations and text are removed from section P of the isolated image using an Optical Character Recognition (OCR) engine, such as a Pytesseract OCR. The OCR engine identifies and removes unwanted characters, such as those in annotations and other text in section P of the isolated image. Generally, this is where current methods of image cleaning will stop. However, the effectiveness of an OCR engine at removing unwanted characters is dependent upon the quality of the image that the OCR engine is processing. The quality of available images is highly variable, especially among open-access research or other scientific and industry literature. As such, blocks 505 through 515 may be sufficient to fully clean a high-quality image but may not result in the removal of all noise from a lower quality image. As such, in some embodiments of the present disclosure, the sub-method 500 further includes block 520 and block 525 to complete the cleaning of the image and remove any noise that is leftover after block 505 through block 515. At block 520, any connected components remaining in the section P of the isolated image are identified using image processing techniques. At block 525, any connected component that is smaller (or shorter) than the plot lines in the section P of the isolated image is removed. The cleaning block 525 results in the removal of any noise that was leftover in section P after block 505 through block 515, producing a fully cleaned image that may be more accurately and efficiently digitized.
Returning now to 
At block 230d, a point-pixel coordinate table is generated for the isolated image. A point-pixel coordinate table is a data structure comprising locations of pixels and a corresponding numeric x-axis and y-axis value for each pixel. In some embodiments, the point-pixel coordinate table contains the locations and corresponding numeric x-axis and y-axis value for every pixel of an image. In other embodiments, the number of sampling points M may be controlled. For example, pixels may only be sampled at M points between the beginning and ending values of the x-axis. Characteristically, the higher the value of M, the more precise the results of the subsequent digitization will be. In some examples, an M value of 1000 is used to optimize accuracy and efficiency.
At block 230e, a preliminary digitization of the isolated image is created. Then, at block 230f, a final digitization of the isolated image is created. The problem of image digitization, particularly for plots, can be formulated as follows. For a general scientific figure (e.g., a plot) described as a 3-channel RGB image I∈[0,255]H×W×3, where H is the height of the image and W is the width of the image, containing K plot lines, the goal of an end-to-end digitization process is to recover:
  
    
  
xki and yki are the x and y coordinates of the ith sample of the kth plot line and Mk is the number of sampled points in the kth plot.
  
At the outset of sub-method 600, the system receives a clean, noise-free, isolated image with information about the location of plots in the image and a point-pixel coordinate with correctly identified axis points. At block 605, the clean image is prepared for digitization. In some embodiments, preparing the clean image for digitization includes enhancing any one or combination of, the sharpness, contrast, and brightness of the clean image. In some embodiments, preparing the clean image includes creating a binary image with plot lines separated from the background of the cleaned image by using any one or combination of, gray scaling, thresholding, and inversion on section P of the cleaned image. In some embodiments of the present disclosure, the resultant binary image is black and white, wherein the plot lines are black, and the background of the image is white.
Next, at block 610, the prepared image is analyzed by the system to identify the pixels of the prepared image that correspond to the plot lines of the prepared image.
Next, at block 615, a set of y-coordinate values that corresponds to each pixel of the plot lines for a plurality of sampling points along the x-axis is recorded. In some embodiments, recording the set of y-coordinates includes using the point-pixel coordinate table to record the pixel y-coordinate locations corresponding to each identified plot line for each sampled x-axis value in M. In some examples, this is achieved via a two-block repetitive process, where an algorithm runs iteratively from left to right along the x-axis and records the corresponding y-coordinate values of pixels identified as being associated with a plot line for each sample point in M along the x-axis. At the completion of block 615, wherein the y-coordinate values that correspond to each pixel of the plot lines for all of the sampling points M along the x-axis are recorded, the result is a preliminary digitization of the prepared image. In some embodiments, the preliminary digitization of the prepared image is a structured data containing a set of digitized points, meaning x and y coordinate values corresponding to the pixels of the identified plot lines in the prepared image. However, it is still not possible to determine K, the number of plot lines, or to subsequently assign the digitized points to the correct plot line. Further, since the availability of large, annotated data is scarce in the applicable domains and synthetic data rarely is able to mimic the actual image quality for digitization results to be useful, the use of supervised learning algorithms to determine K and assign digitized points to the correct plot lines is not feasible.
In some embodiments, to address the issues of identifying the number of plot lines and assigning digitized points to the correct plot line, image digitization method 300 creates a final digitization of the image at block 230f. In some embodiments, after a preliminary digitization of an image is created at block 230c, further processing and digitization of the image is carried out. First, at block 620, the plot lines of the preliminary digitization of the image are separated out into individual plot lines. In some embodiments, the first operation in separating out the plot lines is to recover the color information of the digitized points. Then, in some embodiments, unsupervised machine learning methods of clustering may be applied. Clustering is the process of grouping a set of objects, or in this case digitized points, in such a way that objects in the same group are more similar to each other than to those in other groups. Clustering is an advantageous method, as it provides a two-fold advantage of eliminating noise points and predicting the number of clusters of arbitrary shape to estimate the number of plot lines K′. In some embodiments, the cluster method used is Density Based Spatial Clustering of Applications with Noise (DBSCAN). In some examples, the DBSCAN has a ten-dimensional input, which may be, for example, Red, Green, Blue, Lightness, Green/Magenta Chromatic Axis, Blue/Yellow Chromatic Axis, Luminance, Chroma Red, and Chroma Blue color space transforms of the image, and the set of y-coordinate values corresponding to each pixel of the set of one or more plot lines for every sampling point along the x-axis. Each of these inputs is a different color transform that may be executed on the image prior to processing by the cluster method. The operation of the DBSCAN with respect to the various inputs corresponding to the different color transformations of the image is to pull and compare the color values corresponding to the digitized points for each such color transformation and cluster similar digitized points into one or more clusters, each representing an individual identified plot line. A particular issue may arise when the plot lines of the image intersect with one another or if the color values of a plot line are not consistent along its entire length. To address this issue, in some embodiments, the first operation to separate out the individual plot lines may be to carry out a distance transformation on the image to identify the core portion of the plot line by eliminating noisy boundary points.
The quality of a digitization is highly dependent on the quality of the input image. In some example embodiments of the present disclosure, the image digitization method 300 can identify individual plot lines when the input image has a DPI of 300 or higher and a width greater than 400 pixels. This may be especially beneficial, as many literature depositories from which an input document may be pulled maintain a standard image quality that is at or higher than the quality that may be accurately and efficiently digitized by image digitization method 300.
At block 625, the digitized points are assigned to the correct plot lines of the image. In some embodiments, the output of block 625 is a final digitization of the image that was input into the digitization module 230. In some examples, the final digitization of an image is a tabular version of the image containing information about and data underlying the plot lines therein. In some embodiments, a final digitization will contain all digitized points of an image assigned to one of the plot lines of the image. In some embodiments, the final digitization may also include the original unprocessed input image.
Returning now to 
At block 240b, the digitized image is stored. In some embodiments, the digitized image is stored in a database, cloud storage, or other easy-to-access storage medium. In some embodiments, the database where the digitized image is stored also contains metadata about the input document 205 from which the image originated. In some embodiments, the database where the digitized image is stored also contains a copy of the unprocessed image. In some examples, the digitized images in a database are indexed such that they are matched with the corresponding original unprocessed images and metadata from the input document 205 from which the image originated to make the digited image easily searchable.
Block diagrams are provided herein for exemplary purposes; a person of ordinary skill in the art will recognize myriad variations that nonetheless fall within the scope of the present disclosure. For example, block diagrams may show a particular arrangement of components, modules, services, blocks, processes, or layers, resulting in a particular data flow. It is understood that some embodiments of the systems disclosed herein may include additional components, that some components shown may be absent from some embodiments, and that the arrangement of components may be different than shown, resulting in different data flows while still performing the methods described herein.
Flow diagrams are provided herein for exemplary purposes; a person of ordinary skill in the art will recognize myriad variations that nonetheless fall within the scope of the present disclosure. For example, the logic of flow diagrams may be shown as sequential. However, similar logic could be parallel, massively parallel, object oriented, real-time, event-driven, cellular automaton, or otherwise, while accomplishing the same or similar functions. In order to perform the methods described herein, a processor may divide each of the blocks described herein into a plurality of machine instructions and may execute these instructions at the rate of several hundred, several thousand, several million, or several billion per second, in a single processor or across a plurality of processors. Such rapid execution may be necessary in order to execute the method in the highly efficient manner described herein.
  
  
  
  
  
Here it should be noted that in 
  
The illustrative system 1100 includes a microprocessor 1100a, an input device 1100b, a storage device 1100c, a video surface control system 1100d, a system memory 1100c, a display 1100f, and a communication device 1100g all interconnected by one or more buses 1100h. In several example embodiments, the storage device 1100c may include a floppy drive, hard drive, CD-ROM, optical drive, any other form of storage device and/or any combination thereof. In several example embodiments, the storage device 1100c may include, and/or be capable of receiving, a floppy disk, CD-ROM, DVD-ROM, or any other form of computer-readable medium that may contain executable instructions. In several example embodiments, the communication device 1100g may include a modem, network card, or any other device to enable the system to communicate with other systems. In several example embodiments, any system represents a plurality of interconnected (whether by intranet or Internet) computer systems, including without limitation, personal computers, mainframes, PDAs, smartphones, and cell phones.
In several example embodiments, one or more of the components of the systems described above and/or illustrated in 
In several example embodiments, one or more of the applications, systems, and application programs described above and/or illustrated in 
In several example embodiments, a computer system typically includes at least hardware capable of executing machine readable instructions, as well as the software for executing acts (typically machine-readable instructions) that produce a desired result. In several example embodiments, a computer system may include hybrids of hardware and software, as well as computer sub-systems.
In several example embodiments, hardware generally includes at least processor-capable platforms, such as client-machines (also known as personal computers or servers), and hand-held processing devices (such as smart phones, tablet computers, personal digital assistants (PDAs), or personal computing devices (PCDs), for example). In several example embodiments, hardware may include any physical device that is capable of storing machine-readable instructions, such as memory or other data storage devices. In several example embodiments, other forms of hardware include hardware sub-systems, including transfer devices such as modems, modem cards, ports, and port cards, for example.
In several example embodiments, software includes any machine code stored in any memory medium, such as RAM or ROM, and machine code stored on other devices (such as floppy disks, flash memory, or a CD ROM, for example). In several example embodiments, software may include source or object code. In several example embodiments, software encompasses any set of instructions capable of being executed on a system such as, for example, on a client machine or server.
In several example embodiments, combinations of software and hardware could also be used for providing enhanced functionality and performance for certain embodiments of the present disclosure. In an example embodiment, software functions may be directly manufactured into a silicon chip. Accordingly, it should be understood that combinations of hardware and software are also included within the definition of a computer system and are thus envisioned by the present disclosure as possible equivalent structures and equivalent methods.
In several example embodiments, computer readable mediums include, for example, passive data storage, such as a random-access memory (RAM) as well as semi-permanent data storage such as a compact disk read only memory (CD-ROM). One or more example embodiments of the present disclosure may be embodied in the RAM of a computer to transform a standard computer into a new specific computing machine. In several example embodiments, data structures are defined organizations of data that may enable an embodiment of the present disclosure. In an example embodiment, a data structure may provide an organization of data, or an organization of executable code.
In several example embodiments, any networks and/or one or more portions thereof may be designed to work on any specific architecture. In an example embodiment, one or more portions of any networks may be executed on a single computer, local area networks, client-server networks, wide area networks, internets, hand-held and other portable and wireless devices, and networks.
In several example embodiments, a database may be any standard or proprietary database software. In several example embodiments, the database may have fields, records, data, and other database elements that may be associated through database specific software. In several example embodiments, data may be mapped. In several example embodiments, mapping is the process of associating one data entry with another data entry. In an example embodiment, the data contained in the location of a character file can be mapped to a field in a second table. In several example embodiments, the physical location of the database is not limiting, and the database may be distributed. In an example embodiment, the database may exist remotely from the server, and run on a separate platform. In an example embodiment, the database may be accessible across the Internet. In several example embodiments, more than one database may be implemented.
In several example embodiments, a plurality of instructions stored on a non-transitory computer readable medium may be executed by one or more processors to cause the one or more processors to carry out or implement in whole or in part the above-described operation of each of the above-described example embodiments of the system, the method, and/or any combination thereof. In several example embodiments, such a processor may include one or more of the microprocessor 1100a, any processor(s) that are part of the components of the system, and/or any combination thereof, and such a computer readable medium may be distributed among one or more components of the system. In several example embodiments, such a processor may execute the plurality of instructions in connection with a virtual computer system. In several example embodiments, such a plurality of instructions may communicate directly with the one or more processors, and/or may interact with one or more operating systems, middleware, firmware, other applications, and/or any combination thereof, to cause the one or more processors to execute the instructions.
In several example embodiments, the elements and teachings of the various illustrative example embodiments may be combined in whole or in part in some or all of the illustrative example embodiments. In addition, one or more of the elements and teachings of the various illustrative example embodiments may be omitted, at least in part, and/or combined, at least in part, with one or more of the other elements and teachings of the various illustrative embodiments.
The logical operations making up the embodiments of the technology described herein are referred to variously as operations, blocks, objects, elements, components, layers, or modules. It should be understood that these may occur or be performed or arranged in any order, unless explicitly claimed otherwise or a specific order is inherently necessitated by the claim language. All directional references e.g., upper, lower, inner, outer, upward, downward, left, right, lateral, front, back, top, bottom, above, below, vertical, horizontal, clockwise, counterclockwise, proximal, and distal are only used for identification purposes to aid the reader's understanding of the claimed subject matter, and do not create limitations, particularly as to the position, orientation, or use of the fuel queue management system or its components. Connection references, e.g., attached, coupled, connected, and joined are to be construed broadly and may include intermediate members between a collection of elements and relative movement between elements unless otherwise indicated. As such, connection references do not necessarily imply that two elements are directly connected and in fixed relation to each other. The term “or” shall be interpreted to mean “and/or” rather than “exclusive or.” Unless otherwise noted in the claims, stated values shall be interpreted as illustrative only and shall not be taken to be limiting.
The above specification, examples and data provide an enabling description of the structure and use of exemplary embodiments of the fuel queue management system as defined in the claims. Although various embodiments of the claimed subject matter have been described above with a certain degree of particularity, or with reference to one or more individual embodiments, those skilled in the art would understand that numerous alterations to the disclosed embodiments are contemplated without departing from the spirit or scope of the claimed subject matter.
The Abstract at the end of this disclosure is provided to comply with 37 C.F.R. § 1.72 (b) to allow the reader to quickly ascertain the nature of the technical disclosure. It is submitted with the understanding that it will not be used to interpret or limit the scope or meaning of the claims.
Methods within the scope of the present disclosure may be local or remote in nature. These methods, and any controllers discussed herein, may be achieved by one or more intelligent adaptive controllers, programmable logic controllers, artificial neural networks, and/or other adaptive and/or “learning” controllers or processing apparatus. For example, such methods may be deployed or performed via PLC, PAC, PC, one or more servers, desktops, handhelds, and/or any other form or type of computing device with appropriate capability.
Still other embodiments are contemplated. It is intended that all matter contained in the above description and shown in the accompanying drawings shall be interpreted as illustrative only of particular embodiments and not limiting. Changes in detail or structure may be made without departing from the basic elements of the subject matter as defined in the following claims.