Completed
Push — master ( 980041...30b693 )
by
unknown
10s
created

VectorizerRegistry   A

Complexity

Total Complexity 1

Size/Duplication

Total Lines 9
Duplicated Lines 0 %
Metric Value
wmc 1
dl 0
loc 9
rs 10

1 Method

Rating   Name   Duplication   Size   Complexity  
A __init__() 0 3 1
1
from six.moves import UserDict
0 ignored issues
show
Coding Style introduced by
This module should have a docstring.

The coding style of this project requires that you add a docstring to this code element. Below, you find an example for methods:

class SomeClass:
    def some_method(self):
        """Do x and return foo."""

If you would like to know more about docstrings, we recommend to read PEP-257: Docstring Conventions.

Loading history...
Configuration introduced by
The import six.moves could not be resolved.

This can be caused by one of the following:

1. Missing Dependencies

This error could indicate a configuration issue of Pylint. Make sure that your libraries are available by adding the necessary commands.

# .scrutinizer.yml
before_commands:
    - sudo pip install abc # Python2
    - sudo pip3 install abc # Python3
Tip: We are currently not using virtualenv to run pylint, when installing your modules make sure to use the command for the correct version.

2. Missing __init__.py files

This error could also result from missing __init__.py files in your module folders. Make sure that you place one file in each sub-folder.

Loading history...
2
from functools import partial
3
4
from topik.singleton_registry import _base_register_decorator
5
6
7
# This subclass serves to establish a new singleton instance of functions
8
#    for this particular step in topic modeling.  No implementation necessary.
9
class VectorizerRegistry(UserDict, object):
10
    """Uses Borg design pattern.  Core idea is that there is a global registry for each step's
11
    possible methods
12
    """
13
    __shared_state = {}
14
15
    def __init__(self, *args, **kwargs):
16
        self.__dict__ = self.__shared_state
17
        super(VectorizerRegistry, self).__init__(*args, **kwargs)
18
19
20
# a nicer, more pythonic handle to our singleton instance
21
registered_vectorizers = VectorizerRegistry()
0 ignored issues
show
Coding Style Naming introduced by
The name registered_vectorizers does not conform to the constant naming conventions ((([A-Z_][A-Z0-9_]*)|(__.*__))$).

This check looks for invalid names for a range of different identifiers.

You can set regular expressions to which the identifiers must conform if the defaults do not match your requirements.

If your project includes a Pylint configuration file, the settings contained in that file take precedence.

To find out more about Pylint, please refer to their site.

Loading history...
22
23
# fill in the registration function
24
register = partial(_base_register_decorator, registered_vectorizers)
0 ignored issues
show
Coding Style Naming introduced by
The name register does not conform to the constant naming conventions ((([A-Z_][A-Z0-9_]*)|(__.*__))$).

This check looks for invalid names for a range of different identifiers.

You can set regular expressions to which the identifiers must conform if the defaults do not match your requirements.

If your project includes a Pylint configuration file, the settings contained in that file take precedence.

To find out more about Pylint, please refer to their site.

Loading history...
25
26
27
def vectorize(corpus, method="bag_of_words", **kwargs):
28
    """Represent documents as vectors in word-space.
29
30
    Note: bag-of-words model is implicitly used when no additional
31
    vectorization is called.
32
    """
33
    return registered_vectorizers[method](corpus, **kwargs)
34