## load another dataset
TYPE_OF_VUL = [22, 78, 79, 89, 125, 126, 131, 189, 190, 200, 209, 215, 310, 327, 330, 377, 404, 416, 476, 787, 892]
Prompts_OF_VUL = {
        'cwe-022':'CWE-22, commonly called “Path Traversal,” is a vulnerability when an application fails to appropriately limit the paths users can access through a user-provided input.',
        'cwe-078':'CWE-78, means improper neutralization of special elements used in an OS command (OS command injection), constructs all or part of an OS command using externally-influenced input from an upstream component, but it does not neutralize or incorrectly neutralizes special elements that could modify the intended OS command when it is sent to a downstream component.',
        'cwe-079':'CWE-79, improper neutralization of input during web page generation (cross-site scripting). The code does not neutralize or incorrectly neutralizes user-controllable input before it is placed in output that is used as a web page that is served to other users.',
        'cwe-089':'CWE-89, Improper Neutralization of Special Elements used in an SQL Command (SQL Injection). The product constructs all or part of an SQL command using externally-influenced input from an upstream component, but it does not neutralize or incorrectly neutralizes special elements that could modify the intended SQL command when it is sent to a downstream component. Without sufficient removal or quoting of SQL syntax in user-controllable inputs, the generated SQL query can cause those inputs to be interpreted as SQL instead of ordinary user data.',
        'cwe-119':'CWE-119, Improper Restriction of Operations within the Bounds of a Memory Buffer. The product does not properly restrict the operations that can be performed on a memory buffer, such as reading or writing, based on the intended buffer boundaries.',
        'cwe-125':'CWE-125, Out-of-bounds Read. The product reads data past the end, or before the beginning, of the intended buffer.',
        'cwe-126':'CWE-126, Improper Validation of Array Index. The product does not validate or incorrectly validates the index of an array before using it to access an element of the array.',
        'cwe-131':'CWE-131, Incorrect Calculation of Buffer Size. The product calculates the size of a buffer incorrectly, such as using an incorrect starting index or count, or using an incorrect conversion between characters and bytes.',
        'cwe-189':'CWE-189, Improper Handling of Lengthy Sequences. The product does not properly handle sequences that are too long to process in a reasonable amount of time, such as excessively long strings or arrays.',
        'cwe-190':'CWE-190, Integer Overflow or Wraparound. The product performs a calculation that can produce an integer overflow or wraparound when the logic assumes that the resulting value will always be larger than the original value. This occurs when an integer value is incremented to a value that is too large to store in the associated representation. When this occurs, the value may become a very small or negative number.',
        'cwe-200':'CWE-200, Exposed Internal Components. The product exposes an internal component, interface, or resource to an attacker, which can be exploited to access sensitive information or perform malicious actions.',
        'cwe-209':'CWE-209, Improper Input Validation. The product does not validate or incorrectly validates user-supplied input before using it to make a security-critical decision or perform a security-critical action.',
        'cwe-215':'CWE-215, Information Exposure Through Sent Data. The product transmits data in a way that may expose sensitive information to an unintended actor.',
        'cwe-310':'CWE-310, Cryptographic Issues. The product uses weak cryptographic algorithms, or it does not use cryptographic algorithms at all, to protect sensitive information.',
        'cwe-327':'CWE-327, Use of a Broken or Risky Cryptographic Algorithm. The product uses a cryptographic algorithm that is broken or otherwise risky, such as a weak encryption algorithm, or it does not use cryptographic algorithms at all.',
        'cwe-330':'CWE-330, Use of Insufficiently Random Values. The product uses insufficiently random values, such as a predictable sequence of random numbers, to generate cryptographic keys, passwords, or other secrets.',
        'cwe-377':'CWE-377, Insecure Temporary File. The product creates a temporary file in a directory that is writable by other users, or in a directory that is world-writable, or in the user’s home directory, or in the current working directory, or in a directory that is not properly protected from unauthorized deletion.',
        'cwe-404':'CWE-404, Improper Resource Shutdown or Release. The product fails to release a resource when it is no longer needed, such as a file, socket, or database connection.',
        'cwe-416':'CWE-416, Use After Free. The product reuses or references memory after it has been freed. At some point afterward, the memory may be allocated again and saved in another pointer, while the original pointer references a location somewhere within the new allocation. Any operations using the original pointer are no longer valid because the memory "belongs" to the code that operates on the new pointer.',
        'cwe-476':'CWE-476, NULL Pointer Dereference. The product dereferences a pointer that it expects to be valid but is NULL.',
        'cwe-787':'CWE-787, Out-of-bounds Write. The product writes data past the end, or before the beginning, of the intended buffer.',
        'cwe-892':'CWE-892, Cross-Site Scripting (XSS). The product does not neutralize or incorrectly neutralizes user-controllable input before it is placed in output that is used as a web page that is served to other users.',
}

def load_model(args):
    saved_path = './analysis/saved_tensor/qwen257b'
    base_path = './analysis/'
    vector_dict = {}
    probe_dict = {}
    for vul in TYPE_OF_VUL:
        vector_dict[vul] = torch.load(f'{saved_path}/perp_vec_CWE-{vul[-3:]}.pt')
        vector_dict[vul] = vector_dict[vul].to(args.device)
        model_name = model_dir.split('/')[-1]
        path = base_path + f'linear_probe_{model_name}_CWE-{vul[-3:]}.pt'
        probe = torch.load(path)
        input_dim = probe['linear.weight'].shape[1]
        linear_layer = nn.Linear(input_dim, 2) 
        linear_layer.weight.data = probe['linear.weight']
        linear_layer.bias.data = probe['linear.bias']
        linear_layer.to(args.device)
        linear_layer.eval()
        probe_dict[vul] = linear_layer