US20190012334A1 - Architecture for Responding to Visual Query - Google Patents
Architecture for Responding to Visual Query Download PDFInfo
- Publication number
- US20190012334A1 US20190012334A1 US16/131,004 US201816131004A US2019012334A1 US 20190012334 A1 US20190012334 A1 US 20190012334A1 US 201816131004 A US201816131004 A US 201816131004A US 2019012334 A1 US2019012334 A1 US 2019012334A1
- Authority
- US
- United States
- Prior art keywords
- search
- image
- results
- visual query
- query
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Abandoned
Links
Images
Classifications
-
- G06F17/30277—
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/50—Information retrieval; Database structures therefor; File system structures therefor of still image data
- G06F16/53—Querying
- G06F16/532—Query formulation, e.g. graphical querying
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/24—Querying
- G06F16/245—Query processing
- G06F16/2457—Query processing with adaptation to user needs
- G06F16/24578—Query processing with adaptation to user needs using ranking
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/24—Querying
- G06F16/248—Presentation of query results
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/50—Information retrieval; Database structures therefor; File system structures therefor of still image data
- G06F16/58—Retrieval characterised by using metadata, e.g. metadata not derived from the content or metadata generated manually
- G06F16/583—Retrieval characterised by using metadata, e.g. metadata not derived from the content or metadata generated manually using metadata automatically derived from the content
- G06F16/5838—Retrieval characterised by using metadata, e.g. metadata not derived from the content or metadata generated manually using metadata automatically derived from the content using colour
-
- G06F17/30256—
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06V—IMAGE OR VIDEO RECOGNITION OR UNDERSTANDING
- G06V40/00—Recognition of biometric, human-related or animal-related patterns in image or video data
- G06V40/10—Human or animal bodies, e.g. vehicle occupants or pedestrians; Body parts, e.g. hands
- G06V40/16—Human faces, e.g. facial parts, sketches or expressions
- G06V40/172—Classification, e.g. identification
Definitions
- Provisional Patent Application No. 61/266,133 filed Dec. 2, 2009, entitled “Actionable Search Results for Street View Visual Queries,” and U.S. Provisional Patent Application No. 61/266,499, filed Dec. 3, 2009, entitled “Hybrid Use Location Sensor Data and Visual Query to Return Local Listing for Visual Query.”
- the disclosed embodiments relate generally to a server system architecture encompassing a plurality of parallel search systems for processing a visual query.
- a text-based or term-based searching wherein a user inputs a word or phrase into a search engine and receives a variety of results is a useful tool for searching.
- term based queries require that a user be able to input a relevant term.
- a user may wish to know information about an image. For example, a user might want to know the name of a person in a photograph, or a user might want to know the name of a flower or bird in a picture. Accordingly, a system that can receive a visual query and provide search results would be desirable.
- a visual query is received from a client system.
- the visual query is processed by sending the visual query to a plurality of parallel search systems for simultaneous processing.
- Each of the plurality of search systems implements a distinct visual query search process of a plurality of visual query search processes.
- the plurality of visual query search processes includes at least: optical character recognition (OCR), facial recognition, and a first query-by-image process other than OCR and facial recognition.
- OCR optical character recognition
- a plurality of search results is received from one or more of the plurality of parallel search systems. At least one of the plurality of search results is sent to the client system.
- the method further includes, when at least two of the received search results meet predefined criteria, ranking the received search results that meet the predefined criteria, and sending at least one search result of the ranked search results to the client system.
- the first query-by-image process is product recognition, bar code recognition, object-or-object-category recognition, named entity recognition, or color recognition.
- the visual query is a photograph, a screen shot, a scanned image, or a video frame.
- the client system can be a mobile device, a desktop device, or other device.
- the visual query is received from a client application executed by the client system, such a search application, a search engine plug-in for a browser application, or a search engine extension for a browser application.
- the visual query is received from a content authoring application executed by the client system.
- the search result includes an optical character recognition result for the text element and at least one image-match result for the non-text element.
- the search result when the visual query is an image containing a text element and a non-text element, the search result includes an interactive results document comprising a first visual identifier for the text element with a link to a search result produced by an optical character recognition process, and a second visual identifier for the non-text element with a link to a search result produced by an image-match process.
- the method further includes combining at least two of the plurality of search results into a compound search result.
- a search engine system for processing a visual query.
- the system includes one or more central processing units for executing programs and memory storing one or more programs to be executed by the one or more central processing units.
- the one or more programs include instructions for performing the following.
- a visual query is received from a client system.
- the visual query is processed by sending the visual query to a plurality of parallel search systems for simultaneous processing.
- Each of the plurality of search systems implements a distinct visual query search process of a plurality of visual query search processes.
- the plurality of visual query search processes includes at least: optical character recognition (OCR), facial recognition, and a first query-by-image process other than OCR and facial recognition.
- OCR optical character recognition
- a plurality of search results is received from one or more of the plurality of parallel search systems. At least one of the plurality of search results is sent to the client system.
- Such a system may also include program instructions to execute the additional options discussed above.
- a computer readable storage medium system for processing a visual query.
- the computer readable storage medium stores one or more programs configured for execution by a computer, the one or more programs comprising instructions for performing the following.
- a visual query is received from a client system.
- the visual query is processed by sending the visual query to a plurality of parallel search systems for simultaneous processing.
- Each of the plurality of search systems implements a distinct visual query search process of a plurality of visual query search processes.
- the plurality of visual query search processes includes at least: optical character recognition (OCR), facial recognition, and a first query-by-image process other than OCR and facial recognition.
- OCR optical character recognition
- a plurality of search results is received from one or more of the plurality of parallel search systems. At least one of the plurality of search results is sent to the client system.
- Such a computer readable storage medium may also include program instructions to execute the additional options discussed above.
- FIG. 1 is a block diagram illustrating a computer network that includes a visual query server system.
- FIG. 2 is a flow diagram illustrating the process for responding to a visual query, in accordance with some embodiments.
- FIG. 3 is a flow diagram illustrating the process for responding to a visual query with an interactive results document, in accordance with some embodiments.
- FIG. 4 is a flow diagram illustrating the communications between a client and a visual query server system, in accordance with some embodiments.
- FIG. 5 is a block diagram illustrating a client system, in accordance with some embodiments.
- FIG. 6 is a block diagram illustrating a front end visual query processing server system, in accordance with some embodiments.
- FIG. 7 is a block diagram illustrating a generic one of the parallel search systems utilized to process a visual query, in accordance with some embodiments.
- FIG. 8 is a block diagram illustrating an OCR search system utilized to process a visual query, in accordance with some embodiments.
- FIG. 9 is a block diagram illustrating a facial recognition search system utilized to process a visual query, in accordance with some embodiments.
- FIG. 10 is a block diagram illustrating an image to terms search system utilized to process a visual query, in accordance with some embodiments.
- FIG. 11 illustrates a client system with a screen shot of an exemplary visual query, in accordance with some embodiments.
- FIGS. 12A and 12B each illustrate a client system with a screen shot of an interactive results document with bounding boxes, in accordance with some embodiments.
- FIG. 13 illustrates a client system with a screen shot of an interactive results document that is coded by type, in accordance with some embodiments.
- FIG. 14 illustrates a client system with a screen shot of an interactive results document with labels, in accordance with some embodiments.
- FIG. 15 illustrates a screen shot of an interactive results document and visual query displayed concurrently with a results list, in accordance with some embodiments.
- first, second, etc. may be used herein to describe various elements, these elements should not be limited by these terms. These terms are only used to distinguish one element from another.
- a first contact could be termed a second contact, and, similarly, a second contact could be termed a first contact, without departing from the scope of the present invention.
- the first contact and the second contact are both contacts, but they are not the same contact.
- the term “if” may be construed to mean “when” or “upon” or “in response to determining” or “in response to detecting,” depending on the context.
- the phrase “if it is determined” or “if is detected” may be construed to mean “upon determining” or “in response to determining” or “upon detecting (the stated condition or event)” or “in response to detecting (the stated condition or event),” depending on the context.
- FIG. 1 is a block diagram illustrating a computer network that includes a visual query server system according to some embodiments.
- the computer network 100 includes one or more client systems 102 and a visual query server system 106 .
- One or more communications networks 104 interconnect these components.
- the communications network 104 may be any of a variety of networks, including local area networks (LAN), wide area networks (WAN), wireless networks, wireline networks, the Internet, or a combination of such networks.
- the client system 102 includes a client application 108 , which is executed by the client system, for receiving a visual query (e.g., visual query 1102 of FIG. 11 ).
- a visual query is an image that is submitted as a query to a search engine or search system. Examples of visual queries, without limitations include photographs, scanned documents and images, and drawings.
- the client application 108 is selected from the set consisting of a search application, a search engine plug-in for a browser application, and a search engine extension for a browser application.
- the client application 108 is an “omnivorous” search box, which allows a user to drag and drop any format of image into the search box to be used as the visual query.
- a client system 102 sends queries to and receives data from the visual query server system 106 .
- the client system 102 may be any computer or other device that is capable of communicating with the visual query server system 106 . Examples include, without limitation, desktop and notebook computers, mainframe computers, server computers, mobile devices such as mobile phones and personal digital assistants, network terminals, and set-top boxes.
- the visual query server system 106 includes a front end visual query processing server 110 .
- the front end server 110 receives a visual query from the client 102 , and sends the visual query to a plurality of parallel search systems 112 for simultaneous processing.
- the search systems 112 each implement a distinct visual query search process and access their corresponding databases 114 as necessary to process the visual query by their distinct search process.
- a face recognition search system 112 -A will access a facial image database 114 -A to look for facial matches to the image query.
- the facial recognition search system 112 -A will return one or more search results (e.g., names, matching faces, etc.) from the facial image database 114 -A.
- the optical character recognition (OCR) search system 112 -B converts any recognizable text in the visual query into text for return as one or more search results.
- OCR optical character recognition
- an OCR database 114 -B may be accessed to recognize particular fonts or text patterns as explained in more detail with regard to FIG. 8 .
- Any number of parallel search systems 112 may be used. Some examples include a facial recognition search system 112 -A, an OCR search system 112 -B, an image-to-terms search system 112 -C (which may recognize an object or an object category), a product recognition search system (which may be configured to recognize 2-D images such as book covers and CDs and may also be configured to recognized 3-D images such as furniture), bar code recognition search system (which recognizes 1D and 2D style bar codes), a named entity recognition search system, landmark recognition (which may configured to recognize particular famous landmarks like the Eiffel Tower and may also be configured to recognize a corpus of specific images such as billboards), place recognition aided by geo-location information provided by a GPS receiver in the client system 102 or mobile phone network, a color recognition search system, and a similar image search system (which searches for and identifies images similar to a visual query).
- a facial recognition search system 112 -A an OCR search system 112 -B, an image-to-terms search system 11
- Further search systems can be added as additional parallel search systems, represented in FIG. 1 by system 112 -N. All of the search systems, except the OCR search system, are collectively defined herein as search systems performing an image-match process. All of the search systems including the OCR search system are collectively referred to as query-by-image search systems.
- the visual query server system 106 includes a facial recognition search system 112 -A, an OCR search system 112 -B, and at least one other query-by-image search system 112 .
- the parallel search systems 112 each individually process the visual search query and return their results to the front end server system 110 .
- the front end server 100 may perform one or more analyses on the search results such as one or more of: aggregating the results into a compound document, choosing a subset of results to display, and ranking the results as will be explained in more detail with regard to FIG. 6 .
- the front end server 110 communicates the search results to the client system 102 .
- the client system 102 presents the one or more search results to the user.
- the results may be presented on a display, by an audio speaker, or any other means used to communicate information to a user.
- the user may interact with the search results in a variety of ways.
- the user's selections, annotations, and other interactions with the search results are transmitted to the visual query server system 106 and recorded along with the visual query in a query and annotation database 116 .
- Information in the query and annotation database can be used to improve visual query results.
- the information from the query and annotation database 116 is periodically pushed to the parallel search systems 112 , which incorporate any relevant portions of the information into their respective individual databases 114 .
- the computer network 100 optionally includes a term query server system 118 , for performing searches in response to term queries.
- a term query is a query containing one or more terms, as opposed to a visual query which contains an image.
- the term query server system 118 may be used to generate search results that supplement information produced by the various search engines in the visual query server system 106 .
- the results returned from the term query server system 118 may include any format.
- the term query server system 118 may include textual documents, images, video, etc. While term query server system 118 is shown as a separate system in FIG. 1 , optionally the visual query server system 106 may include a term query server system 118 .
- FIG. 2 is a flow diagram illustrating a visual query server system method for responding to a visual query, according to certain embodiments of the invention.
- Each of the operations shown in FIG. 2 may correspond to instructions stored in a computer memory or computer readable storage medium.
- the visual query server system receives a visual query from a client system ( 202 ).
- the client system for example, may be a desktop computing device, a mobile device, or another similar device ( 204 ) as explained with reference to FIG. 1 .
- An example visual query on an example client system is shown in FIG. 11 .
- the visual query is an image document of any suitable format.
- the visual query can be a photograph, a screen shot, a scanned image, or a frame or a sequence of multiple frames of a video ( 206 ).
- the visual query is a drawing produced by a content authoring program ( 736 , FIG. 5 ).
- the user “draws” the visual query, while in other embodiments the user scans or photographs the visual query.
- Some visual queries are created using an image generation application such as Acrobat, a photograph editing program, a drawing program, or an image editing program.
- a visual query could come from a user taking a photograph of his friend on his mobile phone and then submitting the photograph as the visual query to the server system.
- the visual query could also come from a user scanning a page of a magazine, or taking a screen shot of a webpage on a desktop computer and then submitting the scan or screen shot as the visual query to the server system.
- the visual query is submitted to the server system 106 through a search engine extension of a browser application, through a plug-in for a browser application, or by a search application executed by the client system 102 .
- Visual queries may also be submitted by other application programs (executed by a client system) that support or generate images which can be transmitted to a remotely located server by the client system.
- the visual query can be a combination of text and non-text elements ( 208 ).
- a query could be a scan of a magazine page containing images and text, such as a person standing next to a road sign.
- a visual query can include an image of a person's face, whether taken by a camera embedded in the client system or a document scanned by or otherwise received by the client system.
- a visual query can also be a scan of a document containing only text.
- the visual query can also be an image of numerous distinct subjects, such as several birds in a forest, a person and an object (e.g., car, park bench, etc.), a person and an animal (e.g., pet, farm animal, butterfly, etc.).
- Visual queries may have two or more distinct elements.
- a visual query could include a barcode and an image of a product or product name on a product package.
- the visual query could be a picture of a book cover that includes the title of the book, cover art, and a bar code.
- one visual query will produce two or more distinct search results corresponding to different portions of the visual query, as discussed in more detail below.
- the server system processes the visual query as follows.
- the front end server system sends the visual query to a plurality of parallel search systems for simultaneous processing ( 210 ).
- Each search system implements a distinct visual query search process, i.e., an individual search system processes the visual query by its own processing scheme.
- one of the search systems to which the visual query is sent for processing is an optical character recognition (OCR) search system.
- OCR optical character recognition
- one of the search systems to which the visual query is sent for processing is a facial recognition search system.
- the plurality of search systems running distinct visual query search processes includes at least: optical character recognition (OCR), facial recognition, and another query-by-image process other than OCR and facial recognition ( 212 ).
- the other query-by-image process is selected from a set of processes that includes but is not limited to product recognition, bar code recognition, object-or-object-category recognition, named entity recognition, and color recognition ( 212 ).
- named entity recognition occurs as a post process of the OCR search system, wherein the text result of the OCR is analyzed for famous people, locations, objects and the like, and then the terms identified as being named entities are searched in the term query server system ( 118 , FIG. 1 ).
- images of famous landmarks, logos, people, album covers, trademarks, etc. are recognized by an image-to-terms search system.
- a distinct named entity query-by-image process separate from the image-to-terms search system is utilized.
- the object-or-object category recognition system recognizes generic result types like “car.” In some embodiments, this system also recognizes product brands, particular product models, and the like, and provides more specific descriptions, like “Porsche.” Some of the search systems could be special user specific search systems. For example, particular versions of color recognition and facial recognition could be a special search systems used by the blind.
- the front end server system receives results from the parallel search systems ( 214 ).
- the results are accompanied by a search score.
- some of the search systems will find no relevant results. For example, if the visual query was a picture of a flower, the facial recognition search system and the bar code search system will not find any relevant results.
- a null or zero search score is received from that search system ( 216 ).
- the front end server if it does not receive a result from a search system after a pre-defined period of time (e.g., 0.2, 0.5, 1, 2 or 5 seconds), it will process the received results as if that timed out server produced a null search score and will process the received results from the other search systems.
- a pre-defined period of time e.g., 0.2, 0.5, 1, 2 or 5 seconds
- one of the predefined criteria excludes void results.
- a pre-defined criterion is that the results are not void.
- one of the predefined criteria excludes results having numerical score (e.g., for a relevance factor) that falls below a pre-defined minimum score.
- the plurality of search results are filtered ( 220 ).
- the results are only filtered if the total number of results exceeds a pre-defined threshold.
- all the results are ranked but the results falling below a pre-defined minimum score are excluded.
- the content of the results are filtered. For example, if some of the results contain private information or personal protected information, these results are filtered out.
- the visual query server system creates a compound search result ( 222 ).
- a compound search result ( 222 )
- the term query server system ( 118 , FIG. 1 ) may augment the results from one of the parallel search systems with results from a term search, where the additional results are either links to documents or information sources, or text and/or images containing additional information that may be relevant to the visual query.
- the compound search result may contain an OCR result and a link to a named entity in the OCR document ( 224 ).
- the OCR search system ( 112 -B, FIG. 1 ) or the front end visual query processing server ( 110 , FIG. 1 ) recognizes likely relevant words in the text. For example, it may recognize named entities such as famous people or places. The named entities are submitted as query terms to the term query server system ( 118 , FIG. 1 ). In some embodiments, the term query results produced by the term query server system are embedded in the visual query result as a “link.” In some embodiments, the term query results are returned as separate links. For example, if a picture of a book cover were the visual query, it is likely that an object recognition search system will produce a high scoring hit for the book.
- the term query results are presented in a labeled group to distinguish them from the visual query results.
- the results may be searched individually, or a search may be performed using all the recognized named entities in the search query to produce particularly relevant additional search results.
- the visual query is a scanned travel brochure about Paris
- the returned result may include links to the term query server system 118 for initiating a search on a term query “Notre Dame.”
- compound search results include results from text searches for recognized famous images.
- the visual query server system then sends at least one result to the client system ( 226 ).
- the visual query processing server receives a plurality of search results from at least some of the plurality of search systems, it will then send at least one of the plurality of search results to the client system.
- only one search system will return relevant results.
- the OCR server's results may be relevant.
- only one result from one search system may be relevant.
- only the product related to a scanned bar code may be relevant. In these instances, the front end visual processing server will return only the relevant search result(s).
- a plurality of search results are sent to the client system, and the plurality of search results include search results from more than one of the parallel search systems ( 228 ). This may occur when more than one distinct image is in the visual query. For example, if the visual query were a picture of a person riding a horse, results for facial recognition of the person could be displayed along with object identification results for the horse. In some embodiments, all the results for a particular query by image search system are grouped and presented together. For example, the top N facial recognition results are displayed under a heading “facial recognition results” and the top N object recognition results are displayed together under a heading “object recognition results.” Alternatively, as discussed below, the search results from a particular image search system may be grouped by image region.
- the search results may include both OCR results and one or more image-match results ( 230 ).
- the user may wish to learn more about a particular search result. For example, if the visual query was a picture of a dolphin and the “image to terms” search system returns the following terms “water,” “dolphin,” “blue,” and “Flipper;” the user may wish to run a text based query term search on “Flipper.”
- the query term server system 118 , FIG. 1
- the search on the selected term(s) is run.
- the corresponding search term results are displayed on the client system either separately or in conjunction with the visual query results ( 232 ).
- the front end visual query processing server ( 110 , FIG. 1 ) automatically (i.e., without receiving any user command, other than the initial visual query) chooses one or more top potential text results for the visual query, runs those text results on the term query server system 118 , and then returns those term query results along with the visual query result to the client system as a part of sending at least one search result to the client system ( 232 ).
- the front end server runs a term query on “Flipper” and returns those term query results along with the visual query results to the client system.
- results are displayed as a compound search result ( 222 ) as explained above.
- the results are part of a search result list instead of or in addition to a compound search result.
- FIG. 3 is a flow diagram illustrating the process for responding to a visual query with an interactive results document.
- the first three operations ( 202 , 210 , 214 ) are described above with reference to FIG. 2 .
- an interactive results document is created ( 302 ).
- the interactive results document includes one or more visual identifiers of respective sub-portions of the visual query.
- Each visual identifier has at least one user selectable link to at least one of the search results.
- a visual identifier identifies a respective sub-portion of the visual query.
- the interactive results document has only one visual identifier with one user selectable link to one or more results.
- a respective user selectable link to one or more of the search results has an activation region, and the activation region corresponds to the sub-portion of the visual query that is associated with a corresponding visual identifier.
- the visual identifier is a bounding box ( 304 ).
- the bounding box encloses a sub-portion of the visual query as shown in FIG. 12A .
- the bounding box need not be a square or rectangular box shape but can be any sort of shape including circular, oval, conformal (e.g., to an object in, entity in or region of the visual query), irregular or any other shape as shown in FIG. 12B .
- the bounding box outlines the boundary of an identifiable entity in a sub-portion of the visual query ( 306 ).
- each bounding box includes a user selectable link to one or more search results, where the user selectable link has an activation region corresponding to a sub-portion of the visual query surrounded by the bounding box.
- search results that correspond to the image in the outlined sub-portion are returned.
- the visual identifier is a label ( 307 ) as shown in FIG. 14 .
- label includes at least one term associated with the image in the respective sub-portion of the visual query.
- Each label is formatted for presentation in the interactive results document on or near the respective sub-portion.
- the labels are color coded.
- each respective visual identifiers is formatted for presentation in a visually distinctive manner in accordance with a type of recognized entity in the respective sub-portion of the visual query. For example, as shown in FIG. 13 , bounding boxes around a product, a person, a trademark, and the two textual areas are each presented with distinct cross-hatching patterns, representing differently colored transparent bounding boxes.
- the visual identifiers are formatted for presentation in visually distinctive manners such as overlay color, overlay pattern, label background color, label background pattern, label font color, and border color.
- the user selectable link in the interactive results document is a link to a document or object that contains one or more results related to the corresponding sub-portion of the visual query ( 308 ).
- at least one search result includes data related to the corresponding sub-portion of the visual query.
- the interactive results document may include a bounding box around only the bar code.
- the bar code search result is displayed.
- the bar code search result may include one result, the name of the product corresponding to that bar code, or the bar code results may include several results such as a variety of places in which that product can be purchased, reviewed, etc.
- the search results corresponding to the respective visual identifier include results from a term query search on at least one of the terms in the text.
- the search results corresponding to the respective visual identifier include one or more of: name, handle, contact information, account information, address information, current location of a related mobile device associated with the person whose face is contained in the selectable sub-portion, other images of the person whose face is contained in the selectable sub-portion, and potential image matches for the person's face.
- the search results corresponding to the respective visual identifier include one or more of: product information, a product review, an option to initiate purchase of the product, an option to initiate a bid on the product, a list of similar products, and a list of related products.
- a respective user selectable link in the interactive results document includes anchor text, which is displayed in the document without having to activate the link.
- the anchor text provides information, such as a key word or term, related to the information obtained when the link is activated.
- Anchor text may be displayed as part of the label ( 307 ), or in a portion of a bounding box ( 304 ), or as additional information displayed when a user hovers a cursor over a user selectable link for a pre-determined period of time such as 1 second.
- a respective user selectable link in the interactive results document is a link to a search engine for searching for information or documents corresponding to a text-based query (sometimes herein called a term query).
- Activation of the link causes execution of the search by the search engine, where the query and the search engine are specified by the link (e.g., the search engine is specified by a URL in the link and the text-based search query is specified by a URL parameter of the link), with results returned to the client system.
- the link in this example may include anchor text specifying the text or terms in the search query.
- the interactive results document produced in response to a visual query can include a plurality of links that correspond to results from the same search system.
- a visual query may be an image or picture of a group of people.
- the interactive results document may include bounding boxes around each person, which when activated returns results from the facial recognition search system for each face in the group.
- a plurality of links in the interactive results document corresponds to search results from more than one search system ( 310 ). For example, if a picture of a person and a dog was submitted as the visual query, bounding boxes in the interactive results document may outline the person and the dog separately.
- the interactive results document contains an OCR result and an image match result ( 312 ).
- the interactive results document may include visual identifiers for the person and for the text in the sign.
- the interactive results document may include visual identifiers for photographs or trademarks in advertisements on the page as well as a visual identifier for the text of an article also on that page.
- the interactive results document After the interactive results document has been created, it is sent to the client system ( 314 ).
- the interactive results document (e.g., document 1200 , FIG. 15 ) is sent in conjunction with a list of search results from one or more parallel search systems, as discussed above with reference to FIG. 2 .
- the interactive results document is displayed at the client system above or otherwise adjacent to a list of search results from one or more parallel search systems ( 315 ) as shown in FIG. 15 .
- the user will interact with the results document by selecting a visual identifier in the results document.
- the server system receives from the client system information regarding the user selection of a visual identifier in the interactive results document ( 316 ).
- the link is activated by selecting an activation region inside a bounding box.
- the link is activated by a user selection of a visual identifier of a sub-portion of the visual query, which is not a bounding box.
- the linked visual identifier is a hot button, a label located near the sub-portion, an underlined word in text, or other representation of an object or subject in the visual query.
- the search results list is presented with the interactive results document ( 315 )
- the search result in the search results list corresponding to the selected link is identified.
- the cursor will jump or automatically move to the first result corresponding to the selected link.
- selecting a link in the interactive results document causes the search results list to scroll or jump so as to display at least a first result corresponding to the selected link.
- the results list is reordered such that the first result corresponding to the link is displayed at the top of the results list.
- the visual query server system when the user selects the user selectable link ( 316 ) the visual query server system sends at least a subset of the results, related to a corresponding sub-portion of the visual query, to the client for display to the user ( 318 ).
- the user can select multiple visual identifiers concurrently and will receive a subset of results for all of the selected visual identifiers at the same time.
- search results corresponding to the user selectable links are preloaded onto the client prior to user selection of any of the user selectable links so as to provide search results to the user virtually instantaneously in response to user selection of one or more links in the interactive results document.
- FIG. 4 is a flow diagram illustrating the communications between a client and a visual query server system.
- the client 102 receives a visual query from a user/querier ( 402 ).
- visual queries can only be accepted from users who have signed up for or “opted in” to the visual query system.
- searches for facial recognition matches are only performed for users who have signed up for the facial recognition visual query system, while other types of visual queries are performed for anyone regardless of whether they have “opted in” to the facial recognition portion.
- the format of the visual query can take many forms.
- the visual query will likely contain one or more subjects located in sub-portions of the visual query document.
- the client system 102 performs type recognition pre-processing on the visual query ( 404 ).
- the client system 102 searches for particular recognizable patterns in this pre-processing system. For example, for some visual queries the client may recognize colors.
- the client may recognize that a particular sub-portion is likely to contain text (because that area is made up of small dark characters surrounded by light space etc.)
- the client may contain any number of pre-processing type recognizers, or type recognition modules.
- the client will have a type recognition module (barcode recognition 406 ) for recognizing bar codes. It may do so by recognizing the distinctive striped pattern in a rectangular area.
- the client will have a type recognition module (face detection 408 ) for recognizing that a particular subject or sub-portion of the visual query is likely to contain a face.
- the recognized “type” is returned to the user for verification.
- the client system 102 may return a message stating “a bar code has been found in your visual query, are you interested in receiving bar code query results?”
- the message may even indicate the sub-portion of the visual query where the type has been found.
- this presentation is similar to the interactive results document discussed with reference to FIG. 3 . For example, it may outline a sub-portion of the visual query and indicate that the sub-portion is likely to contain a face, and ask the user if they are interested in receiving facial recognition results.
- the client 102 After the client 102 performs the optional pre-processing of the visual query, the client sends the visual query to the visual query server system 106 , specifically to the front end visual query processing server 110 .
- the client if pre-processing produced relevant results, i.e., if one of the type recognition modules produced results above a certain threshold, indicating that the query or a sub-portion of the query is likely to be of a particular type (face, text, barcode etc.), the client will pass along information regarding the results of the pre-processing. For example, the client may indicate that the face recognition module is 75% sure that a particular sub-portion of the visual query contains a face.
- the pre-processing results include one or more subject type values (e.g., bar code, face, text, etc.).
- the pre-processing results sent to the visual query server system include one or more of: for each subject type value in the pre-processing results, information identifying a sub-portion of the visual query corresponding to the subject type value, and for each subject type value in the pre-processing results, a confidence value indicating a level of confidence in the subject type value and/or the identification of a corresponding sub-portion of the visual query.
- the front end server 110 receives the visual query from the client system ( 202 ).
- the visual query received may contain the pre-processing information discussed above.
- the front end server sends the visual query to a plurality of parallel search systems ( 210 ). If the front end server 110 received pre-processing information regarding the likelihood that a sub-portion contained a subject of a certain type, the front end server may pass this information along to one or more of the parallel search systems. For example, it may pass on the information that a particular sub-portion is likely to be a face so that the facial recognition search system 112 -A can process that subsection of the visual query first.
- sending the same information may be used by the other parallel search systems to ignore that sub-portion or analyze other sub-portions first.
- the front end server will not pass on the pre-processing information to the parallel search systems, but will instead use this information to augment the way in which it processes the results received from the parallel search systems.
- the front end server 110 receives a plurality of search results from the parallel search systems ( 214 ). The front end server may then perform a variety of ranking and filtering, and may create an interactive search result document as explained with reference to FIGS. 2 and 3 . If the front end server 110 received pre-processing information regarding the likelihood that a sub-portion contained a subject of a certain type, it may filter and order by giving preference to those results that match the pre-processed recognized subject type. If the user indicated that a particular type of result was requested, the front end server will take the user's requests into account when processing the results.
- the front end server may filter out all other results if the user only requested bar code information, or the front end server will list all results pertaining to the requested type prior to listing the other results. If an interactive visual query document is returned, the server may pre-search the links associated with the type of result the user indicated interest in, while only providing links for performing related searches for the other subjects indicated in the interactive results document. Then the front end server 110 sends the search results to the client system ( 226 ).
- the client 102 receives the results from the server system ( 412 ). When applicable, these results will include the results that match the type of result found in the pre-processing stage. For example, in some embodiments they will include one or more bar code results ( 414 ) or one or more facial recognition results ( 416 ). If the client's pre-processing modules had indicated that a particular type of result was likely, and that result was found, the found results of that type will be listed prominently.
- the user will select or annotate one or more of the results ( 418 ).
- the user may select one search result, may select a particular type of search result, and/or may select a portion of an interactive results document ( 420 ).
- Selection of a result is implicit feedback that the returned result was relevant to the query. Such feedback information can be utilized in future query processing operations.
- An annotation provides explicit feedback about the returned result that can also be utilized in future query processing operations.
- Annotations take the form of corrections of portions of the returned result (like a correction to a mis-OCRed word) or a separate annotation (either free form or structured.)
- the user's selection of one search result is a process that is referred to as a selection among interpretations.
- the user's selection of a particular type of search result generally selecting the result “type” of interest from several different types of returned results (e.g., choosing the OCRed text of an article in a magazine rather than the visual results for the advertisements also on the same page), is a process that is referred to as disambiguation of intent.
- a user may similarly select particular linked words (such as recognized named entities) in an OCRed document as explained in detail with reference to FIG. 8 .
- the user may alternatively or additionally wish to annotate particular search results.
- This annotation may be done in freeform style or in a structured format ( 422 ).
- the annotations may be descriptions of the result or may be reviews of the result. For example, they may indicate the name of subject(s) in the result, or they could indicate “this is a good book” or “this product broke within a year of purchase.”
- Another example of an annotation is a user-drawn bounding box around a sub-portion of the visual query and user-provided text identifying the object or subject inside the bounding box. User annotations are explained in more detail with reference to FIG. 5 .
- the user selections of search results and other annotations are sent to the server system ( 424 ).
- the front end server 110 receives the selections and annotations and further processes them ( 426 ). If the information was a selection of an object, sub-region or term in an interactive results document, further information regarding that selection may be requested, as appropriate. For example, if the selection was of one visual result, more information about that visual result would be requested. If the selection was a word (either from the OCR server or from the Image-to-Terms server) a textual search of that word would be sent to the term query server system 118 . If the selection was of a person from a facial image recognition search system, that person's profile would be requested. If the selection was for a particular portion of an interactive search result document, the underlying visual query results would be requested.
- the server system receives an annotation, the annotation is stored in a query and annotation database 116 , explained with reference to FIG. 5 . Then the information from the annotation database 116 is periodically copied to individual annotation databases for one or more of the parallel server systems, as discussed below with reference to FIGS. 7-10 .
- FIG. 5 is a block diagram illustrating a client system 102 in accordance with one embodiment of the present invention.
- the client system 102 typically includes one or more processing units (CPU's) 702 , one or more network or other communications interfaces 704 , memory 712 , and one or more communication buses 714 for interconnecting these components.
- the client system 102 includes a user interface 705 .
- the user interface 705 includes a display device 706 and optionally includes an input means such as a keyboard, mouse, or other input buttons 708 .
- the display device 706 includes a touch sensitive surface 709 , in which case the display 706 / 709 is a touch sensitive display.
- a physical keyboard is optional (e.g., a soft keyboard may be displayed when keyboard entry is needed).
- some client systems use a microphone and voice recognition to supplement or replace the keyboard.
- the client 102 includes a GPS (global positioning satellite) receiver, or other location detection apparatus 707 for determining the location of the client system 102 .
- visual query search services are provided that require the client system 102 to provide the visual query server system to receive location information indicating the location of the client system 102 .
- the client system 102 also includes an image capture device 710 such as a camera or scanner.
- Memory 712 includes high-speed random access memory, such as DRAM, SRAM, DDR RAM or other random access solid state memory devices; and may include non-volatile memory, such as one or more magnetic disk storage devices, optical disk storage devices, flash memory devices, or other non-volatile solid state storage devices.
- Memory 712 may optionally include one or more storage devices remotely located from the CPU(s) 702 .
- Memory 712 or alternately the non-volatile memory device(s) within memory 712 , comprises a non-transitory computer readable storage medium.
- memory 712 or the computer readable storage medium of memory 712 stores the following programs, modules and data structures, or a subset thereof:
- the image region selection module 734 which allows a user to select a particular sub-portion of an image for annotation, also allows the user to choose a search result as a “correct” hit without necessarily further annotating it.
- the user may be presented with a top N number of facial recognition matches and may choose the correct person from that results list.
- more than one type of result will be presented, and the user will choose a type of result.
- the image query may include a person standing next to a tree, but only the results regarding the person is of interest to the user. Therefore, the image selection module 734 allows the user to indicate which type of image is the “correct” type—i.e., the type he is interested in receiving.
- the user may also wish to annotate the search result by adding personal comments or descriptive words using either the annotation text entry module 730 (for filling in a form) or freeform annotation text entry module 732 .
- the optional local image analysis module 738 is a portion of the client application ( 108 , FIG. 1 ). Furthermore, in some embodiments the optional local image analysis module 738 includes one or more programs to perform local image analysis to pre-process or categorize the visual query or a portion thereof. For example, the client application 722 may recognize that the image contains a bar code, a face, or text, prior to submitting the visual query to a search engine. In some embodiments, when the local image analysis module 738 detects that the visual query contains a particular type of image, the module asks the user if they are interested in a corresponding type of search result.
- the local image analysis module 738 may detect a face based on its general characteristics (i.e., without determining which person's face) and provides immediate feedback to the user prior to sending the query on to the visual query server system. It may return a result like, “A face has been detected, are you interested in getting facial recognition matches for this face?” This may save time for the visual query server system ( 106 , FIG. 1 ). For some visual queries, the front end visual query processing server ( 110 , FIG. 1 ) only sends the visual query to the search system 112 corresponding to the type of image recognized by the local image analysis module 738 .
- the visual query to the search system 112 may send the visual query to all of the search systems 112 A-N, but will rank results from the search system 112 corresponding to the type of image recognized by the local image analysis module 738 .
- the manner in which local image analysis impacts on operation of the visual query server system depends on the configuration of the client system, or configuration or processing parameters associated with either the user or the client system.
- the actual content of any particular visual query and the results produced by the local image analysis may cause different visual queries to be handled differently at either or both the client system and the visual query server system.
- bar code recognition is performed in two steps, with analysis of whether the visual query includes a bar code performed on the client system at the local image analysis module 738 . Then the visual query is passed to a bar code search system only if the client determines the visual query is likely to include a bar code. In other embodiments, the bar code search system processes every visual query.
- the client system 102 includes additional client applications 740 .
- FIG. 6 is a block diagram illustrating a front end visual query processing server system 110 in accordance with one embodiment of the present invention.
- the front end server 110 typically includes one or more processing units (CPU's) 802 , one or more network or other communications interfaces 804 , memory 812 , and one or more communication buses 814 for interconnecting these components.
- Memory 812 includes high-speed random access memory, such as DRAM, SRAM, DDR RAM or other random access solid state memory devices; and may include non-volatile memory, such as one or more magnetic disk storage devices, optical disk storage devices, flash memory devices, or other non-volatile solid state storage devices.
- Memory 812 may optionally include one or more storage devices remotely located from the CPU(s) 802 .
- Memory 812 or alternately the non-volatile memory device(s) within memory 812 , comprises a non-transitory computer readable storage medium.
- memory 812 or the computer readable storage medium of memory 812 stores the following programs, modules and data structures, or a subset thereof:
- the results ranking and formatting module 824 ranks the results returned from the one or more parallel search systems ( 112 -A- 112 -N, FIG. 1 ). As already noted above, for some visual queries, only the results from one search system may be relevant. In such an instance, only the relevant search results from that one search system are ranked. For some visual queries, several types of search results may be relevant. In these instances, in some embodiments, the results ranking and formatting module 824 ranks all of the results from the search system having the most relevant result (e.g., the result with the highest relevance score) above the results for the less relevant search systems. In other embodiments, the results ranking and formatting module 824 ranks a top result from each relevant search system above the remaining results.
- the results ranking and formatting module 824 ranks the results in accordance with a relevance score computed for each of the search results.
- augmented textual queries are performed in addition to the searching on parallel visual search systems.
- textual queries are also performed, their results are presented in a manner visually distinctive from the visual search system results.
- the results ranking and formatting module 824 also formats the results.
- the results are presented in a list format.
- the results are presented by means of an interactive results document.
- both an interactive results document and a list of results are presented.
- the type of query dictates how the results are presented. For example, if more than one searchable subject is detected in the visual query, then an interactive results document is produced, while if only one searchable subject is detected the results will be displayed in list format only.
- the results document creation module 826 is used to create an interactive search results document.
- the interactive search results document may have one or more detected and searched subjects.
- the bounding box creation module 828 creates a bounding box around one or more of the searched subjects.
- the bounding boxes may be rectangular boxes, or may outline the shape(s) of the subject(s).
- the link creation module 830 creates links to search results associated with their respective subject in the interactive search results document. In some embodiments, clicking within the bounding box area activates the corresponding link inserted by the link creation module.
- the query and annotation database 116 contains information that can be used to improve visual query results.
- the user may annotate the image after the visual query results have been presented.
- the user may annotate the image before sending it to the visual query search system. Pre-annotation may help the visual query processing by focusing the results, or running text based searches on the annotated words in parallel with the visual query searches.
- annotated versions of a picture can be made public (e.g., when the user has given permission for publication, for example by designating the image and annotation(s) as not private), so as to be returned as a potential image match hit.
- the information from the query and annotation database 116 is periodically pushed to the parallel search systems 112 , which incorporate relevant portions of the information (if any) into their respective individual databases 114 .
- FIG. 7 is a block diagram illustrating one of the parallel search systems utilized to process a visual query.
- FIG. 7 illustrates a “generic” server system 112 -N in accordance with one embodiment of the present invention.
- This server system is generic only in that it represents any one of the visual query search servers 112 -N.
- the generic server system 112 -N typically includes one or more processing units (CPU's) 502 , one or more network or other communications interfaces 504 , memory 512 , and one or more communication buses 514 for interconnecting these components.
- Memory 512 includes high-speed random access memory, such as DRAM, SRAM, DDR RAM or other random access solid state memory devices; and may include non-volatile memory, such as one or more magnetic disk storage devices, optical disk storage devices, flash memory devices, or other non-volatile solid state storage devices. Memory 512 may optionally include one or more storage devices remotely located from the CPU(s) 502 . Memory 512 , or alternately the non-volatile memory device(s) within memory 512 , comprises a non-transitory computer readable storage medium. In some embodiments, memory 512 or the computer readable storage medium of memory 512 stores the following programs, modules and data structures, or a subset thereof:
- FIG. 8 is a block diagram illustrating an OCR search system 112 -B utilized to process a visual query in accordance with one embodiment of the present invention.
- the OCR search system 112 -B typically includes one or more processing units (CPU's) 602 , one or more network or other communications interfaces 604 , memory 612 , and one or more communication buses 614 for interconnecting these components.
- Memory 612 includes high-speed random access memory, such as DRAM, SRAM, DDR RAM or other random access solid state memory devices; and may include non-volatile memory, such as one or more magnetic disk storage devices, optical disk storage devices, flash memory devices, or other non-volatile solid state storage devices.
- Memory 612 may optionally include one or more storage devices remotely located from the CPU(s) 602 .
- Memory 612 or alternately the non-volatile memory device(s) within memory 612 , comprises a non-transitory computer readable storage medium.
- memory 612 or the computer readable storage medium of memory 612 stores the following programs, modules and data structures, or a subset thereof:
- FIG. 9 is a block diagram illustrating a facial recognition search system 112 -A utilized to process a visual query in accordance with one embodiment of the present invention.
- the facial recognition search system 112 -A typically includes one or more processing units (CPU's) 902 , one or more network or other communications interfaces 904 , memory 912 , and one or more communication buses 914 for interconnecting these components.
- Memory 912 includes high-speed random access memory, such as DRAM, SRAM, DDR RAM or other random access solid state memory devices; and may include non-volatile memory, such as one or more magnetic disk storage devices, optical disk storage devices, flash memory devices, or other non-volatile solid state storage devices.
- Memory 912 may optionally include one or more storage devices remotely located from the CPU(s) 902 .
- Memory 912 or alternately the non-volatile memory device(s) within memory 912 , comprises a non-transitory computer readable storage medium.
- memory 912 or the computer readable storage medium of memory 912 stores the following programs, modules and data structures, or a subset thereof:
- FIG. 10 is a block diagram illustrating an image-to-terms search system 112 -C utilized to process a visual query in accordance with one embodiment of the present invention.
- the image-to-terms search system recognizes objects (instance recognition) in the visual query.
- the image-to-terms search system recognizes object categories (type recognition) in the visual query.
- the image to terms system recognizes both objects and object-categories. The image-to-terms search system returns potential term matches for images in the visual query.
- the image-to-terms search system 112 -C typically includes one or more processing units (CPU's) 1002 , one or more network or other communications interfaces 1004 , memory 1012 , and one or more communication buses 1014 for interconnecting these components.
- Memory 1012 includes high-speed random access memory, such as DRAM, SRAM, DDR RAM or other random access solid state memory devices; and may include non-volatile memory, such as one or more magnetic disk storage devices, optical disk storage devices, flash memory devices, or other non-volatile solid state storage devices.
- Memory 1012 may optionally include one or more storage devices remotely located from the CPU(s) 1002 .
- Memory 1012 or alternately the non-volatile memory device(s) within memory 1012 , comprises a non-transitory computer readable storage medium.
- memory 1012 or the computer readable storage medium of memory 1012 stores the following programs, modules and data structures, or a subset thereof:
- FIGS. 5-10 are intended more as functional descriptions of the various features which may be present in a set of computer systems than as a structural schematic of the embodiments described herein.
- items shown separately could be combined and some items could be separated.
- some items shown separately in these figures could be implemented on single servers and single items could be implemented by one or more servers.
- the actual number of systems used to implement visual query processing and how features are allocated among them will vary from one implementation to another.
- Each of the methods described herein may be governed by instructions that are stored in a non-transitory computer readable storage medium and that are executed by one or more processors of one or more servers or clients.
- the above identified modules or programs i.e., sets of instructions
- Each of the operations shown in FIGS. 5-10 may correspond to instructions stored in a computer memory or non-transitory computer readable storage medium.
- FIG. 11 illustrates a client system 102 with a screen shot of an exemplary visual query 1102 .
- the client system 102 shown in FIG. 11 is a mobile device such as a cellular telephone, portable music player, or portable emailing device.
- the client system 102 includes a display 706 and one or more input means 708 such the buttons shown in this figure.
- the display 706 is a touch sensitive display 709 .
- soft buttons displayed on the display 709 may optionally replace some or all of the electromechanical buttons 708 .
- Touch sensitive displays are also helpful in interacting with the visual query results as explained in more detail below.
- the client system 102 also includes an image capture mechanism such as a camera 710 .
- FIG. 11 illustrates a visual query 1102 which is a photograph or video frame of a package on a shelf of a store.
- the visual query is a two dimensional image having a resolution corresponding to the size of the visual query in pixels in each of two dimensions.
- the visual query 1102 in this example is a two dimensional image of three dimensional objects.
- the visual query 1102 includes background elements, a product package 1104 , and a variety of types of entities on the package including an image of a person 1106 , an image of a trademark 1108 , an image of a product 1110 , and a variety of textual elements 1112 .
- the visual query 1102 is sent to the front end server 110 , which sends the visual query 1102 to a plurality of parallel search systems ( 112 A-N), receives the results and creates an interactive results document.
- a plurality of parallel search systems 112 A-N
- FIGS. 12A and 12B each illustrate a client system 102 with a screen shot of an embodiment of an interactive results document 1200 .
- the interactive results document 1200 includes one or more visual identifiers 1202 of respective sub-portions of the visual query 1102 , which each include a user selectable link to a subset of search results.
- FIGS. 12A and 12B illustrate an interactive results document 1200 with visual identifiers that are bounding boxes 1202 (e.g., bounding boxes 1202 - 1 , 1202 - 2 , 1202 - 3 ). In the embodiments shown in FIGS.
- the user activates the display of the search results corresponding to a particular sub-portion by tapping on the activation region inside the space outlined by its bounding box 1202 .
- the user would activate the search results corresponding to the image of the person, by tapping on a bounding box 1306 ( FIG. 13 ) surrounding the image of the person.
- the selectable link is selected using a mouse or keyboard rather than a touch sensitive display.
- the first corresponding search result is displayed when a user previews a bounding box 1202 (i.e., when the user single clicks, taps once, or hovers a pointer over the bounding box).
- the user activates the display of a plurality of corresponding search results when the user selects the bounding box (i.e., when the user double clicks, taps twice, or uses another mechanism to indicate selection.)
- the visual identifiers are bounding boxes 1202 surrounding sub-portions of the visual query.
- FIG. 12A illustrates bounding boxes 1202 that are square or rectangular.
- FIG. 12B illustrates a bounding box 1202 that outlines the boundary of an identifiable entity in the sub-portion of the visual query, such as the bounding box 1202 - 3 for a drink bottle.
- a respective bounding box 1202 includes smaller bounding boxes 1202 within it.
- the bounding box identifying the package 1202 - 1 surrounds the bounding box identifying the trademark 1202 - 2 and all of the other bounding boxes 1202 .
- FIG. 12B shows an example where “Active Drink” and “United States” are displayed as hot links 1204 .
- the search results corresponding to these terms are the results received from the term query server system 118 , whereas the results corresponding to the bounding boxes are results from the query by image search systems.
- FIG. 13 illustrates a client system 102 with a screen shot of an interactive results document 1200 that is coded by type of recognized entity in the visual query.
- the visual query of FIG. 11 contains an image of a person 1106 , an image of a trademark 1108 , an image of a product 1110 , and a variety of textual elements 1112 .
- the interactive results document 1200 displayed in FIG. 13 includes bounding boxes 1202 around a person 1306 , a trademark 1308 , a product 1310 , and the two textual areas 1312 .
- the bounding boxes of FIG. 13 are each presented with separate cross-hatching which represents differently colored transparent bounding boxes 1202 .
- the visual identifiers of the bounding boxes are formatted for presentation in visually distinctive manners such as overlay color, overlay pattern, label background color, label background pattern, label font color, and bounding box border color.
- the type coding for particular recognized entities is shown with respect to bounding boxes in FIG. 13 , but coding by type can also be applied to visual identifiers that are labels.
- FIG. 14 illustrates a client device 102 with a screen shot of an interactive results document 1200 with labels 1402 being the visual identifiers of respective sub-portions of the visual query 1102 of FIG. 11 .
- the label visual identifiers 1402 each include a user selectable link to a subset of corresponding search results.
- the selectable link is identified by descriptive text displayed within the area of the label 1402 .
- Some embodiments include a plurality of links within one label 1402 . For example, in FIG. 14 , the label hovering over the image of a woman drinking includes a link to facial recognition results for the woman and a link to image recognition results for that particular picture (e.g., images of other products or advertisements using the same picture.)
- the labels 1402 are displayed as partially transparent areas with text that are located over their respective sub-portions of the interactive results document. In other embodiments, a respective label is positioned near but not located over its respective sub-portion of the interactive results document. In some embodiments, the labels are coded by type in the same manner as discussed with reference to FIG. 13 . In some embodiments, the user activates the display of the search results corresponding to a particular sub-portion corresponding to a label 1302 by tapping on the activation region inside the space outlined by the edges or periphery of the label 1302 . The same previewing and selection functions discussed above with reference to the bounding boxes of FIGS. 12A and 12B also apply to the visual identifiers that are labels 1402 .
- FIG. 15 illustrates a screen shot of an interactive results document 1200 and the original visual query 1102 displayed concurrently with a results list 1500 .
- the interactive results document 1200 is displayed by itself as shown in FIGS. 12-14 .
- the interactive results document 1200 is displayed concurrently with the original visual query as shown in FIG. 15 .
- the list of visual query results 1500 is concurrently displayed along with the original visual query 1102 and/or the interactive results document 1200 .
- the type of client system and the amount of room on the display 706 may determine whether the list of results 1500 is displayed concurrently with the interactive results document 1200 .
- the client system 102 receives (in response to a visual query submitted to the visual query server system) both the list of results 1500 and the interactive results document 1200 , but only displays the list of results 1500 when the user scrolls below the interactive results document 1200 .
- the client system 102 displays the results corresponding to a user selected visual identifier 1202 / 1402 without needing to query the server again because the list of results 1500 is received by the client system 102 in response to the visual query and then stored locally at the client system 102 .
- the list of results 1500 is organized into categories 1502 .
- Each category contains at least one result 1503 .
- the categories titles are highlighted to distinguish them from the results 1503 .
- the categories 1502 are ordered according to their calculated category weight.
- the category weight is a combination of the weights of the highest N results in that category. As such, the category that has likely produced more relevant results is displayed first. In embodiments where more than one category 1502 is returned for the same recognized entity (such as the facial image recognition match and the image match shown in FIG. 15 ) the category displayed first has a higher category weight.
- the cursor when a selectable link in the interactive results document 1200 is selected by a user of the client system 102 , the cursor will automatically move to the appropriate category 1502 or to the first result 1503 in that category.
- the list of results 1500 is re-ordered such that the category or categories relevant to the selected link are displayed first. This is accomplished, for example, by either coding the selectable links with information identifying the corresponding search results, or by coding the search results to indicate the corresponding selectable links or to indicate the corresponding result categories.
- the categories of the search results correspond to the query-by-image search system that produce those search results.
- some of the categories are product match 1506 , logo match 1508 , facial recognition match 1510 , image match 1512 .
- the original visual query 1102 and/or an interactive results document 1200 may be similarly displayed with a category title such as the query 1504 .
- results from any term search performed by the term query server may also be displayed as a separate category, such as web results 1514 .
- more than one entity in a visual query will produce results from the same query-by-image search system.
- the visual query could include two different faces that would return separate results from the facial recognition search system.
- the categories 1502 are divided by recognized entity rather than by search system.
- an image of the recognized entity is displayed in the recognized entity category header 1502 such that the results for that recognized entity are distinguishable from the results for another recognized entity, even though both results are produced by the same query by image search system.
- the product match category 1506 includes two entity product entities and as such as two entity categories 1502 —a boxed product 1516 and a bottled product 1518 , each of which have a plurality of corresponding search results 1503 .
- the categories may be divided by recognized entities and type of query-by-image system. For example, in FIG. 15 , there are two separate entities that returned relevant results under the product match category product.
- the results 1503 include thumbnail images.
- thumbnail images For example, as shown for the facial recognition match results in FIG. 15 , small versions (also called thumbnail images) of the pictures of the facial matches for “Actress X” and “Social Network Friend Y” are displayed along with some textual description such as the name of the person in the image.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Data Mining & Analysis (AREA)
- Databases & Information Systems (AREA)
- General Engineering & Computer Science (AREA)
- Library & Information Science (AREA)
- Mathematical Physics (AREA)
- Computational Linguistics (AREA)
- Health & Medical Sciences (AREA)
- General Health & Medical Sciences (AREA)
- Oral & Maxillofacial Surgery (AREA)
- Human Computer Interaction (AREA)
- Multimedia (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
- Processing Or Creating Images (AREA)
- Character Input (AREA)
Abstract
Description
- This application claims priority to the following U.S. Provisional Patent Applications all of which are incorporated by reference herein in their entirety: U.S. Provisional Patent Application No. 61/266,116, filed Dec. 2, 2009, entitled “Architecture for Responding to a Visual Query,” and U.S. Provisional Patent Application No. 61/232,397, filed Aug. 7, 2009, entitled “Architecture for Responding to a Visual Query.”
- This application is related to the following U.S. Provisional Patent Applications all of which are incorporated by reference herein in their entirety: U.S. Provisional Patent Application No. 61/266,122, filed Dec. 2, 2009, entitled “User Interface for Presenting Search Results for Multiple Regions of a Visual Query;” U.S. Provisional Patent Application No. 61/266,125, filed Dec. 2, 2009, entitled “Identifying Matching Canonical Documents In Response To A Visual Query;” U.S. Provisional Patent Application No. 61/266,126, filed Dec. 2, 2009, entitled “Region of Interest Selector for Visual Queries;” U.S. Provisional Patent Application No. 61/266,130, filed Dec. 2, 2009, entitled “Actionable Search Results for Visual Queries;” U.S. Provisional Patent Application No. 61/266,133, filed Dec. 2, 2009, entitled “Actionable Search Results for Street View Visual Queries,” and U.S. Provisional Patent Application No. 61/266,499, filed Dec. 3, 2009, entitled “Hybrid Use Location Sensor Data and Visual Query to Return Local Listing for Visual Query.”
- The disclosed embodiments relate generally to a server system architecture encompassing a plurality of parallel search systems for processing a visual query.
- A text-based or term-based searching, wherein a user inputs a word or phrase into a search engine and receives a variety of results is a useful tool for searching. However, term based queries require that a user be able to input a relevant term. Sometimes a user may wish to know information about an image. For example, a user might want to know the name of a person in a photograph, or a user might want to know the name of a flower or bird in a picture. Accordingly, a system that can receive a visual query and provide search results would be desirable.
- According to some embodiments, there is computer-implemented method of processing a visual query at a server system. A visual query is received from a client system. The visual query is processed by sending the visual query to a plurality of parallel search systems for simultaneous processing. Each of the plurality of search systems implements a distinct visual query search process of a plurality of visual query search processes. The plurality of visual query search processes includes at least: optical character recognition (OCR), facial recognition, and a first query-by-image process other than OCR and facial recognition. A plurality of search results is received from one or more of the plurality of parallel search systems. At least one of the plurality of search results is sent to the client system.
- In some embodiments, the method further includes, when at least two of the received search results meet predefined criteria, ranking the received search results that meet the predefined criteria, and sending at least one search result of the ranked search results to the client system.
- In some embodiments, the first query-by-image process is product recognition, bar code recognition, object-or-object-category recognition, named entity recognition, or color recognition.
- In some embodiments, the visual query is a photograph, a screen shot, a scanned image, or a video frame. The client system can be a mobile device, a desktop device, or other device.
- In some embodiments, the visual query is received from a client application executed by the client system, such a search application, a search engine plug-in for a browser application, or a search engine extension for a browser application. In some embodiments, the visual query is received from a content authoring application executed by the client system.
- When the visual query is an image containing a text element and a non-text element, in some embodiments, the search result includes an optical character recognition result for the text element and at least one image-match result for the non-text element.
- In some embodiments, when the visual query is an image containing a text element and a non-text element, the search result includes an interactive results document comprising a first visual identifier for the text element with a link to a search result produced by an optical character recognition process, and a second visual identifier for the non-text element with a link to a search result produced by an image-match process.
- In some embodiments, the method further includes combining at least two of the plurality of search results into a compound search result.
- According to some embodiments, a search engine system is provided for processing a visual query. The system includes one or more central processing units for executing programs and memory storing one or more programs to be executed by the one or more central processing units. The one or more programs include instructions for performing the following. A visual query is received from a client system. The visual query is processed by sending the visual query to a plurality of parallel search systems for simultaneous processing. Each of the plurality of search systems implements a distinct visual query search process of a plurality of visual query search processes. The plurality of visual query search processes includes at least: optical character recognition (OCR), facial recognition, and a first query-by-image process other than OCR and facial recognition. A plurality of search results is received from one or more of the plurality of parallel search systems. At least one of the plurality of search results is sent to the client system. Such a system may also include program instructions to execute the additional options discussed above.
- According to some embodiments, a computer readable storage medium system for processing a visual query is provided. The computer readable storage medium stores one or more programs configured for execution by a computer, the one or more programs comprising instructions for performing the following. A visual query is received from a client system. The visual query is processed by sending the visual query to a plurality of parallel search systems for simultaneous processing. Each of the plurality of search systems implements a distinct visual query search process of a plurality of visual query search processes. The plurality of visual query search processes includes at least: optical character recognition (OCR), facial recognition, and a first query-by-image process other than OCR and facial recognition. A plurality of search results is received from one or more of the plurality of parallel search systems. At least one of the plurality of search results is sent to the client system. Such a computer readable storage medium may also include program instructions to execute the additional options discussed above.
-
FIG. 1 is a block diagram illustrating a computer network that includes a visual query server system. -
FIG. 2 is a flow diagram illustrating the process for responding to a visual query, in accordance with some embodiments. -
FIG. 3 is a flow diagram illustrating the process for responding to a visual query with an interactive results document, in accordance with some embodiments. -
FIG. 4 is a flow diagram illustrating the communications between a client and a visual query server system, in accordance with some embodiments. -
FIG. 5 is a block diagram illustrating a client system, in accordance with some embodiments. -
FIG. 6 is a block diagram illustrating a front end visual query processing server system, in accordance with some embodiments. -
FIG. 7 is a block diagram illustrating a generic one of the parallel search systems utilized to process a visual query, in accordance with some embodiments. -
FIG. 8 is a block diagram illustrating an OCR search system utilized to process a visual query, in accordance with some embodiments. -
FIG. 9 is a block diagram illustrating a facial recognition search system utilized to process a visual query, in accordance with some embodiments. -
FIG. 10 is a block diagram illustrating an image to terms search system utilized to process a visual query, in accordance with some embodiments. -
FIG. 11 illustrates a client system with a screen shot of an exemplary visual query, in accordance with some embodiments. -
FIGS. 12A and 12B each illustrate a client system with a screen shot of an interactive results document with bounding boxes, in accordance with some embodiments. -
FIG. 13 illustrates a client system with a screen shot of an interactive results document that is coded by type, in accordance with some embodiments. -
FIG. 14 illustrates a client system with a screen shot of an interactive results document with labels, in accordance with some embodiments. -
FIG. 15 illustrates a screen shot of an interactive results document and visual query displayed concurrently with a results list, in accordance with some embodiments. - Like reference numerals refer to corresponding parts throughout the drawings.
- Reference will now be made in detail to embodiments, examples of which are illustrated in the accompanying drawings. In the following detailed description, numerous specific details are set forth in order to provide a thorough understanding of the present invention. However, it will be apparent to one of ordinary skill in the art that the present invention may be practiced without these specific details. In other instances, well-known methods, procedures, components, circuits, and networks have not been described in detail so as not to unnecessarily obscure aspects of the embodiments.
- It will also be understood that, although the terms first, second, etc. may be used herein to describe various elements, these elements should not be limited by these terms. These terms are only used to distinguish one element from another. For example, a first contact could be termed a second contact, and, similarly, a second contact could be termed a first contact, without departing from the scope of the present invention. The first contact and the second contact are both contacts, but they are not the same contact.
- The terminology used in the description of the invention herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the invention. As used in the description of the invention and the appended claims, the singular forms “a,” “an,” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will also be understood that the term “and/or” as used herein refers to and encompasses any and all possible combinations of one or more of the associated listed items. It will be further understood that the terms “comprises” and/or “comprising,” when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof.
- As used herein, the term “if” may be construed to mean “when” or “upon” or “in response to determining” or “in response to detecting,” depending on the context. Similarly, the phrase “if it is determined” or “if is detected” may be construed to mean “upon determining” or “in response to determining” or “upon detecting (the stated condition or event)” or “in response to detecting (the stated condition or event),” depending on the context.
-
FIG. 1 is a block diagram illustrating a computer network that includes a visual query server system according to some embodiments. Thecomputer network 100 includes one ormore client systems 102 and a visualquery server system 106. One ormore communications networks 104 interconnect these components. Thecommunications network 104 may be any of a variety of networks, including local area networks (LAN), wide area networks (WAN), wireless networks, wireline networks, the Internet, or a combination of such networks. - The
client system 102 includes aclient application 108, which is executed by the client system, for receiving a visual query (e.g.,visual query 1102 ofFIG. 11 ). A visual query is an image that is submitted as a query to a search engine or search system. Examples of visual queries, without limitations include photographs, scanned documents and images, and drawings. In some embodiments, theclient application 108 is selected from the set consisting of a search application, a search engine plug-in for a browser application, and a search engine extension for a browser application. In some embodiments, theclient application 108 is an “omnivorous” search box, which allows a user to drag and drop any format of image into the search box to be used as the visual query. - A
client system 102 sends queries to and receives data from the visualquery server system 106. Theclient system 102 may be any computer or other device that is capable of communicating with the visualquery server system 106. Examples include, without limitation, desktop and notebook computers, mainframe computers, server computers, mobile devices such as mobile phones and personal digital assistants, network terminals, and set-top boxes. - The visual
query server system 106 includes a front end visualquery processing server 110. Thefront end server 110 receives a visual query from theclient 102, and sends the visual query to a plurality ofparallel search systems 112 for simultaneous processing. Thesearch systems 112 each implement a distinct visual query search process and access theircorresponding databases 114 as necessary to process the visual query by their distinct search process. For example, a face recognition search system 112-A will access a facial image database 114-A to look for facial matches to the image query. As will be explained in more detail with regard toFIG. 9 , if the visual query contains a face, the facial recognition search system 112-A will return one or more search results (e.g., names, matching faces, etc.) from the facial image database 114-A. In another example, the optical character recognition (OCR) search system 112-B, converts any recognizable text in the visual query into text for return as one or more search results. In the optical character recognition (OCR) search system 112-B, an OCR database 114-B may be accessed to recognize particular fonts or text patterns as explained in more detail with regard toFIG. 8 . - Any number of
parallel search systems 112 may be used. Some examples include a facial recognition search system 112-A, an OCR search system 112-B, an image-to-terms search system 112-C (which may recognize an object or an object category), a product recognition search system (which may be configured to recognize 2-D images such as book covers and CDs and may also be configured to recognized 3-D images such as furniture), bar code recognition search system (which recognizes 1D and 2D style bar codes), a named entity recognition search system, landmark recognition (which may configured to recognize particular famous landmarks like the Eiffel Tower and may also be configured to recognize a corpus of specific images such as billboards), place recognition aided by geo-location information provided by a GPS receiver in theclient system 102 or mobile phone network, a color recognition search system, and a similar image search system (which searches for and identifies images similar to a visual query). Further search systems can be added as additional parallel search systems, represented inFIG. 1 by system 112-N. All of the search systems, except the OCR search system, are collectively defined herein as search systems performing an image-match process. All of the search systems including the OCR search system are collectively referred to as query-by-image search systems. In some embodiments, the visualquery server system 106 includes a facial recognition search system 112-A, an OCR search system 112-B, and at least one other query-by-image search system 112. - The
parallel search systems 112 each individually process the visual search query and return their results to the frontend server system 110. In some embodiments, thefront end server 100 may perform one or more analyses on the search results such as one or more of: aggregating the results into a compound document, choosing a subset of results to display, and ranking the results as will be explained in more detail with regard toFIG. 6 . Thefront end server 110 communicates the search results to theclient system 102. - The
client system 102 presents the one or more search results to the user. The results may be presented on a display, by an audio speaker, or any other means used to communicate information to a user. The user may interact with the search results in a variety of ways. In some embodiments, the user's selections, annotations, and other interactions with the search results are transmitted to the visualquery server system 106 and recorded along with the visual query in a query andannotation database 116. Information in the query and annotation database can be used to improve visual query results. In some embodiments, the information from the query andannotation database 116 is periodically pushed to theparallel search systems 112, which incorporate any relevant portions of the information into their respectiveindividual databases 114. - The
computer network 100 optionally includes a termquery server system 118, for performing searches in response to term queries. A term query is a query containing one or more terms, as opposed to a visual query which contains an image. The termquery server system 118 may be used to generate search results that supplement information produced by the various search engines in the visualquery server system 106. The results returned from the termquery server system 118 may include any format. The termquery server system 118 may include textual documents, images, video, etc. While termquery server system 118 is shown as a separate system inFIG. 1 , optionally the visualquery server system 106 may include a termquery server system 118. - Additional information about the operation of the visual
query server system 106 is provided below with respect to the flowcharts inFIGS. 2-4 . -
FIG. 2 is a flow diagram illustrating a visual query server system method for responding to a visual query, according to certain embodiments of the invention. Each of the operations shown inFIG. 2 may correspond to instructions stored in a computer memory or computer readable storage medium. - The visual query server system receives a visual query from a client system (202). The client system, for example, may be a desktop computing device, a mobile device, or another similar device (204) as explained with reference to
FIG. 1 . An example visual query on an example client system is shown inFIG. 11 . - The visual query is an image document of any suitable format. For example, the visual query can be a photograph, a screen shot, a scanned image, or a frame or a sequence of multiple frames of a video (206). In some embodiments, the visual query is a drawing produced by a content authoring program (736,
FIG. 5 ). As such, in some embodiments, the user “draws” the visual query, while in other embodiments the user scans or photographs the visual query. Some visual queries are created using an image generation application such as Acrobat, a photograph editing program, a drawing program, or an image editing program. For example, a visual query could come from a user taking a photograph of his friend on his mobile phone and then submitting the photograph as the visual query to the server system. The visual query could also come from a user scanning a page of a magazine, or taking a screen shot of a webpage on a desktop computer and then submitting the scan or screen shot as the visual query to the server system. In some embodiments, the visual query is submitted to theserver system 106 through a search engine extension of a browser application, through a plug-in for a browser application, or by a search application executed by theclient system 102. Visual queries may also be submitted by other application programs (executed by a client system) that support or generate images which can be transmitted to a remotely located server by the client system. - The visual query can be a combination of text and non-text elements (208). For example, a query could be a scan of a magazine page containing images and text, such as a person standing next to a road sign. A visual query can include an image of a person's face, whether taken by a camera embedded in the client system or a document scanned by or otherwise received by the client system. A visual query can also be a scan of a document containing only text. The visual query can also be an image of numerous distinct subjects, such as several birds in a forest, a person and an object (e.g., car, park bench, etc.), a person and an animal (e.g., pet, farm animal, butterfly, etc.). Visual queries may have two or more distinct elements. For example, a visual query could include a barcode and an image of a product or product name on a product package. For example, the visual query could be a picture of a book cover that includes the title of the book, cover art, and a bar code. In some instances, one visual query will produce two or more distinct search results corresponding to different portions of the visual query, as discussed in more detail below.
- The server system processes the visual query as follows. The front end server system sends the visual query to a plurality of parallel search systems for simultaneous processing (210). Each search system implements a distinct visual query search process, i.e., an individual search system processes the visual query by its own processing scheme.
- In some embodiments, one of the search systems to which the visual query is sent for processing is an optical character recognition (OCR) search system. In some embodiments, one of the search systems to which the visual query is sent for processing is a facial recognition search system. In some embodiments, the plurality of search systems running distinct visual query search processes includes at least: optical character recognition (OCR), facial recognition, and another query-by-image process other than OCR and facial recognition (212). The other query-by-image process is selected from a set of processes that includes but is not limited to product recognition, bar code recognition, object-or-object-category recognition, named entity recognition, and color recognition (212).
- In some embodiments, named entity recognition occurs as a post process of the OCR search system, wherein the text result of the OCR is analyzed for famous people, locations, objects and the like, and then the terms identified as being named entities are searched in the term query server system (118,
FIG. 1 ). In other embodiments, images of famous landmarks, logos, people, album covers, trademarks, etc. are recognized by an image-to-terms search system. In other embodiments, a distinct named entity query-by-image process separate from the image-to-terms search system is utilized. The object-or-object category recognition system recognizes generic result types like “car.” In some embodiments, this system also recognizes product brands, particular product models, and the like, and provides more specific descriptions, like “Porsche.” Some of the search systems could be special user specific search systems. For example, particular versions of color recognition and facial recognition could be a special search systems used by the blind. - The front end server system receives results from the parallel search systems (214). In some embodiments, the results are accompanied by a search score. For some visual queries, some of the search systems will find no relevant results. For example, if the visual query was a picture of a flower, the facial recognition search system and the bar code search system will not find any relevant results. In some embodiments, if no relevant results are found, a null or zero search score is received from that search system (216). In some embodiments, if the front end server does not receive a result from a search system after a pre-defined period of time (e.g., 0.2, 0.5, 1, 2 or 5 seconds), it will process the received results as if that timed out server produced a null search score and will process the received results from the other search systems.
- Optionally, when at least two of the received search results meet pre-defined criteria, they are ranked (218). In some embodiments, one of the predefined criteria excludes void results. A pre-defined criterion is that the results are not void. In some embodiments, one of the predefined criteria excludes results having numerical score (e.g., for a relevance factor) that falls below a pre-defined minimum score. Optionally, the plurality of search results are filtered (220). In some embodiments, the results are only filtered if the total number of results exceeds a pre-defined threshold. In some embodiments, all the results are ranked but the results falling below a pre-defined minimum score are excluded. For some visual queries, the content of the results are filtered. For example, if some of the results contain private information or personal protected information, these results are filtered out.
- Optionally, the visual query server system creates a compound search result (222). One embodiment of this is when more than one search system result is embedded in an interactive results document as explained with respect to
FIG. 3 . The term query server system (118,FIG. 1 ) may augment the results from one of the parallel search systems with results from a term search, where the additional results are either links to documents or information sources, or text and/or images containing additional information that may be relevant to the visual query. Thus, for example, the compound search result may contain an OCR result and a link to a named entity in the OCR document (224). - In some embodiments, the OCR search system (112-B,
FIG. 1 ) or the front end visual query processing server (110,FIG. 1 ) recognizes likely relevant words in the text. For example, it may recognize named entities such as famous people or places. The named entities are submitted as query terms to the term query server system (118,FIG. 1 ). In some embodiments, the term query results produced by the term query server system are embedded in the visual query result as a “link.” In some embodiments, the term query results are returned as separate links. For example, if a picture of a book cover were the visual query, it is likely that an object recognition search system will produce a high scoring hit for the book. As such a term query for the title of the book will be run on the termquery server system 118 and the term query results are returned along with the visual query results. In some embodiments, the term query results are presented in a labeled group to distinguish them from the visual query results. The results may be searched individually, or a search may be performed using all the recognized named entities in the search query to produce particularly relevant additional search results. For example, if the visual query is a scanned travel brochure about Paris, the returned result may include links to the termquery server system 118 for initiating a search on a term query “Notre Dame.” Similarly, compound search results include results from text searches for recognized famous images. For example, in the same travel brochure, live links to the term query results for famous destinations shown as pictures in the brochure like “Eiffel Tower” and “Louvre” may also be shown (even if the terms “Eiffel Tower” and “Louvre” did not appear in the brochure itself.) - The visual query server system then sends at least one result to the client system (226). Typically, if the visual query processing server receives a plurality of search results from at least some of the plurality of search systems, it will then send at least one of the plurality of search results to the client system. For some visual queries, only one search system will return relevant results. For example, in a visual query containing only an image of text, only the OCR server's results may be relevant. For some visual queries, only one result from one search system may be relevant. For example, only the product related to a scanned bar code may be relevant. In these instances, the front end visual processing server will return only the relevant search result(s). For some visual queries, a plurality of search results are sent to the client system, and the plurality of search results include search results from more than one of the parallel search systems (228). This may occur when more than one distinct image is in the visual query. For example, if the visual query were a picture of a person riding a horse, results for facial recognition of the person could be displayed along with object identification results for the horse. In some embodiments, all the results for a particular query by image search system are grouped and presented together. For example, the top N facial recognition results are displayed under a heading “facial recognition results” and the top N object recognition results are displayed together under a heading “object recognition results.” Alternatively, as discussed below, the search results from a particular image search system may be grouped by image region. For example, if the visual query includes two faces, both of which produce facial recognition results, the results for each face would be presented as a distinct group. For some visual queries (e.g., a visual query including an image of both text and one or more objects), the search results may include both OCR results and one or more image-match results (230).
- In some embodiments, the user may wish to learn more about a particular search result. For example, if the visual query was a picture of a dolphin and the “image to terms” search system returns the following terms “water,” “dolphin,” “blue,” and “Flipper;” the user may wish to run a text based query term search on “Flipper.” When the user wishes to run a search on a term query (e.g., as indicated by the user clicking on or otherwise selecting a corresponding link in the search results), the query term server system (118,
FIG. 1 ) is accessed, and the search on the selected term(s) is run. The corresponding search term results are displayed on the client system either separately or in conjunction with the visual query results (232). In some embodiments, the front end visual query processing server (110,FIG. 1 ) automatically (i.e., without receiving any user command, other than the initial visual query) chooses one or more top potential text results for the visual query, runs those text results on the termquery server system 118, and then returns those term query results along with the visual query result to the client system as a part of sending at least one search result to the client system (232). In the example above, if “Flipper” was the first term result for the visual query picture of a dolphin, the front end server runs a term query on “Flipper” and returns those term query results along with the visual query results to the client system. This embodiment, wherein a term result that is considered likely to be selected by the user is automatically executed prior to sending search results from the visual query to the user, saves the user time. In some embodiments, these results are displayed as a compound search result (222) as explained above. In other embodiments, the results are part of a search result list instead of or in addition to a compound search result. -
FIG. 3 is a flow diagram illustrating the process for responding to a visual query with an interactive results document. The first three operations (202, 210, 214) are described above with reference toFIG. 2 . From the search results which are received from the parallel search systems (214), an interactive results document is created (302). - Creating the interactive results document (302) will now be described in detail. For some visual queries, the interactive results document includes one or more visual identifiers of respective sub-portions of the visual query. Each visual identifier has at least one user selectable link to at least one of the search results. A visual identifier identifies a respective sub-portion of the visual query. For some visual queries, the interactive results document has only one visual identifier with one user selectable link to one or more results. In some embodiments, a respective user selectable link to one or more of the search results has an activation region, and the activation region corresponds to the sub-portion of the visual query that is associated with a corresponding visual identifier.
- In some embodiments, the visual identifier is a bounding box (304). In some embodiments, the bounding box encloses a sub-portion of the visual query as shown in
FIG. 12A . The bounding box need not be a square or rectangular box shape but can be any sort of shape including circular, oval, conformal (e.g., to an object in, entity in or region of the visual query), irregular or any other shape as shown inFIG. 12B . For some visual queries, the bounding box outlines the boundary of an identifiable entity in a sub-portion of the visual query (306). In some embodiments, each bounding box includes a user selectable link to one or more search results, where the user selectable link has an activation region corresponding to a sub-portion of the visual query surrounded by the bounding box. When the space inside the bounding box (the activation region of the user selectable link) is selected by the user, search results that correspond to the image in the outlined sub-portion are returned. - In some embodiments, the visual identifier is a label (307) as shown in
FIG. 14 . In some embodiments, label includes at least one term associated with the image in the respective sub-portion of the visual query. Each label is formatted for presentation in the interactive results document on or near the respective sub-portion. In some embodiments, the labels are color coded. - In some embodiments, each respective visual identifiers is formatted for presentation in a visually distinctive manner in accordance with a type of recognized entity in the respective sub-portion of the visual query. For example, as shown in
FIG. 13 , bounding boxes around a product, a person, a trademark, and the two textual areas are each presented with distinct cross-hatching patterns, representing differently colored transparent bounding boxes. In some embodiments, the visual identifiers are formatted for presentation in visually distinctive manners such as overlay color, overlay pattern, label background color, label background pattern, label font color, and border color. - In some embodiments, the user selectable link in the interactive results document is a link to a document or object that contains one or more results related to the corresponding sub-portion of the visual query (308). In some embodiments, at least one search result includes data related to the corresponding sub-portion of the visual query. As such, when the user selects the selectable link associated with the respective sub-portion, the user is directed to the search results corresponding to the recognized entity in the respective sub-portion of the visual query.
- For example, if a visual query was a photograph of a bar code, there may be portions of the photograph which are irrelevant parts of the packaging upon which the bar code was affixed. The interactive results document may include a bounding box around only the bar code. When the user selects inside the outlined bar code bounding box, the bar code search result is displayed. The bar code search result may include one result, the name of the product corresponding to that bar code, or the bar code results may include several results such as a variety of places in which that product can be purchased, reviewed, etc.
- In some embodiments, when the sub-portion of the visual query corresponding to a respective visual identifier contains text comprising one or more terms, the search results corresponding to the respective visual identifier include results from a term query search on at least one of the terms in the text. In some embodiments, when the sub-portion of the visual query corresponding to a respective visual identifier contains a person's face for which at least one match (i.e., search result) is found that meets predefined reliability (or other) criteria, the search results corresponding to the respective visual identifier include one or more of: name, handle, contact information, account information, address information, current location of a related mobile device associated with the person whose face is contained in the selectable sub-portion, other images of the person whose face is contained in the selectable sub-portion, and potential image matches for the person's face. In some embodiments, when the sub-portion of the visual query corresponding to a respective visual identifier contains a product for which at least one match (i.e., search result) is found that meets predefined reliability (or other) criteria, the search results corresponding to the respective visual identifier include one or more of: product information, a product review, an option to initiate purchase of the product, an option to initiate a bid on the product, a list of similar products, and a list of related products.
- Optionally, a respective user selectable link in the interactive results document includes anchor text, which is displayed in the document without having to activate the link. The anchor text provides information, such as a key word or term, related to the information obtained when the link is activated. Anchor text may be displayed as part of the label (307), or in a portion of a bounding box (304), or as additional information displayed when a user hovers a cursor over a user selectable link for a pre-determined period of time such as 1 second.
- Optionally, a respective user selectable link in the interactive results document is a link to a search engine for searching for information or documents corresponding to a text-based query (sometimes herein called a term query). Activation of the link causes execution of the search by the search engine, where the query and the search engine are specified by the link (e.g., the search engine is specified by a URL in the link and the text-based search query is specified by a URL parameter of the link), with results returned to the client system. Optionally, the link in this example may include anchor text specifying the text or terms in the search query.
- In some embodiments, the interactive results document produced in response to a visual query can include a plurality of links that correspond to results from the same search system. For example, a visual query may be an image or picture of a group of people. The interactive results document may include bounding boxes around each person, which when activated returns results from the facial recognition search system for each face in the group. For some visual queries, a plurality of links in the interactive results document corresponds to search results from more than one search system (310). For example, if a picture of a person and a dog was submitted as the visual query, bounding boxes in the interactive results document may outline the person and the dog separately. When the person (in the interactive results document) is selected, search results from the facial recognition search system are retuned, and when the dog (in the interactive results document) is selected, results from the image-to-terms search system are returned. For some visual queries, the interactive results document contains an OCR result and an image match result (312). For example, if a picture of a person standing next to a sign were submitted as a visual query, the interactive results document may include visual identifiers for the person and for the text in the sign. Similarly, if a scan of a magazine was used as the visual query, the interactive results document may include visual identifiers for photographs or trademarks in advertisements on the page as well as a visual identifier for the text of an article also on that page.
- After the interactive results document has been created, it is sent to the client system (314). In some embodiments, the interactive results document (e.g.,
document 1200,FIG. 15 ) is sent in conjunction with a list of search results from one or more parallel search systems, as discussed above with reference toFIG. 2 . In some embodiments, the interactive results document is displayed at the client system above or otherwise adjacent to a list of search results from one or more parallel search systems (315) as shown inFIG. 15 . - Optionally, the user will interact with the results document by selecting a visual identifier in the results document. The server system receives from the client system information regarding the user selection of a visual identifier in the interactive results document (316). As discussed above, in some embodiments, the link is activated by selecting an activation region inside a bounding box. In other embodiments, the link is activated by a user selection of a visual identifier of a sub-portion of the visual query, which is not a bounding box. In some embodiments, the linked visual identifier is a hot button, a label located near the sub-portion, an underlined word in text, or other representation of an object or subject in the visual query.
- In embodiments where the search results list is presented with the interactive results document (315), when the user selects a user selectable link (316), the search result in the search results list corresponding to the selected link is identified. In some embodiments, the cursor will jump or automatically move to the first result corresponding to the selected link. In some embodiments in which the display of the
client 102 is too small to display both the interactive results document and the entire search results list, selecting a link in the interactive results document causes the search results list to scroll or jump so as to display at least a first result corresponding to the selected link. In some other embodiments, in response to user selection of a link in the interactive results document, the results list is reordered such that the first result corresponding to the link is displayed at the top of the results list. - In some embodiments, when the user selects the user selectable link (316) the visual query server system sends at least a subset of the results, related to a corresponding sub-portion of the visual query, to the client for display to the user (318). In some embodiments, the user can select multiple visual identifiers concurrently and will receive a subset of results for all of the selected visual identifiers at the same time. In other embodiments, search results corresponding to the user selectable links are preloaded onto the client prior to user selection of any of the user selectable links so as to provide search results to the user virtually instantaneously in response to user selection of one or more links in the interactive results document.
-
FIG. 4 is a flow diagram illustrating the communications between a client and a visual query server system. Theclient 102 receives a visual query from a user/querier (402). In some embodiments, visual queries can only be accepted from users who have signed up for or “opted in” to the visual query system. In some embodiments, searches for facial recognition matches are only performed for users who have signed up for the facial recognition visual query system, while other types of visual queries are performed for anyone regardless of whether they have “opted in” to the facial recognition portion. - As explained above, the format of the visual query can take many forms. The visual query will likely contain one or more subjects located in sub-portions of the visual query document. For some visual queries, the
client system 102 performs type recognition pre-processing on the visual query (404). In some embodiments, theclient system 102 searches for particular recognizable patterns in this pre-processing system. For example, for some visual queries the client may recognize colors. For some visual queries the client may recognize that a particular sub-portion is likely to contain text (because that area is made up of small dark characters surrounded by light space etc.) The client may contain any number of pre-processing type recognizers, or type recognition modules. In some embodiments, the client will have a type recognition module (barcode recognition 406) for recognizing bar codes. It may do so by recognizing the distinctive striped pattern in a rectangular area. In some embodiments, the client will have a type recognition module (face detection 408) for recognizing that a particular subject or sub-portion of the visual query is likely to contain a face. - In some embodiments, the recognized “type” is returned to the user for verification. For example, the
client system 102 may return a message stating “a bar code has been found in your visual query, are you interested in receiving bar code query results?” In some embodiments, the message may even indicate the sub-portion of the visual query where the type has been found. In some embodiments, this presentation is similar to the interactive results document discussed with reference toFIG. 3 . For example, it may outline a sub-portion of the visual query and indicate that the sub-portion is likely to contain a face, and ask the user if they are interested in receiving facial recognition results. - After the
client 102 performs the optional pre-processing of the visual query, the client sends the visual query to the visualquery server system 106, specifically to the front end visualquery processing server 110. In some embodiments, if pre-processing produced relevant results, i.e., if one of the type recognition modules produced results above a certain threshold, indicating that the query or a sub-portion of the query is likely to be of a particular type (face, text, barcode etc.), the client will pass along information regarding the results of the pre-processing. For example, the client may indicate that the face recognition module is 75% sure that a particular sub-portion of the visual query contains a face. More generally, the pre-processing results, if any, include one or more subject type values (e.g., bar code, face, text, etc.). Optionally, the pre-processing results sent to the visual query server system include one or more of: for each subject type value in the pre-processing results, information identifying a sub-portion of the visual query corresponding to the subject type value, and for each subject type value in the pre-processing results, a confidence value indicating a level of confidence in the subject type value and/or the identification of a corresponding sub-portion of the visual query. - The
front end server 110 receives the visual query from the client system (202). The visual query received may contain the pre-processing information discussed above. As described above, the front end server sends the visual query to a plurality of parallel search systems (210). If thefront end server 110 received pre-processing information regarding the likelihood that a sub-portion contained a subject of a certain type, the front end server may pass this information along to one or more of the parallel search systems. For example, it may pass on the information that a particular sub-portion is likely to be a face so that the facial recognition search system 112-A can process that subsection of the visual query first. Similarly, sending the same information (that a particular sub-portion is likely to be a face) may be used by the other parallel search systems to ignore that sub-portion or analyze other sub-portions first. In some embodiments, the front end server will not pass on the pre-processing information to the parallel search systems, but will instead use this information to augment the way in which it processes the results received from the parallel search systems. - As explained with reference to
FIG. 2 , for at some visual queries, thefront end server 110 receives a plurality of search results from the parallel search systems (214). The front end server may then perform a variety of ranking and filtering, and may create an interactive search result document as explained with reference toFIGS. 2 and 3 . If thefront end server 110 received pre-processing information regarding the likelihood that a sub-portion contained a subject of a certain type, it may filter and order by giving preference to those results that match the pre-processed recognized subject type. If the user indicated that a particular type of result was requested, the front end server will take the user's requests into account when processing the results. For example, the front end server may filter out all other results if the user only requested bar code information, or the front end server will list all results pertaining to the requested type prior to listing the other results. If an interactive visual query document is returned, the server may pre-search the links associated with the type of result the user indicated interest in, while only providing links for performing related searches for the other subjects indicated in the interactive results document. Then thefront end server 110 sends the search results to the client system (226). - The
client 102 receives the results from the server system (412). When applicable, these results will include the results that match the type of result found in the pre-processing stage. For example, in some embodiments they will include one or more bar code results (414) or one or more facial recognition results (416). If the client's pre-processing modules had indicated that a particular type of result was likely, and that result was found, the found results of that type will be listed prominently. - Optionally the user will select or annotate one or more of the results (418). The user may select one search result, may select a particular type of search result, and/or may select a portion of an interactive results document (420). Selection of a result is implicit feedback that the returned result was relevant to the query. Such feedback information can be utilized in future query processing operations. An annotation provides explicit feedback about the returned result that can also be utilized in future query processing operations. Annotations take the form of corrections of portions of the returned result (like a correction to a mis-OCRed word) or a separate annotation (either free form or structured.)
- The user's selection of one search result, generally selecting the “correct” result from several of the same type (e.g., choosing the correct result from a facial recognition server), is a process that is referred to as a selection among interpretations. The user's selection of a particular type of search result, generally selecting the result “type” of interest from several different types of returned results (e.g., choosing the OCRed text of an article in a magazine rather than the visual results for the advertisements also on the same page), is a process that is referred to as disambiguation of intent. A user may similarly select particular linked words (such as recognized named entities) in an OCRed document as explained in detail with reference to
FIG. 8 . - The user may alternatively or additionally wish to annotate particular search results. This annotation may be done in freeform style or in a structured format (422). The annotations may be descriptions of the result or may be reviews of the result. For example, they may indicate the name of subject(s) in the result, or they could indicate “this is a good book” or “this product broke within a year of purchase.” Another example of an annotation is a user-drawn bounding box around a sub-portion of the visual query and user-provided text identifying the object or subject inside the bounding box. User annotations are explained in more detail with reference to
FIG. 5 . - The user selections of search results and other annotations are sent to the server system (424). The
front end server 110 receives the selections and annotations and further processes them (426). If the information was a selection of an object, sub-region or term in an interactive results document, further information regarding that selection may be requested, as appropriate. For example, if the selection was of one visual result, more information about that visual result would be requested. If the selection was a word (either from the OCR server or from the Image-to-Terms server) a textual search of that word would be sent to the termquery server system 118. If the selection was of a person from a facial image recognition search system, that person's profile would be requested. If the selection was for a particular portion of an interactive search result document, the underlying visual query results would be requested. - If the server system receives an annotation, the annotation is stored in a query and
annotation database 116, explained with reference toFIG. 5 . Then the information from theannotation database 116 is periodically copied to individual annotation databases for one or more of the parallel server systems, as discussed below with reference toFIGS. 7-10 . -
FIG. 5 is a block diagram illustrating aclient system 102 in accordance with one embodiment of the present invention. Theclient system 102 typically includes one or more processing units (CPU's) 702, one or more network orother communications interfaces 704,memory 712, and one ormore communication buses 714 for interconnecting these components. Theclient system 102 includes auser interface 705. Theuser interface 705 includes adisplay device 706 and optionally includes an input means such as a keyboard, mouse, orother input buttons 708. Alternatively or in addition thedisplay device 706 includes a touchsensitive surface 709, in which case thedisplay 706/709 is a touch sensitive display. In client systems that have a touchsensitive display 706/709, a physical keyboard is optional (e.g., a soft keyboard may be displayed when keyboard entry is needed). Furthermore, some client systems use a microphone and voice recognition to supplement or replace the keyboard. Optionally, theclient 102 includes a GPS (global positioning satellite) receiver, or otherlocation detection apparatus 707 for determining the location of theclient system 102. In some embodiments, visual query search services are provided that require theclient system 102 to provide the visual query server system to receive location information indicating the location of theclient system 102. - The
client system 102 also includes animage capture device 710 such as a camera or scanner.Memory 712 includes high-speed random access memory, such as DRAM, SRAM, DDR RAM or other random access solid state memory devices; and may include non-volatile memory, such as one or more magnetic disk storage devices, optical disk storage devices, flash memory devices, or other non-volatile solid state storage devices.Memory 712 may optionally include one or more storage devices remotely located from the CPU(s) 702.Memory 712, or alternately the non-volatile memory device(s) withinmemory 712, comprises a non-transitory computer readable storage medium. In some embodiments,memory 712 or the computer readable storage medium ofmemory 712 stores the following programs, modules and data structures, or a subset thereof: -
- an
operating system 716 that includes procedures for handling various basic system services and for performing hardware dependent tasks; - a
network communication module 718 that is used for connecting theclient system 102 to other computers via the one or more communication network interfaces 704 (wired or wireless) and one or more communication networks, such as the Internet, other wide area networks, local area networks, metropolitan area networks, and so on; - a
image capture module 720 for processing a respective image captured by the image capture device/camera 710, where the respective image may be sent (e.g., by a client application module) as a visual query to the visual query server system; - one or more
client application modules 722 for handling various aspects of querying by image, including but not limited to: a query-by-image submission module 724 for submitting visual queries to the visual query server system; optionally a region ofinterest selection module 725 that detects a selection (such as a gesture on the touchsensitive display 706/709) of a region of interest in an image and prepares that region of interest as a visual query; aresults browser 726 for displaying the results of the visual query; and optionally anannotation module 728 with optional modules for structuredannotation text entry 730 such as filling in a form or for freeformannotation text entry 732, which can accept annotations from a variety of formats, and an image region selection module 734 (sometimes referred to herein as a result selection module) which allows a user to select a particular sub-portion of an image for annotation; - an optional content authoring application(s) 736 that allow a user to author a visual query by creating or editing an image rather than just capturing one via the
image capture device 710; optionally, one orsuch applications 736 may include instructions that enable a user to select a sub-portion of an image for use as a visual query; - an optional local
image analysis module 738 that pre-processes the visual query before sending it to the visual query server system. The local image analysis may recognize particular types of images, or sub-regions within an image. Examples of image types that may be recognized bysuch modules 738 include one or more of: facial type (facial image recognized within visual query), bar code type (bar code recognized within visual query), and text type (text recognized within visual query); and - additional
optional client applications 740 such as an email application, a phone application, a browser application, a mapping application, instant messaging application, social networking application etc. In some embodiments, the application corresponding to an appropriate actionable search result can be launched or accessed when the actionable search result is selected.
- an
- Optionally, the image
region selection module 734 which allows a user to select a particular sub-portion of an image for annotation, also allows the user to choose a search result as a “correct” hit without necessarily further annotating it. For example, the user may be presented with a top N number of facial recognition matches and may choose the correct person from that results list. For some search queries, more than one type of result will be presented, and the user will choose a type of result. For example, the image query may include a person standing next to a tree, but only the results regarding the person is of interest to the user. Therefore, theimage selection module 734 allows the user to indicate which type of image is the “correct” type—i.e., the type he is interested in receiving. The user may also wish to annotate the search result by adding personal comments or descriptive words using either the annotation text entry module 730 (for filling in a form) or freeform annotationtext entry module 732. - In some embodiments, the optional local
image analysis module 738 is a portion of the client application (108,FIG. 1 ). Furthermore, in some embodiments the optional localimage analysis module 738 includes one or more programs to perform local image analysis to pre-process or categorize the visual query or a portion thereof. For example, theclient application 722 may recognize that the image contains a bar code, a face, or text, prior to submitting the visual query to a search engine. In some embodiments, when the localimage analysis module 738 detects that the visual query contains a particular type of image, the module asks the user if they are interested in a corresponding type of search result. For example, the localimage analysis module 738 may detect a face based on its general characteristics (i.e., without determining which person's face) and provides immediate feedback to the user prior to sending the query on to the visual query server system. It may return a result like, “A face has been detected, are you interested in getting facial recognition matches for this face?” This may save time for the visual query server system (106,FIG. 1 ). For some visual queries, the front end visual query processing server (110,FIG. 1 ) only sends the visual query to thesearch system 112 corresponding to the type of image recognized by the localimage analysis module 738. In other embodiments, the visual query to thesearch system 112 may send the visual query to all of the search systems 112A-N, but will rank results from thesearch system 112 corresponding to the type of image recognized by the localimage analysis module 738. In some embodiments, the manner in which local image analysis impacts on operation of the visual query server system depends on the configuration of the client system, or configuration or processing parameters associated with either the user or the client system. Furthermore, the actual content of any particular visual query and the results produced by the local image analysis may cause different visual queries to be handled differently at either or both the client system and the visual query server system. - In some embodiments, bar code recognition is performed in two steps, with analysis of whether the visual query includes a bar code performed on the client system at the local
image analysis module 738. Then the visual query is passed to a bar code search system only if the client determines the visual query is likely to include a bar code. In other embodiments, the bar code search system processes every visual query. - Optionally, the
client system 102 includesadditional client applications 740. -
FIG. 6 is a block diagram illustrating a front end visual queryprocessing server system 110 in accordance with one embodiment of the present invention. Thefront end server 110 typically includes one or more processing units (CPU's) 802, one or more network orother communications interfaces 804,memory 812, and one ormore communication buses 814 for interconnecting these components.Memory 812 includes high-speed random access memory, such as DRAM, SRAM, DDR RAM or other random access solid state memory devices; and may include non-volatile memory, such as one or more magnetic disk storage devices, optical disk storage devices, flash memory devices, or other non-volatile solid state storage devices.Memory 812 may optionally include one or more storage devices remotely located from the CPU(s) 802.Memory 812, or alternately the non-volatile memory device(s) withinmemory 812, comprises a non-transitory computer readable storage medium. In some embodiments,memory 812 or the computer readable storage medium ofmemory 812 stores the following programs, modules and data structures, or a subset thereof: -
- an
operating system 816 that includes procedures for handling various basic system services and for performing hardware dependent tasks; - a
network communication module 818 that is used for connecting the frontend server system 110 to other computers via the one or more communication network interfaces 804 (wired or wireless) and one or more communication networks, such as the Internet, other wide area networks, local area networks, metropolitan area networks, and so on; - a
query manager 820 for handling the incoming visual queries from theclient system 102 and sending them to two or more parallel search systems; as described elsewhere in this document, in some special situations a visual query may be directed to just one of the search systems, such as when the visual query includes an client-generated instruction (e.g., “facial recognition search only”); - a
results filtering module 822 for optionally filtering the results from the one or more parallel search systems and sending the top or “relevant” results to theclient system 102 for presentation; - a results ranking and
formatting module 824 for optionally ranking the results from the one or more parallel search systems and for formatting the results for presentation; - a results
document creation module 826, is used when appropriate, to create an interactive search results document;module 826 may include sub-modules, including but not limited to a boundingbox creation module 828 and alink creation module 830; - a
label creation module 831 for creating labels that are visual identifiers of respective sub-portions of a visual query; - an
annotation module 832 for receiving annotations from a user and sending them to anannotation database 116; - an actionable
search results module 838 for generating, in response to a visual query, one or more actionable search result elements, each configured to launch a client-side action; examples of actionable search result elements are buttons to initiate a telephone call, to initiate email message, to map an address, to make a restaurant reservation, and to provide an option to purchase a product; and - a query and
annotation database 116 which comprises the database itself 834 and an index to thedatabase 836.
- an
- The results ranking and
formatting module 824 ranks the results returned from the one or more parallel search systems (112-A-112-N,FIG. 1 ). As already noted above, for some visual queries, only the results from one search system may be relevant. In such an instance, only the relevant search results from that one search system are ranked. For some visual queries, several types of search results may be relevant. In these instances, in some embodiments, the results ranking andformatting module 824 ranks all of the results from the search system having the most relevant result (e.g., the result with the highest relevance score) above the results for the less relevant search systems. In other embodiments, the results ranking andformatting module 824 ranks a top result from each relevant search system above the remaining results. In some embodiments, the results ranking andformatting module 824 ranks the results in accordance with a relevance score computed for each of the search results. For some visual queries, augmented textual queries are performed in addition to the searching on parallel visual search systems. In some embodiments, when textual queries are also performed, their results are presented in a manner visually distinctive from the visual search system results. - The results ranking and
formatting module 824 also formats the results. In some embodiments, the results are presented in a list format. In some embodiments, the results are presented by means of an interactive results document. In some embodiments, both an interactive results document and a list of results are presented. In some embodiments, the type of query dictates how the results are presented. For example, if more than one searchable subject is detected in the visual query, then an interactive results document is produced, while if only one searchable subject is detected the results will be displayed in list format only. - The results
document creation module 826 is used to create an interactive search results document. The interactive search results document may have one or more detected and searched subjects. The boundingbox creation module 828 creates a bounding box around one or more of the searched subjects. The bounding boxes may be rectangular boxes, or may outline the shape(s) of the subject(s). Thelink creation module 830 creates links to search results associated with their respective subject in the interactive search results document. In some embodiments, clicking within the bounding box area activates the corresponding link inserted by the link creation module. - The query and
annotation database 116 contains information that can be used to improve visual query results. In some embodiments, the user may annotate the image after the visual query results have been presented. Furthermore, in some embodiments the user may annotate the image before sending it to the visual query search system. Pre-annotation may help the visual query processing by focusing the results, or running text based searches on the annotated words in parallel with the visual query searches. In some embodiments, annotated versions of a picture can be made public (e.g., when the user has given permission for publication, for example by designating the image and annotation(s) as not private), so as to be returned as a potential image match hit. For example, if a user takes a picture of a flower and annotates the image by giving detailed genus and species information about that flower, the user may want that image to be presented to anyone who performs a visual query research looking for that flower. In some embodiments, the information from the query andannotation database 116 is periodically pushed to theparallel search systems 112, which incorporate relevant portions of the information (if any) into their respectiveindividual databases 114. -
FIG. 7 is a block diagram illustrating one of the parallel search systems utilized to process a visual query.FIG. 7 illustrates a “generic” server system 112-N in accordance with one embodiment of the present invention. This server system is generic only in that it represents any one of the visual query search servers 112-N. The generic server system 112-N typically includes one or more processing units (CPU's) 502, one or more network orother communications interfaces 504,memory 512, and one ormore communication buses 514 for interconnecting these components.Memory 512 includes high-speed random access memory, such as DRAM, SRAM, DDR RAM or other random access solid state memory devices; and may include non-volatile memory, such as one or more magnetic disk storage devices, optical disk storage devices, flash memory devices, or other non-volatile solid state storage devices.Memory 512 may optionally include one or more storage devices remotely located from the CPU(s) 502.Memory 512, or alternately the non-volatile memory device(s) withinmemory 512, comprises a non-transitory computer readable storage medium. In some embodiments,memory 512 or the computer readable storage medium ofmemory 512 stores the following programs, modules and data structures, or a subset thereof: -
- an
operating system 516 that includes procedures for handling various basic system services and for performing hardware dependent tasks; - a
network communication module 518 that is used for connecting the generic server system 112-N to other computers via the one or more communication network interfaces 504 (wired or wireless) and one or more communication networks, such as the Internet, other wide area networks, local area networks, metropolitan area networks, and so on; - a
search application 520 specific to the particular server system, it may for example be a bar code search application, a color recognition search application, a product recognition search application, an object-or-object category search application, or the like; - an
optional index 522 if the particular search application utilizes an index; - an
optional image database 524 for storing the images relevant to the particular search application, where the image data stored, if any, depends on the search process type; - an optional results ranking module 526 (sometimes called a relevance scoring module) for ranking the results from the search application, the ranking module may assign a relevancy score for each result from the search application, and if no results reach a pre-defined minimum score, may return a null or zero value score to the front end visual query processing server indicating that the results from this server system are not relevant; and
- an
annotation module 528 for receiving annotation information from an annotation database (116,FIG. 1 ) determining if any of the annotation information is relevant to the particular search application and incorporating any determined relevant portions of the annotation information into therespective annotation database 530.
- an
-
FIG. 8 is a block diagram illustrating an OCR search system 112-B utilized to process a visual query in accordance with one embodiment of the present invention. The OCR search system 112-B typically includes one or more processing units (CPU's) 602, one or more network orother communications interfaces 604,memory 612, and one ormore communication buses 614 for interconnecting these components.Memory 612 includes high-speed random access memory, such as DRAM, SRAM, DDR RAM or other random access solid state memory devices; and may include non-volatile memory, such as one or more magnetic disk storage devices, optical disk storage devices, flash memory devices, or other non-volatile solid state storage devices.Memory 612 may optionally include one or more storage devices remotely located from the CPU(s) 602.Memory 612, or alternately the non-volatile memory device(s) withinmemory 612, comprises a non-transitory computer readable storage medium. In some embodiments,memory 612 or the computer readable storage medium ofmemory 612 stores the following programs, modules and data structures, or a subset thereof: -
- an
operating system 616 that includes procedures for handling various basic system services and for performing hardware dependent tasks; - a
network communication module 618 that is used for connecting the OCR search system 112-B to other computers via the one or more communication network interfaces 604 (wired or wireless) and one or more communication networks, such as the Internet, other wide area networks, local area networks, metropolitan area networks, and so on; - an Optical Character Recognition (OCR)
module 620 which tries to recognize text in the visual query, and converts the images of letters into characters; - an optional OCR database 114-B which is utilized by the
OCR module 620 to recognize particular fonts, text patterns, and other characteristics unique to letter recognition; - an optional
spell check module 622 which improves the conversion of images of letters into characters by checking the converted words against a dictionary and replacing potentially mis-converted letters in words that otherwise match a dictionary word; - an optional named
entity recognition module 624 which searches for named entities within the converted text, sends the recognized named entities as terms in a term query to the term query server system (118,FIG. 1 ), and provides the results from the term query server system as links embedded in the OCRed text associated with the recognized named entities; - an optional
text match application 632 which improves the conversion of images of letters into characters by checking converted segments (such as converted sentences and paragraphs) against a database of text segments and replacing potentially mis-converted letters in OCRed text segments that otherwise match a text match application text segment, in some embodiments the text segment found by the text match application is provided as a link to the user (for example, if the user scanned one page of the New York Times, the text match application may provide a link to the entire posted article on the New York Times website); - a results ranking and
formatting module 626 for formatting the OCRed results for presentation and formatting optional links to named entities, and also optionally ranking any related results from the text match application; and - an
optional annotation module 628 for receiving annotation information from an annotation database (116,FIG. 1 ) determining if any of the annotation information is relevant to the OCR search system and incorporating any determined relevant portions of the annotation information into therespective annotation database 630.
- an
-
FIG. 9 is a block diagram illustrating a facial recognition search system 112-A utilized to process a visual query in accordance with one embodiment of the present invention. The facial recognition search system 112-A typically includes one or more processing units (CPU's) 902, one or more network orother communications interfaces 904,memory 912, and one ormore communication buses 914 for interconnecting these components.Memory 912 includes high-speed random access memory, such as DRAM, SRAM, DDR RAM or other random access solid state memory devices; and may include non-volatile memory, such as one or more magnetic disk storage devices, optical disk storage devices, flash memory devices, or other non-volatile solid state storage devices.Memory 912 may optionally include one or more storage devices remotely located from the CPU(s) 902.Memory 912, or alternately the non-volatile memory device(s) withinmemory 912, comprises a non-transitory computer readable storage medium. In some embodiments,memory 912 or the computer readable storage medium ofmemory 912 stores the following programs, modules and data structures, or a subset thereof: -
- an
operating system 916 that includes procedures for handling various basic system services and for performing hardware dependent tasks; - a
network communication module 918 that is used for connecting the facial recognition search system 112-A to other computers via the one or more communication network interfaces 904 (wired or wireless) and one or more communication networks, such as the Internet, other wide area networks, local area networks, metropolitan area networks, and so on; - a facial
recognition search application 920 for searching for facial images matching the face(s) presented in the visual query in a facial image database 114-A and searches thesocial network database 922 for information regarding each match found in the facial image database 114-A. - a facial image database 114-A for storing one or more facial images for a plurality of users; optionally, the facial image database includes facial images for people other than users, such as family members and others known by users and who have been identified as being present in images included in the facial image database 114-A; optionally, the facial image database includes facial images obtained from external sources, such as vendors of facial images that are legally in the public domain;
- optionally, a
social network database 922 which contains information regarding users of the social network such as name, address, occupation, group memberships, social network connections, current GPS location of mobile device, share preferences, interests, age, hometown, personal statistics, work information, etc. as discussed in more detail with reference toFIG. 12A ; - a results ranking and
formatting module 924 for ranking (e.g., assigning a relevance and/or match quality score to) the potential facial matches from the facial image database 114-A and formatting the results for presentation; in some embodiments, the ranking or scoring of results utilizes related information retrieved from the aforementioned social network database; in some embodiment, the search formatted results include the potential image matches as well as a subset of information from the social network database; and - an
annotation module 926 for receiving annotation information from an annotation database (116,FIG. 1 ) determining if any of the annotation information is relevant to the facial recognition search system and storing any determined relevant portions of the annotation information into therespective annotation database 928.
- an
-
FIG. 10 is a block diagram illustrating an image-to-terms search system 112-C utilized to process a visual query in accordance with one embodiment of the present invention. In some embodiments, the image-to-terms search system recognizes objects (instance recognition) in the visual query. In other embodiments, the image-to-terms search system recognizes object categories (type recognition) in the visual query. In some embodiments, the image to terms system recognizes both objects and object-categories. The image-to-terms search system returns potential term matches for images in the visual query. The image-to-terms search system 112-C typically includes one or more processing units (CPU's) 1002, one or more network orother communications interfaces 1004,memory 1012, and one ormore communication buses 1014 for interconnecting these components.Memory 1012 includes high-speed random access memory, such as DRAM, SRAM, DDR RAM or other random access solid state memory devices; and may include non-volatile memory, such as one or more magnetic disk storage devices, optical disk storage devices, flash memory devices, or other non-volatile solid state storage devices.Memory 1012 may optionally include one or more storage devices remotely located from the CPU(s) 1002.Memory 1012, or alternately the non-volatile memory device(s) withinmemory 1012, comprises a non-transitory computer readable storage medium. In some embodiments,memory 1012 or the computer readable storage medium ofmemory 1012 stores the following programs, modules and data structures, or a subset thereof: -
- an
operating system 1016 that includes procedures for handling various basic system services and for performing hardware dependent tasks; - a
network communication module 1018 that is used for connecting the image-to-terms search system 112-C to other computers via the one or more communication network interfaces 1004 (wired or wireless) and one or more communication networks, such as the Internet, other wide area networks, local area networks, metropolitan area networks, and so on; - a image-to-
terms search application 1020 that searches for images matching the subject or subjects in the visual query in the image search database 114-C; - an image search database 114-C which can be searched by the
search application 1020 to find images similar to the subject(s) of the visual query; - a terms-to-
image inverse index 1022, which stores the textual terms used by users when searching for images using a text basedquery search engine 1006; - a results ranking and
formatting module 1024 for ranking the potential image matches and/or ranking terms associated with the potential image matches identified in the terms-to-image inverse index 1022; and - an
annotation module 1026 for receiving annotation information from an annotation database (116,FIG. 1 ) determining if any of the annotation information is relevant to the image-to terms search system 112-C and storing any determined relevant portions of the annotation information into therespective annotation database 1028.
- an
-
FIGS. 5-10 are intended more as functional descriptions of the various features which may be present in a set of computer systems than as a structural schematic of the embodiments described herein. In practice, and as recognized by those of ordinary skill in the art, items shown separately could be combined and some items could be separated. For example, some items shown separately in these figures could be implemented on single servers and single items could be implemented by one or more servers. The actual number of systems used to implement visual query processing and how features are allocated among them will vary from one implementation to another. - Each of the methods described herein may be governed by instructions that are stored in a non-transitory computer readable storage medium and that are executed by one or more processors of one or more servers or clients. The above identified modules or programs (i.e., sets of instructions) need not be implemented as separate software programs, procedures or modules, and thus various subsets of these modules may be combined or otherwise re-arranged in various embodiments. Each of the operations shown in
FIGS. 5-10 may correspond to instructions stored in a computer memory or non-transitory computer readable storage medium. -
FIG. 11 illustrates aclient system 102 with a screen shot of an exemplaryvisual query 1102. Theclient system 102 shown inFIG. 11 is a mobile device such as a cellular telephone, portable music player, or portable emailing device. Theclient system 102 includes adisplay 706 and one or more input means 708 such the buttons shown in this figure. In some embodiments, thedisplay 706 is a touchsensitive display 709. In embodiments having a touchsensitive display 709, soft buttons displayed on thedisplay 709 may optionally replace some or all of theelectromechanical buttons 708. Touch sensitive displays are also helpful in interacting with the visual query results as explained in more detail below. Theclient system 102 also includes an image capture mechanism such as acamera 710. -
FIG. 11 illustrates avisual query 1102 which is a photograph or video frame of a package on a shelf of a store. In the embodiments described here, the visual query is a two dimensional image having a resolution corresponding to the size of the visual query in pixels in each of two dimensions. Thevisual query 1102 in this example is a two dimensional image of three dimensional objects. Thevisual query 1102 includes background elements, aproduct package 1104, and a variety of types of entities on the package including an image of aperson 1106, an image of atrademark 1108, an image of aproduct 1110, and a variety oftextual elements 1112. - As explained with reference to
FIG. 3 , thevisual query 1102 is sent to thefront end server 110, which sends thevisual query 1102 to a plurality of parallel search systems (112A-N), receives the results and creates an interactive results document. -
FIGS. 12A and 12B each illustrate aclient system 102 with a screen shot of an embodiment of an interactive results document 1200. The interactive results document 1200 includes one or morevisual identifiers 1202 of respective sub-portions of thevisual query 1102, which each include a user selectable link to a subset of search results.FIGS. 12A and 12B illustrate an interactive results document 1200 with visual identifiers that are bounding boxes 1202 (e.g., bounding boxes 1202-1, 1202-2, 1202-3). In the embodiments shown inFIGS. 12A and 12B , the user activates the display of the search results corresponding to a particular sub-portion by tapping on the activation region inside the space outlined by itsbounding box 1202. For example, the user would activate the search results corresponding to the image of the person, by tapping on a bounding box 1306 (FIG. 13 ) surrounding the image of the person. In other embodiments, the selectable link is selected using a mouse or keyboard rather than a touch sensitive display. In some embodiments, the first corresponding search result is displayed when a user previews a bounding box 1202 (i.e., when the user single clicks, taps once, or hovers a pointer over the bounding box). The user activates the display of a plurality of corresponding search results when the user selects the bounding box (i.e., when the user double clicks, taps twice, or uses another mechanism to indicate selection.) - In
FIGS. 12A and 12B the visual identifiers are boundingboxes 1202 surrounding sub-portions of the visual query.FIG. 12A illustrates boundingboxes 1202 that are square or rectangular.FIG. 12B illustrates abounding box 1202 that outlines the boundary of an identifiable entity in the sub-portion of the visual query, such as the bounding box 1202-3 for a drink bottle. In some embodiments, arespective bounding box 1202 includessmaller bounding boxes 1202 within it. For example, inFIGS. 12A and 12B , the bounding box identifying the package 1202-1 surrounds the bounding box identifying the trademark 1202-2 and all of theother bounding boxes 1202. In some embodiments that include text, also include activehot links 1204 for some of the textual terms.FIG. 12B shows an example where “Active Drink” and “United States” are displayed ashot links 1204. The search results corresponding to these terms are the results received from the termquery server system 118, whereas the results corresponding to the bounding boxes are results from the query by image search systems. -
FIG. 13 illustrates aclient system 102 with a screen shot of an interactive results document 1200 that is coded by type of recognized entity in the visual query. The visual query ofFIG. 11 contains an image of aperson 1106, an image of atrademark 1108, an image of aproduct 1110, and a variety oftextual elements 1112. As such the interactive results document 1200 displayed inFIG. 13 includes boundingboxes 1202 around aperson 1306, atrademark 1308, aproduct 1310, and the twotextual areas 1312. The bounding boxes ofFIG. 13 are each presented with separate cross-hatching which represents differently coloredtransparent bounding boxes 1202. In some embodiments, the visual identifiers of the bounding boxes (and/or labels or other visual identifiers in the interactive results document 1200) are formatted for presentation in visually distinctive manners such as overlay color, overlay pattern, label background color, label background pattern, label font color, and bounding box border color. The type coding for particular recognized entities is shown with respect to bounding boxes inFIG. 13 , but coding by type can also be applied to visual identifiers that are labels. -
FIG. 14 illustrates aclient device 102 with a screen shot of an interactive results document 1200 withlabels 1402 being the visual identifiers of respective sub-portions of thevisual query 1102 ofFIG. 11 . The labelvisual identifiers 1402 each include a user selectable link to a subset of corresponding search results. In some embodiments, the selectable link is identified by descriptive text displayed within the area of thelabel 1402. Some embodiments include a plurality of links within onelabel 1402. For example, inFIG. 14 , the label hovering over the image of a woman drinking includes a link to facial recognition results for the woman and a link to image recognition results for that particular picture (e.g., images of other products or advertisements using the same picture.) - In
FIG. 14 , thelabels 1402 are displayed as partially transparent areas with text that are located over their respective sub-portions of the interactive results document. In other embodiments, a respective label is positioned near but not located over its respective sub-portion of the interactive results document. In some embodiments, the labels are coded by type in the same manner as discussed with reference toFIG. 13 . In some embodiments, the user activates the display of the search results corresponding to a particular sub-portion corresponding to a label 1302 by tapping on the activation region inside the space outlined by the edges or periphery of the label 1302. The same previewing and selection functions discussed above with reference to the bounding boxes ofFIGS. 12A and 12B also apply to the visual identifiers that are labels 1402. -
FIG. 15 illustrates a screen shot of an interactive results document 1200 and the originalvisual query 1102 displayed concurrently with aresults list 1500. In some embodiments, the interactive results document 1200 is displayed by itself as shown inFIGS. 12-14 . In other embodiments, the interactive results document 1200 is displayed concurrently with the original visual query as shown inFIG. 15 . In some embodiments, the list of visual query results 1500 is concurrently displayed along with the originalvisual query 1102 and/or the interactive results document 1200. The type of client system and the amount of room on thedisplay 706 may determine whether the list ofresults 1500 is displayed concurrently with the interactive results document 1200. In some embodiments, theclient system 102 receives (in response to a visual query submitted to the visual query server system) both the list ofresults 1500 and the interactive results document 1200, but only displays the list ofresults 1500 when the user scrolls below the interactive results document 1200. In some of these embodiments, theclient system 102 displays the results corresponding to a user selectedvisual identifier 1202/1402 without needing to query the server again because the list ofresults 1500 is received by theclient system 102 in response to the visual query and then stored locally at theclient system 102. - In some embodiments, the list of
results 1500 is organized intocategories 1502. Each category contains at least oneresult 1503. In some embodiments, the categories titles are highlighted to distinguish them from theresults 1503. Thecategories 1502 are ordered according to their calculated category weight. In some embodiments, the category weight is a combination of the weights of the highest N results in that category. As such, the category that has likely produced more relevant results is displayed first. In embodiments where more than onecategory 1502 is returned for the same recognized entity (such as the facial image recognition match and the image match shown inFIG. 15 ) the category displayed first has a higher category weight. - As explained with respect to
FIG. 3 , in some embodiments, when a selectable link in the interactive results document 1200 is selected by a user of theclient system 102, the cursor will automatically move to theappropriate category 1502 or to thefirst result 1503 in that category. Alternatively, when a selectable link in the interactive results document is selected by a user of theclient system 102, the list ofresults 1500 is re-ordered such that the category or categories relevant to the selected link are displayed first. This is accomplished, for example, by either coding the selectable links with information identifying the corresponding search results, or by coding the search results to indicate the corresponding selectable links or to indicate the corresponding result categories. - In some embodiments, the categories of the search results correspond to the query-by-image search system that produce those search results. For example, in
FIG. 15 some of the categories areproduct match 1506,logo match 1508,facial recognition match 1510,image match 1512. The originalvisual query 1102 and/or an interactive results document 1200 may be similarly displayed with a category title such as thequery 1504. Similarly, results from any term search performed by the term query server may also be displayed as a separate category, such as web results 1514. In other embodiments, more than one entity in a visual query will produce results from the same query-by-image search system. For example, the visual query could include two different faces that would return separate results from the facial recognition search system. As such, in some embodiments, thecategories 1502 are divided by recognized entity rather than by search system. In some embodiments, an image of the recognized entity is displayed in the recognizedentity category header 1502 such that the results for that recognized entity are distinguishable from the results for another recognized entity, even though both results are produced by the same query by image search system. For example, inFIG. 15 , theproduct match category 1506 includes two entity product entities and as such as twoentity categories 1502—a boxedproduct 1516 and abottled product 1518, each of which have a plurality of corresponding search results 1503. In some embodiments, the categories may be divided by recognized entities and type of query-by-image system. For example, inFIG. 15 , there are two separate entities that returned relevant results under the product match category product. - In some embodiments, the
results 1503 include thumbnail images. For example, as shown for the facial recognition match results inFIG. 15 , small versions (also called thumbnail images) of the pictures of the facial matches for “Actress X” and “Social Network Friend Y” are displayed along with some textual description such as the name of the person in the image. - The foregoing description, for purpose of explanation, has been described with reference to specific embodiments. However, the illustrative discussions above are not intended to be exhaustive or to limit the invention to the precise forms disclosed. Many modifications and variations are possible in view of the above teachings. The embodiments were chosen and described in order to best explain the principles of the invention and its practical applications, to thereby enable others skilled in the art to best utilize the invention and various embodiments with various modifications as are suited to the particular use contemplated.
Claims (21)
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US16/131,004 US20190012334A1 (en) | 2009-08-07 | 2018-09-13 | Architecture for Responding to Visual Query |
Applications Claiming Priority (5)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US23239709P | 2009-08-07 | 2009-08-07 | |
US26611609P | 2009-12-02 | 2009-12-02 | |
US12/850,483 US9135277B2 (en) | 2009-08-07 | 2010-08-04 | Architecture for responding to a visual query |
US14/183,001 US10534808B2 (en) | 2009-08-07 | 2014-02-18 | Architecture for responding to visual query |
US16/131,004 US20190012334A1 (en) | 2009-08-07 | 2018-09-13 | Architecture for Responding to Visual Query |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/183,001 Continuation US10534808B2 (en) | 2009-08-07 | 2014-02-18 | Architecture for responding to visual query |
Publications (1)
Publication Number | Publication Date |
---|---|
US20190012334A1 true US20190012334A1 (en) | 2019-01-10 |
Family
ID=42752283
Family Applications (3)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/850,483 Active 2031-03-28 US9135277B2 (en) | 2009-08-07 | 2010-08-04 | Architecture for responding to a visual query |
US14/183,001 Expired - Fee Related US10534808B2 (en) | 2009-08-07 | 2014-02-18 | Architecture for responding to visual query |
US16/131,004 Abandoned US20190012334A1 (en) | 2009-08-07 | 2018-09-13 | Architecture for Responding to Visual Query |
Family Applications Before (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/850,483 Active 2031-03-28 US9135277B2 (en) | 2009-08-07 | 2010-08-04 | Architecture for responding to a visual query |
US14/183,001 Expired - Fee Related US10534808B2 (en) | 2009-08-07 | 2014-02-18 | Architecture for responding to visual query |
Country Status (9)
Country | Link |
---|---|
US (3) | US9135277B2 (en) |
EP (1) | EP2462520B1 (en) |
JP (3) | JP2013501975A (en) |
KR (2) | KR101667346B1 (en) |
CN (1) | CN102625937B (en) |
AU (2) | AU2010279333B2 (en) |
BR (1) | BR112012002815B8 (en) |
CA (2) | CA3068761C (en) |
WO (1) | WO2011017557A1 (en) |
Cited By (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10534808B2 (en) | 2009-08-07 | 2020-01-14 | Google Llc | Architecture for responding to visual query |
WO2022158667A1 (en) * | 2021-01-19 | 2022-07-28 | Samsung Electronics Co., Ltd. | Method and system for displaying a video poster based on artificial intelligence |
US20230039682A1 (en) * | 2021-08-09 | 2023-02-09 | Coupang Corp. | Operating Method for Electronic Apparatus for Providing Search Information and Electronic Apparatus Thereof |
US11604820B2 (en) | 2018-08-08 | 2023-03-14 | Samsung Electronics Co., Ltd. | Method for providing information related to goods on basis of priority and electronic device therefor |
US11853108B2 (en) | 2017-10-27 | 2023-12-26 | Samsung Electronics Co., Ltd. | Electronic apparatus for searching related image and control method therefor |
Families Citing this family (186)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20090327235A1 (en) * | 2008-06-27 | 2009-12-31 | Google Inc. | Presenting references with answers in forums |
US8463053B1 (en) | 2008-08-08 | 2013-06-11 | The Research Foundation Of State University Of New York | Enhanced max margin learning on multimodal data mining in a multimedia database |
EP2341450A1 (en) * | 2009-08-21 | 2011-07-06 | Mikko Kalervo Väänänen | Method and means for data searching and language translation |
US9197736B2 (en) | 2009-12-31 | 2015-11-24 | Digimarc Corporation | Intuitive computing methods and systems |
US8121618B2 (en) * | 2009-10-28 | 2012-02-21 | Digimarc Corporation | Intuitive computing methods and systems |
US9176986B2 (en) | 2009-12-02 | 2015-11-03 | Google Inc. | Generating a combination of a visual query and matching canonical document |
US9405772B2 (en) | 2009-12-02 | 2016-08-02 | Google Inc. | Actionable search results for street view visual queries |
US9852156B2 (en) | 2009-12-03 | 2017-12-26 | Google Inc. | Hybrid use of location sensor data and visual query to return local listings for visual query |
WO2011082332A1 (en) | 2009-12-31 | 2011-07-07 | Digimarc Corporation | Methods and arrangements employing sensor-equipped smart phones |
US8600173B2 (en) * | 2010-01-27 | 2013-12-03 | Dst Technologies, Inc. | Contextualization of machine indeterminable information based on machine determinable information |
WO2012050251A1 (en) * | 2010-10-14 | 2012-04-19 | 엘지전자 주식회사 | Mobile terminal and method for controlling same |
US8861896B2 (en) * | 2010-11-29 | 2014-10-14 | Sap Se | Method and system for image-based identification |
US8995775B2 (en) * | 2011-05-02 | 2015-03-31 | Facebook, Inc. | Reducing photo-tagging spam |
JP5316582B2 (en) * | 2011-05-23 | 2013-10-16 | コニカミノルタ株式会社 | Image processing system, image processing device, terminal device, and control program |
EP2533141A1 (en) * | 2011-06-07 | 2012-12-12 | Amadeus S.A.S. | A personal information display system and associated method |
JP5830784B2 (en) * | 2011-06-23 | 2015-12-09 | サイバーアイ・エンタテインメント株式会社 | Interest graph collection system by relevance search with image recognition system |
KR101814120B1 (en) * | 2011-08-26 | 2018-01-03 | 에스프린팅솔루션 주식회사 | Method and apparatus for inserting image to electrical document |
CN103918247B (en) | 2011-09-23 | 2016-08-24 | 数字标记公司 | Intelligent mobile phone sensor logic based on background environment |
US9305108B2 (en) | 2011-10-05 | 2016-04-05 | Google Inc. | Semantic selection and purpose facilitation |
US8890827B1 (en) | 2011-10-05 | 2014-11-18 | Google Inc. | Selected content refinement mechanisms |
US9652556B2 (en) | 2011-10-05 | 2017-05-16 | Google Inc. | Search suggestions based on viewport content |
US8878785B1 (en) | 2011-10-05 | 2014-11-04 | Google Inc. | Intent determination using geometric shape input |
US9032316B1 (en) | 2011-10-05 | 2015-05-12 | Google Inc. | Value-based presentation of user-selectable computing actions |
US8825671B1 (en) * | 2011-10-05 | 2014-09-02 | Google Inc. | Referent determination from selected content |
US10013152B2 (en) | 2011-10-05 | 2018-07-03 | Google Llc | Content selection disambiguation |
US8589410B2 (en) | 2011-10-18 | 2013-11-19 | Microsoft Corporation | Visual search using multiple visual input modalities |
EP2587745A1 (en) | 2011-10-26 | 2013-05-01 | Swisscom AG | A method and system of obtaining contact information for a person or an entity |
TWI451347B (en) * | 2011-11-17 | 2014-09-01 | Univ Nat Chiao Tung | Goods data searching system and method thereof |
US8891907B2 (en) * | 2011-12-06 | 2014-11-18 | Google Inc. | System and method of identifying visual objects |
JP6153086B2 (en) | 2011-12-14 | 2017-06-28 | 日本電気株式会社 | Video processing system, video processing method, video processing apparatus for portable terminal or server, and control method and control program therefor |
JP2015062090A (en) * | 2011-12-15 | 2015-04-02 | 日本電気株式会社 | Video processing system, video processing method, video processing device for portable terminal or server, and control method and control program of the same |
US10115127B2 (en) | 2011-12-16 | 2018-10-30 | Nec Corporation | Information processing system, information processing method, communications terminals and control method and control program thereof |
US10146795B2 (en) * | 2012-01-12 | 2018-12-04 | Kofax, Inc. | Systems and methods for mobile image capture and processing |
US8855375B2 (en) | 2012-01-12 | 2014-10-07 | Kofax, Inc. | Systems and methods for mobile image capture and processing |
US8620021B2 (en) | 2012-03-29 | 2013-12-31 | Digimarc Corporation | Image-related methods and arrangements |
US8935246B2 (en) * | 2012-08-08 | 2015-01-13 | Google Inc. | Identifying textual terms in response to a visual query |
US8868598B2 (en) * | 2012-08-15 | 2014-10-21 | Microsoft Corporation | Smart user-centric information aggregation |
CN102902771A (en) * | 2012-09-27 | 2013-01-30 | 百度国际科技(深圳)有限公司 | Method, device and server for searching pictures |
CN102930263A (en) * | 2012-09-27 | 2013-02-13 | 百度国际科技(深圳)有限公司 | Information processing method and device |
US8990194B2 (en) * | 2012-11-02 | 2015-03-24 | Google Inc. | Adjusting content delivery based on user submissions of photographs |
US20140149257A1 (en) * | 2012-11-28 | 2014-05-29 | Jim S. Baca | Customized Shopping |
US9298712B2 (en) * | 2012-12-13 | 2016-03-29 | Microsoft Technology Licensing, Llc | Content and object metadata based search in e-reader environment |
KR20150140644A (en) * | 2013-02-08 | 2015-12-16 | 이모션트 | Collection of machine learning training data for expression recognition |
US10235358B2 (en) * | 2013-02-21 | 2019-03-19 | Microsoft Technology Licensing, Llc | Exploiting structured content for unsupervised natural language semantic parsing |
US9208176B2 (en) * | 2013-03-12 | 2015-12-08 | International Business Machines Corporation | Gesture-based image shape filtering |
US9355312B2 (en) | 2013-03-13 | 2016-05-31 | Kofax, Inc. | Systems and methods for classifying objects in digital images captured using mobile devices |
US9258597B1 (en) | 2013-03-13 | 2016-02-09 | Google Inc. | System and method for obtaining information relating to video images |
US10127636B2 (en) | 2013-09-27 | 2018-11-13 | Kofax, Inc. | Content-based detection and three dimensional geometric reconstruction of objects in image and video data |
US9247309B2 (en) | 2013-03-14 | 2016-01-26 | Google Inc. | Methods, systems, and media for presenting mobile content corresponding to media content |
US9705728B2 (en) | 2013-03-15 | 2017-07-11 | Google Inc. | Methods, systems, and media for media transmission and management |
US20140316841A1 (en) | 2013-04-23 | 2014-10-23 | Kofax, Inc. | Location-based workflows and services |
US20140330814A1 (en) * | 2013-05-03 | 2014-11-06 | Tencent Technology (Shenzhen) Company Limited | Method, client of retrieving information and computer storage medium |
NZ630397A (en) * | 2013-05-21 | 2017-06-30 | Fmp Group (Australia) Pty Ltd | Image recognition of vehicle parts |
US10176500B1 (en) * | 2013-05-29 | 2019-01-08 | A9.Com, Inc. | Content classification based on data recognition |
US9952042B2 (en) * | 2013-07-12 | 2018-04-24 | Magic Leap, Inc. | Method and system for identifying a user location |
GB201314642D0 (en) * | 2013-08-15 | 2013-10-02 | Summerfield Gideon | Image Identification System and Method |
CN104424257A (en) * | 2013-08-28 | 2015-03-18 | 北大方正集团有限公司 | Information indexing unit and information indexing method |
CN103455590B (en) * | 2013-08-29 | 2017-05-31 | 百度在线网络技术(北京)有限公司 | The method and apparatus retrieved in touch-screen equipment |
US11853377B2 (en) * | 2013-09-11 | 2023-12-26 | See-Out Pty Ltd | Image searching method and apparatus |
US10095833B2 (en) * | 2013-09-22 | 2018-10-09 | Ricoh Co., Ltd. | Mobile information gateway for use by medical personnel |
WO2015073920A1 (en) | 2013-11-15 | 2015-05-21 | Kofax, Inc. | Systems and methods for generating composite images of long documents using mobile video data |
US9491522B1 (en) | 2013-12-31 | 2016-11-08 | Google Inc. | Methods, systems, and media for presenting supplemental content relating to media content on a content interface based on state information that indicates a subsequent visit to the content interface |
US10002191B2 (en) | 2013-12-31 | 2018-06-19 | Google Llc | Methods, systems, and media for generating search results based on contextual information |
US9456237B2 (en) | 2013-12-31 | 2016-09-27 | Google Inc. | Methods, systems, and media for presenting supplemental information corresponding to on-demand media content |
US9411825B2 (en) * | 2013-12-31 | 2016-08-09 | Streamoid Technologies Pvt. Ltd. | Computer implemented system for handling text distracters in a visual search |
US10360907B2 (en) | 2014-01-14 | 2019-07-23 | Toyota Motor Engineering & Manufacturing North America, Inc. | Smart necklace with stereo vision and onboard processing |
US9915545B2 (en) | 2014-01-14 | 2018-03-13 | Toyota Motor Engineering & Manufacturing North America, Inc. | Smart necklace with stereo vision and onboard processing |
US10024679B2 (en) | 2014-01-14 | 2018-07-17 | Toyota Motor Engineering & Manufacturing North America, Inc. | Smart necklace with stereo vision and onboard processing |
US10248856B2 (en) | 2014-01-14 | 2019-04-02 | Toyota Motor Engineering & Manufacturing North America, Inc. | Smart necklace with stereo vision and onboard processing |
KR101791518B1 (en) | 2014-01-23 | 2017-10-30 | 삼성전자주식회사 | Method and apparatus for verifying user |
US9832353B2 (en) | 2014-01-31 | 2017-11-28 | Digimarc Corporation | Methods for encoding, decoding and interpreting auxiliary data in media signals |
WO2015125025A2 (en) | 2014-02-10 | 2015-08-27 | Geenee Ug | Systems and methods for image-feature-based recognition |
US9311639B2 (en) | 2014-02-11 | 2016-04-12 | Digimarc Corporation | Methods, apparatus and arrangements for device to device communication |
US9811592B1 (en) | 2014-06-24 | 2017-11-07 | Google Inc. | Query modification based on textual resource context |
US9830391B1 (en) | 2014-06-24 | 2017-11-28 | Google Inc. | Query modification based on non-textual resource context |
US9582482B1 (en) | 2014-07-11 | 2017-02-28 | Google Inc. | Providing an annotation linking related entities in onscreen content |
US10062099B2 (en) * | 2014-07-25 | 2018-08-28 | Hewlett Packard Enterprise Development Lp | Product identification based on location associated with image of product |
KR101690528B1 (en) * | 2015-06-05 | 2016-12-28 | 오드컨셉 주식회사 | Method, apparatus and computer program for displaying serch information |
US10024667B2 (en) | 2014-08-01 | 2018-07-17 | Toyota Motor Engineering & Manufacturing North America, Inc. | Wearable earpiece for providing social and environmental awareness |
US9965559B2 (en) | 2014-08-21 | 2018-05-08 | Google Llc | Providing automatic actions for mobile onscreen content |
JP6220079B2 (en) * | 2014-09-08 | 2017-10-25 | 日本電信電話株式会社 | Display control apparatus, display control method, and display control program |
US9922236B2 (en) * | 2014-09-17 | 2018-03-20 | Toyota Motor Engineering & Manufacturing North America, Inc. | Wearable eyeglasses for providing social and environmental awareness |
US10024678B2 (en) | 2014-09-17 | 2018-07-17 | Toyota Motor Engineering & Manufacturing North America, Inc. | Wearable clip for providing social and environmental awareness |
US9760788B2 (en) | 2014-10-30 | 2017-09-12 | Kofax, Inc. | Mobile document detection and orientation based on reference object characteristics |
CN104391938B (en) * | 2014-11-24 | 2017-10-10 | 武汉海川云谷软件技术有限公司 | A kind of picture batch in physical assets management imports the method and system of database |
CN104615639B (en) * | 2014-11-28 | 2018-08-24 | 北京百度网讯科技有限公司 | A kind of method and apparatus for providing the presentation information of picture |
CN104536995B (en) * | 2014-12-12 | 2016-05-11 | 北京奇虎科技有限公司 | The method and system of searching for based on terminal interface touch control operation |
CN104572986A (en) * | 2015-01-04 | 2015-04-29 | 百度在线网络技术(北京)有限公司 | Information searching method and device |
US11120478B2 (en) | 2015-01-12 | 2021-09-14 | Ebay Inc. | Joint-based item recognition |
US20160217157A1 (en) * | 2015-01-23 | 2016-07-28 | Ebay Inc. | Recognition of items depicted in images |
US10490102B2 (en) | 2015-02-10 | 2019-11-26 | Toyota Motor Engineering & Manufacturing North America, Inc. | System and method for braille assistance |
US9586318B2 (en) | 2015-02-27 | 2017-03-07 | Toyota Motor Engineering & Manufacturing North America, Inc. | Modular robot with smart device |
US9811752B2 (en) | 2015-03-10 | 2017-11-07 | Toyota Motor Engineering & Manufacturing North America, Inc. | Wearable smart device and method for redundant object identification |
US9972216B2 (en) | 2015-03-20 | 2018-05-15 | Toyota Motor Engineering & Manufacturing North America, Inc. | System and method for storing and playback of information for blind users |
US9922271B2 (en) | 2015-03-20 | 2018-03-20 | Netra, Inc. | Object detection and classification |
US9760792B2 (en) | 2015-03-20 | 2017-09-12 | Netra, Inc. | Object detection and classification |
CN104794220A (en) * | 2015-04-28 | 2015-07-22 | 百度在线网络技术(北京)有限公司 | Information search method and information search device |
US9703541B2 (en) | 2015-04-28 | 2017-07-11 | Google Inc. | Entity action suggestion on a mobile device |
US10062015B2 (en) | 2015-06-25 | 2018-08-28 | The Nielsen Company (Us), Llc | Methods and apparatus for identifying objects depicted in a video using extracted video frames in combination with a reverse image search engine |
AU2016277553B2 (en) * | 2015-06-26 | 2022-02-17 | Rovi Guides, Inc. | Systems and methods for automatic formatting of images for media assets based on user profile |
US10628009B2 (en) | 2015-06-26 | 2020-04-21 | Rovi Guides, Inc. | Systems and methods for automatic formatting of images for media assets based on user profile |
CN105518678B (en) * | 2015-06-29 | 2018-07-31 | 北京旷视科技有限公司 | Searching method, searcher and user equipment |
US10769200B1 (en) * | 2015-07-01 | 2020-09-08 | A9.Com, Inc. | Result re-ranking for object recognition |
US10242285B2 (en) | 2015-07-20 | 2019-03-26 | Kofax, Inc. | Iterative recognition-guided thresholding and data extraction |
CN105069083B (en) | 2015-07-31 | 2019-03-08 | 小米科技有限责任公司 | The determination method and device of association user |
US9898039B2 (en) | 2015-08-03 | 2018-02-20 | Toyota Motor Engineering & Manufacturing North America, Inc. | Modular smart necklace |
WO2017020139A1 (en) * | 2015-08-03 | 2017-02-09 | Orand S.A. | System and method for searching for products in catalogues |
ITUB20153277A1 (en) * | 2015-08-28 | 2017-02-28 | St Microelectronics Srl | PROCEDURE FOR VISUAL VISA, SYSTEM, EQUIPMENT AND COMPUTER PRODUCT |
US10970646B2 (en) | 2015-10-01 | 2021-04-06 | Google Llc | Action suggestions for user-selected content |
US11055343B2 (en) | 2015-10-05 | 2021-07-06 | Pinterest, Inc. | Dynamic search control invocation and visual search |
US11609946B2 (en) * | 2015-10-05 | 2023-03-21 | Pinterest, Inc. | Dynamic search input selection |
JP6204957B2 (en) * | 2015-10-15 | 2017-09-27 | ヤフー株式会社 | Information processing apparatus, information processing method, and information processing program |
US20180004845A1 (en) * | 2015-10-16 | 2018-01-04 | Carlos A. Munoz | Web Based Information Search Method |
US10178527B2 (en) | 2015-10-22 | 2019-01-08 | Google Llc | Personalized entity repository |
US10055390B2 (en) | 2015-11-18 | 2018-08-21 | Google Llc | Simulated hyperlinks on a mobile device based on user intent and a centered selection of text |
US20170185670A1 (en) * | 2015-12-28 | 2017-06-29 | Google Inc. | Generating labels for images associated with a user |
US9881236B2 (en) | 2015-12-28 | 2018-01-30 | Google Llc | Organizing images associated with a user |
US10043102B1 (en) | 2016-01-20 | 2018-08-07 | Palantir Technologies Inc. | Database systems and user interfaces for dynamic and interactive mobile image analysis and identification |
US9779293B2 (en) * | 2016-01-27 | 2017-10-03 | Honeywell International Inc. | Method and tool for post-mortem analysis of tripped field devices in process industry using optical character recognition and intelligent character recognition |
US10024680B2 (en) | 2016-03-11 | 2018-07-17 | Toyota Motor Engineering & Manufacturing North America, Inc. | Step based guidance system |
US10445355B2 (en) * | 2016-04-07 | 2019-10-15 | RELX Inc. | Systems and methods for providing a visualizable results list |
US11003667B1 (en) | 2016-05-27 | 2021-05-11 | Google Llc | Contextual information for a displayed resource |
US9958275B2 (en) | 2016-05-31 | 2018-05-01 | Toyota Motor Engineering & Manufacturing North America, Inc. | System and method for wearable smart device communications |
US10152521B2 (en) | 2016-06-22 | 2018-12-11 | Google Llc | Resource recommendations for a displayed resource |
US10353950B2 (en) * | 2016-06-28 | 2019-07-16 | Google Llc | Visual recognition using user tap locations |
US10802671B2 (en) | 2016-07-11 | 2020-10-13 | Google Llc | Contextual information for a displayed resource that includes an image |
US10561519B2 (en) | 2016-07-20 | 2020-02-18 | Toyota Motor Engineering & Manufacturing North America, Inc. | Wearable computing device having a curved back to reduce pressure on vertebrae |
US10467300B1 (en) | 2016-07-21 | 2019-11-05 | Google Llc | Topical resource recommendations for a displayed resource |
US10051108B2 (en) | 2016-07-21 | 2018-08-14 | Google Llc | Contextual information for a notification |
US10489459B1 (en) | 2016-07-21 | 2019-11-26 | Google Llc | Query recommendations for a displayed resource |
MX2019002626A (en) * | 2016-09-06 | 2019-10-02 | Walmart Apollo Llc | Product part picture picker. |
MY190933A (en) * | 2016-09-08 | 2022-05-20 | Goh Soo Siah | Video ingestion framework for visual search platform |
US10949605B2 (en) * | 2016-09-13 | 2021-03-16 | Bank Of America Corporation | Interprogram communication with event handling for online enhancements |
US10212113B2 (en) | 2016-09-19 | 2019-02-19 | Google Llc | Uniform resource identifier and image sharing for contextual information display |
US10535005B1 (en) | 2016-10-26 | 2020-01-14 | Google Llc | Providing contextual actions for mobile onscreen content |
US10432851B2 (en) | 2016-10-28 | 2019-10-01 | Toyota Motor Engineering & Manufacturing North America, Inc. | Wearable computing device for detecting photography |
US10346727B2 (en) * | 2016-10-28 | 2019-07-09 | Adobe Inc. | Utilizing a digital canvas to conduct a spatial-semantic search for digital visual media |
USD827143S1 (en) | 2016-11-07 | 2018-08-28 | Toyota Motor Engineering & Manufacturing North America, Inc. | Blind aid device |
US10012505B2 (en) | 2016-11-11 | 2018-07-03 | Toyota Motor Engineering & Manufacturing North America, Inc. | Wearable system for providing walking directions |
US10521669B2 (en) | 2016-11-14 | 2019-12-31 | Toyota Motor Engineering & Manufacturing North America, Inc. | System and method for providing guidance or feedback to a user |
US11237696B2 (en) | 2016-12-19 | 2022-02-01 | Google Llc | Smart assist for repeated actions |
US20180218237A1 (en) * | 2017-01-30 | 2018-08-02 | International Business Machines Corporation | System, method and computer program product for creating a contact group using image analytics |
US11449495B2 (en) * | 2017-02-01 | 2022-09-20 | United Parcel Service Of America, Inc. | Indexable database profiles comprising multi-language encoding data and methods for generating the same |
JP6807268B2 (en) * | 2017-04-18 | 2021-01-06 | 日本電信電話株式会社 | Image recognition engine linkage device and program |
KR102368847B1 (en) | 2017-04-28 | 2022-03-02 | 삼성전자주식회사 | Method for outputting content corresponding to object and electronic device thereof |
JP6353118B1 (en) * | 2017-05-10 | 2018-07-04 | ヤフー株式会社 | Display program, information providing apparatus, display apparatus, display method, information providing method, and information providing program |
CN110506276B (en) * | 2017-05-19 | 2021-10-15 | 谷歌有限责任公司 | Efficient image analysis using environmental sensor data |
US11928482B2 (en) * | 2017-06-13 | 2024-03-12 | Google Llc | Interaction with electronic chat interfaces |
US10679068B2 (en) | 2017-06-13 | 2020-06-09 | Google Llc | Media contextual information from buffered media data |
US11417082B2 (en) * | 2017-06-16 | 2022-08-16 | Markable, Inc. | Image processing system |
US10652592B2 (en) | 2017-07-02 | 2020-05-12 | Comigo Ltd. | Named entity disambiguation for providing TV content enrichment |
KR102586170B1 (en) * | 2017-08-01 | 2023-10-10 | 삼성전자주식회사 | Electronic device and method for providing search result thereof |
EP3438853A1 (en) | 2017-08-01 | 2019-02-06 | Samsung Electronics Co., Ltd. | Electronic device and method for providing search result thereof |
KR102469717B1 (en) * | 2017-08-01 | 2022-11-22 | 삼성전자주식회사 | Electronic device and method for controlling the electronic device thereof |
EP3602321B1 (en) | 2017-09-13 | 2023-09-13 | Google LLC | Efficiently augmenting images with related content |
US11841735B2 (en) | 2017-09-22 | 2023-12-12 | Pinterest, Inc. | Object based image search |
US10942966B2 (en) | 2017-09-22 | 2021-03-09 | Pinterest, Inc. | Textual and image based search |
US11126653B2 (en) | 2017-09-22 | 2021-09-21 | Pinterest, Inc. | Mixed type image based search results |
US10803350B2 (en) | 2017-11-30 | 2020-10-13 | Kofax, Inc. | Object detection and image cropping using a multi-detector approach |
CN111819554A (en) * | 2017-12-29 | 2020-10-23 | 电子湾有限公司 | Computer vision and image feature search |
US10740394B2 (en) * | 2018-01-18 | 2020-08-11 | Oath Inc. | Machine-in-the-loop, image-to-video computer vision bootstrapping |
CN108270794B (en) * | 2018-02-06 | 2020-10-09 | 腾讯科技(深圳)有限公司 | Content distribution method, device and readable medium |
KR102068535B1 (en) * | 2018-02-28 | 2020-01-21 | 엔에이치엔 주식회사 | Method for schedule a service based on chat messages |
US10558857B2 (en) * | 2018-03-05 | 2020-02-11 | A9.Com, Inc. | Visual feedback of process state |
JP6684846B2 (en) * | 2018-04-23 | 2020-04-22 | 株式会社ワコム | Article search system |
US10810457B2 (en) * | 2018-05-09 | 2020-10-20 | Fuji Xerox Co., Ltd. | System for searching documents and people based on detecting documents and people around a table |
CN108897841A (en) * | 2018-06-27 | 2018-11-27 | 百度在线网络技术(北京)有限公司 | Panorama sketch searching method, device, equipment, server and storage medium |
KR102661596B1 (en) | 2018-08-08 | 2024-04-29 | 삼성전자주식회사 | Electronic device for providing recognition result about external object using recognition information for image, similarity recognition information related to recognition information, and layer information, and operating method thereof |
US10699112B1 (en) * | 2018-09-28 | 2020-06-30 | Automation Anywhere, Inc. | Identification of key segments in document images |
WO2020106524A2 (en) * | 2018-11-25 | 2020-05-28 | Google Llc | Finding and filtering elements of a visual scene |
JP6934855B2 (en) * | 2018-12-20 | 2021-09-15 | ヤフー株式会社 | Control program |
KR101982990B1 (en) * | 2018-12-27 | 2019-05-27 | 건국대학교 산학협력단 | Method and apparatus for questioning and answering using chatbot |
KR101982991B1 (en) * | 2018-12-28 | 2019-05-27 | 건국대학교 산학협력단 | Method and apparatus for questioning and answering using a plurality of chatbots |
US11494884B2 (en) | 2019-02-21 | 2022-11-08 | Canon U.S.A., Inc. | Method and system for evaluating image sharpness |
WO2020172366A1 (en) | 2019-02-21 | 2020-08-27 | Canon U.S.A., Inc. | Method and system for image searching and evaluation using tags |
US20200327351A1 (en) * | 2019-04-15 | 2020-10-15 | General Electric Company | Optical character recognition error correction based on visual and textual contents |
KR102245774B1 (en) | 2019-11-06 | 2021-04-27 | 연세대학교 산학협력단 | Visual Question Answering Apparatus Using Fair Classification Network and Method Thereof |
KR102368560B1 (en) | 2020-01-31 | 2022-02-25 | 연세대학교 산학협력단 | Visual Question Answering Apparatus Using Selective Residual Learning and Method Thereof |
KR102104246B1 (en) * | 2020-02-17 | 2020-04-24 | 주식회사 비에이템 | Image search system using screen segmentaion |
CN111539438B (en) * | 2020-04-28 | 2024-01-12 | 北京百度网讯科技有限公司 | Text content identification method and device and electronic equipment |
US12045278B2 (en) * | 2020-09-18 | 2024-07-23 | Google Llc | Intelligent systems and methods for visual search queries |
GB2602452A (en) * | 2020-12-18 | 2022-07-06 | Supra Uk Ltd | Instigating communication |
CN112766269B (en) * | 2021-03-04 | 2024-03-12 | 深圳康佳电子科技有限公司 | Picture text retrieval method, intelligent terminal and storage medium |
US12072925B2 (en) * | 2021-03-19 | 2024-08-27 | Google Llc | Visual search via free-form visual feature selection |
CN114969479B (en) * | 2021-04-21 | 2023-08-15 | 中移互联网有限公司 | Searching method, searching device and storage medium |
US11835995B2 (en) | 2022-02-10 | 2023-12-05 | Clarifai, Inc. | Automatic unstructured knowledge cascade visual search |
Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20060251338A1 (en) * | 2005-05-09 | 2006-11-09 | Gokturk Salih B | System and method for providing objectified image renderings using recognition information from images |
US20060253491A1 (en) * | 2005-05-09 | 2006-11-09 | Gokturk Salih B | System and method for enabling search and retrieval from image files based on recognized information |
US20080267504A1 (en) * | 2007-04-24 | 2008-10-30 | Nokia Corporation | Method, device and computer program product for integrating code-based and optical character recognition technologies into a mobile visual search |
US20090024580A1 (en) * | 2007-07-20 | 2009-01-22 | Pere Obrador | Compositional balance and color driven content retrieval |
US20090254539A1 (en) * | 2008-04-03 | 2009-10-08 | Microsoft Corporation | User Intention Modeling For Interactive Image Retrieval |
US20090285492A1 (en) * | 2008-05-15 | 2009-11-19 | Yahoo! Inc. | Data access based on content of image recorded by a mobile device |
US20100046842A1 (en) * | 2008-08-19 | 2010-02-25 | Conwell William Y | Methods and Systems for Content Processing |
US8370358B2 (en) * | 2009-09-18 | 2013-02-05 | Microsoft Corporation | Tagging content with metadata pre-filtered by context |
Family Cites Families (211)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4888690A (en) | 1985-01-11 | 1989-12-19 | Wang Laboratories, Inc. | Interactive error handling means in database management |
US4899292A (en) * | 1988-03-02 | 1990-02-06 | Image Storage/Retrieval Systems, Inc. | System for storing and retrieving text and associated graphics |
CA2048306A1 (en) | 1990-10-02 | 1992-04-03 | Steven P. Miller | Distributed configuration profile for computing system |
US5649183A (en) | 1992-12-08 | 1997-07-15 | Microsoft Corporation | Method for compressing full text indexes with document identifiers and location offsets |
US5574898A (en) | 1993-01-08 | 1996-11-12 | Atria Software, Inc. | Dynamic software version auditor which monitors a process to provide a list of objects that are accessed |
US5544051A (en) | 1993-09-17 | 1996-08-06 | Digital Equipment Corporation | Document management system using multiple threaded processes and having asynchronous repository responses and no busy cursor |
JP2813728B2 (en) * | 1993-11-01 | 1998-10-22 | インターナショナル・ビジネス・マシーンズ・コーポレイション | Personal communication device with zoom / pan function |
US5560005A (en) | 1994-02-25 | 1996-09-24 | Actamed Corp. | Methods and systems for object-based relational distributed databases |
US6216138B1 (en) * | 1994-04-22 | 2001-04-10 | Brooks Automation Inc. | Computer interface system for automatically generating graphical representations of computer operations linked together according to functional relationships |
US6029195A (en) * | 1994-11-29 | 2000-02-22 | Herz; Frederick S. M. | System for customized electronic identification of desirable objects |
US5764799A (en) * | 1995-06-26 | 1998-06-09 | Research Foundation Of State Of State Of New York | OCR method and apparatus using image equivalents |
US5963940A (en) | 1995-08-16 | 1999-10-05 | Syracuse University | Natural language information retrieval system and method |
US6006221A (en) | 1995-08-16 | 1999-12-21 | Syracuse University | Multilingual document retrieval system and method using semantic vector matching |
US6026388A (en) * | 1995-08-16 | 2000-02-15 | Textwise, Llc | User interface and other enhancements for natural language information retrieval system and method |
US5815415A (en) | 1996-01-19 | 1998-09-29 | Bentley Systems, Incorporated | Computer system for portable persistent modeling |
US6076088A (en) * | 1996-02-09 | 2000-06-13 | Paik; Woojin | Information extraction system and method using concept relation concept (CRC) triples |
US5778378A (en) * | 1996-04-30 | 1998-07-07 | International Business Machines Corporation | Object oriented information retrieval framework mechanism |
US6014661A (en) * | 1996-05-06 | 2000-01-11 | Ivee Development Ab | System and method for automatic analysis of data bases and for user-controlled dynamic querying |
US6101515A (en) | 1996-05-31 | 2000-08-08 | Oracle Corporation | Learning system for classification of terminology |
JPH09330336A (en) | 1996-06-11 | 1997-12-22 | Sony Corp | Information processor |
US5870739A (en) * | 1996-09-20 | 1999-02-09 | Novell, Inc. | Hybrid query apparatus and method |
JP3099756B2 (en) * | 1996-10-31 | 2000-10-16 | 富士ゼロックス株式会社 | Document processing device, word extraction device, and word extraction method |
US6480194B1 (en) | 1996-11-12 | 2002-11-12 | Silicon Graphics, Inc. | Computer-related method, system, and program product for controlling data visualization in external dimension(s) |
US6498921B1 (en) | 1999-09-01 | 2002-12-24 | Chi Fai Ho | Method and system to answer a natural-language question |
US5966126A (en) | 1996-12-23 | 1999-10-12 | Szabo; Andrew J. | Graphic user interface for database system |
US5946692A (en) | 1997-05-08 | 1999-08-31 | At & T Corp | Compressed representation of a data base that permits AD HOC querying |
CA2242158C (en) * | 1997-07-01 | 2004-06-01 | Hitachi, Ltd. | Method and apparatus for searching and displaying structured document |
US5987448A (en) * | 1997-07-25 | 1999-11-16 | Claritech Corporation | Methodology for displaying search results using character recognition |
US6188403B1 (en) * | 1997-11-21 | 2001-02-13 | Portola Dimensional Systems, Inc. | User-friendly graphics generator using direct manipulation |
US6105030A (en) | 1998-02-27 | 2000-08-15 | Oracle Corporation | Method and apparatus for copying data that resides in a database |
US6173287B1 (en) | 1998-03-11 | 2001-01-09 | Digital Equipment Corporation | Technique for ranking multimedia annotations of interest |
US6269188B1 (en) | 1998-03-12 | 2001-07-31 | Canon Kabushiki Kaisha | Word grouping accuracy value generation |
US6327574B1 (en) | 1998-07-07 | 2001-12-04 | Encirq Corporation | Hierarchical models of consumer attributes for targeting content in a privacy-preserving manner |
US6137907A (en) | 1998-09-23 | 2000-10-24 | Xerox Corporation | Method and apparatus for pixel-level override of halftone detection within classification blocks to reduce rectangular artifacts |
US6529900B1 (en) | 1999-01-14 | 2003-03-04 | International Business Machines Corporation | Method and apparatus for data visualization |
US6377943B1 (en) * | 1999-01-20 | 2002-04-23 | Oracle Corp. | Initial ordering of tables for database queries |
GB9903451D0 (en) | 1999-02-16 | 1999-04-07 | Hewlett Packard Co | Similarity searching for documents |
US6584464B1 (en) | 1999-03-19 | 2003-06-24 | Ask Jeeves, Inc. | Grammar template query system |
US6263328B1 (en) * | 1999-04-09 | 2001-07-17 | International Business Machines Corporation | Object oriented query model and process for complex heterogeneous database queries |
US20030195872A1 (en) | 1999-04-12 | 2003-10-16 | Paul Senn | Web-based information content analyzer and information dimension dictionary |
US6304864B1 (en) | 1999-04-20 | 2001-10-16 | Textwise Llc | System for retrieving multimedia information from the internet using multiple evolving intelligent agents |
US6629097B1 (en) | 1999-04-28 | 2003-09-30 | Douglas K. Keith | Displaying implicit associations among items in loosely-structured data sets |
JP2000331006A (en) | 1999-05-18 | 2000-11-30 | Nippon Telegr & Teleph Corp <Ntt> | Information retrieval device |
US6721713B1 (en) * | 1999-05-27 | 2004-04-13 | Andersen Consulting Llp | Business alliance identification in a web architecture framework |
US6885990B1 (en) * | 1999-05-31 | 2005-04-26 | Nippon Telegraph And Telephone Company | Speech recognition based on interactive information retrieval scheme using dialogue control to reduce user stress |
US6408293B1 (en) * | 1999-06-09 | 2002-06-18 | International Business Machines Corporation | Interactive framework for understanding user's perception of multimedia data |
US6873982B1 (en) * | 1999-07-16 | 2005-03-29 | International Business Machines Corporation | Ordering of database search results based on user feedback |
US6341306B1 (en) * | 1999-08-13 | 2002-01-22 | Atomica Corporation | Web-based information retrieval responsive to displayed word identified by a text-grabbing algorithm |
CA2281331A1 (en) | 1999-09-03 | 2001-03-03 | Cognos Incorporated | Database management system |
JP4770875B2 (en) | 1999-09-27 | 2011-09-14 | 三菱電機株式会社 | Image feature data generation device, image feature determination device, and image search system |
US6105020A (en) | 1999-10-11 | 2000-08-15 | International Business Machines Corporation | System and method for identifying and constructing star joins for execution by bitmap ANDing |
US6850896B1 (en) * | 1999-10-28 | 2005-02-01 | Market-Touch Corporation | Method and system for managing and providing sales data using world wide web |
US6546388B1 (en) * | 2000-01-14 | 2003-04-08 | International Business Machines Corporation | Metadata search results ranking system |
US6606659B1 (en) | 2000-01-28 | 2003-08-12 | Websense, Inc. | System and method for controlling access to internet sites |
US20030120659A1 (en) * | 2000-03-20 | 2003-06-26 | Sridhar Mandayam Anandampillai | Systems for developing websites and methods therefor |
US6643641B1 (en) | 2000-04-27 | 2003-11-04 | Russell Snyder | Web search engine with graphic snapshots |
US7325201B2 (en) * | 2000-05-18 | 2008-01-29 | Endeca Technologies, Inc. | System and method for manipulating content in a hierarchical data-driven search and navigation system |
US7401131B2 (en) | 2000-05-22 | 2008-07-15 | Verizon Business Global Llc | Method and system for implementing improved containers in a global ecosystem of interrelated services |
US6754677B1 (en) * | 2000-05-30 | 2004-06-22 | Outlooksoft Corporation | Method and system for facilitating information exchange |
US7328349B2 (en) * | 2001-12-14 | 2008-02-05 | Bbn Technologies Corp. | Hash-based systems and methods for detecting, preventing, and tracing network worms and viruses |
US7640489B2 (en) * | 2000-08-01 | 2009-12-29 | Sun Microsystems, Inc. | Methods and systems for inputting data into spreadsheet documents |
US7100083B2 (en) | 2000-08-04 | 2006-08-29 | Sun Microsystems, Inc. | Checks for product knowledge management |
EP1312039B1 (en) | 2000-08-24 | 2006-03-29 | Olive Software, Inc. | System and method for automatic preparation and searching of scanned documents |
US20030217052A1 (en) | 2000-08-24 | 2003-11-20 | Celebros Ltd. | Search engine method and apparatus |
WO2002019228A1 (en) | 2000-09-01 | 2002-03-07 | Togethersoft Corporation | Methods and systems for improving a workflow based on data mined from plans created from the workflow |
US6832218B1 (en) | 2000-09-22 | 2004-12-14 | International Business Machines Corporation | System and method for associating search results |
US6823084B2 (en) * | 2000-09-22 | 2004-11-23 | Sri International | Method and apparatus for portably recognizing text in an image sequence of scene imagery |
US20020065815A1 (en) * | 2000-10-04 | 2002-05-30 | Xcelerix, Inc. | Systems and methods for searching a database |
US7016532B2 (en) | 2000-11-06 | 2006-03-21 | Evryx Technologies | Image capture and identification system and process |
US20020103920A1 (en) | 2000-11-21 | 2002-08-01 | Berkun Ken Alan | Interpretive stream metadata extraction |
US7013308B1 (en) * | 2000-11-28 | 2006-03-14 | Semscript Ltd. | Knowledge storage and retrieval system and method |
US6781599B2 (en) | 2001-01-04 | 2004-08-24 | At&T | System and method for visualizing massive multi-digraphs |
JP2002223105A (en) * | 2001-01-26 | 2002-08-09 | Sanyo Electric Co Ltd | Coaxial resonator, and dielectric filter and dielectric duplexer employing it |
JP4077608B2 (en) | 2001-02-27 | 2008-04-16 | 株式会社エヌ・ティ・ティ・ドコモ | Feature region extraction method and apparatus, and information providing method and apparatus |
US6748398B2 (en) * | 2001-03-30 | 2004-06-08 | Microsoft Corporation | Relevance maximizing, iteration minimizing, relevance-feedback, content-based image retrieval (CBIR) |
US6920477B2 (en) * | 2001-04-06 | 2005-07-19 | President And Fellows Of Harvard College | Distributed, compressed Bloom filter Web cache server |
US7031955B1 (en) * | 2001-04-27 | 2006-04-18 | I2 Technologies Us, Inc. | Optimization using a multi-dimensional data model |
US6961723B2 (en) | 2001-05-04 | 2005-11-01 | Sun Microsystems, Inc. | System and method for determining relevancy of query responses in a distributed network search mechanism |
US7398201B2 (en) | 2001-08-14 | 2008-07-08 | Evri Inc. | Method and system for enhanced data searching |
US7403938B2 (en) * | 2001-09-24 | 2008-07-22 | Iac Search & Media, Inc. | Natural language query processing |
US7313617B2 (en) * | 2001-09-28 | 2007-12-25 | Dale Malik | Methods and systems for a communications and information resource manager |
JP2003150617A (en) | 2001-11-12 | 2003-05-23 | Olympus Optical Co Ltd | Image processor and program |
US6826572B2 (en) | 2001-11-13 | 2004-11-30 | Overture Services, Inc. | System and method allowing advertisers to manage search listings in a pay for placement search system using grouping |
JP3931214B2 (en) * | 2001-12-17 | 2007-06-13 | 日本アイ・ビー・エム株式会社 | Data analysis apparatus and program |
US6988018B2 (en) * | 2001-12-26 | 2006-01-17 | Eames John D | System and method for analyzing controlling forming sections of a paper machine in operation |
US20030154071A1 (en) | 2002-02-11 | 2003-08-14 | Shreve Gregory M. | Process for the document management and computer-assisted translation of documents utilizing document corpora constructed by intelligent agents |
US7343365B2 (en) | 2002-02-20 | 2008-03-11 | Microsoft Corporation | Computer system architecture for automatic context associations |
US6928436B2 (en) | 2002-02-28 | 2005-08-09 | Ilog Sa | Interactive generation of graphical visualizations of large data structures |
US7043521B2 (en) * | 2002-03-21 | 2006-05-09 | Rockwell Electronic Commerce Technologies, Llc | Search agent for searching the internet |
US20040030731A1 (en) * | 2002-04-03 | 2004-02-12 | Liviu Iftode | System and method for accessing files in a network |
US20030208665A1 (en) | 2002-05-01 | 2003-11-06 | Jih-Kwon Peir | Reducing data speculation penalty with early cache hit/miss prediction |
US7158983B2 (en) * | 2002-09-23 | 2007-01-02 | Battelle Memorial Institute | Text analysis technique |
DE10245900A1 (en) | 2002-09-30 | 2004-04-08 | Neven jun., Hartmut, Prof.Dr. | Image based query system for search engines or databases of mobile telephone, portable computer uses image recognition to access more information about objects in image |
US20040167870A1 (en) | 2002-12-06 | 2004-08-26 | Attensity Corporation | Systems and methods for providing a mixed data integration service |
US7181450B2 (en) * | 2002-12-18 | 2007-02-20 | International Business Machines Corporation | Method, system, and program for use of metadata to create multidimensional cubes in a relational database |
US7278111B2 (en) * | 2002-12-26 | 2007-10-02 | Yahoo! Inc. | Systems and methods for selecting a date or range of dates |
US7472110B2 (en) * | 2003-01-29 | 2008-12-30 | Microsoft Corporation | System and method for employing social networks for information discovery |
US7146538B2 (en) | 2003-03-28 | 2006-12-05 | Hewlett-Packard Development Company, L.P. | Bus interface module |
US7111025B2 (en) | 2003-04-30 | 2006-09-19 | International Business Machines Corporation | Information retrieval system and method using index ANDing for improving performance |
US7853508B2 (en) | 2003-05-19 | 2010-12-14 | Serena Software, Inc. | Method and system for object-oriented management of multi-dimensional data |
US7926103B2 (en) * | 2003-06-05 | 2011-04-12 | Hewlett-Packard Development Company, L.P. | System and method for preventing replay attacks |
US7836391B2 (en) | 2003-06-10 | 2010-11-16 | Google Inc. | Document search engine including highlighting of confident results |
US9026901B2 (en) | 2003-06-20 | 2015-05-05 | International Business Machines Corporation | Viewing annotations across multiple applications |
US8321470B2 (en) | 2003-06-20 | 2012-11-27 | International Business Machines Corporation | Heterogeneous multi-level extendable indexing for general purpose annotation systems |
US7162473B2 (en) | 2003-06-26 | 2007-01-09 | Microsoft Corporation | Method and system for usage analyzer that determines user accessed sources, indexes data subsets, and associated metadata, processing implicit queries based on potential interest to users |
US7274822B2 (en) * | 2003-06-30 | 2007-09-25 | Microsoft Corporation | Face annotation for photo management |
US7565425B2 (en) * | 2003-07-02 | 2009-07-21 | Amazon Technologies, Inc. | Server architecture and methods for persistently storing and serving event data |
US7814093B2 (en) * | 2003-07-25 | 2010-10-12 | Microsoft Corporation | Method and system for building a report for execution against a data store |
US7444515B2 (en) * | 2003-08-14 | 2008-10-28 | Washington University | Method and apparatus for detecting predefined signatures in packet payload using Bloom filters |
US7174328B2 (en) * | 2003-09-02 | 2007-02-06 | International Business Machines Corp. | Selective path signatures for query processing over a hierarchical tagged data structure |
US7409406B2 (en) * | 2003-09-08 | 2008-08-05 | International Business Machines Corporation | Uniform search system and method for selectively sharing distributed access-controlled documents |
US20050057566A1 (en) * | 2003-09-11 | 2005-03-17 | International Business Machines Corporation | Rich graphic visualization generation from abstract data representation |
US7236982B2 (en) * | 2003-09-15 | 2007-06-26 | Pic Web Services, Inc. | Computer systems and methods for platform independent presentation design |
US7496560B2 (en) * | 2003-09-23 | 2009-02-24 | Amazon Technologies, Inc. | Personalized searchable library with highlighting capabilities |
JP2005107978A (en) | 2003-09-30 | 2005-04-21 | Nec Corp | Information retrieving device using information terminal with photographing function and information retrieving method |
US7493322B2 (en) * | 2003-10-15 | 2009-02-17 | Xerox Corporation | System and method for computing a measure of similarity between documents |
US7620624B2 (en) * | 2003-10-17 | 2009-11-17 | Yahoo! Inc. | Systems and methods for indexing content for fast and scalable retrieval |
US20050083413A1 (en) * | 2003-10-20 | 2005-04-21 | Logicalis | Method, system, apparatus, and machine-readable medium for use in connection with a server that uses images or audio for initiating remote function calls |
US7415456B2 (en) * | 2003-10-30 | 2008-08-19 | Lucent Technologies Inc. | Network support for caller identification based on biometric measurement |
JP2005165461A (en) | 2003-11-28 | 2005-06-23 | Nifty Corp | Information providing device and program |
US7872669B2 (en) * | 2004-01-22 | 2011-01-18 | Massachusetts Institute Of Technology | Photo-based mobile deixis system and related techniques |
US7707039B2 (en) | 2004-02-15 | 2010-04-27 | Exbiblio B.V. | Automatic modification of web pages |
JP4413633B2 (en) | 2004-01-29 | 2010-02-10 | 株式会社ゼータ・ブリッジ | Information search system, information search method, information search device, information search program, image recognition device, image recognition method and image recognition program, and sales system |
US20050187898A1 (en) | 2004-02-05 | 2005-08-25 | Nec Laboratories America, Inc. | Data Lookup architecture |
US7751805B2 (en) | 2004-02-20 | 2010-07-06 | Google Inc. | Mobile image-based information retrieval system |
US7451185B2 (en) | 2004-02-27 | 2008-11-11 | Fotomedia Technologies, Llc | Method and system for providing links to resources related to a specified resource |
US20050216464A1 (en) | 2004-03-27 | 2005-09-29 | Microsoft Corporation | Automated authoring tool and method to facilitate inclusion of maps and other geographical data into travelogues |
US20050219929A1 (en) | 2004-03-30 | 2005-10-06 | Navas Julio C | Method and apparatus achieving memory and transmission overhead reductions in a content routing network |
WO2005114476A1 (en) | 2004-05-13 | 2005-12-01 | Nevengineering, Inc. | Mobile image-based information retrieval system |
US20050268212A1 (en) | 2004-05-28 | 2005-12-01 | Michael Dagel | System, apparatus, and method for desktop-based creation and publication of a periodic community newsletter |
WO2006007229A1 (en) * | 2004-06-17 | 2006-01-19 | The Regents Of The University Of California | Method and apparatus for retrieving and indexing hidden web pages |
US8051207B2 (en) * | 2004-06-25 | 2011-11-01 | Citrix Systems, Inc. | Inferring server state in s stateless communication protocol |
US7493335B2 (en) * | 2004-07-02 | 2009-02-17 | Graphlogic Inc. | Object process graph relational database interface |
US20060020582A1 (en) * | 2004-07-22 | 2006-01-26 | International Business Machines Corporation | Method and system for processing abstract derived entities defined in a data abstraction model |
US20060020630A1 (en) * | 2004-07-23 | 2006-01-26 | Stager Reed R | Facial database methods and systems |
US7890871B2 (en) * | 2004-08-26 | 2011-02-15 | Redlands Technology, Llc | System and method for dynamically generating, maintaining, and growing an online social network |
JP2006085379A (en) | 2004-09-15 | 2006-03-30 | Canon Inc | Information processor and its control method, and program |
US8385589B2 (en) | 2008-05-15 | 2013-02-26 | Berna Erol | Web-based content detection in images, extraction and recognition |
US8489583B2 (en) | 2004-10-01 | 2013-07-16 | Ricoh Company, Ltd. | Techniques for retrieving documents using an image capture device |
US7809763B2 (en) * | 2004-10-15 | 2010-10-05 | Oracle International Corporation | Method(s) for updating database object metadata |
US20060085386A1 (en) * | 2004-10-19 | 2006-04-20 | Microsoft Corporation | Two pass calculation to optimize formula calculations for a spreadsheet |
WO2006043319A1 (en) | 2004-10-20 | 2006-04-27 | Fujitsu Limited | Terminal and server |
US8320641B2 (en) | 2004-10-28 | 2012-11-27 | DigitalOptics Corporation Europe Limited | Method and apparatus for red-eye detection using preview or other reference images |
US20060149700A1 (en) * | 2004-11-11 | 2006-07-06 | Gladish Randolph J | System and method for automatic geospatial web network generation via metadata transformation |
US7464090B2 (en) | 2006-01-27 | 2008-12-09 | Google Inc. | Object categorization for information extraction |
US20060150119A1 (en) * | 2004-12-31 | 2006-07-06 | France Telecom | Method for interacting with automated information agents using conversational queries |
EP1839193A1 (en) | 2004-12-31 | 2007-10-03 | Nokia Corporation | Provision of target specific information |
JP4282612B2 (en) | 2005-01-19 | 2009-06-24 | エルピーダメモリ株式会社 | Memory device and refresh method thereof |
US20060173824A1 (en) | 2005-02-01 | 2006-08-03 | Metalincs Corporation | Electronic communication analysis and visualization |
US20070201749A1 (en) | 2005-02-07 | 2007-08-30 | Masaki Yamauchi | Image Processing Device And Image Processing Method |
JP4267584B2 (en) | 2005-02-28 | 2009-05-27 | 株式会社東芝 | Device control apparatus and method |
JP2008532177A (en) * | 2005-03-03 | 2008-08-14 | ワシントン ユニヴァーシティー | Method and apparatus for performing biological sequence similarity searches |
US7587387B2 (en) | 2005-03-31 | 2009-09-08 | Google Inc. | User interface for facts query engine with snippets from information sources that include query terms and answer terms |
US7765231B2 (en) | 2005-04-08 | 2010-07-27 | Rathus Spencer A | System and method for accessing electronic data via an image search engine |
US7773822B2 (en) * | 2005-05-02 | 2010-08-10 | Colormax, Inc. | Apparatus and methods for management of electronic images |
US7760917B2 (en) * | 2005-05-09 | 2010-07-20 | Like.Com | Computer-implemented method for performing similarity searches |
US7519200B2 (en) | 2005-05-09 | 2009-04-14 | Like.Com | System and method for enabling the use of captured images through recognition |
US7809192B2 (en) | 2005-05-09 | 2010-10-05 | Like.Com | System and method for recognizing objects from images and identifying relevancy amongst images and information |
US7945099B2 (en) * | 2005-05-09 | 2011-05-17 | Like.Com | System and method for use of images with recognition analysis |
KR100754656B1 (en) | 2005-06-20 | 2007-09-03 | 삼성전자주식회사 | Method and system for providing user with image related information and mobile communication system |
US20080005064A1 (en) * | 2005-06-28 | 2008-01-03 | Yahoo! Inc. | Apparatus and method for content annotation and conditional annotation retrieval in a search context |
US7702681B2 (en) * | 2005-06-29 | 2010-04-20 | Microsoft Corporation | Query-by-image search and retrieval system |
JP2007018166A (en) | 2005-07-06 | 2007-01-25 | Nec Corp | Information search device, information search system, information search method, and information search program |
JP2007018456A (en) | 2005-07-11 | 2007-01-25 | Nikon Corp | Information display device and information display method |
US20070022085A1 (en) * | 2005-07-22 | 2007-01-25 | Parashuram Kulkarni | Techniques for unsupervised web content discovery and automated query generation for crawling the hidden web |
US8666928B2 (en) * | 2005-08-01 | 2014-03-04 | Evi Technologies Limited | Knowledge repository |
US7457825B2 (en) * | 2005-09-21 | 2008-11-25 | Microsoft Corporation | Generating search requests from multimodal queries |
US20090060289A1 (en) * | 2005-09-28 | 2009-03-05 | Alex Shah | Digital Image Search System And Method |
US7876978B2 (en) * | 2005-10-13 | 2011-01-25 | Penthera Technologies, Inc. | Regions of interest in video frames |
US20070098303A1 (en) * | 2005-10-31 | 2007-05-03 | Eastman Kodak Company | Determining a particular person from a collection |
US8849821B2 (en) * | 2005-11-04 | 2014-09-30 | Nokia Corporation | Scalable visual search system simplifying access to network and device functionality |
US7826665B2 (en) | 2005-12-12 | 2010-11-02 | Xerox Corporation | Personal information retrieval using knowledge bases for optical character recognition correction |
US7725477B2 (en) * | 2005-12-19 | 2010-05-25 | Microsoft Corporation | Power filter for online listing service |
US7555471B2 (en) | 2006-01-27 | 2009-06-30 | Google Inc. | Data object visualization |
US20070179965A1 (en) | 2006-01-27 | 2007-08-02 | Hogue Andrew W | Designating data objects for analysis |
US8874591B2 (en) | 2006-01-31 | 2014-10-28 | Microsoft Corporation | Using user feedback to improve search results |
US9336333B2 (en) | 2006-02-13 | 2016-05-10 | Linkedin Corporation | Searching and reference checking within social networks |
US7668405B2 (en) * | 2006-04-07 | 2010-02-23 | Eastman Kodak Company | Forming connections between image collections |
US7917514B2 (en) * | 2006-06-28 | 2011-03-29 | Microsoft Corporation | Visual and multi-dimensional search |
US9176984B2 (en) * | 2006-07-31 | 2015-11-03 | Ricoh Co., Ltd | Mixed media reality retrieval of differentially-weighted links |
US20080031506A1 (en) * | 2006-08-07 | 2008-02-07 | Anuradha Agatheeswaran | Texture analysis for mammography computer aided diagnosis |
US7934156B2 (en) * | 2006-09-06 | 2011-04-26 | Apple Inc. | Deletion gestures on a portable multifunction device |
JP2008071311A (en) | 2006-09-15 | 2008-03-27 | Ricoh Co Ltd | Image retrieval apparatus, image retrieval method, image retrieval program, and information storage medium |
KR100865973B1 (en) | 2007-02-08 | 2008-10-30 | (주)올라웍스 | Method for searching certain person and method and system for generating copyright report for the certain person |
US9058370B2 (en) | 2007-02-27 | 2015-06-16 | International Business Machines Corporation | Method, system and program product for defining imports into and exports out from a database system using spread sheets by use of a control language |
US8861898B2 (en) | 2007-03-16 | 2014-10-14 | Sony Corporation | Content image search |
CN104866469B (en) * | 2007-04-11 | 2018-10-02 | 谷歌有限责任公司 | Input Method Editor with secondary language mode |
US8600343B2 (en) * | 2007-07-25 | 2013-12-03 | Yahoo! Inc. | Method and system for collecting and presenting historical communication data for a mobile device |
JP5207688B2 (en) | 2007-08-30 | 2013-06-12 | キヤノン株式会社 | Image processing apparatus and integrated document generation method |
US8145660B2 (en) | 2007-10-05 | 2012-03-27 | Fujitsu Limited | Implementing an expanded search and providing expanded search results |
KR101435140B1 (en) * | 2007-10-16 | 2014-09-02 | 삼성전자 주식회사 | Display apparatus and method |
US9237213B2 (en) * | 2007-11-20 | 2016-01-12 | Yellowpages.Com Llc | Methods and apparatuses to initiate telephone connections |
US20090144056A1 (en) * | 2007-11-29 | 2009-06-04 | Netta Aizenbud-Reshef | Method and computer program product for generating recognition error correction information |
KR100969298B1 (en) | 2007-12-31 | 2010-07-09 | 인하대학교 산학협력단 | Method For Social Network Analysis Based On Face Recognition In An Image or Image Sequences |
US20090237546A1 (en) | 2008-03-24 | 2009-09-24 | Sony Ericsson Mobile Communications Ab | Mobile Device with Image Recognition Processing Capability |
US20090299990A1 (en) | 2008-05-30 | 2009-12-03 | Vidya Setlur | Method, apparatus and computer program product for providing correlations between information from heterogenous sources |
JP5109836B2 (en) * | 2008-07-01 | 2012-12-26 | 株式会社ニコン | Imaging device |
US8452794B2 (en) * | 2009-02-11 | 2013-05-28 | Microsoft Corporation | Visual and textual query suggestion |
US9135277B2 (en) | 2009-08-07 | 2015-09-15 | Google Inc. | Architecture for responding to a visual query |
US9087059B2 (en) * | 2009-08-07 | 2015-07-21 | Google Inc. | User interface for presenting search results for multiple regions of a visual query |
US8670597B2 (en) | 2009-08-07 | 2014-03-11 | Google Inc. | Facial recognition with social network aiding |
US8977639B2 (en) | 2009-12-02 | 2015-03-10 | Google Inc. | Actionable search results for visual queries |
US8811742B2 (en) | 2009-12-02 | 2014-08-19 | Google Inc. | Identifying matching canonical documents consistent with visual query structural information |
US20110128288A1 (en) | 2009-12-02 | 2011-06-02 | David Petrou | Region of Interest Selector for Visual Queries |
US9183224B2 (en) | 2009-12-02 | 2015-11-10 | Google Inc. | Identifying matching canonical documents in response to a visual query |
US8805079B2 (en) * | 2009-12-02 | 2014-08-12 | Google Inc. | Identifying matching canonical documents in response to a visual query and in accordance with geographic information |
US9176986B2 (en) | 2009-12-02 | 2015-11-03 | Google Inc. | Generating a combination of a visual query and matching canonical document |
US9405772B2 (en) * | 2009-12-02 | 2016-08-02 | Google Inc. | Actionable search results for street view visual queries |
US9852156B2 (en) | 2009-12-03 | 2017-12-26 | Google Inc. | Hybrid use of location sensor data and visual query to return local listings for visual query |
US8189964B2 (en) * | 2009-12-07 | 2012-05-29 | Google Inc. | Matching an approximately located query image against a reference image set |
US8489589B2 (en) * | 2010-02-05 | 2013-07-16 | Microsoft Corporation | Visual search reranking |
-
2010
- 2010-08-04 US US12/850,483 patent/US9135277B2/en active Active
- 2010-08-05 CA CA3068761A patent/CA3068761C/en active Active
- 2010-08-05 KR KR1020127006113A patent/KR101667346B1/en active IP Right Grant
- 2010-08-05 KR KR1020167020177A patent/KR101725885B1/en active IP Right Grant
- 2010-08-05 CN CN201080045164.6A patent/CN102625937B/en active Active
- 2010-08-05 CA CA2771094A patent/CA2771094C/en active Active
- 2010-08-05 JP JP2012523960A patent/JP2013501975A/en active Pending
- 2010-08-05 WO PCT/US2010/044603 patent/WO2011017557A1/en active Application Filing
- 2010-08-05 AU AU2010279333A patent/AU2010279333B2/en not_active Ceased
- 2010-08-05 EP EP10742974.8A patent/EP2462520B1/en active Active
- 2010-08-05 BR BR112012002815A patent/BR112012002815B8/en active IP Right Grant
-
2013
- 2013-05-17 AU AU2013205924A patent/AU2013205924B2/en active Active
-
2014
- 2014-02-18 US US14/183,001 patent/US10534808B2/en not_active Expired - Fee Related
- 2014-12-17 JP JP2014254872A patent/JP5933677B2/en active Active
-
2016
- 2016-03-15 JP JP2016050616A patent/JP6148367B2/en active Active
-
2018
- 2018-09-13 US US16/131,004 patent/US20190012334A1/en not_active Abandoned
Patent Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20060251338A1 (en) * | 2005-05-09 | 2006-11-09 | Gokturk Salih B | System and method for providing objectified image renderings using recognition information from images |
US20060253491A1 (en) * | 2005-05-09 | 2006-11-09 | Gokturk Salih B | System and method for enabling search and retrieval from image files based on recognized information |
US20080267504A1 (en) * | 2007-04-24 | 2008-10-30 | Nokia Corporation | Method, device and computer program product for integrating code-based and optical character recognition technologies into a mobile visual search |
US20090024580A1 (en) * | 2007-07-20 | 2009-01-22 | Pere Obrador | Compositional balance and color driven content retrieval |
US20090254539A1 (en) * | 2008-04-03 | 2009-10-08 | Microsoft Corporation | User Intention Modeling For Interactive Image Retrieval |
US20090285492A1 (en) * | 2008-05-15 | 2009-11-19 | Yahoo! Inc. | Data access based on content of image recorded by a mobile device |
US20100046842A1 (en) * | 2008-08-19 | 2010-02-25 | Conwell William Y | Methods and Systems for Content Processing |
US8370358B2 (en) * | 2009-09-18 | 2013-02-05 | Microsoft Corporation | Tagging content with metadata pre-filtered by context |
Cited By (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10534808B2 (en) | 2009-08-07 | 2020-01-14 | Google Llc | Architecture for responding to visual query |
US11853108B2 (en) | 2017-10-27 | 2023-12-26 | Samsung Electronics Co., Ltd. | Electronic apparatus for searching related image and control method therefor |
US11604820B2 (en) | 2018-08-08 | 2023-03-14 | Samsung Electronics Co., Ltd. | Method for providing information related to goods on basis of priority and electronic device therefor |
WO2022158667A1 (en) * | 2021-01-19 | 2022-07-28 | Samsung Electronics Co., Ltd. | Method and system for displaying a video poster based on artificial intelligence |
US11544814B2 (en) | 2021-01-19 | 2023-01-03 | Samsung Electronics Co., Ltd. | Method and system for displaying a video poster based on artificial intelligence |
US20230039682A1 (en) * | 2021-08-09 | 2023-02-09 | Coupang Corp. | Operating Method for Electronic Apparatus for Providing Search Information and Electronic Apparatus Thereof |
Also Published As
Publication number | Publication date |
---|---|
CN102625937A (en) | 2012-08-01 |
JP6148367B2 (en) | 2017-06-14 |
KR20120058538A (en) | 2012-06-07 |
EP2462520B1 (en) | 2014-07-02 |
KR20160092045A (en) | 2016-08-03 |
KR101667346B1 (en) | 2016-10-18 |
JP2016139424A (en) | 2016-08-04 |
AU2010279333B2 (en) | 2013-02-21 |
KR101725885B1 (en) | 2017-04-11 |
AU2010279333A1 (en) | 2012-03-15 |
JP5933677B2 (en) | 2016-06-15 |
CA2771094A1 (en) | 2011-02-10 |
BR112012002815B8 (en) | 2020-10-06 |
BR112012002815B1 (en) | 2020-06-09 |
EP2462520A1 (en) | 2012-06-13 |
US10534808B2 (en) | 2020-01-14 |
CN102625937B (en) | 2014-02-12 |
WO2011017557A1 (en) | 2011-02-10 |
CA3068761C (en) | 2022-09-13 |
US20140164406A1 (en) | 2014-06-12 |
CA2771094C (en) | 2020-03-24 |
JP2013501975A (en) | 2013-01-17 |
US20110125735A1 (en) | 2011-05-26 |
AU2013205924A1 (en) | 2013-06-06 |
AU2013205924B2 (en) | 2015-12-24 |
US9135277B2 (en) | 2015-09-15 |
JP2015064901A (en) | 2015-04-09 |
CA3068761A1 (en) | 2011-02-10 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US20190012334A1 (en) | Architecture for Responding to Visual Query | |
US9087059B2 (en) | User interface for presenting search results for multiple regions of a visual query | |
AU2017272149B2 (en) | Identifying matching canonical documents in response to a visual query | |
CA2770186C (en) | User interface for presenting search results for multiple regions of a visual query | |
US9183224B2 (en) | Identifying matching canonical documents in response to a visual query | |
US8977639B2 (en) | Actionable search results for visual queries | |
US9405772B2 (en) | Actionable search results for street view visual queries | |
US8805079B2 (en) | Identifying matching canonical documents in response to a visual query and in accordance with geographic information | |
US9176986B2 (en) | Generating a combination of a visual query and matching canonical document | |
US20110128288A1 (en) | Region of Interest Selector for Visual Queries | |
AU2016200659B2 (en) | Architecture for responding to a visual query |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
STPP | Information on status: patent application and granting procedure in general |
Free format text: APPLICATION DISPATCHED FROM PREEXAM, NOT YET DOCKETED |
|
AS | Assignment |
Owner name: GOOGLE INC., CALIFORNIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:PETROU, DAVID;REEL/FRAME:047247/0207 Effective date: 20140328 Owner name: GOOGLE LLC, CALIFORNIA Free format text: ENTITY CONVERSION;ASSIGNOR:GOOGLE INC.;REEL/FRAME:047276/0038 Effective date: 20170929 |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: DOCKETED NEW CASE - READY FOR EXAMINATION |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: NON FINAL ACTION MAILED |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: FINAL REJECTION MAILED |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: DOCKETED NEW CASE - READY FOR EXAMINATION |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: NON FINAL ACTION MAILED |
|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |