The invention generally relates to social networks. More particularly, the invention relates to distributing content across communities within online social networks.
Online social networks connect users with common interests to each other. Social networking sites such as Myspace.com, Friendster.com, Tribe.net, and Orkut.com foster relationships between their members, thereby offering a higher level of affiliation and trust than other online media through which users can interact with each other such as electronic message boards or forums.
Communities, organized around a theme, interest, or common endeavor represent a major organizing unit in a number of online social networks. Members within a community can observe, interact, and form affiliations with other members of a community by virtue of their community activities. Community members may decide what other users to reach out to or network with based on another user's community memberships.
Despite the importance of communities to online social networks, existing processes for interacting within and between communities are often clumsy. User interests often straddle more than one existing community, making it difficult to choose what community to join or post content to. In addition, content posted to one community may be of interest or highly relevant to another community of which the user is not aware. Unless members of other communities actively seek out content posted to the user's community, opportunities for the user to connect with other members through the content are missed.
An online social network provides novel methods of distributing content within the network. In an embodiment, content to be posted to a host community along with labels to associate with the content are received. The labels are used to identify communities in the online social network to which to post the content. Code is generated that, when executed, displays the content on a webpage of the host community, and displays the content on a webpage of each of the identified communities. The content may comprise one or more blogs, events, images, albums of images, forum topics, or forum topic replies.
Furthermore, in an embodiment, one or more replies to the posted content are received. In one disclosed method, code is generated that, when executed, displays the one or more replies on the webpage of the host community and the webpage of each of the identified communities. According to another method, code is generated that, when executed, displays the one or more replies on a single webpage to which access is provided to members of the host community and members of each of the identified communities.
The figures depict embodiments of the invention for purposes of illustration only. One skilled in the art will readily recognize from the following description that alternative embodiments of the structures and methods illustrated herein may be employed without departing from the principles of the invention described herein.
The present disclosure describes various methods and systems for the creation of communities in online social networks and distribution of content within them. Techniques and systems for ranking objects such as users, forum topics, albums, blogs, and communities within social networks are also disclosed. The techniques described herein can be applied to various online social networks including public and private online networks, social networks within enterprises, and social networks within other environments.
The features and advantages described herein are not all-inclusive and, in particular, many additional features and advantages will be apparent to one of ordinary skill in the art in view of the figures and description. It should also be noted that the language used in the specification has been principally selected for readability and instructional purposes, and not to limit the scope of the inventive subject matter. Furthermore, the description herein focuses on selected features of online social networks including communities, forums, and ranking systems. Other techniques, functionalities, and components not discussed, whether conventional or custom, can be used as desired in conjunction with providing these features, as will be apparent in light of this disclosure.
The social network server 200 enables users of devices such as clients 102, to interact with other users in an online social network. The various servers in the social networking system 100 may comprise a dedicated server-class computer system comprising applications, one or more processors, memory, storage, and associated software applications. The servers may also individually comprise multiple computers operating under a load balancing scheme, or other mechanisms for distributing processes and data.
The social networking system 100 supports an online social network comprising a set of entities who are members of the social network, and who communicate with each other via the services and facilities of the system 100. A member of an online social network can be any entity such as, for example, a person, an organization, a business, a corporation, a community, or other suitable entity. These entities can have various types of social relationships, such as community membership, professional or social organizations, friendships, or simply groups with common interests.
Each member is represented by a stored profile that comprises one or more entries containing information about the member. A member may be represented by a person profile, business profile, organizational profile, or a profile belonging to any other class of profile. Each member has an identifier that can be used to identify the member within the network (e.g., a user name). Each profile type is associated with different types of entries. For instance, a person profile can include entries comprising contact, personal, and professional information, while a business profile may include entries describing industry information or financial information. Other entry types can store social, demographic, networking, or other types of information. Personal profile entries may comprise contact information such as email addresses, mailing addresses, IM name, or phone number, personal information such as relationship status, birth date, age, children, ethnicity, religion, political view, sense of humor, sexual orientation, fashion preferences, smoking habits, drinking habits, pets, hometown location, passions, sports, activities, favorite books, music, TV, or movie preferences, or favorite cuisines, professional information such as skills, career, or job description; photographs of a person or other graphics associated with an entity, or any other information describing, identifying, or otherwise associated with a profile. Entries for a business profile can comprise industry information such as market sector, customer base, location, or supplier information, financial information such as net profits, net worth, number of employees, stock performance, or other types of information associated with the business profile.
Each member's profile includes information that associates the member with the profiles of other members in the social network. An association between members has a type. Types of associations include, for example, friendships, romantic relationships, business relationships, acquaintances, community associations, activity partner associations, common interest associations, common characteristic associations, or any other suitable type of association between profiles. For example, a user may designate himself as a “fan” or a “friend” of another user. A given type of association can have multiple levels to indicate the degree of the association. For example friendship levels can include, for example, a “haven't met” level, an “acquaintance” level, a “friend” level, a “good friend” level, a “best friend” level, or other suitable levels. Similar levels for other types of associations are readily determined by those of skill in the art.
The social network system 100 further supports the creation and manipulation of a variety of social network objects. The social network objects include the members themselves (as represented by their user name), as well and the various types of content objects supported by the social network, including forums and message posting therein, blogs, community, albums, images, media files, articles, documents, and the like. Users of clients 102 can enter search queries (e.g., via a browser) to search for any of these objects in the social network system 100. The search queries are provided over the network 106 to the social network server 200 and processed by a search engine 305. The search engine 305 comprises code for parsing search queries, a crawler for locating social network objects, and a ranking module 330 for ranking and indexing social network objects. The search engine receives search queries and can perform Boolean or relevance searching based on the queries. The results are ordered in accordance with the indexing performed by the ranking module, and provided to the community server 300. The community server 300, in turn, takes the search results and provides them in a format that the requesting client 102 can use to present the data to the user (e.g., via a browser or other application). If no matches are found, alternative search queries may be provided to users, as is discussed in greater detail with respect to
The ranking module 330 evaluates and ranks various online social network objects returned in response to a query and is described in greater detail with reference to
The social network server 200 also comprises a community server 300 for carrying out various aspects of online community management such as creating and operating communities. Communities are named and preferably have descriptions that specify the types of topics, events, and members of the community. Communities may also have keywords and/or labels that indicate the types of topics and subject categories that are off interest to the members of the community, and which can be used to classify the community and its members. Posting within a community may be moderated by a member or online community provider comprising a community “owner” or may be unmoderated. Community membership may be restricted in some manner or may be open to the public at large.
Communities may be placed into various categories and subcategories of organization. Community subcategories can comprise groups of profiles within a larger category that share common interests or characteristics independent from the entire community. For example, a general “basketball players” community category can comprise communities of basketball players for any location or type of basketball. A sub-community category within the basketball community category could comprise communities of basketball players belonging to a certain geography. Thus, a “California basketball players” sub community category could comprise communities including “LA basketball player,” “Oakland basketball player,” and “Santa Clara basketball player” communities. The general “basketball community” can also be placed into a larger overall “basketball” community that includes “basketball player” communities as well as “basketball watcher” communities.
The community server 300 supports the management of variety of community features and social objects therein, such as forums, events, messaging, blogs, photo albums, maps, links to news and web pages, relevant advertisements, and affinity and other links to other members or communities, as described in greater detail with reference to
Community content, links, images, postings, relationships, descriptions, and other community data as well as member data and profiles are stored by community server 300 within the social network database 130. The database 130 may be implemented as one or more relational database management system (RDBMS), lightweight database access protocol (LDAP), flat file, and/or other databases, or using another database architecture. Data storage elements may include any one or combination of methods for storing data, including without limitation, arrays, hash tables, lists, and trees. Other similar types of data storage devices can be accessed by the server 200. The community server 300 receives data comprising the profiles and communities from the social network database 130 and also sends data comprising communities and profiles to the social network database 130 for storage. The social network database 130 is communicatively coupled to the social network server 200 by way of a network connection (not shown).
The social network server 200 is coupled to an internet server 150 and a messaging server 160. The internet server 150 comprises a server for serving content to requesting clients. Through its connection to the internet server 150, the social network server 200 can provide internet content to online social networks and communities, through links to relevant web pages, news, advertisements, and pages discussed within community forums. In an embodiment, the internet server 150 or social network server 200 is coupled to a messaging server 160 for providing instant messaging, email, or other messaging services. The messaging server 160 also or alternatively comprises a mobile device messaging server that is in communication with a cellular phone or other mobile communications network. The social network server 200 can communicate and exchange messages on behalf of social network members using the server 160.
The client devices 102 shown in
The network 106 enables data communication between and among the entities shown in
It should be noted that embodiments of the present invention may comprise systems having different architectures than that which are shown in
The community webpage includes a search interface 210 for receiving queries from members seeking content on the online social network. This content can comprise various social network objects such as members, discussion forums 220, events, photo albums, blogs, documents, files, and communities. Such objects can be ranked in accordance with any of a variety of ranking popularity functions. Objects with high popularity rankings may be annotated, for instance with a star, or placed into a particular portion of a community webpage such as a “hot pick” or “most popular” section.
The community webpage includes several forums 220 for discussion of various topics, such as “volunteer opportunities,” and “fencing fans sought.” The forums include messages in a discussion thread. Messages can be modified and deleted after their creation by the creator or by an administrator of the community. In an embodiment, messages on the same topic can be browsed from the oldest to the most recent. In addition, a topic can contain an unlimited number of messages. Users can create topics for discussions. In an embodiment, the topic comprises the subject of a first message in a discussion thread. Topics can be modified and deleted after their creation by the creator or by an administrator of the community. Several most recent topics are displayed on the community pages. Communities may allow for “open” posting by members outside of the community. Or they may restrict posts to community members, as specified by the community creator or administrator.
The community webpage also includes an event calendar 230 for storing information about events. Events are short messages describing an event (location, date, etc). In an embodiment, any user can create, modify, and delete their own events as well as post community events. Several most recent events may be displayed on the event calendar 230. The event calendar can be supplemented with geographic information including the location of the event. In an embodiment, a map display of an event location is included in or linked to from the community page. Users can choose to participate in events, and participants in an event may be made visible to other members of the community.
A number of different types of links may be supported in an online social network among users and communities. As shown in
A community may have self-regulatory mechanisms. For instance, a member may be able to “report spam” using a report spam button. In addition, a community may have outlinks to relevant content on the internet. Such links may comprise web links, news links, and links to relevant advertisements. The content may be customized based on user activity on the community webpage, for instance within forum, event, or other types of activity. A community may also support messaging by its members. A community member may, for instance, send and receive text, instant, or email messages.
The community creation module 320 comprises a module for creating online communities. The community creation module 320 enables the dynamic creation of online communities according to specific scenarios. In one scenario, a member types in a search query in order to locate a community of her interests, using for instance a search interface within an online social network. The search engine 305 processes the search query and looks for matches, for instance an exact match to the search query and/or matches to one or more of the search terms. When there are no matches, according to whatever search approach is used by the search engine 305, the community creation module 320 prompts the user to create a new public community with a name supplied by the user. The name is unique among public communities.
In another scenario, the community creation module 320 dynamically creates a public named community when a user attempts to specify a community that does not exist. In such a scenario, a user attempts to apply a label to a social network object such as an event, posting, forum, or blog entry. The search engine searches for any communities that have names that match one or more terms in the label name. If there are no communities that match the label name, the community creation module 320 dynamically creates a community with the label name. Under both of these scenarios, a community is automatically created for the user, bypassing the conventional community creation process.
In an embodiment, the resulting community under either of these scenarios is a public community whose ownership belongs to the public. This means that the community is administered by social network administrators rather than the creator or her designees. Once a community has been created, the community creation module 320 may prompt the user to optionally enter some description, labels, and/or keywords and provide images for the community. The community creation module 320 preferably performs additional steps to automate the population and management of newly created communities. For instance, the community creation module 320 may apply default settings to the community that membership is open to the public, rather than restricted. The new community includes the user as a member.
In addition, the community creation module 320 may implement several controls or policies on the new community that encourages members to join the community by reducing the risk of spam and off-content posting. Such controls may include disallowing the sending of messages to all community members, and disabling anonymous posting by social network users. These controls may be publicized in a community information or profile page. They may be encoded by a social network server into the presentation of community webpages (e.g. with or without a “send to all members” option displayed). Furthermore, a community rules engine may implement controls such that, when a user attempts a prohibited action, they are prevented from doing so. The community creation module 320 may also automatically search for relevant web content such as news, images, and advertising posted on the interne and place such content in a newly created forum or an existing forum. Similar searches for related or relevant communities, members, blogs, and other online social network content can be performed. The searches may be performed based on the community name, or any other content description, keyword, images, or content provided by the user. This information may be used in combination with the user's profile information such as the user's membership in related communities, friends, or fans. For instance, communities that have overlapping keywords with a newly created community may be identified as appropriate for receiving a solicitation to join the new community. A social network server generates code that, when executed, displays a link to the new community to these identified pre-existing communities. Other users within the online social network to whom the new community can be advertised may be identified in a similar way. Users are identified that have provided keywords, labels, postings, or other content to the social network that match the new community's name, keyword, or other description using standard Boolean, relevance, or other matching techniques. Links to the new online community can also be provided to these users.
A suggestion processor 310 may be provided to improve the community creation process carried out by the community creation module 320. The suggestion processor 310 comprises a server and software for providing search results to unmatched search queries using any of a variety of techniques. For instance, in an embodiment, the suggestion processor 310 uses known language processing techniques to identify spelling, grammatical, or other obvious errors in a user query. The suggestion processor 310 devises one or more suggested search terms, based on a dictionary, a directory of existing community names, or the most common spelling of each word in the query, based on queries of other users. The terms may be supplied back to the user, who can be prompted to re-initiate a search based on the revised terms. In another embodiment, the suggestion processor 310 may use other language processing techniques that rely, for instance, on known associations/substitutions of words (as may be provided by a thesaurus or slang dictionary, for instance) to search existing communities and suggest them to a user based on their query. The search may be performed based on the names as well as keywords of existing communities. For example, a user may enter a query like “China Olympic,” or “Peking 2008.” Although there may not be a specific match for either of these community names, the suggestion processor 310, based on information about existing communities or the most common spellings of words based on queries of other users, may suggest the community “Beijing Olympics 2008” to the user. By providing such suggestions, the risk of creating of multiple communities with different names that all are meant to refer to the same thing is minimized.
The community content module 340 comprises code for distributing content within a social network. Users provide content to the online social network such as forums, forum posts, events, blog entries, documents, files, videos, and images. The community content module 340 takes the content and makes it available to other users. In an embodiment, the content module 340 supports multi-community content sharing. When a user creates an object such as a forum within the context of a single community, the user may indicate by direct designation what other communities the forum topic should also be cross-posted to. In an embodiment, the user does not need to directly designate communities for cross-listing of the object contributed by the user. Instead, the user can associate labels with the object. Based on the label, a matching module (not shown) can find relevant communities to which to also cross-post the user's contribution. The community content module 340 receives this information and uses it to provide the object to multiple different communities. Responses to the object, such as follow up posts, entries, or comments provided by other users may also be provided by the community content module 340 within the different communities in which the object is posted. Alternatively, the responses may also be provided in a single webpage accessible to the multiple communities devised by the community content module 340. The ranking module 330 comprises a processor for ranking various social network objects such as users, communities, forums, blogs, blog postings, and photo albums. The ranking module 330 collects data with which the social network objects can be scored and ranked. Object rank can be generated based on extrinsic factors, such as the popularity of the object to users as measured, for example, based on quantity, velocity, or recency of access or responses received, or other intrinsic factors such as the status of the poster of the object. Ranking data such as community traffic may be stored in a social network database. The engine 330 periodically evaluates objects within the social network using the ranking data in order to determine a score or rank for each of the objects.
A social network server as previously described generates code that, when executed, displays a webpage with the forum topic and post of the host community, and the webpage of each community 440 identified by a community content module and selected by the user, as long as the posting is consistent with the individual community's policies. Each posting initiates a new topic of discussion in each of the communities that receives the content. This allows the user to reach different communities and audiences without having to individually create and post new individual topics in the forums for each of the different communities. Each time replies are received, code is generated for displaying the replies on the webpages of the host and identified communities.
Alternatively, the forum topics and reply posts are provided in each of the communities, but the discussion is consolidated into a single conversation forum 450. A single webpage for hosting the conversation may be provided and receive and display responses from the different communities. A link to the webpage is provided to members of the host community and identified communities. This way, members of different forums can benefit from the comments and replies of members from other forums. In yet another embodiment, while the initial forum topic and/or post are provided across communities, the follow up replies are not shared, but posted exclusively to the community in which the reply originates.
In another embodiment, the forum topic is not posted to the identified communities but merely advertised to them, through posting of the full or a part of the topic or a description of the topic, and a link to a host community where the conversation is taking place. This drives traffic to the host community and allows users outside the host community to dialogue with members of the host community.
The distribution of objects other than forum topics or forum messages can be carried out across communities using a similar process. For instance, in an embodiment, an event can be posted across communities based on labels provided by the event poster. Image, journals, and albums can also be shared across communities in a similar manner. Blog entries may also be distributed across communities, whether initial posts or follow up posts. Responses and reactions to the posted events or images may be, as described above, provided within a shared webpage or separately within communities.
One or more of the steps shown in
The foregoing description of the embodiments of the invention has been presented for the purpose of illustration; it is not intended to be exhaustive or to limit the invention to the precise forms disclosed. Persons skilled in the relevant art can appreciate that many modifications and variations are possible in light of the above teachings. It is therefore intended that the scope of the invention be limited not by this detailed description, but rather by the claims appended hereto.
The invention has been described in particular detail with respect to several possible embodiments. Those of skill in the art will appreciate that the invention may be practiced in other embodiments. First, the particular naming of the components, capitalization of terms, the attributes, data structures, or any other programming or structural aspect is not mandatory or significant, and the mechanisms that implement the invention or its features may have different names, formats, or protocols. Further, the system may be implemented via a combination of hardware and software, as described, or entirely in hardware elements. Also, the particular division of functionality between the various system components described herein is merely exemplary, and not mandatory; functions performed by a single system component may instead be performed by multiple components, and functions performed by multiple components may instead performed by a single component.
Some portions of above description present the features of embodiments of the invention in terms of ranking functions and symbolic representations of operations on information. These ranking function descriptions and representations are the means used by those skilled in the data processing arts to most effectively convey the substance of their work to others skilled in the art. These operations, while described functionally or logically, are understood to be implemented by computer programs. Furthermore, it has also proven convenient at times, to refer to these arrangements of operations as modules or by functional names, without loss of generality.
Embodiments of the invention also include computer program products for performing various operations disclosed herein. The computer program products comprises program code that may be embodied on a computer-readable storage medium, such as, but not limited to, any type of disk including floppy disks, optical disks, CD-ROMs, magnetic-optical disks, read-only memories (ROMs), random access memories (RAMs), EPROMs, EEPROMs, magnetic or optical cards, application specific integrated circuits (ASICs), or any type of media suitable for storing electronic instructions. One or more parts of the program code may be distributed as part of an appliance, downloaded, and/or otherwise provided to a customer.
The ranking functions and operations presented herein are not inherently related to any particular computer or other apparatus. Various general-purpose systems may also be used with programs in accordance with the teachings herein, or it may prove convenient to construct more specialized apparatus to perform the required method steps. The required structure for a variety of these systems will be apparent to those of skill in the art, along with equivalent variations. In addition, embodiments of the invention are not described with reference to any particular programming language. It is appreciated that a variety of programming languages may be used to implement the present teachings as described herein, and any references to specific languages are provided for disclosure of enablement and best mode of embodiments of the invention. Embodiments of the invention are well suited to a wide variety of computer network systems over numerous topologies. Within this field, the configuration and management of large networks include storage devices and computers that are communicatively coupled to dissimilar computers and storage devices over a network, such as the Internet.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/CN07/02486 | 8/17/2007 | WO | 00 | 2/16/2010 |