Data
KDDCup99

KDDCup99

active ARFF Publicly available Visibility: public Uploaded 04-12-2020 by Marcos de Paula Bueno
0 likes downloaded by 0 people , 0 total downloads 0 issues 0 downvotes
Issue #Downvotes for this reason By


Loading wiki
Help us complete this description Edit
INTRUSION DETECTOR LEARNING Software to detect network intrusions protects a computer network from unauthorized users, including perhaps insiders. The intrusion detector learning task is to build a predictive model (i.e. a classifier) capable of distinguishing between "bad" connections, called intrusions or attacks, and "good" normal connections. The 1998 DARPA Intrusion Detection Evaluation Program was prepared and managed by MIT Lincoln Labs. The objective was to survey and evaluate research in intrusion detection. A standard set of data to be audited, which includes a wide variety of intrusions simulated in a military network environment, was provided. The 1999 KDD intrusion detection contest uses a version of this dataset. Lincoln Labs set up an environment to acquire nine weeks of raw TCP dump data for a local-area network (LAN) simulating a typical U.S. Air Force LAN. They operated the LAN as if it were a true Air Force environment, but peppered it with multiple attacks. The raw training data was about four gigabytes of compressed binary TCP dump data from seven weeks of network traffic. This was processed into about five million connection records. Similarly, the two weeks of test data yielded around two million connection records. A connection is a sequence of TCP packets starting and ending at some well defined times, between which data flows to and from a source IP address to a target IP address under some well defined protocol. Each connection is labeled as either normal, or as an attack, with exactly one specific attack type. Each connection record consists of about 100 bytes. Attacks fall into four main categories: * DOS: denial-of-service, e.g. syn flood; * R2L: unauthorized access from a remote machine, e.g. guessing password; * U2R: unauthorized access to local superuser (root) privileges, e.g., various "buffer overflow" attacks; * probing: surveillance and other probing, e.g., port scanning. It is important to note that the test data is not from the same probability distribution as the training data, and it includes specific attack types not in the training data. This makes the task more realistic. Some intrusion experts believe that most novel attacks are variants of known attacks and the "signature" of known attacks can be sufficient to catch novel variants. The datasets contain a total of 24 training attack types, with an additional 14 types in the test data only. DERIVED FEATURES Stolfo et al. defined higher-level features that help in distinguishing normal connections from attacks. There are several categories of derived features. The "same host" features examine only the connections in the past two seconds that have the same destination host as the current connection, and calculate statistics related to protocol behavior, service, etc. The similar "same service" features examine only the connections in the past two seconds that have the same service as the current connection. "Same host" and "same service" features are together called time-based traffic features of the connection records. Some probing attacks scan the hosts (or ports) using a much larger time interval than two seconds, for example once per minute. Therefore, connection records were also sorted by destination host, and features were constructed using a window of 100 connections to the same host instead of a time window. This yields a set of so-called host-based traffic features. Unlike most of the DOS and probing attacks, there appear to be no sequential patterns that are frequent in records of R2L and U2R attacks. This is because the DOS and probing attacks involve many connections to some host(s) in a very short period of time, but the R2L and U2R attacks are embedded in the data portions of packets, and normally involve only a single connection. Useful algorithms for mining the unstructured data portions of packets automatically are an open research question. Stolfo et al. used domain knowledge to add features that look for suspicious behavior in the data portions, such as the number of failed login attempts. These features are called "content" features. A complete listing of the set of features defined for the connection records is given in the three tables below. The data schema of the contest dataset is available in machine-readable form . feature namedescription type * duration length (number of seconds) of the connection continuous * protocol_type type of the protocol, e.g. tcp, udp, etc. discrete * service network service on the destination, e.g., http, telnet, etc. discrete * src_bytes number of data bytes from source to destination continuous * dst_bytes number of data bytes from destination to source continuous * flag normal or error status of the connection discrete * land 1 if connection is from/to the same host/port; 0 otherwise discrete * wrong_fragment number of "wrong" fragments continuous * urgent number of urgent packets continuous Table 1: Basic features of individual TCP connections. feature namedescription type * hot number of "hot" indicatorscontinuous * num_failed_logins number of failed login attempts continuous * logged_in 1 if successfully logged in; 0 otherwise discrete * num_compromised number of "compromised" conditions continuous * root_shell 1 if root shell is obtained; 0 otherwise discrete * su_attempted 1 if "su root" command attempted; 0 otherwise discrete * num_root number of "root" accesses continuous * num_file_creations number of file creation operations continuous * num_shells number of shell prompts continuous * num_access_files number of operations on access control files continuous * num_outbound_cmdsnumber of outbound commands in an ftp session continuous * is_hot_login 1 if the login belongs to the "hot" list; 0 otherwise discrete * is_guest_login 1 if the login is a "guest"login; 0 otherwise discrete Table 2: Content features within a connection suggested by domain knowledge. feature namedescription type * count number of connections to the same host as the current connection in the past two seconds continuous Note: The following features refer to these same-host connections. * serror_rate % of connections that have "SYN" errors continuous * rerror_rate % of connections that have "REJ" errors continuous * same_srv_rate % of connections to the same service continuous * diff_srv_rate % of connections to different services continuous * srv_count number of connections to the same service as the current connection in the past two seconds continuous Note: The following features refer to these same-service connections. * srv_serror_rate % of connections that have "SYN" errors continuous * srv_rerror_rate % of connections that have "REJ" errors continuous * srv_diff_host_rate % of connections to different hosts continuous Table 3: Traffic features computed using a two-second time window.

42 features

target (target)nominal23 unique values
0 missing
durationnumeric9883 unique values
0 missing
protocol_typenominal3 unique values
0 missing
servicenominal70 unique values
0 missing
flagnominal11 unique values
0 missing
src_bytesnumeric7195 unique values
0 missing
dst_bytesnumeric21493 unique values
0 missing
landnominal2 unique values
0 missing
wrong_fragmentnumeric3 unique values
0 missing
urgentnumeric6 unique values
0 missing
hotnumeric30 unique values
0 missing
num_failed_loginsnumeric6 unique values
0 missing
logged_innominal2 unique values
0 missing
num_compromisednumeric98 unique values
0 missing
root_shellnominal2 unique values
0 missing
su_attemptednominal3 unique values
0 missing
num_rootnumeric93 unique values
0 missing
num_file_creationsnumeric42 unique values
0 missing
num_shellsnumeric3 unique values
0 missing
num_access_filesnumeric10 unique values
0 missing
num_outbound_cmdsnumeric1 unique values
0 missing
is_host_loginnominal2 unique values
0 missing
is_guest_loginnominal2 unique values
0 missing
countnumeric512 unique values
0 missing
srv_countnumeric512 unique values
0 missing
serror_ratenumeric96 unique values
0 missing
srv_serror_ratenumeric87 unique values
0 missing
rerror_ratenumeric89 unique values
0 missing
srv_rerror_ratenumeric76 unique values
0 missing
same_srv_ratenumeric101 unique values
0 missing
diff_srv_ratenumeric95 unique values
0 missing
srv_diff_host_ratenumeric72 unique values
0 missing
dst_host_countnumeric256 unique values
0 missing
dst_host_srv_countnumeric256 unique values
0 missing
dst_host_same_srv_ratenumeric101 unique values
0 missing
dst_host_diff_srv_ratenumeric101 unique values
0 missing
dst_host_same_src_port_ratenumeric101 unique values
0 missing
dst_host_srv_diff_host_ratenumeric76 unique values
0 missing
dst_host_serror_ratenumeric101 unique values
0 missing
dst_host_srv_serror_ratenumeric100 unique values
0 missing
dst_host_rerror_ratenumeric101 unique values
0 missing
dst_host_srv_rerror_ratenumeric101 unique values
0 missing

19 properties

4898431
Number of instances (rows) of the dataset.
42
Number of attributes (columns) of the dataset.
23
Number of distinct values of the target attribute (if it is nominal).
0
Number of missing values in the dataset.
0
Number of instances with at least one value missing.
32
Number of numeric attributes.
10
Number of nominal attributes.
11.9
Percentage of binary attributes.
0
Percentage of instances having missing values.
0
Percentage of missing values.
1
Average class difference between consecutive instances.
76.19
Percentage of numeric attributes.
0
Number of attributes divided by the number of instances.
23.81
Percentage of nominal attributes.
57.32
Percentage of instances belonging to the most frequent class.
2807886
Number of instances belonging to the most frequent class.
0
Percentage of instances belonging to the least frequent class.
2
Number of instances belonging to the least frequent class.
5
Number of binary attributes.

3 tasks

0 runs - estimation_procedure: 10-fold Crossvalidation - evaluation_measure: predictive_accuracy - target_feature: target
0 runs - estimation_procedure: 4-fold Crossvalidation - target_feature: target
0 runs - estimation_procedure: 10-fold Crossvalidation - target_feature: target
Define a new task