0

我正在尝试将受歧视的工会作为成员进行记录,但是在制作“API”记录后,我只能访问工会而不是我放入其中的内容....

type DefaultExpr = Expr<int -> Ref<int> -> int -> unit>
type Option1Expr = Expr<int -> Ref<int> -> int -> Ref<int> -> unit>
type Option2Expr = Expr<int -> Ref<int> -> int -> Ref<int> -> Ref<int> -> unit>

module Identityless =
    type DefaultExpr = Expr<int -> Ref<int> -> unit>
    type Option1Expr = Expr<int -> Ref<int> -> Ref<int> -> unit>
    type Option2Expr = Expr<int -> Ref<int> -> Ref<int> -> Ref<int> -> unit>

type DefaultU =
    | ID of DefaultExpr
    | NoID of Identityless.DefaultExpr

type Option1U =
    | ID of Option1Expr
    | NoID of Identityless.Option1Expr

type Option2U =
    | ID of Option2Expr
    | NoID of Identityless.Option2Expr


type API =
    {
        Default :   DefaultU
        Option1 :   Option1U
        Option2 :   Option2U
    }


module InclusiveSum =

    let private Default (scan_op:IScanOp) =
        <@ fun (input:int) (output:Ref<int>) -> () @>

    let private Option1 (scan_op:IScanOp) =
        <@ fun (input:int) (output:Ref<int>) (block_aggregate:Ref<int>) -> () @>

    let private Option2 (scan_op:IScanOp) =
        <@ fun (input:int) (output:Ref<int>) (block_aggregate:Ref<int>) (block_prefix_callback_op:Ref<int>) -> () @>


    let api scan_op =
        {
            Default = scan_op |> Default |> DefaultU.NoID                       
            Option1 = scan_op |> Option1 |> Option1U.NoID                 
            Option2 = scan_op |> Option2 |> Option2U.NoID
        }

所以当我制作我的api时......

let foo = InclusiveSum.api (scan_op ADD 0)

我希望 foo.Default 给我我的 DefaultExpr 使用

在阅读了一些帖子之后,我想我必须回去做一些模式匹配,这会破坏这里的整个目的......

那么如何让我的 DefaultExpr 退出 API 记录呢?

4

1 回答 1

0

由于类型是API.Default可区​​分的联合类型Default1U,因此使用 API.Default 中的值的唯一(*)方法是通过模式匹配。所以你需要类似的东西:

match foo with 
  ID e -> ...
| NoId e -> ...

没有其他方法(*)。

(*) 忽略反射

于 2014-03-08T09:54:04.537 回答