Skip to main content

YiJian-Community

Project description

YiJian-Community: Full-Process Automated Large Model Safety Evaluation Tool

The support for the Global AI Offensive and Defensive Challenge — Track 1: Vaccination for Text-to-Image Generative Models will be ready in just a few days.

What is YiJian?

YiJian-Professional

For risks such as large model hallucinations, ideologies, and privacy, based on domestic and international laws and regulations, academic research, and enterprise needs, YiJian has built a comprehensive risk taxonomy. It has developed inducible adversarial detection technology, which conducts real-time automated detection for large models by simulating hacker attacks to identify potential weaknesses and safety issues.

Platform Architecture

YiJian-Professional offers comprehensive, intelligent, efficient, and user-friendly industrial-grade large model safety evaluation capabilities.

  • Comprehensiveness
    • Evaluation Data: Hundred-Billion-level risk data in the safety domain;
    • Risk Taxonomy: Four major categories—Content Safety, Data Safety, Ethics Safety, and Compliance Safety, with over 200 sub-categories;
    • Data Modalities: Text, image, audio, video;
    • Evaluation Objects: Base models, domain models, Agents;
    • Attack Methods: Over 50 advanced attack techniques;
  • Intelligence
    • Intelligent generation of test data;
    • Multi-round dialogue adaptive attacks;
    • Intelligent recognition of risks, refusals, and attack methods;
  • Efficience
    • Ten-Billion-level risk preliminary screening per day;
    • Billion-level data fine-grained annotation per day;
    • Hour-level evaluation report generation;
  • User-Friendly
    • One-stop evaluation, requiring only account registration and model API interface provision to initiate the evaluation;

YiJian-Community

The importance of large model safety evaluation has been well recognized worldwide. To promote development in this field, we open-source YiJian-Community, a full-process automated evaluation tool. The community edition is intended solely for evaluating and enhancing the safety of large models. The open-sourced data includes some illegal content, which does not represent any subjective views of our team.

Project Overview

Core components of YiJian-Community include:

  • data

    • Natively supports data in CSV, JSON, and Parquet formats. Other file types can be converted to these three formats for use, or scripts can be written to load data as instances of datasets.Dataset;

    • Not limited by language, can be used to assess any language;

      For details of the risk taxonomy and data samples, please refer to data_en.md.

  • technique

    • Provides implementations of 13 adversarial attack methods for text-to-text large models and introductions of 7 methods;

    • Provides implementations of 5 adversarial attack methods for text-to-image large models and introductions of 4 methods;

      Detials can be found at technique_en.md.

  • model

    • Supports loading and inference for all text-to-text and text-to-image large models on Hugging Face;
    • Supports API access for mainstream closed-source large models, e.g., GPT-4;
    • Supports loading and inference of any other format models (requires inheriting the Infer base class);
  • evaluator

    • Provides diverse large model safety evaluation metrics, such as attack success rate and decline rate;
    • Provides lightweight automated risk assessment methods;
    • Supports JailbreakEval;

By configuring the above four components (technique is optional), automated evaluation can be achieved.

How to Use?

Installation

It is recommended to create a new conda environment and use it there

conda create -n yijian python=3.10
conda activate yijian

PIP Installation

pip install yijian-community==0.1.2

Source Code Installation

git clone https://github.com/yijian-community/yijian-community.git
cd yijian-community
pip install .

Quick Start

  1. Environment Setup
    # If you cannot access 🤗 Hugging Face
    export HF_ENDPOINT="https://hf-mirror.com"
    
  2. Load Evaluation Data
    from yijian_community.data import load_data
    
    test_set = load_data("path/to/samples_50_en.jsonl")
    
  3. Attack Enhancement (Optional)
    from yijian_community.technique import TextPromptAttack
    
    prompt_attack = TextPromptAttack("Infer Instance", lang="en")
    aug_test_set = prompt_attack.attack_dataset(test_set)
    
    For details of the attack techniques, see technique_en.md.
  4. Configuration of the target Model to be evaluated
    from yijian_community.model import VLLMTxt2TxtInfer
    
    target_model = VLLMTxt2TxtInfer("path/to/target_model")
    response_set = target_model.infer_dataset(test_set, batch_size=32, target_column="prompt_text")
    
  5. Initiate Evaluation
    from yijian_community.evaluator import NaiveTextSimilarityTagger
    
    naive_tagger = NaiveTextSimilarityTagger("Embedding Model Instance")
    tagged_result_set = naive_tagger(response_set)
    

For more examples, please refer to the examples folder.

Advanced Features

For more comprehensive and accurate or customized evaluations, please apply to use YiJian-Professional.

Important Notices

Contribution

The development of large models is unstoppable, and ensuring their safety is essential. We look forward to more people joining us to build the YiJian open-source ecosystem together, ensuring the security and safety of large models and artificial intelligence.

Contact Us

Under construction, stay tuned!

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

yijian_community-0.1.2.tar.gz (47.5 kB view details)

Uploaded Source

Built Distribution

yijian_community-0.1.2-py3-none-any.whl (75.8 kB view details)

Uploaded Python 3

File details

Details for the file yijian_community-0.1.2.tar.gz.

File metadata

  • Download URL: yijian_community-0.1.2.tar.gz
  • Upload date:
  • Size: 47.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.11.9

File hashes

Hashes for yijian_community-0.1.2.tar.gz
Algorithm Hash digest
SHA256 861daadb190203609fb76ccd116a38a667023f3c6f9b3e41dd22e9d96001a9fd
MD5 f3f0d0be3044429fdb47c20fac500110
BLAKE2b-256 28f7ffa87ffacff69b42aa205c36c277bd7a3c66be83cdc3675331a950d686f6

See more details on using hashes here.

File details

Details for the file yijian_community-0.1.2-py3-none-any.whl.

File metadata

File hashes

Hashes for yijian_community-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 7c82fa58c62df27ad2399e5a95ebf8dfd257e5d156c6ad57032552a574698049
MD5 fe40f3459e83d7c20592dd4b559632bd
BLAKE2b-256 097000a0cd05048d0d6c0ad9532bacf0f203c3c03847e6ede7270d4ff0b4af01

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page