Skip to content

A project which examines the prevalence of fake news in light of communication breakthroughs made possible by the rise of social networking sites.

Notifications You must be signed in to change notification settings

agyeyamishra27/fake-news-detection-using-machine-learning

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

19 Commits
 
 
 
 
 
 

Repository files navigation

Fake News Detection Using Machine Learning

This is a course project done for Department of Computer Engineering, Delhi Technological University (formerly, Delhi College of Engineering) for a course in Machine Learning (Course Code - CO327) for the Fall Semester 2021.


Introduction

  • Fake news existed way before social media but was multifold when social media was introduced.
  • Fake news is a piece of news designed to spread hoaxes, propaganda, and disinformation deliberately.
  • Fake news stories are usually spread through social media sites like Facebook, Twitter, etc.
  • People are profiting by publishing fake news online.
  • In general, the goal is profiting through clickbaits.
  • Such clickbaits lure users and entice curiosity with flashy headlines or designs to click links to increase advertisement revenues.

Some Major Problems

Some of the major problems related to fake news that are generally faced by people are:

  1. By clicking on a clickbait, users are led to a page that contains false information.
  2. Fake news influences people’s perceptions.
  3. The risk of fake news has become a global problem that even major tech companies like Facebook and Google are struggling to solve. It can be difficult to determine whether a text is factual without additional context and human judgement.

Purpose

  • This project aims to develop a method for detecting and classifying news stories using Natural Language Processing.
  • The main goal is to identify fake news, which is a classic text classification issue.
  • We gathered our data, pre-processed the text, and translated our articles into supervised model features.
  • Our goal is to develop a model that classifies a given news article as either fake or true.

Delimitations

There are two delimitations associated with our project:

  1. Our system does not guarantee 100% accuracy.
  2. The system is unable to test data that is unrelated to the training database.

Types of Fake News

There are basically two types of fake news:

  1. Visual based type: Visual based are mainly photoshopped images, and videos which are posted on various social media platforms.
  2. Linguistic based type: Linguistic based are mainly the manipulation of text and string content. These issues are with blogs, news, and emails.

Natural Language Processing (NLP)

  • There have been attempts made to use Artificial Intelligence techniques specifically machine learning/deep learning technique and natural language processing (NLP), to automate the process of detecting fake news and stopping it from spreading any further.
  • It can be possible to teach a computer how to read and differentiate between real news and fake news using Natural Language Processing (NLP).
  • The building blocks of our project are Dataset and Machine Learning.

Abou the Dataset

  1. It has the following attributes:
  • id: unique id for a news article
  • title: the title of a news article
  • author: author of the news article
  • text: the text of the article; could be incomplete
  • label: a label that marks the article as potentially unreliable
  1. The size of the dataset is 7796 x 4, which means it has 7796 rows and 4 columns.
  2. The dataset is published on Kaggle for research and educational purposes.
  3. We have 80% of data as training data and 20% data as testing data.


Workflow

The steps involved in the workflow of our project are:

  1. First, we import the necessary libraries required for our project.
  2. Then, we try to read the data into a DataFrame and get the shape of the data and the first 5 records.
  3. After this, we get the labels from the DataFrame.
  4. Now, we split our dataset into training and testing sets. The training set would contain the data which will be fed into the model. The testing set will contain the data on which we test the trained and validated model.
  5. Now, we initialize a TfidfVectorizer with stop words from the English language and a maximum document frequency of 0.7 (terms with a higher document frequency will be discarded).
  6. Next, we’ll initialize a PassiveAggressiveClassifier and try to calculate the accuracy.
  7. Finally, we print out a confusion matrix to gain insight into the number of false and true negatives and positives.

Architecture

Fig: ML Model Architecture

Techniques

  • We used TF-IDF for feature extraction.
  • We trained our data by using PA algorithm.
  • We tested the efficiency of the classifier using accuracy metric.


TF-IDF

  • It denotes Term Frequency and Inverse Document Frequency.
  • TF (Term Frequency): The number of times a word appears in a document is its Term Frequency. A higher value means a term appears more often than others, and so, the document is a good match when the term is part of the search terms.
  • IDF (Inverse Document Frequency): Words that occur many times a document, but also occur many times in many others, may be irrelevant. IDF is a measure of how significant a term is in the entire corpus.
  • The TF-IDF is very commonly used in data mining and data recovery.
  • Search engines commonly use TF-IDF to rate and rank documents.
  • TF-IDF may be used to separate stop-words in a variety of subjects such as text summarization and classification.

𝑇𝐹(𝑥) = (𝑁𝑢𝑚𝑏𝑒𝑟 𝑜𝑓 𝑡𝑖𝑚𝑒𝑠 𝑤𝑜𝑟𝑑 𝑥 𝑎𝑝𝑝𝑒𝑎𝑟𝑠 𝑖𝑛 𝑎 𝑑𝑜𝑐𝑢𝑚𝑒𝑛𝑡)/(𝑇𝑜𝑡𝑎𝑙 𝑛𝑢𝑚𝑏𝑒𝑟 𝑜𝑓 𝑤𝑜𝑟𝑑𝑠 𝑖𝑛 𝑡ℎ𝑒 𝑑𝑜𝑐𝑢𝑚𝑒𝑛𝑡)

𝐼𝐷𝐹(𝑥) = ln⁡((𝑇𝑜𝑡𝑎𝑙 𝑛𝑢𝑚𝑏𝑒𝑟 𝑜𝑓 𝑑𝑜𝑐𝑢𝑚𝑒𝑛𝑡𝑠)/(𝑁𝑢𝑚𝑏𝑒𝑟 𝑜𝑓 𝑑𝑜𝑐𝑢𝑚𝑒𝑛𝑡𝑠 𝑤𝑖𝑡ℎ 𝑤𝑜𝑟𝑑 𝑥 𝑖𝑛 𝑖𝑡))


PA Algorithm

  • PA algorithm denotes Passive Aggressive algorithm.
  • Passive-aggressive algorithms are generally used for large-scale learning.
  • It is one of the few 'online-learning algorithms'.
  • In online machine learning algorithms, the input data comes in sequential order and the machine learning model is updated step-by-step, as opposed to batch learning, where the entire training dataset is used at once.
  • This is very useful in situations where there is a huge amount of data and it is computationally infeasible to train the entire dataset because of the sheer size of the data.
  • A very good example of this would be to detect fake news on a social media website like Twitter, where new data is being added every second.

Results

  1. We took a political dataset, implemented a TfidfVectorizer, initialized a PassiveAggressiveClassifier, and fit our model. We ended up obtaining an accuracy of 92.11% in magnitude.
  2. Also, with this model, we ended up getting 585 true positives, 582 true negatives, 47 false positives and 53 false negatives.

Real World Applications and Implementations

Real world applications:

  1. Elections
  2. Fake job rackets
  3. Checking the credibility of news links received on social media platforms like Facebook, WhatsApp, Twitter, etc.
  4. Fake medical news messages

Real world implementation:

  • To implement this in real life, we can make a mobile app or a WhatsApp-integrated feature.
  • Users would simply enter the link of a news website and be able to verify whether a news website is true or fake.
  • In the future, our improved model could be extended to a lot of other data and not just our dataset.

About

A project which examines the prevalence of fake news in light of communication breakthroughs made possible by the rise of social networking sites.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Jupyter Notebook 86.2%
  • Python 13.8%