Lambda相关图形

序言

  1. 概述:
    1. Lambda是JDK8语法糖中函数式编程思想,让我们不用关注是什么对象,而关注的是对数据进行了什么操作【三更草堂】
    2. Lambda可以对某些匿名内部类的写法进行简化。
  2. 基本格式【boge】

    (参数类型 参数名称) -> {
          代码体;
    }
    格式说明:
          (参数类型 参数名称):参数列表
          {代码体;}:方法体
          ->:箭头,分割参数列表和方法体
  3. 省略规则 【三更草堂】

    * 小括号内的参数类型可以省略。
    * 如果方法只有一个参数,则小括号可以省略。
    * 如果方法体有且仅有一句代码,则可以同时省略大括号、return关键字、唯一一句代码的语句分号。
    * 以上这些规则都记不住也可以省略不记。

  4. Lambda表达式的语法是非常简洁的,但是Lambda表达式不是随便使用的,使用时有几个条件要特别注意:【boge】

         1. 方法的参数或局部变量类型必须为接口才能使用Lambda
         2. 接口中有且仅有一个抽象方法(@FunctionalInterface)
  5. Lambda表达式的原理【boge】
    匿名内部类在编译的时候会产生一个class文件。

    Lambda表达式在程序运行的时候会形成一个类。
         1. 在类中新增了一个方法,这个方法的方法体就是Lambda表达式中的代码
         2. 还会形成一个匿名内部类,实现接口,重写抽象方法
         3. 在接口中重写方法会调用新生成的方法
  6. 类型推断 【sgg】
    上述 Lambda 表达式中的参数类型都是由编译器推断 得出的。Lambda 表达式中无需指定类型,程序依然可以编译,这是因为 javac 根据程序的上下文,在后台推断出了参数的类型。Lambda 表达式的类型依赖于上下文环境,是由编译器推断出来的。这就是所谓的 “ 类型推断”
  7. Lambda和匿名内部类的对比【boge】

    1. 所需类型不一样
          匿名内部类的类型可以是 类,抽象类,接口
          Lambda表达式需要的类型必须是接口
    2. 抽象方法的数量不一样
          匿名内部类所需的接口中的抽象方法的数量是随意的
          Lambda表达式所需的接口中只能有一个抽象方法
    3. 实现原理不一样
          匿名内部类是在编译后形成一个class
          Lambda表达式是在程序运行的时候动态生成 class
     

一 生活中的需求:Runnable接口、run()方法

import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;

public class Ex01 {
    public static void main1(String[] args) {
        //  我们在创建线程并启动时可以使用匿名内部类的写法:
        new Thread(new Runnable() {
            public void run() {
                System.out.println("你知道吗 我比你想象的 更想在你身边01");
            }
        }).start();
    }
}
class Ex11{
    public static void main(String[] args) {
        new Thread(()->{
            System.out.println("你知道吗 我比你想象的 更想在你身边02");
        }).start();
    }
}

二 生活中的需求:无参无返回值的Lambda

public class Ex6 {
    public static void goShow(UserService userService){
        userService.show();
    }
    public static void main(String[] args) {
        //  非lambda,匿名内部类的写法调用该方法
        goShow(
                new UserService() {
                    @Override
                    public void show() {
                            System.out.println("show 方法执行了...");
                    }
        });

        //  lambda
        goShow(
                ()
                ->
                { System.out.println("Lambda show 方法执行了..."); }
        );
    }
}
interface UserService {
    void show();
}

三 生活中的需求:有参无返回值的Lambda

import java.sql.SQLOutput;

public class Ex05 {
    public static void foreachArr(IntConsumer consumer){
        int[] arr = {1,2,3,4,5,6,7,8,9,10};
        for (int i : arr) {
            consumer.accept(i);
        }
    }

    public static void main(String[] args) {
        //  非lambda,匿名内部类的写法调用该方法
        foreachArr(new IntConsumer() {
            public void accept(int value) {
                System.out.println(value);
            }
        });

        //  lambda格式
        foreachArr(
                (int value)
                ->
                {
                    System.out.println(value);
                }
        );
    }
}

interface IntConsumer{
    void accept(int value);
}

四 生活中的需求:有参有返回值的Lambda

public class Ex03 {
    public static void printNum(IntPredicate predicate){
        int[] arr = {1,2,3,4,5,6,7,8,9,10};
        for (int i : arr) {
            if(predicate.test(i)){
                System.out.println(i);
            }
        }
    }
   
    public static void main1(String[] args) {
        //  非lambda,匿名内部类的写法调用该方法
        printNum(new IntPredicate() {
            public boolean test(int value) {
                return value%2==0;
            }
        });

        // lambda格式
        printNum(
            (int value)
            -> 
            {
                return value%2==0;
            }
        );
    }
}
interface IntPredicate{
    boolean test(int value);
}

public class Ex04 {
    public static <R> R typeConver(Function<String,R> function){
        String str = "1235";
        R result = function.apply(str);
        return result;
    }

    public static void main(String[] args) {
        //  非lambda,先使用匿名内部类的写法调用该方法
        Integer result1 = typeConver(new Function<String, Integer>() {
            public Integer apply(String s) {
                return Integer.valueOf(s);
            }
        });
        System.out.println(result1);

        //  lambda
        Integer result2 = typeConver(
            (String s)
            ->
            {
                return Integer.valueOf(s);
            }
        );
        System.out.println("lambda结果 = "+result2);
    }
}
interface Function<String,Integer>{
    Integer apply(String s);
}

public class Ex02 {
    public static int calculateNum(IntBinaryOperator operator){
        int a = 10;
        int b = 20;
        return operator.applyAsInt(a, b);
    }

    public static void main(String[] args) {
        //  非lambda,先使用匿名内部类的写法调用该方法
        int i1 = calculateNum(new IntBinaryOperator() {
            public int applyAsInt(int left, int right) {
                return left + right;
            }
        });
        System.out.println(i1);

        //  lambda
        int i2 = calculateNum(
            (int left, int right)
            ->
            {
                return left + right;
            }
        );
        System.out.println(i2);
    }
}
interface IntBinaryOperator{
    int applyAsInt(int a,int b);
}

五 生活中的需求:forEach循环:普通、ArrayList、HashMap

import java.util.ArrayList;
import java.util.HashMap;
import java.util.stream.IntStream;

public class ExFor {
    public static void main(String[] args) {
        System.out.println("--------------------------普通的for循环-------------------------------------");
        IntStream.range(0,4).forEach(
            i
            ->
            System.out.println("循环变量i:"+i)
        );


        System.out.println("--------------------------arrayList-------------------------------------");
        int[] index = {0};
        ArrayList list = new ArrayList();
        list.add("a");
        list.add("b");
        list.add("c");
        list.forEach(
            e 
            -> 
            {
                index[0] = list.indexOf(e);
                System.out.print("循环变量i:"+index[0]+"\t");
                System.out.println("list里面的值:"+e);
            }
        );

        System.out.println("--------------------------hashmap-------------------------------------");
        HashMap<String, String> map = new HashMap();
        map.put("1", "张三");
        map.put("2", "李四");
        map.put("3", "王五");
        map.forEach(
            (k,v)
            -> 
            System.out.println("键:"+k+",值:"+v)
        );
    }
}

六 生活中的需求:接口只能声明一个抽象方法:@FunctionalInterface注解【boge】

/**
  * @FunctionalInterface 
  * 这是一个标志注解,被该注解修饰的接口只能声明一个抽象方法 
  */ 
@FunctionalInterface 
public interface UserService { 
    void show(); 
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在使用Lasso回归时,可以使用交叉验证来选择最佳的正则化参数lambda。一种方法是绘制lambda值的路径,该显示了每个lambda值的系数缩减程度。以下是如何绘制lambda值的路径: 1. 导入必要的库和数据 ``` python import numpy as np import pandas as pd from sklearn.linear_model import LassoCV import matplotlib.pyplot as plt # 导入数据 data = pd.read_csv('data.csv') X = data.drop('y', axis=1) y = data['y'] ``` 2. 拟合Lasso模型并计算系数缩减程度 ``` python # 创建LassoCV对象 lasso = LassoCV(normalize=True, cv=10) # 拟合Lasso模型 lasso.fit(X, y) # 计算系数缩减程度 alphas = lasso.alphas_ coefs = lasso.coef_path_ neg_log_alphas = -np.log10(alphas) # 绘制lambda值的路径 plt.figure(figsize=(10, 6)) plt.plot(neg_log_alphas, coefs.T) plt.xlabel('-log10(alpha)') plt.ylabel('coefficients') plt.title('Lasso Path') plt.axis('tight') plt.show() ``` 在这个中,x轴是-log10(alpha),y轴是系数。每条线表示一个特征的系数随lambda值的变化情况。lambda值越小,系数越倾向于缩减为0。因此,在中找到最小的alpha值,它对应的是系数缩减程度最强的lambda值。 ### 回答2: Lasso回归是一种常用于特征选择和模型建立的线性回归方法,lambda是其关键参数,用于控制变量选择的程度。 在Lasso回归中,当lambda的取值较小时,Lasso模型会更倾向于选择更多的变量,即保留更多的特征。当lambda的取值较大时,Lasso模型会更倾向于选择较少的变量,即更加倾向于将某些特征的系数设定为0。这可以通过Lasso回归系数缩减路径来可视化。 Lasso回归系数缩减路径是一种描述Lasso模型在不同lambda取值下,特征系数随着lambda的变化而变化的图形。横轴表示lambda的取值,纵轴表示特征系数的取值。 通常,lambda值较小的时候,特征系数呈现较大的绝对值;而lambda值较大的时候,特征系数会趋向于0。因此,通过观察Lasso lambda选值,可以看出在哪个lambda值附近,特征系数开始显著地变为0,从而可以确定哪些特征对模型的预测能力贡献较小,可以进行特征选择以提高模型的解释能力和泛化能力。 在应用Lasso回归模型时,我们可以根据需求选择合适的lambda值。如果希望保留更多的特征,可以选择较小的lambda值;如果希望进行特征选择,可以选择较大的lambda值。通过分析Lasso lambda选值,我们可以更好地了解Lasso回归模型在不同lambda取值下的特性,有助于选择最优的lambda值以获得更好的模型结果。 ### 回答3: Lasso回归是一种常用的特征选择方法,通过对模型加入L1正则化项约束来实现特征的稀疏性,同时进行变量选择。在Lasso回归中,选择适当的lambda值是非常重要的,因为它控制了正则化项的强度。 Lasso lambda选值是一种用于选择最佳lambda值的图形表示方法。中的横轴代表不同的lambda值,纵轴上表示的是模型的性能指标。我们可以通过观察该,选择合适的lambda值。 在Lasso lambda选值中,通常有两种常见的曲线:纵轴为残差平方和(RSS)或平均均方误差(MSE)的曲线,以及纵轴为非零系数个数的曲线。 对于残差平方和曲线,我们可以选择使得MSE最小的lambda值。在开始的时候,lambda较小,模型的复杂度较高,此时MSE逐渐减小。当lambda超过某个值后,MSE开始出现平稳或微小的增加,此时我们可以选择一个较小的lambda值作为最优lambda,以平衡模型的拟合度和简洁度。 而对于非零系数个数曲线,则是用于帮助我们选择特征的数量。在开始的时候,lambda较大,模型的稀疏性较高,非零系数个数为0。随着lambda的减小,非零系数个数逐渐增加,直到出现一个平稳或微小波动,此时我们可以选择一个较大的lambda值作为最优lambda,以实现较好的特征选择效果。 综上所述,Lasso lambda选值是用于选择最佳lambda值的一个重要工具。根据不同的需求,我们可以选择合适的lambda值来平衡模型的性能和模型的简约性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值