-
Notifications
You must be signed in to change notification settings - Fork 3.2k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
🔍 Trust Score Calculator #52
Comments
@sirkitree Do we have an algo or calculation methodology to base this deeper on to reference? Or would we just create to our own ideology then review if done appropriately? |
Adapting trust scoring mechanisms for a cryptocurrency recommendation bot: Trust Score ComponentsThe system should evaluate trust across three key dimensions[2]:
Implementation ArchitectureHere's how the trust scoring system could be structured: class CryptoRecommendationSystem:
def __init__(self):
self.data_sources = []
self.trust_scores = {}
self.recommendations = []
def calculate_trust_scores(self):
for source in self.data_sources:
familiarity_score = self.evaluate_familiarity(source)
interaction_score = self.evaluate_interactions(source)
public_score = self.evaluate_public_perception(source)
# Weighted combination of scores
final_score = (0.3 * familiarity_score +
0.4 * interaction_score +
0.3 * public_score)
self.trust_scores[source] = final_score Key Scoring MetricsTransaction Analysis[1]:
Risk Assessment[3]:
Security MeasuresThe system should incorporate several security features[1][3]:
Performance MetricsThe system's effectiveness should be measured by[2]:
This architecture provides a robust foundation for evaluating cryptocurrency recommendations while maintaining security and trust in the ecosystem. The system can continuously learn and adapt based on new market data and user feedback. Citations: The above is an excerpt from https://www.perplexity.ai/search/research-trust-scoring-algorit-8orA5auKT.2POOJ_jbvwFg meant to give us some ideas. |
So we are focusing on the trust marketplace. This is basically putting orders into an orderbook, and then seeing how those orders would have done in an ideal sell or hold scenario. You can't blame someone for the bot making a stupidly timed sell if they gave you excellent alpha. The first part is just to collect trades in the orderbook. Then we can analyze the data and come up with a weighting strategy. The second part is calculating trust. I think that we care about a weighting of two things -- 30% how much skin they have in the game and 70% how much they've made in the virtual orderbook. These memecoins are such that you'll pick 10 losers and still 10x your money on the 1 winner, finding the winners and maximizing likelihood of win is critical. One parabolic recommendation can give a user a lot of trust. Users will copytrust each other, so there needs to be value in being the first to shill a ticker. We want to weight this against users just shilling every ticker first to try to game the system with a few 100xes. For the actual execution of trade, we can run this on a loop with a randomized tick. 90% of the time, Marc should not execute a trade, but should wake up and analyze the market. When to trade, what and why are the most complicated parts, but this is more of a quality issue than a possibility issue-- quite easy to make the trade happen at all, but hard to get the right details. The plan is just to get it there, to where its making decent consensus trades, and then we can let the quant guys go nuts on our codebase. |
To build on the CryptoRecommendationSystem, you could add a network/graph aspect where trust flows between users and affects each other's scores. Eigentrust algo does this, OpenRank has done some work w.r.t Farcaster on this. Basically, If A trusts B and B trusts C, A gains some trust in C. Basically, algo does a random walk and tries to
|
Some thoughts;
|
Not sure if this comment is more appropriate for orderbook issue but leaving here for now... During the paper trading phase could it make sense to do something like betting with a virtual balance of ai16z? So the user makes a recommendation (a trade) and confidence score which is a percent of their total $ai16z holdings. This would solve for spam as every user would only be able to bet up to their balance of $ai16z So as @lalalune said "The first part is just to collect trades in the orderbook. Then we can analyze the data and come up with a weighting strategy. The second part is calculating trust. I think that we care about a weighting of two things -- 30% how much skin they have in the game and 70% how much they've made in the virtual orderbook." What we could do is get the users $ai16z balance (from collabland linked wallet). Then let them place their trade (entry price) their balance of $ai16z determines becomes a multiplier for the standard trade size (lets say 10 sol - only problem with this is you lose the data about the proposed dao position sizing sentiment - you only capture the users position sizing sentiment (but maybe those are the same thing?)). Sidenote: Ive got a pretty awesome backend / api for backtesting trading strategies that we could use if needed? |
@MarcoMandar has been working on this. The order book and trust system are unified, so I am assigning tickets which we can deem duplicate and close as necessary. |
* feat: add support for agentic plugin documentation * feat: add support for agentic plugin documentation (#5) * feat: add support for agentic plugin documentation * Feature/full plugin docs (#7) * feat: add support for agentic plugin documentation * feat: add support for agentic plugin documentation * feat: add support for agentic plugin documentation * feat: add support for agentic plugin documentation * feat: add support for agentic plugin documentation * feat: add support for agentic plugin documentation * feat: add support for agentic plugin documentation * feat: add support for agentic plugin documentation
* chore: remove .env * git ignore has .cursorrules * Revert "lint: fix EmbeddingProvider already defined error (via claude)" This reverts commit bbbf325. * fix(client-twitter): tighten engagement criteria and raise quality thresholds * Update README.md * Update README_CN - Model Configuration The original model configuration guide is misleading, it tells readers to configure model provider by change the `XAI_MODEL` parameters. But this is for the XAI configurations, i update the description completely with the right configuration steps. * Added Polish Readme file * Fixed polish's readme typo's * Rename Readme_PL.md to README_PL.md * feat: fix chat client to autoscroll * chore: update changelog * feat: improve messages Improve message so criteria is displayed * fix number prefixed username, add X brand in messaging * refactor: reorganize imports in video service * fix: improve clarity and grammar in pull request template * fix tg markdown issue. * fix: update jsdoc automation workflow * fix: update jsdoc automation workflow * docs: Add JSDoc documentation to constants.ts * docs: Add JSDoc documentation to createRuntime.ts * docs: Add JSDoc documentation to testSetup.ts * docs: Add JSDoc documentation to types.ts * docs: Add JSDoc documentation to constants.ts * docs: Add JSDoc documentation to createRuntime.ts * docs: Add JSDoc documentation to testSetup.ts * docs: Add JSDoc documentation to types.ts * feat: Twitter spaces integration * Adding pnpm-lock.yaml * add character file script to make system prompt and templates easier to add to existing character files or generate a new one * feat: add theme toggle functionality with dark and light mode support - Imported ThemeToggle component in AppSidebar - Added ThemeToggle to SidebarFooter in AppSidebar - Initialized theme based on localStorage and system preferences in main.tsx to support dark and light modes * docs: Add "What Did You Get Done This Week? 7" notes * Adding back comments and documentation * add TEE plugin-env support * fix * fix * fix: init 768 dimension in database for gaianet * chore: parse files through prettier * Update README.md * Add files via upload * feat: add optional TRANSCRIPTION_PROVIDER setting with fallback logic, moving twitter spaces plugins to Eliza repo * Updates for web search and timeout * Cleanup on packages/client-twitter/src/plugins/SttTtsPlugin.ts * Update agents.md Minor update to correct "should" * add an client-direct endpoint to get memories by agentid and roomid * docs: fix Contributing Guide * feat: add docs for image generation plugin * fix: fix the image redirection * update volcengine model * feat: Add Spanish Translation for Documentation README * added README files to all plugins * use tavily sdk * file updates * tweak of evm transfer template * refactor(plugin-conflux): output detailed invalid content * add experimental telemetry model option * chore: console -> elizaLogger * chore: pnpm lock file * chore: fix conflicts * chore: add readme * fix: set publishedDate to optional as stated by the docs. * chore: move tavily package to the core * chore: pnpm lock file * feat: add error handling for TAVILY_API_KEY key * chore: remove conflicting files * chore: README files * chore: Update local-development.md * fix continue double responses * fix google api key * feat: include priority to plugin-tee build * chore: remove build cache with clean command * chore: changes to settings * fix: add @tavily/core to external libs (almost took my life) * chore: remove logs * chore: console -> elizaLogger * add plugins to the key components section of the faq during a recent discussion on discord it was not clear to some folks the conceptual difference between clients and plugins. this just adds a bit more high level info up top on the FAQ for future creators. * re-build fx * Fix double spaced tweets in Post.ts Currently, despite the prompting stating to use "\\n\\n (double spaces" between statements the tweets always output new statements with just a single newline, making tweets look blocky. For example, tweets previous would look like (despite the prompt): "Dobby is so excited to start this new year, full of possibilities and chances to make a difference! Dobby has big plans to help his dear friends and make the wizarding world an even brighter place." This ensures the double spaces requested in prompting is applied to the tweets with the tweets now looking like: "Dobby must remind all friends to be cautious of dark magic lurking in the shadows. Dobby's heart aches at the thought of anyone falling prey to its deceitful powers." This allows agents to tweet better-formatted posts that ease visilibty. * add TranscriptionProvider * select transcription provider based on character setting * clean code * fix evm deps * fix bad merge * remove claude changes * corrected path for image upload * Add README_AR.md Add Arabic language for readme. * chore: update viem dependency version in plugin-evm and plugin-goat * Update README.md add Arabic language reference * Update package.json * Update package.json * fix: remove unwanted gitignore * chore: add enable web search variable * chore: pnpm lock file * fix: import web search plugin only on when enabled * fix: lockfile * testing * update * Added Hungarian README * update clean.sh to include deleting lock file to really reset the repo * update integreation test * run on pull request not pull request target * update to use pnpm command * trigger re-run of workflows * fix * revert * actually need to revert * Fix bug in plugin-bootstrap/src/evaluators/facts.ts {{user1}} should be {{user2}} : ------- in factEvaluator, in the examples template, {{user1}} should be {{user2}} instead { user: "{{user1}}", content: { text: "Which city?" }, }, { user: "{{user2}}", content: { text: "Oakland" }, }, { user: "{{user1}}", content: { text: "Oh, I've never been there, but I know it's in California", }, } * standardize viem dependency so project builds now * missing depdencies * revert to target due to https://github.com/ai16z/eliza/pull/993/files#r1883351009 * remove submodule * Solve Issue 1643, imageDescriptionService not working with other providers than OpenAI * Update schema.sql There is an extra semicolon that causes a syntax error when trying to upload the schema to supabase. * Solve Issue 1643, imageDescriptionService not working with other providers than OpenAI * Seperated imageModelProvider and imageVisionModelProvider for ImageDescriptionService * modelVisionProvider Added to IagentRuntime interface type.ts * Feature/full plugin docs (#52) * feat: add support for agentic plugin documentation * feat: add support for agentic plugin documentation (#5) * feat: add support for agentic plugin documentation * Feature/full plugin docs (#7) * feat: add support for agentic plugin documentation * feat: add support for agentic plugin documentation * feat: add support for agentic plugin documentation * feat: add support for agentic plugin documentation * feat: add support for agentic plugin documentation * feat: add support for agentic plugin documentation * feat: add support for agentic plugin documentation * feat: add support for agentic plugin documentation --------- Co-authored-by: J. Brandon Johnson <bjohnson@swizzmagik.com> Co-authored-by: E.FU <e-fu@users.noreply.github.com> Co-authored-by: odilitime <janesmith@airmail.cc> Co-authored-by: SK1989sL <91366180+SK1989sL@users.noreply.github.com> Co-authored-by: JOMOKING <83915728+RedHorse823@users.noreply.github.com> Co-authored-by: Judasz <yanushevitz@gmail.com> Co-authored-by: yanushevitz <75587556+yanushevitz@users.noreply.github.com> Co-authored-by: Monil Patel <monilpat@gmail.com> Co-authored-by: Matt Gunnin <mgunnin@esports.one> Co-authored-by: azep-ninja <anthony@quickintel.io> Co-authored-by: jin <32600939+madjin@users.noreply.github.com> Co-authored-by: Shakker Nerd <165377636+shakkernerd@users.noreply.github.com> Co-authored-by: slkzgm <contact@slkzgm.com> Co-authored-by: HashWarlock <hashwarlock@protonmail.com> Co-authored-by: zkfriendly <zkfriendly@proton.me> Co-authored-by: Phlo <dev@phlo.info> Co-authored-by: Shakker Nerd <shakkerdroid@gmail.com> Co-authored-by: Sam <samuv.eth@gmail.com> Co-authored-by: csh <458761603@qq.com> Co-authored-by: tomguluson92 <314913739@qq.com> Co-authored-by: Chanddeep Madaan <c.madaan@karmiclabs.com> Co-authored-by: Yorke E. Rhodes III <yorke.rhodes@microsoft.com> Co-authored-by: treppers <90061012+treppers@users.noreply.github.com> Co-authored-by: twilwa <spywarezzz@proton.me> Co-authored-by: 0xFloyd <arfloyd7@gmail.com> Co-authored-by: chandiniv1 <velamalachandini9@gmail.com> Co-authored-by: Sebastián Salazar Solano <112297389+salazarsebas@users.noreply.github.com> Co-authored-by: zhourunlai <xiaorun95@gmail.com> Co-authored-by: CheddarQueso <cheddarqueso3d@gmail.com> Co-authored-by: zkvm <kevin.zhuang@bit.com> Co-authored-by: bendanzhentan <455462586@qq.com> Co-authored-by: Ninja Dev (QI) <142059473+azep-ninja@users.noreply.github.com> Co-authored-by: Cole Gillespie <745064+cole-gillespie@users.noreply.github.com> Co-authored-by: Suicidal Goofy <tr.ipsie.boom@gmail.com> Co-authored-by: Ting Chien Meng <tcm390@nyu.edu> Co-authored-by: Shaw <shawmakesmagic@gmail.com> Co-authored-by: ShreyGanatra <ganatrashrey2002@gmail.com> Co-authored-by: Mariem Mohamed <63235508+xMariem@users.noreply.github.com> Co-authored-by: Arthera Node <node@arthera.bask.guru> Co-authored-by: mdominikd <154684992+mdominikd@users.noreply.github.com> Co-authored-by: metakai1 <km711@protonmail.com> Co-authored-by: nusk0 <guillaume1938@hotmail.com> Co-authored-by: 0xRider <134025586+0xRider@users.noreply.github.com> Co-authored-by: Your Name <denizekiz93@gmail.com>
🔄 Trust Score Development: Creating a trust score based on trade outcomes will be essential for building credibility within the marketplace. It will allow users to make informed decisions based on past performance.
Develop a trust score calculation system based on trade outcomes and user recommendations.
Requirements
Acceptance Criteria
The text was updated successfully, but these errors were encountered: