로지스틱 회귀를 완료하는 Python 방법
이 글은 주로 파이썬에서 로지스틱 회귀를 구현하는 방법에 대한 예제를 소개합니다. 머신러닝 과정에서 진행되는 실험입니다. 필요한 친구들이 참고해서 배워보도록 하겠습니다. 함께 보세요.
이 글에서 구현한 원리는 매우 간단하며, 최적화 방법은 경사하강법(Gradient Descent)입니다. 나중에 테스트 결과가 나올 겁니다.
먼저 구현된 샘플 코드를 살펴보겠습니다.
# coding=utf-8 from math import exp import matplotlib.pyplot as plt import numpy as np from sklearn.datasets.samples_generator import make_blobs def sigmoid(num): ''' :param num: 待计算的x :return: sigmoid之后的数值 ''' if type(num) == int or type(num) == float: return 1.0 / (1 + exp(-1 * num)) else: raise ValueError, 'only int or float data can compute sigmoid' class logistic(): def init(self, x, y): if type(x) == type(y) == list: self.x = np.array(x) self.y = np.array(y) elif type(x) == type(y) == np.ndarray: self.x = x self.y = y else: raise ValueError, 'input data error' def sigmoid(self, x): ''' :param x: 输入向量 :return: 对输入向量整体进行simgoid计算后的向量结果 ''' s = np.frompyfunc(lambda x: sigmoid(x), 1, 1) return s(x) def train_with_punish(self, alpha, errors, punish=0.0001): ''' :param alpha: alpha为学习速率 :param errors: 误差小于多少时停止迭代的阈值 :param punish: 惩罚系数 :param times: 最大迭代次数 :return: ''' self.punish = punish dimension = self.x.shape[1] self.theta = np.random.random(dimension) compute_error = 100000000 times = 0 while compute_error > errors: res = np.dot(self.x, self.theta) delta = self.sigmoid(res) - self.y self.theta = self.theta - alpha * np.dot(self.x.T, delta) - punish * self.theta # 带惩罚的梯度下降方法 compute_error = np.sum(delta) times += 1 def predict(self, x): ''' :param x: 给入新的未标注的向量 :return: 按照计算出的参数返回判定的类别 ''' x = np.array(x) if self.sigmoid(np.dot(x, self.theta)) > 0.5: return 1 else: return 0 def test1(): ''' 用来进行测试和画图,展现效果 :return: ''' x, y = make_blobs(n_samples=200, centers=2, n_features=2, random_state=0, center_box=(10, 20)) x1 = [] y1 = [] x2 = [] y2 = [] for i in range(len(y)): if y[i] == 0: x1.append(x[i][0]) y1.append(x[i][1]) elif y[i] == 1: x2.append(x[i][0]) y2.append(x[i][1]) # 以上均为处理数据,生成出两类数据 p = logistic(x, y) p.train_with_punish(alpha=0.00001, errors=0.005, punish=0.01) # 步长是0.00001,最大允许误差是0.005,惩罚系数是0.01 x_test = np.arange(10, 20, 0.01) y_test = (-1 * p.theta[0] / p.theta[1]) * x_test plt.plot(x_test, y_test, c='g', label='logistic_line') plt.scatter(x1, y1, c='r', label='positive') plt.scatter(x2, y2, c='b', label='negative') plt.legend(loc=2) plt.title('punish value = ' + p.punish.str()) plt.show() if name == 'main': test1()
실행 결과는 아래와 같습니다
요약
[관련 추천]
위 내용은 로지스틱 회귀를 완료하는 Python 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undress AI Tool
무료로 이미지를 벗다

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

파이썬 가상 환경을 만들려면 VenV 모듈을 사용할 수 있습니다. 단계는 다음과 같습니다. 1. 프로젝트 디렉토리를 입력하여 환경을 만들기 위해 Python-Mvenvenv 환경을 실행하십시오. 2. Sourceenv/bin/활성화 Mac/Linux 및 Env \ Scripts \ Windows로 활성화; 3. PipinStall 설치 패키지, PipFreeze> 요구 사항을 사용하여 종속성을 내보내십시오. 4. 가상 환경을 GIT에 제출하지 않도록주의하고 설치 중에 올바른 환경에 있는지 확인하십시오. 가상 환경은 프로젝트 종속성을 분리하여 충돌을 방지 할 수 있습니다. 특히 다중 프로젝트 개발에 적합합니다. Pycharm 또는 VScode와 같은 편집자도 있습니다.

pythonlistscani 구현 () penouspop () penouspop () popopoperations.1.useappend () 2- 벨리프 stotetopoftestack.2.usep op () toremoveAndreturnthetop 요소, leftertestackisnotempoavoidindexerror.3. pekattehatopelement on -pekattehatopelement withhithithithithithithithithithithithatheptestacke

Pythonschedule 라이브러리를 사용하여 타이밍 작업을 쉽게 구현하십시오. 먼저 PipinStallSchedule을 통해 라이브러리를 설치 한 다음 일정 및 시간 모듈을 가져오고 정기적으로 실행 해야하는 기능을 정의 한 다음 스케줄을 사용하여 시간 간격을 설정하고 작업 기능을 바인딩합니다. 마지막으로, 호출 schedule.run_pending () 및 time.sleep (1)에서 작업을 지속적으로 실행하기 위해 LOOP; 예를 들어, 10 초마다 작업을 실행하는 경우 일정으로 작성할 수 있습니다. 일정 (10) .seconds.do (작업)로 일정을 지원하는 일정, 시간, 일, 주 등을 지원하며 특정 작업을 지정할 수도 있습니다.

inriteThyInisinStalledAddAddAddAddAddAddEbdObeCeckingSioninterMinal; 2.SaveFileWith.Pyextension; 3.Uectrl BTORUNVIADEFAULTBUILDSYSTEM; 4. CREATEACUSTOMBUILDSYSTEMIFNEDDOGROGHINGTOTOOLS> BUILDSYSTEM> NEWBUILDSYSTEM

USETRACEMALLOCTOTRACKMORYALLOCATIONS 및 HIGH-MEMORYLINES; 2. MONITOROBJECTCOUNTSSWITHGCANDOBJGRAPHTECTETECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTECTESTEBSEPS;

생존 분석은 사건의 시간을 연구하는 데 사용되며 일반적으로 수명 및 Scikit-Survival을 사용하여 Python에서 구현됩니다. 1. 수명 라인 라이브러리를 설치하고 시간 및 이벤트 상태가 포함 된 데이터를 준비하십시오. 2. Kaplan-Meier 추정기를 사용하여 생존 곡선을 끌어 이벤트가 발생하지 않을 확률을 시각화하십시오. 3. COX 비례 위험 모델을 통해 이벤트 시간에 대한 변수의 영향을 분석하고 모델 가정을 확인하십시오. 4. 검열 된 데이터 처리에주의를 기울여 이벤트 열이 올바르게 검열되고 이벤트 발생을 표시하는지 확인하십시오.

usezoneinfoforpython3.9 thecreateTimezone-awaredateTimes and convertBetweTimezoneswithastimezone (); 2. forpyThon3.6–3.8, usepytzwithlocalize () toavoiddsterrors;

금융 거래를위한 Java, 경량 서비스 용 Python과 같은 고성능 요구 사항이있는 시스템; 2. Python은 MVP에 적합한 개발 효율성이 높으며 Java는 대규모 팀 협업에 적합합니다. 3. Java는 Java Enterprise 수준의 생태계에서 성숙하며 Python 프레임 워크는 가볍고 특히 Fastapi는 뛰어납니다. 4. Java는 높은 일환 분산 시스템의 첫 번째 선택이며, Python은 성능을 향상시키기 위해 비동기 모델을 요구합니다. 5. Python은 원활한 학습 곡선과 광범위한 재능을 가지고 있으며 Java는 충분한 엔터프라이즈 수준의 재능을 보유하고 있습니다. 6. Python은 클라우드 네이티브 경량 배치에 적합하며 Java는 전통적인 운영 및 유지 보수에서 더 안정적입니다. 최종 선택은 팀의 기술 스택, 프로젝트주기, 성능 요구 사항, 통합 복잡성 및 운영 및 유지 보수 비용과 결합해야하며, 키는 올바른 시나리오를 사용하는 것입니다.
