public:i-700-abms-08-1:final_system
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
public:i-700-abms-08-1:final_system [2008/04/05 00:25] – ivar | public:i-700-abms-08-1:final_system [2024/04/29 13:33] (current) – external edit 127.0.0.1 | ||
---|---|---|---|
Line 47: | Line 47: | ||
* demands | * demands | ||
- | * **functions** | + | * **Functions** |
* post - Sends a message to the whiteboard. | * post - Sends a message to the whiteboard. | ||
* main - Parses the arguments sent to the Industry and calls the constructor. | * main - Parses the arguments sent to the Industry and calls the constructor. | ||
Line 86: | Line 86: | ||
The industries listen to all messages from the market of the form: carbon.quota.response, | The industries listen to all messages from the market of the form: carbon.quota.response, | ||
+ | |||
Line 105: | Line 106: | ||
* **offers** = Is a vector that stores all the offers that come to the market | * **offers** = Is a vector that stores all the offers that come to the market | ||
* **DIM** = Is used to set the dimention when initializing an array in the market class | * **DIM** = Is used to set the dimention when initializing an array in the market class | ||
- | * **removeListBid** = Stores the information of which bid is scheduled to be removed from the bids vector. | ||
- | * **removeListOffer** = Stores the information of which offer is scheduled to be removed from the offers vector. | ||
* **bought** = Is a boolean used for checking if something was bought or not. | * **bought** = Is a boolean used for checking if something was bought or not. | ||
* **sold** = Is a boolean used for checking if something was sold or not. | * **sold** = Is a boolean used for checking if something was sold or not. | ||
Line 114: | Line 113: | ||
* **Functions: | * **Functions: | ||
- | * **auctionImprove()** | + | * **auctionMatch()** = Simply does the matching for bids and offers. If the price is ok then link them. At the end calls auctionImprove |
- | * **auctionMatch()** | + | * **auctionImprove()** = This is meant to improve the current matches. If a bid has a better choice, repoints it to the nicer one. |
- | * **checkExpiration()** | + | * **checkExpiration()** |
- | * **checkOut()** | + | * **checkOut()** |
- | * **destroy()** | + | * **destroy()** |
- | * **getIndex(String)** | + | * **getIndex(String)** |
- | * **isConnected()** | + | * **isConnected()** |
* **post(type, | * **post(type, | ||
* **printVectors()** = This function prints out the information of the status of the bids and offers in the vectors | * **printVectors()** = This function prints out the information of the status of the bids and offers in the vectors | ||
* **startListening()** = This function makes the market start waiting for messages | * **startListening()** = This function makes the market start waiting for messages | ||
- | * **store(XMLElement, | + | * **store(XMLElement, |
For every bid that the market receives it stores it in the bids vector. It then checks daily if the bids have a matching offer or are expiring. If the bid is expiring it marks it in the removeListBid and then checks for the last time if it has any offers for it. If it has an offer for it it sends both the seller and the buyer a **carbon.quota.response** message saying that they have bought or sold some units and for the asking price of the offer.\\ | For every bid that the market receives it stores it in the bids vector. It then checks daily if the bids have a matching offer or are expiring. If the bid is expiring it marks it in the removeListBid and then checks for the last time if it has any offers for it. If it has an offer for it it sends both the seller and the buyer a **carbon.quota.response** message saying that they have bought or sold some units and for the asking price of the offer.\\ | ||
Line 133: | Line 132: | ||
The market can receive three kinds of messages: Two types from the Industries: **carbon.quota.bids** and **carbon.quota.offer**. It receives one kind of message from the Timer: **simulation.time**. When the market receives this type of message it starts by updating the date variable and then checks what bids and offer are expiring. | The market can receive three kinds of messages: Two types from the Industries: **carbon.quota.bids** and **carbon.quota.offer**. It receives one kind of message from the Timer: **simulation.time**. When the market receives this type of message it starts by updating the date variable and then checks what bids and offer are expiring. | ||
+ | |||
====== Timer ====== | ====== Timer ====== | ||
Line 143: | Line 143: | ||
* **aDay** | * **aDay** | ||
* **date** | * **date** | ||
- | * **mode** | + | * **mode** |
===== Timer message ===== | ===== Timer message ===== | ||
Line 170: | Line 170: | ||
This picture shows the messages how they go from the Industries to the white board and then to the market and wise versa. It also shows how the messages come from the Timer and go through the white-board to all of the modules\\ | This picture shows the messages how they go from the Industries to the white board and then to the market and wise versa. It also shows how the messages come from the Timer and go through the white-board to all of the modules\\ | ||
{{public: | {{public: | ||
+ | |||
====== psySpec ====== | ====== psySpec ====== | ||
- | The newest [[psySpec]] file has three new modules: Timer, Tester and the GUIForKristinn. The Timer module has one parameter name=" | + | The newest [[http:// |
Line 189: | Line 191: | ||
**simulation.time**\\ | **simulation.time**\\ | ||
This message is sent to the white-board and it contains the date of the simulation in milliseconds. This message makes everybody know when new day is starting. | This message is sent to the white-board and it contains the date of the simulation in milliseconds. This message makes everybody know when new day is starting. | ||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | ====== Screenshots of running system ====== | ||
+ | Below screehshots of the running system are taken to show the trend of the prices during the simulation. | ||
+ | |||
+ | The next two images refer to the bids prices in two different moments.\\ | ||
+ | {{public: | ||
+ | {{public: | ||
+ | The next two images show the trend of the offers prices.\\ | ||
+ | {{public: | ||
+ | {{public: | ||
+ | The next two screenshots are taken from market responses.\\ | ||
+ | {{public: | ||
+ | {{public: | ||
+ |
/var/www/cadia.ru.is/wiki/data/attic/public/i-700-abms-08-1/final_system.1207355104.txt.gz · Last modified: 2024/04/29 13:32 (external edit)