This invention relates to a method and apparatus for searching for images, in particular the field known as CBIR (Content based image retrieval) or reverse image searching.
The weakness with traditional image search technologies is that they rely on the user being able to describe what they are searching for in terms of keywords. This works extremely well in some cases (e.g., “photo of Barack Obama”) but is entirely useless when what you are searching for can only be expressed by pointing at an object or another photo, or an abstract idea. CBIR attempts to solve that problem by allowing the user to start a search by supplying an image to search from.
The idea of CBIR is to allow users to search for images based on content rather than by entering keyword queries. The two best known examples of this kind of technology are Google http://www.google.com/insidesearch/features/images/searchbyimage.html and TinEye: http://www.tineye.com/.
Searches based around images are also known in the patent literature. For example, US2012123976 describes methods and systems for object-sensitive image searches. These methods and systems are usable for receiving a query for an image of an object and providing a ranked list of query results to the user based on a ranking of the images. The object-sensitive image searches may generate a pre-trained multi-instance learning (MIL) model trained from free training data from users sharing images at web sites to identify a common pattern of the object.
US2012117051 describes how search queries containing multiple modes of query input are used to identify responsive results. The search queries can be composed of combinations of keyword or text input, image input, video input, audio input, or other modes of input. The multiple modes of query input can be presented in an initial search request, or an initial request containing a single type of query input can be supplemented with a second type of input.
US2012030234 describes a computer-implemented method for generating a search query for searching a source of data. The method comprises: a) receiving image and/or text data; b) extracting one or more search query parameters from the image and/or text data; and c) generating the search query from the or each extracted parameter. Search is, fundamentally, a way to explore a space. In the case of a text-based search engine like those described above, the space that is being searched is typically the space of web pages, and the space is organized around the textual content of those pages, as well as the relationships between them. This space can be visualized as a large graph (in the mathematical sense of nodes connected by edges with arbitrary connections, including cycles, permissible). Navigating the space is only really possible by following links from one site to another: in other words, the search engine's influence ends as soon as you visit a page it has linked you to.
The problem with this model is that it means that you lose your place in the search space, or your ability to perceive your place in the search space, meaning that you are only able to follow a single strand through the space without any guidance related to relevance from elsewhere apart from the information provided by the links on the page you're looking at.
So, after entering a query in a search-engine and clicking on a promising-seeming link, the user is taken to a page which may or may not be what they are looking for. If it's not, the only options they have are to follow links from that page or go back to the search results and try again. But perhaps the user has found that the page is very close to being what they are looking for, and they want to find pages that are like this one; more like this one than the average of the results presented by the search engine. The only way to achieve this is to go back to the search engine and enter a modified query, using keywords learned from the interesting page.
This means that the user needs to understand quite a lot about the way that search engines work, and how to optimize their queries accordingly. It also means that the user needs to store a lot of information in their head, and if they don't then finding the right content can be a hit-or-miss process.
US2010/0312787 recognizes the problem of specifying parameters that control the scope of the search. A user interface is presented which comprises a first screen portion for enabling a search and at least one further screen portion for enabling a sub-search. The user is able to dynamically vary the scope of the on-going search by varying the prioritization of the sub-searches and/or varying the sub-searches which are part of the search. The results of the search are provided in real time as the search progresses and the scope is varied without terminating the on-going search.
WO2012/129062 describes a graphical user interface having a query screen with a query development workspace and a search results panel. The visual representation may enable users of a document searching system to more fully understand the query that is being submitted or has been submitted.
WO2007/137289 describes a user interface having multiple sections which are independently updatable. The sections include a section for inputting a search query, a section for displaying search results and a drop region for moving a result into a notebook. The notebook may be shared with other users and is a virtual basket for collecting and organizing search results.
US2012/0159368 aims to facilitate search history navigation. First and second search icons corresponding to first and second searches are presented on a graphical user interface. By selecting one of the icons, a user can access the search criteria used to generate the results, the quantity of results, the results themselves or any combination thereof.
US2010/0088647 describes the difficulties of searching for images based on a text-based submission of an image query. This is addressed by providing a graphical user interface in which the images are clustered and each cluster is presented with a name for that cluster.
The applicant has recognized the need for an improved searching method and apparatus.
According to a first aspect of the invention, there is provided a computer-implemented method of conducting a search comprising receiving a first image query which comprises a user selection of a first feature within a first user selected image; searching for results which match said first image query; outputting said first search results to a graphical user interface for said user; receiving a second image query which comprises a user selection of a second feature within a second user selected image which is selected from within said first search results; repeating said searching and outputting steps based on said second image query; displaying said first and second search results together on said graphical user interface and receiving a third image query based on a third user selected image which is selected from within said first search results and said second search results. This method may be implemented on a system.
According to another aspect of the invention, there is provided a system for conducting a search comprising: a processor which is configured to receive a first user image query comprising a user selection of a first feature within a first user selected image; a search engine which is configured to search for results which match said first image query; output said search results to a graphical user interface for said user; wherein said processor is further configured to receive a second image query which is comprises a user selection of a second feature within a second user selected image selected from within said first search results; wherein said search engine is further configured to repeat said searching and outputting steps based on said second image query; display said first and second search results together on said graphical user interface and receive a third image query based on a third user selected image which is selected from within said first search results and said second search results.
These tools encourage users to adopt an exploratory search method, where the user starts from one point (perhaps an image they've seen on a web site) and systematically refines their search in a series of steps and possibly through one or more iterations of these series of steps until they find the image or images they are looking for. The third image query may be processed in a similar manner to the first and second image queries. In other words, the searching, outputting and displaying steps may be repeated. It will be appreciated that there is no limit to the number of subsequent image queries which may be received.
Each feature may be a subsection of said user selected image, e.g. a chair within a picture of a room. The feature may be a shape, color, texture, pattern or other parameter of an object within said user selected image. The or each selected feature from each selected image may be the same or different.
The iterative nature of the search may be supplemented by using a composite image as the basis of the image query. There may be more than one feature selected from within each selected image for each image query. For example, a user selection of a first feature may be received from within said first user selected image and a user selection of a second and third feature may be received from within said second user selected image. Moreover, each image query may be a composite image query comprising at least one feature selected from each of a plurality of user selected images. For example, the second query may comprise a composite image query formed from a user selection of a second feature within a second image selected from within said first search results and a user selection of a feature within a different image also selected from within said first search results. The third query may comprise a composite image query formed from a user selection of a third feature within a third image selected from within said second search results and a user selection of a feature within an image selected from within said first search results. The composite image query may be a combination all the selected features.
By combining features from two or more images, the invention allows the user to search from multiple images as well as specifying what exactly it is about an image that they want to search for. By providing this functionality in the query server, an improved apparatus for searching is provided.
At least one of said user selected images may be segmented into a plurality of objects which may be presented to a user, e.g. on a user interface. Said feature may be selected from one of said plurality of objects, e.g. by clicking on said object.
A weight may be applied to each selected feature when combining to form said composite image. Said weight may be adjusted by said user.
The invention further provides processor control code to implement the above-described systems and methods, for example on a general purpose computer system or on a digital signal processor (DSP). The code is provided on a physical data carrier such as a disk, CD- or DVD-ROM, programmed memory such as non-volatile memory (eg Flash) or read-only memory (Firmware). Code (and/or data) to implement embodiments of the invention may comprise source, object or executable code in a conventional programming language (interpreted or compiled) such as C, or assembly code. As the skilled person will appreciate such code and/or data may be distributed between a plurality of coupled components in communication with one another.
The invention is diagrammatically illustrated, by way of example, in the accompanying drawings, in which:
a shows one application of the method of
b shows an alternative application of the method of
a and 3b are representations of weighting which is an optional feature in the method of
a and 4b illustrate different ways of selecting an input image for the method of
a is an illustration of a typical system for implementing the method,
b is a screenshot showing an example of how the browser extension (with Google's Chrome browser) might be implemented;
a to 7c show graphical user interface at various stages through
a and 8b are alternative graphical user interfaces for presenting search results to a user; and
As
In order for the user of the system to specify which part of the image they are interested in, they need a mechanism for selecting parts of images. Examples of the kinds of selection methods that might be used include:
Rectangular selection boxes which are overlaid on the original image (as shown in
Polygonal (the user selects a number of points on the edge of the area they're interested in, and a polygon is created that joins those points)
Lasso (the user draws free-hand around the area they are interested in).
Automatic segmentation (in this case, the system automatically segments the image into a number of objects, and the user is able to simply click on one object (or more than one object) to indicate which one they are interested in).
The next step S104 is to consider whether or not other images are to be added into the search. If additional images are to be used, the method loops back to the first step and repeats the selection of the image and the selection of the feature within the image. If additional images are not to be used, the method combines the selected image(s) and feature(s) at step S106 to create a composite query which is searched. Creating the composite query may comprise creating a composite image made up of the selected image(s) or feature(s) but it is also possible to combine the selections without creating a composite image. This combination step may be termed ‘Clamp and Combine’. ‘Clamping and combining’ allows the user to select specific aspects of an image (for example its shape alone, or a combination of color and texture) which are then “clamped” into the search. This effectively filters the search results with multiple clamps, which when combined provide a more refined and useful end result.
As set out above, the feature(s) selected may be part of an image or a feature within the part. The user can indicate which features they want to search, and can combine that partial image with another (whole or partial) image. The user indication of the feature(s) within a (whole or partial) image(s) may be a textual description. For example, the user may say “I want to search for an image that has the color of this part of image 1 but the shape of this part of image 2”. Automated segmentation facilitates such selection. The segmentation would enable the user to select an object within an image (e.g. a car, a dress, a cat or a tree) by simply clicking on the object of interest. In this case, the system could optionally provide a textual description of the selected feature(s) and image(s), for example by displaying a message such as: “You have selected an image of a lady wearing a black dress”. The user indication could then be confirmation that the message is in line with their selection.
An improvement which is optionally included in the method is to add weight features according to how strongly the user would like to see those features displayed in the next round of search results. As shown at step S108, these weights may be presented to a user. At step S110, user input on weighting is received. The user input may be in response to the presentation at step S108 or may be independently input.
Another optional improvement is to add domain filtering. At step S112, the user also has the ability to impose a structured domain filter on the image. For example, the user might select an image of a dress but restrict the search to the domain of skirts or curtains, to find a different type of item that is of the same color.
Once all the inputs are received, the search is carried out at step S114 and the results are output (step S116). A number of different algorithms may be applied for the searching itself. Examples include:
Color matching: comparing histograms of colors using chi-squared distance.
Shape matching: a method such as Histogram of oriented gradients (HOG: http://en.wikipedia.org/wiki/Histogram_of_oriented_gradients)
Texture matching: a method such as that described by Haralick in his 1973 paper: http://dceanalysis.bigr.nl/Haralick73Textural %20features %20for %20image %20classification.pdf
Pattern matching: matching larger-scale patterns such as stripes, dots, flowers and checks that appear on clothing and other products.
In fact, the invention is not dependent on these specific methods: it could be deployed using a different set of algorithms for matching shape, color, pattern and texture, or indeed using algorithms for matching a range of other feature types (e.g. automatically extracted objects). Furthermore, the output of the searches may be a ranked list as is well known in the art. Alternatively, the output may not be ranked.
As an alternative for searching for matching results, an extension may be to generate new images at step S114. For example, the user may select an image of a dress and select the color green to form the composite image to the input to the system, i.e. the user might say “I'm looking for a dress like this, but in green”. The system would use its knowledge of images, objects, shape, color, pattern and texture to generate a new image that reflects that requirement. Similarly it might be asked to combine features from two or more images and use those to create a new image that reflects those combined features. This could, for example, be applied to icons: If a user has found a pair of icons, one of which has the color they are looking for and one which has the right shape, they might initiate a search using those selected features. If the search finds an existing icon that combines these features, this will be presented to the user, but in the case where no such icon exists, the system might generate a new icon which combines the selected features.
The results may just be the first round of the search process and thus a user is queried whether or not the search results are acceptable at step S118. If the user has found what they are looking for, no further searching is required and the process ends. Otherwise, the search results themselves may be used to form the basis of the next round of searching. This may be as simple as a user clicking on one of the images from the search in which case the method returns to step S100. Alternatively, an iterative search as detailed in relation to
The selection (or non selection) of features effectively turns off or on a range of features (together or individually) as part of the search process. Thus it becomes possible for a user to provide non-linguistic, highly intuitive feedback to the image search engine. This is much more like the way humans naturally describe things to one another by pointing and showing, and saying ‘more like this bit’ or ‘similar to this shape’. By the iterative repetition of the search steps, a user can ‘steer’ their way towards a satisfactory end result, without needing to describe in words what they are looking for.
The method described here encourages a new way of searching for images via an evolutionary navigational process. In other words, a user might start with a query (e.g. a dress), narrow the search by specifying a particular feature (e.g. color), narrow the search further by combining this with a feature from another image (e.g. the texture of a shirt) and then navigate by clicking on the images that seem closest to the one they are looking for. Each click on an image starts a new search (possibly modulated by the elements included in the original search) and brings the user one step closer to what they are looking for. And when it doesn't, i.e., when it takes the user further from what they're looking for, they back-track and try again. Back-tracking may be facilitated by use of a specially adapted user interface as described in more detail below.
a shows one application of the method of
b shows an alternative application of the method of
a illustrates one method of presenting a user with a weighting for a feature. For example, the user may be shown the colors that were identified in the image which forms the basis of the search. In this case, the image 40 selected is a dress, and the bar 42 above the image shows the relative weights of each color contained in the image. In this example, a bright red has the highest weighting with a first shade of black having the next highest weighting. The user can adjust the relative weights of the individual colors, for example, by dragging the divisions between the colors. Alternatively, a user can remove colors, for example by clicking on the color and selecting delete. Removal of the color shows that a user is not interested in this color, e.g. the black parts of this image. Finally, a user may be able to add in new colors. This may be done by a user inputting a textual description (e.g. “I'd like to find an item that is this shade of red, but with a bit of green added in as well”) or alternatively a menu could be provided (perhaps by clicking on the bar) to allow a user to select other colors.
The user may be shown the representation of
a and 4b illustrate how the first step of the method of
In
Thus, the first step S100 of
a shows a system in which the method may be implemented. The search service is deployed using the normal components of a search engine which includes at least one query engine 74 to prompt for and respond to queries from users. This system can be formed of many servers and databases distributed across a network, or in principle they can be consolidated at a single location or machine. The term search engine can refer to the front end, which is the query engine in this case, and some, all or none of the back end parts used by the query engine, whose functions can be replaced with calls to external services.
A user can make searches via the query engine using an input device 70. The input device may be any suitable device, including computers, laptops, mobile phones. The input device 70 is connected over a network 72, e.g. a wireless network managed by a network operator, which is in turn connected to the Internet via a WAP gateway, IP router or other similar device (not shown explicitly). Each input device typically comprises one or more processors 84, memory, user interface 86, e.g. devices such as keypad, keyboard, microphone, touch screen, a display and a wireless network radio interface.
The processor 84 of the input device 70 may be configured to create the composite query which is sent to the query server 72 for searching. Thus the processor of the input device may be configured to receive a user selection of at least one image and at least one feature within each image, e.g. from the user interface on the input device 70. The processor 84 may then combine the selections, add any weighting or filters and send the composite query to the query server. Some or all of the steps in creating the composite query may be undertaken by the processor 82 of the query server. In this case, the processor of the query server may be configured to receive a user selection of at least one image and at least one feature within each image from the input device 70. The processor 82 may then combine the selections, add any weighting or filters and search for the resulting composite query. As explained above, the method provides a better query which initiates the search and thus when the query engine is enabling a user to the input this improved query, the query engine is effectively acting as a more efficient query server.
As shown in
As a browser plug-in/extension. When a user views an image in a user interface 60 they are interested in, they could right-click on the image to reveal a context-sensitive menu 62. Within this menu would be an option to search for similar images. Having selected this, a side-bar 64 would appear showing similar images and providing further options. This is illustrated in
As a dedicated web site.
As an addition to an existing e-commerce site.
As a native app on a mobile phone or other hand-held device (and in this case it could be used to find similar objects to one contained in a photo taken using the device).
There are various applications for the described method. For example, with reference to
Clearly, there is a more general application as a tool for helping people find interesting content. Like
This method can be applied to searching for content of all kinds, but in this example we will focus on image-searching. The user starts by entering a query (S200), which could be specified as a keyword query or by pointing to an image (e.g., by uploading it from a phone or by clicking on an image on a web page).
As shown in
First, the user can initiate a new search from one or a combination of the search results (S208). This could be achieved simply by selecting one of the displayed images and initiating a new search. The selected image may be very close to what a user is seeking or alternatively, may just be a step closer to what they are looking for than anything else. In this last case, the user is embarking on an evolutionary-style process of manual artificial-selection. In other words, they are perhaps searching for a blue dress of a particular shade of dark blue, and the system has shown a lot of dresses in various colors. Accordingly, they select the one that is pale blue because it is, at least, blue. The next set of search results contains a lot of blue dresses, including some that are darker blue, so the user selects one of these darker blue images. The next set of images are all dark blue dresses, and the user can keep following this process until they have narrowed in on the precise item they are searching for.
A combination of features from different images within the search results may also be selected. For example as shown in
The method then loops back to step S204 to determine whether or not the correct image is shown. As before, if one of the search results is suitable, the search is terminated. However, if the search results are not what is desired, the user can run another search.
The user can then select a single feature or a combination of features from one or more images in the second set of results and run a new search. For example, the user can select the pattern from the fifth image and the results of this search are shown in
Such a presentation of results allows the user to follow an iterative search mechanism. For example, after following a thread towards stripes, perhaps the user realizes that the he is only interested in striped shirts. The user interface of
As another alternative, perhaps the user has followed a search thread towards darker dresses and now realizes that although they are seeing dresses of the right color, the dresses are no longer in the right style. Perhaps they are looking for a ball-gown and the search has produced mainly plain dresses such as cocktail dresses. The user now wants to be able to say something like “I want dresses that are this color but have the same style as the dresses I had in the results list for my first query”. The iterative search system provides this capability. Similarly, the user may go down a wrong path, perhaps making the dresses too dark, and they can then easily backtrack up a level to see the previous set of dresses and follow a new path from one of those.
This process can be repeated, enabling the user to add many images to their search: “I want something that captures the essence of these 5 images”. And this process can be hidden from the user and made automatic: effectively learning from the user's behavior what are the kinds of images, colors, shapes, styles or objects that they are more likely to be interested in, meaning that when a user initiates a completely new search this additional information can be taken into account to bias the first set of results.
In
b shows another graphical user interface in which four search results are presented. Symbols rather than letters are used to depict the features (color, pattern and type) that may be selected. Although
a to 8b also show only a maximum of four sets of search results on a single page of the graphical user interface. However, all of the earlier sets of search results are also retained so that a user may select feature(s) from image(s) in any previous search. It is expected that a vertical scroll bar will also be included to allow a user to access previous search results. However, it will be difficult for a user to navigate all the previous sets of search results if too many results are presented. Accordingly, the user interface may be enhanced by including a side-bar or other drop zone on the screen into which a user can move individual images. These images may form a set of favorites for a user. Any images moved (or simply dragged and dropped) into this area may be stored for ease of including them in subsequent searches.
Some or all of the images in the drop zone may be combined with some or all of the images in other search result sets. This means, for example, that it's possible (and easy) to combine an image from one query with an image from a query that is carried out many queries later. It also could become a mechanism for a user to store all kinds of items that they like, indicating that they like everything about one image (i.e., all features) and the color of one and the pattern of another. The user could then say “carry out a search for an image like this dress, but take into account my entire set of favorites”, which would create a very large query, combining features from lots of images or any other items stored in the drop zone.
The query is submitted, via the Internet, to the query engine or server 52. The server 52 comprises a plurality of modules including a web server 54, image search engine 56, a feature extractor 58 and images on disk 60. The search query is received at the web server which in turn passes the query to the image search engine 56. The image search engine 56 checks whether the features for the query image are already available. If they are not available, the image search engine 56 passes the query image to the feature extractor 58 to extracts feature from the query image as described above. Once the image search engine has the required features, these features are then compared with the features for the images in the image database 62 to find the most similar images. These images are submitted back, via the web server, to the user's browser as a set of search results.
A key difference in the proposed method is the common display of multiple historic searches. Accordingly, it is necessary to store the set of search results. Information about the query and its results may be stored in the local storage on a user input device. Such storage may be managed by the web browser. For example, on a subsequent query, information from the local storage may be combined with the information from the current query results to generate a new query, which proceeds as above. Alternatively or additionally, a user's query information could be stored by the query server in a user database 64, so that subsequent queries that the user makes (say, from a different PC or just after the local storage has been cleared) could still take into account previous query results or stored information.
In all the embodiments above, the image is preferably a digital image which may be stored in any convenient file format, such as JPEG, GIF, BMP etc. The image may be a photograph, a graphic, a video image or any combination thereof. Each digital image includes image data for an array of pixels forming the image.
In
The query engine or server for conducting the search, including servers for indexing, calculating metrics and for crawling, can be implemented using standard hardware. The hardware components of any server typically include: a central processing unit (CPU), an Input/Output (I/O) Controller, a system power and clock source; display driver; RAM; ROM; and a hard disk drive. A network interface provides connection to a computer network such as Ethernet, TCP/IP or other popular protocol network interfaces. The functionality may be embodied in software residing in computer-readable media (such as the hard drive, RAM, or ROM). A typical software hierarchy for the system can include a BIOS (Basic Input Output System) which is a set of low level computer hardware instructions, usually stored in ROM, for communications between an operating system, device driver(s) and hardware. Device drivers are hardware specific code used to communicate between the operating system and hardware peripherals. Applications are software applications written typically in C/C++, Java, assembler or equivalent which implement the desired functionality, running on top of and thus dependent on the operating system for interaction with other software code and hardware. The operating system loads after BIOS initializes, and controls and runs the hardware. Examples of operating systems include Linux™, Solaris™, Unix™, OSX™ Windows XP™ and equivalents.
The following describe examples for creating the composite image used as the search query:
1. A user is a casual shopper wanting to find some jewelry for his wife. He knows the kinds of things she likes, but have no idea what they have in common. He can recognize the right kind of thing, but has no idea how to describe it. Initially, he would select a random set of jewelry and would click on the one that was closest to what he was looking for, and would navigate from there.
2. A user is a shopper with a specific need for a replacement item of jewelry. The shape is like a polo (a circle with a hole in the middle) and the kind of material is quartz, maybe, or some crystalline pink-ish material. The composite image would be formed by selected an image and selecting the polo shape and by selecting an image and selecting the color pink. The user would navigate from there.
3. A user is a designer, looking for a good background image to go on a piece of marketing material. As shown in
4. A user is a casual shopper wanting to buy a coffee table for the lounge. The user uploads a photo of the lounge as the image to be searched. The results will return similar lounges, possibly with coffee tables. Once an image with a suitable table is returned, the user can select the table as the input to the search to find a place to buy that (or a similar) table.
5. A user is an art lover wanting to buy a painting that will look good in a room that already has two paintings. Photos of the two paintings are uploaded to form the composite image for the search. The search results will return other paintings with similar properties (color, texture, etc.) to those two.
6. A user is a casual shopper looking for a bed-spread that matches the curtains. A photo of my curtains as the image in step S100, and the user follows the other steps of the method.
7. A user is a casual window shopper who likes to browse the internet looking at things he might buy one day. Occasionally he'll buy something. Starting from a link sent by a friend, he is shown other similar items. Clicking on one of those items provides the image in step S100, and the user follows the other steps of the method.
8. A user is a house-buyer. He uploads a photo of a house he likes that is not for sale as the image in step S100. Features such as style, age, shape can be used to generate the composite image and a filter can be applied to generate results in the right area.
9. A user is a female shopper browsing the internet looking for new clothes. One day, she sees a dress she likes and clicks on the “I like this” button on the browser add-on. This triggers the searching by the system which returns a collection of similar dresses, and other types of clothing that have similar patterns and colors depending on the features and/or weighting applied by the user.
10. A user is a shopper who sees an architectural feature on a building. He uploads a photo of the feature to find an object for inside the home (a sculpture, a light—fitting etc.) that is similar in style.
11. A user is redecorating his house, and looking for a bath shower-tap thing that is similar in shape to an old-fashioned phone handset. The image in step S100 is a picture of a phone which can be combined with the shower category (either by filtering of using an image of a shower).
12. A user is building a web site and looking for an icon that will fit with my existing design. The composite image is built from an icon that has the right shape and another that has the right color palette. The search is thus initiated from these two icons.
No doubt many other effective alternatives will occur to the skilled person. It will be understood that the invention is not limited to the described embodiments and encompasses modifications apparent to those skilled in the art lying within the spirit and scope of the claims appended hereto.
Number | Date | Country | Kind |
---|---|---|---|
GB 1212518.3 | Jul 2012 | GB | national |
The Present application is a continuation of U.S. patent application Ser. No. 13/648,105 entitled “Method and Apparatus for Image Searching” and filed by Coppin et al. on Oct. 9, 2012, which claims priority to Great Britain Patent Application GB 1212518.3 filed on Jul. 13, 2012. The entirety of the aforementioned references are incorporated herein by reference for all purposes.
Number | Date | Country | |
---|---|---|---|
Parent | 13648105 | Oct 2012 | US |
Child | 13804382 | US |