GithubHelp home page GithubHelp logo

curioustauseef / write-free-science-books-to-get-famous-website Goto Github PK

View Code? Open in Web Editor NEW

This project forked from ************/write-free-science-books-to-get-famous-website

0.0 1.0 0.0 35 KB

Dream: live in a world where you can learn mathematics, physics, chemistry, biology and engineering from perfect open source books made for free by people who want to get famous to get better paying jobs. This is just a wacky project idea right now, there is no prototype nor business model.

write-free-science-books-to-get-famous-website's Introduction

Write Free Science Books to Get Famous Website

Dream: live in a world where you can learn mathematics, physics, chemistry, biology and engineering for free whenever they want from perfect open source books made for free by people who want to get famous to get better paying jobs.

Desired society impact: crush the current grossly inneficient educational system, replace today's students + teachers + researchers with unified "online content creators / consumers". Gamify them, and pay the best creators so they can work it full time, until some company hires for more them since they are so provenly good.

This is just a wacky project idea right now.

Method: a crash between:

  • Stack Overflow gamification
  • GitHub-like pull requests. Not anyone can edit anything like Wikipedia madness, but you can make your own copy (fork), and a precise a suggestion.
  • Wikipedia. Imagine if you could link up-votable application examples to the useless page of a Mathematics theorem, and add you own completely different versions of articles explaining them in your own perfect manner.
  • page rank-like algorithm for user reputation, including a per-tag reputation (which user knows more about mathematics?) and content recommendation (what are the best articles about a given subject?)

Very early stage prototype(s):

Why you can't make money with this website right now:

  • society has huge inertia
  • Stack Overflow is good enough (?), even though it could be so much better

Intro

Consider a Stack-Overflow-like Q&A website:

  • there are questions and answers
  • questions have tags, e.g. programming languages like C, C++, Java
  • users have a reputation measure. If you upvote someone's question or answer, his reputation increases. You need 15 reputation to upvote someone.

But Stack Overflow's reputation system sucks because:

  • if the living ultimate god of C++ upvotes you, you get 10 reputation
  • if the first-day newb of Java upvotes you, you also get 10 reputation

We want to improve Stack Overflow's simplistic linear reputation system to determine who is the user who knows the most about a given tag.

Fundamental requirement: a Google PageRank-like algorithm (Eigenvalue based) such that:

  • everyone has one reputation per tag
  • if someone with high rep on a given tag upvotes you, you get a lot of reputation on that tag. More than you would get from someone with low reputation on that tag.

Optional but very desirable requirements:

  • users can upvote tags on a given question to say: "I agree that this question deserves this tag".

    The vote of users with higher rep on the tag should count more.

  • each time you upvote the same given person, it has less positive impact on his reputation for that tag.

    This would counter voting fraud, e.g. of close groups of friends which upvote each other a lot.

  • people can post articles, not just questions. A question is just a topic definition for an article.

Another problem this would solve: multiple site split silliness: http://meta.stackoverflow.com/questions/271989/does-it-pay-to-spin-off-sites Since there is no human moderation, only algorithms, splitting websites makes no sense.

Extra problems

Tag duplicates

How to mark tags java and Java as being duplicates without moderators?

Possible solution: everyone can mark tags as duplicate.

Once you mark tags as duplicate, if you search for one, you will see both.

Then we need some algorithms that fuzilly joins all subjects that many people said are the same.

This is one of Quora's focus: https://data.quora.com/First-Quora-Dataset-Release-Question-Pairs

Original research vs explanations

How to determine if something is "original research" or not?

E.g.: a genius discovers something and publishes it really badly explained.

Someone less intelligent comes, explains it better, and gets widely read.

Or someone who just posts a bunch of links to good sources.

Post age

Post metrics on Stack Overflow also suck: the post with most upvotes goes up and that is it.

It would be cool to give a boost to recent posts that got lots of upvotes.

They can't beat the older ones in total upvotes, but the upvote rate is a strong indicator of quality.

Even better, would be to consider how many times users view EACH post in a single page, with some JS black magic. With that, we can just use the Wilso score interval https://en.wikipedia.org/wiki/Binomial_proportion_confidence_interval#Wilson_score_interval as mentioned at: https://www.evanmiller.org/how-not-to-sort-by-average-rating.html

SO threads:

Non SO literature:

User trusts user

It would be cool for a user to say: I trust this other user on given tags / all tags.

Maybe this is required. E.g., given a real network, a bot network could make an exact copy of it, and that should have the same reputation as the real one.

Such relations make per-user score of other users / posts even more important.

Per user score of all other users

Rate how much one user likes other users based on his actions.

E.g.: someone who only upvotes C questions will give score 0 for someone with only Java questions.

Pull request disagreements

What happens if:

  • the writter of an answer dies, and someone makes a great pull request to his answer with 1M upvotes?
  • 50% of users agree with a pull request, 50% don't?

Possible solution:

  • next to each answer, have a list of forks
  • everyone can mark an answer as the "best version" or just upvote the pull requests

Testing: a difficulty

While it is possible to download all public data from Stack overflow in dumps, this algorithms would need private information like who upvoted what.

So generating meaningful test data would be a problem in itself.

Research

Software:

StackApps:

General reputation systems:

Concept maps:

Social network:

PageRank

Implementations:

Mathematical problem: make a stochastic matrix graph where each entry equals:

  • (1 / n_links) if there is a link going out
  • 0 otherwise

Now calculate the steady state of the Markov process: https://en.wikipedia.org/wiki/Markov_chain#Steady-state_analysis_and_limiting_distributions which is the same as calculating the eigenvector.

Convergence of simple interactive algorithm: stochastic link matrix M iff M is both: (TODO proof):

Proposal to use it on Stack Overflow:

PageRank tutorials and papers:

PageRank alternatives:

PageRank variants:

Algorithm possibilities

The most obvious possibility is to reduce the problem to pagerank.

If we forget tags to simplify, we could do a bipartite authors / posts graph:

  • each post and user is node in one side of the bipartite graph
  • if userN upvotes postN, add a link from userN to postN
  • link postN to it's author userN

To consider tags without weight, in addition:

  • each user is represented by one node per tag userN-tagM
  • if userN upvotes postN, add a link from userN-tagM to postN if postN is tagged with tagM
  • link from postN to each userN-tagM where userN is the autor and tagM a tag of the post

Tag hierarchy extraction

We could be able to deduce that animal includes dog, is a lot of articles tagged as

Websites with tag votes by any user

  • Flickr 2016 only photo author can add tags
  • Delicious TODO down?

Datasets

Business model

Consulting

Start with consulting for universities to get some cash flowing.

Help teachers create perfect courses.

At the same time, develop the website, and use the generated content to bootstrap it.

Choose a domain of knowledge, generate perfect courses for it, and find all teachers of the domain in the world who are teaching that and help them out.

Then expand out to other domains.

TODO: which domain of knowledge should we go for? The more precise the better.

  • maths is perfect because it "never" changes. But does not make money.
  • computer science might be good, e.g. machine learning.

Knowledge market

If enough people use it, we can let people sell courses through us, to become the YouTube of courses.

Teachers have the incentive of making open source to get more students.

Students pay when they want help to learn something.

Who to propose this to

https://catalogue.polytechnique.fr/cours.php?id=2913

http://psc.polytechnique.fr/

Ads

Possibly shared with top content producers, like Tsu.

Plus a paid option to opt out of ads.

But this is what YouTube does with videos, and it only pays for a ton of views...

write-free-science-books-to-get-famous-website's People

Contributors

cirosantilli avatar lrw04 avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.