1. Field of the Invention
The present invention relates generally to an electronic commerce system, method, and apparatus. More specifically, the present invention relates to an electronic commerce system, method, and apparatus capable of servicing and/or providing a wide range of possible transactions.
2. Description of Related Art
Electronic commerce transactions that employ a mobile wireless communications device, for example a cellular telephone handset, are recognized as a commercially valuable opportunity for new services. Barcodes of various symbologies, encoded and transmitted as messages and displayed on the device screen, have been employed to represent electronic tokens. Such tokens have entitled the bearer to products and services of various types. Such token systems had limitations on there usefulness in a variety of contexts.
For example, these tokens were limited to providing a single service and were often limited to being used in environments where network coverage was acceptable. Additionally, many of the previous systems were not user friendly and could be cumbersome to use.
Further, prior systems were generally limited to very specific implementations. That is, systems were implemented for specific services and not capable of general mobile commerce.
E-commerce is currently at a very early stage of evolution and lacking many convenient, accepted patterns of practice and forms of expression. This lack of structures and platforms has inhibited the growth of electronic commerce, particularly when consumers are involved.
The invention described in PCT/AU2005/001799 discloses an electronic token, called bToken, for use for mobile electronic transactions. The invention also teaches the construction of self-executing electronic contracts, called bContracts, underlying such transactions.
The present invention improves the previous inventions disclosed by teaching the construction of additional bContract representations, enabling additional services to be constructed. Such additional services include the composition of multiple services as a single service, the inclusion of embedded and external digital media and more efficient execution of bContracts.
The present invention discloses a distributed object method, which enables the execution of bContracts themselves on mobile handsets, scanning devices and any other device capable of interpreting a bContract language. The present invention provides for more efficient execution of electronic contracts, a better, more responsive user experience, the ability to execute electronic contracts on small devices even when network coverage is poor or absent and scalability and lower cost of the electronic commerce platform.
Accordingly, embodiments of the present invention disclose the construction of a novel electronic commerce system referred to herein as a distributed bPlatform. In embodiments, the platform may provide a ways to conduct electronic commerce transactions in a way that is convenient, natural and provides a rich consumer experience. The rich consumer experience includes the presentation, composition and capture of digital media, fast response to consumer input and changes in the local context of the experience. The platform may also provide a way to conduct more general mobile commerce and electronic commerce transactions in a more efficient manner and in a more convenient form than is currently possible.
Electronic commerce is based on contracts, agreements, and promises. The essential constituent of a contract is a promise by one party (promisor) to cause specified actions to be performed, generally for the benefit of another party (promisee). The bPlatform employs a digital encoding to express, and a mechanism to give effect to contracts, agreements, and promises. A bContract defines the aforementioned expression and mechanism.
In embodiments, the present invention enables the expression of electronic contracts that contain other electronic contracts (subcontracts) as parts. Such a mechanism, enabling the composition of electronic contracts, is required for the construction of bundled services consisting of a number of separately contracted parts. A bContract can express a list of explicit or implicit bContracts as being subcontracts or super-contracts. Other relationships between electronic contracts, such as the succession of one bContract by another may be useful and readily implemented using this method pattern.
In embodiments, the distributed bPlatform implements a bEngine component that may be incorporated as part of any computing device, such as a cellular mobile telephone, personal digital assistant (PDA) device, digital camera, music player or other consumer appliance. The bEngine is able to interpret a bContract locally on the embedding device. The bEngine enables bContract operations to be performed in the case of poor or absent network connectivity to server computers. The local execution of bContracts may provide a better user experience than remote execution. The ability to execute bContracts on client devices makes the scaling of the bPlatform to deal with large numbers of bContracts less costly.
In embodiments, the bEngine incorporates one or more digital security certificates and a digital signing mechanism that ensures that bContracts that are altered by unauthorized parties are detected as fakes by examining a digital signature generated by the bEngine.
In embodiments the bEngine provides a representation of the local context of execution of the bContract. The local context enables the bContract to respond to the geographic location, date and time, executing and nearby device characteristics, user identity and other contextual parameters and changes in those parameters. In embodiments this mechanism may be used to provide a different user experience prior to redeeming a ticket or voucher, compared to after redemption; A different user experience depending on the user's current location and so on. For example, digital media may be made available to the user at a specific location, such as a retail outlet for example.
In embodiments, the distributed bCode platform provides services such as cinema and event ticketing, retail vouchers and loyalty schemes, digital rights tokens and other services that are based on contractual abstractions and needing to provide a convenient rich user experience for consumers of the service.
In embodiments the distributed bCode platform provides a service that enables consumers to pre-purchase items of value, such as meals and drinks, and nominate one or more persons to receive tokens that entitle the bearer or specific person to the pre-purchased product or service.
Additionally, in embodiments the platform may provide a service that enables a consumer to challenge others to a bet, or other form of wager or challenge. The parties being challenged receive tokens that they may use to accept or reject the challenge and claim a prize in the case of the winner.
Additional objects, features, and advantages of the present invention will become apparent from the following detailed description of embodiments of the invention in conjunction with the accompanying drawings where like reference numerals indicate like features, in which:
Generally, commercial transactions are based on contracts, agreements, and/or promises that govern the execution of future actions. The present invention relates to a bContract, its constituent parts, its execution, and other additional parts, which make up a novel mechanism that may, in embodiments, be analogous to the conceptualization of a contract. In general, a bContract is a powerful expression of a contract in a number of ways described in PCT/AU2005/001799 (and below).
For example, a bContract may be configured to govern the execution of future actions, and may also contain an executable specification of actions. The expression that specifies actions is referred to herein as a bFunction. The actions specified by a bFunction may be logical operations executed by digital computers, communication operations, and/or physical actions executed by digitally controlled mechanisms. A bFunction, in certain embodiments, may specify constraints on the order in which the operations that constitute an action are performed. Additionally, a bFunction may, in certain embodiments, have the expressive power to specify conditional (contingent) actions. Examples of conditions, or contingencies, that can be expressed include conditions on time and location, observable state and relationships of physical objects, state of the bContract or other information bearing structure, and/or knowledge (or lack of knowledge) of information. Of course, the above listings are only examples of some of the expressive powers of the bFunction.
As shown in
For example, a bContract that constitutes an offer by an “offerer” party to an anonymous “offeree” party. The offer contract encapsulates the partially instantiated contract being offered “offered-contract” as one of its terms. Such partially instantiated contracts may be referred to as bContract templates. These templates are instantiated by meta-level bFunctions.
The offeree may accept the offer by invoking the “accept” meta-level bFunction. This function creates the new contract instance. The system may be constructed to explicitly or implicitly save such new contracts in the bContracts database. In this embodiment an array called “contracts” is used to hold such contracts to be stored.
The “accept” function also calls on the bToken allocate, associate and issue functions to create a new bToken for the customer. These functions may be coalesced into a single function call, but as discussed above, may also be separate for didactic purposes.
The above meta-contract mechanism provides the means to express a range of instruments including, but not limited to: Offers to Sell—Partially instantiated contracts representing goods, services for sale, with a meta-contract function that instantiates the offer; Offers to Buy—Partially instantiated contracts representing requests-for-quotations (RFQs), requests-for-proposals (RFPs) and other offers and expressions of interest to acquire goods or services. In this case meta-contract functions may be provided for sellers to respond to the offer; and Derivatives—Any bContract, terms of the bContract permitting, may be manipulated by meta-contract functions to alter the terms of the contract, divide the contract, compose multiple contracts into one and similar operations.
Once the bContract is instantiated it may be stored persistently on a bContract server as illustrated in
Once a bContract is instantiated, a bToken may be issued to one or more of the contract parties. The relationship of bCodes to the bContract is illustrated in
The device (bClient) receiving the abovementioned bCode message may incorporate a distributed bPlatform engine (bEngine).
Once the bClient has received the aforementioned bToken message, the bEngine intercepts the message, and may contact a bContract server, as shown in
The user of the bClient may invoke the bToken and associated bContract operations by operating the user interface of the bClient device. In response the bContract engine may execute bContract operations, such as providing further information about the contract, requesting postponement, cancellation, transfer or other operations provided for by the bContract. A further example of execution is the presentation of digital media or other digital service, as instructed by the bContract.
The user of the bClient may present the bToken to a bScanner device. An embodiment of a bScanner device apparatus and the presentation of a bToken is illustrated in
A bScanner device may be managed by a bScanner server, as shown in
A bScanner may incorporate a bEngine for the purpose of interpreting bContracts. A bScanner device may download all or part of a bContract, prior or subsequent to the presentation of a bToken associated with the bContract. The bScanner may execute operations of the bContract in response to the scan of a bToken or in response to other user interaction, such as touch screen manipulation of user interface widgets, or timed events. Alternatively the bScanner may request the bContract server to execute bContract operations.
The bScanner may download or upload digital media or other resources from a media server, as referenced or instructed by a bContract. In response to a bToken scan or other operation, the bContract may instruct the presentation or capture of audio, visual or other media for the user. A bContract may instruct the bScanner to contact the user's bClient device to download or upload media to that device. In the illustration of
For comparison,
b) illustrates the extended component structure and control/data flow when the device of
Subsequently the network client component in
A consumer may subsequently invoke the bContract by selecting it from a menu of available bContracts. One possible selection interface is illustrated in the previous disclosure PCT/AU2005/001799 (and below). In response to being selected an “open” event may be generated. A bContract interpreter component responds to this event by executing bContract instructions guarded by the “open” event.
The execution of the bContract may result in the display of information about the bContracted service, a rendering of the bToken, rendering of digital media, user interface widgets providing access to associated media and services. In the example illustrated in
An advantage of the present system is that the bToken may be rendered in a form,
Another advantage of the present method is that the consumer may have access to valuable associated services and media. In this example, the consumer has access to a mapping service that directs her to the location where the bContracted service is being provided. The mapping service is invoked in response to the consumer selecting the “How to Get There?” user interface widget. The mapping service may itself be implemented as bContract operations or as an external service.
In this case illustrated in
A successful scan occurs when the bToken is recognized and successfully decoded into a bCode. The result in a “scan” event, which invokes the bContract associated with the scanned bCode. The scan event results in the execution of any bContract operations that have been guarded by a “scan” event occurring on a scanner device.
As an example,
The bContract Engine, in embodiments of the present invention, may be a processing component that executes bFunctions that form part of a bContract. This execution mechanism may, for example, consist of physical sensors and computer hardware to execute conditional tests, computer hardware as memory to execute logical operations, communications hardware to execute communications operations and physical effectors to execute physical operations.
The main components and structure of a bContract Engine in accordance with an embodiment may include the following exemplary components: a persistent store containing a collection of bContracts and optionally an index that facilitates fast retrieval of the bContract associated with a given bToken; a bFunction execution mechanism (bInterpreter), which performs the evaluation and execution of bFunction conditions and actions; a bContract Service Interface, which enables an external entity to call for the execution of a bContract.
Additionally, the bContract Engine Interfaces may be implemented using a number of techniques, including procedure calls, web service protocols, asynchronous messaging and so on. Calls on bContracts may be issued by a remote procedure call (RPC) mechanism or received as an asynchronous message (MSG), and bToken issue/revoke may be implemented by an RPC mechanism, for example.
A bEngine contains a network client component, which communicates with a bContract server to download and upload bContracts from that server. The bContract server may be constructed as a distributed service consisting of any number of servers hosting a large number of bContracts in an efficient manner. The bContract server may be implemented as a reliable distributed object store.
Reliable execution of bContracts requires that multiple devices do not execute bContract operations simultaneously in a manner that would allow unintended behaviour or lead the bContract to an inconsistent state. The required reliability may be implemented using transactions to enforce mutual exclusion to the entire bContract or to critical regions of the bContract. Offline execution of bContracts may be implemented by providing bEngines with execution permits (capabilities) that expire unless renewed. A person skilled in the art of distributed systems may apply other alternative methods to ensure safety and synchrony.
A bEngine may contain a cache component that locally stores bCodes, bContracts and associated media and other resources. The cache component is typically required to provide efficient execution in the face of limited network communications bandwidth, high communications latency and high communications cost.
A bContract interpreter forms part of a bEngine. PCT/AU2005/001799, teaches the construction of a bContract interpreter. A bContract interpreter reads and executes the language used to express bContracts. The bContract language is preferably a simple scripting language or simple logic based language with declarative semantics. Examples of such languages are ECMAScript, Python, Prolog, OPS-5/Clips and so on. The present disclosure employs a simple declarative query/assertion language.
A bEngine may contain a user interface component that gives effect to the audio/visual rendering and interaction by the user of the device. As an example,
Note that
As shown in
An advantage of the representation illustrated in
The structure includes an execution context, which enables the execution path to depend on time, geographic location, executing device, present parties and other information about the context in which execution is occurring. This method enables the construction of context aware services.
a) and (b) illustrates a mechanism used to construct composite bContracts. In this case a service provider has promised to provide a “Dream Holiday” to a consumer. A “Lagoon Restaurant Invitation” forms part of the “Dream Holiday”. Using the illustrated subcontract/supercontract mechanism a hierarchy of bContrats may be constructed. The user interface to the bContract may provide a convenient means to view and operate on such composite contracts. The manner in which the bContract itself may generate the interfaces is described below.
a) illustrates how information about the parties to a bContract and the unique identifiers (bCodes) may be represented. In this case the representation includes selected service parameters that apply individually to each of the parties. More generally, service parameters and references to external resources, such as digital media, may be represented and associated with parties in other parts of the bContract, such as the media section described below for instance.
Note that the service provider is also issued a bCode in order to enable the service provider to execute elements of the bContract. In this case the service provider may scan this bCode to confirm that a redemption of the promise encoded by the bContract has been delivered. Additionally the bContract may include operations enabling the service provider to change terms, provide refunds and other operations agreed to by the parties and encoded as executable by the service provider.
b) illustrates a representation of the terms of the bContract. As illustrated, the information items represented here may be analogous to the terms of a contract as written in a natural language, such as English.
The terms, and other items, of a bContract are not limited to explicitly nominated data. The final clause in
a) and (b) illustrate the representation of an execution context for a bContract. For 10(a) the execution context is a bScanner device that has just experienced a scan event of a specific bToken. For 10(b) the context is a cellular mobile phone, where the user possessing the nominated bToken has just selected to open the bContract for viewing.
b) illustrates the use of an execute clause to assert a value for the party of the current execute context. This party is the party whose bCode appears in the current execute context. Note that the exclamation mark “!” denotes an assertion, analogous to an SQL update clause. This same effect can be stated more directly, as shown in
Some of the discussion of PCT/AU2005/001799 is detailed below.
Commerce is normally conceptualized and regulated in terms of contracts, agreements, promises and the like. A contract generally consists of a set of promises and an agreement by the parties to the contract to perform (i.e., fulfill) the aforementioned promises. Traditionally, commercial contracts are often implied by conventional and legislated patterns of practice. Promises and contracts are expressed in forms of words, which may be recorded as text on paper or other suitable physical media. Because these traditional non-digital commerce methods have been limited by manual processes involved in trade such as paper contracts and face-to-face presence and encounters required to perform trade some of the limitations include: static paper contracts that are time-costly and money-costly to instantiate, negotiate, execute, alter, perform and police; static invocation using physical artifacts such as paper tickets, receipts, documents and cards (e.g. magnetic stripe, barcode, smart-cards) which requires physical presence by humans and machines to perform trade, or part processes to a trade; manual processing of transactions; and manual and/or external performances to contracts; common human languages (e.g. English) that's hard to decipher, alter and understand, often imprecise and hard to automate using machines. As a result, markets are very fragmented (as illustrated in
The availability of low cost computing devices and communications networks is enabling electronic commerce. The term electronic commerce (e-commerce) denotes forms of commercial practice involving transactions assisted by or carried out by computers communicating across networks. More recently, e-commerce has become an increasingly popular way to carry out commercial transactions between business entities (B2B e-commerce). In e-commerce practice, promises and contracts are expressed as text, which is encoded in digital form, stored in computer files, and transmitted in electronic data interchange formats based on encoding technologies such as XML.
More recently, the availability of low cost mobile computing devices and wireless communications networks is extending the reach of e-commerce so that transactions involving computation and network communications can take place anywhere and at any time. The term mobile electronic commerce (m-commerce) is generally used to refer to commercial practices involving such transactions.
One aspect of an m-commerce transaction is that it can take place at a time and in a location and within a context that is related to the transaction. The term mobile electronic commerce in context (x-commerce) refers to commercial practices involving such transactions in context. An x-commerce transaction can involve a mix of remote network, local electronic, and local physical interactions between computing devices and parties to the transaction. X-commerce transactions can provide a convenient, natural and rich experience for consumers, and therefore extend the reach of electronic commerce beyond business-to-business (B2B), into business-to-consumer (B2C) and consumer-to-consumer (C2C) commerce.
All forms of e-commerce are currently at a very early stage of evolution and lacking many convenient, accepted patterns of practice and forms of expression. This lack of structures and platforms has inhibited the growth of electronic commerce, particularly when consumers are involved (e.g., B2C and C2C).
Accordingly, embodiments of the present invention disclose the construction of a novel electronic commerce system referred to herein as a bPlatform. In certain embodiments, the platform may provide a ways to conduct x-commerce transactions in a way that is convenient, natural and provides a rich consumer experience. The platform may also provide a way to conduct more general m-commerce and e-commerce transactions in a more efficient manner and in a more convenient form than is currently possible.
As discussed above, e-commerce is based on contracts, agreements, and promises. The essential constituent of a contract is a promise by one party (promisor) to cause specified actions to be performed, generally for the benefit of another party (promisee). The bPlatform employs a novel digital encoding to express, and a mechanism to give effect to contracts, agreements, and promises. A bContract defines the aforementioned expression and mechanism.
The disclosed bContract mechanism is a powerful new primitive for e-commerce. In certain embodiments, the disclosed bPlatform implements and employs the bContract method to provide a number of advantages and opportunities that are not provided by other known electronic commerce methods. In certain embodiments, some of these advantages may include, but are not limited to: (1) construction of a rich range of electronic promises, including: fixed, variable and contingent promises; unilateral promises, such as electronic offers, RFPs and RFQs; multilateral promises involving N parties in various roles; (2) composition of promises to form bundled offers, contracts and other composites and the inverse decomposition of these composites to enable a rich, highly efficient marketplace to develop electronic promises and their derivatives; (3) providing a mechanism to formalize conventional and commonly useful patterns of practice as contract templates, and to instantiate the templates as effective promises, contracts and other derivatives; (4) mechanisms for the parties to the contract to conveniently and securely call on promised actions anywhere and at any time employing an electronic device that provides the necessary computational and communications devices; (5) ways for the parties to the contract to conveniently conduct actions of a promise as a mobile commerce transaction in context (x-commerce); and (6) providing controlled visibility and auditing of the electronic contract and its lifecycle from creation to termination.
In an embodiment of the present invention, an electronic commerce (bCommerce) method is provided that includes publishing a sell-side or buy-side offer for a product or service (bTemplate); receiving, by a user, the published offer and conditionally accepting the offer, forwarding the conditional acceptance to a matching processor (bMarket) to request the product or service; receiving the conditional acceptance by the matching processor; determining, by the matching processor, whether conditions present in the conditional acceptance can be fulfilled; forwarding, by the matching processor, at least one option for acceptance; displaying the at least one option for selection to a user, selecting, by the user, one of the at least one options; and providing a token (broken) to the user. Additionally, in certain embodiments, the token is configured to be used to call for execution of the promised actions of the offer, such as redeem the service or product, be transferable to another user device, or to be stored for future redemption of the product or service.
Additionally, in certain embodiments, the offer may be for movie tickets and the conditional acceptance is conditioned on at least one of the movie, the time of the movie, the price of the ticket, the location of the showing of the movie, or the number of movie tickets available; or the offer may be for a transportation ticket and the conditional acceptance is conditioned on at least one of the destination, the time of departure/arrival, the price of the ticket, or the number of tickets available. Additionally, the token may be stored in one of a user device or a remote storage device that can be accessed by the user device for redemption or transfer, and the redemption of the token causes additional offers to be published to the user; one or more tokens can be used to redeem one or more products or services. In further embodiments, redemption of a token is accomplished by presenting the token to an electronic scanner or electronically transmitting the token to a receiver.
In other embodiments, the token represents the ability to redeem or transfer at least one of: an entertainment event ticket, a transportation ticket, a key, a raffle/lottery ticket, a license, a membership, a personal identifier, monetary value, a voucher, a loyalty card, a medical prescription, a transaction receipt, login credentials, a url/uri, a digital right, a piece of digital media, a business card, a queuing token, a bill, or a non-disclosure or other agreement to refrain and/or the token may be designed for use in mobile devices.
Further, in certain embodiments, the token may be human readable, machine readable, or OCRable and may be configured for multi-mode presentation including at least one of OCR, barcode, or NFC.
Additionally, the token may be transferable using a store and forward messaging protocol including SMS, MMS, and/or e-mail or a synchronous protocol including HTTP or WAP.
In still a further embodiment, an electronic commerce system, is provided that includes a user device for requesting a product or service with predetermined terms, the user device being configured to forward the request to a matching processor; the matching processor being configured to receive the request from the user device, determine whether the predetermined terms can be fulfilled, and forwarding at least one option for acceptance to the user device; and a display device associated with the user device for displaying the at least one option for selection, wherein when one of the at least one options is selected, the user device is provided with a token. The token may be configured to be used to redeem the service or product, be transferable to another user device, or to be stored for future redemption of the product or service and, in some embodiments, the request may be made from one of a template provided to the user device or as a free text input that can be parsed by the matching processor.
In still further embodiments of the invention, an electronic commerce method may include forwarding at least one offer for acceptance to a user device based on a request from a user, and providing a token to the user based on the user's selection of one of the at least one offers. The token may represent the ability to redeem a product or service, transfer the redeemability of the at least one product or service to another user, may be stored in one of the user device or a remote storage device that can be accessed by the user device for redemption or transfer, and can be combined to redeem one or more products or services; and redemption of a token may be accomplished by presenting the token to an electronic scanner, or electronically transmitting the token to a receiver.
In still further embodiments of the invention, an electronic commerce method may include forwarding at least one offer for acceptance to a user device based on a request from a user, and providing a token to the user based on the user's selection of one of the at least one offers. The token may represent the ability to redeem a product or service, transfer the redeemability of the at least one product or service to another user, may be stored in a remote storage device that is configured to store a plurality of a the user's tokens in a manner such that the user can access the tokens from the user device and select a token for redemption or transfer, and redemption of a token may be accomplished by presenting the token to an electronic scanner, or electronically transmitting the token to a receiver.
In still further embodiments of the invention a matching system may include a receiver for receiving a request from goods or services from a user, wherein the request includes an identification of the goods or services and user defined terms associated with the request for the goods or services; a parser for parsing the request to determine the requested goods or services and the associated terms; a processor for comparing the parsed request to information in a database to match the parsed request with actual goods or services that are available; and a transmitter for forwarding at least one match to the request to the user for acceptance. The user may select one of the at least one matches, the matching system provides the user with a token that is configured to be used to redeem the service or product, be transferable to another user device, or to be stored for future redemption of the product or service.
Generally, commercial transactions are based on contracts, agreements, and/or promises that govern the execution of future actions. The present invention relates to a bContract, its constituent parts, and other additional parts which make up a novel mechanism that may, in certain embodiments, be analogous to the conceptualization of a contract. In general, a bContract is a new more powerful expression of a contract in a number of ways.
For example, a bContract may be configured to govern the execution of future actions, and may also contain an executable specification of actions. The expression that specifies actions is referred to herein as a bFunction. The actions specified by a bFunction may be logical operations executed by digital computers, communication operations, and/or physical actions executed by digitally controlled mechanisms. A bFunction, in certain embodiments, may specify constraints on the order in which the operations that constitute an action are performed. Additionally, a bFunction may, in certain embodiments, have the expressive power to specify conditional (contingent) actions. Examples of conditions, or contingencies, that can be expressed include conditions on time and location, observable state and relationships of physical objects, state of the bContract or other information bearing structure, and/or knowledge (or lack of knowledge) of information. Of course, the above listings are only examples of some of the expressive powers of the bFunction.
A bPlatform provides a mechanism to evaluate the conditions described above and execute the actions specified by the bFunction(s). The evaluation/execution mechanism is referred to herein as a bInterpreter.
In certain embodiments, the bContract may provide at least one of the parties to the contract a digital token that enables parties to the contract to call on those specific actions of the contract that the respective party is entitled to. These tokens are referred to herein as a bToken. Further, bContracts are self contained digital entities with persistent states.
The above terms will be further described and defined below with respect to various embodiments to provide a person with ordinary skill in the art a better understanding of the present invention.
The embodiment in
More generally, a bContract contains one or more bFunctions, and is associated with zero or more bTokens. Each bToken maps to one or more bFunctions within the bContract.
In certain embodiments, extensible mark-up language (XML) syntax may be employed to represent the state of bTokens, bContracts, bFunctions and other information bearing entities. In
While XML is used here to express structured state information, a person of ordinary skill in the art may readily employ other representations, such as relational database records, object oriented programming models, semantic networks and so on. XML syntax is convenient to express structured state information, but it can be difficult to read when used to express conditions or constraints to be evaluated and operations to be executed. Instead of XML, therefore, simple scripting style language within the XML to express conditional actions (bFunctions) may be embedded, as illustrated in
For clarity, some purely technical details are omitted from the exemplary scripts. For example, explicit <![CDATA[ . . . ]]> constructs, which would normally be required to ensure correct parsing of XML meta characters such as “<” and “&” are omitted from embodiments. Additionally, logical operators, such as “<” (less) and “>” (greater) can recognize and respect the semantics of lexical ordering of strings and temporal ordering of dates and times, as well as numeric values. A person skilled in the art should be able to readily infer these and other technicalities.
Scripts generally employ dot notation to denote XML structures, as used in ECMAScript for XML (E4X) for example. Each statement of a script is a logical expression. For example, in the case that the logical expression evaluates true, the following statement is executed or in the case that it evaluates false, the processing of the bFunction terminates; etc. Short circuit evaluation of logical operators, may also be assumed. Control constructs, such as if . . . then . . . else . . . conditionals, are assumed to have conventional meanings.
bToken
In certain embodiments, a bToken may be a sequence of binary digits. The aforementioned sequence may, in certain embodiments, be at least 40 binary digits long (in other embodiments, the sequence may be as long or as short as desired, e.g., 10-20, 30-60, 60-100 bits long), as illustrated in
As illustrated in the example of
Flowchart-like notation is used herein to describe architectural and procedural aspects of the system. In
In the case that bTokens are allocated in a sequential or otherwise determinable manner, then bTokens may be encrypted to hide this predictable structure. The bToken may, in certain embodiments, by encrypted before it is transmitted, and decrypted before it is resolved.
A bToken refers (e.g., maps and/or identifies) to one or more objects by means of an association/resolution method pair. The association method records which object(s) a bToken identifies. Subsequently given a bToken, resolution returns a resolvent consisting of the previously associated object(s), or an error indication if no current association exists.
For the purpose of the present embodiment, a bToken maps to a bContract and to a specific party to that bContract.
bCode
Once a bToken has been allocated and associated with a bContract and party to the bContract, the bToken is made available to that party. The bToken may be encoded (e.g., encode bToken step in
As discussed above, the bToken may be encoded in the N-CODE format. This format is referred to herein as the bCode format and bTokens encoded in this format as bCodes. This encoding is illustrated in
Subsequent to encoding the bToken into a bCode or other format, the bCode may be embedded into a message, such as an SMS short message, e-mail message, instant message or other such messaging form for transmission to an end-customer. The formatting of the bCode as a short message is illustrated in
As an example, a typical bToken message may consists of: a header line including the text “bCode”; a bToken encoded as a bCode or other encoding; descriptive information about the associated bContract; descriptive information about the actions and conditions of the bContract; instructions to the end-user related to the use of the bToken; and optionally other media to be used to display the bToken message or associated with the service.
A person skilled in the art may readily construct other bToken and message formats and useful functionality, such as bToken deletion/retirement/revocation and re-transmission/re-issuing for example.
In certain embodiments, the allocation, association, issuing, resolution and retirement processes maintain a comprehensive database of information about allocated bTokens. Examples of such information include, but are not limited to, the date and time of these events.
bFunction
A bContract may contain one or more bFunctions. At one extreme, implementations may choose to express all the various algorithmic elements of a bContract as a single bFunction. At the other extreme, an implementation may choose to employ a set of constraint expressions or conditional action rules, in which case each of these expressions or rules could be considered to be a small bFunction.
In certain embodiments, the algorithmic aspect of a bContract may be expressed as a small set of reasonably independent bFunctions. bFunctions consist of conditions to be evaluated and actions to be executed contingent on the value of the evaluated conditions. Other programming language may also be employed to express bFunctions. In certain embodiments, the chosen language may have a compact textual representation, and is easy for humans to read. A scripting language, such as X4E or the style of language illustrated in
As an example,
context.date.$now.
The value of this expression is true, and a side effect of evaluating the expression may be to bind a variable $now to the value of the date element of the context top level element, i.e. “2005-10-01”. The expression would evaluate to false in the case that no date element existed in a context element. In this embodiment, the evaluation of the “terminate-offer” function would terminate. Optionally such unexpected termination of functions may be used to generate an exception, which can be supplied by any conventional technique.
The remaining expression of interest is: assert contract.state.terminated. The evaluation of this expression adds a <terminated!> element to the state of the bContract, as illustrated by the arrow in
bContract Engine
The bPlatform may be partitioned into a number of “engine” components. A bPlatform may, for example, be constructed from a selection of engine components, as illustrated in
The bContract Engine, in this embodiment, is a processing component that executes bFunctions that form part of a bContract. This execution mechanism may, for example, consist of physical sensors and computer hardware to execute conditional tests, computer hardware as memory and to execute logical operations, communications hardware to execute communications operations and physical effectors to execute physical operations.
The main components and structure of a bContract Engine in accordance with an embodiment are illustrated in
Additionally, a bContract Engine may provide more than the two interfaces shown in
The bContract Engine Interfaces may be implemented using a number of techniques, including procedure calls, web service protocols, asynchronous messaging and so on. As illustrated in
As indicated in
Step 1: Wait for trigger event: A trigger event may be a call via the bContract Service Interface or an external event, such as a time-of-day event nominated as a condition of execution by a bFunction.
Step 2: Retrieve the one or more bContracts associated with the event from persistent store.
Step 3: Evaluate the conditions and actions of bFunctions of the retrieved bContract.
Step 4: In the case that the execution of actions modified the bContract or created new bContracts, store the updated bContracts in the persistent store.
Step 5: Go to step 1.
The bInterpreter illustrated in
The bInterpreter functionality may, in certain embodiments, be implemented by means of alternative mechanisms, such as a persistent object database and Java Enterprise (J2EE) execution mechanism, or a relational database and a .NET execution mechanism and environment.
bContract
This exemplary bContract form of
For the
Alternative implementations may provide mechanisms for declarative bFunction conditions or pre-evaluation to provide more efficient selection of bContract execution. However, the illustrated execution order and mechanism is very simple to implement, and since bFunction execution represents a relatively small load, a simple implementation, may be preferred.
Note that three of the bFunctions, illustrated in
There are two bToken values, issued to the two parties of the contract illustrated in
Persons skilled in the art may formulate bContracts for additional applications as well without deviating from the principles of the present invention.
In order to facilitate the above applications, the bContract structure may be extended as illustrated in
So far the bContract mechanism has been used to manipulate object-level information and state about an application domain, such as ticketing for example. However, the bContract mechanism may also be lifted from this object level to the meta-level, where the bContract reflects and manipulates information and states of bContracts themselves.
The meta-bContract art, shown in
The offeree may accept the offer by invoking the “accept” meta-level bFunction. This function creates the new contract instance using the expression: assert contracts[1].$new-contract. The bInterpreter may be constructed to explicitly or implicitly save such new contracts in the bContracts database. In this embodiment an array called “contracts” is used to hold such contracts to be stored.
The “accept” function also calls on the bToken allocate, associate and issue functions to create a new bToken for the customer. These functions may be coalesced into a single function call, but as discussed above, may also be separate for didactic purposes.
The above meta-contract mechanism provides the means to express a range of instruments including, but not limited to: Offers to Sell—Partially instantiated contracts representing goods, services for sale, with a meta-contract function that instantiates the offer; Offers to Buy—Partially instantiated contracts representing requests-for-quotations (RFQs), requests-for-proposals (RFPs) and other offers and expressions of interest to acquire goods or services. In this case meta-contract functions may be provided for sellers to respond to the offer; and Derivatives—Any bContract, terms of the bContract permitting, may be manipulated by meta-contract functions to alter the terms of the contract, divide the contract, compose multiple contracts into one and similar operations.
In addition to the meta-contract aspect,
The exemplary bContract also provides a “descriptors” function, which may be called by any of the contract parties to return an XML formatted description of the function signatures of the bContract.
Typically bContracts are embedded within a bPlatform that employs the bContract mechanism to provide economically valuable services in a way that is convenient for consumers to use. bContracts may implement a standardized set of well known bFunctions, which other processing and user interaction elements of the bPlatform can rely on to provide the functionality they need. The above-mentioned “descriptors” bFunction, and the “metadata” bFunction are examples of such a protocol.
bWallet
A bPlatform may optionally provide a bWallet service that enables an end user to manage the set of bTokens issued to that end user. A bWallet service may be implemented as a remote server-based service, a service that executes on a user's mobile client device or as a service on an intermediate device, such as a bScanner, for example.
A user (customer) of the bWallet service may access the service via a web portal interface or via an RPC or asynchronous messaging interface.
While a simple bWallet consists of a collection of currently valid bTokens, more elaborate implementations may choose to provide a persistent record of expired bContracts as well. Still other implementations may provide a search mechanism or recommendation mechanism that enables the customer to search for bContracts, such as offers of interest.
Additional embodiments and functionality of the bWallet are illustrated in
bClient
A bClient provides the necessary functionality that a consumer needs to access bPlatform services. The bPlatform may be designed to enable the use of existing portable electronic devices for this purpose so that any device that provides the mechanism for digital data messaging can be utilized as a simple bClient. Exemplary devices include, but are not limited to, cellular phones, PDAs, mobile game consoles, music and multimedia players and notebook computers. Exemplary messaging services include, but are not limited to, short messaging services, such as the SMS/GSM service, e-mail services and instant messaging services.
A cellular telephone handset is a typical example of a simple bClient. bTokens, encoded as bCode messages, may be transmitted to such a device by means of a short messaging service, such as the SMS/GSM service, for example.
Another example of a bClient is a cellular phone equipped with a low power radio frequency (LPRF) transceiver, such as a Bluetooth or Near Field Communications (NFC) transceiver, for example. In this case a bToken may still be transmitted to the client as a bCode message. In order to make full use of the LPRF capability, the client may incorporate additional functionality to automatically call for another form of token encoded in a form specifically designed for LPRF presentation. This client-calls back mechanism may operate as follows: (1) The bClient receives a bCode message; (2) The bClient recognizes the bCode message by message header or content pattern match; (3) The bClient transmits a request to a bPlatorm to provide an alternative format and/or other associated content; (4) The bPlatform replies with the requested representation and/or content. This client-calls-back mechanism may be advantageous because the sender of the bToken need not know what formats are supported by a specific client, while at the same time heterogeneous clients are supported provided so long as the clients implement the “lowest common denominator” bCode format and the call back mechanism.
A bClient Engine may also incorporate a bToken presentation component, which responds to a query, transmitted via LPRF by a bScanner, by transmitting a bToken that matches the query as a reply to the bScanner. This query-initiated form of presentation improves the end-user experience by eliminating the need for the end user to manually find and select a bToken for presentation.
The bToken prefix, illustrated in
A bClient engine may provide a richer user experience by automatically calling on a bToken to supply alternative or additional digital media, such as graphics, audio, or video associated with the bToken. These media may then be presented to the end user as representations or additional to the bToken.
bScanner
The bPlatform may employ intermediary devices, called bScanners, to provide the tools for consumers to carry out x-commerce (m-commerce in a local context) transactions. Such local contexts include the entry turnstile of a cinema or transit authority, the point-of-sale of a retail business and so on. The consumer experience may be improved by providing the tools to complete a transaction by interacting with a local hardware device that recognizes bTokens, provides rich user interaction means, calls on bFunctions and performs actions nominated by the bFunction locally.
A bScanner typically operates according to the following procedure:
Step 0: A bPlatform may employ a bScanner Provisioning interface to preload or cache (partial) bContracts, bScanner functions and presentation media that the bScanner may require to operate. This provisioning step may occur at any time.
Step 1: Wait for customer to approach. During this time a bScanner equipped with display or an audio rendering apparatus may display promotional or other content. A bScanner equipped with an LPRF device may broadcast LPRF advertisements of the services the scanner offers.
Step 2: Acquire bToken from a bClient. A digital camera, triggered by a proximity detector, may be used to obtain a bCode image displayed on a mobile device screen. An audio signal, emitted by a bClient, may be acquired using a microphone. An LPRF radio signal may be acquired using an LPRF receiver, according to a protocol such as the example in
Step 3: Decode the acquired bToken. In the case of a visual bCode, decode is performed by segmenting the bCode from the acquired image, applying optical character recognition (OCR) and applying the reverse of the encoding process illustrated in
Step 4: Ensure that the given bToken is valid by querying a bToken index, typically via a bContract service interface. In the case that the bToken is valid, and of a type that the bScanner is able to deal with, proceed to step 5. Otherwise provide an indication to the user that the bToken is not valid and go to step 1.
Step 5: The bScanner may directly invoke the bContract with a predetermined bFunction name (and other parameters). Alternatively the bScanner may present the consumer with a menu of available functions for the given bToken. In this case the “metadata” and “descriptors” functions may be invoked by the bScanner to discover the available functionality and required parameters. Subsequently the user may select the functionality to be called. The bContract underlying the given bToken may be processed remotely or (partially) cached on the bScanner itself.
Step 6: The bContract engine will typically reply to a bFunction call with a reply containing the result of processing the request. The reply may contain an informative message, media to be presented or a function call to be performed by the bScanner. Examples of such bScanner functions called include opening of a turnstile and dispensing of an item by a vending machine of which the bScanner forms a part. The underlying bContract may implement a handshake protocol, which requires the bScanner to provide a positive or negative acknowledgement on completion of the requested bScanner function.
Step 7: Go to step 1.
bPlatform Architecture
The following bPlatform components were described above:
a bContract Engine;
a bWallet Engine;
a bScanner Engine; and
a bClient Engine.
These components are designed to fit together to form an entire bPlatform. Exemplary bPlatform configurations are illustrated in
Alternative bPlatform configurations using the elements described in the present disclosure should be obvious to persons of ordinary skill in the art.
bPlatform Server
The value of an electronic token (bToken) to an end-user is that it provides the end-user with the capability to call on the transaction methods (bFunctions) of the digital contract associated with bTokens in the end-user's possession.
Given a bCode, for example, an end user may invoke bFunctions of the underlying bContract in the following ways:
bScanner Presentation: User locates a bCode message in the short message inbox of a cellular telephone and places the phone display on the scan-plate of the bScanner apparatus described below.
Message Presentation: User composes a short message using her cellular telephone functionality. The message consists of the word “information” or other bFunction name followed by a bCode from the cell phone inbox.
Portal Presentation: User logs onto a web portal and pastes the text of a bCode into a text field provided for this purpose on the web page input form.
RPC Presentation: User employs a Java MIDLet installed on her cell phone to pick a bCode and function to be invoked.
A server computer hosting a bContract platform and connected to the Internet receives and processes the requested bFunction. The effect of the execution is an informative message or execution of the requested functionality.
In an exemplary interaction between the client and server, the client receives a message containing a bCode from the server, as a cellular short message. In this embodiment the server employs a Short Message Centre (SMSC) connection arranged with a cellular telecommunications carrier. Subsequently the client sends a message containing the same bCode to the server requesting the execution of a bFunction permitted by the bCode. As an example, the bContract underlying the bCode may entitle the holder of the bCode to receive a piece of digitally encoded music. The music file is transmitted to the client in response to the request.
The bPlatform may be embedded as a component of a larger system.
The exemplary bContract may consist of two promises between a consumer (party 1) and a merchant (party 2) that operates the external platform. Promise 1 is an obligation on the part of party 2 for the benefit of party 1, and promise 2 is an obligation by party 1 for the benefit of party 2. Together the promises satisfy the notion of consideration required for some forms of legal contract. For the purposes of this embodiment, promise 1 may provide party 1 the right to claim a prize that party 1 has been fortunate to win in a game of chance conducted by party 2. In this case promise 2 may represent the fee paid by party 1 to party 2 to enter the prize draw.
bScanner Apparatus
Example applications of bScanner devices include ticket, voucher and customer recognition scanners, vending machines and other sales and service points that recognize bTokens. bScanner device form factor details that may vary depending on the application and details of embedding of the scanner apparatus as part of existing equipment. In this section a stand-alone bScanner device design is described. This design can readily be modified for many embedded configurations by persons skilled in the art.
In
The above industrial design with an angled scan plate enables a consumer to quickly and conveniently position a cell phone in front of the scan plate. Preferably the bScanner apparatus is positioned at approximately waist height for the average end-user group of the bScanner.
The memory and processing devices for the bScanner embodiment may be provided by a standard small form factor personal computer motherboard, low power processor and flash memory. The bScanner employs a standard embedded wireless communications modem to provide access to the bContract platform backend server.
The bScanner core functionality may be implemented using the C++ programming language or other appropriate language. This bScanner embodiment may employ the well-known Flash platform by Macromedia Corporation for user interaction using the LCD touch screen, and as the programming language for the bScanner functions.
bIntermediaries
The bMarket described herein allows offers from buyers and sellers. Each can list standing offers to buy or sell products and services and any incomplete contract can be listed on the market as a standing offer which could have a variety of offer conditions and proposed terms. Existing bTemplates may, in certain embodiments, be used as a shortcut for the offer drafting process. In conventional systems, however, the processes are unilateral, and a single place is provided for sellers to list fixed and basic products and services for sale.
Additionally, in certain embodiments of the present invention, the bContract fields (which may be marked-up using XML) may be categorized with specific meanings and may create meaning, context, and relationships for the field information, whereas conventional systems are only capable of using a keyword syntax. Specifically, in certain embodiments, advanced searching that can search bContract fields along with information such as Object Model relationships and Associative relationships may be utilized. The associative relationships may be, for example, relationships between field data that give users adjacent or related results that are relevant and desired by the user performing the search. In certain embodiments, a number of browsing tools may be available to give a user textual or graphical representations of related results. The search base for each search may be large and bContract terms may be potentially complex. Further, associated logic may be rich, meaningful and user-friendly interfaces may be required for users to use the bMarket environment. Accordingly, the interface, in certain embodiments, may be tailored to provide manageable navigation for users. Examples of such interfaces, may in certain embodiments, include hub and spoke, hierarchy-based object browsers, proximity maps, n-dimensional maps, color-coded maps, etc (i.e., more than, for example, a straight list of products). These display methods have been used to browse content on the Internet, such as the news browser Liveplasma.com is providing for News.com. The bMarket Associate Browsers may, in certain embodiments, utilize similar methods for a bContract browser, utilizing the unique contract mark-up and classification language specified in the present invention, as well as the associative intelligence (discussed below), giving bMarket users the same functionality of browsing as if the bContracts were static context-sensitive relational content such as News.
Additionally, the goods associated with the bContract may, in certain embodiments, include all physical and virtual goods. Additionally variable term contracts which expand the tradable good domain significantly to include any unit of demand or supply in an economy may be available. For example, different stage buy offers (marketing, lead generation, request for information, request for proposals, initial offer, etc), and different stage sell offers (partially completed goods, goods requiring assembly, bundling or processing, etc.) may be possible using certain embodiments of the present invention. Accordingly, transactions in accordance with the present invention are not limited to tradable goods limited to physical goods with fixed terms of sale.
Furthermore, as described herein, the bMarket allows goods, services and bContracts to be traded in real-time. Once a bToken is exchanged, the recipient may get instant access to the physical good or service associated therewith. Accordingly, for example, the bToken can be used to get immediate access to a venue since bContracts are maintained by the bMarket central authority, all trades happen in real-time, and along with the actual transfer of the entitlements. Accordingly, there is no delay as a result of logistical events that are often slow (e.g., postage, escrow processes, etc.). Additionally, the bMarket may contain mechanisms to execute elements of bContracts. Performance may be internal to the bMarket such that actions such as redemption, variation, cancellation, transfer, etc, are directly invoked, authorized, tracked and reported by the bMarket.
Additionally, in certain embodiments, a 1-to-1 and/or a 1-to-many negotiation tool may be provided for allowing parties to negotiate variations to a contract until agreement is reached.
In addition, in certain embodiments, a bIntermediary may be employed to achieve further flexibility within the bMarket. bIntermediaries may be devices or programs that help match particular products or services with customers. In certain embodiments, the bIntermediaries may be configured to set up a portal or “skin” to provide specialized access or usage to target a specific user base or for specific products, services, industries, markets, or types of bContracts. For example, a bIntermediary may be configured to specialize in sourcing masseurs and may, therefore, be configured to create a custom portal to attract them, provide value-added content and services, and then plug them into the bMarket. In an other embodiment, a bIntermediary may be configured to set up a website that specializes in selling chocolate that uses the bMarket to source the products, and then package them in a that adds some type of value to a specialized chocolate sales portal. The bMarket bIntermediary architecture allows intermediary portals that use the Internet, Mobile Phones, PDAs, offline channels, etc. to give certain user-bases more meaningful access to the bMarket, and vice versa. Furthermore, in addition to the variety of object browsing tools such as APIs, subscription-based feeds, event-based feeds, and rule-based feeds etc. for human users, for bIntermediaries, there may be a variety of query tools, filtering tools, associative “views” of the database, etc.
In conventional systems, however, there are no such secondary market capabilities or market creation capabilities. Specifically, user & programmatic interfaces available for human or machine intermediaries to trade in the bMarket may contribute efficiency to the market given the security and credibility control systems of the market. bIntermediaries, as discussed above, are agencies that act as facilitators for the creation, negotiation and completion of bContracts between parties, buyers and sellers. In some embodiments, the buyers or sellers may not be aware that they are going to indeed be buyers and sellers because bIntermediaries can also play a market-making function. In
As an exemplary embodiment of how bIntermediaries can function, an airline passenger and tourist from China arrives at the Sydney airport. The passenger uses his mobile device to put a bContract offer onto the bMarket requesting proposals for 5 nights of luxury accommodations. A number of accommodation providers would already have subscribed to a qualified feed of such tourists, and may choose to respond to the tourist directly. However most of these providers may be filtered out by the requester in certain embodiments, i.e. tourist, based on market credibility criteria. Of those direct bContract offer responses, the Shangri La hotel may, for example, make it through to the participant, as it may already have a credibility rating with the tourist. The Hilton hotel may also make it through. Even though it may not have a prior credibility rating with the tourist, it may have a sufficiently high market-based credibility to also make it past the selection criteria of the tourist.
In certain embodiments, there may be a number of bIntermediaries that would have also subscribed to the feed of incoming passengers. One of these could be an internally renowned holiday management organization such as Accor. One of Accor's expertise is careful management of travel needs by travelers. In this instance, Accor may use its own intelligence to find the tourist a well-recommended luxury accommodation in Sydney for China-originating travelers, i.e., one that has Chinese-speaking staff. In addition, along with its response for accommodation, in certain embodiments, it may offer a tour package which includes restaurant accommodations and a brief tour of the Sydney Casino, even though these offers were not prompted by the requester. In embodiments, Accor may be able to get past the Chinese tourist's selection criteria, because it has market credibility or it may simply be requested by the tourist.
Another bIntermediary may also get through the selection criteria, as it realizes that this particular tourist has an advertised profile of seeking a female companion, even though that did not form a part of the accommodation request. bIntermediaries can also act as experts in relationships with participants, whether as supplier relationship management or customer relationship management. In this embodiment, the bIntermediary may also package into the offer, a tour to the great singles bars in the area. The selection criteria offered by the bMarket to the tourist may contain advanced selection configuration capabilities that may allow this particular bIntermediary to be selected.
On the supply side, certain bIntermediaries can aggregate buyer groups for presentation to suppliers. In this embodiment, the forementioned bIntermediary may specialize in aggregating tourists from China and presenting that buyer block to the Sydney Casino, to obtain better terms such as price on the accommodation for this buyer group. In doing so, it is intermediating a market niche and, in embodiments, profiting as a result.
In terms of credibility development, similar to what Blogs use for building up a credibility hierarchy as well as allowing low-credibility provider to rise up the ranks, the bMarket may enable the more adventurous participants to sample lower-ranked providers and services. These participants will configure their selection criteria to target new providers. Thus the gradual build up of opinion and trading record as a result of these transactions will eventually lift quality participants and bIntermediaries where they can transact en-masse. The bMarket provides application and user interfaces for the bMarket participants and intermediaries to transact in the fashion described above.
In certain embodiments, the matching of requirements may be, just like real-life human situations, often non-precise and based on associative and fuzzy logic. So the matching of these requirements in these embodiments may often be described by a combination of words and menu selections, and are matched by the method described later under word matching, associative and affinity logic.
As shown in
This last step completes the typical bMarket transaction. As shown in
Cinema Ticket System
A cinema ticket system may be constructed using the bPlatform system and bScanner apparatus described above. The ticket system may, for example, consist of:
Ticket Portal: An Internet ticket sales web portal is constructed using standard web portal implementation techniques. This portal provides an option for the user to receive a chosen ticket as an SMS short message containing a bToken in the bCode format.
SMS Gateway: The bCode short message is formatted and transmitted to the end-user via an SMS messaging gateway service.
bPlatform Server: An Internet connected server computer is used to host a bContract engine and a bWallet engine. Administrative and bScanner provisioning components are also implemented as part of the server.
bScanners: bScanner devices are located at the entrance of cinemas screening films promoted by the ticket sales portal. These scanners display an “admit” message in response to the presentation of a valid bCode encoded token. Additional bScanners are located at the cinema “candy bars”, where the customer may redeem a bCode voucher.
The bContracts underlying the cinema ticket bTokens, provide bFunctions that enable the consumer to redeem a ticket for cinema entrance, redeem an optional promotional voucher at the cinema candy bar, transfer the bToken to another consumer, rebook the ticket for another time, to obtain a short description of the film being screened and the screening times and to receive an alert at a set time prior to the screening of a film.
The deployed bScanners provide the tools for the cinema or film distributor to associate individual audio (ScanTones) and visual media (ScAnimations) to be rendered on the bScanner or other suitable device as the consumer presents her bToken. Some of these media associations are more rare than others, providing the holder of a “rare” ticket an additional incentive.
Additional embodiments of movie ticket redemption are provided in
For example, in
Additionally, in this and other embodiments of the present invention, a mobile device may use text messaging to make request for information or for a bToken for goods and services. The same method may also enable the service provider to accurately interpret what the mobile user meant with the request.
Text messaging based services are prevalent in global markets. Such a service may enable mobile users to order ring-tones, check bank balances, book air-tickets, receive movie session times and use plenty of other services. However most services use the “Keyword” method for requesting and interpreting transaction requests. The keyword method requires the user to remember some sort of pre-defined keywords, in a pre-defined arbitrary syntax. The time it requires to input the information is short, but the onus of having to remember different keywords and different syntaxes across the broad range of services is ineffective, and stifling the growth of these services.
Accordingly, text messaging (e.g., SMS messaging) that utilizes a customized subset of natural language inputs that can be made common across different services, and at the same time intuitive enough for mobile users not to have to remember specific syntax, and easy enough to be input via the mobile phone, may be provided. Such a method actually allows the mobile user to type in more keystrokes corresponding to more parameters than the commonly-used Keyword method, in return for intuitiveness and ease of use.
In certain embodiments, the messaging method may include a method of using a customized subset of natural language input for requesting and interpreting transaction requests via mobile text messaging which allows users, among other things, to: use domain-specific information that is tied to a destination address number (e.g., 1999-FILM for movies) to create an overlapped area between possible meanings and possible outcomes, and use this area to limit the domain information to a minimum and restrict the Agent in Active Voice to be I (the mobile user), and the purpose of the message to be either a WH-Question or a Verb or Action. So the typical syntax becomes: <WH-Question or Verb><Domain-Specific Data Words><Stop Words><Domain-Specific Data Words><Stop Words>, etc.
The service provider can easily advertise and instruct the users of this common and intuitive format. For example: in the request “When is Bad Santa showing at Fox Studios tomorrow?”, “When” is the WH-Question, “Bad Santa”, “Fox Studio” and “Tomorrow” are Domain-Specific Data Words that the method will recognize, and “Is” and “At” are Stop-Words that the method may be configured to ignore.
One difference between this method and a general NLP (Natural Language Processing) is that this does not need to understand the meaning or semantics of the sentence. It is using NLP syntax as an easy way for mobile users to remember how to request a bToken. The interpretation aspect of this method is actually using a “Recursive Best-Match” matching algorithm to predict the intended meaning.
Specifically, the method first finds the action word, which is either a WH-Question or Verb. This is almost always in the beginning of the sentence, with the exception that certain stop words might stand in the way and need to be eliminated, e.g. “I like to”
With regards to “Recursive Best-Match”, specifically, best-match uses different matching algorithms to match domain-specific lexicon words to the Domain-Specific Data Words in the sentence, including Exact, SoundEx (and SoundEx variants), Mobile Phone Keypad Mapping, and Starts-Of, Contains and Contained-In varieties of Partial Matching.” At each input there might be matches to multiple Domain-Specific Data Words, which are recursively evaluated within the invention to get the set of possible matches to the input. The method may prescribe a specific preference order to the possible matches to determine the best match (e.g., use this order “Exact, 2-way Part of Word, SoundEx, Phone Keypad Mapping). The method may also use relationship between the Domain-Specific Data Words to further determine the best match (e.g., “Syd” and “Mel” will probably indicate that “Mel” is Melbourne and not Melon, in certain contexts).
The method may further be configured to avoid having to use complex NLP techniques such as Stemming, Statistical Parsing, Tagging, etc. since the method described herein uses keyword-matching techniques to natural language input to deliver a transaction request medium via mobile text messaging, and the method may also avoid dealing with complex natural language elements, including but not limited to Abstract nouns, Adjectives, Adverbs, Pronouns, Auxiliary Verbs, Conjunctions, Disambiguation, Grammar, etc, all because of Domain-restriction and Keyword-Matching.
Further examples of requests may include, but are obviously not limited to, “Check my savings accounts balance”, “Fly from Syd to Mel on 3Sep to 6Sep”, “When is JQ123 arriving”, “Where can I see Bad Santa”, “Order super supreme meal with Pepsi and 4 chicken wings”, “Book Bad Santa at Fox today at 2:30 for two”,
According to additional features of this methods, a matching method Exact, where words containing the same sequence letters are matched, ignore casing and punctuation, may be implemented or a matching method, “2-Way Part of Word”, where word contain a combination of three varieties of Partial Matching may also be implemented. Examples of such features may include, but are not limited to:
(Input) Start-Of (domain-word), e.g. “Hell” Start-Of “Bellboy”=match
(Input) Contains (domain-word), e.g. “BadSanta” Contains “Bad”=match
(Input) Part-Of (domain-word), e.g. “boy” Part-Of “Hellboy”
This may also give weight to the length of the partial match (e.g., The match “Hellboy” Starts-With “H” is not a strong match). Additionally, this matching method may be configured to catch concatenation errors (when words that should be concatenated are not, and words that should not be concatenated are)
In certain embodiments, a matching method, “Soundex” that uses the commonly known SoundEx matching algorithm as a component of the overall matching method may be utilized. Additionally, in certain embodiments, a matching method, “Phone Keyword Matching”, which maps alphabets into the numeric equivalents on the dialing pad of phones may be utilized, so, for example,
QZ maps to 1;
ABC maps to 2;
DEF maps to 3;
GHI maps to 4;
JKL maps to 5;
MNO maps to 6;
PRS maps to 7;
TUV maps to 8; and
WXY maps to 9.
Accordingly, Bad Santa would map to 22372682. If the mobile user accidentally typed “Baf Santa”, which is a common mistake for phone-typing when the Predictive Text is Off (d became an f because of the same key), or “Ace Santa” which is a common mistake for phone-typing when the Predictive Text is On, both “Baf Santa” and “Ace Santa” still map to 22372682, which will return a match.
In additional embodiments, a matching method that uses a pre-defined domain-specific logical lexicon to return a match, e.g., “Moore Park” as a suburb, “2032” as a postcode will both match to “Fox Studios” as the name of the cinema.
Additionally, in certain embodiments, a method of defining properties for items in a lexicon to enhance matching and parsing performance may be provides so that, for example, the following features could also be provided:
(1) Stop-Word part of Domain data—in the case where a Stop-Word is also a Domain-Specific Data Word, then it is matched recursively to both options, and the best match is then chosen; (2) Restricted Matching Method. “LAX”—Only return a match with the “Exact” method, and not the other 3 matching methods; (3) Matching Priority so that “Tomorrow” in “The Day After Tomorrow” is of a higher priority than “Tomorrow” as a date; and (4) Default Meaning such that these are the words that are assumed if it was not found across a concept, e.g., “Today” is assumed for movie session times if not given, “1” is assumed for number of passengers for a booking if not supplied, etc.
A method of expanding the Domain-Specific Data Words may also be provided to cover a wider area than only those where the service provides data such as:
If a match was previously valid, and is not longer valid, i.e., the status has changed over time, rather than returning an invalid match, return with user-friendly information, e.g., “Sorry that movie is no longer showing at this cinema”;
If a match has valid individual Domain-Specific Data Words, but does not have an overall match, return with user-friendly information, e.g., “Sorry there is no direct flight from Sydney to Brisbane”; or
If a match requires additional information to complete a match, and contain partial matching, return with user-friendly information, e.g., “Can you confirm the quantity of chicken wings you require?”
Additional features of this SMS (or more generally text) messaging should be apparent to a person of ordinary skill in the art and it should also be obvious that this feature could be used in other areas outside of the present invention or in other aspects of the present invention.
In another embodiment, a method of profiling and associating data using keyword indices may be provided. In certain embodiments, the method may be provided between people who would like to meet, transact or just socialize. For example, profile description of one market participant in words (e.g., “30 year old accounting professional. Enjoys kayaking and skiing”); profile description of a member's desired connection in words (e.g., “Seeking new role in Commercial Accounting”); record of communication with proposed connections with counterparties such as an employer or a friend, including its responses to initial bContract negotiation phase, and participant to participant direct communication such as email or instant messaging; record of communication, bContract negotiations, in-progress and complete transactions with all participants of the bMarket; all other types of content that the bMarket has access to about its participants, whether they are through interaction within bMarket human and machine user interfaces, or external (Blogs, Ebay, other electronic markets, or any other publicly available information source); and gathering feedback periodically about how good the bMarket matched market participants to each other, about how bContracts and relationships between market participants evolved, for the purposes of optimizing it's performance.
In embodiments, the method may then index all of the text content pertinent to complete or incomplete bContracts, and create a dictionary of important words and terms that belong to the particular bMarket participant or bIntermediary. The method may be a unique method that profiles any information such as people, contracts, parties in contracts, buyers & sellers, products & services and transactions by keywords. See, for example,
A method of assessing the potential suitability of proposed connections between items in the bMarket (item being parties, products, services, bContracts & bOffers, etc.), and to analyze the results and continually improve the connection proposal and matching process, using a unique rating system for the keyword-index dictionaries of bContracts and bMarket participants including bIntermediaries may be provided. This will allow the bMarket itself, as well as participants and bIntermediaries to propose connections between parties for trade within the bMarket. For example, in the context of bMarket participants seeking to trade, keyword matching may be done by matching a participant's required match keywords in its dictionary, whether it'd be a “desired connection” or just keyword about itself, with the potentially suitable proposed connection. For example:
Participant A may have keywords AAA, BBB, CCC, EEE, FFF
Participant B may have keywords AAA, MMM, NNN, QQQ, RRR
Participant C may have keywords BBB, CCC, EEE, QQQ, ZZZ
Then a Participant A-Participant C match would return a higher “affinity” score between them, and that connection would rank ahead of Participant A-Participant B and Participant B-Participant C. Additionally, more intelligent algorithms are detailed below.
The simplistic model above assumes that the keywords supplied by the participant itself, whether through their advertised information, or through their proposed bContract offers, are genuine and deemed correct and useful by other participants. However, verification of content by the rest of the bMarket may introduce a scoring system for those keywords to measure credibility of a bMarket participant. The content may be verified market wide to reduce the chance of the bMarket or bIntermediary making bad matches because of statistical fluctuations in small sample sets. In the above example, if after Participant-A and Participant C interacted, it turns out that the proposed connection was successful, i.e. a completed bContract transaction has taken place, then the following may happen to the keywords:
For Participant A, Keyword BBB, CCC and EEE, which are the overlap keywords used to determine the proposed connection, might receive positive scoring.
For Participant B, Keyword BBB, CCC and EEE might also receive the same positive scoring.
If, however, the connection was only deemed successful by Participant A, then only Participant B might be receiving the scoring, and vice versa.
The score could, in certain embodiments, be further qualified by the extent of endorsement from the approving party. For instance, it could be divided into:
“Yes, I would like to trade with Participant B” and
“Yes, I will endorse Person B for its trading credibility” This can, in certain embodiments, create different score levels for fine-tuning of the scoring system. For example, applying mass feedback to participant-specific keywords, which might be used by Internet search engines for websites, e.g. Google Page-Rank, and Internet Social Networks, e.g. LinkedIn Endorsements, as a way to use the general population to perform a level of due diligence on the credibility of the advertised content about a participant and its trading records within the bMarket or otherwise, might allow that feedback to become useful in identifying the most relevant matches for users. Additionally, the mass-feedback process may be applied to keywords that belong to individual people, to validate those keywords about the individual, in a background process that is not known to the participants, and then used to create adaptive intelligent by the bMarket to perform progressively better matching, all in the background.
In embodiments, the algorithm may use the amount of endorsed keywords as a sign of credible context-specific content about persons. A person might profess to be tall, a successful entrepreneur and a supplier of accurate stock predictions. But if he's actually short, knows nothing about stocks but a successful entrepreneur in medical science, then the method, with the help of other members, will find that out using the algorithm. This algorithm, when applied generically, may seek and extract credible information about bMarket participants rapidly and precisely, and then use that information in a context-specific manner to propose the most appropriate connections between participants for bMarket trading. In certain embodiments, the keyword dictionary may be formed from a variety of data sources about the persons and is therefore extremely powerful. From the participant's personal information, to trading history, to trading credibility, to access to other participants and bIntermediaries, to knowledge, to professional history, to political opinion, to hobbies, technology skills, product knowledge, etc.
Additionally, the method leaves open the ability for human and organizational users, in addition to just the bMarket matching engine itself, to perform searches for participants, intermediaries and bContract offers using this data, even though those features may never be implemented commercially for privacy reasons. This precise catalogue of people, and intimate information about these people, may be best inaccessible by external entities to the bMarket.
Additional Scoring Considerations may also be provided in certain embodiments. Additional scoring considerations may include, but are not limited to:
(1) Negative scoring (devaluing Keywords based on unsuccessful matches).
(2) Inter Keyword Linkages (Consider Participant A's keywords of “Panoramic Views, High Class Restaurant, Exclusive Bar”. If High Class Restaurant receives a match, then create Inter Keyword Linkage records between High Class Restaurant and Panoramic Views and High Class Restaurant and Exclusive Bar, even though there is no direct match. When the adaptive engine apply regressive analysis on those, it may find that certain Inter-Keyword Linkages will contribute to greater connection success, i.e. “Exclusive Bar” and “High Class Restaurant” will return a “weak” match, creating a successful match between two otherwise no-match persons. However, since this is applied generically, this could lead to the bMarket making propositions that tall people might be better at business, etc, when it may be statistically spurious. This means that, in certain embodiments, this scoring consideration should only be considered once a large sample size is obtained or periodically reviewed by a human or artificially intelligent expert.
(3) Different endorsement levels, as explained earlier
(4) Frequency of word
(5) Where is the word found? (Apply different ratings to Completed bContracts, Peer credibility feedback, Advertised Profile, Web Blog, Email Messages, etc)
(6) Any other matching criteria that the bMarket will discover from continual data mining of the bPlatform database and adaptive reasoning that is statistically significant
Additionally, in certain embodiments, mandatory and negative keywords may be provided. Within the criteria definition process by each member, i.e. what they are seeking, they may be allowed to specify Mandatory Keyword criteria, i.e. keywords that must be present in the target within a specific context, e.g. for provision of a therapeutic massage service, the provider must live in Sydney, Australia, or negative keyword, e.g. smoker is not acceptable under any circumstance. These criteria may, in certain embodiments, be best selected as pull-down menu items as the system can control the format of the precise text so not to have confusion, for instance: “Been to Australia” and “Live in Australia” cannot be mixed up with a separation of keywords. So the bMarket can use [Live In Australia] as a delimited keyword for residence; Non-Smoker might also return “Smoker” so in this case, space delimiters before and after Smoker are required to correctly match these; and the multi-word indices will also assist in eliminating these logical problems within the algorithm
Overall affinity score and matching process may also be provided in certain embodiments. For example, using the matching basis above, there is a total of (n)*(n−1) potential connections recommendations by the bMarket from a period-to-period basis where (n) is the total number of participants in the bMarket. In this case, the Engine may use the information from each participant about how many maximum proposed connections it likes to receive on a period-to-period basis, then derive the highest affinity-scored pairs for each member, where the affinity score is the highest keyword overlap between 2 persons, adjusted by the credibility score. Then the engine may propose connections and bContract offer negotiations between participants, and then allow the negotiations to progress from there, and then after a time period, collect feedback from the members, and then file and analyse the information, to apply this adaptive intelligence repeatedly.
Another feature, the may be present in certain embodiments, is the second-degree and third-degree affinity. In this process proposed connections between a participant, say Participant A, with other participants that have high affinity scores with people that are one, two, or more degrees away from Participant A via existing proposed connections may be created, e.g., Participant A is connected to Participant B and Participant C. Participant C is connected to Participant D. So second-degree Affinity means that Participant A will be proposed to connect with High-Affinity prospects for Participant B and Participant C, and third-degree Affinity means that Participant A will be proposed to connect with High-Affinity prospects for Participant D. This method is a commonly used method in social networking sites such as LinkedIn. In this present invention, this method is used to make proposed connections to allow them to perform trade and create complete bContracts between them.
Second-degree Affinity may be useful for Like-Attract aggregation (Buyer and seller groups). So if Participant A works at the Docks, and Participant B also work at the Docks, then second-degree affinity makes sense because they are “Likes” and should be linked to more “Likes” to create a union of Dock Workers to negotiate better trades for themselves against shipping companies.
Third-degree Affinity is useful for Opposite-Attract aggregation (Male-Female Dating, Entrepreneur and Venture Funds, Jobs and Seekers, etc). So if Male A is linked to Female B, who is in turned linked to Male C, then Male A being linked to Females with high Affinity with Male C may make sense. Likewise with Entrepreneur and Venture Funds, Jobs and Seekers, etc. Second-degree Affinity and Third-degree Affinity commonly take place in real-life social networking such as networking functions. The present invention performs these electronically and in real-time, and additionally provide an environment for actual trading and execution of bContracts.
Although this example is used for connection between humans in a social situations, this word-based affinity information and determination method can be used to determine the associative relationship between items of the bMarket for the benefit of the machine or human user performing the searching, browsing or subscription of bContract offer data in the market or in any other part of the present invention individually or in combination with other features.
Retail Voucher System
A retail voucher system may be a component of the above cinema ticket system. The retail voucher system may also be deployed as a stand-alone system providing retail voucher token issuing, redemption and associated services for retail merchants.
The retail voucher system may employ a bScanner with an optional second screen facing service staff to provide a list of voucher scans to be fulfilled. The retail staff members may be issued with bTokens encoded as a bCodes for administrative operations, such as positive/negative acknowledgement of a voucher fulfillment, and to indicate availability/unavailability of items being offered. The staff bCodes may be printed on laminated cards.
Game System
Computer games played by consumers on personal computers, video game consoles, portable game consoles and cellular phones are a popular form of entertainment. Vendors of computer games wish to provide incentives for consumers to buy the games and pay online game subscriptions. Vendors of consumer products and services often promote their products, service and brand by paying for advertising placements within consumer media, such as computer games.
In certain embodiments, a bCode game system may provide a reward to the game player, and at the same time the opportunity for a consumer-products company to promote a product and brand.
The game system embodiment can be readily generalized to issue prizes, vouchers or other bTokens in the course of other activities, such as Internet web browsing, orienteering or other sports activity, location based services offered on cellular handsets and so on.
bMarket System
Tickets, vouchers, keys and other bTokens may be transferred and traded by providing the appropriate functionality as part of the underlying bContracts. A transfer may duplicate a bToken or revoke an existing bToken and issue a fresh bToken to the new owner.
Often transfer of ownership events may require approval or acknowledgement by multiple parties. bTokens that provide an acknowledge bFunction may be employed for such purposes.
Typically bContracts with appreciable value will implement a “valuation” bFunction, which returns a monetary value from the point of view of the party holding the requesting bToken. In the embodiments of a contractual promise, the value returned for the beneficiary may be positive, whereas the value for the promisor may be negative. An entire bWallet or collection of bWallets may be valued by aggregating the valuations of all constituent bTokens.
In addition to the above object-level trading functionality, more powerful electronic trading services can be constructed using the meta-bContract technology described above. Meta-contracts enable trading in sell-side and buy-side offers, composite contracts and other derivatives. As examples of buy-side offers and derivatives: Tender for services on given terms (e.g. I want a $7 movie ticket for 7 pm); Tender for services with variable terms (e.g., I want movie tickets); Derivatives, including futures, options, short, forward, cap, ratchets and so on; Title to property and assets; Title to intellectual property; Agency/power of attorney; and voting.
Another bMarket embodiment architecture is shown in
The object-bContracts follow a lifecycle, starting as bContract templates, which are instantiated by meta-bFunctions to become offers. Offers are converted into completed bContracts by way of “accept” meta-level bFunctions. Optionally additional functions that implement other aspects of deal negotiation may be implemented. Optionally completed transferable contracts may be converted back into offers individually or as bundled offers.
The bMarket is a new way of constructing an electronic marketplace that is superior to existing electronic markets in terms of reach, speed, breadth of products and services, mobility and efficiency.
As discussed above, the present invention relates to a new platform for hyper-efficient digital/electronic commerce, utilizing real-time capabilities afforded by mobile portable devices. The invention deals with a number of novel and innovative components, that separately and in combination, enables a novel real-time mobile commerce platform based on transmission of bit data across enabling devices and machines. Details of each of these components was provided above and is summarized below.
The bDataFormat is a collection of standard data formats for the transmission of bit data to enable real-time digital trade across a diverse number of devices and machines (e.g., bDevices and bMachines). bDataFormat may be a superset of independent data formats including, but not limited to: i) bCode data format ii) Normal numeric representation, with or without checksums and redundancy iii) 1-dimensional barcodes, 2-dimensional barcodes, and 3-dimensional barcodes, including holographic and 3-D graphical, numeric or textual representations iv) RFID identification numbers v) other hardware-based identification numbers for radio frequency transmissions (Bluetooth) and vi) waveform representation (Audio, Magnetic, Infrared or any representation using the Electromagnetic wave spectrum).
Backwards and Forwards compatibility of the bDataFormat for the existence of a collection of data formats may enable real-time translation between those formats for integration into legacy and future infrastructure that do not support one or more of the formats listed e.g., existing point-of-sale scanners may recognize 1-dimensional barcodes only, and the existence of this bDataFormat class, will enable the same bToken to be successfully recognized for function invocation.
In another example, a mobile device that supports RFID transmission may receive a bToken in bCode data format. Upon recognition of the bCode and the RFID capability, the device may then issue a pull request to a central server, after receipt of the bCode bToken may push to acquire additional metadata for an RED presentation of the bToken to an RFID-enabled scanner. The bDataFormat collection also enables this type of translation to take place to ensure backwards and forwards compatibility.
In a further example, a user with a bToken that is in bCode or numeric representation may want to present a bToken to a remote merchant that do not have any fixed line or mobile internet capability. The user then simply reads the bToken over the phone to the merchant, and the merchant will manually type in or handwrite the information into its own system. In this instance, the bDataFormat class allows translation into audio waveform presentation for successful invocation.
In-line code recognition allows certain text-based formats such as bCode and numeric presentation to be incorporated in-line in paragraph text. For example, “Do you consent to the transfer of =AMMKJ=MKL2P=to Mr. Joe Smith?” or “Your ticket number is 01293090”. The nature of these bDataFormat sub-classes allow for recognition and invocation of the bTokens even within paragraph text, when optically scanned or when read by humans, using pattern and text recognition techniques.
In-pattern code recognition allows certain graphical-based formats such as 1-D, 2-D and 3-D barcodes to be incorporated into other graphical elements such as pictures, art and photos, and can still be recognized as a bToken electronically using various pattern recognition techniques.
In-waveform code recognition allows certain waveform-based formats such as audio and electromagnetic, to be incorporated into a larger waveform such as human speech and radio broadcast, and can still be recognized as a bToken electronically using pattern recognition techniques.
The bCode, discussed above is a particular bDataFormat that resolves interoperability issues between the 2 billion, and growing, existing mobile devices in the market.
As covered above, the bCode is a character-based data format that uses the particular patterns of a string of alphanumeric characters, in English or other languages, to represent bit-based data.
The bCode is a unique format that is easily transmitted across analog and digital channels, using translation or native form: It can be optically scanned from the screen of a displaying device with high reliability and data redundancy (e.g. Mobile phone, Game console, Notebook computer) and can also be digitally scanned using radio frequencies such as RFID, Bluetooth and Infrared. The bCode can be read by a human, and spoken to another over voice. It can also be ready by a human, and typed into a keypad. This feature overcomes the limitations of graphical barcodes. The bCode format enables reliable and efficiency optical scanning, by using features of text-based characters to allow an optical scanning device to recognize the code, its orientation, and isolation from its surroundings, using one or more of the following techniques: i) optical character recognition (OCR). Use OCR techniques to identify the symbols displayed, and once they are identified, translate the symbols to their underlying bit value. These can be any symbols that are displayed on the devices, or pattern of symbols or dots that can be recognized for data encoding purposes; ii) marker characters (e.g., Using an equal “=” sign to mark various parts of the bCode; iii) directional patterns (e.g., Use a directional pattern in any of the axis to recognize orientation and location of the code, such as “B will always precede X in the y-axis”); iv) other geometric methods such as frequency of symbols, symbol groups, line segments, symbol sequences, symbol differentials, constellation symbol maps; and v) directional data encoding (e.g., Use a directional pattern in any of the axis to encode data, such as “The distance between a certain angled strokes in the x-axis is used to encode bit-based data. So characters are chosen on that basis to represent code).
The bCode can use preceding, succeeding or surrounding text to identify rotational orientation of the code. If the bCode contains header text “bCode Ticket”, that additional information can be used to find out the exact direction of the text, or give the scanning apparatus additional information about the underlying bCode, such as seat assignment for a stadium ticket, as a cross-check to the server held content. In addition, if this requirement is built into an algorithm or chipset in the apparatus, it can be used to prevent counterfeit bCode tickets from being issued without the authorized brand that will be attached to the bCode. If “Company X” is a pre-requisite in the decoding algorithm, then it's difficult for a rogue provider to issue their own “Company Rogue” bCodes with “Company Rogue” headers, as they could be prevented from working.
The bCode can use a range of techniques to customize and optimize data encoding techniques for specific channels. For example, certain screen type could mean that some of the techniques in section above, optical recognizability, are more effective than others, and that the exact method parameters can be adjusted (e.g., for screens with large and same-size character layouts, directional patterns might be particularly effective) and certain font size will have characters that resemble each other to more or less extent (e.g. 5 and S), in this case, constellation type symbol mapping where data is encoded in differential between characters, and only certain sequences are logical, will help optimize encoding efficiency for particular channel characteristics (e.g., An “S” cannot possibly in the spot where the 5 was supposed to be).
A bToken enables any type of instrument or contract representation (bContract). A bToken is encoded in a bDataFormat, and is thus presentable and invocable across a diverse number of devices, machines, medium, parties and communication channels. It can be adapted to interoperate with all existing electronic representatives. A bToken is instantiated and then stored at the central authority on the server-side, as well as on the client device side to allow remote invocation. This architecture allows the creation of a universal bToken labeling and numbering system, enabling it to benefit from a diverse number of bServices. A bToken, due to its efficient and compact encoding in bDataFormat, allows itself to be stored on many different types of client devices (e.g., Mobile phones, PDAs, game console, music players, watches). Some of these devices will be smart devices, and will be able to additionally store metadata on the underlying contract (e.g., actual graphical ticket design for a bToken ticket, a photo of a physical good, contract extract for financial or other instruments). With the exception of anonymous bTokens, bToken ownership and authority information may be stored in the central authority, or delegated equivalent, so that upon each invocation, proper authority can be checked to ensure security of transactions.
A bContract, unlike the syntactic and unstructured nature of traditional contracts, enable its content and terms to be labeled, structured, categorized and valued in systematic ways, and allows it to be machine-sorted, processed, interpreted, valued, analyzed and marketed.
Fields of the bContract can be dynamically changed if the terms of the contract allows. Its dynamic nature, unlike static electronic or paper contracts, allow changes to be made in real-time. This is a key characteristic of a bContract that enables it to operate in real-time markets. The bContract contains persistent state of performance and contract statuses—the most current status of each aspect of a bContract is stored as persistent states within the bContract itself. This enables the bContract to be traded in real-time, because there are generally no externalities that will affect its status and value. This feature, combined with the executed program code, further enables bContracts to be self-policing and self-representing. Functions within bContracts can be called upon for execution by presentation of bTokens, instead of the cumbersome process of manual external performances and policing in ordinary contracts. A bToken, which is coded in bDataFormats, can be presented to a bContract through a variety of medium, to invoke functions that the bContract is pre-defined to perform. The bContract generally contains executable program code that can be automatically executed to perform operations in the contract. Traditional contracts require external functions and actions to happen, in order for compliance with the contract. This means that there are non-real-time elements which in turns means that it cannot execute and operate in real-time. bContracts may have the additional capability of having the functions locally defined within the contract, so that the bContract can make a decision to directly and automatically execute those as program code. The program code can be in scripting language or variants, and can be integrated with external systems for performances outside the host system of the bContract Through valuation services, bContracts can be summated to give individual and aggregate book values and market values, therefore easily return net-worth of its controlling entities and parties. The deliverables, when delivered, performed or operated on, such as cancellation and transfer, can give the flow value (profit and loss, change in net-worth) of its controlling entities and parties.
With these attributes, bContracts can deliver functions that paper, or static-electronic counterparts cannot currently deliver within reasonable timeframes. As a result bContracts can help deliver real-time digital trade.
bContracts can optionally contain a resident constitution, which enables it to be self-policing and self-representing. This also enables it to become an independent entity that parties can rely on for the most efficient execution of functions. Generally, bContracts are functionally more broad than what a conventional contract is capable of A bContract is an instrument that prescribes future functional performances, these performances could include physical acts, exchanges, recitals of fact, delivery of services, production and presentation of physical goods, transfer of titles, creation of intellectual property, discovery of information, completion of projection tasks, teaching to actions, etc.
bContracts can be partially or fully completed. Incomplete contracts (some of which fall under the conventional interpretation of “Offers”) are also supported by bContracts. In some cultures (such as Korea), the meaning of “contract” is quite different to the western world, in the sense that any signed or executed contract is still a running document of prescribed future functional performances. This notion blurs the line between Offer, Contract and Performance, as it is essentially a single object at different points in time. bContracts supports all of these states
Existing non-digital and e-commerce markets only allow trading of near-complete or complete contracts, e.g., financial instruments that are traded are typically contracts that have fixed parameters. There is no efficient market for the trade of incomplete contracts. bContracts, on the other hand, can be traded even in incomplete form. bContract due to its marked-up, machine-readable and dynamic format, provide markets with structured information about itself, enabling the market to objectively value it, and allow it to be traded.
bTemplates are types of bContracts that are used as reference designs of bContracts to enable rapid instantiation of bContracts. bTemplates may be manipulated by meta-bContracts. bTemplates may contain one or more of the following types of information: i) terms template, ii) design information, iii) teaching, iv) project and future actions plan, v) methods, vi) system design, vii) apparatus design, viii) schematics, ix) business plan, x) program code, and xi) constitution. bTemplates can be selected from a library, subject to access levels by the user, in order to instantiate bContracts without having to create each of the bContract components from scratch and bTemplates may contain important synthesis data for productivity and economic output by the associated bContract entities.
bTemplates can carry aliases that enables parties to quickly identify the underlying terms and design information. For example, two parties that would like to enter a Non-Disclosure-Agreement (NDA), can ask each other whether they are happy to comply to the “USNDA1008” bTemplate.
bDevices are client devices that contain bTokens that are acting as Transaction Artifacts to invoke bContract operations. Through the innovations from bDataFormats and bCodes, bDevices operate on a single common platform, and in addition provide backwards and forwards compatibility into existing systems to maintain a single interoperable platform for digital trade. This resolves interoperability issue of traditional Transaction Artifacts. Exemplary device include, but are not limited to, cellular phones, PDAs, mobile game consoles, smartcards that have on-board processor and user interface music and multimedia players and notebook and portable computers;
bMachines are machines that act as either an electronic representative and/or a performer of bContract functions. These machines provide user interface and/or execution mechanism and may provide persistent memory to hold part or whole of bContracts. These can be ticket scanner plus turnstiles, point-of-sale terminals, multi-purpose kiosks, networked kitchen appliances, computer servers, etc. These resolve the interoperability problems encountered by traditional electronic representatives by responding to common invocation capabilities such as bTokens.
bNetworks are the physical communication networks that are created to enable presentation and communication of bTokens. These are the network backbones that support the existence and operation of bMarkets (see, for example,
The nature of bContracts allow the creation of bMarkets, which is a digital and dynamic market for trade of all goods and services. The machine-marked up and persistent state nature of bContracts enable real-time complete information access for the status and properties for all goods and services, enabling market mechanisms such as valuation and agencies to function. Traditional non-digital and e-commerce markets lack bContracts, and as a result, the cost and time required for digital trade of any good or service becomes prohibitive. The construction of a bMarket is based on information transparency and real-time access by all participants, including human agents, machine agents, bDevices and bMachines. This resolves traditional time and cost efficiencies, and more importantly, the problems of Reach, Common Protocol and Interoperability and Marketability of economic units. bMarkets allow proprietary entities and systems to open its internal functions and operations into the open market, create a system of hyper-efficiency. Traditional barriers such as factory doors, application programmable interfaces are eliminated. (see, for example,
As an example, a consumer may want to buy a ticket to a specific football game this weekend. This consumer can use bServices such as bSearch or bBrowse to find such a game, and then buy the ticket from the venue directly.
Alternatively, this consumer may want to issue a broader offer, using a bTemplate to create a general offer for sporting entertainment dated this Saturday, that has a mandatory requirement of admission to that match. This way, the consumer will be privy to special promotional bundles, such as Ticket plus Meal, Ticket plus Drink, better seating, or discount non-refundable tickets, and so on. These bContract offers will be released into the market, and market participants may then reply to the offer, attempt to negotiate and solicit, offer alternative bundles or divided goods, value-added services, related services.
Alternatively, the consumer may want to specify alternative terms, such as maximum price, and just the football team. This way, the bContract will be marketed accordingly, and the consumer may receive tickets to that same team at alternative venues.
As another example, an employer may need access to 200 low-skill-level man-hours to clean the garden to a venue before a Xmas event. The employer may issue bContract offers that specific the requires dates and location for the labor.
Alternatively, the employer may issue an aggregated demand, and for another economic agent or market participate to source the right people, and combine them to deliver the bContract requirements.
Alternatively, the employer may draft the bContract so that it has the flexibility to accommodate both permutations above.
An entrepreneur that has conceptualized a novel business plan may want to put that into the bMarket to seek venture capital funding. Once that party of the bContract is completed, the entrepreneur may elect to keep the bContract in the current direction, and continue to source required parties and/or resources and keep the bContract as an ongoing economic entity.
Alternatively, the bContract can be traded with other parties at any point in time. The price of the transfer can be negotiated. Alternatively it can also be externally valued by bValuation services.
Unlike physical markets, bMarkets are not restricted by geographic limitations or aggregations (e.g. a retail shop). Unlike conventional e-commerce markets (e.g. Ebay), bMarkets are not restricted by syntactic groupings.
bContracts with its mark-up data structure, as well as associative meanings (refer to bSearching for more information on associative intelligence) enables participates to simply “drop” a bContract into the bMarket for trade. bMarket mechanisms and services will then pick up the item for trade, and use associative intelligence, matching and listing bServices to find potential counterparties.
bMarketListing is based on a combination of associative and conventional syntactic groupings to allow market participants to trade in real-time, with maximum reach and marketability. It overcomes market inefficiencies that result from natural language descriptions (e.g. Google search for products) and syntactic groupings used in convention e-commerce (e.g. E-Bay) because those language structures do not enable buyer and seller to find each other easily. For example, a buyer that is listing “I want to rent a green mouse” and a seller listing “I want to rent out a green mouse” will not be automatically matched because there are no syntactic relationships between those syntactic sequences in the eyes of the e-commerce markets. bMarket and bMarketListing overcomes this by understanding those associative relationships. (Refer to bSearching for more information).
bServices are enhanced market services that are made possible by the bMarket. These are services offered by market participants such as human users, machine users, human and machine agents, bMachines and a combination of these. These services may include, but are not limited to: i) valuation services (of bContracts), ii) market makers, iii) arbitragers, iv) resellers, v) re-buyers, vi) matchers, vii) participant analysts (e.g. credibility, size, economic capabilities), viii) other analysts, ix) simulators, x) financiers, xi) advertisers and marketers, xii) contract lookup, xiii) policing, xiv) template libraries, xv) escrows, xvi) information traders, xvii) relationship traders, xviii) browsers/search, and xix) accounting services.
These functions exist in traditional commerce. However, bServices contain unique design elements that enable these functions to operate in bMarkets and bCommerce environments. In particular, they all need to be real-time enabled interoperable, be operable in markets with tremendous reach, contain electronic interfaces, and operable with bMarkets and bContracts.
One bServices is a search service that plays a key market-making function for helping bMarket participants find specific products, services, contract offers and instruments. Existing search services are syntactic and keyword only, and are very limited. The bSearch service utilizes marked up fields in bContracts as the data source, which is structured data and not just natural language descriptions. In addition, it has associative intelligence (discussed above) that can create associations between words, allowing the search service to deliver highly useful search results. For example, “LCD Screens” will be associated with “Monitors”, “Samsung”, “OLED” Which means that the search service will take into account these associations when searching through the marked up fields of the bContracts that are published into the bMarket(s).
The search service may derive its associative data from one or more of the following sources: i) Existing electronic literature (e.g., Websites, RSS feeds, IP broadcasts). So words that reside on same pages, same websites, and linked websites are scored accordingly; ii) bMarket transactions. Any exchange in a bMarket will generate associative relationships between words and content of bContracts; and iii) bSearch data. Actual search requests, browsing and selection activities will also generate associative relationships between words and content of bContracts
Using those data sources, bSearch services can then build a database of associated relationships, in terms of how many degrees each word or term or concept or category is associated with another category given the presence of context, with context meaning the presence of other word or term or concept or category in the same communication. For example, a bMarket request of “Find LCD screen components” will retrieve bContracts relating to “LCD Screens” “TFT screens” “12V Power Supply” “Video Adapters”, and not “Monitors” because “LCD screen” is only associated with those words in the presence of the context of “Components”
If a bSearch query contains domain-specific context (e.g., if the query is sent to 1999-FILM) then bSearch can utilize non-traditional-NLP techniques to make relevant matches, as discussed above with respect to requesting a bToken.
The efficiency, execution, and operation of bContracts and bServices in bMarkets is going to generate a large amount of highly structured, detailed and categorizable transaction data. bDataServices utilize the knowledge of the underlying protocols to effectively capture this data into repositories, and, in certain embodiments, make the information available to buyers and users of this information via a human and machine interfaced 0.
A bCommerceSystem is the holistic platform composed of all the bCommerce entities and components to deliver bMarket services. The bNetwork is a physical network that enables bMarket participants, including human users, machine users, bServices, bDevices, bMachines to communicate with each other using a common set of protocols. Through this communication, identities are authenticated, tokens are presented and functions can be invoked and performed, which will enable all types of bMarket services to execute. (see, for example,
Many alterations and modifications of the present invention will be comprehended by a person skilled in the art after having read the foregoing description. It is to be understood that the particular embodiments shown and described by way of illustration are in no way intended to be considered limiting. Therefore, references to details of particular embodiments are not intended to limit the scope of the claims, which in themselves recite only those features regarded as essential to the invention.
The embodiments described herein are intended to be illustrative of this invention. As will be recognized by those of ordinary skill in the art, various modifications and changes can be made to these embodiments and such variations and modifications would remain within the spirit and scope of the invention defined in the appended claims and their equivalents. Additional advantages and modifications will readily occur to those of ordinary skill in the art. Therefore, the invention in its broader aspects is not limited to the specific details and representative embodiments shown and described herein.
The present application is a continuation of U.S. Ser. No. 12/310,721, filed Mar. 5, 2009, which is the National Phase application of International Application No. PCT/AU2007/001307, filed Sep. 5, 2007, which designates the United States and was published in English and which claims the benefit of U.S. Provisional Application No. 60/842,356, filed Sep. 6, 2006, which is related to International Application PCT/AU2005/001799 entitled ELECTRONIC COMMERCE SYSTEM, METHOD AND APPARATUS, filed on Nov. 29, 2005 and published on Jun. 15, 2006 as WO 2006/060849, which claimed priority to Australian Provisional Application AU2004906982, filed on Dec. 7, 2004. Each of these applications are incorporated herein by reference in their entirety.
Number | Date | Country | |
---|---|---|---|
Parent | 12310721 | Oct 2009 | US |
Child | 13955044 | US |