Credit Card Fraud Analysis Using Predictive Modeling

Download as pdf or txt
Download as pdf or txt
You are on page 1of 31

CREDIT CARD FRAUD ANALYSIS USING PREDICTIVE MODELING

INTRODUCTION
1.1 INTRODUCTION
The online shopping growing day to day. Credit cards are used for purchasing goods and services
with the help of virtual card and physical card where as virtual card for online transaction and
physical card for offline transaction. In a physical-card based purchase, the cardholder presents his
card physically to a merchant for making a payment. To carry out fraudulent transactions in this
kind of purchase, an attacker has to steal the credit card. If the cardholder does not realize the loss
of card, it can lead to a substantial financial loss to the credit card company. In online payment
mode, attackers need only little information for doing fraudulent transaction (secure code, card
number, expiration date etc.). In this purchase method, mainly transactions will be done through
Internet or telephone.

To commit fraud in these types of purchases, a fraudster simply needs to know the card details.
Most of the time, the genuine cardholder is not aware that someone else has seen or stolen his card
information. The only way to detect this kind of fraud is to analyse the spending patterns on every
card and to figure out any inconsistency with respect to the “usual” spending patterns.

Fraud detection based on the analysis of existing purchase data of cardholder is a promising way to
reduce the rate of successful credit card frauds. Since humans tend to exhibit specific behavioristic
profiles, every cardholder can be represented by a set of patterns containing information about the
typical purchase category, the time since the last purchase, the amount of money spent, etc.
Deviation from such patterns is a potential threat to the system.
1.2 PURPOSE OF THE PROJECT

The main objective of the Project on Credit Card Fraud Detection System is to manage the details
of Credit Card, Transactions, Datasets, Files, Prediction. It manages all the information about Credit
Card, Customer, Prediction, Credit card. The project is totally built at administrative end and thus
only the administrator is guaranteed the access. The purpose of the project is to build an application
program to reduce the manual work for managing the credit card, transactions, customers, datasets.
It tracks all the all the details about datasets, files, prediction.

1
CREDIT CARD FRAUD ANALYSIS USING PREDICTIVE MODELING

Design:

PROBLEM STATEMENT
Credit card fraud stands as major problem for word wide financial institutions. Annual lost due to
it scales to billions of dollars. We can observe this from many financial reports. Such as
(Bhattacharyya et al., 2011) 10th annual online fraud report by Cyber Source shows that estimated
loss due to online fraud is $4 billion for 2008 which is 11% increase than $3.6 billion loss in 2007and
in 2006, fraud in United Kingdom alone was estimated to be £535 million in 2007 and now costing
around 13.9 billion a year (Mahdi et al., 2010). From 2006 to 2008, UK alone has lost £427.0 million
to £609.90 million due to credit and debit card fraud (Woolsey &Schulz, 2011). Although, there is
some decrease in such losses after implementation of detection and prevention systems by
government and bank, card-not-present fraud losses are increasing at higher rate due to online
transactions. Worst thing is it is still increasing un-protective and un-detective way.
Over the year, government and banks have implemented some steps to subdue these frauds but along
with the evolution of fraud detection and control methods, perpetrators are also evolving their
methods and practices to avoid detection.

2
CREDIT CARD FRAUD ANALYSIS USING PREDICTIVE MODELING

LITERATURE REVIEW

2.1 EXISTING SYSTEM


In case of the existing system the fraud is detected after the fraud is done that is , the fraud is
detected after the complaint of the holder. And so the card holder faced a lot of trouble before the
investigation finish. And also as all the transaction is maintained in a log, we need to maintain a
huge data, and also nowaday’s lot of online purchases are made so we don’t know the person how
is using the cardonline , we just capture the IP address for a verification purpose. So there need a
help from the cyber crime to investigate the fraud. The old manual system was suffering from a
series of drawbacks. Since whole system was to be maintained with hands.The process of
keeping, maintaining and retrieving the information was tedious and lengthy. The records were
never used to be in a systematic order. There used to be lot of difficulty in associating any
particular transaction with a particular context. There would always be unnecessary consumption
of time while entering and retrieving records. One more problem was that it was very difficult to
find errors while entering the records.
Once the records were entered it was very difficult to update these records.
i.The card holder faced a lot of trouble before the investigation finish.
ii. All the transaction is maintained in a log, we need to maintain a huge data.
iii. We do not know the person how is using the card online, we just capture the IP address for
verification purpose
iv. So there need a help from the cyber crime to investigate the fraud.
Disadvantages:
The Clustering doesn’t produce the less accuracy when compared to Regression methods in
scenarios like credit card fraud detection. Comparatively with other algorithms k-means produce
less accurate scores in prediction in this kind of scenarios
2.2 PROPOSED SYSTEM
Our goal is to implement machine learning model in order to classify, to the highest possible degree
of accuracy, credit card fraud from a dataset gathered from Kaggle. After initial data exploration,
we knew we would implement a logistic regression model for best accuracy reports.Logistic
regression, as it was a good candidate for binary classification. Python sklearn library was used to
implement the project, We used Kaggle datasets for Credit card fraud detection, using pandas to
data frame for class ==0 forno fraud and class==1 for fraud, matplotlib for plotting the fraud and
non fraud data, train_test_split for data extraction (Split arrays or matrices into random train and
test subsets) and used Logistic Regression machine learning algorithm for fraud detection and print

3
CREDIT CARD FRAUD ANALYSIS USING PREDICTIVE MODELING

predicting score according to the algorithm. Finally Confusion matrix was plotted on true and
predicted.

Advantages:
 The results obtained by the Logistic Regression Algorithm is best compared to any other
Algorithms.
 The Accuracy obtained was almost equal to cent percent which proves using of Logistic
algorithm gives best results.
 The plots that were plotted according to the proper data that is processed during the
implementation
2.3 FEASIBILITY STUDY
Preliminary investigation examine project feasibility, the likelihood the system will be useful to the
organization. The main objective of the feasibility study is to test the Technical, Operational and
Economical feasibility for adding new modules and debugging old running system. All system is
feasible if they are unlimited resources and infinite time. There are aspects in the feasibility study
portion of the preliminary investigation:
 Technical Feasibility
 Operational Feasibility
 Economical Feasibility
2.3.1 TECHNICAL FEASIBILITY
The technical issue usually raised during the feasibility stage of the investigation includes the
following:
 Does the necessary technology exist to do what is suggested?
 Do the proposed equipments have the technical capacity to hold the data required to use the new
system?
 Will the proposed system provide adequate response to inquiries, regardless of the number or
location of users?
 Can the system be upgraded if developed?
 Are there technical guarantees of accuracy, reliability, ease of access and data security?
Earlier no system existed to cater to the needs of ‘Secure Infrastructure Implementation
System’. The current system developed is technically feasible. It is a web based user interface for
audit workflow at NIC-CSD. Thus it provides an easy access to the users. The database’s purpose
is to create, establish and maintain a workflow among various entities in order to facilitate all
concerned users in their various capacities or roles. Permission to the users would be granted based
4
CREDIT CARD FRAUD ANALYSIS USING PREDICTIVE MODELING

on the roles specified. Therefore, it provides the technical guarantee of accuracy, reliability and
security. The software and hard requirements for the development of this project are not many and
are already available in-house at NIC or are available as free as open source. The work for the
project is done with the current equipment and existing software technology. Necessary bandwidth
exists for providing a fast feedback to the users irrespective of the number of users using the system.
2.3.2 OPERATIONAL FEASIBILITY
Proposed projects are beneficial only if they can be turned out into information system. That
will meet the organization’s operating requirements. Operational feasibility aspects of the project
are to be taken as an important part of the project implementation. Some of the important issues
raised are to test the operational feasibility of a project includes the following: -
 Is there sufficient support for the management from the users?
 Will the system be used and work properly if it is being developed and implemented?
 Will there be any resistance from the user that will undermine the possible application benefits?
This system is targeted to be in accordance with the above-mentioned issues. Beforehand,
the management issues and user requirements have been taken into consideration. So there is no
question of resistance from the users that can undermine the possible application benefits.
The well-planned design would ensure the optimal utilization of the computer resources and would
help in the improvement of performance status.
2.3.3 ECONOMICAL FEASIBILITY
A system can be developed technically and that will be used if installed must still be a good
investment for the organization. In the economical feasibility, the
development cost in creating the system is evaluated against the ultimate benefit derived from the
new systems. Financial benefits must equal or exceed the costs.
The system is economically feasible. It does not require any addition hardware or software.
Since the interface for this system is developed using the existing resources and technologies
available at NIC, There is nominal expenditure and economical feasibility for certain.

5
CREDIT CARD FRAUD ANALYSIS USING PREDICTIVE MODELING

SYSTEM DESIGN
3.1. INTRODUCTION

Software design sits at the technical kernel of the software engineering process and is applied
regardless of the development paradigm and area of application. Design is the first step in the
development phase for any engineered product or system. The designer’s goal is to produce a model
or representation of an entity that will later be built. Beginning, once system requirement have been
specified and analyzed, system design is the first of the three technical activities -design, code and
test that is required to build and verify software.
The importance can be stated with a single word “Quality”. Design is the place where quality is
fostered in software development. Design provides us with representations of software that can
assess for quality. Design is the only way that we can accurately translate a customer’s view into a
finished software product or system. Software design serves as a foundation for all the software
engineering steps that follow. Without a strong design we risk building an unstable system – one
that will be difficult to test, one whose quality cannot be assessed until the last stage.The purpose
of the design phase is to plan a solution of the problem specified by the requirement document.This
phase is the first step in moving from the problem domain to the solution domain.In other words,
starting with what is needed, design takes us toward how to satisfy the needs.The design of a system
is perhaps the most critical factor affection the quality of the software; it has a major impact on the
later phase, particularly testing, maintenance.The output of this phase is the design document. This
document is similar to a blueprint for the solution and is used later during implementation, testing
and maintenance.The design activity is often divided into two separate phases System Design and
Detailed Design.
System Design also called top-level design aims to identify the modules that should be in the system,
the specifications of these modules, and how they interact with each other to produce the desired
results.
3.2 SYSTEM DESIGN
Systems design is the process of defining the architecture, product design, modules, interfaces, and
data for a system to satisfy specified requirements. Systems design could be seen as the application
of systems theory to product development. The procedure which we followed to predict the result
are understanding problem statement and data by performing statistical analysis and visualization
then checking whether the data is balance or not, In this data set the data is imbalanced, balanced
by using oversampling, then scaling the data using standardization and normalization and testing
data with different ML algorithms For any data science project some package are very important
such as Numpy that is numeric python And pandas and for visualization of the data, matplotlib and
6
CREDIT CARD FRAUD ANALYSIS USING PREDICTIVE MODELING

seaborn is used which build on matplotlib with some extra features. Anaconda navigator is used as
it is having several IDE’s installed in it python programming language is used to implement machine
learning algorithms as it is easy to learn and implement. In this project Jupyter notebook is used to
process the complete code where the code can be viewed as block of codes and running each section
and identifying the errors is easier.
1. The fraud detection module will work in the following steps.
2. The Incoming set of transactions and amount are treated as credit card transactions.
3. The credit card transactions are given to machine learning algorithms as an input.
4. The output will result in either fraud or valid transaction by analyzing the data and observing a
pattern and using machine learning algorithms to do anomaly detection.
5. The fraud transactions alerts the user that fraud transaction has occurred and the user can block
the card to prevent further financial loss to him as well as the credit card company.
6. The valid transactions are treated as genuine transactions
3.2 ARCHITECTURE DIAGRAM

Fig 3.1: Architecture Diagram

3.3 REQUIREMENT SPECIFICATIONS

HARDWARE REQUIREMENTS:
 RAM : 4GB and High
 Processor : Intel i3 and above
 Hard Disk : 500GB: Minimum
SOFTWARE REQUIREMENTS:
 OS : Windows or Linux
 Python IDE : python 2.7.x and above

7
CREDIT CARD FRAUD ANALYSIS USING PREDICTIVE MODELING

 Pycharm IDE Required


 Setup tools and pip to be installed for 3.6 and above
 Language : Python Scripting
PYTHON :
Python is a high-level, interpreted, interactive and object-oriented scripting language. Python is
designed to be highly readable. It uses English keywords frequently where as other languages use
punctuation, and it has fewer syntactical constructions than other languages.
Python is Interpreted − Python is processed at runtime by the interpreter. You do not need to compile
your program before executing it. This is similar to PERL and PHP.
Python is Interactive − You can actually sit at a Python prompt and interact with the interpreter
directly to write your programs.
Python is Object-Oriented − Python supports Object-Oriented style or technique of programming
that encapsulates code within objects.
Python is a Beginner's Language − Python is a great language for the beginner-level programmers
and supports the development of a wide range of applications from simple text processing to WWW
browsers to games.
PYHON FEATURES
Python's features include
 Easy-to-learn − Python has few keywords, simple structure, and a clearly defined syntax. This
allows the student to pick up the language quickly.
 Easy-to-read − Python code is more clearly defined and visible to the eyes. Easy-to-maintain
− Python's source code is fairly easy-to-maintain.
 A broad standard library − Python's bulk of the library is very portable and crossplatform
compatible on UNIX, Windows, and Macintosh.
 Interactive Mode − Python has support for an interactive mode which allows interactive testing
and debugging of snippets of code.
 Portable − Python can run on a wide variety of hardware platforms and has the same interface
on all platforms.
 Extendable − You can add low-level modules to the Python interpreter. These modules enable
programmers to add to or customize their tools to be more efficient.

8
CREDIT CARD FRAUD ANALYSIS USING PREDICTIVE MODELING

METHODOLOGY

4.1 MACHINE LEARNING


Machine learning (ML) is a type of artificial intelligence (AI) that allows software applications to
become more accurate at predicting outcomes without being explicitly programmed to do so.
Machine learning algorithms use historical data as input to predict new output values.

Fig 4.1: Machine Learning


There are three types of Machine Learning
1. Supervised Learning
2. Unsupervised Learning
3. Reinforcement Learning
1. SUPERVISED LEARNING
Machines are trained using well "labelled" training data, and on basis of that data, machines
predict the output. The labelled data means some input data is already tagged with the correct
output.
2. UNSUPERVISED LEARNING
Unsupervised learning is a type of machine learning in which models are trained using unlabeled
dataset and are allowed to act on that data without any supervision. The goal of unsupervised
learning is to find the underlying structure of dataset, group that data according to similarities, and
represent that dataset in a compressed format.
3. REINFORCEMENT LEARNING

Data scientists typically use reinforcement learning to teach a machine to complete a multistep
process for which there are clearly defined rules. Data scientists program an algorithm to complete
a task and give it positive or negative cues as it works out how to complete a task. But for the
most part, the algorithm decides on its own what steps to take along the way.

9
CREDIT CARD FRAUD ANALYSIS USING PREDICTIVE MODELING

4.2 ALGORITHMS

4.2.1 LOGISTIC REGRESSION

Logistic Regression is one of the classification algorithm, used to predict a binary values in a
given set of independent variables (1 / 0, Yes / No, True / False). To represent binary / categorical
values, dummy variables are used. For the purpose of special case in the logistic regression is a
linear regression, when the resulting variable is categorical then the log of odds are used for
dependent variable and also it predicts the probability of occurrence of an event by fitting data to a
logistic function. Such as O = e^(I0 + I1*x) / (1 + e^(I0 + I1*x)) (3.1) Where, O is the predicted
output I0 is the bias or intercept term I1 is the coefficient for the single input value (x). Logistic
regression is started with the simple linear regression equation in which dependent variable can be
enclosed in a link function i.e., to start with logistic regression.

4.2.2 DECISION TREE

Decision tree is a type of supervised learning algorithm (having a pre-defined target variable) that
is mostly used in classification problems. It works for both categorical and continuous input and
output variables. In this technique, we split the population or sample into two or more
homogeneous sets (or sub-populations) based on most significant splitter / differentiator in input
variables.

TYPES OF DECISION TREE

1.Categorical Variable Decision Tree:


Decision Tree which has categorical target variable then it called as categorical variable decision
tree.
2.Continuous Variable Decision Tree:
Decision Tree has continuous target variable then it is called as Continuous Variable Decision
tree.
TERMINOLOGY OF DECISION TREE:
1. Root Node: It represents entire population or sample and this further gets divided into two or
more homogeneous sets.
2. Splitting: It is a process of dividing a node into two or more sub-nodes.
3. Decision Node: When a sub-node splits into further subnodes, then it is called decision node.
4. Leaf/ Terminal Node: Nodes do not split is called Leaf or Terminal node.

10
CREDIT CARD FRAUD ANALYSIS USING PREDICTIVE MODELING

5. Pruning: When we remove sub-nodes of a decision node, this process is called pruning. You
can say opposite process of splitting.
6. Branch / Sub-Tree: A sub section of entire tree is called branch or sub-tree.
7. Parent and Child Node: A node, which is divided into sub-nodes is called parent node of sub-
nodes where as sub-nodes are the child of parent node.

11
CREDIT CARD FRAUD ANALYSIS USING PREDICTIVE MODELING

UML Diagrams Overview

UML combines best techniques from data modeling (entity relationship diagrams), business
modeling (work flows), object modeling, and component modeling. It can be used with all
processes, throughout the software development life cycle, and across different implementation
technologies. UML has synthesized the notations of the Booch method, the Object-modeling
technique (OMT) and Object-oriented software engineering (OOSE) by fusing them into a single,
common and widely usable modeling language. UML aims to be a standard modeling language
which can model concurrent and distributed systems.
5.1 UMLS ON CREDIT FRAUD DETECTIONS

Class diagram:

datasets prepair list


+kaggle +feature
+open() +target
+read()

validate
algoritham
+fraud
+logistic ression +non fraud
+appy() +check()

Sequence diagram:

A sequence diagram in Unified Modeling Language (UML) is a kind of interaction diagram that
shows how processes operate with one another and in what order. It is a construct of a Message
12
CREDIT CARD FRAUD ANALYSIS USING PREDICTIVE MODELING

Sequence Chart. A sequence diagram shows, as parallel vertical lines ("lifelines"), different
processes or objects that live simultaneously, and, as horizontal arrows, the messages exchanged
between them, in the order in which they occur. This allows the specification of simple runtime
scenarios in a graphical manner.

Component diagram:

pandas
kaggle dataset

server

sklearn logistic reassions

13
CREDIT CARD FRAUD ANALYSIS USING PREDICTIVE MODELING

Deployement diagram:

sklearns kaggle datasets

system

logistic regressions
pandas library

Nearest neighbors:

Algorithm

Example of k-NN classification. The test sample (green circle) should be classified either to the
first class of blue squares or to the second class of red triangles. If k = 3 (solid line circle) it is
assigned to the second class because there are 2 triangles and only 1 square inside the inner circle.
If k = 5 (dashed line circle) it is assigned to the first class (3 squares vs. 2 triangles inside the outer
circle).
The training examples are vectors in a multidimensional feature space, each with a class label. The
training phase of the algorithm consists only of storing the feature vectors and class labels of the
training samples.
In the classification phase, k is a user-defined constant, and an unlabeled vector (a query or test
point) is classified by assigning the label which is most frequent among the k training samples
nearest to that query point.
A commonly used distance metric for continuous variables is Euclidean distance. For discrete
variables, such as for text classification, another metric can be used, such as the overlap
14
CREDIT CARD FRAUD ANALYSIS USING PREDICTIVE MODELING

metric (or Hamming distance). In the context of gene expression microarray data, for example, k-
NN has also been employed with correlation coefficients such as Pearson and Spearman.[3] Often,
the classification accuracy of k-NN can be improved significantly if the distance metric is learned
with specialized algorithms such as Large Margin Nearest Neighbor or Neighbourhood
components analysis.
A drawback of the basic "majority voting" classification occurs when the class distribution is
skewed. That is, examples of a more frequent class tend to dominate the prediction of the new
example, because they tend to be common among the k nearest neighbors due to their large
number.[4] One way to overcome this problem is to weight the classification, taking into account
the distance from the test point to each of its k nearest neighbors. The class (or value, in regression
problems) of each of the k nearest points is multiplied by a weight proportional to the inverse of
the distance from that point to the test point. Another way to overcome skew is by abstraction in
data representation. For example, in a self-organizing map (SOM), each node is a representative (a
center) of a cluster of similar points, regardless of their density in the original training data. K-NN
can then be applied to the SOM.
Parameter selection
The best choice of k depends upon the data; generally, larger values of k reduces effect of the
noise on the classification,[5] but make boundaries between classes less distinct. A good k can be
selected by various heuristic techniques (see hyperparameter optimization). The special case
where the class is predicted to be the class of the closest training sample (i.e. when k = 1) is called
the nearest neighbor algorithm.
The accuracy of the k-NN algorithm can be severely degraded by the presence of noisy or
irrelevant features, or if the feature scales are not consistent with their importance. Much research
effort has been put into selecting or scaling features to improve classification. A particularly
popular approach is the use of evolutionary algorithms to optimize feature scaling. Another
popular approach is to scale features by the mutual information of the training data with the
training classes.
In binary (two class) classification problems, it is helpful to choose k to be an odd number as this
avoids tied votes. One popular way of choosing the empirically optimal k in this setting is via
bootstrap method.
The 1-nearest neighbor classifier
The most intuitive nearest neighbour type classifier is the one nearest neighbour classifier
As the size of training data set approaches infinity, the one nearest neighbour classifier guarantees
an error rate of no worse than twice the Bayes error rate (the minimum achievable error rate given
the distribution of the data).
15
CREDIT CARD FRAUD ANALYSIS USING PREDICTIVE MODELING

Properties
k-NN is a special case of a variable-bandwidth, kernel density "balloon" estimator with a
uniform kernel.
The naive version of the algorithm is easy to implement by computing the distances from the test
example to all stored examples, but it is computationally intensive for large training sets. Using an
approximate nearest neighbor search algorithm makes k-NN computationally tractable even for
large data sets. Many nearest neighbor search algorithms have been proposed over the years; these
generally seek to reduce the number of distance evaluations actually performed.
k-NN has some strong consistency results. As the amount of data approaches infinity, the two-
class k-NN algorithm is guaranteed to yield an error rate no worse than twice the Bayes error
rate (the minimum achievable error rate given the distribution of the data). Various improvements
to the k-NN speed are possible by using proximity graphs.
For multi-class k-NN classification, Cover and Hart (1967) prove an upper bound error rate of
where is the Bayes error rate (which is the minimal error rate
possible), is the k-NN error rate, and M is the number of classes in the problem. For and as the
Bayesian error rate approaches zero, this limit reduces to "not more than twice the Bayesian error
rate".
Error rates
There are many results on the error rate of the k nearest neighbour classifiers. The k-nearest
neighbour classifier is strongly (that is for any joint distribution on) consistent provided diverges
and converges to zero as,Let denote the k nearest algorithm
Dimension reduction
For high-dimensional data (e.g., with number of dimensions more than 10) dimension reduction is
usually performed prior to applying the k-NN algorithm in order to avoid the effects of the curse
of dimensionality.
The curse of dimensionality in the k-NN context basically means that Euclidean distance is
unhelpful in high dimensions because all vectors are almost equidistant to the search query vector
(imagine multiple points lying more or less on a circle with the query point at the center; the
distance from the query to all data points in the search space is almost the same).
Feature extraction and dimension reduction can be combined in one step using principal
component analysis (PCA), linear discriminant analysis(LDA), or canonical correlation
analysis (CCA) techniques as a pre-processing step, followed by clustering by k-NN on feature
vectors in reduced-dimension space. In machine learning this process is also called low-
dimensional embedding.

16
CREDIT CARD FRAUD ANALYSIS USING PREDICTIVE MODELING

For very-high-dimensional datasets (e.g. when performing a similarity search on live video
streams, DNA data or high-dimensional time series) running a fast approximate k-NN search
using locality sensitive hashing, "random projections", "sketches" or other high-dimensional
similarity search techniques from the VLDB toolbox might be the only feasible option.
Decision boundary
Nearest neighbor rules in effect implicitly compute the decision boundary. It is also possible to
compute the decision boundary explicitly, and to do so efficiently, so that the computational
complexity is a function of the boundary complexity.
Data reduction
Data reduction is one of the most important problems for work with huge data sets. Usually, only
some of the data points are needed for accurate classification. Those data are called
the prototypes and can be found as follows:
1.Select the class-outliers, that is, training data that are classified incorrectly by k-NN (for a
given k)
2.Separate the rest of the data into two sets: (i) the prototypes that are used for the classification
decisions and (ii) the absorbed points that can be correctly classified by k-NN using prototypes.
The absorbed points can then be removed from the training set.
CNN for data reduction
Condensed nearest neighbor (CNN, the Hart algorithm) is an algorithm designed to reduce the
data set for k-NN classification. It selects the set of prototypes U from the training data, such that
1NN with U can classify the examples almost as accurately as 1NN does with the whole data set.

Calculation of the border ratio.

Three types of points: prototypes, class-outliers, and absorbed points.


Given a training set X, CNN works iteratively:
1. Scan all elements of X, looking for an element x whose nearest prototype from U has a
different label than x.
2. Remove x from X and add it to U
3. Repeat the scan until no more prototypes are added to U.

17
CREDIT CARD FRAUD ANALYSIS USING PREDICTIVE MODELING

Use U instead of X for classification. The examples that are not prototypes are called "absorbed"
points.
It is efficient to scan the training examples in order of decreasing border ratio. The border ratio of
a training example x is defined as
a(x) = ||x'-y||/ ||x-y||
where ||x-y|| is the distance to the closest example y having a different color than x, and ||x'-y|| is
the distance from y to its closest example x' with the same label as x.
The border ratio is in the interval [0,1] because ||x'-y||never exceeds ||x-y||. This ordering gives
preference to the borders of the classes for inclusion in the set of prototypes U. A point of a
different label than x is called external to x. The calculation of the border ratio is illustrated by the
figure on the right. The data points are labeled by colors: the initial point is x and its label is red.
External points are blue and green. The closest to x external point is y. The closest to y red point
is x' . The border ratio a(x) = ||x'-y|| / ||x-y||is the attribute of the initial point x.
Below is an illustration of CNN in a series of figures. There are three classes (red, green and
blue). Fig. 1: initially there are 60 points in each class. Fig. 2 shows the 1NN classification map:
each pixel is classified by 1NN using all the data. Fig. 3 shows the 5NN classification map. White
areas correspond to the unclassified regions, where 5NN voting is tied (for example, if there are
two green, two red and one blue points among 5 nearest neighbors). Fig. 4 shows the reduced data
set. The crosses are the class-outliers selected by the (3,2)NN rule (all the three nearest neighbors
of these instances belong to other classes); the squares are the prototypes, and the empty circles
are the absorbed points. The left bottom corner shows the numbers of the class-outliers, prototypes
and absorbed points for all three classes. The number of prototypes varies from 15% to 20% for
different classes in this example. Fig. 5 shows that the 1NN classification map with the prototypes
is very similar to that with the initial data set. The figures were produced using the Mirkes applet.

 CNN model reduction for k-NN classifiers


Fig. 1. The dataset.

18
CREDIT CARD FRAUD ANALYSIS USING PREDICTIVE MODELING

Fig. 2. The 1NN classification map.

Fig. 3. The 5NN classification map.

Fig. 4. The CNN reduced dataset.

Fig. 5. The 1NN classification map based on the CNN extracted prototypes.

FCNN (for Fast Condensed Nearest Neighbor) is a variant of CNN, which turns out to be one of
the fastest data set reduction algorithms for k-NN classification.

19
CREDIT CARD FRAUD ANALYSIS USING PREDICTIVE MODELING

K-NN regression

In k-NN regression, the k-NN algorithm is used for estimating continuous variables. One such
algorithm uses a weighted average of the k nearest neighbors, weighted by the inverse of their
distance. This algorithm works as follows:

 Compute the Euclidean or Mahalanobis distance from the query example to the labeled
examples.
 Order the labeled examples by increasing distance.
 Find a heuristically optimal number k of nearest neighbors, based on RMSE. This is done
using cross validation.
 Calculate an inverse distance weighted average with the k-nearest multivariate neighbors.

K-NN outlier

The distance to the kth nearest neighbor can also be seen as a local density estimate and thus is
also a popular outlier score in anomaly detection. The larger the distance to the k-NN, the lower
the local density, the more likely the query point is an outlier.To take into account the whole
neighborhood of the query point, the average distance to the k-NN can be used. Although quite
simple, this outlier model, along with another classic data mining method, local outlier factor,
works quite well also in comparison to more recent and more complex approaches, according to a
large scale experimental analysis.

Validation of results

A confusion matrix or "matching matrix" is often used as a tool to validate the accuracy of k-NN
classification. More robust statistical methods such as likelihood-ratio test can also be applied.

5.2 Import modules


import numpy as np
#import sklearn python machine learning module
import sklearn as sk
#import pandas dataframes
import pandas as pd
#import matplotlib for plotting
import matplotlib.pyplot as plt
#import datasets and linear_model from sklearn module
20
CREDIT CARD FRAUD ANALYSIS USING PREDICTIVE MODELING

from sklearn import datasets, linear_model


#import Polynomial features from sklearn module
from sklearn.preprocessing import PolynomialFeatures
#import train_test_split data classification
from sklearn.model_selection import train_test_split
#import ConfusionMatrix from pandas_ml
from pandas_ml import ConfusionMatrix
Loading the dataset
dataframe = pd.read_csv('C:/Python27/creditcard.csv', low_memory=False)
#dataframe.sample Returns a random sample of items from an axis of object.
#The frac keyword argument specifies the fraction of rows to return in the random sample, so
frac=1 means return all rows (in random order).
# If you wish to shuffle your dataframe in-place and reset the index
dataframe = dataframe.sample(frac=1).reset_index(drop=True)
#dataframe.head(n) returns a DataFrame holding the first n rows of dataframe.
dataframe.head()
print dataframe
Checking the target classes
fraud_class = dataframe.loc[dataframe['Class'] == 1]
#here in dataframe class with 1 label is selected for non_fraud_class
non_fraud_class = dataframe.loc[dataframe['Class'] == 0]
Splitting the data
X = dataframe.iloc[:,:-1]
y = dataframe['Class']
#Finding the length of X and y
print("X and y sizes, respectively:", len(X), len(y))
#Splitting the training and Testing data
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.35, random_state=500)
Train
logistic = linear_model.LogisticRegression(C=1e5)
#Fitting the Algorithm for X_train and y_train
logistic.fit(X_train, y_train)
Test
print("Score: ", logistic.score(X_test, y_test))

21
CREDIT CARD FRAUD ANALYSIS USING PREDICTIVE MODELING

print("Number of frauds on y_test:", len(y_test.loc[dataframe['Class'] == 1]),


len(y_test.loc[dataframe['Class'] == 1]) / len(y_test))
Predict the data
y_predicted = np.array(logistic.predict(X_test))
y_right = np.array(y_test)
#The confusion matrix (or error matrix) is one way to summarize the performance of a classifier
# for binary classification tasks. This square matrix
# consists of columns and rows that list the number of instances as absolute or
# relative "actual class" vs. "predicted class" ratios.
#Plotting the Confusion matrix for y_right and y_predicted
Finally got confusion matrics
confusion_matrix = ConfusionMatrix(y_right, y_predicted)
print("Confusion matrix:",confusion_matrix)
confusion_matrix.plot(normalized=True)
plt.show()
#printing the stats of Confusion matrix
confusion_matrix.print_stats()

22
CREDIT CARD FRAUD ANALYSIS USING PREDICTIVE MODELING

Output Screen
step1:-

23
CREDIT CARD FRAUD ANALYSIS USING PREDICTIVE MODELING

Step 2:-

Step 3:-

24
CREDIT CARD FRAUD ANALYSIS USING PREDICTIVE MODELING

Step 4:-
Finally got confusion metrics and high accuracy

25
CREDIT CARD FRAUD ANALYSIS USING PREDICTIVE MODELING

SYSTEM TESTING AND IMPLEMENTATION

8.1INTRODUCTION
Software testing is a critical element of software quality assurance and represents the
ultimate review of specification, design and coding. In fact, testing is the one step in the software
engineering process that could be viewed as destructive rather than constructive.
A strategy for software testing integrates software test case design methods into a well-
planned series of steps that result in the successful construction of software. Testing is the set of
activities that can be planned in advance and conducted systematically. The underlying motivation
of program testing is to affirm software quality with methods that can economically and effectively
apply to both strategic to both large and small-scale systems.

8.2. STRATEGIC APPROACH TO SOFTWARE TESTING


The software engineering process can be viewed as a spiral. Initially system engineering
defines the role of software and leads to software requirement analysis where the information
domain, functions, behavior, performance, constraints and validation criteria for software are
established. Moving inward along the spiral, we come to design and finally to coding. To develop
computer software we spiral in along streamlines that decrease the level of abstraction on each turn.
A strategy for software testing may also be viewed in the context of the spiral. Unit testing
begins at the vertex of the spiral and concentrates on each unit of the software as implemented in
source code. Testing progress by moving outward along the spiral to integration testing, where the
focus is on the design
and the construction of the software architecture. Talking another turn on outward on the spiral we
encounter validation testing where requirements established as part of software requirements
analysis are validated against the software that has been constructed. Finally we arrive at system
testing, where the software and other system elements are tested as a whole.

26
CREDIT CARD FRAUD ANALYSIS USING PREDICTIVE MODELING

UNIT
TESTING

MODULE
TESTING

SUB-SYSTEM
Component TESING
Testing

SYSTEM
TESTING

Integration
Testing

ACCEPTANC
E TESTING

User
Testing

8.3. UNIT TESTING


Unit testing focuses verification effort on the smallest unit of software design, the module.
The unit testing we have is white box oriented and some modules the steps are conducted in parallel.
1.WHITE BOX TESTING

This type of testing ensures that


 All independent paths have been exercised at least once
 All logical decisions have been exercised on their true and false sides
 All loops are executed at their boundaries and within their operational bounds
 All internal data structures have been exercised to assure their validity.
27
CREDIT CARD FRAUD ANALYSIS USING PREDICTIVE MODELING

To follow the concept of white box testing we have tested each form .we have created
independently to verify that Data flow is correct, All conditions are exercised to check their validity,
All loops are executed on their boundaries.

2.BASIC PATH TESTING


Established technique of flow graph with Cyclomatic complexity was used to derive test cases for
all the functions. The main steps in deriving test cases were:
Use the design of the code and draw correspondent flow graph.
Determine the Cyclomatic complexity of resultant flow graph, using formula:
V(G)=E-N+2 or
V(G)=P+1 or
V (G) =Number Of Regions
Where V (G) is Cyclomatic complexity,
E is the number of edges,
N is the number of flow graph nodes,
P is the number of predicate nodes.
Determine the basis of set of linearly independent paths.
3.CONDITIONAL TESTING
In this part of the testing each of the conditions were tested to both true and false aspects. And all
the resulting paths were tested. So that each path that may be generate on particular condition is
traced to uncover any possible errors.
4. DATA FLOW TESTING
This type of testing selects the path of the program according to the location of definition and use
of variables. This kind of testing was used only when some local variable were declared. The
definition-use chain method was used in this type of testing. These were particularly useful in nested
statements.
5. LOOP TESTING
In this type of testing all the loops are tested to all the limits possible. The following exercise was
adopted for all loops:
 All the loops were tested at their limits, just above them and just below them.
 All the loops were skipped at least once.
 For nested loops test the inner most loop first and then work outwards.
 For concatenated loops the values of dependent loops were set with the help of connected
loop.Unstructured loops were resolved into nested loops or concatenated loops and tested as
above
28
CREDIT CARD FRAUD ANALYSIS USING PREDICTIVE MODELING

SYSTEM SECURITY

9.1 INTRODUCTION
The protection of computer based resources that include hardware, software, data,
procedures and people against unauthorized use or natural Disaster is known as System Security.
System Security can be divided into four related issues:
1. Security
2. Integrity
3. Privacy
4. Confidentiality
SYSTEM SECURITY refers to the technical innovations and procedures applied to the hardware
and operation systems to protect against deliberate or accidental damage from a defined threat.
DATA SECURITY is the protection of data from loss, disclosure, modification and destruction.
SYSTEM INTEGRITY refers to the power functioning of hardware and programs, appropriate
physical security and safety against external threats such as eavesdropping and wiretapping.
PRIVACY defines the rights of the user or organizations to determine what information they are
willing to share with or accept from others and how the organization can be protected against
unwelcome, unfair or excessive dissemination of information about it.
CONFIDENTIALITY is a special status given to sensitive information in a database to minimize
the possible invasion of privacy. It is an attribute of information that characterizes its need for
protection.
9.2SECURITY SOFTWARE
It is the technique used for the purpose of converting communication. It transfers
message secretly by embedding it into a cover medium with the use of information hiding
techniques. It is one of the conventional techniques capable of hiding large secret message in a cover
image without introducing many perceptible distortions.
NET has two kinds of security:
 Role Based Security
 Code Access Security
The Common Language Runtime (CLR) allows code to perform only those operations that the code
has permission to perform. So CAS is the CLR's security system that enforces security policies by
preventing unauthorized access to protected resources and operations. Using the Code Access
Security, you can do the following:
 Restrict what your code can do

29
CREDIT CARD FRAUD ANALYSIS USING PREDICTIVE MODELING

CONCLUSION

This machine learning fraud detection showed how to tackle the problem of credit card fraud
detection using machine learning. It is fairly easy to come up with a simple model, implement it in
Python and get great results for the Credit Card Fraud Detection task on Kaggle.

30
CREDIT CARD FRAUD ANALYSIS USING PREDICTIVE MODELING

REFERENCES
1. L.J.P. vander Maaten and G.E. Hinton, Visualizing High-Dimensional Data Using t-SNE (2014),
Journal of Machine Learning Research

2. Machine Learning Group — ULB, Credit Card Fraud Detection (2018), Kaggle

3. Nathalie Japkowicz, Learning from Imbalanced Data Sets: A Comparison of Various


Strategies (2000), AAAI Technical Report WS-00–05

4. F. N. Ogwueleka,"Data Mining Application in Credit Card Fraud Detection System",Journal of


Engineering Science and Technology, vol. 6, no. 3, pp. 311-322, 2011.

5. K. Chaudhary, B. Mallick, "Credit Card Fraud: The study of its impact and detection techniques",
International Journal of Computer Science and Network (IJCSN), vol. 1, no. 4, pp. 31-35, 2012,
ISSN ISSN: 2277-5420.

6. R. Wheeler, S. Aitken, "Multiple algorithms for fraud detection" in Knowledge-Based Systems,


Elsevier, vol. 13, no. 2, pp. 93-99, 2000.

31

You might also like