1. Field of the Invention
The present invention relates to aggregation of electronic messages and, more particularly, to aggregation of messages posted to online financial message boards.
2. Related Art
People have long used computer networks to communicate with each other in a variety of ways. Email, for example, enables both one-to-one and one-to-many communication in a way that is analogous to traditional written communications delivered by postal mail. Email became the dominant form of personal communication in the early years of the Internet, perhaps because it is easy to learn how to use and does not require high bandwidth networks or powerful computers to implement.
Email, however, has drawbacks. It is not, for example, useful for many-to-many communications, or for archiving communications for subsequent viewing over the network by those other than the original sender and recipient. Early forms of network communication that addressed these problems were electronic bulletin board systems (BBSs) and newsgroups. Such systems allowed users to post messages on particular topics, and for other users to view messages posted on each topics. Newsgroups remain a popular way for people to engage in conversation and find information on particular topics of interest to them.
Such systems, however, have their own drawbacks. For example, newsgroup postings typically are limited to text, or to text with an attached binary file. Newsgroups, in other words, do not provide users with the rich graphical experience they have come to expect from content on the World Wide Web. Similarly, newsgroup user interfaces typically display only a list of messages in each newsgroup, and do not provide additional graphical content that could be used to enhance the user's experience and/or to display advertisements or otherwise generate revenue for the provider of the newsgroup user interface.
At least in part in response to these problems, web sites have been made available which enable users to access email, newsgroups, and other forms of online communication through a web browser. Such web sites typically provide a graphical user interface through which users may write, post, read, and delete messages. Such web sites may also display advertisements or otherwise employ mechanisms that generate revenue for the provider of the graphical user interface. This approach attempts to create a win-win situation for the web site user and provider, by providing the user with powerful communications features and a rich graphical experience, and providing the web site provider with the ability to generate profit from the value it adds to the user's experience.
A newsgroup is one of many kinds of online message boards. One particularly popular kind of online message board is the financial message board, which is used to exchange information about company stock prices and other financial information. Frequent users of financial message boards require highly current and accurate information, due to the speed at which financial information changes and the consequences of making financial decisions based on inaccurate information. To obtain as much accurate information as quickly as possible, such users may scan multiple message boards for messages about a single stock. For example, financial message board users often refer to relevant information about a company hosted on multiple financial portal web sites, such as the company profile, stock charts, competitors, SEC filings, analyst opinions, news, upcoming events, trades made by officers, and other users' rumors. Furthermore, a single user may track a large number of stocks at the same time, while also keeping track of broader economic trends such as fluctuations in interest rates and currency exchange rates.
The unique needs of financial message board users, therefore, create special challenges for those seeking to design user interfaces for such message boards. For example, it is critical to provide the user with all of the information he desires, but within the constraints of the available display screen and network bandwidth, and without providing the user with so much information at once that he becomes overloaded.
Financial message boards also provide a unique opportunity for web site providers. Heavy users of financial message boards tend to be affluent, well-educated, and Internet-savvy. They also tend to be frequent purchasers of financial products and services, and to purchase such products and services over the Internet. Financial message board users, therefore, represent an attractive market to web advertisers. Web sites that provide access to financial message boards using features that attract large numbers of repeat users would therefore likely be capable of generating significant advertising revenue.
Web content representing a first message is displayed in a window of a computer program. The first message is one of a plurality of messages posted to an online forum. A plurality of message summaries are displayed in the same window of the computer program, contemporaneously with the first message. The plurality of message summaries include first information derived from the first message and second information derived from a second message in the plurality of messages. The web content representing the first message may, for example, be displayed in a first frame of the window and the information derived from the first message may be displayed in a second frame of the same window. The online forum may, for example, be a web-based financial message board. For example, one aspect of the present invention is directed to a computer-implemented method including: (1) displaying, in a window of a computer program, web content representing a first message, the first message, comprising one of a plurality of messages posted to a ‘first online forum; and (2) displaying, in the window of the computer program and contemporaneously with (1), a plurality of message summaries, the plurality of message summaries comprising first information derived from the first message and second information derived from a second message in the plurality of messages.
Another aspect of the present invention is directed to a computer-implemented method including: (1) receiving, over a network, first information comprising a plurality of message data units, wherein each of the plurality of message data units contains information derived from a corresponding one of a plurality of messages posted to an online forum; (2) displaying, in a first frame of a window of a computer program, web content representing a first one of the plurality of messages; and (3) displaying in a second frame of the window distinct from the first frame and contemporaneously with (2), a plurality of message summaries corresponding to the plurality of messages, wherein each of the plurality of message summaries consists of a subset of information in a corresponding one of the plurality of message data units.
Yet another aspect of the present invention is directed to a computer-implemented method including: (1) displaying, in a window of a computer program, web content representing a first message, the first message comprising one of a plurality of messages posted to a first online forum; (2) displaying, in the window of the computer program and contemporaneously with (1), a message summary, the message summary comprising first information derived from the first message; (3) receiving, from a user, input selecting the message summary; and (4) displaying third information derived from the first message, in response to receiving the user input.
Referring to
In general, the window 300 shown in
The web page 306 is an example of a “source” web page as that term is used herein. The message table 302 may include summaries of messages originally posted to more than one source web page. The web page 300, therefore, provides an aggregation service which aggregates messages from a plurality of web-based message boards. The web page 300, therefore, is referred to herein as an “aggregation” web page.
Having described certain general features of particular embodiments of the present invention, techniques that may be used to implement embodiments of the present invention will now be disclosed. Referring to
Furthermore, although only three external message boards 102a, 102b, and 102m are shown in
A single message board, such as a web-based financial message board, may include a plurality of topics, each of which may include a plurality of threads or sub-topics. For ease of illustration and explanation, each of the message boards 102a-m is illustrated in
The aggregation system 100 also includes a message board aggregation server 112 and a corresponding message board 114 (which includes set 116 of messages 118a-n). The message board 114 is managed by the aggregation server 112 or by the same entity that manages the aggregation server. Therefore, the message board 114 will be referred to herein as an “internal” message board, while the message boards 102a-m will be referred to herein as “external” message boards in relation to the aggregation server 112. As will be described in more detail below, the aggregation server 112 aggregates messages from two or more of the message boards 102a-m and 114, and displays content from the aggregated messages in the web page 300.
Referring again to
In the particular example illustrated in
The user 142 selects other input parameters (such as the number of messages to be retrieved) (step 203). As described in more detail below, the aggregation server 112 may store the other input parameters in a set of other preferences 126.
The user 142 selects a particular message board topic to view (step 204). The user 142 may, for example, make this selection by identifying a particular company, such as by typing the company's name or stock ticker symbol in text field 312 and clicking button 314. This is only one of many ways in which the user may select a message board topic to view.
Furthermore, in the embodiment illustrated in
The user's message board selection is transmitted by the web browser 140 over the Internet 138 to the message board aggregation server 112. In response to receiving the user's selection, the aggregation server 112 retrieves information derived from messages in the selected source message board(s) having the selected topic (step 206). In the embodiment illustrated in
Note further that any subset of the external message boards 102a-m may be selectable as a source by the user 142. Such a subset may, for example, consist of all of the external message boards 102a-m, any one of the message boards 102a-m, or any combination of fewer than all of the message boards 102a-m.
The information extracted from the selected source message board(s) by the aggregation server may include any of a variety of information that may be of interest to the user 142. Examples of information that may be extracted from each on-topic message in the selected message board(s) includes, but is not limited to the message title, author, ID, sentiment, time of writing, web page source, person being replied to, and message statistics (e.g., the number of times others have recommended the message, or a rating of the popularity of the message).
At any time during performance of the method 200 illustrated in
The particular selection of fields allowed in the embodiment illustrated in
At any time during performance of the method 200 illustrated in
The aggregation server 112 keeps track of: (1) the source message board(s) selected by the user 142 in source selections 120; (2) the topic (e.g., company) selected by the user 142 in topic selection 121; (3) the field(s) selected by the user 142 in field selections 122; (4) the sort order 124 selected by the user 142 in sort order 124; and (5) any other preferences 126 specified by the user 142.
The aggregation server 112 includes an aggregation engine 128, which generates message content units 132 based on the information extracted in step 206 and the user preferences described above (step 212). For example, the message content units 132 may include a content unit for each message that matches the topic selection 121 (e.g., company) in any of the source message board(s) indicated by the source selection(s) 120. Each of the message content units 132 may include information only for the fields specified by the field selections 122, but this is not required. The message content units 132 may, for example, include extracted information for fields other than those specified by the field selections. The message content units 132 may include all of the information that was extracted in step 206.
As will be described in more detail below, the information in the message content units 132 forms the basis for the information displayed in the message table 302 on the web page 300 (
The aggregation engine 128, therefore, provides message content 130 corresponding to the currently-selected message summary in the message table 302 (step 214). The aggregation engine 128 may, for example, provide the content 130 in the form of HTML and/or other web content by copying the content 130 from its source message board (e.g., one of the external message boards 102a-m or the internal message board 114). The content 130 may either be copied to a storage medium local to the aggregation server 112, or merely passed as a reference to the client web browser 140, which may retrieve the message content 130 directly from its source and display it in the frame 308, without using the aggregation server 112 to serve the content 130 to the user 142.
The aggregation server 112 includes a web page generator 134, which produces an aggregated web page 136 (including HTML and/or other web content) that includes both the message content units 132 and the message content 130 (or a link to the message content 130) (step 216). The aggregated web page 136 may, for example, include a first frame for displaying a table including information from the message content units 132, and a second frame for displaying the message content 130.
The aggregation server 112 transmits the aggregated web page 136 to the web browser 140 over the Internet (step 218). The web browser 140 displays a window (such as the window 300 shown in
As described above, the message content units 132 that are downloaded by the web browser 140 to the local machine of the user 142 may include more information than is displayed in the table 302. The table 302 may, for example, be designed to display only the information that is considered most important to the user 142, such as the title, author, and/or timestamp of the aggregated messages. The user 142 may, however, read a particular one of the message summaries in the table 302 and desire to obtain additional information about the corresponding message. Although the user 142 could obtain such additional information by clicking on the message summary, thereby causing the corresponding message web content to be displayed in the frame 308, this requires the web browser 140 to download and render additional web content. Acquiring additional information about many messages in this way may therefore be tedious and time-consuming.
Alternatively, the web page 300 allows the user 142 to quickly obtain additional summary information about any message listed in the table 302 by, for example, moving and holding (“hovering”) the mouse cursor over the message's summary. For example, in the case illustrated in
Because the additional summary information has been preloaded by the web browser 140 in the process of downloading the message content units 132 from the aggregation server 112, the web browser 140 may generate and display the tooltip essentially instantaneously, and without again accessing the server 112. This allows the user 142 to quickly browse such additional information for many messages listed in the table 302 quickly and easily, simply by moving the mouse cursor over the corresponding message summaries.
The aggregation of messages from multiple message boards at multiple URLs into a single rich web page, including content initially is hidden and that may be displayed essentially instantaneously by the web browser client 140 without the need to make an additional access to the server 112, is made convenient by the increasing availability of broadband connectivity to users. Such broadband connectivity increasingly is available not only through wired networks at home and in the workplace but also through wireless networks accessible using mobile computing devices. By making it feasible for the client web browser 140 to download content-rich web pages without causing the user 142 to incur a significant delay before the web page is displayed, broadband connections allow the web browser 140 to provide a degree of interactivity in web pages that approaches or even matches that previously available only in client-side applications.
Note that the use of a tooltip is provided merely as an example and does not constitute a limitation of the present invention. Rather, the additional summary information may be provided in other forms, such as in a static object (e.g., a text box) on the web page 300. Furthermore, the user 142 may cause the additional summary information to be displayed using actions other than hovering, such as clicking or pressing a hotkey.
The tooltip, or other graphical user interface element that is used to display additional summary information, may be variable in size. For example, the web page 300 may allow the user 142 to select from among three sizes: small, large, and very large. The very large size may be particularly useful for users who are visually impaired. Such a feature may make it possible for visually impaired users to benefit from the features of the web page 300, without requiring the design of the web page (e.g., the font size of text in the table) to change.
Furthermore, the web page 300 may be implemented such that selecting (e.g., hovering or clicking) one of the message summaries in the table 302 always causes the corresponding message to be displayed in the frame 308, while the additional summary information (e.g., tooltip) is displayed. Although there may be some delay in loading and displaying the full message in the frame 308, the user 142 may view the additional summary information essentially immediately, thereby enabling the user 142 to decide quickly whether to wait for the remainder of the message to load or to move on to the next message summary.
The web page 300 may allow the user 142 to post additional messages to any of the source message boards. For example, in the embodiment illustrated in
Similarly, the web page 300 may include a “Reply Message” button (not shown in
Message summaries in the message table 302 may be sorted in any manner. For example, the summaries may be sorted by time of posting by default. The user 142 may, however, sort these messages in other ways (e.g., by message title, message author, message ID, message sentiment, message web page source, person being replied to). If the message table 302 includes message summaries derived from multiple source message boards, the message table 302 may nonetheless display the summaries in an aggregated sorted list. For example, the summaries may be sorted by time of posting, in which case message summaries corresponding to messages from different source message boards may be interwoven with each other according to the times at which they were posted. This feature provides the user 142 with a unified view of messages across multiple message boards.
Among the advantages of the invention are one or more of the following. The features of the web page 300 illustrated in
Furthermore, the techniques disclosed herein make it possible to read and write messages from and to multiple message board sources. Writing messages can be performed either from the web page 300, or at the original message board source in the frame 308. This saves the user 142 time in comparison to reading and writing multiple message boards using distinct web browser windows for each message board.
By providing features that are attractive and useful to frequent users of financial message boards, the techniques disclosed herein provide an opportunity to generate significant revenue from advertising. An example of a banner advertisement for a financial services firm is shown on the web page 300 in
Furthermore, note that content other than an advertisement may occupy the space occupied by the advertisement in
It is to be understood that although the invention has been described above in terms of particular embodiments, the foregoing embodiments are provided as illustrative only, and do not limit or define the scope of the invention. Various other embodiments, including but not limited to the following, are also within the scope of the claims. For example, elements and components described herein may be further divided into additional components or joined together to form fewer components for performing the same functions. In particular, the functions performed by the aggregation server 112 shown in
Although certain examples disclosed herein relate to financial message boards, the present invention is not limited to such examples. More generally, the techniques disclosed herein may be applied to any kind of messaging system, such as email and newsgroups, and to messaging systems containing messages whose content does not relate to finance. Furthermore, the techniques disclosed herein may be applied to aggregate content from web sites and other communications systems that are not designed as message boards. For example, the techniques disclosed herein may be used to aggregate news articles posted to news web sites, such as the web site for the New York Times (www.nytimes.com) or the Business Week (www.businessweek.com), even though such web sites are not designed as message boards to which members of the public may post messages. The term “message,” as used herein, therefore, includes not only messages posted to message boards, but more generally to any unit of communication, such as an email message, a newsgroup posting, or a news article posted by an administrator to a news web site.
As described above, the aggregation server 112 extracts certain information from source message boards to produce the message content units 132. Examples of categories from which information may be derived include, but are not limited to: message title, message author, message identifier, message sentiment, message timestamp, message web address, message thread, message attribute (e.g., size), message link (links contained in the message), message keyword (keywords contained in the message), message recipient, and message statistics (e.g., the number of times others have recommended the message, or a rating of the popularity of the message). The user 142 may be allowed to sort the aggregated message summaries displayed in the message table 302 by, for example, any of the categories mentioned above.
Ease of visual cognition is key to a successful user interface. Various techniques may be combined with those described above to improve such ease of visual cognition. For example, message summaries in the table 302 may be color-coded or otherwise coded (such as by the use of distinct icons or words) according to their source or to any other attribute, such as according to any of the categories mentioned above. The table 302 may include any number of rows and columns. Columns may be assigned to message categories (attributes) in any way. For example, a single column may correspond to a single attribute or to multiple attributes. For example, in one embodiment, there are two columns: (1) title and (2) time and author.
The web browser 140 is not limited to any particular web browser application. The web browser 140 may, for example, be of any kind and operate on any kind of device (e.g., desktop computer, laptop computer, personal-digital assistant, or smart phone). Furthermore, although the network 138 in
The techniques described above may be implemented, for example, in hardware, software, firmware, or any combination thereof. The techniques described above may be implemented in one or more computer programs executing on a programmable computer including a processor, a storage medium readable by the processor (including, for example, volatile and non-volatile memory and/or storage elements), at least one input device, and at least one output device. Program code may be applied to input entered using the input device to perform the functions described and to generate output. The output may be provided to one or more output devices.
Each computer program within the scope of the claims below may be implemented in any programming language, such as assembly language, machine language, a high-level procedural programming language, or an object-oriented programming language. The programming language may, for example, be a compiled or interpreted programming language.
Each such computer program may be implemented in a computer program product tangibly embodied in a machine-readable storage device for execution by a computer processor. Method steps of the invention may be performed by a computer processor executing a program tangibly embodied on a computer-readable medium to perform functions of the invention by operating on input and generating output. Suitable processors include, by way of example, both general and special purpose microprocessors. Generally, the processor receives instructions and data from a read-only memory and/or a random access memory. Storage devices suitable for tangibly embodying computer program instructions include, for example, all forms of non-volatile memory, such as semiconductor memory devices, including EPROM, EEPROM, and flash memory devices; magnetic disks such as internal hard disks and removable disks; magneto-optical disks; and CD-ROMs. Any of the foregoing may be supplemented by, or incorporated in, specially-designed ASICs (application-specific integrated circuits) or FPGAs (Field-Programmable Gate Arrays). A computer can generally also receive programs and data from a storage medium such as an internal disk (not shown) or a removable disk. These elements will also be found in a conventional desktop or workstation computer as well as other computers suitable for executing computer programs implementing the methods described herein, which may be used in conjunction with any digital print engine or marking engine, display monitor, or other raster output device capable of producing color or gray scale pixels on paper, film, display screen, or other output medium.
Referring to
In the particular embodiment illustrated in
For purposes of the following discussion, however, assume that the text input field 402 is used to enter either the name of a company or the stock ticker symbol of the company. The program that provides the text input field 402 may maintain a list of ticker-name tuples. For example, one tuple may include the stock ticker symbol “AAP” and the name of the company having that stock ticker symbol, namely “Advance Auto Parts Inc.” Another tuple may, for example, include the stock ticker symbol “AAPH” and the name of the company having that stock ticker symbol, namely “American Petro-Hunter Inc.” Yet another tuple may, for example, include the stock ticker symbol “AAPL” and the name of the company having that stock ticker symbol, namely “Apple Computer Inc.”
In the particular example illustrated in
If the program determines that the text typed by the user so far matches any of the text in a particular tuple, the program may indicate such a match to the user. For example, if the program determines that the text typed by the user so far matches either the stock ticker symbol or the company name of a particular tuple, the program may indicate to the user that a match has been found. If matches are found with text in multiple tuples, the program may indicate to the user that multiple matches have been found.
In the particular embodiment illustrated in
Furthermore, the subset of each text item in the list that matches the input text may be visually emphasized. For example, in
In the particular example illustrated in
Referring to
Once a list of matching tuples has been displayed (such as any of the lists 406a-c illustrated in
The techniques disclosed herein may be used to reduce the number of keystrokes required to be input by the user. This may save the user effort and enable the user to use the corresponding computer program more quickly. For example, in comparison, conventional financial portal web sites typically provide a “symbol lookup” feature that allows a user to find the stock ticker symbol for a company by typing the company's name, and then clicking on a “find” button. Examples of existing financial portal web sites, some of which provide some form of “symbol lookup” feature, but which do not include the kind of lookup features disclosed herein, include: http://moneycentral.msn.com/investor/common/find.asp?NextPage=/detail/sto-ck quote, http://finance.yahoo.com/lookup, http://money.cnn.com/quote/lookup/index.html, http://www.marketwatch.com/tools/quotes/lookup.asp, http://clearstation.etrade.com/cgi-bin/symbol search, http://www.marketcenter.com/std/search.action, http://www.marketcenter.com/std/toolbox.jsp, http://www.quote.com/qc/lookup/symbol search.aspx, http://www.wallstreettape.com/charts/custom/symbol-lookup.asp, http://online.wsj.com/public/us, http://online.barrons.com/public/main, http://bigcharts.marketwatch.com/symbollookup/symbollookup.asp, http://www.esignalcentral.com/support/symbol/defaultasp, http://www.hoovers.com/free/, http://www.bloomberg.com/apps/tkrlookup, http://www2.barchart.com/lookup.asp, http://stockcharts.com/index.html, http://tools.thestreet.com/tsc/quotes.html?pg=qcn&, http://www.earningswhispers.com/tickerlookup.asp, http://www.whispernumber.com/index.jsp, http://www.google.com, http://quote.morningstar.com/TickerLookup.html, http://www.fool.com, http://www.siliconinvestor.com, http://www.investorshub.com, http://www.ragingbull.com, http://www.boardcentral.com, http://www.briefing.com/, http://www.newyorktimes.com, http://www.washingtonpost.com, http://www.boston.com, http://www.ft.com, http://news.bbc.co.uk/, http://www.inc.com, http://www.forbes.com, http://www.fortune.com, http://research.businessweek.com/ticker/create_ticker.asp, http://www.etrade.com, http://www.ameritrade.com, http://www.schwab.com, http://www.scottrade.com, http://www.sharebuilder.com, and http://www.vanguard.com, http://seekingalpha.com/, http://portfolios.abcnews.go.com/guotes/getQuote, http://www.investorvillage.com/home.asp, http://www.tickertech.com/cgi/?a=lookup, http://www.investors.com/symbol.asp, http://www.cboe.com/DelayedQuote/Symbol.aspx, http://personal.fidelity.com/research/stocks/content/stocksind ex.shtml?bar=c, http://www.quicken.com/investments/tsl/, http://www.globeinvestor.com/static/hubs/lookup.html, http://www.usatoday.com/money/search-tips.htm, http://stockhouse.com/, http://www.thelion.com/, http://www.island.com/, http://www.zacks.com/, http://www.troweprice.com/common/indexHtm13/0,0,htmlid=38,00.html, http://www.amex.com/?href=/quickquote/SymbolLookup.jsp, http://www.nasdaq.com, http://www.nyse.com/, http://www.londonstockexchange.com/en-gb/, http://www.euronext.com, http://www.tsx.com/, http://www.asx.com.au/, http://www.advfn.com, http://www.mldirect.ml.com, http://www.foxnews.com/business/index.html, http://www.quickandreilly.com/, http://www.economist.com/index.html, http://www.kiplinger.com/, http://www.pennystock.com/, http://www.wallstreetselect.com/, http://www.sec.gov/edgar.shtml, http://www.edgar-online.com/, http://freeedgar.com/, http://www.thedeal.com, http://www.investools.com, http://www.activetradermag.com/, http://www.traders.com/, and http://www.ipohome.com.
The techniques disclosed herein may also provide the user with a beneficial degree of flexibility. For example, the techniques disclosed herein provide the user with the flexibility to type either a stock ticker symbol or a company name, depending on the user's preference, or depending on which of the two the user remembers most easily. The user, therefore, is not limited to a particular mode of input dictated by the program. This may make the program easily usable by different classes of users, such as both those users who are sophisticated stock traders (and therefore likely to remember stock ticker symbols) and less sophisticated users (who are likely to remember company names rather than symbols). More generally, the techniques disclosed herein reduce the need for the user to rely on his memory to provide necessary textual input.
It is to be understood that although the invention has been described above in terms of particular embodiments, the foregoing embodiments are provided as illustrative only, and do not limit or define the scope of the invention. Various other embodiments, including but not limited to the following, are also within the scope of the claims. For example, elements and components described herein may be further divided into additional components or joined together to form fewer components for performing the same functions.
Although certain examples described herein use stock ticker symbol and company name as the categories of text strings stored in n-tuples, the techniques disclosed herein may be applied to text strings representing any categories of content. For example, company sector (or other means of categorizing a company) is another example of a category of content to which the techniques disclosed herein may be applied.
Although particular examples disclosed herein involve the use of pairs of text strings, such pairs are merely special cases of n-tuples, in which n=2. The techniques disclosed herein may be applied more generally, to n-tuples where n>1. Furthermore, the text in the tuples may be of any kind and have any relationship to each other. For example, although stock ticker symbols typically have some textual similarity to the corresponding company names, this is not required. For example, an n-tuple may include a person's name and the person's street address, in which case there may be no textual similarity between the various text strings in the n-tuple.
In certain examples disclosed herein, the text typed by the user is matched against the beginning (leading characters) of text in the n-tuples. This is not, however, a requirement of the present invention. Rather, matching may be performed by comparing any subset of the text typed by the user against any subset of the n-tuple text. Furthermore, matching need not be performed against all elements in an n-tuple, or in the same manner against all elements in an n-tuple. For example, if n=3, matching may be performed against two rather than three of the text strings in the n-tuple.
Although certain examples disclosed herein provide the user with an indication of matches by displaying a list of all text in matching n-tuples, this is not a requirement of the present invention. Rather, matches may be displayed in a form other than a list. Furthermore, displayed matches need not display all of the text in matching tuples. The user may be allowed to select a matching tuple using any kind of input mechanism.
Any kind of computer program may implement the techniques disclosed herein. For example, the techniques disclosed herein may be implemented in a web site displayed by a web browser.
Although the concept of an n-tuple is used herein, the techniques disclosed herein may be implemented without storing data in structures organized as n-tuples. Rather, the techniques disclosed herein may be implemented using any kind of data structure, such as linked lists. The data against which the user input is matched may be pre-stored, downloaded over a network connection, generated on-the-fly, or produced, stored, and processed in any suitable manner.
The techniques described above may be implemented, for example, in hardware, software, firmware, or any combination thereof. The techniques described above may be implemented in one or more computer programs executing on a programmable computer including a processor, a storage medium readable by the processor (including, for example, volatile and non-volatile memory and/or storage elements), at least one input device, and at least one output device. Program code may be applied to input entered using the input device to perform the functions described and to generate output. The output may be provided to one or more output devices.
Each computer program within the scope of the claims below may be implemented in any programming language, such as assembly language, machine language, a high-level procedural programming language, or an object-oriented programming language. The programming language may, for example, be a compiled or interpreted programming language.
Each such computer program may be implemented in a computer program product tangibly embodied in a machine-readable storage device for execution by a computer processor. Method steps of the invention may be performed by a computer processor executing a program tangibly embodied on a computer-readable medium to perform functions of the invention by operating on input and generating output. Suitable processors include, by way of example, both general and special purpose microprocessors. Generally, the processor receives instructions and data from a read-only memory and/or a random access memory. Storage devices suitable for tangibly embodying computer program instructions include, for example, all forms of non-volatile memory, such as semiconductor memory devices, including EPROM, EEPROM, and flash memory devices; magnetic disks such as internal hard disks and removable disks; magneto-optical disks; and CD-ROMs. Any of the foregoing may be supplemented by, or incorporated in, specially-designed ASICs (application-specific integrated circuits) or FPGAs (Field-Programmable Gate Arrays). A computer can generally also receive programs and data from a storage medium such as an internal disk (not shown) or a removable disk. These elements will also be found in a conventional desktop or workstation computer as well as other computers suitable for executing computer programs implementing the methods described herein, which may be used in conjunction with any digital print engine or marking engine, display monitor, or other raster output device capable of producing color or gray scale pixels on paper, film, display screen, or other output medium.
A computer program provides a first set of representations (e.g., textual representations) of a first set of hyperlinks. In response to selection by a user of one of the first set of hyperlink representations (such as by clicking on or hovering a cursor over the representation), the program displays a second set of representations (e.g., graphical representations) of a second set of hyperlinks. The user may select one of the second set of representations, in response to which the program navigates to the destination of the hyperlink. The second set of representations may, for example, be logos of companies, and the second set of hyperlinks may be hyperlinks to the companies' web sites.
For example, referring to
In the embodiment illustrated in
The hyperlink representations 504a enable the user to access the underlying hyperlinks to external websites by hovering over selecting any of the hypertext 506a-h. The user may, for example, select a particular link either by clicking on one of the hypertext links 506a-h or by hovering a mouse cursor over one of the hypertext links 506a-h.
In response to receiving a selection of one of the hypertext links 5060a-h from the user, the web page 500 displays a second set of hyperlink representations 504b. In the particular example illustrated in
More specifically, in the embodiment illustrated in
Therefore, when the user selects (e.g., clicks on or hovers over) one of the second set of hyperlink representations 508a-1, the web browser displays the destination of the selected hyperlink in the frame 502b. For example, if the user selects hyperlink representation 508a (i.e., the logo of www.bigcharts.com), the web browser will navigate to and display the home page of www.bigcharts.com in frame 502b.
Different sets of hyperlinks are displayed as the user selects (e.g., clicks on or hovers over) different ones of the first set of hyperlinks 506a-h. For example, as shown in
The techniques just described may, for example, be implemented in conjunction with a message board aggregation web site of the kind disclosed in the patent application entitled, “Message Board Aggregator”, now issued under U.S. Pat. No. 7,529,795.
One advantage of the techniques disclosed herein is that hyperlink representations (e.g., the hyperlinks 504b and 504c) may be displayed to the user essentially instantaneously. Such techniques, therefore, provide the user with a method of scanning through links that is more intuitive and thus quicker for users than traditional techniques. Furthermore, the use of company logos or other graphical representations of hyperlinks facilitates the users experience, because it is likely that the user will already associate the company logo with the corresponding company name (attached to the hyperlink). The method is also visually more appealing than commonly used plain text methods.
It is to be understood that although the invention has been described above in terms of particular embodiments, the foregoing embodiments are provided as illustrative only, and do not limit or define the scope of the invention. Various other embodiments, including but not limited to the following, are also within the scope of the claims. For example, elements and components described herein may be further divided into additional components or joined together to form fewer components for performing the same functions. In particular, the functions performed by the aggregation server 112 shown in
The first set of hyperlinks 504a may be sorted into categories, sub-categories, and so on, in any manner. Alternatively, they may be unsorted. The hyperlinks that are displayed may be predetermined by the web page designer, determined by the user, or any combination thereof. The user may, for example, be provided with the ability to set up categories (and subcategories) comprising favorite website hyperlinks.
Any kind of computer program may implement the techniques disclosed herein. For example, the techniques disclosed herein may be implemented in a web site displayed by a web browser.
The techniques described above may be implemented, for example, in hardware, software, firmware, or any combination thereof. The techniques described above may be implemented in one or more computer programs executing on a programmable computer including a processor, a storage medium readable by the processor (including, for example, volatile and non-volatile memory and/or storage elements), at least one input device, and at least one output device. Program code may be applied to input entered using the input device to perform the functions described and to generate output. The output may be provided to one or more output devices.
Each computer program within the scope of the claims below may be implemented in any programming language, such as assembly language, machine language, a high-level procedural programming language, or an object-oriented programming language. The programming language may, for example, be a compiled or interpreted programming language.
Each such computer program may be implemented in a computer program product tangibly embodied in a machine-readable storage device for execution by a computer processor. Method steps of the invention may be performed by a computer processor executing a program tangibly embodied on a computer-readable medium to perform functions of the invention by operating on input and generating output. Suitable processors include, by way of example, both general and special purpose microprocessors. Generally, the processor receives instructions and data from a read-only memory and/or a random access memory. Storage devices suitable for tangibly embodying computer program instructions include, for example, all forms of non-volatile memory, such as semiconductor memory devices, including EPROM, EEPROM, and flash memory devices; magnetic disks such as internal hard disks and removable disks; magneto-optical disks; and CD-ROMs. Any of the foregoing may be supplemented by, or incorporated in, specially-designed ASICs (application-specific integrated circuits) or FPGAs (Field-Programmable Gate Arrays). A computer can generally also receive programs and data from a storage medium such as an internal disk (not shown) or a removable disk. These elements will also be found in a conventional desktop or workstation computer as well as other computers suitable for executing computer programs implementing the methods described herein, which may be used in conjunction with any digital print engine or marking engine, display monitor, or other raster output device capable of producing color or gray scale pixels on paper, film, display screen, or other output medium.
The present application is a continuation of U.S. application Ser. No. 11/384,957 filed Mar. 20, 2006, now issued under U.S. Pat. No. 7,529,795, which is incorporated herein by reference and which, in turn, incorporates by reference U.S. Provisional Application Ser. No. 60/784,140 filed Mar. 20, 2006 and U.S. Provisional Application Ser. No. 60/784,141 filed Mar. 20, 2006, both of which are incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
4356589 | Mealing et al. | Nov 1982 | A |
5754176 | Crawford | May 1998 | A |
5854630 | Nielsen | Dec 1998 | A |
6065051 | Steele et al. | May 2000 | A |
6199077 | Inala et al. | Mar 2001 | B1 |
6199157 | Dov et al. | Mar 2001 | B1 |
6208339 | Atlas et al. | Mar 2001 | B1 |
6216141 | Straub et al. | Apr 2001 | B1 |
6253325 | Steele et al. | Jun 2001 | B1 |
6282548 | Burner et al. | Aug 2001 | B1 |
6314458 | Steele et al. | Nov 2001 | B1 |
6336133 | Morris et al. | Jan 2002 | B1 |
6393468 | McGee | May 2002 | B1 |
6405238 | Votipka | Jun 2002 | B1 |
6421651 | Tedesco et al. | Jul 2002 | B1 |
6430537 | Tedesco et al. | Aug 2002 | B1 |
6456303 | Walden et al. | Sep 2002 | B1 |
6484149 | Jammes et al. | Nov 2002 | B1 |
6498835 | Skladman et al. | Dec 2002 | B1 |
6515681 | Knight | Feb 2003 | B1 |
6633311 | Douvikas et al. | Oct 2003 | B1 |
6661877 | Lee et al. | Dec 2003 | B1 |
6691158 | Douvikas et al. | Feb 2004 | B1 |
6748449 | Dutta | Jun 2004 | B1 |
6874126 | Lapidous | Mar 2005 | B1 |
6879691 | Koretz | Apr 2005 | B1 |
6889213 | Douvikas et al. | May 2005 | B1 |
6952730 | Najork et al. | Oct 2005 | B1 |
7017109 | Douvikas et al. | Mar 2006 | B1 |
7024451 | Jorgenson | Apr 2006 | B2 |
7069308 | Abrams | Jun 2006 | B2 |
7117254 | Lunt et al. | Oct 2006 | B2 |
7188080 | Walker et al. | Mar 2007 | B1 |
7188153 | Lunt et al. | Mar 2007 | B2 |
7194552 | Schneider | Mar 2007 | B1 |
7231428 | Teague | Jun 2007 | B2 |
7233997 | Leveridge et al. | Jun 2007 | B1 |
7340419 | Walker et al. | Mar 2008 | B2 |
7373338 | Thompson et al. | May 2008 | B2 |
7451161 | Zhu et al. | Nov 2008 | B2 |
7478078 | Lunt et al. | Jan 2009 | B2 |
7487441 | Szeto | Feb 2009 | B2 |
7499940 | Gibbs | Mar 2009 | B1 |
7526440 | Walker et al. | Apr 2009 | B2 |
7590687 | Bales et al. | Sep 2009 | B2 |
7606687 | Galbreath et al. | Oct 2009 | B2 |
7606865 | Kumar et al. | Oct 2009 | B2 |
7669123 | Zuckerberg et al. | Feb 2010 | B2 |
7680882 | Tiu et al. | Mar 2010 | B2 |
7685036 | Hsu et al. | Mar 2010 | B1 |
7725492 | Sittig et al. | May 2010 | B2 |
7752251 | Shuster et al. | Jul 2010 | B1 |
7765568 | Gagnon et al. | Jul 2010 | B1 |
7788260 | Lunt et al. | Aug 2010 | B2 |
7797256 | Zuckerberg et al. | Sep 2010 | B2 |
7809805 | Stremel et al. | Oct 2010 | B2 |
7827208 | Bosworth et al. | Nov 2010 | B2 |
7827265 | Cheever et al. | Nov 2010 | B2 |
7835950 | Walker et al. | Nov 2010 | B2 |
7890501 | Lunt et al. | Feb 2011 | B2 |
7912758 | Walker et al. | Mar 2011 | B2 |
7933810 | Morgenstern | Apr 2011 | B2 |
7945653 | Zuckerberg et al. | May 2011 | B2 |
7970657 | Morgenstern | Jun 2011 | B2 |
8005919 | Mehanna et al. | Aug 2011 | B2 |
20010018698 | Uchino et al. | Aug 2001 | A1 |
20020065671 | Goerz, Jr. et al. | May 2002 | A1 |
20020130895 | Brandt et al. | Sep 2002 | A1 |
20020152238 | Hayes | Oct 2002 | A1 |
20030041147 | van den Oord et al. | Feb 2003 | A1 |
20030061114 | Schwartz et al. | Mar 2003 | A1 |
20030115306 | Hagarty et al. | Jun 2003 | A1 |
20030188263 | Bates et al. | Oct 2003 | A1 |
20030196172 | Bates et al. | Oct 2003 | A1 |
20040098269 | Wise et al. | May 2004 | A1 |
20040143841 | Wang et al. | Jul 2004 | A1 |
20040172405 | Farran | Sep 2004 | A1 |
20040225708 | Christodoulou | Nov 2004 | A1 |
20040254881 | Kumar et al. | Dec 2004 | A1 |
20050049939 | Lai et al. | Mar 2005 | A1 |
20050076110 | Mathew et al. | Apr 2005 | A1 |
20050144573 | Moody et al. | Jun 2005 | A1 |
20050165793 | Mosterman | Jul 2005 | A1 |
20050198128 | Anderson et al. | Sep 2005 | A1 |
20050267940 | Galbreath et al. | Dec 2005 | A1 |
20050278443 | Winner et al. | Dec 2005 | A1 |
20060015821 | Parker et al. | Jan 2006 | A1 |
20060021009 | Lunt | Jan 2006 | A1 |
20060031404 | Kassab | Feb 2006 | A1 |
20060064342 | Frengut et al. | Mar 2006 | A1 |
20060155809 | Arav | Jul 2006 | A1 |
20060168233 | Alcorn et al. | Jul 2006 | A1 |
20060174340 | Santos et al. | Aug 2006 | A1 |
20060206454 | Forstall et al. | Sep 2006 | A1 |
20060239546 | Tedesco et al. | Oct 2006 | A1 |
20060248160 | Plummer | Nov 2006 | A1 |
20070022021 | Walker et al. | Jan 2007 | A1 |
20070028185 | Bhogal et al. | Feb 2007 | A1 |
20070100779 | Levy et al. | May 2007 | A1 |
20070112835 | McMullen et al. | May 2007 | A1 |
20070113201 | Bales et al. | May 2007 | A1 |
20070143704 | Laird-McConnell | Jun 2007 | A1 |
20070192181 | Asdourian | Aug 2007 | A1 |
20070192299 | Zuckerberg et al. | Aug 2007 | A1 |
20080040474 | Zuckerberg et al. | Feb 2008 | A1 |
20080040475 | Bosworth et al. | Feb 2008 | A1 |
20080046976 | Zuckerberg | Feb 2008 | A1 |
20080059607 | Schneider | Mar 2008 | A1 |
20080065604 | Tiu et al. | Mar 2008 | A1 |
20080065701 | Lindstrom et al. | Mar 2008 | A1 |
20080189292 | Stremel et al. | Aug 2008 | A1 |
20080189380 | Bosworth et al. | Aug 2008 | A1 |
20080189395 | Stremel et al. | Aug 2008 | A1 |
20080189768 | Callahan et al. | Aug 2008 | A1 |
20080281816 | Kim | Nov 2008 | A1 |
20080313714 | Fetterman et al. | Dec 2008 | A1 |
20090013413 | Vera et al. | Jan 2009 | A1 |
20090024548 | Zhu et al. | Jan 2009 | A1 |
20090031301 | D'Angelo et al. | Jan 2009 | A1 |
20090037277 | Zuckerberg et al. | Feb 2009 | A1 |
20090048922 | Morgenstern et al. | Feb 2009 | A1 |
20090049014 | Steinberg | Feb 2009 | A1 |
20090049036 | Juan et al. | Feb 2009 | A1 |
20090049070 | Steinberg | Feb 2009 | A1 |
20090049127 | Juan et al. | Feb 2009 | A1 |
20090049525 | D'Angelo et al. | Feb 2009 | A1 |
20090070219 | D'Angelo et al. | Mar 2009 | A1 |
20090070334 | Callahan et al. | Mar 2009 | A1 |
20090070412 | D'Angelo et al. | Mar 2009 | A1 |
20090119167 | Kendall et al. | May 2009 | A1 |
20090144392 | Wang et al. | Jun 2009 | A1 |
20090158143 | Arav | Jun 2009 | A1 |
20090158169 | Arav | Jun 2009 | A1 |
20090182589 | Kendall et al. | Jul 2009 | A1 |
20090193333 | Arav | Jul 2009 | A1 |
20090193349 | Arav | Jul 2009 | A1 |
20090198487 | Wong et al. | Aug 2009 | A1 |
20090199135 | Arav | Aug 2009 | A1 |
20090228342 | Walker et al. | Sep 2009 | A1 |
20090228780 | McGeehan | Sep 2009 | A1 |
20090287786 | Arav | Nov 2009 | A1 |
20100049534 | Whitnah et al. | Feb 2010 | A1 |
20100049852 | Whitnah et al. | Feb 2010 | A1 |
20100132049 | Vernal et al. | May 2010 | A1 |
20100162375 | Tiu, Jr. et al. | Jun 2010 | A1 |
20100164957 | Lindsay et al. | Jul 2010 | A1 |
20100169327 | Lindsay et al. | Jul 2010 | A1 |
20100180032 | Lunt | Jul 2010 | A1 |
20100185580 | Zhu et al. | Jul 2010 | A1 |
20100198581 | Ellis | Aug 2010 | A1 |
20100211996 | Mcgeehan et al. | Aug 2010 | A1 |
20100211997 | McGeehan et al. | Aug 2010 | A1 |
20100217645 | Jin et al. | Aug 2010 | A1 |
20100229223 | Shepard et al. | Sep 2010 | A1 |
20100257023 | Kendall et al. | Oct 2010 | A1 |
20100257459 | Galbreath et al. | Oct 2010 | A1 |
20100306043 | Lindsay et al. | Dec 2010 | A1 |
20100318571 | Pearlman et al. | Dec 2010 | A1 |
20110004692 | Occhino et al. | Jan 2011 | A1 |
20110004831 | Steinberg et al. | Jan 2011 | A1 |
20110016169 | Cahill et al. | Jan 2011 | A1 |
20110016381 | Cahill et al. | Jan 2011 | A1 |
20110016382 | Cahill et al. | Jan 2011 | A1 |
20110018342 | Park et al. | Jan 2011 | A1 |
20110022657 | Zhu et al. | Jan 2011 | A1 |
20110023101 | Vernal et al. | Jan 2011 | A1 |
20110023129 | Vernal et al. | Jan 2011 | A1 |
20110044354 | Wei | Feb 2011 | A1 |
20110055314 | Rosenstein et al. | Mar 2011 | A1 |
20110055332 | Stein | Mar 2011 | A1 |
20110055683 | Jiang | Mar 2011 | A1 |
20110083101 | Sharon et al. | Apr 2011 | A1 |
20110087526 | Morgenstern et al. | Apr 2011 | A1 |
20110106630 | Hegeman et al. | May 2011 | A1 |
20110125599 | Morin et al. | May 2011 | A1 |
20110128699 | Heydari et al. | Jun 2011 | A1 |
20110137902 | Wable et al. | Jun 2011 | A1 |
20110137932 | Wable | Jun 2011 | A1 |
20110145287 | Jiang et al. | Jun 2011 | A1 |
20110145321 | Jiang | Jun 2011 | A1 |
20110153377 | Novikov et al. | Jun 2011 | A1 |
20110153412 | Novikov et al. | Jun 2011 | A1 |
20110153416 | Walker et al. | Jun 2011 | A1 |
20110153421 | Novikov et al. | Jun 2011 | A1 |
20110154223 | Whitnah et al. | Jun 2011 | A1 |
20110154842 | Heydari et al. | Jun 2011 | A1 |
20110156480 | Park | Jun 2011 | A1 |
20110161602 | Adams et al. | Jun 2011 | A1 |
20110161980 | English et al. | Jun 2011 | A1 |
20110161987 | Huang et al. | Jun 2011 | A1 |
20110179347 | Proctor et al. | Jul 2011 | A1 |
20110196855 | Wable et al. | Aug 2011 | A1 |
Number | Date | Country |
---|---|---|
WO 0203243 | Jan 2002 | WO |
WO 02061610 | Aug 2002 | WO |
WO 2004029780 | Aug 2004 | WO |
WO 2007109264 | Aug 2008 | WO |
Entry |
---|
Office Action Summary from U.S. Appl. No. 12/334,068 dated Jun. 10, 2011. |
Nicholas C. Zakas, Professional JavaScript for Web Development, Wrox (2005), pp. 362-364. |
Michael Glass, Beginning PHP, Apache, MySQL Web Development, Wiley Publishing (2004), p. 361. |
James Keogh, JavaScript Demystified, McGraw-Hill Osborne Media (2005), pp. 294-305. |
google.com screenshot captured by web.archive.org (Dec. 15, 2004). |
Bitflux Blog Wild screenshot captured by web.archive.org (Feb. 6, 2005). |
Jon Udell, The Browser Reloaded, InfoWorld.com (Feb. 21, 2005). |
J. Keith, DOM Scripting, Keith (2005), p. 303. |
F. Schneider, How to Do Everything with Google, McGraw-Hill (2004), p. 51-52. |
c/net home page captured by web.archive.org (Mar. 1, 2005), Figs 1-4. |
BoardCentral Website (Feb. 15, 2006). |
StockHouse Bullboards Website (Feb. 15, 2006). |
ClearStation Website (Feb. 15, 2006). |
FreeRealTime Message Boards Website (Feb. 15, 2006). |
MarketWatch Message Boards Website (Feb. 15, 2006). |
The Motley Fool Discussion Boards Website (Feb. 15, 2006). |
MSN Money Message Boards Website (Feb. 15, 2006). |
Yahoo! Message Boards Website (Feb. 15, 2006). |
StockSelector.com Message Boards Website (Feb. 15, 2006). |
SmallCapCenter.com Message Boards Website (Feb. 15, 2006). |
Silicon Investor Message Boards Website (Feb. 15, 2006). |
RagingBull Website (Feb. 15, 2006). |
WallStreetTape.com Website (Feb. 15, 2006). |
InvestorVillage Website (Feb. 17, 2006). |
Forex Trading Website (Feb. 17, 2006). |
Elite Trader.com as viewed on Mar. 21, 2007. |
AllStocks.com as viewed on Mar. 21, 2007. |
InvestorsHub.com as viewed on Mar. 21, 2007. |
TheLion.com as viewed on Mar. 21, 2007. |
Finance.Google.com as viewed on Mar. 21, 2007. |
ADVFN.com as viewed on Mar. 21, 2007. |
EquityGroups.com as viewed on Mar. 21, 2007. |
StockPickr.com as viewed on Mar. 21, 2007. |
StockTickr.com as viewed on Mar. 21, 2007. |
SocialPicks.com as viewed on Mar. 21, 2007. |
Wallstrip.com as viewed on Mar. 21, 2007. |
Monitor110.com as viewed on Mar. 21, 2007. |
CollectiveIntellect.com as viewed on Mar. 21, 2007. |
Office Action Summary from U.S. Appl. No. 11/384,957 mailed on May 13, 2008. |
Notice of Allowance from U.S. Appl. No. 11/384,957 mailed on Feb. 25, 2009. |
Moneycentral.msn.com/investor/common/find.asp?NextPage=/detail/stock—quote (Mar. 15, 2010). |
finance.yahoo.com (Mar. 15, 2010). |
money.cnn.com/quote/lookup/index.html (Mar. 15, 2010). |
Marketwatch.com (Mar. 15, 2010). |
clearstation.etrade.com/cgi-bin/symbol—search (Mar. 15, 2010). |
quote.com/std/search.action (Mar. 15, 2010). |
quote.com/help/resources/toolboxjsp (Mar. 15, 2010). |
quote.com/search.action (Mar. 15, 2010). |
online wsj.com/home-page (Mar. 15, 2010)). |
online barrons.com/home-page (Mar. 15, 2010). |
bigcharts.marketwatch.com/ (Mar. 15, 2010). |
esignal.com/support/default.aspx (Mar. 15, 2010). |
hoovers.com (Mar. 15, 2010). |
bloomberg.com/apps/tkrlookup (Mar. 15, 2010). |
2.barchart.com/lookup.asp (Mar. 15, 2010). |
stockcharts.com/index.html (Mar. 15, 2010). |
thestreet.com/quote/%5EDJI.html?pg-qcn& (Mar. 15, 2010). |
earningswhispers.com/tickerlookup.asp (Mar. 15, 2010). |
whispernumber.com/indexjsp (Mar. 15, 2010). |
Google.com (Mar. 15, 2010). |
quote.morningstar.com/tickerlookup.html (Mar. 15, 2010). |
fool.com/ (Mar. 15, 2010). |
siliconinvestor.advfn.com/ (Mar. 15, 2010). |
investorshub.advfn.com/ (Mar. 15, 2010). |
ragingbull.quote.com/cgi-bin/static.cgi/a=index.txt&d=mainpages (Mar. 15, 2010). |
boardcentral.com/ (Mar. 15, 2010). |
briefing.com/ (Mar. 15, 2010). |
nytimes.com/ (Mar. 15, 2010). |
washingtonpost.com/ (Mar. 15, 2010). |
boston.com/ (Mar. 15, 2010). |
ft.com/home/uk (Mar. 15, 2010). |
news.bbc.co.uk/ (Mar. 15, 2010). |
inc.com/ (Mar. 15, 2010). |
Forbes.com (Mar. 15, 2010). |
money.cnn.com/magazines/fortune/ (Mar. 15, 2010). |
businessweek.com/ (Mar. 15, 2010). |
us.etrade.com/e/t/home (Mar. 15, 2010). |
tdameritrade.com/welcome4.html (Mar. 15, 2010). |
schwab.com/public/schwab/home/welcomep.html (Mar. 15, 2010). |
scottrade.com/ (Mar. 15, 2010). |
sharebuilder.com/ (Mar. 15, 2010). |
vanguard.com/ (Mar. 15, 2010). |
seekingalpha.com/ (Mar. 15, 2010). |
abcnews.go.com/business (Mar. 15, 2010). |
investorvillage.com/home.asp (Mar. 15, 2010). |
tickertech.com/cgi/?a=lookup (Mar. 15, 2010). |
investors.com/symbol.asp (Mar. 15, 2010). |
cboe.com/DelayedQuote/Symbol.aspx (Mar. 15, 2010). |
personal.fidelity.com/research/stocks/content/stocksindex.shtml?bar=c (Mar. 15, 2010). |
investing.quicken.com/public/symbolLookup.asp (Mar. 15, 2010). |
globeinvestor.com/static/hubs/lookup.html (Mar. 15, 2010). |
usatoday.com/money/2007-05-15-search-tips—N.htm (Mar. 15, 2010). |
stockhouse.com/ (Mar. 15, 2010). |
thelion.com/ (Mar. 15, 2010). |
zacks.com/ (Mar. 15, 2010). |
individual.troweprice.com/public/Retail/Products-&-Services/Brokerage (Mar. 15, 2010). |
nyse.com/attachment/amex—landing.htm (Mar. 15, 2010). |
nasdaq.com/ (Mar. 15, 2010). |
nyse.com/ (Mar. 15, 2010). |
londonstockexchange.com/home/homepage.htm (Mar. 15, 2010). |
euronext.com/landing/indexMarket-18812-EN.html (Mar. 15, 2010). |
tmx.com/ (Mar. 15, 2010). |
asx.com.au/ (Mar. 15, 2010). |
advfn.com/ (Mar. 15, 2010). |
mldirect.ml.com/ (Mar. 15, 2010). |
foxbusiness.com/index.html (Mar. 15, 2010). |
economist.com/index.html (Mar. 15, 2010). |
kiplinger.com/ (Mar. 15, 2010). |
pennystock.com/ (Mar. 15, 2010). |
wallstreetselect.com/ (Mar. 15, 2010). |
sec.gov/edgar.shtml (Mar. 15, 2010). |
edgar-online.com/ (Mar. 15, 2010). |
FeedTheBull.com as viewed on Mar. 21, 2007. |
Bullpoo.com as viewed on Mar. 21, 2007. |
thedeal.com/ (Mar. 15, 2010). |
investools.com/ (Mar. 15, 2010). |
activetradermag.com/ (Mar. 15, 2010). |
traders.com/ (Mar. 15, 2010). |
renaissancecapital.com/RenCap/Default.aspx (Mar. 15, 2010). |
ant.com/tags/finance/?page=1 (Mar. 15, 2010). |
freeedgar.com/ (Mar. 15, 2010). |
Office Action Summary from U.S. Appl. No. 12/334,037 mailed on Mar. 9, 2010. |
Notice of Allowance from U.S. Appl. No. 12/334,037 mailed on Oct. 1, 2010. |
Office Action Summary from U.S. Appl. No. 12/334,063 mailed on Mar. 9, 2010. |
Office Action Summary from U.S. Appl. No. 12/334,068 mailed on Aug. 4, 2010. |
Office Action Summary from U.S. Appl. No. 12/334,093 mailed on Aug. 18, 2010. |
Notice of Allowance from U.S. Appl. No. 12/334,063 mailed on Sep. 20, 2010. |
Office Action Summary from U.S. Appl. No. 12/435,296 dated Aug. 20, 2010. |
Office Action Summary from U.S. Appl. No. 12/435,296 dated Feb. 3, 2011. |
Office Action Summary from U.S. Appl. No. 13/099,342 dated Sep. 6, 2011. |
Office Action Summary from U.S. Appl. No. 12/334,093 dated May 12, 2011. |
Office Action Summary from U.S. Appl. No. 13/099,345 dated Dec. 22, 2011. |
Chein, Andrew A., “Concurrent Aggregates: Using Multiple-Access Data Abstractions to Manage Complexity in Concurrent Programs,” ACM, 1990, pp. 31-36. |
Number | Date | Country | |
---|---|---|---|
20090158169 A1 | Jun 2009 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 11384957 | Mar 2006 | US |
Child | 12334024 | US |