Data Science Interview Questions - 1
Data Science Interview Questions - 1
Interview Questions
“Suppose that we are interested in estimating the average height among all people. Collecting data for
every person in the world is impossible. While we can’t obtain a height measurement from everyone in the
population, we can still sample some people. The question now becomes, what can we say about the
average height of the entire population given a single sample. The Central Limit Theorem addresses this
question exactly.” Read more here.
“A type I error occurs when the null hypothesis is true, but is rejected. A type II error occurs when the null
hypothesis is false, but erroneously fails to be rejected.” Read the full answer here.
4.     What is linear regression? What do the terms p-value, coefficient, and r-squared
       value mean? What is the significance of each of these components?
A linear regression is a good tool for quick predictive analysis: for example, the price of a house depends
on a myriad of factors, such as its size or its location. In order to see the relationship between these
variables, we need to build a linear regression, which predicts the line of best fit between them and can
help conclude whether or not these two factors have a positive or negative relationship. Read
more here and here.
There are four major assumptions: 1. There is a linear relationship between the dependent variables and
the regressors, meaning the model you are creating actually fits the data, 2. The errors or residuals of the
data are normally distributed and independent from each other, 3. There is minimal multicollinearity
between explanatory variables, and 4. Homoscedasticity. This means the variance around the regression
line is the same for all values of the predictor variable.
”Basically, an interaction is when the effect of one factor (input variable) on the dependent variable (output
variable) differs among levels of another factor.” Read more here.
“Selection (or ‘sampling’) bias occurs in an ‘active,’ sense when the sample data that is gathered and
prepared for modeling has characteristics that are not representative of the true, future population of cases
                                                                                  Created By : Sonu Kumar
the model will see. That is, active selection bias occurs when a subset of the data are systematically (i.e.,
non-randomly) excluded from analysis.” Read more here.
“The Gaussian distribution is part of the Exponential family of distributions, but there are a lot more of them,
with the same sort of ease of use, in many cases, and if the person doing the machine learning has a solid
grounding in statistics, they can be utilized where appropriate.” Read more here.
9. What is the Binomial Probability Formula?
“The binomial distribution consists of the probabilities of each of the possible numbers of successes on N
trials for independent events that each have a probability of π (the Greek letter pi) of occurring.” Read more
                      :             Data Science
Q1. What is Data Science? List the differences between supervised and unsupervised
learning.
Data Science is a blend of various tools, algorithms, and machine learning principles with the goal to discover
hidden patterns from the raw data. How is this different from what statisticians have been doing for years?
The answer lies in the difference between explaining and predicting.
   1. Sampling bias: It is a systematic error due to a non-random sample of a population causing some
       members of the population to be less likely to be included than others resulting in a biased sample.
   2. Time interval: A trial may be terminated early at an extreme value (often for ethical reasons), but the
   extreme value is likely to be reached by the variable with the largest variance, even if all variables
   have a similar mean.
   3. Data: When specific subsets of data are chosen to support a conclusion or rejection of bad data on
       arbitrary grounds, instead of according to previously stated or generally agreed criteria.
   4. Attrition: Attrition bias is a kind of selection bias caused by attrition (loss of participants) discounting
       trial subjects/tests that did not run to completion.
Bias: Bias is an error introduced in your model due to oversimplification of the machine learning algorithm. It
can lead to underfitting. When you train your model at that time model makes simplified assumptions to make
the target function easier to understand.
Low bias machine learning algorithms — Decision Trees, k-NN and SVM High bias machine learning
algorithms — Linear Regression, Logistic Regression
Variance: Variance is error introduced in your model due to complex machine learning algorithm, your model
learns noise also from the training data set and performs badly on test data set. It can lead to high sensitivity
and overfitting.
Normally, as you increase the complexity of your model, you will see a reduction in error due to lower bias
in the model. However, this only happens until a particular point. As you continue to make your model more
complex, you end up over-fitting your model and hence your model will start suffering from high variance.
Bias-Variance trade-off: The goal of any supervised machine learning algorithm is to have low bias and
low variance to achieve good prediction performance.
There is no escaping the relationship between bias and variance in machine learning. Increasing the bias
will decrease the variance. Increasing the variance will decrease bias.
The confusion matrix is a 2X2 table that contains 4 outputs provided by the binary classifier. Various
measures, such as error-rate, accuracy, specificity, sensitivity, precision and recall are derived from it.
Confusion Matrix
 A data set used for performance evaluation is called a test data set . It should contain the correct labels and
 predicted labels.
The predicted labels will exactly the same if the performance of a binary classifier is perfect.
A binary classifier predicts all data instances of a test data set as either positive or negative. This produces
four outcomes-
Q5. What is the difference between “long” and “wide” format data?
In the wide-format, a subject’s repeated responses will be in a single row, and each response is in a
separate column. In the long-format, each row is a one-time point per subject. You can recognize data in
wide format by the fact that columns generally represent groups.
Data is usually distributed in different ways with a bias to the left or to the right or it can all be jumbled up.
However, there are chances that data is distributed around a central value without any bias to the left or right
and reaches normal distribution in the form of a bell-shaped curve.
The random variables are distributed in the form of a symmetrical, bell-shaped curve.
                                                                             Correlation:
Correlation is considered or described as the best technique for measuring and also for estimating the
quantitative relationship between two variables. Correlation measures how strongly two variables are
related.
Covariance: In covariance two items vary together and it’s a measure that indicates the extent to which two
random variables change in cycle. It is a statistical term; it explains the systematic relation between a pair of
random variables, wherein changes in one variable reciprocal by a corresponding change in another
variable.
Q8. What is the difference between Point Estimates and Confidence Interval?
Point Estimation gives us a particular value as an estimate of a population parameter. Method of Moments
and Maximum Likelihood estimator methods are used to derive Point Estimators for population parameters.
A confidence interval gives us a range of values which is likely to contain the population parameter. The
confidence interval is generally preferred, as it tells us how likely this interval is to contain the population
parameter. This likeliness or probability is called Confidence Level or Confidence coefficient and represented
by 1 — alpha, where alpha is the level of significance.
The goal of A/B Testing is to identify any changes to the web page to maximize or increase the outcome of
interest. A/B testing is a fantastic method for figuring out the best online promotional and marketing strategies
for your business. It can be used to test everything from website copy to sales emails to search ads
When you perform a hypothesis test in statistics, a p-value can help you determine the strength of your
results. p-value is a number between 0 and 1. Based on the value it will denote the strength of the results.
The claim which is on trial is called the Null Hypothesis.
Low p-value (≤ 0.05) indicates strength against the null hypothesis which means we can reject the null
Hypothesis. High p-value (≥ 0.05) indicates strength for the null hypothesis which means we can accept the
null Hypothesis p-value of 0.05 indicates the Hypothesis could go either way. To put it in another way,
High P values: your data are likely with a true null. Low P values: your data are unlikely with a true null.
Q11. In any 15-minute interval, there is a 20% probability that you will see at least one shooting
star. What is the probability that you see at least one shooting star in the period of an hour?
 Probability of not seeing any shooting star in 15 minutes is
Probability of not seeing any shooting star in the period of one hour
= (0.8) ^ 4 = 0.4096
Q12. How can you generate a random number between 1 – 7 with only a die?
     •   Any die has six sides from 1-6. There is no way to get seven equal outcomes from a single rolling of
         a die. If we roll the die twice and consider the event of two rolls, we now have 36 different outcomes.
     •   To get our 7 equal outcomes we have to reduce this 36 to a number divisible by 7. We can thus
         consider only 35 outcomes and exclude the other one.
     •   A simple scenario can be to exclude the combination (6,6), i.e., to roll the die again if 6 appears twice.
     •   All the remaining combinations from (1,1) till (6,5) can be divided into 7 parts of 5 each. This way all
         the seven sets of outcomes are equally likely.
Q13. A certain couple tells you that they have two children, at least one of which is a girl. What is
the probability that they have two girls?
where B = Boy and G = Girl and the first letter denotes the first child.
 From the question, we can exclude the first case of BB. Thus from the remaining 3 possibilities
 of BG, GB & BB, we have to find the probability of the case with two girls.
There are two ways of choosing the coin. One is to pick a fair coin and the other is to pick the one with two
heads.
Probability
                    of          selecting        fair        coin         =          999/1000           = 0.999
Probability of selecting unfair coin = 1/1000 = 0.001
Selecting 10 heads in a row = Selecting fair coin * Getting 10 heads + Selecting an unfair coin
Q15. What do you understand by statistical power of sensitivity and how do you calculate it?
Sensitivity is commonly used to validate the accuracy of a classifier (Logistic, SVM, Random Forest etc.).
Sensitivity is nothing but “Predicted True events/ Total events”. True events here are the events which were
true and model also predicted them as true.
Calculation of seasonality is pretty straightforward.
     •   Estimating the accuracy of sample statistics by using subsets of accessible data or drawing randomly
     •   with replacement from a set of data points
     •   Substituting labels on data points when performing significance tests
         Validating models by using random subsets (bootstrapping, cross-validation)
In statistics and machine learning, one of the most common tasks is to fit a model to a set of training data,
so as to be able to make reliable predictions on general untrained data.
To combat overfitting and underfitting, you can resample the data to estimate the model accuracy (k-fold
cross-validation) and by having a validation dataset to evaluate the model.
Q19. What is regularisation? Why is it useful?
Explore Curriculum Regularisation is the process of adding tuning parameter to a model to induce smoothness
in order to prevent
overfitting. This is most often done by adding a constant multiple to an existing weight vector. This constant
is often the L1(Lasso) or L2(ridge). The model predictions should then minimize the loss function calculated
on the regularized training set.
Q20. What Is the Law of Large Numbers?
In statistics, a confounder is a variable that influences both the dependent variable and independent variable.
For example, if you are researching whether a lack of exercise leads to weight gain,
A confounding variable here would be any other variable that affects both of these variables, such as the age
of the subject.
Q22. What Are the Types of Biases That Can Occur During Sampling?
     •   Selection bias
     •   Under coverage bias
     •   Survivorship bias
 It is the logical error of focusing aspects that support surviving some process and casually overlooking those
that did not work because of their lack of prominence. This can lead to wrong conclusions in numerous
different means.
Selection bias occurs when the sample obtained is not representative of the population intended to be
analysed.
Q25. Explain how a ROC curve works?
The ROC curve is a graphical representation of the contrast between true positive rates and false-positive
rates at various thresholds. It is often used as a proxy for the trade-off between the sensitivity(true positive
rate) and false-positive rate.
The TF–IDF value increases proportionally to the number of times a word appears in the document but is
offset by the frequency of the word in the corpus, which helps to adjust for the fact that some words appear
more frequently in general.
Q27. Why we generally use Softmax non-linearity function as last operation in-network?
It is because it takes in a vector of real numbers and returns a probability distribution. Its definition is as
follows. Let x be a vector of real numbers (positive, negative, whatever, there are no constraints).
Then the i’th component of Softmax(x) is —
   •   Python would be the best option because it has Pandas library that provides easy to use data
   •   structures and high-performance data analysis tools.
   •   R is more suitable for machine learning than just text analysis.
       Python performs faster for all types of text analytics.
Q29. How does data cleaning plays a vital role in the analysis?
   •   Cleaning data from multiple sources helps to transform it into a format that data analysts or data
   •   scientists can work with.
   •   Data Cleaning helps to increase the accuracy of the model in machine learning.
       It is a cumbersome process because as the number of data sources increases, the time taken to
       clean the data increases exponentially due to the number of sources and the volume of data
       generated by these sources.
   •   It might take up to 80% of the time for just cleaning data making it a critical part of the analysis task.
Univariate analyses are descriptive statistical analysis techniques which can be differentiated based on the
number of variables involved at a given point of time. For example, the pie charts of sales based on territory
involve only one variable and can the analysis can be referred to as univariate analysis.
The bivariate analysis attempts to understand the difference between two variables at a time as in a
scatterplot. For example, analyzing the volume of sale and spending can be considered as an example of
bivariate analysis.
Multivariate analysis deals with the study of more than two variables to understand the effect of variables
on the responses.
physical names or
descriptions and can be connected to the central fact table using the ID fields; these tables are known as
lookup tables and are principally useful in real-time applications, as they save a lot of memory. Sometimes
star schemas involve several layers of summarization to recover information faster.
Q32. What is Cluster Sampling?
Cluster sampling is a technique used when it becomes difficult to study the target population spread across
a wide area and simple random sampling cannot be applied. Cluster Sample is a probability sample where
each sampling unit is a collection or cluster of elements.
For eg., A researcher wants to survey the academic performance of high school students in Japan. He can
divide the entire population of Japan into different clusters (cities). Then the researcher selects a number of
clusters depending on his research through simple or systematic random sampling.
Let’s continue our Data Science Interview Questions blog with some more statistics questions.
Systematic sampling is a statistical technique where elements are selected from an ordered sampling frame.
In systematic sampling, the list is progressed in a circular manner so once you reach the end of the list, it is
progressed from the top again. The best example of systematic sampling is equal probability method.
Eigenvectors are used for understanding linear transformations. In data analysis, we usually calculate the
eigenvectors for a correlation or covariance matrix. Eigenvectors are the directions along which a particular
linear transformation acts by flipping, compressing or stretching.
Eigenvalue can be referred to as the strength of the transformation in the direction of eigenvector or the
factor by which the compression occurs.
Q35. Can you cite some examples where a false positive is important than a false negative?
Let us first understand what false positives and false negatives are.
   •   False Positives are the cases where you wrongly classified a non-event as an event a.k.a Type I
   •   error.
       False Negatives are the cases where you wrongly classify events as non-events, a.k.a Type II error.
Example 1: In the medical field, assume you have to give chemotherapy to patients. Assume a patient
comes to that hospital and he is tested positive for cancer, based on the lab prediction but he actually doesn’t
have cancer. This is a case of false positive. Here it is of utmost danger to start chemotherapy on this patient
when he actually does not have cancer. In the absence of cancerous cell, chemotherapy will do certain
damage to his normal healthy cells and might lead to severe diseases, even cancer.
Example 2: Let’s say an e-commerce company decided to give $1000 Gift voucher to the customers whom
they assume to purchase at least $10,000 worth of items. They send free voucher mail directly to 100
customers without any minimum purchase condition because they assume to make at least 20% profit on
sold items above $10,000. Now the issue is if we send the $1000 gift vouchers to customers who have not
actually purchased anything but are marked as having made $10,000 worth of purchase.
there is an airport ‘A’ which has received high-security threats and based on certain
characteristics they identify whether a particular passenger can be a threat or not. Due to a shortage of staff,
they decide to scan passengers being predicted as risk positives by their predictive model. What will happen
if a true threat customer is being flagged as non-threat by airport model?
Example 2: What if Jury or judge decides to make a criminal go free?
Example 3: What if you rejected to marry a very good person based on your predictive model and you
happen to meet him/her after a few years and realize that you had a false negative?
Q37. Can you cite some examples where both false positive and false negatives are equally
important?
In the Banking industry giving loans is the primary source of making money but at the same time if your
repayment rate is not good you will not make any profit, rather you will risk huge losses.
Banks don’t want to lose good customers and at the same point in time, they don’t want to acquire bad
customers. In this scenario, both the false positives and false negatives become very important to measure.
Q38. Can you explain the difference between a Validation Set and a Test Set?
A Validation set can be considered as a part of the training set as it is used for parameter selection and to
avoid overfitting of the model being built.
On the other hand, a Test Set is used for testing or evaluating the performance of a trained machine learning
model.
In simple terms, the differences can be summarized as; training set is to fit the parameters i.e. weights and
test set is to assess the performance of the model i.e. evaluating the predictive power and generalization.
Q39. Explain cross-validation.
Cross-validation is a model validation technique for evaluating how the outcomes of statistical analysis
will generalize to an independent dataset. Mainly used in backgrounds where the objective is forecast and
one wants to estimate how accurately a model will accomplish in practice.
The goal of cross-validation is to term a data set to test the model in the training phase (i.e. validation data
set) in order to limit problems like overfitting and get an insight on how the model will generalize to an
independent data set.
Machine Learning explores the study and construction of algorithms that can learn from and make predictions
on data. Closely related to computational statistics. Used to devise complex models and algorithms that lend
themselves to a prediction which in commercial use is known as predictive analytics. Given below, is an image
representing the various domains Machine Learning lends itself to.
Supervised learning is the machine learning task of inferring a function from labeled training data. The
training data consist of a set of training examples.
Algorithms: Support Vector Machines, Regression, Naive Bayes, Decision Trees, K-nearest
Neighbor Algorithm and Neural Networks
E.g. If you built a fruit classifier, the labels will be “this is an orange, this is an apple and this is a banana”,
based on showing the classifier examples of apples, oranges and bananas.
Q42. What is Unsupervised learning?
Unsupervised learning is a type of machine learning algorithm used to draw inferences from datasets
consisting of input data without labelled responses.
Algorithms: Clustering, Anomaly Detection, Neural Networks and Latent Variable Models
E.g. In the same example, a fruit clustering will categorize as “fruits with soft skin and lots of dimples”, “fruits
with shiny hard skin” and “elongated yellow fruits”.
Q43. What are the various classification algorithms?
The Naive Bayes Algorithm is based on the Bayes Theorem. Bayes’ theorem describes the probability of
an event, based on prior knowledge of conditions that might be related to the event.
The Algorithm is ‘naive’ because it makes assumptions that may or may not turn out to be correct.
SVM stands for support vector machine, it is a supervised machine learning algorithm which can be used for
both Regression and Classification. If you have n features in your training data set, SVM tries to plot it
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
in n-dimensional space with the value of each feature being the value of a particular coordinate. SVM uses
hyperplanes to separate out different classes based on the provided kernel function.
In the diagram, we see that the thinner lines mark the distance from the classifier to the closest data points
called the support vectors (darkened data points). The distance between the two thin lines is called the
margin.
Q47. What are the different kernels in SVM?
    1. Linear Kernel
    2. Polynomial kernel
    3. Radial basis kernel
    4. Sigmoid kernel
Q49. What are Entropy and Information gain in Decision tree algorithm?
The core algorithm for building a decision tree is called ID3. ID3 uses Entropy and Information Gain Entropy A
decision tree is built top-down from a root node and involve partitioning of data into homogenious
subsets. ID3 uses enteropy to check the homogeneity of a sample. If the sample is completely homogenious
then entropy is zero and if the sample is an equally divided it has entropy of one.
Information Gain
The Information Gain is based on the decrease in entropy after a dataset is split on an attribute.
Constructing a decision tree is all about finding attributes that return the highest information gain.
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
Q50. What is pruning in Decision Tree?
Pruning is a technique in machine learning and search algorithms that reduces the size of decision trees by
removing sections of the tree that provide little power to classify instances. So, when we remove sub-nodes of
a decision node, this process is called pruning or opposite process of splitting.
Q51. What is logistic regression? State an example when you have used logistic regression
recently.
Logistic Regression often referred to as the logit model is a technique to predict the binary outcome from a
linear combination of predictor variables.
For example, if you want to predict whether a particular political leader will win the election or not. In this
case, the outcome of prediction is binary i.e. 0 or 1 (Win/Lose). The predictor variables here would be the
amount of money spent for election campaigning of a particular candidate, the amount of time spent in
campaigning, etc.
Q52. What is Linear Regression?
Linear regression is a statistical technique where the score of a variable Y is predicted from the score of a
second variable X. X is referred to as the predictor variable and Y as the criterion variable.
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
Follow me for more AI and Data science posts: https://lnkd.in/gZu463X
Q53. What Are the Drawbacks of the Linear Model?
Both Regression and classification machine learning techniques come under Supervised machine learning
algorithms. In Supervised machine learning algorithm, we have to train the model using labelled data set,
While training we have to explicitly provide the correct labels and algorithm tries to learn the pattern from
input to output. If our labels are discrete values then it will a classification problem, e.g A,B etc. but if our
labels are continuous values then it will be a regression problem, e.g 1.23, 1.333 etc.
Q55. What are Recommender Systems?
Recommender Systems are a subclass of information filtering systems that are meant to predict the
preferences or ratings that a user would give to a product. Recommender systems are widely used in movies,
news, research articles, products, social tags, music, etc. Examples include movie recommenders in IMDB,
Netflix & BookMyShow, product recommenders in e- commerce sites like Amazon, eBay & Flipkart, YouTube
video recommendations and game recommendations in Xbox.
Q56. What is Collaborative filtering?
The process of filtering used by most of the recommender systems to find patterns or information by
collaborating viewpoints, various data sources and multiple agents.
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
An example of collaborative filtering can be to predict the rating of a particular user based on his/her ratings
for other movies and others’ ratings for all movies. This concept is widely used in recommending movies in
IMDB, Netflix & BookMyShow, product recommenders in e-commerce sites like Amazon, eBay & Flipkart,
YouTube video recommendations and game recommendations in Xbox.
Q57. How can outlier values be treated?
Outlier values can be identified by using univariate or any other graphical analysis method. If the number of
outlier values is few then they can be assessed individually but for a large number of outliers, the values can
be substituted with either the 99th or the 1st percentile values.
All extreme values are not outlier values. The most common ways to treat outlier values
The extent of the missing values is identified after identifying the variables with missing values. If any patterns
are identified the analyst has to concentrate on them as it could lead to interesting and meaningful business
insights.
If there are no patterns identified, then the missing values can be substituted with mean or median values
(imputation) or they can simply be ignored. Assigning a default value which can be mean, minimum or
maximum value. Getting into the data is important.
If it is a categorical variable, the default value is assigned. The missing value is assigned a default value. If
you have a distribution of data coming, for normal distribution give the mean value.
If 80% of the values for a variable are missing then you can answer that you would be dropping the variable
instead of treating the missing values.
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
Q60. How will you define the number of clusters in a clustering algorithm?
Though the Clustering Algorithm is not specified, this question is mostly in reference to K-Means clustering
where “K” defines the number of clusters. The objective of clustering is to group similar entities in a way that
the entities within a group are similar to each other but the groups are different from each other.
For example, the following image shows three different groups.
of squares is generally used to explain the homogeneity within a cluster. If you plot WSS for
                                                                                          Within
                                                                                              a range
                                                                                                    Sum
                                                                                                      of number
of clusters, you will get the plot shown below.
This is the widely used approach but few data scientists also use Hierarchical clustering first to create
dendrograms and identify the distinct groups from there.
Bagging tries to implement similar learners on small sample populations and then takes a mean of all the
predictions. In generalised bagging, you can use different learners on different population. As you expect
this helps us to reduce the variance error.
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
Boosting
Boosting is an iterative technique which adjusts the weight of an observation based on the last
classification. If an observation was classified incorrectly, it tries to increase the weight of this observation
and vice versa. Boosting in general decreases the bias error and builds strong predictive models. However,
they may over fit on the training data.
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
                                                    In Random Forest, we grow multiple trees as opposed to
a single tree. To classify a new object based on attributes, each tree gives a classification. The forest
chooses the classification having the most votes(Overall the trees in the forest) and in case of regression,
it takes the average of outputs by different trees.
Q64. How Do You Work Towards a Random Forest?
The underlying principle of this technique is that several weak learners combined to provide a keen
learner. The steps involved are
Q65. What cross-validation technique would you use on a time series data set?
Instead of using k-fold cross-validation, you should be aware of the fact that a time series is not randomly
distributed data — It is inherently ordered by chronological order.
In case of time series data, you should use techniques like forward=chaining — Where you will be model
on past data then look at forward-facing data.
fold 1: training[1], test[2]
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
techniques assume normality. Applying a box cox transformation means that you can run a broader
number of tests.
A Box-Cox transformation is a way to transform non-normal dependent variables into a normal shape.
Normality is an important assumption for many statistical techniques, if your data isn’t normal, applying a
Box-Cox means that you are able to run a broader number of tests. The Box-Cox transformation is named
after statisticians George Box and Sir David Roxbee Cox who collaborated on a 1964 paper and
developed the technique.
Q67. How Regularly Must an Algorithm be Updated?
Q68. If you are having 4GB RAM in your machine and you want to train your model on 10GB
data set. How would you go about this problem? Have you ever faced this kind of problem in
your machine learning/data science experience so far?
First of all, you have to ask which ML model you want to train.
For Neural networks: Batch size with Numpy array will work.
Steps:
    1. Load the whole data in the Numpy array. Numpy array has a property to create a mapping of the
        complete data set, it doesn’t load complete data set in memory.
    2. You can pass an index to Numpy array to get required data.
    3. Use this data to pass to the Neural network.
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
    4. Have a small batch size.
Steps:
However, you could actually face such an issue in reality. So, you could check out the best laptop for
Machine Learning to prevent that. Having said that, let’s move on to some questions on deep learning.
Deep Learning is nothing but a paradigm of machine learning which has shown incredible promise in recent
years. This is because of the fact that Deep Learning shows a great analogy with the functioning of the human
brain.
Q70. What is the difference between machine learning and deep learning?
Machine learning is a field of computer science that gives computers the ability to learn without being
explicitly programmed. Machine learning can be categorised in the following three categories.
Deep Learning is a
subfield of machine learning concerned with algorithms inspired by the structure and function of the brain
called artificial neural networks.
Q71. What, in your opinion, is the reason for the popularity of Deep Learning in recent
times?
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
Now although Deep Learning has been around for many years, the major breakthroughs from these
techniques came just in recent years. This is because of two main reasons:
Learning is                                                                    Reinforcement
learning what to do and how to map situations to actions. The end result is to maximise the numerical reward
signal. The learner is not told which action to take but instead must discover which action will yield the
maximum reward. Reinforcement learning is inspired by the learning of human beings, it is based on the
reward/penalty mechanism.
Q73. What are Artificial Neural Networks?
Artificial Neural networks are a specific set of algorithms that have revolutionized machine learning. They
are inspired by biological neural networks. Neural Networks can adapt to changing the input so the network
generates the best possible result without needing to redesign the output criteria.
Q74. Describe the structure of Artificial Neural Networks?
Artificial Neural Networks works on the same principle as a biological Neural Network. It consists of inputs
which get processed with weighted sums and Bias, with the help of Activation Functions.
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
Q75. How Are Weights Initialized in a Network?
There are two methods here: we can either initialize the weights to zero or assign them randomly. Initializing
all weights to 0: This makes your model similar to a linear model. All the neurons and every layer
perform the same operation, giving the same output and making the deep net useless.
Initializing all weights randomly: Here, the weights are assigned randomly by initializing them very close to
0. It gives better accuracy to the model since every neuron performs different computations. This is the most
commonly used method.
Also referred to as “loss” or “error,” cost function is a measure to evaluate how good your model’s
performance is. It’s used to compute the error of the output layer during backpropagation. We push that error
backwards through the neural network and use that during the different training functions.
With neural networks, you’re usually working with hyperparameters once the data is formatted correctly. A
hyperparameter is a parameter whose value is set before the learning process begins. It determines how a
network is trained and the structure of the network (such as the number of hidden units, the learning rate,
epochs, etc.).
Q78. What Will Happen If the Learning Rate Is Set inaccurately (Too Low or Too High)?
When your learning rate is too low, training of the model will progress very slowly as we are making minimal
updates to the weights. It will take many updates before reaching the minimum point.
If the learning rate is set too high, this causes undesirable divergent behaviour to the loss function due to
drastic updates in weights. It may fail to converge (model can give a good output) or even diverge (data is
too chaotic for the network to train).
Q79. What Is the Difference Between Epoch, Batch, and Iteration in Deep Learning?
    •    Epoch – Represents one iteration over the entire dataset (everything put into the training model).
    •    Batch – Refers to when we cannot pass the entire dataset into the neural network at once, so we
         divide the dataset into several batches.
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
    •    Iteration – if we have 10,000 images as data and a batch size of 200. then an epoch should run 50
         iterations (10,000 divided by 50).
    1. Convolutional Layer – the layer that performs a convolutional operation, creating several smaller
        picture windows to go over the data.
    2. ReLU Layer – it brings non-linearity to the network and converts all the negative pixels to zero. The
        output is a rectified feature map.
    3. Pooling Layer – pooling is a down-sampling operation that reduces the dimensionality of the feature
        map.
    4. Fully Connected Layer – this layer recognizes and classifies the objects in the image.
                                                                                           Q81. What           Is
Pooling on CNN, and How Does It Work?
Pooling is used to reduce the spatial dimensions of a CNN. It performs down-sampling operations to reduce
the dimensionality and creates a pooled feature map by sliding a filter matrix over the input matrix.
Q82. What are Recurrent Neural Networks(RNNs)?
RNNs are a type of artificial neural networks designed to recognise the pattern from the sequence of data
such as Time series, stock market and government agencies etc. To understand recurrent nets, first, you
have to understand the basics of feedforward nets.
Both these networks RNN and feed-forward named after the way they channel information through a series
of mathematical orations performed at the nodes of the network. One feeds information through
straight(never touching the same node twice), while the other cycles it through a loop, and the latter are
called recurrent.
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
Recurrent networks, on the other hand, take as their input, not just the current input example they see, but
also the what they have perceived previously in time.
The decision a recurrent neural network reached at time t-1 affects the decision that it will reach one moment
later at time t. So recurrent networks have two sources of input, the present and the recent past, which
combine to determine how they respond to new data, much as we do in life.
The error they generate will return via backpropagation and be used to adjust their weights until error can’t
go any lower. Remember, the purpose of recurrent nets is to accurately classify sequential input. We rely on
the backpropagation of error and gradient descent to do so.
Q83. How Does an LSTM Network Work?
Long-Short-Term Memory (LSTM) is a special kind of recurrent neural network capable of learning long-
term dependencies, remembering information for long periods as its default behaviour. There are three
steps in an LSTM network:
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
As in Neural Networks, MLPs have an input layer, a hidden layer, and an output layer. It has the
same structure as a single layer perceptron with one or more hidden layers. A single layer perceptron can
classify only linear separable classes with binary output (0,1), but MLP can classify nonlinear classes.
A gradient measures how much the output of a function changes if you change the inputs a little bit. It
simply measures the change in all weights with regard to the change in error. You can also think of a
gradient as the slope of a function.
Gradient Descent can be thought of climbing down to the bottom of a valley, instead of climbing up a
hill. This is because it is a minimization algorithm that minimizes a given function (Activation Function).
                                                                                             Q86. What is
exploding gradients?
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
While training an RNN, if you see exponentially growing (very large) error gradients which accumulate
and result in very large updates to neural network model weights during training, they’re known as
exploding gradients. At an extreme, the values of weights can become so large as to overflow and result in
NaN values.
This has the effect of your model is unstable and unable to learn from your training data.
While training an RNN, your slope can become either too small; this makes the training difficult. When the
slope is too small, the problem is known as a Vanishing Gradient. It leads to long training times, poor
performance, and low accuracy.
Q89. What is Back Propagation and Explain it’s Working.
Backpropagation is a training algorithm used for multilayer neural network. In this method, we move the
error from an end of the network to all weights inside the network and thus allowing efficient computation of
the gradient.
It has the following steps:
    •    Stochastic Gradient Descent: We use only a single training example for calculation of gradient and
         update parameters. Batch Gradient Descent: We calculate the gradient for the whole dataset and
    •    perform the update at each iteration. Mini-batch Gradient Descent: It’s one of the most popular
         optimization algorithms. It’s a variant of Stochastic Gradient Descent and here instead of single training
    •    example, mini-batch of samples is used.
    •    Pytorch
    •    TensorFlow
    •    Microsoft Cognitive Toolkit
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
    •    Keras
    •    Caffe
    •    Chainer
The Activation function is used to introduce non-linearity into the neural network helping it to learn more
complex function. Without which the neural network would be only able to learn linear function which is a
linear combination of its input data. An activation function is a function in an artificial neuron that delivers an
output based on inputs.
                                 Purpose                                                          Libraries
 Scientific Computation                                                          Numpy
 Tabular Data                                                                    Pandas
 Data Modelling & Preprocessing                                                  Scikit Learn
 Time-Series Analysis                                                            Statsmodels
 Text processing                                                                 Regular Expressions, NLTK
 Deep Learning                                                                   Tensorflow, Pytorch
Q94. What is an Auto-Encoder?
Auto-encoders are simple learning networks that aim to transform inputs into outputs with the minimum
possible error. This means that we want the output to be as close to input as possible. We add a couple of
layers between the input and the output, and the sizes of these layers are smaller than the input layer. The
auto-encoder receives unlabelled input which is then encoded to reconstruct the input.
Boltzmann machines have a simple learning algorithm that allows them to discover interesting features that
represent complex regularities in the training data. The Boltzmann machine is basically used to optimise the
weights and the quantity for the given problem. The learning algorithm is very slow in networks with many
layers of feature detectors. “Restricted Boltzmann Machines” algorithm has a single layer of feature detectors
which makes it faster than the rest.
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
                                                              Q96. What Is Dropout and Batch Normalization?
Dropout is a technique of dropping out hidden and visible units of a network randomly to prevent overfitting
of data (typically dropping 20 per cent of the nodes). It doubles the number of iterations needed to converge
the network.
Batch normalization is the technique to improve the performance and stability of neural networks by
normalizing the inputs in every layer so that they have mean output activation of zero and standard deviation
of one.
Q97. What Is the Difference Between Batch Gradient Descent and Stochastic Gradient
Descent?
Tensorflow provides both C++ and Python APIs, making it easier to work on and has a faster compilation time
compared to other Deep Learning libraries like Keras and Torch. Tensorflow supports both CPU and GPU
computing devices.
Q99. What Do You Mean by Tensor in Tensorflow?
A tensor is a mathematical object represented as arrays of higher dimensions. These arrays of data with
different dimensions and ranks fed as input to the neural network are called “Tensors.”
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
  Q100. What is the Computational Graph?
  Everything in a tensorflow is based on creating a computational graph. It has a network of nodes where each
  node operates, Nodes represent mathematical operations, and edges represent tensors. Since data flows in
  the form of a graph, it is also called a “DataFlow Graph.”
Q101. What are the differences between supervised and unsupervised learning?
             vector
             machine
  Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
The formula and graph for the sigmoid function are as shown:
4. Choose the attribute with the highest information gain as the root node
5. Repeat the same procedure on every branch until the decision node of each branch is finalized
For example, let's say you want to build a decision tree to decide whether you should accept or decline a
job offer. The decision tree for this case is as shown:
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
It is clear from the decision tree that an offer is accepted if:
A random forest is built up of a number of decision trees. If you split the data into different packages and
make a decision tree in each of the different groups of data, the random forest brings all those trees
together.
1. Randomly select 'k' features from a total of'm' features where k << m
2. Among the 'k' features, calculate the node D using the best split point
3. Split the node into daughter nodes using the best split
4. Repeat steps two and three until leaf nodes are finalized
5. Build forest by repeating steps one to four for 'n' times to create 'n' number of trees
Overfitting refers to a model that is only set for a very small amount of data and ignores the bigger picture.
There are three main methods to avoid overfitting:
1. Keep the model simple—take fewer variables into account, thereby removing some of the noise in the
    training data
Univariate data contains only one variable. The purpose of the univariate analysis is to describe the data
and find patterns that exist within it.
164
167.3
170
174.2
178
180
The patterns can be studied by drawing conclusions using mean, median, mode, dispersion or range,
minimum, maximum, etc.
Bivariate
Bivariate data involves two different variables. The analysis of this type of data deals with causes and
relationships and the analysis is done to determine the relationship between the two variables.
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
       Temperature (in Celcius)                                                         Sales
20 2,000
25 2,100
26 2,300
28 2,400
30 2,600
36 3,100
Here, the relationship is visible from the table that temperature and sales are directly proportional to each
other. The hotter the temperature, the better the sales.
Multivariate
Multivariate data involves three or more variables, it is categorized under multivariate. It is similar to a
bivariate, but contains more than one dependent variable.
2 0 900 $4000,00
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
       3                                     2                           1,100      $600,000
4 3 2,100 $1,200,000
The patterns can be studied by drawing conclusions using mean, median, and mode, dispersion or range,
minimum, maximum, etc. You can start describing the data and using it to guess what the price of the
house will be.
107. What are the feature selection methods used to select the right variables?
Filter Methods
This involves:
The best analogy for selecting features is "bad data in, bad answer out." When we're limiting or selecting
the features, it's all about cleaning up the data coming in.
Wrapper Methods
This involves:
• Forward Selection: We test one feature at a time and keep adding them until we get a good fit
• Backward Selection: We test all the features and start removing them to see what works better
•   Recursive Feature Elimination: Recursively looks through all the different features and how they pair
    together
Wrapper methods are very labor-intensive, and high-end computers are needed if a lot of data analysis is
performed with the wrapper method.
108. In your choice of language, write a program that prints the numbers ranging from
one to 50.
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
But for multiples of three, print "Fizz" instead of the number and for the multiples of five, print "Buzz." For
numbers which are multiples of both three and five, print "FizzBuzz"
Note that the range mentioned is 51, which means zero to 50. However, the range asked in the question is
one to 50. Therefore, in the above code, you can include the range as (1,51).
109. You are given a data set consisting of variables with more than 30 percent missing
values. How will you deal with them?
If the data set is large, we can just simply remove the rows with missing data values. It is the quickest way;
we use the rest of the data to predict the values.
For smaller data sets, we can substitute missing values with the mean or average of the rest of the data
using pandas data frame in python. There are different ways to do so, such as df.mean(), df.fillna(mean).
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
110. For the given points, how will you calculate the Euclidean distance in Python?
plot1 = [1,3]
plot2 = [2,5]
This reduction helps in compressing data and reducing storage space. It also reduces computation time as
fewer dimensions lead to less computing. It removes redundant features; for example, there's no point in
storing a value in two different units (meters and inches).
112. How will you calculate eigenvalues and eigenvectors of the following 3x3 matrix?
-2 -4 2
-2 1 2
4 2 5
Expanding determinant:
- λ3 + 4λ2 + 27λ – 90 = 0,
λ3 - 4 λ2 -27 λ + 90 = 0
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
33 – 4 x 32 - 27 x 3 +90 = 0
Hence, (λ - 3) is a factor:
For X = 1,
-5 - 4Y + 2Z =0,
-2 - 2Y + 2Z =0
3 + 2Y = 0,
Y = -(3/2)
Z = -(1/2)
Monitor
Constant monitoring of all models is needed to determine their performance accuracy. When you change
something, you want to figure out how your changes are going to affect things. This needs to be monitored
to ensure it's doing what it's supposed to do.
Evaluate
Evaluation metrics of the current model are calculated to determine if a new algorithm is needed.
Compare
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
The new models are compared to each other to determine which model performs the best.
Rebuild
A recommender system predicts what a user would rate a specific product based on their preferences. It
can be split into two different areas:
Collaborative filtering
As an example, Last.fm recommends tracks that other users with similar interests play often. This is also
commonly seen on Amazon after making a purchase; customers may notice the following message
accompanied by product recommendations: "Users who bought this also bought…"
Content-based filtering
As an example: Pandora uses the properties of a song to recommend music with similar properties. Here,
we look at content, instead of looking at who else is listening to music.
115. How do you find RMSE and MSE in a linear regression model?
RMSE and MSE are two of the most common measures of accuracy for a linear regression model.
We use the elbow method to select k for k-means clustering. The idea of the elbow method is to run k-
means clustering on the data set where 'k' is the number of clusters.
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
Within the sum of squares (WSS), it is defined as the sum of the squared distance between each member
of the cluster and its centroid.
This indicates strong evidence against the null hypothesis; so you reject the null hypothesis.
This indicates weak evidence against the null hypothesis, so you accept the null hypothesis.
Example: height of an adult = abc ft. This cannot be true, as the height cannot be a string value. In this
case, outliers can be removed.
If the outliers have extreme values, they can be removed. For example, if all the data points are clustered
between zero to 10, but one point lies at 100, then we can remove this point.
•   Try a different model. Data detected as outliers by linear models can be fit by nonlinear models.
    Therefore, be sure you are choosing the correct model.
•   Try normalizing the data. This way, the extreme data points are pulled to a similar range.
•   You can use algorithms that are less affected by outliers; an example would be random forests.
It is stationary when the variance and mean of the series are constant with time.
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
In the first graph, the variance is constant with time. Here, X is the time factor and Y is the variable. The
value of Y goes through the same points all the time; in other words, it is stationary.
In the second graph, the waves get bigger, which means it is non-stationary and the variance is changing
with time.
You can see the values for total data, actual values, and predicted values.
= 609 / 650
= 0.93
121. Write the equation and calculate the precision and recall rate.
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
Consider the same confusion matrix used in the previous question.
= 262 / 277
= 0.94
= 262 / 288
= 0.90
122. 'People who bought this also bought…' recommendations seen on Amazon are a
result of which algorithm?
The recommendation engine is accomplished with collaborative filtering. Collaborative filtering explains the
behavior of other users and their purchase history in terms of ratings, selection, etc.
The engine makes predictions on what might interest a person based on the preferences of other users. In
this algorithm, item features are unknown.
For example, a sales page shows that a certain number of people buy a new phone and also buy
tempered glass at the same time. Next time, when a person buys a phone, he or she may see a
recommendation to buy tempered glass as well.
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
Suppose there is a wine shop purchasing wine from dealers, which they resell later. But some dealers sell
fake wine. In this case, the shop owner should be able to distinguish between fake and authentic wine.
The forger will try different techniques to sell fake wine and make sure specific techniques go past the shop
owner’s check. The shop owner would probably get some feedback from wine experts that some of the wine
is not original. The owner would have to improve how he determines whether a wine is fake or authentic.
The forger’s goal is to create wines that are indistinguishable from the authentic ones while the shop owner
intends to tell if the wine is real or not accurately
Let us understand this example with the help of an image.
The Discriminator gets two inputs; one is the fake wine, while the other is the real authentic wine. The shop
owner has to figure out whether it is real or fake.
So, there are two primary components of Generative Adversarial Network (GAN) named:
    1. Generator
    2. Discriminator
The generator is a CNN that keeps keys producing images and is closer in appearance to the real images
while the discriminator tries to determine the difference between real and fake images The ultimate aim is to
make the discriminator learn to identify real and fake images.
Apart from the very technical questions, your interviewer could even hit you up with a few simple ones to
check your overall confidence, in the likes of the following.
124. You are given a dataset on cancer detection. You have built a classification model
and achieved an accuracy of 96 percent. Why shouldn't you be happy with your model
performance? What can you do about it?
Cancer detection results in imbalanced data. In an imbalanced dataset, accuracy should not be based as a
measure of performance. It is important to focus on the remaining four percent, which represents the
patients who were wrongly diagnosed. Early diagnosis is crucial when it comes to cancer detection, and
can greatly improve a patient's prognosis.
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
Hence, to evaluate model performance, we should use Sensitivity (True Positive Rate), Specificity (True
Negative Rate), F measure to determine the class wise performance of the classifier.
125. Which of the following machine learning algorithms can be used for inputting
missing values of both categorical and continuous variables?
•   K-means clustering
•   Linear regression
•
    K-NN (k-nearest neighbor)
•
    Decision trees
The K nearest neighbor algorithm can be used because it can compute the nearest neighbor and if it
doesn't have a value, it just computes the nearest neighbor based on all the other features.
When you're dealing with K-means clustering or linear regression, you need to do that in your pre-
processing, otherwise, they'll crash. Decision trees also have the same problem, although there is some
variance.
126. Below are the eight actual values of the target variable in the train file. What is the
entropy of the target variable?
[0, 0, 0, 1, 1, 1, 1, 1]
127. We want to predict the probability of death from heart disease based on three risk
factors: age, gender, and blood cholesterol level. What is the most appropriate
algorithm for this case?
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
1. Logistic Regression
2. Linear Regression
3. K-means clustering
4. Apriori algorithm
128. After studying the behavior of a population, you have identified four specific
individual types that are valuable to your study. You would like to find all users who are
most similar to each individual type. Which algorithm is most appropriate for this
study?
1. K-means clustering
2. Linear regression
3. Association rules
4. Decision trees
As we are looking for grouping people together specifically by four different similarities, it indicates the
value of k. Therefore, K-means clustering (answer A) is the most appropriate algorithm for this study.
129. You have run the association rules algorithm on your dataset, and the two rules
{banana, apple} => {grape} and {apple, orange} => {grape} have been found to be
relevant. What else must be true?
130. Your organization has a website where visitors randomly receive one of two
coupons. It is also possible that visitors to the website will not receive a coupon. You
have been asked to determine if offering a coupon to website visitors has any impact on
their purchase decisions. Which analysis method should you use?
1. One-way ANOVA
2. K-means clustering
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
3. Association rules
4. Student's t-test
A feature vector is an n-dimensional vector of numerical features that represent an object. In machine
learning, feature vectors are used to represent numeric or symbolic characteristics (called features) of an
object in a mathematical way that's easy to analyze.
Root cause analysis was initially developed to analyze industrial accidents but is now widely used in other
areas. It is a problem-solving technique used for isolating the root causes of faults or problems. A factor is
called a root cause if its deduction from the problem-fault-sequence averts the final undesirable event from
recurring.
Logistic regression is also known as the logit model. It is a technique used to forecast the binary outcome
from a linear combination of predictor variables.
Recommender systems are a subclass of information filtering systems that are meant to predict the
preferences or ratings that a user would give to a product.
The goal of cross-validation is to term a data set to test the model in the training phase (i.e. validation data
set) to limit problems like overfitting and gain insight into how the model will generalize to an independent
data set.
Most recommender systems use this filtering process to find patterns and information by collaborating
perspectives, numerous data sources, and several agents.
They do not, because in some cases, they reach a local minima or a local optima point. You would not
reach the global optima point. This is governed by the data and the starting conditions.
This is statistical hypothesis testing for randomized experiments with two variables, A and B. The objective
of A/B testing is to detect any changes to a web page to maximize or increase the outcome of a strategy.
It is a theorem that describes the result of performing the same experiment very frequently. This theorem
forms the basis of frequency-style thinking. It states that the sample mean, sample variance and sample
standard deviation converge to what they are trying to estimate.
These are extraneous variables in a statistical model that correlates directly or inversely with both the
dependent and the independent variable. The estimate fails to account for the confounding factor.
It is a traditional database schema with a central table. Satellite tables map IDs to physical names or
descriptions and can be connected to the central fact table using the ID fields; these tables are known as
Follow Steve Nouri for more AI and Data science posts: https://lnkd.in/gZu463X
lookup tables and are principally useful in real-time applications, as they save a lot of memory. Sometimes,
star schemas involve several layers of summarization to recover information faster.
Eigenvalues are the directions along which a particular linear transformation acts by flipping, compressing,
or stretching.
Eigenvectors are for understanding linear transformations. In data analysis, we usually calculate the
eigenvectors for a correlation or covariance matrix.
•   Estimating the accuracy of sample statistics by using subsets of accessible data, or drawing randomly
    with replacement from a set of data points
•   Substituting labels on data points when performing significance tests
•   Validating models by using random subsets (bootstrapping, cross-validation)
Selection bias, in general, is a problematic situation in which error is introduced due to a non-random
population sample.
148. What are the types of biases that can occur during sampling?
1. Selection bias
2. Undercoverage bias
3. Survivorship bias
The underlying principle of this technique is that several weak learners combine to provide a strong
learner. The steps involved are:
151. What are the important skills to have in Python with regard to data analysis?
The following are some of the important skills to possess which will come handy when performing data
analysis using Python.
    •    Good understanding of the built-in data types especially lists, dictionaries, tuples, and sets.
    •    Mastery of N-dimensional NumPy Arrays.
    •
    •    Mastery of Pandas dataframes.
    •    Ability to perform element-wise vector and matrix operations on NumPy arrays.
    •    Knowing that you should use the Anaconda distribution and the conda package manager.
    •    Familiarity with Scikit-learn. **Scikit-Learn Cheat Sheet**
    ••
         Ability to write efficient list comprehensions instead of traditional for loops.
         Ability to write small, clean functions (important for any developer), preferably pure functions that don’t
         alter objects.
         Knowing how to profile the performance of a Python script and how to optimize bottlenecks.