The disclosed example embodiments relate generally to the field of social networks and in particular to a system for analyzing content impact.
The rise of the computer age has resulted in increased access to personalized services online. As the cost of electronics and networking services drop, many services that were previously provided in person are now provided remotely over the Internet. For example, entertainment has increasingly shifted to the online space with companies such as Netflix and Amazon streaming television shows and movies to members at home. Similarly, electronic mail (e-mail) has reduced the need for letters to be physically delivered. Instead, messages are sent over networked systems almost instantly. Similarly, online social networking sites allow members to build and maintain personal and business relationships in a much more comprehensive and manageable manner.
One important application of new computer technologies is allowing companies to increase their visibility and contact with current customers and potential customers. For example, social networking sites allow consumers to directly interact with brand managers and, similarly, provides new avenues for content and product producers to communicate with potential consumers. However, traditional methods of measuring and optimizing these interactions are inadequate or often inapplicable.
Some example embodiments are illustrated by way of example and not limitation in the figures of the accompanying drawings, in which:
Like reference numerals refer to corresponding parts throughout the drawings.
The present disclosure describes methods, systems and computer program products for measuring impact of content in a social networking system. In the following description, for purposes of explanation, numerous specific details are set forth to provide a thorough understanding of the various aspects of different example embodiments. It will be evident, however, to one skilled in the art, that any particular example embodiment may be practiced without all of the specific details and/or with variations, permutations, and combinations of the various features and elements described herein.
In some example embodiments, the social networking system stores organization data from a plurality of organizations (e.g., small businesses, corporations, education institutions, non-governmental organizations (NGOs), non-profit organizations, government organizations, and so on). In some example embodiments, the stored data is received explicitly from the organizations. In other example embodiments, the social networking system analyzes existing data to infer some organization data. In some example embodiments, one or more organizations engage on content sharing through the social networking system.
In some example embodiments, the social networking system receives a request to generate a content marketing score for a respective organization in the one or more organizations that engage in content sharing (e.g., paid or unpaid advertising or messaging) on the social networking system. In response, the social networking system generates a group of peer organizations (e.g., organizations that are relevant comparisons for the respective organization based on business type, size, revenue, location, and so on). In some example embodiments, the list of peer organizations is based on a customized list received from a client system along with the request. In other example embodiments, the social networking system generates a list of peer organizations based on stored organization data, including common social connections, location, size of organization, organization purpose or business field, and so on.
In some example embodiments, once the peer organizations have been identified, the social networking system generates a content marketing score for each. In some example embodiments, a content marketing score for a first organization is generated by measuring the number of unique social interactions (e.g., clicks, likes, shares, up-votes, comments, follow, subscribe, donate, purchase, and so on) with content associated with the first organization (e.g., advertisements, sponsored content, groups, influencer posts, employee posts, organization posts, and so on).
The total active audience is then measured for the entire peer group. The total active audience is all members who have been active (e.g., based on last login/number of times logging on per year) that fit within the audience parameters set by the organizations. In some example embodiments, the audience can be limited to certain people/certain roles for a more specialized content marketing score. In some example embodiments, the content marketing score is generated based on the ratio of unique social interactions for content items associated with a specific organization and the total active audience for the entire peer group.
In some example embodiments, the social networking system then transmits the generated scores to the requesting client system. In some example embodiments, the social networking system also transmits recommendations for improving the content management score for an organization.
In some example embodiments, a client system 102 is an electronic device, such as a personal computer (PC), a laptop, a smartphone, a tablet, a mobile phone, or any other electronic device capable of communication with a communication network 110. The client system 102 includes one or more client applications 104, which are executed by the client system 102. In some example embodiments, the client application(s) 104 include one or more applications from a set consisting of search applications, communication applications, productivity applications, game applications, word processing applications, or any other useful applications. The client application(s) 104 include a web browser 106. The client system 102 uses the web browser 106 to communicate with the social networking system 120 and displays information received from the social networking system 120. In some example embodiments, the client system 102 includes an application specifically customized for communication with the social networking system 120 (e.g., a LinkedIn iPhone application). In some example embodiments, the social networking system 120 is a server system that is associated with a social networking service. However, the social networking system 120 and the server system that actually provides the social networking service may be completely distinct computer systems.
In some example embodiments, the client system 102 sends a request to the social networking system 120 for a webpage associated with the social networking system 120 (e.g., the client system 102 sends a request to the social networking system 120 for an updated list of activity). For example, a member of the client system 102 logs onto the social networking system 120 and clicks on a link to their home page that includes a list of recent activities of the member on the social networking system 120. In response, the client system 102 receives the requested data (e.g., information about schools and enrollment) and displays them on the client system 102.
In some example embodiments, as shown in
As shown in
As shown in
Consistent with some example embodiments, when a person initially registers to become a member of the social networking system 120, the person will be prompted to provide some personal information, such as his or her name, age (e.g., birth date), gender, interests, contact information, home town, address, educational background (e.g., schools, majors, etc.), current job title, job description, industry, employment history, skills, professional organizations, and so on. This information is stored, for example, in the member profile data 130. In some example embodiments, the social networking system 120 will also prompt the person to determine whether that person is interested in attending one or more schools in the future.
In some example embodiments, the member profile data 130 includes activity data 132. In other example embodiments, the activity data 132 is distinct from, but associated with, the member profile data 130. The activity data 132 stores data related to activities taken by members of the social networking system (e.g., system 120 in
In some example embodiments, the organization profile data 134 stores data related to companies represented on the social networking system 120 and their employees. In some example embodiments, specific members of the social networking system 120 are associated with particular companies (e.g., they list an organization as an employer). In some example embodiments, organization profile data includes, but is not limited to, organization locations (e.g., headquarters locations, store/facility/production/retail locations, organization size, market sector(s), employees, revenues, past interactions with the social networking system 120, and so on).
In some example embodiments, the engagement event data 136 includes group activity, influencer posts, organization posts, sponsored posts, employee posts, sponsored updates, and so on. In some example embodiments, the engagement events are events that were explicitly paid for by an organization. In other example embodiments, engagement events are events that results from routine, unpaid, member interaction on the social networking system 120 (e.g., an employee posts about a new product).
Once registered, a member may invite other members, or be invited by other members, to connect via the network service. A “connection” may include a bi-lateral agreement by the members, such that both members acknowledge the establishment of the connection. Similarly, with some example embodiments, a member may elect to “follow” another member. In contrast to establishing a “connection,” the concept of “following” another member typically is a unilateral operation and, at least with some example embodiments, does not include acknowledgement or approval by the member that is being followed. When one member follows another, the member who is following may receive automatic notifications about various activities undertaken by the member being followed. In addition to following another member, a member may elect to follow an organization, a topic, a conversation, or some other entity, which may or may not be included in the social graph. Various other types of relationships may exist between different entities and are represented in the social graph data 138.
The social networking system 120 may provide a broad range of other applications and services that allow members the opportunity to share and receive information, which is often customized to the interests of the member. In some example embodiments, the social networking service may include a photo sharing application that allows members to upload and share photos with other members. As such, at least with some example embodiments, a photograph may be a property or entity included within a social graph. With some example embodiments, members of a social networking service may be able to self-organize into groups, or interest groups, organized around a subject matter or topic of interest. In some example embodiments, the data for a group may be stored in a database. When a member joins a group, his or her membership in the group will be reflected in the organization activity data, the member activity data, and the social graph data stored in the social graph data 138.
In some example embodiments, the application logic layer includes various application server modules, which, in conjunction with the user interface module(s) 122, generates various user interfaces (e.g., web pages) with data retrieved from various data sources in the data layer. With some example embodiments, individual application server modules are used to implement the functionality associated with various applications, services, and features of the social networking service. For instance, a messaging application, such as an email application, an instant messaging application, or some hybrid or variation of the two, may be implemented with one or more application server modules. Similarly, a search engine enabling members to search for and browse member profiles may be implemented with one or more application server modules. Of course, other applications or services that utilize a comparison module 124 or a content score module 126 may be separately implemented in their own application server modules.
In addition to the various application server modules, the application logic layer includes a comparison module 124 and a content score module 126. As illustrated in
Generally, the comparison module 124 module determines, based on organization profile data 134 stored at the social networking system 120, companies that would make a good comparison for a first organization (e.g., companies that are similar or operate in similar fields). In some example embodiments, the comparison module 124 determines a list of peer companies by identifying an industry sector for the first organization. In some example embodiments, the comparison module 124 also determines the first company's size, revenue, location, and number of employees.
Based on the gathered data for the first organization and potential peer companies, the comparison module 124 gives each potential peer organization a score, with the score representing the degree to which each potential peer organization is similar to the first organization.
In some example embodiments, the comparison module 124 ranks each potential peer organization based on the generated scores, such that the organizations with the highest scores are the most likely to be peers of the first organization. In some example embodiments, the comparison module 124 then selects a predetermined number of the potential peer organizations with the highest rank (e.g., the top ten or the top twenty and so on) and uses them as the peer group for the first organization.
In some example embodiments, the first organization sends a request for comparison and includes one or more organizations to include in the peer group. In this case, the one or more organizations selected by the requesting first organization are used as the peer group, with other organizations being added only if the number of selected organizations are below the predetermined number of organizations needed for comparison.
In some example embodiments, the content score module 126 uses stored information about engagement event data 136 to generate a content score for a requesting first organization and a peer group of organizations determined by the comparison module 124.
In some example embodiments, generating a content marketing score for a first organization includes determining the number of unique members who engage with content from the first organization. Content from the first organization includes paid advertising from the first organization, such as sponsored updates or posts, actions that the organization officially takes on the social networking system 120 (such as status updates or normal posts), and actions taken by members who are associated with the first organization (e.g., employees, owners, customers, and so on), such as commenting, sharing, blog posts, and so on.
In some example embodiments, once the content score module 126 identifies the content associated with the first organization, it then determines the number of unique members that have interacted with the content in some way. For example, a member that likes, shares, or comments on a sponsored post is determined to have interacted with the sponsored post. The content score module 126 then determines the number of active unique members in the audience. In some example embodiments, a member is considered active if the member has logged onto the social networking system 120 at least once in the past month. Other lengths of time or methods of determining whether a member is active can be used.
In some example embodiments, the audience includes all active members of the social networking servers. In other example embodiments, the audience is defined to be more focused and includes only individuals that fit filter criteria given by the first organization or by an individual preparing a presentation for the first organization. For example, the first organization determines that only members with a certain roles are to be used in the potential audience. A first organization only wants members that are in human resources in Fortune 500 company. In some example embodiments, only interactions from members of the selected audience are used to generate the content marketing score.
In some example embodiments, the content score module 126 calculates a content marketing score for the first organization and the peer organizations by calculating the ratio of unique member interactions to the size of the active member audience. In some example embodiments, the content marketing scores represent a relative position in the peer group for each organization such that organizations with a high member engagement (e.g., the highest ratio of unique member interactions to unique audience members) have higher content marketing scores than organizations with low member engagement.
In some example embodiments, the organization server 150 is a server system that is located remotely from the social networking system 120 and is associated with a particular organization. The organization server connects to the social networking system 120 via the communication network 110. In some example embodiments, the organization server 150 stores organization data 152 related to the organization.
In some example embodiments, the organization server 150 sends a request to the social networking system 120 to determine a content marketing score for the organization associated with the organization server 150. In some example embodiments, the request includes a target audience (e.g., criteria for members to be considered) and a list of one or more peers. In some example embodiments, the organization server 150 receives a response from the social networking system 120 that includes a content marketing score for the associated organization and one or more organizations in the organization's peer group.
Memory 212 includes high-speed random access memory, such as dynamic random-access memory (DRAM), static random access memory (SRAM), double data rate random access memory (DDR RAM) or other random access solid state memory devices; and may include non-volatile memory, such as one or more magnetic disk storage devices, optical disk storage devices, flash memory devices, or other non-volatile solid state storage devices. Memory 212 may optionally include one or more storage devices remotely located from the CPU(s) 202. Memory 212, or alternately, the non-volatile memory device(s) within memory 212, comprise(s) a non-transitory computer readable storage medium.
In some example embodiments, memory 212 or the computer-readable storage medium of memory 212 stores the following programs, modules, and data structures, or a subset thereof:
Memory 306, or alternately the non-volatile memory device(s) within memory 306, comprises a non-transitory computer readable storage medium. In some example embodiments, memory 306, or the computer readable storage medium of memory 306, stores the following programs, modules, and data structures, or a subset thereof:
In some example embodiments, a respective organization profile 402 stores a unique organization identification (ID) 404 for the organization profile 402, a name 406 for the organization (e.g., the organization's legal name), the location 408 of the organization, the size of the organization 410, the business sector or sectors 412 that the organization deals with, the organization's employees 414, the revenue 416 of the organization, and content 418 published on the social networking system (e.g., system 120 in
In some example embodiments, the organization's location 408 includes a list of locations with which the organization is associated including offices, headquarters, campuses, manufacturing plants, warehouses, retail stores, and so on. In some example embodiments, the size of an organization 410 is the number of employees that an organization has. In other example embodiments, the size of an organization 410 represents the total book value of an organization.
In some example embodiments, the business sector 412 of an organization represents the one or more areas of business, commerce, or non-profit activity that the organization engages in. In some example embodiments, the list of employees 414 includes links to the member profiles of all the members who are associated with the organization and includes employees, managers, owners, and so on. In some example embodiments, the revenue 416 includes information describing the average or expected revenue of the organization.
In some example embodiments, an organization profile 402 includes a list of content items (422-1 to 422-L) associated with the organization and any interaction events (424-1 to 424-L) associated with each content item. Each content item represents a specific piece of content associated with the organization including, but not limited to, influencer posts, organization posts, sponsored posts, employee posts, sponsored updates, group posts, and so on. The social networking system (e.g., system 120 in
In some example embodiments, each content item 422 includes a list of interaction events 424 that are associated with that item. In some example embodiments, the interaction events 424 also include the member who performed the specific interaction. In some example embodiments, interaction events include clicks, likes, follows, shares, comments, posts, and so on.
In some example embodiments, the user interface 500 displays content marketing scores for a series of organizations in a bar chart format, with each content marketing score being represented as a bar above the name of the organization with which it is associated.
In some example embodiments, the chart 502 includes a plurality of organization names (504-1 to 504-6) below the x-axis line. Above each organization name are bars, with each bar (506-1 to 506-6) representing a content marketing score for the organization above whose name it is positioned. For example, the organization Pear, Inc. (504-1) has a bar chart above it. The bar chart associated with Pear, Inc. (506-1) represents a content marketing score of 103 and has the highest content marketing score in the displayed peer group. The numerical value of a displayed bar is displayed such that it is positioned directly above the corresponding bar.
In some example embodiments, the organization that requested the content marketing score be performed (or on whose behalf it was performed) is visually distinguished among the group of peer organizations. In the example displayed, the bar displayed for Device Fruit (504-2) is distinguished from the other organizations based on the color of the bar itself (e.g., grey rather than black). In some example embodiments, any other suitable method can be used to visually distinguish one or more organizations.
In some example embodiments, the social networking system (e.g., social networking system 120 of
In some example embodiments, the social networking system (e.g., system 120 in
In some example embodiments, the social networking system (e.g., system 120 in
In some example embodiments, the social networking system (e.g., system 120 in
In some example embodiments, the social networking system (e.g., system 120 in
In some embodiments the method is performed at a social networking system (e.g., system 120 in
In some example embodiments, the social networking system (e.g., system 120 in
In some example embodiments, the social networking system (e.g., system 120 in
In some example embodiments, organization data includes a list of members associated with each organization and the social connections of those members. For example, the organization includes a list of employees, owners, and other stakeholders for an organization. In some example embodiments, the data is only stored for members that consent to have their information used in this way.
In some example embodiments, organization data includes business description data, including, but not limited to, the size of the organization, the location of the organization, and the business sector of the organization.
In some example embodiments, the social networking system (e.g., system 120 in
In some example embodiments, determining one or more peer organizations comprises the social networking system (e.g., system 120 in
In some example embodiments, the social networking system (e.g., system 120 in
In some example embodiments, the social networking system (e.g., system 120 in
In some example embodiments, based on the social connections of the one or more members associated with the first organization, the social networking system (e.g., system 120 in
In some embodiments the method is performed at a social networking system (e.g., system 120 in
In some example embodiments, the social networking system (e.g., system 120 in
In some example embodiments, the social networking system (e.g., system 120 in
In some example embodiments, the social networking system (e.g., system 120 in
In some example embodiments, the social networking system (e.g., system 120 in
In some example embodiments, the social networking system (e.g., system 120 in
In some example embodiments, the social networking system (e.g., system 120 in
In some embodiments the method is performed at a social networking system (e.g., system 120 in
In some example embodiments, the social networking system (e.g., system 120 in
In some example embodiments, a content marketing score can be broken down based on three categories: reach of the content, frequency of shared content, and quality of content. Reach represents the number of members who see (e.g., in their activity feed) a particular piece of content. Frequency refers to how often content is shared from the first organization. Quality of content refers to how good each piece of content is at encouraging interactions from members of the social networking system (e.g., system 120 in
Thus, when the social networking system (e.g., system 120 in
In some example embodiments, the content is actually presented to a very small fraction of the target audience. For example, the social networking system (e.g., system 120 in
In some example embodiments, in accordance with a determination that a significant reason for a low content marketing score is lack of reach, the social networking system (e.g., system 120 in
In another example, the social networking system (e.g., system 120 in
In some example embodiments, in accordance with a determination that a significant reason for a low content marketing score is content item quality, the social networking system (e.g., system 120 in
In another example, the social networking system (e.g., system 120 in
In some example embodiments, the social networking system (e.g., system 120 in
In some example embodiments, the social networking system (e.g., system 120 in
The operating system 802 may manage hardware resources and provide common services. The operating system 802 may include, for example, a kernel 820, services 822, and drivers 824. The kernel 820 may act as an abstraction layer between the hardware and the other software layers. For example, the kernel 820 may be responsible for memory management, processor management (e.g., scheduling), component management, networking, security settings, and so on. The services 822 may provide other common services for the other software layers. The drivers 824 may be responsible for controlling and/or interfacing with the underlying hardware. For instance, the drivers 824 may include display drivers, camera drivers, Bluetooth® drivers, flash memory drivers, serial communication drivers (e.g., Universal Serial Bus (USB) drivers), Wi-Fi® drivers, audio drivers, power management drivers, and so forth.
The libraries 804 may provide a low-level common infrastructure that may be utilized by the applications 808. The libraries 804 may include system libraries 830 (e.g., C standard library) that may provide functions such as memory allocation functions, string manipulation functions, mathematic functions, and the like. In addition, the libraries 804 may include API libraries 832 such as media libraries (e.g., libraries to support presentation and manipulation of various media format such as MPREG4, H.264, MP3, AAC, AMR, JPG, PNG), graphics libraries (e.g., an OpenGL framework that may be used to render 2D and 3D in a graphic content on a display), database libraries (e.g., SQLite that may provide various relational database functions), web libraries (e.g., WebKit that may provide web browsing functionality), and the like. The libraries 804 may also include a wide variety of other libraries 834 to provide many other APIs to the applications 808.
The frameworks 806 may provide a high-level common infrastructure that may be utilized by the applications 808. For example, the frameworks 806 may provide various graphic user interface (GUI) functions, high-level resource management, high-level location services, and so forth. The frameworks 806 may provide a broad spectrum of other APIs that may be utilized by the applications 808, some of which may be specific to a particular operating system or platform.
The applications 808 include a home application 850, a contacts application 852, a browser application 854, a book reader application 856, a location application 858, a media application 860, a messaging application 862, a game application 864, and a broad assortment of other applications such as third party application 866. In a specific example, the third party application 866 (e.g., an application developed using the Android™ or iOS™ software development kit (SDK) by an entity other than the vendor of the particular platform) may be mobile software running on a mobile operating system such as iOS™, Android™, Windows® Phone, or other mobile operating systems. In this example, the third party application 866 may invoke the API calls 810 provided by the mobile operating system 802 to facilitate functionality described herein.
The machine 900 may include processors 910, memory 930, and I/O components 950, which may be configured to communicate with each other via a bus 905. In an example embodiment, the processors 910 (e.g., a CPU, a Reduced Instruction Set Computing (RISC) processor, a Complex Instruction Set Computing (CISC) processor, a Graphics Processing Unit (GPU), a Digital Signal Processor (DSP), an Application Specific Integrated Circuit (ASIC), a Radio-Frequency Integrated Circuit (RFIC), another processor, or any suitable combination thereof) may include, for example, processor 915 and processor 920 that may execute instructions 925. The term “processor” is intended to include a multi-core processor that may comprise two or more independent processors (also referred to as “cores”) that may execute instructions contemporaneously. Although
The memory 930 may include a main memory 935, a static memory 940, and a storage unit 945 accessible to the processors 910 via the bus 905. The storage unit 945 may include a machine-readable medium 947 on which are stored the instructions 925 embodying any one or more of the methodologies or functions described herein. The instructions 925 may also reside, completely or at least partially, within the main memory 935, within the static memory 940, within at least one of the processors 910 (e.g., within the processor's cache memory), or any suitable combination thereof, during execution thereof by the machine 900. Accordingly, the main memory 935, static memory 940, and the processors 910 may be considered as machine-readable media 947.
As used herein, the term “memory” refers to a machine-readable medium 947 able to store data temporarily or permanently and may be taken to include, but not be limited to, random-access memory (RAM), read-only memory (ROM), buffer memory, flash memory, and cache memory. While the machine-readable medium 947 is shown in an example embodiment to be a single medium, the term “machine-readable medium” should be taken to include a single medium or multiple media (e.g., a centralized or distributed database, or associated caches and servers) able to store instructions 925. The term “machine-readable medium” shall also be taken to include any medium, or combination of multiple media, that is capable of storing instructions (e.g., instructions 925) for execution by a machine (e.g., machine 900), such that the instructions, when executed by one or more processors of the machine 900 (e.g., processors 910), cause the machine 900 to perform any one or more of the methodologies described herein. Accordingly, a “machine-readable medium” refers to a single storage apparatus or device, as well as “cloud-based” storage systems or storage networks that include multiple storage apparatus or devices. The term “machine-readable medium” shall accordingly be taken to include, but not be limited to, one or more data repositories in the form of a solid-state memory (e.g., flash memory), an optical medium, a magnetic medium, other non-volatile memory (e.g., Erasable Programmable Read-Only Memory (EPROM)), or any suitable combination thereof. The term “machine-readable medium” specifically excludes non-statutory signals per se.
Certain embodiments are described herein as including logic or a number of components, modules, or mechanisms. Modules may constitute either software modules (e.g., code embodied on a machine-readable medium or in a transmission signal) or hardware modules. A “hardware module” is a tangible unit capable of performing certain operations and may be configured or arranged in a certain physical manner. In various example embodiments, one or more computer systems (e.g., a standalone computer system, a client computer system, or a server computer system) or one or more hardware modules of a computer system (e.g., a processor or a group of processors) may be configured by software (e.g., an application or application portion) as a hardware module that operates to perform certain operations as described herein.
In some embodiments, a hardware module may be implemented mechanically, electronically, or any suitable combination thereof. For example, a hardware module may include dedicated circuitry or logic that is permanently configured to perform certain operations. For example, a hardware module may be a special-purpose processor, such as a field-programmable gate array (FPGA) or an ASIC. A hardware module may also include programmable logic or circuitry that is temporarily configured by software to perform certain operations. For example, a hardware module may include software encompassed within a general-purpose processor or other programmable processor. It will be appreciated that the decision to implement a hardware module mechanically, in dedicated and permanently configured circuitry, or in temporarily configured circuitry (e.g., configured by software) may be driven by cost and time considerations.
Accordingly, the phrase “hardware module” should be understood to encompass a tangible entity, be that an entity that is physically constructed, permanently configured (e.g., hardwired), or temporarily configured (e.g., programmed) to operate in a certain manner or to perform certain operations described herein. As used herein, “hardware-implemented module” refers to a hardware module. Considering embodiments in which hardware modules are temporarily configured (e.g., programmed), each of the hardware modules need not be configured or instantiated at any one instance in time. For example, where a hardware module comprises a general-purpose processor configured by software to become a special-purpose processor, the general-purpose processor may be configured as respectively different special-purpose processors (e.g., comprising different hardware modules) at different times. Software may accordingly configure a processor, for example, to constitute a particular hardware module at one instance of time and to constitute a different hardware module at a different instance of time.
Hardware modules can provide information to, and receive information from, other hardware modules. Accordingly, the described hardware modules may be regarded as being communicatively coupled. Where multiple hardware modules exist contemporaneously, communications may be achieved through signal transmission (e.g., over appropriate circuits and buses) between or among two or more of the hardware modules. In embodiments in which multiple hardware modules are configured or instantiated at different times, communications between such hardware modules may be achieved, for example, through the storage and retrieval of information in memory structures to which the multiple hardware modules have access. For example, one hardware module may perform an operation and store the output of that operation in a memory device to which it is communicatively coupled. A further hardware module may then, at a later time, access the memory device to retrieve and process the stored output. Hardware modules may also initiate communications with input or output devices, and can operate on a resource (e.g., a collection of information).
The various operations of example methods described herein may be performed, at least partially, by one or more processors that are temporarily configured (e.g., by software) or permanently configured to perform the relevant operations. Whether temporarily or permanently configured, such processors may constitute processor-implemented modules that operate to perform one or more operations or functions described herein. As used herein, “processor-implemented module” refers to a hardware module implemented using one or more processors.
Similarly, the methods described herein may be at least partially processor-implemented, a processor being an example of hardware. For example, at least some of the operations of a method may be performed by one or more processors or processor-implemented modules. Moreover, the one or more processors may also operate to support performance of the relevant operations in a “cloud computing” environment or as a “software as a service” (SaaS). For example, at least some of the operations may be performed by a group of computers (as examples of machines including processors), with these operations being accessible via a network (e.g., the Internet) and via one or more appropriate interfaces (e.g., an API).
The performance of certain of the operations may be distributed among the one or more processors, not only residing within a single machine, but deployed across a number of machines. In some example embodiments, the one or more processors or processor-implemented modules may be located in a single geographic location (e.g., within a home environment, an office environment, or a server farm). In other example embodiments, the one or more processors or processor-implemented modules may be distributed across a number of geographic locations.
The I/O components 950 may include a wide variety of components to receive input, provide and/or produce output, transmit information, exchange information, capture measurements, and so on. It will be appreciated that the I/O components 950 may include many other components that are not shown in
In further example embodiments, the I/O components 950 may include biometric components 956, motion components 958, environmental components 960, and/or position components 962 among a wide array of other components. For example, the biometric components 956 may include components to detect expressions (e.g., hand expressions, facial expressions, vocal expressions, body gestures, or eye tracking), measure bio signals (e.g., blood pressure, heart rate, body temperature, perspiration, or brain waves), identify a person (e.g., voice identification, retinal identification, facial identification, finger print identification, or electroencephalogram based identification), and the like. The motion components 958 may include acceleration sensor components (e.g., accelerometer), gravitation sensor components, rotation sensor components (e.g., gyroscope), and so forth. The environmental components 960 may include, for example, illumination sensor components (e.g., photometer), temperature sensor components (e.g., one or more thermometers that detect ambient temperature), humidity sensor components, pressure sensor components (e.g., barometer), acoustic sensor components (e.g., one or more microphones that detect background noise), proximity sensor components (e.g., infrared sensors that detect nearby objects), and/or other components that may provide indications, measurements, and/or signals corresponding to a surrounding physical environment. The position components 962 may include location sensor components (e.g., a GPS receiver component), altitude sensor components (e.g., altimeters and/or barometers that detect air pressure from which altitude may be derived), orientation sensor components (e.g., magnetometers), and the like.
Communication may be implemented using a wide variety of technologies. The I/O components 950 may include communication components 964 operable to couple the machine 900 to a network 980 and/or devices 970 via coupling 982 and coupling 972, respectively. For example, the communication components 964 may include a network interface component or other suitable device to interface with the network 980. In further examples, communication components 964 may include wired communication components, wireless communication components, cellular communication components, Near Field Communication (NFC) components, Bluetooth® components (e.g., Bluetooth® Low Energy), Wi-Fi® components, and other communication components to provide communication via other modalities. The devices 970 may be another machine and/or any of a wide variety of peripheral devices (e.g., a peripheral device coupled via a USB).
Moreover, the communication components 964 may detect identifiers and/or include components operable to detect identifiers. For example, the communication components 964 may include Radio Frequency Identification (RFID) tag reader components, NFC smart tag detection components, optical reader components (e.g., an optical sensor to detect one-dimensional bar codes such as Universal Product Code (UPC) bar code, multi-dimensional bar codes such as Quick Response (QR) code, Aztec code, Data Matrix, Dataglyph, MaxiCode, PDF48, Ultra Code, UCC RSS-2D bar code, and other optical codes), acoustic detection components (e.g., microphones to identify tagged audio signals), and so on. In additional, a variety of information may be derived via the communication components 964 such as location via Internet Protocol (IP) geo-location, location via Wi-Fi® signal triangulation, location via detecting a NFC beacon signal that may indicate a particular location, and so forth.
In various example embodiments, one or more portions of the network 980 may be an ad hoc network, an intranet, an extranet, a virtual private network (VPN), a LAN, a wireless LAN (WLAN), a WAN, a wireless WAN (WWAN), a metropolitan area network (MAN), the Internet, a portion of the Internet, a portion of the Public Switched Telephone Network (PSTN), a plain old telephone service (POTS) network, a cellular telephone network, a wireless network, a Wi-Fi® network, another type of network, or a combination of two or more such networks. For example, the network 980 or a portion of the network 980 may include a wireless or cellular network and the coupling 982 may be a Code Division Multiple Access (CDMA) connection, a Global System for Mobile communications (GSM) connection, or other type of cellular or wireless coupling. In this example, the coupling 982 may implement any of a variety of types of data transfer technology, such as Single Carrier Radio Transmission Technology (1×RTT), Evolution-Data Optimized (EVDO) technology, General Packet Radio Service (GPRS) technology, Enhanced Data rates for GSM Evolution (EDGE) technology, third Generation Partnership Project (3GPP) including 3G, fourth generation wireless (4G) networks, Universal Mobile Telecommunications System (UMTS), High Speed Packet Access (HSPA), Worldwide Interoperability for Microwave Access (WiMAX), Long Term Evolution (LTE) standard, others defined by various standard setting organizations, other long range protocols, or other data transfer technology.
The instructions 925 may be transmitted or received over the network 980 using a transmission medium via a network interface device (e.g., a network interface component included in the communication components 964) and utilizing any one of a number of well-known transfer protocols (e.g., HTTP). Similarly, the instructions 925 may be transmitted and/or received using a transmission medium via the coupling 972 (e.g., a peer-to-peer coupling) to devices 970. The term “transmission medium” shall be taken to include any intangible medium that is capable of storing, encoding, or carrying instructions 925 for execution by the machine 900, and includes digital or analog communications signals or other intangible medium to facilitate communication of such software.
Furthermore, the machine-readable medium 947 is non-transitory (in other words, not having any transitory signals) in that it does not embody a propagating signal. However, labeling the machine-readable medium 947 as “non-transitory” should not be construed to mean that the medium is incapable of movement; the medium 947 should be considered as being transportable from one physical location to another. Additionally, since the machine-readable medium 947 is tangible, the medium may be considered to be a machine-readable device.
Throughout this specification, plural instances may implement components, operations, or structures described as a single instance. Although individual operations of one or more methods are illustrated and described as separate operations, one or more of the individual operations may be performed concurrently, and nothing requires that the operations be performed in the order illustrated. Structures and functionality presented as separate components in example configurations may be implemented as a combined structure or component. Similarly, structures and functionality presented as a single component may be implemented as separate components. These and other variations, modifications, additions, and improvements fall within the scope of the subject matter herein.
Although an overview of the inventive subject matter has been described with reference to specific example embodiments, various modifications and changes may be made to these embodiments without departing from the broader scope of embodiments of the present disclosure. Such embodiments of the inventive subject matter may be referred to herein, individually or collectively, by the term “invention” merely for convenience and without intending to voluntarily limit the scope of this application to any single disclosure or inventive concept if more than one is, in fact, disclosed.
The embodiments illustrated herein are described in sufficient detail to enable those skilled in the art to practice the teachings disclosed. Other embodiments may be used and derived therefrom, such that structural and logical substitutions and changes may be made without departing from the scope of this disclosure. The Detailed Description, therefore, is not to be taken in a limiting sense, and the scope of various embodiments is defined only by the appended claims, along with the full range of equivalents to which such claims are entitled.
As used herein, the term “or” may be construed in either an inclusive or exclusive sense. Moreover, plural instances may be provided for resources, operations, or structures described herein as a single instance. Additionally, boundaries between various resources, operations, modules, engines, and data stores are somewhat arbitrary, and particular operations are illustrated in a context of specific illustrative configurations. Other allocations of functionality are envisioned and may fall within a scope of various embodiments of the present disclosure. In general, structures and functionality presented as separate resources in the example configurations may be implemented as a combined structure or resource. Similarly, structures and functionality presented as a single resource may be implemented as separate resources. These and other variations, modifications, additions, and improvements fall within a scope of embodiments of the present disclosure as represented by the appended claims. The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense.