Skip to content

Commit

Permalink
formatted Python modules from the internal repository using autopep8
Browse files Browse the repository at this point in the history
  • Loading branch information
gfursin committed Dec 8, 2024
1 parent 80959de commit b3c0005
Show file tree
Hide file tree
Showing 9 changed files with 650 additions and 582 deletions.
30 changes: 13 additions & 17 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -13,28 +13,31 @@

[Collective Knowledge (CK, CM, CM4MLOps, CM4MLPerf and CMX)](https://cKnowledge.org)
is an educational community project to learn how to run AI, ML and other emerging workloads
in the most efficient and cost-effective way across diverse models, data sets, software and hardware.
in the most efficient and cost-effective way across diverse models, data sets, software and hardware:
[ [white paper](https://arxiv.org/abs/2406.16791) ].

It includes the following sub-projects.

### Collective Mind (CM)

[Collective Mind (CM)](https://github.com/mlcommons/ck/tree/master/cm) -
a very lightweight Python-based framework with a unified CLI, Python API and minimal dependencies
intended to help researchers and engineers automate their repetitive, tedious and time-consuming tasks
to build, run, benchmark and optimize AI, ML and other applications and systems
across diverse and continuously changing models, data, software and hardware.
The [Collective Mind framework](https://github.com/mlcommons/ck/tree/master/cm)
is a lightweight, Python-based toolset featuring
a unified command-line interface (CLI), Python API, and minimal dependencies.
It is designed to assist researchers and engineers in automating repetitive, time-consuming
tasks such as building, running, benchmarking, and optimizing AI, machine learning,
and other applications across diverse and continuously changing models, data, software and hardware.

Collective Mind is continuously enhanced through public and private CM4* Git repositories,
which serve as the unified interface for various collections of reusable automations and artifacts.
Collective Mind is continuously enhanced through public and private Git repositories
with CM automation recipes and artifacts accessible via unified CM interface.

The CM architecture diagram is available for viewing
[here](https://github.com/mlcommons/ck/tree/master/docs/specs/cm-diagram-v3.5.1.png).

### Collective Mind repositories
### Notable Collective Mind repositories

#### CM4MLOps

[CM4MLOPS repository powered by CM](https://github.com/mlcommons/cm4mlops) -
[CM4MLOPS repository powered by CM](https://github.com/mlcommons/ck/tree/master/cm-mlops) -
a collection of portable, extensible and technology-agnostic automation recipes
with a common CLI and Python API (CM scripts) to unify and automate
all the manual steps required to compose, run, benchmark and optimize complex ML/AI applications
Expand Down Expand Up @@ -121,13 +124,6 @@ based on user feedback. Follow the project's progress [here]( https://github.com

* [Grigori Fursin](https://cKnowledge.org/gfursin) (FlexAI, cTuning)

## Maintainers

* Collective Mind (CM): [Grigori Fursin](https://cKnowledge.org/gfursin)
* CM4MLOps repository: [Arjun Suresh](https://github.com/arjunsuresh) and [Anandhu Sooraj](https://github.com/anandhu-eng)
* CMX (the next generation of CM and CM4MLOps): [Grigori Fursin](https://cKnowledge.org/gfursin)


## Citing Collective Mind and Collective Knowledge

If you found the CM automation framework helpful, kindly reference this article:
Expand Down
2 changes: 1 addition & 1 deletion cm-mlops/README.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
**This repository is archived. In April 2024, we have separated this CM repo from the CM framework
and moved it to a [standalone mlcommons@cm4mlops repository](https://github.com/mlcommons/cm4mlops/tree/dev)
and moved it to a [standalone mlcommons@cm4mlops repository](https://github.com/mlcommons/cm4mlops)
following the suggesion from our users and MLCommons members.**

We keep this directory for backwards compatibility to let users reproduce past projects relying on this repository.
3 changes: 3 additions & 0 deletions cm/CHANGES.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,6 @@
## V3.5.1.1
- formatted Python modules from the internal repository using autopep8

## V3.5.1
- added Collective Mind architecture diagram:
https://github.com/mlcommons/ck/tree/master/docs/specs/cm-diagram-v3.5.1.png
Expand Down
76 changes: 42 additions & 34 deletions cm/cmind/repo/automation/automation/module.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@
from cmind.automation import Automation
from cmind import utils


class CAutomation(Automation):
"""
CM "automation" automation actions
Expand Down Expand Up @@ -35,12 +36,12 @@ def print_input(self, i):
"""

import json
print (json.dumps(i, indent=2))

return {'return':0}
print(json.dumps(i, indent=2))

return {'return': 0}

############################################################

def add(self, i):
"""
Add CM automation.
Expand All @@ -66,36 +67,40 @@ def add(self, i):

console = i.get('out') == 'con'

parsed_artifact = i.get('parsed_artifact',[])
parsed_artifact = i.get('parsed_artifact', [])

artifact_obj = parsed_artifact[0] if len(parsed_artifact)>0 else ('','')
artifact_obj = parsed_artifact[0] if len(
parsed_artifact) > 0 else ('', '')

module_name = 'module.py'

tags_list = utils.convert_tags_to_list(i)
if 'automation' not in tags_list: tags_list.append('automation')
if 'automation' not in tags_list:
tags_list.append('automation')

# Add placeholder (use common action)
i['out']='con'
i['common']=True
i['out'] = 'con'
i['common'] = True

i['meta']={'automation_alias':self.meta['alias'],
'automation_uid':self.meta['uid'],
'tags':tags_list}
i['meta'] = {'automation_alias': self.meta['alias'],
'automation_uid': self.meta['uid'],
'tags': tags_list}

if 'tags' in i: del(i['tags'])
if 'tags' in i:
del (i['tags'])

automation = i['automation']
if automation!='.' and ',' not in automation:
if automation != '.' and ',' not in automation:
i['automation'] = automation + ',' + self.meta['uid']

r_obj=self.cmind.access(i)
if r_obj['return']>0: return r_obj
r_obj = self.cmind.access(i)
if r_obj['return'] > 0:
return r_obj

new_automation_path = r_obj['path']

if console:
print ('Created automation in {}'.format(new_automation_path))
print('Created automation in {}'.format(new_automation_path))

# Create Python module holder
module_holder_path = new_automation_path
Expand All @@ -106,12 +111,12 @@ def add(self, i):
# Copy module files
for f in ['module_dummy.py']:
f1 = os.path.join(self.path, f)
f2 = os.path.join(new_automation_path, f.replace('_dummy',''))
f2 = os.path.join(new_automation_path, f.replace('_dummy', ''))

if console:
print (' * Copying {} to {}'.format(f1, f2))
print(' * Copying {} to {}'.format(f1, f2))

shutil.copyfile(f1,f2)
shutil.copyfile(f1, f2)

return r_obj

Expand All @@ -137,33 +142,37 @@ def add_cmx(self, i):

# Prepare to call common function
r = utils.process_input(i)
if r['return']>0: return r
if r['return'] > 0:
return r

# Take only out from original control
i['control']={'out':i['control']['out'],
'common':True}
i['control'] = {'out': i['control']['out'],
'common': True}

tags_list = utils.convert_tags_to_list(i)
if 'automation' not in tags_list: tags_list.append('automation')
if 'automation' not in tags_list:
tags_list.append('automation')

i['meta']={'automation_alias':self.meta['alias'],
'automation_uid':self.meta['uid'],
'tags':tags_list}
i['meta'] = {'automation_alias': self.meta['alias'],
'automation_uid': self.meta['uid'],
'tags': tags_list}

if 'tags' in i: del(i['tags'])
if 'tags' in i:
del (i['tags'])

# Use yaml by default
if 'yaml' not in i:
i['yaml'] = True

# Pass to common action
r_obj = self.cmind.x(i)
if r_obj['return']>0: return r_obj
if r_obj['return'] > 0:
return r_obj

new_automation_path = r_obj['path']

if console:
print ('Created automation in {}'.format(new_automation_path))
print('Created automation in {}'.format(new_automation_path))

module_name = 'modulex.py'

Expand All @@ -176,18 +185,17 @@ def add_cmx(self, i):
# Copy module files
for f in ['modulex_dummy.py']:
f1 = os.path.join(self.path, f)
f2 = os.path.join(new_automation_path, f.replace('_dummy',''))
f2 = os.path.join(new_automation_path, f.replace('_dummy', ''))

if console:
print (' * Copying {} to {}'.format(f1, f2))
print(' * Copying {} to {}'.format(f1, f2))

shutil.copyfile(f1,f2)
shutil.copyfile(f1, f2)

return r_obj



############################################################

def doc(self, i):
"""
Add CM automation.
Expand Down
Loading

0 comments on commit b3c0005

Please sign in to comment.