찾다
백엔드 개발파이썬 튜토리얼Python 유전 알고리즘 Geatpy 도구 상자에 대한 간략한 소개

【관련 추천: Python3 동영상 튜토리얼

1. 유전 알고리즘이란 무엇인가요?

유전 알고리즘은 생물학적 유전학과 자연 선택의 메커니즘을 어느 정도 시뮬레이션하여 인위적으로 구축한 검색 알고리즘의 한 종류입니다. 생물학적 개체군의 생존 과정은 일반적으로 다윈의 진화 원리를 따릅니다. 개체군 내 개체는 환경에 적응하는 능력에 따라 자연적으로 선택되거나 제거됩니다. 진화 과정의 결과는 개체의 구조에 반영되며, 염색체에는 여러 유전자가 포함되어 있습니다. 표현형과 유전자형 사이의 해당 연결은 개체의 외부 특성과 내부 메커니즘 사이의 논리적 관계를 반영합니다. 개인 간의 교배와 돌연변이를 통해 자연환경에 적응합니다. 생물학적 염색체는 수학적으로 또는 컴퓨터적으로 염색체라고 불리는 일련의 숫자로 표시되며, 적응성은 염색체에 해당하는 숫자 값으로 측정되며 직면한 문제에 따라 결정됩니다. 또는 최소.

2. 유전자 알고리즘 라이브러리 Geatpy

2.1 유전자 알고리즘 도구 상자 Geatpy 매개변수 소개

API 공식 참조 문서

population 매개변수[중요 속성: Chrom, Phen, Objv, CV, FitnV]

  • sizes : int - 인구 규모, 즉 인구에 포함된 개인의 수입니다.
  • ChromNum: int - 염색체 수, 즉 각 개인이 가지고 있는 염색체 수입니다.
  • 인코딩: str - 염색체 인코딩 방법, 'BG': 바이너리/그레이 인코딩; 'RI': 실수와 정수의 혼합 인코딩, 'P': 순열 인코딩
  • Field: 배열 - 디코딩 행렬
  • Chrom: 배열 - 모집단 염색체 행렬, 각 행은 개인의 염색체에 해당합니다.
  • Lind : int - 모집단 염색체 길이.
  • ObjV: 배열 - 모집단 목적 함수 값 행렬, 각 행은 개인의 목적 함수 값에 해당하고, 각 열은 목적에 해당합니다.
  • FitnV: 배열 - 모집단 개인 적합성 열 벡터, 각 요소는 개인의 적합성에 해당합니다. 개인, 최소 적합도는 0
  • CV입니다. 배열 - CV(Constraint Violation Value)는 제약 조건의 위반 정도를 정량적으로 설명하는 데 사용되는 행렬입니다. 각 행은 개인에 해당하고, 각 열은 제약 조건에 해당합니다.
  • Phen: 배열 - 모집단 표현형 행렬(즉, 디코딩 후 모집단의 각 염색체가 나타내는 결정 변수로 구성된 행렬)입니다.
  • CV 행렬을 통해 타당성 규칙에 따라 제약 조건을 설정한 경우 부등식 제약 조건은 ≤이어야 하며, 등식 제약 조건은 abs()에 전달되어야 합니다(값이 클수록 피트니스가 작음)

    ea.Problem.
  • init() lbin 및 ubin(결정 변수 범위 경계 행렬)은 범위 구간의 열기 및 닫기를 나타냅니다. 1은 닫힌 구간이고 0은 열린 구간입니다

Geatpy 결과 매개변수 소개

success: True 또는 False, 알고리즘이 성공적으로 해결되었는지 여부를 나타냅니다.

success: True or False, 表示算法是否成功求解。

stopMsg: 存储着算法停止原因的字符串。

optPop: 存储着算法求解结果的种群对象。如果无可行解,则optPop.sizes=0。optPop.Phen为决策变量矩阵,optPop.ObjV为目标函数值矩阵。

lastPop: 算法进化结束后的最后一代种群对象。

Vars: 等于optPop.Phen,此处即最优解。若无可行解,则Vars=None。

ObjV: 等于optPop.ObjV,此处即最优解对应的目标函数值。若无可行解,ObjV=None。

CV: 等于optPop.CV,此处即最优解对应的违反约束程度矩阵。若无可行解,CV=None。

startTime: 程序执行开始时间。

endTime: 程序执行结束时间。

executeTime: 算法 所用时间。

nfev: 算法评价次数

gd: (多目标优化且给定了理论最优解时才有) GD指标值。

igd: (多目标优化且给定了理论最优解时才有) IGD指标值。

hv: (多目标优化才有) HV指标值。

spacingstopMsg: 알고리즘 중지 이유를 저장하는 문자열입니다.

🎜optPop: 알고리즘 솔루션 결과를 저장하는 인구 개체입니다. 실행 가능한 솔루션이 없으면 optPop.sizes=0입니다. optPop.Phen은 결정 변수 행렬이고, optPop.ObjV는 목적 함수 값 행렬입니다. 🎜🎜lastPop: 알고리즘 진화가 완료된 후 마지막 세대 인구 개체입니다. 🎜🎜Vars: optPop.Phen과 동일하며 여기에 최적의 솔루션이 있습니다. 실현 가능한 솔루션이 없으면 Vars=None입니다. 🎜🎜ObjV: 최적의 솔루션에 해당하는 목적 함수 값인 optPop.ObjV와 동일합니다. 실현 가능한 솔루션이 없으면 ObjV=None입니다. 🎜🎜CV: 최적의 솔루션에 해당하는 제약 위반 매트릭스인 optPop.CV와 동일합니다. 실현 가능한 솔루션이 없으면 CV=None입니다. 🎜🎜startTime: 프로그램 실행 시작 시간. 🎜🎜endTime: 프로그램 실행이 종료되는 시간입니다. 🎜🎜executeTime: 알고리즘에 소요되는 시간입니다. 🎜🎜nfev: 알고리즘 평가 횟수 🎜🎜gd: (다목적 최적화에만 사용 가능하며 이론적 최적 솔루션이 제공됨) GD 지수 값입니다. 🎜🎜igd: (다목적 최적화에만 사용 가능하며 이론적 최적 솔루션이 제공됨) IGD 지표 값입니다. 🎜🎜hv: (다목적 최적화에만 사용 가능) HV 표시 값입니다. 🎜🎜간격: (다목적 최적화에만 사용 가능) 간격 표시 값입니다. 🎜

3. 모범 사례

3.1 코드 예제 | 매개변수 템플릿

솔루션 세트:

header_regex = '|'.join(['{}'] * len(headers))
header_str = header_regex.format(*[str(key).center(width) for key, width in zip(headers, widths)])
print("=" * len(header_str))
            print(header_str)
            print("-" * len(header_str))

gen: 평가 횟수 기록
f_opt: 현대 최적의 개인 목적 함수 값
f_max=현대 인구의 최대 함수 값
f_min 최소 f_avg: 평균 수준
f_std: 표준 제약 수준

3.2 모범 사례

geatpy 라이브러리를 사용하여 최단 문제를 해결하세요. 방향성 비순환 그래프 Road

Code [최단 경로] 1: geatpy 라이브러리 사용

import numpy as np
import geatpy as ea
class MyProblem(ea.Problem):  # 继承Problem父类
    def __init__(self):
        name = 'Shortest_Path'  # 初始化name(函数名称,可以随意设置)
        M = 1  # 初始化M(目标维数)
        maxormins = [1]  # 初始化maxormins(目标最小最大化标记列表,1:最小化该目标;-1:最大化该目标)
        Dim = 10  # 初始化Dim(决策变量维数)
        varTypes = [1] * Dim  # 初始化varTypes(决策变量的类型,元素为0表示对应的变量是连续的;1表示是离散的)
        lb = [0] * Dim  # 决策变量下界
        ub = [9] * Dim  # 决策变量上界
        lbin = [1] * Dim  # 决策变量下边界 1表示闭合区间,0表示开区间
        ubin = [1] * Dim  # 决策变量上边界
        # 调用父类构造方法完成实例化
        ea.Problem.__init__(self, name, M, maxormins, Dim, varTypes, lb, ub, lbin, ubin)
        # 设置每一个结点下一步可达的结点(结点从1开始数,因此列表nodes的第0号元素设为空列表表示无意义)
        self.nodes = [[], [2, 3], [3, 4, 5], [5, 6], [7, 8], [4, 6], [7, 9], [8, 9], [9, 10], [10]]
        # 设置有向图中各条边的权重
        self.weights = {'(1, 2)': 36, '(1, 3)': 27, '(2, 4)': 18, '(2, 5)': 20, '(2, 3)': 13, '(3, 5)': 12,
                        '(3, 6)': 23,
                        '(4, 7)': 11, '(4, 8)': 32, '(5, 4)': 16, '(5, 6)': 30, '(6, 7)': 12, '(6, 9)': 38,
                        '(7, 8)': 20,
                        '(7, 9)': 32, '(8, 9)': 15, '(8, 10)': 24, '(9, 10)': 13}
    def decode(self, priority):  # 将优先级编码的染色体解码得到一条从节点1到节点10的可行路径
        edges = []  # 存储边
        path = [1]  # 结点1是路径起点
        while not path[-1] == 10:  # 开始从起点走到终点
            currentNode = path[-1]  # 得到当前所在的结点编号
            nextNodes = self.nodes[currentNode]  # 获取下一步可达的结点组成的列表
            chooseNode = nextNodes[np.argmax(
                priority[np.array(nextNodes) - 1])]  # 从NextNodes中选择优先级更高的结点作为下一步要访问的结点,因为结点从1数起,而下标从0数起,因此要减去1
            path.append(chooseNode)
            edges.append((currentNode, chooseNode))
        return path, edges
    def aimFunc(self, pop):  # 目标函数
        pop.ObjV = np.zeros((pop.sizes, 1))  # 初始化ObjV
        for i in range(pop.sizes):  # 遍历种群的每个个体,分别计算各个个体的目标函数值
            priority = pop.Phen[i, :]
            path, edges = self.decode(priority)  # 将优先级编码的染色体解码得到访问路径及经过的边
            pathLen = 0
            for edge in edges:
                key = str(edge)  # 根据路径得到键值,以便根据键值找到路径对应的长度
                if not key in self.weights:
                    raise RuntimeError("Error in aimFunc: The path is invalid. (当前路径是无效的。)", path)
                pathLen += self.weights[key]  # 将该段路径长度加入
            pop.ObjV[i] = pathLen  # 计算目标函数值,赋值给pop种群对象的ObjV属性
## 执行脚本
if __name__ == "__main__":
    # 实例化问题对象
    problem = MyProblem()
    # 构建算法
    algorithm = ea.soea_EGA_templet(problem,
                                    ea.Population(Encoding='RI', NIND=4),
                                    MAXGEN=10,  # 最大进化代数
                                    logTras=1)  # 表示每隔多少代记录一次日志信息
    # 求解
    res = ea.optimize(algorithm, verbose=True, drawing=1, outputMsg=False, drawLog=False, saveFlag=True,
                      dirName='result')
    print('最短路程为:%s' % (res['ObjV'][0][0]))
    print('最佳路线为:')
    best_journey, edges = problem.decode(res['Vars'][0])
    for i in range(len(best_journey)):
        print(int(best_journey[i]), end=' ')
    print()

[관련 권장 사항:

Python3 비디오 튜토리얼 ]

위 내용은 Python 유전 알고리즘 Geatpy 도구 상자에 대한 간략한 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 脚本之家에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
Python vs. C : 주요 차이점 이해Python vs. C : 주요 차이점 이해Apr 21, 2025 am 12:18 AM

Python과 C는 각각 고유 한 장점이 있으며 선택은 프로젝트 요구 사항을 기반으로해야합니다. 1) Python은 간결한 구문 및 동적 타이핑으로 인해 빠른 개발 및 데이터 처리에 적합합니다. 2) C는 정적 타이핑 및 수동 메모리 관리로 인해 고성능 및 시스템 프로그래밍에 적합합니다.

Python vs. C : 프로젝트를 위해 어떤 언어를 선택해야합니까?Python vs. C : 프로젝트를 위해 어떤 언어를 선택해야합니까?Apr 21, 2025 am 12:17 AM

Python 또는 C를 선택하는 것은 프로젝트 요구 사항에 따라 다릅니다. 1) 빠른 개발, 데이터 처리 및 프로토 타입 설계가 필요한 경우 Python을 선택하십시오. 2) 고성능, 낮은 대기 시간 및 근접 하드웨어 제어가 필요한 경우 C를 선택하십시오.

파이썬 목표에 도달 : 매일 2 시간의 힘파이썬 목표에 도달 : 매일 2 시간의 힘Apr 20, 2025 am 12:21 AM

매일 2 시간의 파이썬 학습을 투자하면 프로그래밍 기술을 효과적으로 향상시킬 수 있습니다. 1. 새로운 지식 배우기 : 문서를 읽거나 자습서를 시청하십시오. 2. 연습 : 코드를 작성하고 완전한 연습을합니다. 3. 검토 : 배운 내용을 통합하십시오. 4. 프로젝트 실무 : 실제 프로젝트에서 배운 것을 적용하십시오. 이러한 구조화 된 학습 계획은 파이썬을 체계적으로 마스터하고 경력 목표를 달성하는 데 도움이 될 수 있습니다.

2 시간 극대화 : 효과적인 파이썬 학습 전략2 시간 극대화 : 효과적인 파이썬 학습 전략Apr 20, 2025 am 12:20 AM

2 시간 이내에 Python을 효율적으로 학습하는 방법 : 1. 기본 지식을 검토하고 Python 설치 및 기본 구문에 익숙한 지 확인하십시오. 2. 변수, 목록, 기능 등과 같은 파이썬의 핵심 개념을 이해합니다. 3. 예제를 사용하여 마스터 기본 및 고급 사용; 4. 일반적인 오류 및 디버깅 기술을 배우십시오. 5. 목록 이해력 사용 및 PEP8 스타일 안내서와 같은 성능 최적화 및 모범 사례를 적용합니다.

Python과 C : The Hight Language 중에서 선택Python과 C : The Hight Language 중에서 선택Apr 20, 2025 am 12:20 AM

Python은 초보자 및 데이터 과학에 적합하며 C는 시스템 프로그래밍 및 게임 개발에 적합합니다. 1. 파이썬은 간단하고 사용하기 쉽고 데이터 과학 및 웹 개발에 적합합니다. 2.C는 게임 개발 및 시스템 프로그래밍에 적합한 고성능 및 제어를 제공합니다. 선택은 프로젝트 요구와 개인적인 이익을 기반으로해야합니다.

Python vs. C : 프로그래밍 언어의 비교 분석Python vs. C : 프로그래밍 언어의 비교 분석Apr 20, 2025 am 12:14 AM

Python은 데이터 과학 및 빠른 개발에 더 적합한 반면 C는 고성능 및 시스템 프로그래밍에 더 적합합니다. 1. Python Syntax는 간결하고 학습하기 쉽고 데이터 처리 및 과학 컴퓨팅에 적합합니다. 2.C는 복잡한 구문을 가지고 있지만 성능이 뛰어나고 게임 개발 및 시스템 프로그래밍에 종종 사용됩니다.

하루 2 시간 : 파이썬 학습의 잠재력하루 2 시간 : 파이썬 학습의 잠재력Apr 20, 2025 am 12:14 AM

파이썬을 배우기 위해 하루에 2 시간을 투자하는 것이 가능합니다. 1. 새로운 지식 배우기 : 목록 및 사전과 같은 1 시간 안에 새로운 개념을 배우십시오. 2. 연습 및 연습 : 1 시간을 사용하여 소규모 프로그램 작성과 같은 프로그래밍 연습을 수행하십시오. 합리적인 계획과 인내를 통해 짧은 시간에 Python의 핵심 개념을 마스터 할 수 있습니다.

Python vs. C : 학습 곡선 및 사용 편의성Python vs. C : 학습 곡선 및 사용 편의성Apr 19, 2025 am 12:20 AM

Python은 배우고 사용하기 쉽고 C는 더 강력하지만 복잡합니다. 1. Python Syntax는 간결하며 초보자에게 적합합니다. 동적 타이핑 및 자동 메모리 관리를 사용하면 사용하기 쉽지만 런타임 오류가 발생할 수 있습니다. 2.C는 고성능 응용 프로그램에 적합한 저수준 제어 및 고급 기능을 제공하지만 학습 임계 값이 높고 수동 메모리 및 유형 안전 관리가 필요합니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)