遗传算法的神经网络python实现源码

代码过程中,把代码过程较好的一些代码段记录起来,下边代码是关于遗传算法的神经网络python实现的代码,应该对大伙有一些用处。

from operator import itemgetter, attrgetter

import math

import random

import string

import timeit

from timeit import Timer as t

import matplotlib.pyplot as plt

import numpy as np

def sigmoid (x):

  return math.tanh(x)

def makeMatrix ( I, J, fill=0.0):

  m = []

  for i in range(I):

  return m


def randomizeMatrix ( matrix, a, b):

  for i in range ( len (matrix) ):

    for j in range ( len (matrix[0]) ):

      matrix[i][j] = random.uniform(a,b)

class NN:

  def __init__(self, NI, NH, NO):

    self.ni = NI

    self.nh = NH

    self.no = NO

    randomizeMatrix ( self.wi, -0.2, 0.2 )

    randomizeMatrix ( self.wo, -2.0, 2.0 )

  def runNN (self, inputs):

    if len(inputs) != self.ni:

      print 'incorrect number of inputs'

    for i in range(self.ni):

      self.ai[i] = inputs[i]

    for j in range(self.nh):

    for k in range(self.no):

    return self.ao

  def weights(self):

    print 'Input weights:'

    for i in range(self.ni):

      print self.wi[i]

    print

    print 'Output weights:'

    for j in range(self.nh):

      print self.wo[j]

    print ''

  def test(self, patterns):

    results, targets = [], []

    for p in patterns:

      inputs = p[0]

      rounded = [ round(i) for i in self.runNN(inputs) ]

      if rounded == p[1]: result = '+++++'

      else: result = '-----'

      print '%s %s %s %s %s %s %s' %( 'Inputs:', p[0], '-->', str(self.runNN(inputs)).rjust(65), 'Target', p[1], result)

      results+= self.runNN(inputs)

      targets += p[1]

    return results, targets

  def sumErrors (self):

    error = 0.0

    for p in pat:

      inputs = p[0]

      targets = p[1]

      self.runNN(inputs)

      error += self.calcError(targets)

    inverr = 1.0/error

    return inverr

  def calcError (self, targets):

    error = 0.0

    for k in range(len(targets)):

    return error

  def assignWeights (self, weights, I):

    io = 0

    for i in range(self.ni):

      for j in range(self.nh):

        self.wi[i][j] = weights[I][io][i][j]

    io = 1

    for j in range(self.nh):

      for k in range(self.no):

        self.wo[j][k] = weights[I][io][j][k]

  def testWeights (self, weights, I):

    same = []

    io = 0

    for i in range(self.ni):

      for j in range(self.nh):

        if self.wi[i][j] != weights[I][io][i][j]:

          same.append(('I',i,j, round(self.wi[i][j],2),round(weights[I][io][i][j],2),round(self.wi[i][j] - weights[I][io][i][j],2)))

    io = 1

    for j in range(self.nh):

      for k in range(self.no):

        if self.wo[j][k] !=  weights[I][io][j][k]:

          same.append((('O',j,k), round(self.wo[j][k],2),round(weights[I][io][j][k],2),round(self.wo[j][k] - weights[I][io][j][k],2)))

    if same != []:

      print same

def roulette (fitnessScores):

  cumalativeFitness = 0.0

  r = random.random()

  for i in range(len(fitnessScores)):

    cumalativeFitness += fitnessScores[i]

    if cumalativeFitness > r:

      return i


def calcFit (numbers):  # each fitness is a fraction of the total error

  total, fitnesses = sum(numbers), []

  for i in range(len(numbers)):         

    fitnesses.append(numbers[i]/total)

  return fitnesses

# takes a population of NN objects

def pairPop (pop):

  weights, errors = [], []

  for i in range(len(pop)):                # for each individual

    weights.append([pop[i].wi,pop[i].wo])  # append input & output weights of individual to list of all pop weights

    errors.append(pop[i].sumErrors())      # append 1/sum(MSEs) of individual to list of pop errors

  fitnesses = calcFit(errors)              # fitnesses are a fraction of the total error

  del pop

  return zip(weights, errors,fitnesses)            # weights become item[0] and fitnesses[1] in this way fitness is paired with its weight in a tuple


def rankPop (newpopW,pop):

  errors, copy = [], []          # a fresh pop of NN's are assigned to a list of len pop_size

  pop = [NN(ni,nh,no) for i in range(pop_size) ]

  for i in range(pop_size): copy.append(newpopW[i])

  for i in range(pop_size): 

    pop[i].assignWeights(newpopW, i)# each individual is assigned the weights generated from previous iteration

    pop[i].testWeights(newpopW, i)

  for i in range(pop_size): 

    pop[i].testWeights(newpopW, i)

  pairedPop = pairPop(pop)          # the fitness of these weights is calculated and tupled with the weights

  rankedPop = sorted(pairedPop, key = itemgetter(-1), reverse = True)  # weights are sorted in descending order of fitness (fittest first)

  errors = [ eval(repr(x[1])) for x in rankedPop ]

  return rankedPop, eval(repr(rankedPop[0][1])), float(sum(errors))/float(len(errors))

def iteratePop (rankedPop):

  rankedWeights = [ item[0] for item in rankedPop]

  fitnessScores = [ item[-1] for item in rankedPop]

  while len(newpopW) <= pop_size:  # Breed two randomly selected but different chromos until pop_size reached

    ch1, ch2 = [], []

    index1 = roulette(fitnessScores)

    index2 = roulette(fitnessScores)

    while index1 == index2:        # ensures different chromos are used for breeeding

      index2 = roulette(fitnessScores)

    #index1, index2 = 3,4

    ch1.extend(eval(repr(rankedWeights[index1])))

    ch2.extend(eval(repr(rankedWeights[index2])))

    if random.random() < crossover_rate:

      ch1, ch2 = crossover(ch1, ch2)

    mutate(ch1)

    mutate(ch2)

    newpopW.append(ch1)

    newpopW.append(ch2)

  return newpopW

graphical_error_scale = 100

max_iterations = 4000

pop_size = 100

mutation_rate = 0.1

crossover_rate = 0.8

ni, nh, no = 4,6,1

def main ():

  # Rank first random population

  pop = [ NN(ni,nh,no) for i in range(pop_size) ] # fresh pop

  pairedPop = pairPop(pop)

  rankedPop = sorted(pairedPop, key = itemgetter(-1), reverse = True) # THIS IS CORRECT

  # Keep iterating new pops until max_iterations

  iters = 0

  tops, avgs = [], []

  while iters != max_iterations:

    if iters%1 == 0:

      print 'Iteration'.rjust(150), iters

    newpopW = iteratePop(rankedPop)

    rankedPop, toperr, avgerr = rankPop(newpopW,pop)

    tops.append(toperr)

    avgs.append(avgerr)

    iters+=1


  # test a NN with the fittest weights

  tester = NN (ni,nh,no)

  fittestWeights = [ x[0] for x in rankedPop ]

  tester.assignWeights(fittestWeights, 0)

  results, targets = tester.test(testpat)

  x = np.arange(0,150)

  title2 = 'Test after '+str(iters)+' iterations'

  plt.title(title2)

  plt.ylabel('Node output')

  plt.xlabel('Instances')

  plt.plot( results, 'xr', linewidth = 0.5)

  plt.plot( targets, 's', color = 'black',linewidth = 3)

  #lines = plt.plot( results, 'sg')

  plt.annotate(s='Target Values', xy = (110, 0),color = 'black', family = 'sans-serif', size  ='small')

  plt.annotate(s='Test Values', xy = (110, 0.5),color = 'red', family = 'sans-serif', size  ='small', weight = 'bold')

  plt.figure(2)

  plt.subplot(121)

  plt.title('Top individual error evolution')

  plt.ylabel('Inverse error')

  plt.xlabel('Iterations')

  plt.plot( tops, '-g', linewidth = 1)

  plt.subplot(122)

  plt.plot( avgs, '-g', linewidth = 1)

  plt.title('Population average error evolution')

  plt.ylabel('Inverse error')

  plt.xlabel('Iterations')


  plt.show()


def crossover (m1, m2):

  for i in range(len(m1)):

    for j in range(len(m1[i])):

      for k in range(len(m1[i][j])):

        if r >= 0:

          output1[i][j][k] = m1[i][j][k]

          output2[i][j][k] = m2[i][j][k]

        elif r < 0:

          output1[i][j][k] = m2[i][j][k]

          output2[i][j][k] = m1[i][j][k]

        r -=1

  return output1, output2

def mutate (m):

  # could include a constant to control

  # how much the weight is mutated by

  for i in range(len(m)):

    for j in range(len(m[i])):

      for k in range(len(m[i][j])):

        if random.random() < mutation_rate:

            m[i][j][k] = random.uniform(-2.0,2.0)


if __name__ == "__main__":

    main()

pat = [

  [[5.1, 3.5, 1.4, 0.2], [-1], ['Iris-setosa']] ,

  [[4.9, 3.0, 1.4, 0.2], [-1], ['Iris-setosa']] ,

  [[4.7, 3.2, 1.3, 0.2], [-1], ['Iris-setosa']] ,

  [[5.4, 3.9, 1.7, 0.4], [-1], ['Iris-setosa']] ,

  [[4.6, 3.4, 1.4, 0.3], [-1], ['Iris-setosa']] ,

  [[5.0, 3.4, 1.5, 0.2], [-1], ['Iris-setosa']] ,

  [[4.4, 2.9, 1.4, 0.2], [-1], ['Iris-setosa']] ,

  [[4.9, 3.1, 1.5, 0.1], [-1], ['Iris-setosa']] ,

  [[5.4, 3.7, 1.5, 0.2], [-1], ['Iris-setosa']] ,

  [[4.8, 3.4, 1.6, 0.2], [-1], ['Iris-setosa']] ,

  [[4.8, 3.0, 1.4, 0.1], [-1], ['Iris-setosa']] ,

  [[4.3, 3.0, 1.1, 0.1], [-1], ['Iris-setosa']] ,

  [[5.8, 4.0, 1.2, 0.2], [-1], ['Iris-setosa']] ,

  [[5.7, 4.4, 1.5, 0.4], [-1], ['Iris-setosa']] ,

  [[5.4, 3.9, 1.3, 0.4], [-1], ['Iris-setosa']] ,

  [[5.1, 3.5, 1.4, 0.3], [-1], ['Iris-setosa']] ,

  [[5.7, 3.8, 1.7, 0.3], [-1], ['Iris-setosa']] ,

  [[5.1, 3.8, 1.5, 0.3], [-1], ['Iris-setosa']] ,

  [[5.4, 3.4, 1.7, 0.2], [-1], ['Iris-setosa']] ,

  [[5.1, 3.7, 1.5, 0.4], [-1], ['Iris-setosa']] ,

  [[4.6, 3.6, 1.0, 0.2], [-1], ['Iris-setosa']] ,

  [[5.1, 3.3, 1.7, 0.5], [-1], ['Iris-setosa']] ,

  [[4.8, 3.4, 1.9, 0.2], [-1], ['Iris-setosa']] ,

  [[5.0, 3.0, 1.6, 0.2], [-1], ['Iris-setosa']] ,

  [[5.0, 3.4, 1.6, 0.4], [-1], ['Iris-setosa']] ,

  [[5.2, 3.5, 1.5, 0.2], [-1], ['Iris-setosa']] ,

  [[5.2, 3.4, 1.4, 0.2], [-1], ['Iris-setosa']] ,

  [[4.7, 3.2, 1.6, 0.2], [-1], ['Iris-setosa']] ,

  [[4.8, 3.1, 1.6, 0.2], [-1], ['Iris-setosa']] ,

  [[5.4, 3.4, 1.5, 0.4], [-1], ['Iris-setosa']] ,

  [[5.2, 4.1, 1.5, 0.1], [-1], ['Iris-setosa']] ,

  [[5.5, 4.2, 1.4, 0.2], [-1], ['Iris-setosa']] ,

  [[4.9, 3.1, 1.5, 0.1], [-1], ['Iris-setosa']] ,

  [[5.0, 3.2, 1.2, 0.2], [-1], ['Iris-setosa']] ,

  [[5.5, 3.5, 1.3, 0.2], [-1], ['Iris-setosa']] ,

  [[4.9, 3.1, 1.5, 0.1], [-1], ['Iris-setosa']] ,

  [[4.4, 3.0, 1.3, 0.2], [-1], ['Iris-setosa']] ,

  [[5.1, 3.4, 1.5, 0.2], [-1], ['Iris-setosa']] ,

  [[5.0, 3.5, 1.3, 0.3], [-1], ['Iris-setosa']] ,

  [[4.5, 2.3, 1.3, 0.3], [-1], ['Iris-setosa']] ,

  [[4.4, 3.2, 1.3, 0.2], [-1], ['Iris-setosa']] ,

  [[5.0, 3.5, 1.6, 0.6], [-1], ['Iris-setosa']] ,

  [[5.1, 3.8, 1.9, 0.4], [-1], ['Iris-setosa']] ,

  [[4.8, 3.0, 1.4, 0.3], [-1], ['Iris-setosa']] ,

  [[5.1, 3.8, 1.6, 0.2], [-1], ['Iris-setosa']] ,

  [[4.6, 3.2, 1.4, 0.2], [-1], ['Iris-setosa']] ,

  [[5.3, 3.7, 1.5, 0.2], [-1], ['Iris-setosa']] ,

  [[5.0, 3.3, 1.4, 0.2], [-1], ['Iris-setosa']] ,

  [[7.0, 3.2, 4.7, 1.4], [0], ['Iris-versicolor']] ,

  [[6.4, 3.2, 4.5, 1.5], [0], ['Iris-versicolor']] ,

  [[6.9, 3.1, 4.9, 1.5], [0], ['Iris-versicolor']] ,

  [[5.5, 2.3, 4.0, 1.3], [0], ['Iris-versicolor']] ,

  [[6.5, 2.8, 4.6, 1.5], [0], ['Iris-versicolor']] ,

  [[5.7, 2.8, 4.5, 1.3], [0], ['Iris-versicolor']] ,

  [[6.3, 3.3, 4.7, 1.6], [0], ['Iris-versicolor']] ,

  [[4.9, 2.4, 3.3, 1.0], [0], ['Iris-versicolor']] ,

  [[6.6, 2.9, 4.6, 1.3], [0], ['Iris-versicolor']] ,

  [[5.2, 2.7, 3.9, 1.4], [0], ['Iris-versicolor']] ,

  [[5.0, 2.0, 3.5, 1.0], [0], ['Iris-versicolor']] ,

  [[5.9, 3.0, 4.2, 1.5], [0], ['Iris-versicolor']] ,

  [[6.0, 2.2, 4.0, 1.0], [0], ['Iris-versicolor']] ,

  [[6.1, 2.9, 4.7, 1.4], [0], ['Iris-versicolor']] ,

  [[5.6, 2.9, 3.6, 1.3], [0], ['Iris-versicolor']] ,

  [[6.7, 3.1, 4.4, 1.4], [0], ['Iris-versicolor']] ,

  [[5.6, 3.0, 4.5, 1.5], [0], ['Iris-versicolor']] ,

  [[5.8, 2.7, 4.1, 1.0], [0], ['Iris-versicolor']] ,

  [[6.2, 2.2, 4.5, 1.5], [0], ['Iris-versicolor']] ,

  [[5.6, 2.5, 3.9, 1.1], [0], ['Iris-versicolor']] ,

  [[5.9, 3.2, 4.8, 1.8], [0], ['Iris-versicolor']] ,

  [[6.1, 2.8, 4.0, 1.3], [0], ['Iris-versicolor']] ,

  [[6.3, 2.5, 4.9, 1.5], [0], ['Iris-versicolor']] ,

  [[6.1, 2.8, 4.7, 1.2], [0], ['Iris-versicolor']] ,

  [[6.4, 2.9, 4.3, 1.3], [0], ['Iris-versicolor']] ,

  [[6.6, 3.0, 4.4, 1.4], [0], ['Iris-versicolor']] ,

  [[6.8, 2.8, 4.8, 1.4], [0], ['Iris-versicolor']] ,

  [[6.7, 3.0, 5.0, 1.7], [0], ['Iris-versicolor']] ,

  [[6.0, 2.9, 4.5, 1.5], [0], ['Iris-versicolor']] ,

  [[5.7, 2.6, 3.5, 1.0], [0], ['Iris-versicolor']] ,

  [[5.5, 2.4, 3.8, 1.1], [0], ['Iris-versicolor']] ,

  [[5.5, 2.4, 3.7, 1.0], [0], ['Iris-versicolor']] ,

  [[5.8, 2.7, 3.9, 1.2], [0], ['Iris-versicolor']] ,

  [[6.0, 2.7, 5.1, 1.6], [0], ['Iris-versicolor']] ,

  [[5.4, 3.0, 4.5, 1.5], [0], ['Iris-versicolor']] ,

  [[6.0, 3.4, 4.5, 1.6], [0], ['Iris-versicolor']] ,

  [[6.7, 3.1, 4.7, 1.5], [0], ['Iris-versicolor']] ,

  [[6.3, 2.3, 4.4, 1.3], [0], ['Iris-versicolor']] ,

  [[5.6, 3.0, 4.1, 1.3], [0], ['Iris-versicolor']] ,

  [[6.1, 3.0, 4.6, 1.4], [0], ['Iris-versicolor']] ,

  [[5.8, 2.6, 4.0, 1.2], [0], ['Iris-versicolor']] ,

  [[5.0, 2.3, 3.3, 1.0], [0], ['Iris-versicolor']] ,

  [[5.6, 2.7, 4.2, 1.3], [0], ['Iris-versicolor']] ,

  [[5.7, 3.0, 4.2, 1.2], [0], ['Iris-versicolor']] ,

  [[5.7, 2.9, 4.2, 1.3], [0], ['Iris-versicolor']] ,

  [[6.2, 2.9, 4.3, 1.3], [0], ['Iris-versicolor']] ,

  [[5.1, 2.5, 3.0, 1.1], [0], ['Iris-versicolor']] ,

  [[5.7, 2.8, 4.1, 1.3], [0], ['Iris-versicolor']] ,

  [[6.3, 3.3, 6.0, 2.5], [1], ['Iris-virginica']] ,

  [[5.8, 2.7, 5.1, 1.9], [1], ['Iris-virginica']] ,

  [[7.1, 3.0, 5.9, 2.1], [1], ['Iris-virginica']] ,

  [[6.3, 2.9, 5.6, 1.8], [1], ['Iris-virginica']] ,

  [[6.5, 3.0, 5.8, 2.2], [1], ['Iris-virginica']] ,

  [[7.6, 3.0, 6.6, 2.1], [1], ['Iris-virginica']] ,

  [[4.9, 2.5, 4.5, 1.7], [1], ['Iris-virginica']] ,

  [[7.3, 2.9, 6.3, 1.8], [1], ['Iris-virginica']] ,

  [[6.7, 2.5, 5.8, 1.8], [1], ['Iris-virginica']] ,

  [[7.2, 3.6, 6.1, 2.5], [1], ['Iris-virginica']] ,

  [[6.5, 3.2, 5.1, 2.0], [1], ['Iris-virginica']] ,

  [[6.4, 2.7, 5.3, 1.9], [1], ['Iris-virginica']] ,

  [[6.8, 3.0, 5.5, 2.1], [1], ['Iris-virginica']] ,

  [[5.7, 2.5, 5.0, 2.0], [1], ['Iris-virginica']] ,

  [[5.8, 2.8, 5.1, 2.4], [1], ['Iris-virginica']] ,

  [[7.7, 3.8, 6.7, 2.2], [1], ['Iris-virginica']] ,

  [[7.7, 2.6, 6.9, 2.3], [1], ['Iris-virginica']] ,

  [[6.0, 2.2, 5.0, 1.5], [1], ['Iris-virginica']] ,

  [[6.9, 3.2, 5.7, 2.3], [1], ['Iris-virginica']] ,

  [[5.6, 2.8, 4.9, 2.0], [1], ['Iris-virginica']] ,

  [[7.7, 2.8, 6.7, 2.0], [1], ['Iris-virginica']] ,

  [[6.3, 2.7, 4.9, 1.8], [1], ['Iris-virginica']] ,

  [[6.7, 3.3, 5.7, 2.1], [1], ['Iris-virginica']] ,

  [[7.2, 3.2, 6.0, 1.8], [1], ['Iris-virginica']] ,

  [[6.2, 2.8, 4.8, 1.8], [1], ['Iris-virginica']] ,

  [[6.1, 3.0, 4.9, 1.8], [1], ['Iris-virginica']] ,

  [[6.4, 2.8, 5.6, 2.1], [1], ['Iris-virginica']] ,

  [[7.2, 3.0, 5.8, 1.6], [1], ['Iris-virginica']] ,

  [[7.4, 2.8, 6.1, 1.9], [1], ['Iris-virginica']] ,

  [[7.9, 3.8, 6.4, 2.0], [1], ['Iris-virginica']] ,

  [[6.4, 2.8, 5.6, 2.2], [1], ['Iris-virginica']] ,

  [[6.3, 2.8, 5.1, 1.5], [1], ['Iris-virginica']] ,

  [[6.1, 2.6, 5.6, 1.4], [1], ['Iris-virginica']] ,

  [[7.7, 3.0, 6.1, 2.3], [1], ['Iris-virginica']] ,

  [[6.3, 3.4, 5.6, 2.4], [1], ['Iris-virginica']] ,

  [[6.4, 3.1, 5.5, 1.8], [1], ['Iris-virginica']] ,

  [[6.0, 3.0, 4.8, 1.8], [1], ['Iris-virginica']] ,

  [[6.9, 3.1, 5.4, 2.1], [1], ['Iris-virginica']] ,

  [[6.7, 3.1, 5.6, 2.4], [1], ['Iris-virginica']] ,

  [[6.9, 3.1, 5.1, 2.3], [1], ['Iris-virginica']] ,

  [[5.8, 2.7, 5.1, 1.9], [1], ['Iris-virginica']] ,

  [[6.8, 3.2, 5.9, 2.3], [1], ['Iris-virginica']] ,

  [[6.7, 3.3, 5.7, 2.5], [1], ['Iris-virginica']] ,

  [[6.7, 3.0, 5.2, 2.3], [1], ['Iris-virginica']] ,

  [[6.3, 2.5, 5.0, 1.9], [1], ['Iris-virginica']] ,

  [[6.5, 3.0, 5.2, 2.0], [1], ['Iris-virginica']] ,

  [[6.2, 3.4, 5.4, 2.3], [1], ['Iris-virginica']] ,

  [[5.9, 3.0, 5.1, 1.8], [1], ['Iris-virginica']]

]

testpat = [

  [[5.1, 3.5, 1.4, 0.2], [-1], ['Iris-setosa']] ,

  [[4.9, 3.0, 1.4, 0.2], [-1], ['Iris-setosa']] ,

  [[4.7, 3.2, 1.3, 0.2], [-1], ['Iris-setosa']] ,

  [[5.4, 3.9, 1.7, 0.4], [-1], ['Iris-setosa']] ,

  [[4.6, 3.4, 1.4, 0.3], [-1], ['Iris-setosa']] ,

  [[5.0, 3.4, 1.5, 0.2], [-1], ['Iris-setosa']] ,

  [[4.4, 2.9, 1.4, 0.2], [-1], ['Iris-setosa']] ,

  [[4.9, 3.1, 1.5, 0.1], [-1], ['Iris-setosa']] ,

  [[5.4, 3.7, 1.5, 0.2], [-1], ['Iris-setosa']] ,

  [[4.8, 3.4, 1.6, 0.2], [-1], ['Iris-setosa']] ,

  [[4.8, 3.0, 1.4, 0.1], [-1], ['Iris-setosa']] ,

  [[4.3, 3.0, 1.1, 0.1], [-1], ['Iris-setosa']] ,

  [[5.8, 4.0, 1.2, 0.2], [-1], ['Iris-setosa']] ,

  [[5.7, 4.4, 1.5, 0.4], [-1], ['Iris-setosa']] ,

  [[5.4, 3.9, 1.3, 0.4], [-1], ['Iris-setosa']] ,

  [[5.1, 3.5, 1.4, 0.3], [-1], ['Iris-setosa']] ,

  [[5.7, 3.8, 1.7, 0.3], [-1], ['Iris-setosa']] ,

  [[5.1, 3.8, 1.5, 0.3], [-1], ['Iris-setosa']] ,

  [[5.4, 3.4, 1.7, 0.2], [-1], ['Iris-setosa']] ,

  [[5.1, 3.7, 1.5, 0.4], [-1], ['Iris-setosa']] ,

  [[4.6, 3.6, 1.0, 0.2], [-1], ['Iris-setosa']] ,

  [[5.1, 3.3, 1.7, 0.5], [-1], ['Iris-setosa']] ,

  [[4.8, 3.4, 1.9, 0.2], [-1], ['Iris-setosa']] ,

  [[5.0, 3.0, 1.6, 0.2], [-1], ['Iris-setosa']] ,

  [[5.0, 3.4, 1.6, 0.4], [-1], ['Iris-setosa']] ,

  [[5.2, 3.5, 1.5, 0.2], [-1], ['Iris-setosa']] ,

  [[5.2, 3.4, 1.4, 0.2], [-1], ['Iris-setosa']] ,

  [[4.7, 3.2, 1.6, 0.2], [-1], ['Iris-setosa']] ,

  [[4.8, 3.1, 1.6, 0.2], [-1], ['Iris-setosa']] ,

  [[5.4, 3.4, 1.5, 0.4], [-1], ['Iris-setosa']] ,

  [[5.2, 4.1, 1.5, 0.1], [-1], ['Iris-setosa']] ,

  [[5.5, 4.2, 1.4, 0.2], [-1], ['Iris-setosa']] ,

  [[4.9, 3.1, 1.5, 0.1], [-1], ['Iris-setosa']] ,

  [[5.0, 3.2, 1.2, 0.2], [-1], ['Iris-setosa']] ,

  [[5.5, 3.5, 1.3, 0.2], [-1], ['Iris-setosa']] ,

  [[4.9, 3.1, 1.5, 0.1], [-1], ['Iris-setosa']] ,

  [[4.4, 3.0, 1.3, 0.2], [-1], ['Iris-setosa']] ,

  [[5.1, 3.4, 1.5, 0.2], [-1], ['Iris-setosa']] ,

  [[5.0, 3.5, 1.3, 0.3], [-1], ['Iris-setosa']] ,

  [[4.5, 2.3, 1.3, 0.3], [-1], ['Iris-setosa']] ,

  [[4.4, 3.2, 1.3, 0.2], [-1], ['Iris-setosa']] ,

  [[5.0, 3.5, 1.6, 0.6], [-1], ['Iris-setosa']] ,

  [[5.1, 3.8, 1.9, 0.4], [-1], ['Iris-setosa']] ,

  [[4.8, 3.0, 1.4, 0.3], [-1], ['Iris-setosa']] ,

  [[5.1, 3.8, 1.6, 0.2], [-1], ['Iris-setosa']] ,

  [[4.6, 3.2, 1.4, 0.2], [-1], ['Iris-setosa']] ,

  [[5.3, 3.7, 1.5, 0.2], [-1], ['Iris-setosa']] ,

  [[5.0, 3.3, 1.4, 0.2], [-1], ['Iris-setosa']] ,

  [[7.0, 3.2, 4.7, 1.4], [0], ['Iris-versicolor']] ,

  [[6.4, 3.2, 4.5, 1.5], [0], ['Iris-versicolor']] ,

  [[6.9, 3.1, 4.9, 1.5], [0], ['Iris-versicolor']] ,

  [[5.5, 2.3, 4.0, 1.3], [0], ['Iris-versicolor']] ,

  [[6.5, 2.8, 4.6, 1.5], [0], ['Iris-versicolor']] ,

  [[5.7, 2.8, 4.5, 1.3], [0], ['Iris-versicolor']] ,

  [[6.3, 3.3, 4.7, 1.6], [0], ['Iris-versicolor']] ,

  [[4.9, 2.4, 3.3, 1.0], [0], ['Iris-versicolor']] ,

  [[6.6, 2.9, 4.6, 1.3], [0], ['Iris-versicolor']] ,

  [[5.2, 2.7, 3.9, 1.4], [0], ['Iris-versicolor']] ,

  [[5.0, 2.0, 3.5, 1.0], [0], ['Iris-versicolor']] ,

  [[5.9, 3.0, 4.2, 1.5], [0], ['Iris-versicolor']] ,

  [[6.0, 2.2, 4.0, 1.0], [0], ['Iris-versicolor']] ,

  [[6.1, 2.9, 4.7, 1.4], [0], ['Iris-versicolor']] ,

  [[5.6, 2.9, 3.6, 1.3], [0], ['Iris-versicolor']] ,

  [[6.7, 3.1, 4.4, 1.4], [0], ['Iris-versicolor']] ,

  [[5.6, 3.0, 4.5, 1.5], [0], ['Iris-versicolor']] ,

  [[5.8, 2.7, 4.1, 1.0], [0], ['Iris-versicolor']] ,

  [[6.2, 2.2, 4.5, 1.5], [0], ['Iris-versicolor']] ,

  [[5.6, 2.5, 3.9, 1.1], [0], ['Iris-versicolor']] ,

  [[5.9, 3.2, 4.8, 1.8], [0], ['Iris-versicolor']] ,

  [[6.1, 2.8, 4.0, 1.3], [0], ['Iris-versicolor']] ,

  [[6.3, 2.5, 4.9, 1.5], [0], ['Iris-versicolor']] ,

  [[6.1, 2.8, 4.7, 1.2], [0], ['Iris-versicolor']] ,

  [[6.4, 2.9, 4.3, 1.3], [0], ['Iris-versicolor']] ,

  [[6.6, 3.0, 4.4, 1.4], [0], ['Iris-versicolor']] ,

  [[6.8, 2.8, 4.8, 1.4], [0], ['Iris-versicolor']] ,

  [[6.7, 3.0, 5.0, 1.7], [0], ['Iris-versicolor']] ,

  [[6.0, 2.9, 4.5, 1.5], [0], ['Iris-versicolor']] ,

  [[5.7, 2.6, 3.5, 1.0], [0], ['Iris-versicolor']] ,

  [[5.5, 2.4, 3.8, 1.1], [0], ['Iris-versicolor']] ,

  [[5.5, 2.4, 3.7, 1.0], [0], ['Iris-versicolor']] ,

  [[5.8, 2.7, 3.9, 1.2], [0], ['Iris-versicolor']] ,

  [[6.0, 2.7, 5.1, 1.6], [0], ['Iris-versicolor']] ,

  [[5.4, 3.0, 4.5, 1.5], [0], ['Iris-versicolor']] ,

  [[6.0, 3.4, 4.5, 1.6], [0], ['Iris-versicolor']] ,

  [[6.7, 3.1, 4.7, 1.5], [0], ['Iris-versicolor']] ,

  [[6.3, 2.3, 4.4, 1.3], [0], ['Iris-versicolor']] ,

  [[5.6, 3.0, 4.1, 1.3], [0], ['Iris-versicolor']] ,

  [[6.1, 3.0, 4.6, 1.4], [0], ['Iris-versicolor']] ,

  [[5.8, 2.6, 4.0, 1.2], [0], ['Iris-versicolor']] ,

  [[5.0, 2.3, 3.3, 1.0], [0], ['Iris-versicolor']] ,

  [[5.6, 2.7, 4.2, 1.3], [0], ['Iris-versicolor']] ,

  [[5.7, 3.0, 4.2, 1.2], [0], ['Iris-versicolor']] ,

  [[5.7, 2.9, 4.2, 1.3], [0], ['Iris-versicolor']] ,

  [[6.2, 2.9, 4.3, 1.3], [0], ['Iris-versicolor']] ,

  [[5.1, 2.5, 3.0, 1.1], [0], ['Iris-versicolor']] ,

  [[5.7, 2.8, 4.1, 1.3], [0], ['Iris-versicolor']] ,

  [[6.3, 3.3, 6.0, 2.5], [1], ['Iris-virginica']] ,

  [[5.8, 2.7, 5.1, 1.9], [1], ['Iris-virginica']] ,

  [[7.1, 3.0, 5.9, 2.1], [1], ['Iris-virginica']] ,

  [[6.3, 2.9, 5.6, 1.8], [1], ['Iris-virginica']] ,

  [[6.5, 3.0, 5.8, 2.2], [1], ['Iris-virginica']] ,

  [[7.6, 3.0, 6.6, 2.1], [1], ['Iris-virginica']] ,

  [[4.9, 2.5, 4.5, 1.7], [1], ['Iris-virginica']] ,

  [[7.3, 2.9, 6.3, 1.8], [1], ['Iris-virginica']] ,

  [[6.7, 2.5, 5.8, 1.8], [1], ['Iris-virginica']] ,

  [[7.2, 3.6, 6.1, 2.5], [1], ['Iris-virginica']] ,

  [[6.5, 3.2, 5.1, 2.0], [1], ['Iris-virginica']] ,

  [[6.4, 2.7, 5.3, 1.9], [1], ['Iris-virginica']] ,

  [[6.8, 3.0, 5.5, 2.1], [1], ['Iris-virginica']] ,

  [[5.7, 2.5, 5.0, 2.0], [1], ['Iris-virginica']] ,

  [[5.8, 2.8, 5.1, 2.4], [1], ['Iris-virginica']] ,

  [[7.7, 3.8, 6.7, 2.2], [1], ['Iris-virginica']] ,

  [[7.7, 2.6, 6.9, 2.3], [1], ['Iris-virginica']] ,

  [[6.0, 2.2, 5.0, 1.5], [1], ['Iris-virginica']] ,

  [[6.9, 3.2, 5.7, 2.3], [1], ['Iris-virginica']] ,

  [[5.6, 2.8, 4.9, 2.0], [1], ['Iris-virginica']] ,

  [[7.7, 2.8, 6.7, 2.0], [1], ['Iris-virginica']] ,

  [[6.3, 2.7, 4.9, 1.8], [1], ['Iris-virginica']] ,

  [[6.7, 3.3, 5.7, 2.1], [1], ['Iris-virginica']] ,

  [[7.2, 3.2, 6.0, 1.8], [1], ['Iris-virginica']] ,

  [[6.2, 2.8, 4.8, 1.8], [1], ['Iris-virginica']] ,

  [[6.1, 3.0, 4.9, 1.8], [1], ['Iris-virginica']] ,

  [[6.4, 2.8, 5.6, 2.1], [1], ['Iris-virginica']] ,

  [[7.2, 3.0, 5.8, 1.6], [1], ['Iris-virginica']] ,

  [[7.4, 2.8, 6.1, 1.9], [1], ['Iris-virginica']] ,

  [[7.9, 3.8, 6.4, 2.0], [1], ['Iris-virginica']] ,

  [[6.4, 2.8, 5.6, 2.2], [1], ['Iris-virginica']] ,

  [[6.3, 2.8, 5.1, 1.5], [1], ['Iris-virginica']] ,

  [[6.1, 2.6, 5.6, 1.4], [1], ['Iris-virginica']] ,

  [[7.7, 3.0, 6.1, 2.3], [1], ['Iris-virginica']] ,

  [[6.3, 3.4, 5.6, 2.4], [1], ['Iris-virginica']] ,

  [[6.4, 3.1, 5.5, 1.8], [1], ['Iris-virginica']] ,

  [[6.0, 3.0, 4.8, 1.8], [1], ['Iris-virginica']] ,

  [[6.9, 3.1, 5.4, 2.1], [1], ['Iris-virginica']] ,

  [[6.7, 3.1, 5.6, 2.4], [1], ['Iris-virginica']] ,

  [[6.9, 3.1, 5.1, 2.3], [1], ['Iris-virginica']] ,

  [[5.8, 2.7, 5.1, 1.9], [1], ['Iris-virginica']] ,

  [[6.8, 3.2, 5.9, 2.3], [1], ['Iris-virginica']] ,

  [[6.7, 3.3, 5.7, 2.5], [1], ['Iris-virginica']] ,

  [[6.7, 3.0, 5.2, 2.3], [1], ['Iris-virginica']] ,

  [[6.3, 2.5, 5.0, 1.9], [1], ['Iris-virginica']] ,

  [[6.5, 3.0, 5.2, 2.0], [1], ['Iris-virginica']] ,

  [[6.2, 3.4, 5.4, 2.3], [1], ['Iris-virginica']] ,

  [[5.9, 3.0, 5.1, 1.8], [1], ['Iris-virginica']]

]

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,047评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,807评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,501评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,839评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,951评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,117评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,188评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,929评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,372评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,679评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,837评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,536评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,168评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,886评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,129评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,665评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,739评论 2 351

推荐阅读更多精彩内容