感知器演算法及其python 實現 V2.0
import matplotlib.pyplot as plt
import numpy as np
from random import uniform, seed, shuffle ,sample
import math
import logging
# from random import random
'''JY_Toolkit.py'''
class Jy_makeDataset(object):
def random_state(random_seed):
seed(int(random_seed))
def draw_HalfMoon(n_sample: int = 1000, # 樣本點個數,兩個分類一共 n_sample
w: float = 1, # 半月的線寬
radius: float = 4, # 半月的半徑
hor_distance: float = 4, # Horizontal direction distance for two point
ver_distance: float = 0, # Vertical direction distance for two point
slope: float = 0, # 半月傾斜的角度 [0 ~ 180]
positive_val: int = 1,
negative_val: int = -1,
):
slope %= 180 # make the `slope` between 0 and 180
# 將 n_sample 和樣本分為兩類每個樣本 n_sample / 2 類
each_m = n_sample//2
# circle origin point of positive moon [x , y]
p_origin = [1 + w/2 + radius, 1 + w/2 + radius + ver_distance]
# circle origin point of negative moon [x , y]
n_origin = [p_origin[0] + hor_distance, p_origin[1] - ver_distance]
# product positive point
p_sample = []
n_sample = []
for i in range(each_m):
# Randomly generate l
temp_l = radius + uniform(-(w/2), w/2)
# Randomly generate angle i.e. theta
temp_angle = uniform(slope, slope + 180)
point_x = p_origin[0] + temp_l*math.cos(math.pi/180*temp_angle)
point_y = p_origin[1] + temp_l*math.sin(math.pi/180*temp_angle)
p_sample.append([point_x, point_y, positive_val])
for i in range(each_m):
# Randomly generate l
temp_l = radius + uniform(-(w/2), w/2)
# Randomly generate angle i.e. theta , but the angle of negative point should between `slope + 180` and `slope + 360`
temp_angle = uniform(slope + 180, slope + 360)
point_x = n_origin[0] + temp_l*math.cos(math.pi/180*temp_angle)
point_y = n_origin[1] + temp_l*math.sin(math.pi/180*temp_angle)
n_sample.append([point_x, point_y, negative_val])
sample_points = p_sample + n_sample
shuffle(sample_points)
sample_points = np.array(sample_points)
return sample_points[:, 0:2], sample_points[:, 2]
pass
class Jy_dataSetProcess(object):
def Jy_train_test_split(X,
y,
test_size : 0.2,
):
data = np.column_stack((X,y))
if test_size >= 1 and test_size <= 0:
logging.exception('test_size must be greater than 0 less than 1, we will assign test_size value of 0.2')
test_size = 0.2
sample_count = int(len(data)*test_size)
'''
分離思路:
先將輸入的資料集打亂,外匯跟單gendan5.com然後取前 test_size 部分為測試集,後部分為訓練集
'''
shuffle(data)
X_test = data[0:sample_count-1]
X_train = data[sample_count:]
return X_train[:,0:2], X_test[:,0:2] ,X_train[:,2] , X_test[:,2]
pass
if __name__ == '__main__':
random_seed = 52
Jy_makeDataset.random_state(random_seed)
np_data, label = Jy_makeDataset.draw_HalfMoon(n_sample=2000)
p_point_x1 = [np_data[i][0] for i in range(len(np_data)) if label[i] == 1]
p_point_x2 = [np_data[i][1] for i in range(len(np_data)) if label[i] == 1]
n_point_x1 = [np_data[i][0] for i in range(len(np_data)) if label[i] == -1]
n_point_x2 = [np_data[i][1] for i in range(len(np_data)) if label[i] == -1]
fig = plt.figure(num="HalfMoons", figsize=(8, 8))
ax1 = fig.add_subplot(111)
ax1.scatter(p_point_x1, p_point_x2, c='red')
ax1.scatter(n_point_x1, n_point_x2, c='blue')
plt.show()
print(np_data)
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69946337/viewspace-2842965/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 蟻群演算法原理及其實現(python)演算法Python
- 線性表及其演算法(java實現)演算法Java
- 社會網路分析及其Python實現Python
- 迴圈碼、卷積碼及其python實現卷積Python
- 熱力圖生成演算法及其具體實現演算法
- FM演算法python實現演算法Python
- python實現冒泡演算法Python演算法
- python實現FM演算法Python演算法
- RSA演算法與Python實現演算法Python
- 8 大內部排序演算法相關及其java實現排序演算法Java
- 紙上談兵: 排序演算法簡介及其C實現排序演算法
- 一文了解 Elasticsearch 及其與 Python 的對接實現ElasticsearchPython
- 通過leetcode學習常見排序演算法及其Go實現LeetCode排序演算法Go
- PageRank演算法概述與Python實現演算法Python
- python實現希爾排序演算法Python排序演算法
- tf.keras實現線性迴歸和多層感知器Keras
- 線性表及其實現
- AOP如何實現及其原理
- Set介面及其實現類
- 分散式鎖及其實現分散式
- 字首樹及其Java實現Java
- 資料結構與演算法--簡單棧實現及其應用資料結構演算法
- python實現常用五種排序演算法Python排序演算法
- 模擬退火演算法(1)Python 實現演算法Python
- 字典樹及其C++實現C++
- Bloom實現及其數學分析OOM
- (二)區塊鏈的共識演算法:PoS 及其 例子 程式碼 實現區塊鏈演算法
- 常見排序演算法及其實現(Binary,Insert、Select、Quick、Bubble.etc.Sort)排序演算法UI
- 吳恩達《Machine Learning》精煉筆記 9:PCA 及其 Python 實現吳恩達Mac筆記PCAPython
- [資料結構與演算法]-排序演算法之插入排序(insertion sort)及其實現(Java)資料結構演算法排序Java
- [譯]使用 Python 實現接縫裁剪演算法Python演算法
- 隨機森林演算法原理與Python實現隨機森林演算法Python
- CART演算法解密:從原理到Python實現演算法解密Python
- 用Python實現約瑟夫環演算法Python演算法
- 目標匹配:匈牙利演算法的python實現演算法Python
- 排序演算法原理總結和Python實現排序演算法Python
- 手寫演算法-python程式碼實現Kmeans演算法Python
- 短址(short URL)原理及其實現